@liteforge/modal 0.2.0 → 1.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/dist/index.d.ts +3 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1 -0
- package/dist/index.js.map +1 -1
- package/dist/modal.d.ts.map +1 -1
- package/dist/modal.js +2 -0
- package/dist/modal.js.map +1 -1
- package/dist/plugin.d.ts +25 -0
- package/dist/plugin.d.ts.map +1 -0
- package/dist/plugin.js +33 -0
- package/dist/plugin.js.map +1 -0
- package/dist/presets.d.ts.map +1 -1
- package/dist/presets.js +37 -9
- package/dist/presets.js.map +1 -1
- package/dist/provider.d.ts +1 -1
- package/dist/provider.d.ts.map +1 -1
- package/dist/provider.js +15 -8
- package/dist/provider.js.map +1 -1
- package/dist/styles.d.ts +7 -0
- package/dist/styles.d.ts.map +1 -1
- package/dist/styles.js +28 -0
- package/dist/styles.js.map +1 -1
- package/dist/types.d.ts +20 -0
- package/dist/types.d.ts.map +1 -1
- package/package.json +10 -3
package/dist/index.d.ts
CHANGED
|
@@ -2,5 +2,7 @@ export { createModal } from './modal.js';
|
|
|
2
2
|
export { ModalProvider } from './provider.js';
|
|
3
3
|
export { confirm, alert, prompt } from './presets.js';
|
|
4
4
|
export { injectDefaultStyles, resetStylesInjection } from './styles.js';
|
|
5
|
-
export type { ModalConfig, CreateModalOptions, ModalResult, ModalSize } from './types.js';
|
|
5
|
+
export type { ModalConfig, CreateModalOptions, ModalResult, ModalSize, ModalStyles, ModalClasses } from './types.js';
|
|
6
|
+
export { modalPlugin } from './plugin.js';
|
|
7
|
+
export type { ModalApi } from './plugin.js';
|
|
6
8
|
//# sourceMappingURL=index.d.ts.map
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AACzC,OAAO,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AAC9C,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,cAAc,CAAC;AACtD,OAAO,EAAE,mBAAmB,EAAE,oBAAoB,EAAE,MAAM,aAAa,CAAC;AACxE,YAAY,EAAE,WAAW,EAAE,kBAAkB,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,YAAY,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AACzC,OAAO,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AAC9C,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,cAAc,CAAC;AACtD,OAAO,EAAE,mBAAmB,EAAE,oBAAoB,EAAE,MAAM,aAAa,CAAC;AACxE,YAAY,EAAE,WAAW,EAAE,kBAAkB,EAAE,WAAW,EAAE,SAAS,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AACrH,OAAO,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAC1C,YAAY,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC"}
|
package/dist/index.js
CHANGED
|
@@ -2,4 +2,5 @@ export { createModal } from './modal.js';
|
|
|
2
2
|
export { ModalProvider } from './provider.js';
|
|
3
3
|
export { confirm, alert, prompt } from './presets.js';
|
|
4
4
|
export { injectDefaultStyles, resetStylesInjection } from './styles.js';
|
|
5
|
+
export { modalPlugin } from './plugin.js';
|
|
5
6
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AACzC,OAAO,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AAC9C,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,cAAc,CAAC;AACtD,OAAO,EAAE,mBAAmB,EAAE,oBAAoB,EAAE,MAAM,aAAa,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AACzC,OAAO,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AAC9C,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,cAAc,CAAC;AACtD,OAAO,EAAE,mBAAmB,EAAE,oBAAoB,EAAE,MAAM,aAAa,CAAC;AAExE,OAAO,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC"}
|
package/dist/modal.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"modal.d.ts","sourceRoot":"","sources":["../src/modal.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AACzC,OAAO,KAAK,EAAE,WAAW,EAAE,kBAAkB,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAI/E,MAAM,WAAW,UAAU;IACzB,EAAE,EAAE,MAAM,CAAC;IACX,OAAO,EAAE,QAAQ,CAAC,WAAW,CAAC,CAAC;IAC/B,SAAS,EAAE,MAAM,IAAI,CAAC;IACtB,MAAM,EAAE,UAAU,CAAC,OAAO,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC;IAC3C,IAAI,EAAE,MAAM,IAAI,CAAC;IACjB,KAAK,EAAE,MAAM,IAAI,CAAC;IAClB,MAAM,EAAE,MAAM,IAAI,CAAC;IACnB,OAAO,EAAE,MAAM,IAAI,CAAC;CACrB;AAwBD,eAAO,MAAM,aAAa,EAAE,GAAG,CAAC,UAAU,CAAoB,CAAC;AAE/D;;;GAGG;AACH,eAAO,MAAM,eAAe,EAAE,UAAU,CAAC,OAAO,MAAM,CAAC,MAAM,CAAC,CAAmB,CAAC;AA4BlF,wBAAgB,WAAW,CAAC,IAAI,EAAE,kBAAkB,GAAG,WAAW,
|
|
1
|
+
{"version":3,"file":"modal.d.ts","sourceRoot":"","sources":["../src/modal.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AACzC,OAAO,KAAK,EAAE,WAAW,EAAE,kBAAkB,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAI/E,MAAM,WAAW,UAAU;IACzB,EAAE,EAAE,MAAM,CAAC;IACX,OAAO,EAAE,QAAQ,CAAC,WAAW,CAAC,CAAC;IAC/B,SAAS,EAAE,MAAM,IAAI,CAAC;IACtB,MAAM,EAAE,UAAU,CAAC,OAAO,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC;IAC3C,IAAI,EAAE,MAAM,IAAI,CAAC;IACjB,KAAK,EAAE,MAAM,IAAI,CAAC;IAClB,MAAM,EAAE,MAAM,IAAI,CAAC;IACnB,OAAO,EAAE,MAAM,IAAI,CAAC;CACrB;AAwBD,eAAO,MAAM,aAAa,EAAE,GAAG,CAAC,UAAU,CAAoB,CAAC;AAE/D;;;GAGG;AACH,eAAO,MAAM,eAAe,EAAE,UAAU,CAAC,OAAO,MAAM,CAAC,MAAM,CAAC,CAAmB,CAAC;AA4BlF,wBAAgB,WAAW,CAAC,IAAI,EAAE,kBAAkB,GAAG,WAAW,CA+EjE"}
|
package/dist/modal.js
CHANGED
|
@@ -51,6 +51,8 @@ export function createModal(opts) {
|
|
|
51
51
|
closeOnBackdrop: cfg.closeOnBackdrop ?? true,
|
|
52
52
|
closeOnEsc: cfg.closeOnEsc ?? true,
|
|
53
53
|
unstyled: cfg.unstyled ?? false,
|
|
54
|
+
styles: cfg.styles ?? {},
|
|
55
|
+
classes: cfg.classes ?? {},
|
|
54
56
|
onOpen: cfg.onOpen ?? (() => { }),
|
|
55
57
|
onClose: cfg.onClose ?? (() => { }),
|
|
56
58
|
};
|
package/dist/modal.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"modal.js","sourceRoot":"","sources":["../src/modal.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"modal.js","sourceRoot":"","sources":["../src/modal.ts"],"names":[],"mappings":"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"}
|
package/dist/plugin.d.ts
ADDED
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @liteforge/modal — modalPlugin
|
|
3
|
+
*
|
|
4
|
+
* Wraps ModalProvider as a formal LiteForgePlugin.
|
|
5
|
+
* Inserts the modal root container next to the app target (not on body).
|
|
6
|
+
* Registers the modal API under the 'modal' key in the app context.
|
|
7
|
+
*/
|
|
8
|
+
import type { LiteForgePlugin } from '@liteforge/runtime';
|
|
9
|
+
import { createModal } from './modal.js';
|
|
10
|
+
import { confirm, alert, prompt } from './presets.js';
|
|
11
|
+
export interface ModalApi {
|
|
12
|
+
open: typeof createModal;
|
|
13
|
+
confirm: typeof confirm;
|
|
14
|
+
alert: typeof alert;
|
|
15
|
+
prompt: typeof prompt;
|
|
16
|
+
}
|
|
17
|
+
export declare function modalPlugin(options?: {
|
|
18
|
+
unstyled?: boolean;
|
|
19
|
+
}): LiteForgePlugin;
|
|
20
|
+
declare module '@liteforge/runtime' {
|
|
21
|
+
interface PluginRegistry {
|
|
22
|
+
modal: ModalApi;
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
//# sourceMappingURL=plugin.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"plugin.d.ts","sourceRoot":"","sources":["../src/plugin.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,KAAK,EAAE,eAAe,EAAiB,MAAM,oBAAoB,CAAC;AACzE,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAEzC,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,cAAc,CAAC;AAEtD,MAAM,WAAW,QAAQ;IACvB,IAAI,EAAE,OAAO,WAAW,CAAC;IACzB,OAAO,EAAE,OAAO,OAAO,CAAC;IACxB,KAAK,EAAE,OAAO,KAAK,CAAC;IACpB,MAAM,EAAE,OAAO,MAAM,CAAC;CACvB;AAED,wBAAgB,WAAW,CAAC,OAAO,CAAC,EAAE;IAAE,QAAQ,CAAC,EAAE,OAAO,CAAA;CAAE,GAAG,eAAe,CAyB7E;AAED,OAAO,QAAQ,oBAAoB,CAAC;IAClC,UAAU,cAAc;QACtB,KAAK,EAAE,QAAQ,CAAC;KACjB;CACF"}
|
package/dist/plugin.js
ADDED
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @liteforge/modal — modalPlugin
|
|
3
|
+
*
|
|
4
|
+
* Wraps ModalProvider as a formal LiteForgePlugin.
|
|
5
|
+
* Inserts the modal root container next to the app target (not on body).
|
|
6
|
+
* Registers the modal API under the 'modal' key in the app context.
|
|
7
|
+
*/
|
|
8
|
+
import { createModal } from './modal.js';
|
|
9
|
+
import { ModalProvider } from './provider.js';
|
|
10
|
+
import { confirm, alert, prompt } from './presets.js';
|
|
11
|
+
export function modalPlugin(options) {
|
|
12
|
+
return {
|
|
13
|
+
name: 'modal',
|
|
14
|
+
install(context) {
|
|
15
|
+
const api = { open: createModal, confirm, alert, prompt };
|
|
16
|
+
context.provide('modal', api);
|
|
17
|
+
// Insert container next to #app, not on body
|
|
18
|
+
const container = document.createElement('div');
|
|
19
|
+
container.id = 'liteforge-modal-root';
|
|
20
|
+
const parent = context.target.parentElement;
|
|
21
|
+
const next = context.target.nextSibling;
|
|
22
|
+
if (parent) {
|
|
23
|
+
parent.insertBefore(container, next);
|
|
24
|
+
}
|
|
25
|
+
const provider = options?.unstyled ? ModalProvider({ unstyled: true }) : ModalProvider();
|
|
26
|
+
container.appendChild(provider);
|
|
27
|
+
return () => {
|
|
28
|
+
container.parentNode?.removeChild(container);
|
|
29
|
+
};
|
|
30
|
+
},
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
//# sourceMappingURL=plugin.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"plugin.js","sourceRoot":"","sources":["../src/plugin.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAGH,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AACzC,OAAO,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AAC9C,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,cAAc,CAAC;AAStD,MAAM,UAAU,WAAW,CAAC,OAAgC;IAC1D,OAAO;QACL,IAAI,EAAE,OAAO;QACb,OAAO,CAAC,OAAsB;YAC5B,MAAM,GAAG,GAAa,EAAE,IAAI,EAAE,WAAW,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC;YACpE,OAAO,CAAC,OAAO,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC;YAE9B,6CAA6C;YAC7C,MAAM,SAAS,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;YAChD,SAAS,CAAC,EAAE,GAAG,sBAAsB,CAAC;YAEtC,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,aAAa,CAAC;YAC5C,MAAM,IAAI,GAAG,OAAO,CAAC,MAAM,CAAC,WAAW,CAAC;YACxC,IAAI,MAAM,EAAE,CAAC;gBACX,MAAM,CAAC,YAAY,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;YACvC,CAAC;YAED,MAAM,QAAQ,GAAG,OAAO,EAAE,QAAQ,CAAC,CAAC,CAAC,aAAa,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC,aAAa,EAAE,CAAC;YACzF,SAAS,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC;YAEhC,OAAO,GAAG,EAAE;gBACV,SAAS,CAAC,UAAU,EAAE,WAAW,CAAC,SAAS,CAAC,CAAC;YAC/C,CAAC,CAAC;QACJ,CAAC;KACF,CAAC;AACJ,CAAC"}
|
package/dist/presets.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"presets.d.ts","sourceRoot":"","sources":["../src/presets.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;
|
|
1
|
+
{"version":3,"file":"presets.d.ts","sourceRoot":"","sources":["../src/presets.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAmC9C,wBAAgB,OAAO,CACrB,OAAO,EAAE,MAAM,EACf,MAAM,CAAC,EAAE,OAAO,CAAC,WAAW,CAAC,GAC5B,OAAO,CAAC,OAAO,CAAC,CAsDlB;AAID,wBAAgB,KAAK,CACnB,OAAO,EAAE,MAAM,EACf,MAAM,CAAC,EAAE,OAAO,CAAC,WAAW,CAAC,GAC5B,OAAO,CAAC,IAAI,CAAC,CAwCf;AAID,wBAAgB,MAAM,CACpB,OAAO,EAAE,MAAM,EACf,YAAY,CAAC,EAAE,MAAM,EACrB,MAAM,CAAC,EAAE,OAAO,CAAC,WAAW,CAAC,GAC5B,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,CA+DxB"}
|
package/dist/presets.js
CHANGED
|
@@ -1,4 +1,31 @@
|
|
|
1
1
|
import { createModal } from './modal.js';
|
|
2
|
+
// ─── Shared button/input styles using modal CSS variables ────
|
|
3
|
+
function styleBtn(btn, variant) {
|
|
4
|
+
btn.style.cssText = [
|
|
5
|
+
'display:inline-flex;align-items:center;justify-content:center',
|
|
6
|
+
'padding:6px 16px;border-radius:6px;font-size:14px;font-weight:500',
|
|
7
|
+
'cursor:pointer;transition:opacity 0.15s;border:none',
|
|
8
|
+
variant === 'primary'
|
|
9
|
+
? 'background:#4f46e5;color:#fff'
|
|
10
|
+
: 'background:transparent;color:var(--lf-modal-header-color);border:1px solid rgba(128,128,128,0.35)',
|
|
11
|
+
].join(';');
|
|
12
|
+
btn.addEventListener('mouseenter', () => { btn.style.opacity = '0.85'; });
|
|
13
|
+
btn.addEventListener('mouseleave', () => { btn.style.opacity = '1'; });
|
|
14
|
+
}
|
|
15
|
+
function styleInput(input) {
|
|
16
|
+
input.style.cssText = [
|
|
17
|
+
'width:100%;box-sizing:border-box',
|
|
18
|
+
'padding:8px 10px;border-radius:6px;font-size:14px',
|
|
19
|
+
'background:rgba(0,0,0,0.25);color:var(--lf-modal-header-color)',
|
|
20
|
+
'border:1px solid rgba(128,128,128,0.35)',
|
|
21
|
+
'outline:none;margin-bottom:16px',
|
|
22
|
+
].join(';');
|
|
23
|
+
input.addEventListener('focus', () => { input.style.borderColor = '#4f46e5'; });
|
|
24
|
+
input.addEventListener('blur', () => { input.style.borderColor = 'rgba(128,128,128,0.35)'; });
|
|
25
|
+
}
|
|
26
|
+
function styleMsg(msg) {
|
|
27
|
+
msg.style.cssText = 'margin:0 0 20px;color:var(--lf-modal-body-color);font-size:14px;line-height:1.6';
|
|
28
|
+
}
|
|
2
29
|
// ─── confirm() ───────────────────────────────────────────────
|
|
3
30
|
export function confirm(message, config) {
|
|
4
31
|
return new Promise((resolve) => {
|
|
@@ -15,14 +42,14 @@ export function confirm(message, config) {
|
|
|
15
42
|
component: () => {
|
|
16
43
|
const wrapper = document.createElement('div');
|
|
17
44
|
const msg = document.createElement('p');
|
|
18
|
-
msg
|
|
45
|
+
styleMsg(msg);
|
|
19
46
|
msg.textContent = message;
|
|
20
47
|
wrapper.appendChild(msg);
|
|
21
48
|
const actions = document.createElement('div');
|
|
22
49
|
actions.style.cssText = 'display:flex;gap:8px;justify-content:flex-end';
|
|
23
50
|
const cancelBtn = document.createElement('button');
|
|
24
51
|
cancelBtn.textContent = 'Cancel';
|
|
25
|
-
cancelBtn
|
|
52
|
+
styleBtn(cancelBtn, 'secondary');
|
|
26
53
|
cancelBtn.addEventListener('click', () => {
|
|
27
54
|
if (!resolved) {
|
|
28
55
|
resolved = true;
|
|
@@ -32,7 +59,7 @@ export function confirm(message, config) {
|
|
|
32
59
|
});
|
|
33
60
|
const okBtn = document.createElement('button');
|
|
34
61
|
okBtn.textContent = 'OK';
|
|
35
|
-
okBtn
|
|
62
|
+
styleBtn(okBtn, 'primary');
|
|
36
63
|
okBtn.addEventListener('click', () => {
|
|
37
64
|
if (!resolved) {
|
|
38
65
|
resolved = true;
|
|
@@ -73,14 +100,14 @@ export function alert(message, config) {
|
|
|
73
100
|
component: () => {
|
|
74
101
|
const wrapper = document.createElement('div');
|
|
75
102
|
const msg = document.createElement('p');
|
|
76
|
-
msg
|
|
103
|
+
styleMsg(msg);
|
|
77
104
|
msg.textContent = message;
|
|
78
105
|
wrapper.appendChild(msg);
|
|
79
106
|
const actions = document.createElement('div');
|
|
80
107
|
actions.style.cssText = 'display:flex;justify-content:flex-end';
|
|
81
108
|
const okBtn = document.createElement('button');
|
|
82
109
|
okBtn.textContent = 'OK';
|
|
83
|
-
okBtn
|
|
110
|
+
styleBtn(okBtn, 'primary');
|
|
84
111
|
okBtn.addEventListener('click', () => {
|
|
85
112
|
modal.close();
|
|
86
113
|
modal.destroy();
|
|
@@ -110,19 +137,20 @@ export function prompt(message, defaultValue, config) {
|
|
|
110
137
|
component: () => {
|
|
111
138
|
const wrapper = document.createElement('div');
|
|
112
139
|
const msg = document.createElement('p');
|
|
113
|
-
msg.style.
|
|
140
|
+
msg.style.cssText = 'margin:0 0 12px;color:var(--lf-modal-body-color);font-size:14px';
|
|
114
141
|
msg.textContent = message;
|
|
115
142
|
wrapper.appendChild(msg);
|
|
116
143
|
const input = document.createElement('input');
|
|
117
144
|
input.type = 'text';
|
|
118
145
|
input.value = defaultValue ?? '';
|
|
119
|
-
input
|
|
146
|
+
styleInput(input);
|
|
147
|
+
setTimeout(() => input.focus(), 50);
|
|
120
148
|
wrapper.appendChild(input);
|
|
121
149
|
const actions = document.createElement('div');
|
|
122
150
|
actions.style.cssText = 'display:flex;gap:8px;justify-content:flex-end';
|
|
123
151
|
const cancelBtn = document.createElement('button');
|
|
124
152
|
cancelBtn.textContent = 'Cancel';
|
|
125
|
-
cancelBtn
|
|
153
|
+
styleBtn(cancelBtn, 'secondary');
|
|
126
154
|
cancelBtn.addEventListener('click', () => {
|
|
127
155
|
if (!resolved) {
|
|
128
156
|
resolved = true;
|
|
@@ -133,7 +161,7 @@ export function prompt(message, defaultValue, config) {
|
|
|
133
161
|
});
|
|
134
162
|
const okBtn = document.createElement('button');
|
|
135
163
|
okBtn.textContent = 'OK';
|
|
136
|
-
okBtn
|
|
164
|
+
styleBtn(okBtn, 'primary');
|
|
137
165
|
okBtn.addEventListener('click', () => {
|
|
138
166
|
if (!resolved) {
|
|
139
167
|
resolved = true;
|
package/dist/presets.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"presets.js","sourceRoot":"","sources":["../src/presets.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAGzC,gEAAgE;AAEhE,MAAM,UAAU,OAAO,CACrB,OAAe,EACf,MAA6B;IAE7B,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE;QAC7B,IAAI,QAAQ,GAAG,KAAK,CAAC;QACrB,MAAM,KAAK,GAAG,WAAW,CAAC;YACxB,MAAM,EAAE;gBACN,KAAK,EAAE,SAAS;gBAChB,IAAI,EAAE,IAAI;gBACV,QAAQ,EAAE,KAAK;gBACf,eAAe,EAAE,KAAK;gBACtB,UAAU,EAAE,KAAK;gBACjB,GAAG,MAAM;aACV;YACD,SAAS,EAAE,GAAG,EAAE;gBACd,MAAM,OAAO,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;gBAE9C,MAAM,GAAG,GAAG,QAAQ,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC;gBACxC,
|
|
1
|
+
{"version":3,"file":"presets.js","sourceRoot":"","sources":["../src/presets.ts"],"names":[],"mappings":"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"}
|
package/dist/provider.d.ts
CHANGED
package/dist/provider.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"provider.d.ts","sourceRoot":"","sources":["../src/provider.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"provider.d.ts","sourceRoot":"","sources":["../src/provider.ts"],"names":[],"mappings":"AA+HA,wBAAgB,aAAa,CAAC,IAAI,CAAC,EAAE;IAAE,QAAQ,CAAC,EAAE,OAAO,CAAA;CAAE,GAAG,WAAW,CA+BxE"}
|
package/dist/provider.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { effect } from '@liteforge/core';
|
|
2
2
|
import { modalRegistry, registryVersion } from './modal.js';
|
|
3
|
-
import { injectDefaultStyles } from './styles.js';
|
|
3
|
+
import { injectDefaultStyles, STYLE_TOKEN_MAP } from './styles.js';
|
|
4
4
|
// ─── Focus trap helpers ──────────────────────────────────────
|
|
5
5
|
const FOCUSABLE_SELECTOR = 'a[href], button:not([disabled]), input:not([disabled]), select:not([disabled]), textarea:not([disabled]), [tabindex]:not([tabindex="-1"])';
|
|
6
6
|
function getFocusableElements(el) {
|
|
@@ -31,23 +31,30 @@ function trapFocus(modalEl) {
|
|
|
31
31
|
}
|
|
32
32
|
// ─── Render a single modal overlay ──────────────────────────
|
|
33
33
|
function renderOverlay(entry, onRemove) {
|
|
34
|
-
const size = entry.options
|
|
34
|
+
const { size, styles, classes } = entry.options;
|
|
35
|
+
const cls = classes;
|
|
35
36
|
const overlay = document.createElement('div');
|
|
36
|
-
overlay.className =
|
|
37
|
+
overlay.className = `${cls.overlay ?? 'lf-modal-overlay'} lf-modal-overlay--${size}`;
|
|
38
|
+
// Apply per-instance style token overrides (CSS vars inherit into children)
|
|
39
|
+
for (const [key, cssVar] of STYLE_TOKEN_MAP) {
|
|
40
|
+
const value = styles[key];
|
|
41
|
+
if (value !== undefined)
|
|
42
|
+
overlay.style.setProperty(cssVar, value);
|
|
43
|
+
}
|
|
37
44
|
const modalEl = document.createElement('div');
|
|
38
|
-
modalEl.className = 'lf-modal';
|
|
45
|
+
modalEl.className = cls.modal ?? 'lf-modal';
|
|
39
46
|
modalEl.setAttribute('role', 'dialog');
|
|
40
47
|
modalEl.setAttribute('aria-modal', 'true');
|
|
41
48
|
// Header
|
|
42
49
|
const header = document.createElement('div');
|
|
43
|
-
header.className = 'lf-modal-header';
|
|
50
|
+
header.className = cls.header ?? 'lf-modal-header';
|
|
44
51
|
const titleEl = document.createElement('span');
|
|
45
|
-
titleEl.className = 'lf-modal-title';
|
|
52
|
+
titleEl.className = cls.title ?? 'lf-modal-title';
|
|
46
53
|
titleEl.textContent = entry.options.title;
|
|
47
54
|
header.appendChild(titleEl);
|
|
48
55
|
if (entry.options.closable) {
|
|
49
56
|
const closeBtn = document.createElement('button');
|
|
50
|
-
closeBtn.className = 'lf-modal-close';
|
|
57
|
+
closeBtn.className = cls.close ?? 'lf-modal-close';
|
|
51
58
|
closeBtn.textContent = '✕';
|
|
52
59
|
closeBtn.setAttribute('aria-label', 'Close');
|
|
53
60
|
closeBtn.addEventListener('click', () => entry.close());
|
|
@@ -56,7 +63,7 @@ function renderOverlay(entry, onRemove) {
|
|
|
56
63
|
modalEl.appendChild(header);
|
|
57
64
|
// Body
|
|
58
65
|
const body = document.createElement('div');
|
|
59
|
-
body.className = 'lf-modal-body';
|
|
66
|
+
body.className = cls.body ?? 'lf-modal-body';
|
|
60
67
|
body.appendChild(entry.contentFn());
|
|
61
68
|
modalEl.appendChild(body);
|
|
62
69
|
overlay.appendChild(modalEl);
|
package/dist/provider.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"provider.js","sourceRoot":"","sources":["../src/provider.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AACzC,OAAO,EAAE,aAAa,EAAE,eAAe,EAAE,MAAM,YAAY,CAAC;AAC5D,OAAO,EAAE,mBAAmB,EAAE,MAAM,aAAa,CAAC;
|
|
1
|
+
{"version":3,"file":"provider.js","sourceRoot":"","sources":["../src/provider.ts"],"names":[],"mappings":"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"}
|
package/dist/styles.d.ts
CHANGED
|
@@ -4,6 +4,13 @@
|
|
|
4
4
|
* Minimal, clean default styles using CSS variables.
|
|
5
5
|
* Injected once when the first modal provider is created (unless unstyled: true).
|
|
6
6
|
*/
|
|
7
|
+
import type { ModalStyles } from './types.js';
|
|
8
|
+
/**
|
|
9
|
+
* Maps ModalStyles keys to their CSS variable names.
|
|
10
|
+
* Applied as inline styles on the overlay element so each modal instance
|
|
11
|
+
* can override the global :root variables without affecting other modals.
|
|
12
|
+
*/
|
|
13
|
+
export declare const STYLE_TOKEN_MAP: ReadonlyArray<readonly [keyof ModalStyles, string]>;
|
|
7
14
|
/**
|
|
8
15
|
* Inject default styles into the document head.
|
|
9
16
|
* Called automatically when the first ModalProvider is created (unless unstyled: true).
|
package/dist/styles.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"styles.d.ts","sourceRoot":"","sources":["../src/styles.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;
|
|
1
|
+
{"version":3,"file":"styles.d.ts","sourceRoot":"","sources":["../src/styles.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAE9C;;;;GAIG;AACH,eAAO,MAAM,eAAe,EAAE,aAAa,CAAC,SAAS,CAAC,MAAM,WAAW,EAAE,MAAM,CAAC,CAStE,CAAA;AAqJV;;;GAGG;AACH,wBAAgB,mBAAmB,IAAI,IAAI,CAU1C;AAED;;GAEG;AACH,wBAAgB,oBAAoB,IAAI,IAAI,CAM3C"}
|
package/dist/styles.js
CHANGED
|
@@ -4,6 +4,21 @@
|
|
|
4
4
|
* Minimal, clean default styles using CSS variables.
|
|
5
5
|
* Injected once when the first modal provider is created (unless unstyled: true).
|
|
6
6
|
*/
|
|
7
|
+
/**
|
|
8
|
+
* Maps ModalStyles keys to their CSS variable names.
|
|
9
|
+
* Applied as inline styles on the overlay element so each modal instance
|
|
10
|
+
* can override the global :root variables without affecting other modals.
|
|
11
|
+
*/
|
|
12
|
+
export const STYLE_TOKEN_MAP = [
|
|
13
|
+
['bg', '--lf-modal-bg'],
|
|
14
|
+
['headerBg', '--lf-modal-header-bg'],
|
|
15
|
+
['headerColor', '--lf-modal-header-color'],
|
|
16
|
+
['bodyColor', '--lf-modal-body-color'],
|
|
17
|
+
['closeColor', '--lf-modal-close-color'],
|
|
18
|
+
['backdrop', '--lf-modal-backdrop'],
|
|
19
|
+
['shadow', '--lf-modal-shadow'],
|
|
20
|
+
['borderRadius', '--lf-modal-border-radius'],
|
|
21
|
+
];
|
|
7
22
|
let stylesInjected = false;
|
|
8
23
|
const DEFAULT_STYLES = `
|
|
9
24
|
/* ─── CSS Variables (Customizable) ─────────────────────────── */
|
|
@@ -126,6 +141,7 @@ const DEFAULT_STYLES = `
|
|
|
126
141
|
|
|
127
142
|
/* ─── Dark Mode Support ────────────────────────────────────── */
|
|
128
143
|
|
|
144
|
+
.dark,
|
|
129
145
|
[data-theme="dark"] {
|
|
130
146
|
--lf-modal-backdrop: rgba(0, 0, 0, 0.7);
|
|
131
147
|
--lf-modal-bg: #1e1e2e;
|
|
@@ -135,6 +151,18 @@ const DEFAULT_STYLES = `
|
|
|
135
151
|
--lf-modal-body-color: #a6adc8;
|
|
136
152
|
--lf-modal-close-color: #6c7086;
|
|
137
153
|
}
|
|
154
|
+
|
|
155
|
+
@media (prefers-color-scheme: dark) {
|
|
156
|
+
:root:not([data-theme="light"]) {
|
|
157
|
+
--lf-modal-backdrop: rgba(0, 0, 0, 0.7);
|
|
158
|
+
--lf-modal-bg: #1e1e2e;
|
|
159
|
+
--lf-modal-shadow: 0 20px 60px rgba(0, 0, 0, 0.6);
|
|
160
|
+
--lf-modal-header-bg: #181825;
|
|
161
|
+
--lf-modal-header-color: #cdd6f4;
|
|
162
|
+
--lf-modal-body-color: #a6adc8;
|
|
163
|
+
--lf-modal-close-color: #6c7086;
|
|
164
|
+
}
|
|
165
|
+
}
|
|
138
166
|
`;
|
|
139
167
|
/**
|
|
140
168
|
* Inject default styles into the document head.
|
package/dist/styles.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"styles.js","sourceRoot":"","sources":["../src/styles.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;
|
|
1
|
+
{"version":3,"file":"styles.js","sourceRoot":"","sources":["../src/styles.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAIH;;;;GAIG;AACH,MAAM,CAAC,MAAM,eAAe,GAAwD;IAClF,CAAC,IAAI,EAAY,eAAe,CAAC;IACjC,CAAC,UAAU,EAAM,sBAAsB,CAAC;IACxC,CAAC,aAAa,EAAG,yBAAyB,CAAC;IAC3C,CAAC,WAAW,EAAK,uBAAuB,CAAC;IACzC,CAAC,YAAY,EAAI,wBAAwB,CAAC;IAC1C,CAAC,UAAU,EAAM,qBAAqB,CAAC;IACvC,CAAC,QAAQ,EAAQ,mBAAmB,CAAC;IACrC,CAAC,cAAc,EAAE,0BAA0B,CAAC;CACpC,CAAA;AAEV,IAAI,cAAc,GAAG,KAAK,CAAA;AAE1B,MAAM,cAAc,GAAG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA+ItB,CAAA;AAED;;;GAGG;AACH,MAAM,UAAU,mBAAmB;IACjC,IAAI,cAAc;QAAE,OAAM;IAC1B,IAAI,OAAO,QAAQ,KAAK,WAAW;QAAE,OAAM,CAAC,aAAa;IAEzD,MAAM,KAAK,GAAG,QAAQ,CAAC,aAAa,CAAC,OAAO,CAAC,CAAA;IAC7C,KAAK,CAAC,EAAE,GAAG,iBAAiB,CAAA;IAC5B,KAAK,CAAC,WAAW,GAAG,cAAc,CAAA;IAClC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAA;IAEhC,cAAc,GAAG,IAAI,CAAA;AACvB,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,oBAAoB;IAClC,cAAc,GAAG,KAAK,CAAA;IACtB,MAAM,QAAQ,GAAG,QAAQ,CAAC,cAAc,CAAC,iBAAiB,CAAC,CAAA;IAC3D,IAAI,QAAQ,EAAE,CAAC;QACb,QAAQ,CAAC,MAAM,EAAE,CAAA;IACnB,CAAC;AACH,CAAC"}
|
package/dist/types.d.ts
CHANGED
|
@@ -1,5 +1,23 @@
|
|
|
1
1
|
import type { Signal } from '@liteforge/core';
|
|
2
2
|
export type ModalSize = 'sm' | 'md' | 'lg' | 'xl' | 'full';
|
|
3
|
+
export interface ModalStyles {
|
|
4
|
+
bg?: string;
|
|
5
|
+
headerBg?: string;
|
|
6
|
+
headerColor?: string;
|
|
7
|
+
bodyColor?: string;
|
|
8
|
+
closeColor?: string;
|
|
9
|
+
backdrop?: string;
|
|
10
|
+
shadow?: string;
|
|
11
|
+
borderRadius?: string;
|
|
12
|
+
}
|
|
13
|
+
export interface ModalClasses {
|
|
14
|
+
overlay?: string;
|
|
15
|
+
modal?: string;
|
|
16
|
+
header?: string;
|
|
17
|
+
title?: string;
|
|
18
|
+
close?: string;
|
|
19
|
+
body?: string;
|
|
20
|
+
}
|
|
3
21
|
export interface ModalConfig {
|
|
4
22
|
title?: string;
|
|
5
23
|
size?: ModalSize;
|
|
@@ -7,6 +25,8 @@ export interface ModalConfig {
|
|
|
7
25
|
closeOnBackdrop?: boolean;
|
|
8
26
|
closeOnEsc?: boolean;
|
|
9
27
|
unstyled?: boolean;
|
|
28
|
+
styles?: ModalStyles;
|
|
29
|
+
classes?: ModalClasses;
|
|
10
30
|
onOpen?: () => void;
|
|
11
31
|
onClose?: () => void;
|
|
12
32
|
}
|
package/dist/types.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AAE9C,MAAM,MAAM,SAAS,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,MAAM,CAAC;AAE3D,MAAM,WAAW,WAAW;IAC1B,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,IAAI,CAAC,EAAE,SAAS,CAAC;IACjB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,MAAM,CAAC,EAAE,MAAM,IAAI,CAAC;IACpB,OAAO,CAAC,EAAE,MAAM,IAAI,CAAC;CACtB;AAED,MAAM,WAAW,kBAAkB;IACjC,MAAM,CAAC,EAAE,WAAW,CAAC;IACrB,SAAS,EAAE,MAAM,IAAI,CAAC;CACvB;AAED,6DAA6D;AAC7D,MAAM,MAAM,YAAY,GAAG,WAAW,CAAC;AAEvC,MAAM,WAAW,WAAW;IAC1B,MAAM,EAAE,MAAM,CAAC,OAAO,CAAC,CAAC;IACxB,IAAI,EAAE,MAAM,IAAI,CAAC;IACjB,KAAK,EAAE,MAAM,IAAI,CAAC;IAClB,MAAM,EAAE,MAAM,IAAI,CAAC;IACnB,OAAO,EAAE,MAAM,IAAI,CAAC;CACrB"}
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AAE9C,MAAM,MAAM,SAAS,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,MAAM,CAAC;AAE3D,MAAM,WAAW,WAAW;IAC1B,EAAE,CAAC,EAAY,MAAM,CAAC;IACtB,QAAQ,CAAC,EAAM,MAAM,CAAC;IACtB,WAAW,CAAC,EAAG,MAAM,CAAC;IACtB,SAAS,CAAC,EAAK,MAAM,CAAC;IACtB,UAAU,CAAC,EAAI,MAAM,CAAC;IACtB,QAAQ,CAAC,EAAM,MAAM,CAAC;IACtB,MAAM,CAAC,EAAQ,MAAM,CAAC;IACtB,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB;AAED,MAAM,WAAW,YAAY;IAC3B,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,KAAK,CAAC,EAAI,MAAM,CAAC;IACjB,MAAM,CAAC,EAAG,MAAM,CAAC;IACjB,KAAK,CAAC,EAAI,MAAM,CAAC;IACjB,KAAK,CAAC,EAAI,MAAM,CAAC;IACjB,IAAI,CAAC,EAAK,MAAM,CAAC;CAClB;AAED,MAAM,WAAW,WAAW;IAC1B,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,IAAI,CAAC,EAAE,SAAS,CAAC;IACjB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,MAAM,CAAC,EAAE,WAAW,CAAC;IACrB,OAAO,CAAC,EAAE,YAAY,CAAC;IACvB,MAAM,CAAC,EAAE,MAAM,IAAI,CAAC;IACpB,OAAO,CAAC,EAAE,MAAM,IAAI,CAAC;CACtB;AAED,MAAM,WAAW,kBAAkB;IACjC,MAAM,CAAC,EAAE,WAAW,CAAC;IACrB,SAAS,EAAE,MAAM,IAAI,CAAC;CACvB;AAED,6DAA6D;AAC7D,MAAM,MAAM,YAAY,GAAG,WAAW,CAAC;AAEvC,MAAM,WAAW,WAAW;IAC1B,MAAM,EAAE,MAAM,CAAC,OAAO,CAAC,CAAC;IACxB,IAAI,EAAE,MAAM,IAAI,CAAC;IACjB,KAAK,EAAE,MAAM,IAAI,CAAC;IAClB,MAAM,EAAE,MAAM,IAAI,CAAC;IACnB,OAAO,EAAE,MAAM,IAAI,CAAC;CACrB"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@liteforge/modal",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "1.0.0",
|
|
4
4
|
"description": "Signal-based modal system. createModal, ModalProvider, confirm/alert/prompt presets.",
|
|
5
5
|
"author": "SchildW3rk <contact@schildw3rk.dev>",
|
|
6
6
|
"license": "MIT",
|
|
@@ -44,10 +44,17 @@
|
|
|
44
44
|
"access": "public"
|
|
45
45
|
},
|
|
46
46
|
"peerDependencies": {
|
|
47
|
-
"@liteforge/core": ">=0.1.0"
|
|
47
|
+
"@liteforge/core": ">=0.1.0",
|
|
48
|
+
"@liteforge/runtime": ">=0.4.0"
|
|
49
|
+
},
|
|
50
|
+
"peerDependenciesMeta": {
|
|
51
|
+
"@liteforge/runtime": {
|
|
52
|
+
"optional": true
|
|
53
|
+
}
|
|
48
54
|
},
|
|
49
55
|
"devDependencies": {
|
|
50
|
-
"@liteforge/core": "0.1.0"
|
|
56
|
+
"@liteforge/core": "0.1.0",
|
|
57
|
+
"@liteforge/runtime": "0.4.0"
|
|
51
58
|
},
|
|
52
59
|
"scripts": {
|
|
53
60
|
"build": "tsc -p tsconfig.build.json",
|