@liteforge/modal 0.2.0 → 1.1.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/css/styles.css ADDED
@@ -0,0 +1,119 @@
1
+ /* ─── CSS Variables (Customizable) ─────────────────────────── */
2
+ /* Default values reference @liteforge/theme semantic tokens. */
3
+ /* Dark mode cascades automatically through the theme selectors. */
4
+
5
+ :root {
6
+ --lf-modal-backdrop: var(--lf-color-bg-overlay, rgba(0, 0, 0, 0.5));
7
+ --lf-modal-bg: var(--lf-color-surface, #ffffff);
8
+ --lf-modal-border-radius: 10px;
9
+ --lf-modal-shadow: var(--lf-shadow-xl, 0 20px 60px rgba(0, 0, 0, 0.3));
10
+ --lf-modal-header-bg: var(--lf-color-bg-subtle, #f8fafc);
11
+ --lf-modal-header-color: var(--lf-color-text, #1e293b);
12
+ --lf-modal-body-color: var(--lf-color-text, #374151);
13
+ --lf-modal-close-color: var(--lf-color-text-muted, #6b7280);
14
+ --lf-modal-z-index: var(--lf-z-modal, 1000);
15
+ }
16
+
17
+ /* ─── Provider ─────────────────────────────────────────────── */
18
+
19
+ .lf-modal-provider {
20
+ position: fixed;
21
+ inset: 0;
22
+ pointer-events: none;
23
+ z-index: var(--lf-modal-z-index);
24
+ }
25
+
26
+ /* ─── Overlay ──────────────────────────────────────────────── */
27
+
28
+ .lf-modal-overlay {
29
+ position: fixed;
30
+ inset: 0;
31
+ background: var(--lf-modal-backdrop);
32
+ display: flex;
33
+ align-items: center;
34
+ justify-content: center;
35
+ pointer-events: all;
36
+ opacity: 0;
37
+ transition: opacity var(--lf-transition-base, 0.2s ease);
38
+ padding: var(--lf-space-4, 16px);
39
+ box-sizing: border-box;
40
+ }
41
+
42
+ .lf-modal-overlay--open {
43
+ opacity: 1;
44
+ }
45
+
46
+ /* ─── Size Variants ────────────────────────────────────────── */
47
+
48
+ .lf-modal-overlay--sm .lf-modal { max-width: 400px; }
49
+ .lf-modal-overlay--md .lf-modal { max-width: 560px; }
50
+ .lf-modal-overlay--lg .lf-modal { max-width: 720px; }
51
+ .lf-modal-overlay--xl .lf-modal { max-width: 1000px; }
52
+ .lf-modal-overlay--full .lf-modal { max-width: 100vw; margin: 0; border-radius: 0; }
53
+
54
+ /* ─── Modal ────────────────────────────────────────────────── */
55
+
56
+ .lf-modal {
57
+ background: var(--lf-modal-bg);
58
+ border-radius: var(--lf-modal-border-radius);
59
+ box-shadow: var(--lf-modal-shadow);
60
+ width: 100%;
61
+ max-height: calc(100vh - 32px);
62
+ display: flex;
63
+ flex-direction: column;
64
+ transform: translateY(-8px);
65
+ transition: transform var(--lf-transition-base, 0.2s ease);
66
+ overflow: hidden;
67
+ font-family: var(--lf-font-sans, system-ui, -apple-system, sans-serif);
68
+ }
69
+
70
+ .lf-modal-overlay--open .lf-modal {
71
+ transform: translateY(0);
72
+ }
73
+
74
+ /* ─── Header ───────────────────────────────────────────────── */
75
+
76
+ .lf-modal-header {
77
+ display: flex;
78
+ align-items: center;
79
+ justify-content: space-between;
80
+ padding: var(--lf-space-4, 16px) var(--lf-space-5, 20px);
81
+ background: var(--lf-modal-header-bg);
82
+ border-bottom: 1px solid var(--lf-color-border, rgba(0, 0, 0, 0.08));
83
+ flex-shrink: 0;
84
+ }
85
+
86
+ .lf-modal-title {
87
+ font-size: var(--lf-text-md, 16px);
88
+ font-weight: var(--lf-font-semibold, 600);
89
+ color: var(--lf-modal-header-color);
90
+ line-height: 1.4;
91
+ }
92
+
93
+ .lf-modal-close {
94
+ background: none;
95
+ border: none;
96
+ cursor: pointer;
97
+ color: var(--lf-modal-close-color);
98
+ font-size: 18px;
99
+ padding: 4px 8px;
100
+ border-radius: var(--lf-radius-sm, 4px);
101
+ line-height: 1;
102
+ transition: background-color var(--lf-transition-fast, 0.15s), color var(--lf-transition-fast, 0.15s);
103
+ flex-shrink: 0;
104
+ }
105
+
106
+ .lf-modal-close:hover {
107
+ background: var(--lf-color-bg-muted, rgba(0, 0, 0, 0.06));
108
+ color: var(--lf-modal-header-color);
109
+ }
110
+
111
+ /* ─── Body ─────────────────────────────────────────────────── */
112
+
113
+ .lf-modal-body {
114
+ padding: var(--lf-space-5, 20px);
115
+ color: var(--lf-modal-body-color);
116
+ font-size: var(--lf-text-base, 14px);
117
+ line-height: 1.6;
118
+ overflow-y: auto;
119
+ }
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
@@ -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"}
@@ -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,CA6EjE"}
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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"}
@@ -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"}
@@ -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;AAI9C,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,CA8DxB"}
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.style.margin = '0 0 20px';
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.style.cssText = 'padding:8px 16px;border:1px solid #d1d5db;border-radius:6px;background:#fff;cursor:pointer;font-size:14px';
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.style.cssText = 'padding:8px 16px;border:none;border-radius:6px;background:#3b82f6;color:#fff;cursor:pointer;font-size:14px';
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.style.margin = '0 0 20px';
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.style.cssText = 'padding:8px 16px;border:none;border-radius:6px;background:#3b82f6;color:#fff;cursor:pointer;font-size:14px';
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.margin = '0 0 12px';
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.style.cssText = 'width:100%;padding:8px 10px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;box-sizing:border-box;margin-bottom:16px';
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.style.cssText = 'padding:8px 16px;border:1px solid #d1d5db;border-radius:6px;background:#fff;cursor:pointer;font-size:14px';
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.style.cssText = 'padding:8px 16px;border:none;border-radius:6px;background:#3b82f6;color:#fff;cursor:pointer;font-size:14px';
164
+ styleBtn(okBtn, 'primary');
137
165
  okBtn.addEventListener('click', () => {
138
166
  if (!resolved) {
139
167
  resolved = true;
@@ -1 +1 @@
1
- {"version":3,"file":"presets.js","sourceRoot":"","sources":["../src/presets.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"presets.js","sourceRoot":"","sources":["../src/presets.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAGzC,gEAAgE;AAEhE,SAAS,QAAQ,CAAC,GAAsB,EAAE,OAAgC;IACxE,GAAG,CAAC,KAAK,CAAC,OAAO,GAAG;QAClB,+DAA+D;QAC/D,mEAAmE;QACnE,qDAAqD;QACrD,OAAO,KAAK,SAAS;YACnB,CAAC,CAAC,+BAA+B;YACjC,CAAC,CAAC,mGAAmG;KACxG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACZ,GAAG,CAAC,gBAAgB,CAAC,YAAY,EAAE,GAAG,EAAE,GAAG,GAAG,CAAC,KAAK,CAAC,OAAO,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;IAC1E,GAAG,CAAC,gBAAgB,CAAC,YAAY,EAAE,GAAG,EAAE,GAAG,GAAG,CAAC,KAAK,CAAC,OAAO,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;AACzE,CAAC;AAED,SAAS,UAAU,CAAC,KAAuB;IACzC,KAAK,CAAC,KAAK,CAAC,OAAO,GAAG;QACpB,kCAAkC;QAClC,mDAAmD;QACnD,gEAAgE;QAChE,yCAAyC;QACzC,iCAAiC;KAClC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACZ,KAAK,CAAC,gBAAgB,CAAC,OAAO,EAAE,GAAG,EAAE,GAAG,KAAK,CAAC,KAAK,CAAC,WAAW,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC;IAChF,KAAK,CAAC,gBAAgB,CAAC,MAAM,EAAG,GAAG,EAAE,GAAG,KAAK,CAAC,KAAK,CAAC,WAAW,GAAG,wBAAwB,CAAC,CAAC,CAAC,CAAC,CAAC;AACjG,CAAC;AAED,SAAS,QAAQ,CAAC,GAAyB;IACzC,GAAG,CAAC,KAAK,CAAC,OAAO,GAAG,iFAAiF,CAAC;AACxG,CAAC;AAED,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,QAAQ,CAAC,GAAG,CAAC,CAAC;gBACd,GAAG,CAAC,WAAW,GAAG,OAAO,CAAC;gBAC1B,OAAO,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;gBAEzB,MAAM,OAAO,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;gBAC9C,OAAO,CAAC,KAAK,CAAC,OAAO,GAAG,+CAA+C,CAAC;gBAExE,MAAM,SAAS,GAAG,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;gBACnD,SAAS,CAAC,WAAW,GAAG,QAAQ,CAAC;gBACjC,QAAQ,CAAC,SAAS,EAAE,WAAW,CAAC,CAAC;gBACjC,SAAS,CAAC,gBAAgB,CAAC,OAAO,EAAE,GAAG,EAAE;oBACvC,IAAI,CAAC,QAAQ,EAAE,CAAC;wBAAC,QAAQ,GAAG,IAAI,CAAC;wBAAC,KAAK,CAAC,KAAK,EAAE,CAAC;wBAAC,OAAO,CAAC,KAAK,CAAC,CAAC;oBAAC,CAAC;gBACpE,CAAC,CAAC,CAAC;gBAEH,MAAM,KAAK,GAAG,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;gBAC/C,KAAK,CAAC,WAAW,GAAG,IAAI,CAAC;gBACzB,QAAQ,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;gBAC3B,KAAK,CAAC,gBAAgB,CAAC,OAAO,EAAE,GAAG,EAAE;oBACnC,IAAI,CAAC,QAAQ,EAAE,CAAC;wBAAC,QAAQ,GAAG,IAAI,CAAC;wBAAC,KAAK,CAAC,KAAK,EAAE,CAAC;wBAAC,OAAO,CAAC,IAAI,CAAC,CAAC;oBAAC,CAAC;gBACnE,CAAC,CAAC,CAAC;gBAEH,OAAO,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC;gBAC/B,OAAO,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;gBAC3B,OAAO,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;gBAE7B,OAAO,OAAO,CAAC;YACjB,CAAC;SACF,CAAC,CAAC;QAEH,KAAK,CAAC,IAAI,EAAE,CAAC;QAEb,qCAAqC;QACrC,MAAM,SAAS,GAAG,KAAK,CAAC,KAAK,CAAC;QAC9B,KAAK,CAAC,KAAK,GAAG,GAAG,EAAE;YACjB,SAAS,EAAE,CAAC;YACZ,IAAI,CAAC,QAAQ,EAAE,CAAC;gBAAC,QAAQ,GAAG,IAAI,CAAC;gBAAC,OAAO,CAAC,KAAK,CAAC,CAAC;YAAC,CAAC;QACrD,CAAC,CAAC;IACJ,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAiB,CAAC,CAAC;AACzC,CAAC;AAED,gEAAgE;AAEhE,MAAM,UAAU,KAAK,CACnB,OAAe,EACf,MAA6B;IAE7B,OAAO,IAAI,OAAO,CAAO,CAAC,OAAO,EAAE,EAAE;QACnC,MAAM,KAAK,GAAG,WAAW,CAAC;YACxB,MAAM,EAAE;gBACN,KAAK,EAAE,OAAO;gBACd,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,QAAQ,CAAC,GAAG,CAAC,CAAC;gBACd,GAAG,CAAC,WAAW,GAAG,OAAO,CAAC;gBAC1B,OAAO,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;gBAEzB,MAAM,OAAO,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;gBAC9C,OAAO,CAAC,KAAK,CAAC,OAAO,GAAG,uCAAuC,CAAC;gBAEhE,MAAM,KAAK,GAAG,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;gBAC/C,KAAK,CAAC,WAAW,GAAG,IAAI,CAAC;gBACzB,QAAQ,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;gBAC3B,KAAK,CAAC,gBAAgB,CAAC,OAAO,EAAE,GAAG,EAAE;oBACnC,KAAK,CAAC,KAAK,EAAE,CAAC;oBACd,KAAK,CAAC,OAAO,EAAE,CAAC;oBAChB,OAAO,EAAE,CAAC;gBACZ,CAAC,CAAC,CAAC;gBAEH,OAAO,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;gBAC3B,OAAO,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;gBAE7B,OAAO,OAAO,CAAC;YACjB,CAAC;SACF,CAAC,CAAC;QAEH,KAAK,CAAC,IAAI,EAAE,CAAC;IACf,CAAC,CAAC,CAAC;AACL,CAAC;AAED,gEAAgE;AAEhE,MAAM,UAAU,MAAM,CACpB,OAAe,EACf,YAAqB,EACrB,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,OAAO;gBACd,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,GAAG,CAAC,KAAK,CAAC,OAAO,GAAG,iEAAiE,CAAC;gBACtF,GAAG,CAAC,WAAW,GAAG,OAAO,CAAC;gBAC1B,OAAO,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;gBAEzB,MAAM,KAAK,GAAG,QAAQ,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;gBAC9C,KAAK,CAAC,IAAI,GAAG,MAAM,CAAC;gBACpB,KAAK,CAAC,KAAK,GAAG,YAAY,IAAI,EAAE,CAAC;gBACjC,UAAU,CAAC,KAAK,CAAC,CAAC;gBAClB,UAAU,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE,CAAC,CAAC;gBACpC,OAAO,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;gBAE3B,MAAM,OAAO,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;gBAC9C,OAAO,CAAC,KAAK,CAAC,OAAO,GAAG,+CAA+C,CAAC;gBAExE,MAAM,SAAS,GAAG,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;gBACnD,SAAS,CAAC,WAAW,GAAG,QAAQ,CAAC;gBACjC,QAAQ,CAAC,SAAS,EAAE,WAAW,CAAC,CAAC;gBACjC,SAAS,CAAC,gBAAgB,CAAC,OAAO,EAAE,GAAG,EAAE;oBACvC,IAAI,CAAC,QAAQ,EAAE,CAAC;wBAAC,QAAQ,GAAG,IAAI,CAAC;wBAAC,KAAK,CAAC,KAAK,EAAE,CAAC;wBAAC,KAAK,CAAC,OAAO,EAAE,CAAC;wBAAC,OAAO,CAAC,IAAI,CAAC,CAAC;oBAAC,CAAC;gBACpF,CAAC,CAAC,CAAC;gBAEH,MAAM,KAAK,GAAG,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;gBAC/C,KAAK,CAAC,WAAW,GAAG,IAAI,CAAC;gBACzB,QAAQ,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;gBAC3B,KAAK,CAAC,gBAAgB,CAAC,OAAO,EAAE,GAAG,EAAE;oBACnC,IAAI,CAAC,QAAQ,EAAE,CAAC;wBAAC,QAAQ,GAAG,IAAI,CAAC;wBAAC,KAAK,CAAC,KAAK,EAAE,CAAC;wBAAC,KAAK,CAAC,OAAO,EAAE,CAAC;wBAAC,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;oBAAC,CAAC;gBAC3F,CAAC,CAAC,CAAC;gBAEH,KAAK,CAAC,gBAAgB,CAAC,SAAS,EAAE,CAAC,CAAC,EAAE,EAAE;oBACtC,IAAI,CAAC,CAAC,GAAG,KAAK,OAAO,IAAI,CAAC,QAAQ,EAAE,CAAC;wBACnC,QAAQ,GAAG,IAAI,CAAC;wBAChB,KAAK,CAAC,KAAK,EAAE,CAAC;wBACd,KAAK,CAAC,OAAO,EAAE,CAAC;wBAChB,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;oBACvB,CAAC;gBACH,CAAC,CAAC,CAAC;gBAEH,OAAO,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC;gBAC/B,OAAO,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;gBAC3B,OAAO,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;gBAE7B,OAAO,OAAO,CAAC;YACjB,CAAC;SACF,CAAC,CAAC;QAEH,KAAK,CAAC,IAAI,EAAE,CAAC;IACf,CAAC,CAAC,CAAC;AACL,CAAC"}
@@ -1,4 +1,4 @@
1
1
  export declare function ModalProvider(opts?: {
2
2
  unstyled?: boolean;
3
- }): Node;
3
+ }): HTMLElement;
4
4
  //# sourceMappingURL=provider.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"provider.d.ts","sourceRoot":"","sources":["../src/provider.ts"],"names":[],"mappings":"AAwHA,wBAAgB,aAAa,CAAC,IAAI,CAAC,EAAE;IAAE,QAAQ,CAAC,EAAE,OAAO,CAAA;CAAE,GAAG,IAAI,CA+BjE"}
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.size;
34
+ const { size, styles, classes } = entry.options;
35
+ const cls = classes;
35
36
  const overlay = document.createElement('div');
36
- overlay.className = `lf-modal-overlay lf-modal-overlay--${size}`;
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);
@@ -1 +1 @@
1
- {"version":3,"file":"provider.js","sourceRoot":"","sources":["../src/provider.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"provider.js","sourceRoot":"","sources":["../src/provider.ts"],"names":[],"mappings":"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"}
package/dist/styles.d.ts CHANGED
@@ -1,16 +1,10 @@
1
+ import type { ModalStyles } from './types.js';
1
2
  /**
2
- * @liteforge/modal - Default CSS Theme
3
- *
4
- * Minimal, clean default styles using CSS variables.
5
- * Injected once when the first modal provider is created (unless unstyled: true).
6
- */
7
- /**
8
- * Inject default styles into the document head.
9
- * Called automatically when the first ModalProvider is created (unless unstyled: true).
3
+ * Maps ModalStyles keys to their CSS variable names.
4
+ * Applied as inline styles on the overlay element so each modal instance
5
+ * can override the global :root variables without affecting other modals.
10
6
  */
7
+ export declare const STYLE_TOKEN_MAP: ReadonlyArray<readonly [keyof ModalStyles, string]>;
11
8
  export declare function injectDefaultStyles(): void;
12
- /**
13
- * Reset styles injection flag (for testing)
14
- */
15
9
  export declare function resetStylesInjection(): void;
16
10
  //# sourceMappingURL=styles.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"styles.d.ts","sourceRoot":"","sources":["../src/styles.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAwIH;;;GAGG;AACH,wBAAgB,mBAAmB,IAAI,IAAI,CAU1C;AAED;;GAEG;AACH,wBAAgB,oBAAoB,IAAI,IAAI,CAM3C"}
1
+ {"version":3,"file":"styles.d.ts","sourceRoot":"","sources":["../src/styles.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAG9C;;;;GAIG;AACH,eAAO,MAAM,eAAe,EAAE,aAAa,CAAC,SAAS,CAAC,MAAM,WAAW,EAAE,MAAM,CAAC,CAStE,CAAA;AAIV,wBAAgB,mBAAmB,IAAI,IAAI,CAS1C;AAED,wBAAgB,oBAAoB,IAAI,IAAI,CAG3C"}
package/dist/styles.js CHANGED
@@ -1,164 +1,34 @@
1
+ import stylesUrl from '../css/styles.css?url';
1
2
  /**
2
- * @liteforge/modal - Default CSS Theme
3
- *
4
- * Minimal, clean default styles using CSS variables.
5
- * Injected once when the first modal provider is created (unless unstyled: true).
3
+ * Maps ModalStyles keys to their CSS variable names.
4
+ * Applied as inline styles on the overlay element so each modal instance
5
+ * can override the global :root variables without affecting other modals.
6
6
  */
7
+ export const STYLE_TOKEN_MAP = [
8
+ ['bg', '--lf-modal-bg'],
9
+ ['headerBg', '--lf-modal-header-bg'],
10
+ ['headerColor', '--lf-modal-header-color'],
11
+ ['bodyColor', '--lf-modal-body-color'],
12
+ ['closeColor', '--lf-modal-close-color'],
13
+ ['backdrop', '--lf-modal-backdrop'],
14
+ ['shadow', '--lf-modal-shadow'],
15
+ ['borderRadius', '--lf-modal-border-radius'],
16
+ ];
7
17
  let stylesInjected = false;
8
- const DEFAULT_STYLES = `
9
- /* ─── CSS Variables (Customizable) ─────────────────────────── */
10
-
11
- :root {
12
- --lf-modal-backdrop: rgba(0, 0, 0, 0.5);
13
- --lf-modal-bg: #ffffff;
14
- --lf-modal-border-radius: 10px;
15
- --lf-modal-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
16
- --lf-modal-header-bg: #f8fafc;
17
- --lf-modal-header-color: #1e293b;
18
- --lf-modal-body-color: #374151;
19
- --lf-modal-close-color: #6b7280;
20
- --lf-modal-z-index: 1000;
21
- }
22
-
23
- /* ─── Provider ─────────────────────────────────────────────── */
24
-
25
- .lf-modal-provider {
26
- position: fixed;
27
- inset: 0;
28
- pointer-events: none;
29
- z-index: var(--lf-modal-z-index);
30
- }
31
-
32
- /* ─── Overlay ──────────────────────────────────────────────── */
33
-
34
- .lf-modal-overlay {
35
- position: fixed;
36
- inset: 0;
37
- background: var(--lf-modal-backdrop);
38
- display: flex;
39
- align-items: center;
40
- justify-content: center;
41
- pointer-events: all;
42
- opacity: 0;
43
- transition: opacity 0.2s ease;
44
- padding: 16px;
45
- box-sizing: border-box;
46
- }
47
-
48
- .lf-modal-overlay--open {
49
- opacity: 1;
50
- }
51
-
52
- /* ─── Size Variants ────────────────────────────────────────── */
53
-
54
- .lf-modal-overlay--sm .lf-modal { max-width: 400px; }
55
- .lf-modal-overlay--md .lf-modal { max-width: 560px; }
56
- .lf-modal-overlay--lg .lf-modal { max-width: 720px; }
57
- .lf-modal-overlay--xl .lf-modal { max-width: 1000px; }
58
- .lf-modal-overlay--full .lf-modal { max-width: 100vw; margin: 0; border-radius: 0; }
59
-
60
- /* ─── Modal ────────────────────────────────────────────────── */
61
-
62
- .lf-modal {
63
- background: var(--lf-modal-bg);
64
- border-radius: var(--lf-modal-border-radius);
65
- box-shadow: var(--lf-modal-shadow);
66
- width: 100%;
67
- max-height: calc(100vh - 32px);
68
- display: flex;
69
- flex-direction: column;
70
- transform: translateY(-8px);
71
- transition: transform 0.2s ease;
72
- overflow: hidden;
73
- font-family: system-ui, -apple-system, sans-serif;
74
- }
75
-
76
- .lf-modal-overlay--open .lf-modal {
77
- transform: translateY(0);
78
- }
79
-
80
- /* ─── Header ───────────────────────────────────────────────── */
81
-
82
- .lf-modal-header {
83
- display: flex;
84
- align-items: center;
85
- justify-content: space-between;
86
- padding: 16px 20px;
87
- background: var(--lf-modal-header-bg);
88
- border-bottom: 1px solid rgba(0, 0, 0, 0.08);
89
- flex-shrink: 0;
90
- }
91
-
92
- .lf-modal-title {
93
- font-size: 16px;
94
- font-weight: 600;
95
- color: var(--lf-modal-header-color);
96
- line-height: 1.4;
97
- }
98
-
99
- .lf-modal-close {
100
- background: none;
101
- border: none;
102
- cursor: pointer;
103
- color: var(--lf-modal-close-color);
104
- font-size: 18px;
105
- padding: 4px 8px;
106
- border-radius: 4px;
107
- line-height: 1;
108
- transition: background-color 0.15s, color 0.15s;
109
- flex-shrink: 0;
110
- }
111
-
112
- .lf-modal-close:hover {
113
- background: rgba(0, 0, 0, 0.06);
114
- color: var(--lf-modal-header-color);
115
- }
116
-
117
- /* ─── Body ─────────────────────────────────────────────────── */
118
-
119
- .lf-modal-body {
120
- padding: 20px;
121
- color: var(--lf-modal-body-color);
122
- font-size: 14px;
123
- line-height: 1.6;
124
- overflow-y: auto;
125
- }
126
-
127
- /* ─── Dark Mode Support ────────────────────────────────────── */
128
-
129
- [data-theme="dark"] {
130
- --lf-modal-backdrop: rgba(0, 0, 0, 0.7);
131
- --lf-modal-bg: #1e1e2e;
132
- --lf-modal-shadow: 0 20px 60px rgba(0, 0, 0, 0.6);
133
- --lf-modal-header-bg: #181825;
134
- --lf-modal-header-color: #cdd6f4;
135
- --lf-modal-body-color: #a6adc8;
136
- --lf-modal-close-color: #6c7086;
137
- }
138
- `;
139
- /**
140
- * Inject default styles into the document head.
141
- * Called automatically when the first ModalProvider is created (unless unstyled: true).
142
- */
143
18
  export function injectDefaultStyles() {
144
19
  if (stylesInjected)
145
20
  return;
146
21
  if (typeof document === 'undefined')
147
22
  return; // SSR safety
148
- const style = document.createElement('style');
149
- style.id = 'lf-modal-styles';
150
- style.textContent = DEFAULT_STYLES;
151
- document.head.appendChild(style);
23
+ const link = document.createElement('link');
24
+ link.rel = 'stylesheet';
25
+ link.href = stylesUrl;
26
+ link.setAttribute('data-lf-modal', '');
27
+ document.head.appendChild(link);
152
28
  stylesInjected = true;
153
29
  }
154
- /**
155
- * Reset styles injection flag (for testing)
156
- */
157
30
  export function resetStylesInjection() {
158
31
  stylesInjected = false;
159
- const existing = document.getElementById('lf-modal-styles');
160
- if (existing) {
161
- existing.remove();
162
- }
32
+ document.querySelector('link[data-lf-modal]')?.remove();
163
33
  }
164
34
  //# sourceMappingURL=styles.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"styles.js","sourceRoot":"","sources":["../src/styles.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,IAAI,cAAc,GAAG,KAAK,CAAA;AAE1B,MAAM,cAAc,GAAG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAkItB,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"}
1
+ {"version":3,"file":"styles.js","sourceRoot":"","sources":["../src/styles.ts"],"names":[],"mappings":"AACA,OAAO,SAAS,MAAM,uBAAuB,CAAC;AAE9C;;;;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,UAAU,mBAAmB;IACjC,IAAI,cAAc;QAAE,OAAM;IAC1B,IAAI,OAAO,QAAQ,KAAK,WAAW;QAAE,OAAM,CAAC,aAAa;IACzD,MAAM,IAAI,GAAG,QAAQ,CAAC,aAAa,CAAC,MAAM,CAAC,CAAA;IAC3C,IAAI,CAAC,GAAG,GAAG,YAAY,CAAA;IACvB,IAAI,CAAC,IAAI,GAAG,SAAS,CAAA;IACrB,IAAI,CAAC,YAAY,CAAC,eAAe,EAAE,EAAE,CAAC,CAAA;IACtC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAA;IAC/B,cAAc,GAAG,IAAI,CAAA;AACvB,CAAC;AAED,MAAM,UAAU,oBAAoB;IAClC,cAAc,GAAG,KAAK,CAAA;IACtB,QAAQ,CAAC,aAAa,CAAC,qBAAqB,CAAC,EAAE,MAAM,EAAE,CAAA;AACzD,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
  }
@@ -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.2.0",
3
+ "version": "1.1.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",
@@ -29,14 +29,18 @@
29
29
  ".": {
30
30
  "types": "./dist/index.d.ts",
31
31
  "import": "./dist/index.js"
32
- }
32
+ },
33
+ "./styles": "./css/styles.css"
33
34
  },
34
35
  "files": [
35
36
  "dist",
37
+ "css",
36
38
  "README.md",
37
39
  "LICENSE"
38
40
  ],
39
- "sideEffects": false,
41
+ "sideEffects": [
42
+ "css/*.css"
43
+ ],
40
44
  "engines": {
41
45
  "node": ">=18"
42
46
  },
@@ -44,10 +48,17 @@
44
48
  "access": "public"
45
49
  },
46
50
  "peerDependencies": {
47
- "@liteforge/core": ">=0.1.0"
51
+ "@liteforge/core": ">=0.1.0",
52
+ "@liteforge/runtime": ">=0.4.3"
53
+ },
54
+ "peerDependenciesMeta": {
55
+ "@liteforge/runtime": {
56
+ "optional": true
57
+ }
48
58
  },
49
59
  "devDependencies": {
50
- "@liteforge/core": "0.1.0"
60
+ "@liteforge/core": "0.1.0",
61
+ "@liteforge/runtime": "0.4.3"
51
62
  },
52
63
  "scripts": {
53
64
  "build": "tsc -p tsconfig.build.json",