@framv/slides 0.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/dist/cdn.d.ts ADDED
@@ -0,0 +1,5 @@
1
+ import "./slide.js";
2
+ import "./element.js";
3
+ export { FramvSlideElement } from "./slide.js";
4
+ export { FramvSlidesElement } from "./element.js";
5
+ //# sourceMappingURL=cdn.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cdn.d.ts","sourceRoot":"","sources":["../src/cdn.ts"],"names":[],"mappings":"AAAA,OAAO,YAAY,CAAC;AACpB,OAAO,cAAc,CAAC;AACtB,OAAO,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAC;AAC/C,OAAO,EAAE,kBAAkB,EAAE,MAAM,cAAc,CAAC"}
package/dist/cdn.js ADDED
@@ -0,0 +1,5 @@
1
+ import "./slide.js";
2
+ import "./element.js";
3
+ export { FramvSlideElement } from "./slide.js";
4
+ export { FramvSlidesElement } from "./element.js";
5
+ //# sourceMappingURL=cdn.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cdn.js","sourceRoot":"","sources":["../src/cdn.ts"],"names":[],"mappings":"AAAA,OAAO,YAAY,CAAC;AACpB,OAAO,cAAc,CAAC;AACtB,OAAO,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAC;AAC/C,OAAO,EAAE,kBAAkB,EAAE,MAAM,cAAc,CAAC"}
@@ -0,0 +1,53 @@
1
+ /**
2
+ * `<framv-slides>` — a slideshow presentation container.
3
+ *
4
+ * Attributes:
5
+ * transition — global transition: fade, slide, slide-up, zoom (default: slide)
6
+ * autoplay — advance slides automatically
7
+ * interval — autoplay interval in ms (default: 5000)
8
+ * controls — always show controls
9
+ * loop — loop back to first slide
10
+ * width — presentation width (default: 1920)
11
+ * height — presentation height (default: 1080)
12
+ *
13
+ * @example
14
+ * ```html
15
+ * <framv-slides controls width="1920" height="1080">
16
+ * <framv-slide background="#1a1a2e">
17
+ * <h1 style="color:white;font-size:64px">Title</h1>
18
+ * </framv-slide>
19
+ * <framv-slide background="#16213e">
20
+ * <h2 style="color:white;font-size:48px">Slide 2</h2>
21
+ * </framv-slide>
22
+ * </framv-slides>
23
+ * ```
24
+ */
25
+ export declare class FramvSlidesElement extends HTMLElement {
26
+ static observedAttributes: string[];
27
+ private _currentIndex;
28
+ private _slides;
29
+ private _stage;
30
+ private _controls;
31
+ private _counter;
32
+ private _progress;
33
+ private _prevBtn;
34
+ private _nextBtn;
35
+ private _fullscreenBtn;
36
+ private _exportBtn;
37
+ private _autoplayTimer;
38
+ private _exporting;
39
+ get currentIndex(): number;
40
+ get slideCount(): number;
41
+ get transition(): string;
42
+ connectedCallback(): void;
43
+ disconnectedCallback(): void;
44
+ attributeChangedCallback(name: string): void;
45
+ next(): void;
46
+ prev(): void;
47
+ goTo(index: number): void;
48
+ private _showSlide;
49
+ private _updateCounter;
50
+ private _toggleFullscreen;
51
+ private _export;
52
+ }
53
+ //# sourceMappingURL=element.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"element.d.ts","sourceRoot":"","sources":["../src/element.ts"],"names":[],"mappings":"AA0DA;;;;;;;;;;;;;;;;;;;;;;;GAuBG;AACH,qBAAa,kBAAmB,SAAQ,WAAW;IACjD,MAAM,CAAC,kBAAkB,WAAkB;IAE3C,OAAO,CAAC,aAAa,CAAK;IAC1B,OAAO,CAAC,OAAO,CAAgD;IAC/D,OAAO,CAAC,MAAM,CAAkB;IAChC,OAAO,CAAC,SAAS,CAAkB;IACnC,OAAO,CAAC,QAAQ,CAAmB;IACnC,OAAO,CAAC,SAAS,CAAkB;IACnC,OAAO,CAAC,QAAQ,CAAqB;IACrC,OAAO,CAAC,QAAQ,CAAqB;IACrC,OAAO,CAAC,cAAc,CAAqB;IAC3C,OAAO,CAAC,UAAU,CAAqB;IACvC,OAAO,CAAC,cAAc,CAA+C;IACrE,OAAO,CAAC,UAAU,CAAS;IAE3B,IAAI,YAAY,IAAI,MAAM,CAEzB;IACD,IAAI,UAAU,IAAI,MAAM,CAEvB;IACD,IAAI,UAAU,IAAI,MAAM,CAEvB;IAED,iBAAiB,IAAI,IAAI;IA8EzB,oBAAoB,IAAI,IAAI;IAI5B,wBAAwB,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI;IAQ5C,IAAI,IAAI,IAAI;IAQZ,IAAI,IAAI,IAAI;IAQZ,IAAI,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;IAMzB,OAAO,CAAC,UAAU;IAUlB,OAAO,CAAC,cAAc;IAQtB,OAAO,CAAC,iBAAiB;YAQX,OAAO;CA8BtB"}
@@ -0,0 +1,265 @@
1
+ const STYLES = `
2
+ :host {
3
+ display: block;
4
+ position: relative;
5
+ background: #000;
6
+ overflow: hidden;
7
+ font-family: system-ui, sans-serif;
8
+ }
9
+ .framv-slides-stage {
10
+ position: relative;
11
+ width: 100%;
12
+ height: 100%;
13
+ }
14
+ .framv-slides-controls {
15
+ position: absolute; bottom: 0; left: 0; right: 0;
16
+ display: flex; align-items: center; gap: 12px;
17
+ padding: 12px 20px;
18
+ background: linear-gradient(transparent, rgba(0,0,0,0.6));
19
+ color: #fff; font: 13px system-ui;
20
+ opacity: 0; transition: opacity 0.3s;
21
+ z-index: 20;
22
+ }
23
+ :host(:hover) .framv-slides-controls,
24
+ :host([controls]) .framv-slides-controls { opacity: 1; }
25
+ .framv-slides-controls button {
26
+ background: rgba(255,255,255,0.15); border: none;
27
+ color: #fff; cursor: pointer;
28
+ padding: 8px 14px; font: inherit; border-radius: 6px;
29
+ transition: background 0.2s;
30
+ }
31
+ .framv-slides-controls button:hover { background: rgba(255,255,255,0.3); }
32
+ .framv-slides-controls button:disabled { opacity: 0.3; cursor: default; }
33
+ .framv-counter {
34
+ margin: 0 auto; opacity: 0.7; font-variant-numeric: tabular-nums;
35
+ }
36
+ .framv-progress {
37
+ position: absolute; bottom: 0; left: 0;
38
+ height: 3px; background: #ff79c6;
39
+ transition: width 0.3s ease;
40
+ z-index: 21;
41
+ }
42
+ .framv-fullscreen-badge {
43
+ position: absolute; top: 12px; right: 12px;
44
+ background: rgba(0,0,0,0.5); color: #fff;
45
+ padding: 4px 12px; border-radius: 4px;
46
+ font: 11px system-ui; opacity: 0; transition: opacity 0.3s;
47
+ z-index: 15;
48
+ }
49
+ :host(:hover) .framv-fullscreen-badge { opacity: 1; }
50
+ .framv-exporting-overlay {
51
+ position: absolute; inset: 0;
52
+ background: rgba(0,0,0,0.8); display: flex;
53
+ align-items: center; justify-content: center;
54
+ color: #fff; font: 14px system-ui; z-index: 30;
55
+ gap: 8px;
56
+ }
57
+ `;
58
+ /**
59
+ * `<framv-slides>` — a slideshow presentation container.
60
+ *
61
+ * Attributes:
62
+ * transition — global transition: fade, slide, slide-up, zoom (default: slide)
63
+ * autoplay — advance slides automatically
64
+ * interval — autoplay interval in ms (default: 5000)
65
+ * controls — always show controls
66
+ * loop — loop back to first slide
67
+ * width — presentation width (default: 1920)
68
+ * height — presentation height (default: 1080)
69
+ *
70
+ * @example
71
+ * ```html
72
+ * <framv-slides controls width="1920" height="1080">
73
+ * <framv-slide background="#1a1a2e">
74
+ * <h1 style="color:white;font-size:64px">Title</h1>
75
+ * </framv-slide>
76
+ * <framv-slide background="#16213e">
77
+ * <h2 style="color:white;font-size:48px">Slide 2</h2>
78
+ * </framv-slide>
79
+ * </framv-slides>
80
+ * ```
81
+ */
82
+ export class FramvSlidesElement extends HTMLElement {
83
+ static observedAttributes = ["transition"];
84
+ _currentIndex = 0;
85
+ _slides = [];
86
+ _stage;
87
+ _controls;
88
+ _counter;
89
+ _progress;
90
+ _prevBtn;
91
+ _nextBtn;
92
+ _fullscreenBtn;
93
+ _exportBtn;
94
+ _autoplayTimer = null;
95
+ _exporting = false;
96
+ get currentIndex() {
97
+ return this._currentIndex;
98
+ }
99
+ get slideCount() {
100
+ return this._slides.length;
101
+ }
102
+ get transition() {
103
+ return this.getAttribute("transition") ?? "slide";
104
+ }
105
+ connectedCallback() {
106
+ const w = this.getAttribute("width") ?? "1920";
107
+ const h = this.getAttribute("height") ?? "1080";
108
+ this.style.aspectRatio = `${w} / ${h}`;
109
+ this.style.maxWidth = "100%";
110
+ this.innerHTML = `
111
+ <style>${STYLES}</style>
112
+ <div class="framv-fullscreen-badge">framv slides · ${w}x${h}</div>
113
+ <div class="framv-slides-stage"></div>
114
+ <div class="framv-progress"></div>
115
+ <div class="framv-slides-controls">
116
+ <button class="btn-prev">◀ Prev</button>
117
+ <button class="btn-next">Next ▶</button>
118
+ <span class="framv-counter">1 / 1</span>
119
+ <button class="btn-fullscreen">⛶ Fullscreen</button>
120
+ <button class="btn-export" style="border:1px solid #ff79c6;color:#ff79c6">⬇ Export PDF</button>
121
+ </div>
122
+ `;
123
+ this._stage = this.querySelector(".framv-slides-stage");
124
+ this._controls = this.querySelector(".framv-slides-controls");
125
+ this._counter = this.querySelector(".framv-counter");
126
+ this._progress = this.querySelector(".framv-progress");
127
+ this._prevBtn = this.querySelector(".btn-prev");
128
+ this._nextBtn = this.querySelector(".btn-next");
129
+ this._fullscreenBtn = this.querySelector(".btn-fullscreen");
130
+ this._exportBtn = this.querySelector(".btn-export");
131
+ // Move slide children into stage
132
+ this._slides = Array.from(this.querySelectorAll("framv-slide"));
133
+ this._slides.forEach((slide, i) => {
134
+ slide.setAttribute("transition", slide.getAttribute("transition") ?? this.transition);
135
+ this._stage.appendChild(slide);
136
+ });
137
+ // Show first slide
138
+ this._showSlide(0);
139
+ // Button events
140
+ this._prevBtn.addEventListener("click", () => this.prev());
141
+ this._nextBtn.addEventListener("click", () => this.next());
142
+ this._fullscreenBtn.addEventListener("click", () => this._toggleFullscreen());
143
+ this._exportBtn.addEventListener("click", () => this._export());
144
+ // Keyboard
145
+ this.addEventListener("keydown", (e) => {
146
+ if (e.key === "ArrowRight" || e.key === " ") {
147
+ e.preventDefault();
148
+ this.next();
149
+ }
150
+ if (e.key === "ArrowLeft") {
151
+ e.preventDefault();
152
+ this.prev();
153
+ }
154
+ if (e.key === "f" || e.key === "F") {
155
+ e.preventDefault();
156
+ this._toggleFullscreen();
157
+ }
158
+ });
159
+ // Click to advance (unless clicking a button)
160
+ this.addEventListener("click", (e) => {
161
+ const target = e.target;
162
+ if (target.closest("button, .framv-slides-controls"))
163
+ return;
164
+ this.next();
165
+ });
166
+ // Autoplay
167
+ if (this.hasAttribute("autoplay")) {
168
+ const interval = parseInt(this.getAttribute("interval") ?? "5000");
169
+ this._autoplayTimer = setInterval(() => this.next(), interval);
170
+ }
171
+ this._updateCounter();
172
+ }
173
+ disconnectedCallback() {
174
+ if (this._autoplayTimer)
175
+ clearInterval(this._autoplayTimer);
176
+ }
177
+ attributeChangedCallback(name) {
178
+ if (name === "transition" && this._slides.length > 0) {
179
+ this._slides.forEach((s) => {
180
+ if (!s.hasAttribute("transition"))
181
+ s.setAttribute("transition", this.transition);
182
+ });
183
+ }
184
+ }
185
+ next() {
186
+ if (this._currentIndex < this._slides.length - 1) {
187
+ this._showSlide(this._currentIndex + 1);
188
+ }
189
+ else if (this.hasAttribute("loop")) {
190
+ this._showSlide(0);
191
+ }
192
+ }
193
+ prev() {
194
+ if (this._currentIndex > 0) {
195
+ this._showSlide(this._currentIndex - 1);
196
+ }
197
+ else if (this.hasAttribute("loop")) {
198
+ this._showSlide(this._slides.length - 1);
199
+ }
200
+ }
201
+ goTo(index) {
202
+ if (index >= 0 && index < this._slides.length) {
203
+ this._showSlide(index);
204
+ }
205
+ }
206
+ _showSlide(index) {
207
+ if (this._slides.length === 0)
208
+ return;
209
+ this._slides.forEach((s) => (s.active = false));
210
+ this._currentIndex = index;
211
+ this._slides[index].active = true;
212
+ this._updateCounter();
213
+ }
214
+ _updateCounter() {
215
+ if (this._counter)
216
+ this._counter.textContent = `${this._currentIndex + 1} / ${this._slides.length}`;
217
+ if (this._progress)
218
+ this._progress.style.width = `${((this._currentIndex + 1) / this._slides.length) * 100}%`;
219
+ if (this._prevBtn)
220
+ this._prevBtn.disabled = this._currentIndex === 0 && !this.hasAttribute("loop");
221
+ if (this._nextBtn)
222
+ this._nextBtn.disabled = this._currentIndex === this._slides.length - 1 && !this.hasAttribute("loop");
223
+ }
224
+ _toggleFullscreen() {
225
+ if (document.fullscreenElement) {
226
+ document.exitFullscreen();
227
+ }
228
+ else {
229
+ this.requestFullscreen();
230
+ }
231
+ }
232
+ async _export() {
233
+ if (this._exporting)
234
+ return;
235
+ this._exporting = true;
236
+ const w = parseInt(this.getAttribute("width") ?? "1920");
237
+ const h = parseInt(this.getAttribute("height") ?? "1080");
238
+ const overlay = document.createElement("div");
239
+ overlay.className = "framv-exporting-overlay";
240
+ this.appendChild(overlay);
241
+ try {
242
+ const { jsPDF } = await import("jspdf");
243
+ const pdf = new jsPDF({ orientation: "l", unit: "px", format: [w, h] });
244
+ for (let i = 0; i < this._slides.length; i++) {
245
+ if (i > 0)
246
+ pdf.addPage();
247
+ const slide = this._slides[i];
248
+ overlay.textContent = `Exporting slide ${i + 1}/${this._slides.length}...`;
249
+ await pdf.html(slide, { x: 0, y: 0, width: w, windowWidth: w });
250
+ }
251
+ pdf.save("framv-presentation.pdf");
252
+ }
253
+ catch (err) {
254
+ console.error("Export failed:", err);
255
+ }
256
+ finally {
257
+ overlay.remove();
258
+ this._exporting = false;
259
+ }
260
+ }
261
+ }
262
+ if (!customElements.get("framv-slides")) {
263
+ customElements.define("framv-slides", FramvSlidesElement);
264
+ }
265
+ //# sourceMappingURL=element.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"element.js","sourceRoot":"","sources":["../src/element.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ export { FramvSlideElement } from "./slide.js";
2
+ export { FramvSlidesElement } from "./element.js";
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAC;AAC/C,OAAO,EAAE,kBAAkB,EAAE,MAAM,cAAc,CAAC"}
package/dist/index.js ADDED
@@ -0,0 +1,3 @@
1
+ export { FramvSlideElement } from "./slide.js";
2
+ export { FramvSlidesElement } from "./element.js";
3
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAC;AAC/C,OAAO,EAAE,kBAAkB,EAAE,MAAM,cAAc,CAAC"}
@@ -0,0 +1,24 @@
1
+ /**
2
+ * `<framv-slide>` — a single slide inside `<framv-slides>`.
3
+ *
4
+ * Attributes:
5
+ * background — CSS background value for the slide
6
+ * transition — fade, slide-up, zoom, or slide (default: slide)
7
+ *
8
+ * @example
9
+ * ```html
10
+ * <framv-slide background="linear-gradient(135deg, #667eea, #764ba2)">
11
+ * <h1>My Title</h1>
12
+ * <p>Slide content</p>
13
+ * </framv-slide>
14
+ * ```
15
+ */
16
+ export declare class FramvSlideElement extends HTMLElement {
17
+ static observedAttributes: string[];
18
+ connectedCallback(): void;
19
+ attributeChangedCallback(name: string): void;
20
+ set active(val: boolean);
21
+ get active(): boolean;
22
+ private _applyBackground;
23
+ }
24
+ //# sourceMappingURL=slide.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"slide.d.ts","sourceRoot":"","sources":["../src/slide.ts"],"names":[],"mappings":"AAoCA;;;;;;;;;;;;;;GAcG;AACH,qBAAa,iBAAkB,SAAQ,WAAW;IAChD,MAAM,CAAC,kBAAkB,WAA0C;IAEnE,iBAAiB,IAAI,IAAI;IAOzB,wBAAwB,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI;IAI5C,IAAI,MAAM,CAAC,GAAG,EAAE,OAAO,EAGtB;IAED,IAAI,MAAM,IAAI,OAAO,CAEpB;IAED,OAAO,CAAC,gBAAgB;CAIzB"}
package/dist/slide.js ADDED
@@ -0,0 +1,81 @@
1
+ const STYLES = `
2
+ :host {
3
+ display: flex;
4
+ position: absolute;
5
+ inset: 0;
6
+ align-items: center;
7
+ justify-content: center;
8
+ flex-direction: column;
9
+ opacity: 0;
10
+ transition: opacity 0.4s ease, transform 0.4s ease;
11
+ transform: translateX(30px);
12
+ pointer-events: none;
13
+ }
14
+ :host([active]) {
15
+ opacity: 1;
16
+ transform: translateX(0);
17
+ pointer-events: auto;
18
+ }
19
+ :host([transition="fade"]) {
20
+ transition: opacity 0.5s ease;
21
+ transform: none;
22
+ }
23
+ :host([transition="slide-up"]) {
24
+ transform: translateY(40px);
25
+ }
26
+ :host([transition="slide-up"][active]) {
27
+ transform: translateY(0);
28
+ }
29
+ :host([transition="zoom"]) {
30
+ transform: scale(0.9);
31
+ }
32
+ :host([transition="zoom"][active]) {
33
+ transform: scale(1);
34
+ }
35
+ `;
36
+ /**
37
+ * `<framv-slide>` — a single slide inside `<framv-slides>`.
38
+ *
39
+ * Attributes:
40
+ * background — CSS background value for the slide
41
+ * transition — fade, slide-up, zoom, or slide (default: slide)
42
+ *
43
+ * @example
44
+ * ```html
45
+ * <framv-slide background="linear-gradient(135deg, #667eea, #764ba2)">
46
+ * <h1>My Title</h1>
47
+ * <p>Slide content</p>
48
+ * </framv-slide>
49
+ * ```
50
+ */
51
+ export class FramvSlideElement extends HTMLElement {
52
+ static observedAttributes = ["background", "active", "transition"];
53
+ connectedCallback() {
54
+ if (!this.shadowRoot) {
55
+ this.attachShadow({ mode: "open" }).innerHTML = `<style>${STYLES}</style><slot></slot>`;
56
+ }
57
+ this._applyBackground();
58
+ }
59
+ attributeChangedCallback(name) {
60
+ if (name === "background")
61
+ this._applyBackground();
62
+ }
63
+ set active(val) {
64
+ if (val)
65
+ this.setAttribute("active", "");
66
+ else
67
+ this.removeAttribute("active");
68
+ }
69
+ get active() {
70
+ return this.hasAttribute("active");
71
+ }
72
+ _applyBackground() {
73
+ const bg = this.getAttribute("background");
74
+ if (bg)
75
+ this.style.background = bg;
76
+ }
77
+ }
78
+ if (!customElements.get("framv-slide")) {
79
+ customElements.define("framv-slide", FramvSlideElement);
80
+ }
81
+ //# sourceMappingURL=slide.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"slide.js","sourceRoot":"","sources":["../src/slide.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,GAAG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAkCd,CAAC;AAEF;;;;;;;;;;;;;;GAcG;AACH,MAAM,OAAO,iBAAkB,SAAQ,WAAW;IAChD,MAAM,CAAC,kBAAkB,GAAG,CAAC,YAAY,EAAE,QAAQ,EAAE,YAAY,CAAC,CAAC;IAEnE,iBAAiB;QACf,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC;YACrB,IAAI,CAAC,YAAY,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC,CAAC,SAAS,GAAG,UAAU,MAAM,uBAAuB,CAAC;QAC1F,CAAC;QACD,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC1B,CAAC;IAED,wBAAwB,CAAC,IAAY;QACnC,IAAI,IAAI,KAAK,YAAY;YAAE,IAAI,CAAC,gBAAgB,EAAE,CAAC;IACrD,CAAC;IAED,IAAI,MAAM,CAAC,GAAY;QACrB,IAAI,GAAG;YAAE,IAAI,CAAC,YAAY,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;;YACpC,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAC;IACtC,CAAC;IAED,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;IACrC,CAAC;IAEO,gBAAgB;QACtB,MAAM,EAAE,GAAG,IAAI,CAAC,YAAY,CAAC,YAAY,CAAC,CAAC;QAC3C,IAAI,EAAE;YAAE,IAAI,CAAC,KAAK,CAAC,UAAU,GAAG,EAAE,CAAC;IACrC,CAAC;;AAGH,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,aAAa,CAAC,EAAE,CAAC;IACvC,cAAc,CAAC,MAAM,CAAC,aAAa,EAAE,iBAAiB,CAAC,CAAC;AAC1D,CAAC"}
package/package.json ADDED
@@ -0,0 +1,42 @@
1
+ {
2
+ "name": "@framv/slides",
3
+ "version": "0.1.0",
4
+ "private": false,
5
+ "type": "module",
6
+ "main": "dist/index.js",
7
+ "types": "dist/index.d.ts",
8
+ "exports": {
9
+ ".": {
10
+ "types": "./dist/index.d.ts",
11
+ "import": "./dist/index.js",
12
+ "default": "./dist/index.js"
13
+ }
14
+ },
15
+ "files": [
16
+ "dist"
17
+ ],
18
+ "scripts": {
19
+ "build": "tsc -b && npm run bundle",
20
+ "prepublishOnly": "npm run build",
21
+ "bundle": "esbuild src/index.ts --bundle --format=esm --external:@framv/core --external:jspdf --outfile=dist/bundle.esm.js && esbuild src/cdn.ts --bundle --format=iife --global-name=FramvSlides --outfile=dist/bundle.iife.js"
22
+ },
23
+ "dependencies": {
24
+ "@framv/core": "*",
25
+ "jspdf": "^4.2.0"
26
+ },
27
+ "devDependencies": {
28
+ "esbuild": "^0.27.2",
29
+ "serve": "^14.2.5",
30
+ "typescript": "^5.9.3"
31
+ },
32
+ "author": "Mens Reversa",
33
+ "license": "MIT",
34
+ "repository": {
35
+ "type": "git",
36
+ "url": "https://github.com/mensreversa/framv.git",
37
+ "directory": "packages/slides"
38
+ },
39
+ "bugs": {
40
+ "url": "https://github.com/mensreversa/framv/issues"
41
+ }
42
+ }