@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/LICENSE +21 -0
- package/README.md +1 -0
- package/dist/bundle.esm.js +287 -0
- package/dist/bundle.iife.js +33425 -0
- package/dist/cdn.d.ts +5 -0
- package/dist/cdn.d.ts.map +1 -0
- package/dist/cdn.js +5 -0
- package/dist/cdn.js.map +1 -0
- package/dist/element.d.ts +53 -0
- package/dist/element.d.ts.map +1 -0
- package/dist/element.js +265 -0
- package/dist/element.js.map +1 -0
- package/dist/index.d.ts +3 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +3 -0
- package/dist/index.js.map +1 -0
- package/dist/slide.d.ts +24 -0
- package/dist/slide.d.ts.map +1 -0
- package/dist/slide.js +81 -0
- package/dist/slide.js.map +1 -0
- package/package.json +42 -0
package/dist/cdn.d.ts
ADDED
|
@@ -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
package/dist/cdn.js.map
ADDED
|
@@ -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"}
|
package/dist/element.js
ADDED
|
@@ -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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"}
|
package/dist/index.d.ts
ADDED
|
@@ -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 @@
|
|
|
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"}
|
package/dist/slide.d.ts
ADDED
|
@@ -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
|
+
}
|