vidply 1.0.5 → 1.0.6

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.
@@ -1,183 +1,183 @@
1
- /**
2
- * SVG Icon Library for VidPly
3
- * Optimized with common viewBox and fill attributes
4
- */
5
-
6
- // SVG paths only (viewBox and fill added by wrapper)
7
- const iconPaths = {
8
- play: `<path d="M8 5v14l11-7z"/>`,
9
-
10
- pause: `<path d="M6 4h4v16H6V4zm8 0h4v16h-4V4z"/>`,
11
-
12
- stop: `<rect x="6" y="6" width="12" height="12"/>`,
13
-
14
- rewind: `<path d="M11 18V6l-8.5 6 8.5 6zm.5-6l8.5 6V6l-8.5 6z"/>`,
15
-
16
- forward: `<path d="M4 18l8.5-6L4 6v12zm9-12v12l8.5-6L13 6z"/>`,
17
-
18
- skipPrevious: `<path d="M6 6h2v12H6V6zm3 6l8.5 6V6L9 12z"/>`,
19
-
20
- skipNext: `<path d="M16 6h2v12h-2V6zM6 6l8.5 6L6 18V6z"/>`,
21
-
22
- restart: `<path d="M12 5V1L7 6l5 5V7c3.31 0 6 2.69 6 6s-2.69 6-6 6-6-2.69-6-6H4c0 4.42 3.58 8 8 8s8-3.58 8-8-3.58-8-8-8z"/>`,
23
-
24
- volumeHigh: `<path d="M3 9v6h4l5 5V4L7 9H3zm13.5 3c0-1.77-1.02-3.29-2.5-4.03v8.05c1.48-.73 2.5-2.25 2.5-4.02zM14 3.23v2.06c2.89.86 5 3.54 5 6.71s-2.11 5.85-5 6.71v2.06c4.01-.91 7-4.49 7-8.77s-2.99-7.86-7-8.77z"/>`,
25
-
26
- volumeMedium: `<path d="M3 9v6h4l5 5V4L7 9H3zm13.5 3c0-1.77-1.02-3.29-2.5-4.03v8.05c1.48-.73 2.5-2.25 2.5-4.02z"/>`,
27
-
28
- volumeLow: `<path d="M7 9v6h4l5 5V4l-5 5H7z"/>`,
29
-
30
- volumeMuted: `<path d="M16.5 12c0-1.77-1.02-3.29-2.5-4.03v2.21l2.45 2.45c.03-.2.05-.41.05-.63zm2.5 0c0 .94-.2 1.82-.54 2.64l1.51 1.51C20.63 14.91 21 13.5 21 12c0-4.28-2.99-7.86-7-8.77v2.06c2.89.86 5 3.54 5 6.71zM4.27 3L3 4.27 7.73 9H3v6h4l5 5v-6.73l4.25 4.25c-.67.52-1.42.93-2.25 1.18v2.06c1.38-.31 2.63-.95 3.69-1.81L19.73 21 21 19.73l-9-9L4.27 3zM12 4L9.91 6.09 12 8.18V4z"/>`,
31
-
32
- fullscreen: `<path d="M7 14H5v5h5v-2H7v-3zm-2-4h2V7h3V5H5v5zm12 7h-3v2h5v-5h-2v3zM14 5v2h3v3h2V5h-5z"/>`,
33
-
34
- fullscreenExit: `<path d="M5 16h3v3h2v-5H5v2zm3-8H5v2h5V5H8v3zm6 11h2v-3h3v-2h-5v5zm2-11V5h-2v5h5V8h-3z"/>`,
35
-
36
- settings: `<path d="M19.14 12.94c.04-.3.06-.61.06-.94 0-.32-.02-.64-.07-.94l2.03-1.58c.18-.14.23-.41.12-.61l-1.92-3.32c-.12-.22-.37-.29-.59-.22l-2.39.96c-.5-.38-1.03-.7-1.62-.94L14.4 2.81c-.04-.24-.24-.41-.48-.41h-3.84c-.24 0-.43.17-.47.41l-.36 2.54c-.59.24-1.13.57-1.62.94l-2.39-.96c-.22-.08-.47 0-.59.22L2.74 8.87c-.12.21-.08.47.12.61l2.03 1.58c-.05.3-.09.63-.09.94s.02.64.07.94l-2.03 1.58c-.18.14-.23.41-.12.61l1.92 3.32c.12.22.37.29.59.22l2.39-.96c.5.38 1.03.7 1.62.94l.36 2.54c.05.24.24.41.48.41h3.84c.24 0 .44-.17.47-.41l.36-2.54c.59-.24 1.13-.56 1.62-.94l2.39.96c.22.08.47 0 .59-.22l1.92-3.32c.12-.22.07-.47-.12-.61l-2.01-1.58zM12 15.6c-1.98 0-3.6-1.62-3.6-3.6s1.62-3.6 3.6-3.6 3.6 1.62 3.6 3.6-1.62 3.6-3.6 3.6z"/>`,
37
-
38
- captions: `<path d="M19 4H5c-1.11 0-2 .9-2 2v12c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2zm-8 7H9.5v-.5h-2v3h2V13H11v1c0 .55-.45 1-1 1H7c-.55 0-1-.45-1-1v-4c0-.55.45-1 1-1h3c.55 0 1 .45 1 1v1zm7 0h-1.5v-.5h-2v3h2V13H18v1c0 .55-.45 1-1 1h-3c-.55 0-1-.45-1-1v-4c0-.55.45-1 1-1h3c.55 0 1 .45 1 1v1z"/>`,
39
-
40
- captionsOff: `<path d="M19 4H5c-1.11 0-2 .9-2 2v12c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2zm-8 7H9.5v-.5h-2v3h2V13H11v1c0 .55-.45 1-1 1H7c-.55 0-1-.45-1-1v-4c0-.55.45-1 1-1h3c.55 0 1 .45 1 1v1zm7 0h-1.5v-.5h-2v3h2V13H18v1c0 .55-.45 1-1 1h-3c-.55 0-1-.45-1-1v-4c0-.55.45-1 1-1h3c.55 0 1 .45 1 1v1z"/><path d="M0 0h24v24H0z" fill="none"/>`,
41
-
42
- pip: `<path d="M19 7h-8v6h8V7zm2-4H3c-1.1 0-2 .9-2 2v14c0 1.1.9 1.98 2 1.98h18c1.1 0 2-.88 2-1.98V5c0-1.1-.9-2-2-2zm0 16.01H3V4.98h18v14.03z"/>`,
43
-
44
- speed: `<path d="M20.38 8.57l-1.23 1.85a8 8 0 0 1-.22 7.58H5.07A8 8 0 0 1 15.58 6.85l1.85-1.23A10 10 0 0 0 3.35 19a2 2 0 0 0 1.72 1h13.85a2 2 0 0 0 1.74-1 10 10 0 0 0-.27-10.44z"/><path d="M10.59 15.41a2 2 0 0 0 2.83 0l5.66-8.49-8.49 5.66a2 2 0 0 0 0 2.83z"/>`,
45
-
46
- close: `<path d="M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12z"/>`,
47
-
48
- check: `<path d="M9 16.17L4.83 12l-1.42 1.41L9 19 21 7l-1.41-1.41z"/>`,
49
-
50
- arrowUp: `<path d="M7 14l5-5 5 5z"/>`,
51
-
52
- arrowDown: `<path d="M7 10l5 5 5-5z"/>`,
53
-
54
- arrowLeft: `<path d="M15.41 7.41L14 6l-6 6 6 6 1.41-1.41L10.83 12z"/>`,
55
-
56
- arrowRight: `<path d="M10 6L8.59 7.41 13.17 12l-4.58 4.59L10 18l6-6z"/>`,
57
-
58
- loading: `<path d="M12 4V1L8 5l4 4V6c3.31 0 6 2.69 6 6 0 1.01-.25 1.97-.7 2.8l1.46 1.46C19.54 15.03 20 13.57 20 12c0-4.42-3.58-8-8-8zm0 14c-3.31 0-6-2.69-6-6 0-1.01.25-1.97.7-2.8L5.24 7.74C4.46 8.97 4 10.43 4 12c0 4.42 3.58 8 8 8v3l4-4-4-4v3z"/>`,
59
-
60
- error: `<path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm1 15h-2v-2h2v2zm0-4h-2V7h2v6z"/>`,
61
-
62
- download: `<path d="M19 9h-4V3H9v6H5l7 7 7-7zM5 18v2h14v-2H5z"/>`,
63
-
64
- link: `<path d="M3.9 12c0-1.71 1.39-3.1 3.1-3.1h4V7H7c-2.76 0-5 2.24-5 5s2.24 5 5 5h4v-1.9H7c-1.71 0-3.1-1.39-3.1-3.1zM8 13h8v-2H8v2zm9-6h-4v1.9h4c1.71 0 3.1 1.39 3.1 3.1s-1.39 3.1-3.1 3.1h-4V17h4c2.76 0 5-2.24 5-5s-2.24-5-5-5z"/>`,
65
-
66
- playlist: `<path d="M15 6H3v2h12V6zm0 4H3v2h12v-2zM3 16h8v-2H3v2zM17 6v8.18c-.31-.11-.65-.18-1-.18-1.66 0-3 1.34-3 3s1.34 3 3 3 3-1.34 3-3V8h3V6h-5z"/>`,
67
-
68
- language: `<path d="M11.99 2C6.47 2 2 6.48 2 12s4.47 10 9.99 10C17.52 22 22 17.52 22 12S17.52 2 11.99 2zm6.93 6h-2.95c-.32-1.25-.78-2.45-1.38-3.56 1.84.63 3.37 1.91 4.33 3.56zM12 4.04c.83 1.2 1.48 2.53 1.91 3.96h-3.82c.43-1.43 1.08-2.76 1.91-3.96zM4.26 14C4.1 13.36 4 12.69 4 12s.1-1.36.26-2h3.38c-.08.66-.14 1.32-.14 2 0 .68.06 1.34.14 2H4.26zm.82 2h2.95c.32 1.25.78 2.45 1.38 3.56-1.84-.63-3.37-1.9-4.33-3.56zm2.95-8H5.08c.96-1.66 2.49-2.93 4.33-3.56C8.81 5.55 8.35 6.75 8.03 8zM12 19.96c-.83-1.2-1.48-2.53-1.91-3.96h3.82c-.43 1.43-1.08 2.76-1.91 3.96zM14.34 14H9.66c-.09-.66-.16-1.32-.16-2 0-.68.07-1.35.16-2h4.68c.09.65.16 1.32.16 2 0 .68-.07 1.34-.16 2zm.25 5.56c.6-1.11 1.06-2.31 1.38-3.56h2.95c-.96 1.65-2.49 2.93-4.33 3.56zM16.36 14c.08-.66.14-1.32.14-2 0-.68-.06-1.34-.14-2h3.38c.16.64.26 1.31.26 2s-.1 1.36-.26 2h-3.38z"/>`,
69
-
70
- hd: `<path d="M19 3H5c-1.11 0-2 .9-2 2v14c0 1.1.89 2 2 2h14c1.11 0 2-.9 2-2V5c0-1.1-.89-2-2-2zm-8 12H9.5v-2h-2v2H6V9h1.5v2.5h2V9H11v6zm7-1c0 .55-.45 1-1 1h-.75v1.5h-1.5V15H14c-.55 0-1-.45-1-1v-4c0-.55.45-1 1-1h3c.55 0 1 .45 1 1v4zm-3.5-.5h2v-3h-2v3z"/>`,
71
-
72
- transcript: `<path d="M14 2H6c-1.1 0-1.99.9-1.99 2L4 20c0 1.1.89 2 1.99 2H18c1.1 0 2-.9 2-2V8l-6-6zm2 16H8v-2h8v2zm0-4H8v-2h8v2zm-3-5V3.5L18.5 9H13z"/>`,
73
-
74
- audioDescription: `<path d="M12 3v9.28c-.47-.17-.97-.28-1.5-.28C8.01 12 6 14.01 6 16.5S8.01 21 10.5 21c2.31 0 4.2-1.75 4.45-4H15V6h4V3h-7z"/><path d="M10.5 19c-1.38 0-2.5-1.12-2.5-2.5s1.12-2.5 2.5-2.5 2.5 1.12 2.5 2.5-1.12 2.5-2.5 2.5z"/>`,
75
-
76
- audioDescriptionOn: `<path d="M12 3v9.28c-.47-.17-.97-.28-1.5-.28C8.01 12 6 14.01 6 16.5S8.01 21 10.5 21c2.31 0 4.2-1.75 4.45-4H15V6h4V3h-7z"/><path d="M10.5 19c-1.38 0-2.5-1.12-2.5-2.5s1.12-2.5 2.5-2.5 2.5 1.12 2.5 2.5-1.12 2.5-2.5 2.5z"/><circle cx="19" cy="16" r="3" fill="#3b82f6"/><path d="M18.5 17.5l1-1 1.5 1.5" stroke="white" stroke-width="1.5" fill="none" stroke-linecap="round" stroke-linejoin="round"/>`,
77
-
78
- signLanguage: `<g transform="scale(1.5)"><path d="M16 11.3c-.1-.9-4.8 1.3-5.4 1.1-2.6-1 5.8-1.3 5.1-2.9s-5.1 1.5-6 1.4C6.5 9.4 16.5 9.1 13.5 8c-1.9-.6-8.8 2.9-6.8.4.7-.6.7-1.9-.7-1.7-9.7 7.2-.7 12.2 8.8 7 0-1.3-3.5.4-4.1.4-2.6 0 5.6-2 5.4-3ZM3.9 7.8c3.2-4.2 3.7 1.2 6 .1s.2-.2.2-.3c.7-2.7 2.5-7.5-1.5-1.3-1.6 0 1.1-4 1-4.6C8.9-1 7.3 4.4 7.2 4.9c-1.6.7-.9-1.4-.7-1.5 3-6-.6-3.1-.9.4-2.5 1.8 0-2.8 0-3.5C2.8-.9 4 9.4 1.1 4.9S.1 4.6 0 5c-.4 2.7 2.6 7.2 3.9 2.8Z"/></g>`,
79
-
80
- signLanguageOn: `<g transform="scale(1.5)"><path d="M16 11.3c-.1-.9-4.8 1.3-5.4 1.1-2.6-1 5.8-1.3 5.1-2.9s-5.1 1.5-6 1.4C6.5 9.4 16.5 9.1 13.5 8c-1.9-.6-8.8 2.9-6.8.4.7-.6.7-1.9-.7-1.7-9.7 7.2-.7 12.2 8.8 7 0-1.3-3.5.4-4.1.4-2.6 0 5.6-2 5.4-3ZM3.9 7.8c3.2-4.2 3.7 1.2 6 .1s.2-.2.2-.3c.7-2.7 2.5-7.5-1.5-1.3-1.6 0 1.1-4 1-4.6C8.9-1 7.3 4.4 7.2 4.9c-1.6.7-.9-1.4-.7-1.5 3-6-.6-3.1-.9.4-2.5 1.8 0-2.8 0-3.5C2.8-.9 4 9.4 1.1 4.9S.1 4.6 0 5c-.4 2.7 2.6 7.2 3.9 2.8Z"/></g>`,
81
-
82
- speaker: `<path d="M3 9v6h4l5 5V4L7 9H3zm13.5 3c0-1.77-1.02-3.29-2.5-4.03v8.05c1.48-.73 2.5-2.25 2.5-4.02z"/>`,
83
-
84
- music: `<path d="M12 3v9.28c-.47-.17-.97-.28-1.5-.28C8.01 12 6 14.01 6 16.5S8.01 21 10.5 21c2.31 0 4.2-1.75 4.45-4H15V6h4V3h-7zm-1.5 16c-1.38 0-2.5-1.12-2.5-2.5s1.12-2.5 2.5-2.5 2.5 1.12 2.5 2.5-1.12 2.5-2.5 2.5z"/>`,
85
-
86
- moreVertical: `<path d="M12 8c1.1 0 2-.9 2-2s-.9-2-2-2-2 .9-2 2 .9 2 2 2zm0 2c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm0 6c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2z"/>`,
87
-
88
- moreHorizontal: `<path d="M6 10c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm12 0c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm-6 0c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2z"/>`
89
- };
90
-
91
- // Optimized wrapper that adds common SVG attributes
92
- const svgWrapper = (paths) => `<svg viewBox="0 0 24 24" fill="currentColor">${paths}</svg>`;
93
-
94
- // Export Icons object with SVG wrappers
95
- export const Icons = Object.fromEntries(
96
- Object.entries(iconPaths).map(([key, value]) => [key, svgWrapper(value)])
97
- );
98
-
99
- export function getIcon(name) {
100
- return Icons[name] || Icons.play;
101
- }
102
-
103
- export function createIconElement(name, className = '') {
104
- const wrapper = document.createElement('span');
105
- wrapper.className = `vidply-icon ${className}`.trim();
106
- wrapper.innerHTML = getIcon(name);
107
- wrapper.setAttribute('aria-hidden', 'true');
108
- return wrapper;
109
- }
110
-
111
- /**
112
- * Create the large centered play button overlay (complete SVG)
113
- * @returns {SVGElement} Complete SVG element with circle background and play icon
114
- */
115
- export function createPlayOverlay() {
116
- const svg = document.createElementNS('http://www.w3.org/2000/svg', 'svg');
117
- svg.setAttribute('class', 'vidply-play-overlay');
118
- svg.setAttribute('viewBox', '0 0 80 80');
119
- svg.setAttribute('width', '80');
120
- svg.setAttribute('height', '80');
121
- svg.setAttribute('aria-hidden', 'true');
122
- svg.setAttribute('role', 'presentation');
123
- svg.style.cursor = 'pointer';
124
-
125
- // Create filter for drop shadow
126
- const defs = document.createElementNS('http://www.w3.org/2000/svg', 'defs');
127
- const filterId = `vidply-play-shadow-${Math.random().toString(36).substr(2, 9)}`;
128
- const filter = document.createElementNS('http://www.w3.org/2000/svg', 'filter');
129
- filter.setAttribute('id', filterId);
130
- filter.setAttribute('x', '-50%');
131
- filter.setAttribute('y', '-50%');
132
- filter.setAttribute('width', '200%');
133
- filter.setAttribute('height', '200%');
134
-
135
- const feGaussianBlur = document.createElementNS('http://www.w3.org/2000/svg', 'feGaussianBlur');
136
- feGaussianBlur.setAttribute('in', 'SourceAlpha');
137
- feGaussianBlur.setAttribute('stdDeviation', '3');
138
-
139
- const feOffset = document.createElementNS('http://www.w3.org/2000/svg', 'feOffset');
140
- feOffset.setAttribute('dx', '0');
141
- feOffset.setAttribute('dy', '2');
142
- feOffset.setAttribute('result', 'offsetblur');
143
-
144
- const feComponentTransfer = document.createElementNS('http://www.w3.org/2000/svg', 'feComponentTransfer');
145
- const feFuncA = document.createElementNS('http://www.w3.org/2000/svg', 'feFuncA');
146
- feFuncA.setAttribute('type', 'linear');
147
- feFuncA.setAttribute('slope', '0.3');
148
- feComponentTransfer.appendChild(feFuncA);
149
-
150
- const feMerge = document.createElementNS('http://www.w3.org/2000/svg', 'feMerge');
151
- const feMergeNode1 = document.createElementNS('http://www.w3.org/2000/svg', 'feMergeNode');
152
- const feMergeNode2 = document.createElementNS('http://www.w3.org/2000/svg', 'feMergeNode');
153
- feMergeNode2.setAttribute('in', 'SourceGraphic');
154
- feMerge.appendChild(feMergeNode1);
155
- feMerge.appendChild(feMergeNode2);
156
-
157
- filter.appendChild(feGaussianBlur);
158
- filter.appendChild(feOffset);
159
- filter.appendChild(feComponentTransfer);
160
- filter.appendChild(feMerge);
161
- defs.appendChild(filter);
162
- svg.appendChild(defs);
163
-
164
- // White circle background
165
- const circle = document.createElementNS('http://www.w3.org/2000/svg', 'circle');
166
- circle.setAttribute('cx', '40');
167
- circle.setAttribute('cy', '40');
168
- circle.setAttribute('r', '40');
169
- circle.setAttribute('fill', 'rgba(255, 255, 255, 0.95)');
170
- circle.setAttribute('filter', `url(#${filterId})`);
171
- circle.setAttribute('class', 'vidply-play-overlay-bg');
172
- svg.appendChild(circle);
173
-
174
- // Play icon triangle (centered with optical adjustment)
175
- const playTriangle = document.createElementNS('http://www.w3.org/2000/svg', 'polygon');
176
- playTriangle.setAttribute('points', '32,28 32,52 54,40');
177
- playTriangle.setAttribute('fill', '#0a406e');
178
- playTriangle.setAttribute('class', 'vidply-play-overlay-icon');
179
- svg.appendChild(playTriangle);
180
-
181
- return svg;
182
- }
183
-
1
+ /**
2
+ * SVG Icon Library for VidPly
3
+ * Optimized with common viewBox and fill attributes
4
+ */
5
+
6
+ // SVG paths only (viewBox and fill added by wrapper)
7
+ const iconPaths = {
8
+ play: `<path d="M8 5v14l11-7z"/>`,
9
+
10
+ pause: `<path d="M6 4h4v16H6V4zm8 0h4v16h-4V4z"/>`,
11
+
12
+ stop: `<rect x="6" y="6" width="12" height="12"/>`,
13
+
14
+ rewind: `<path d="M11 18V6l-8.5 6 8.5 6zm.5-6l8.5 6V6l-8.5 6z"/>`,
15
+
16
+ forward: `<path d="M4 18l8.5-6L4 6v12zm9-12v12l8.5-6L13 6z"/>`,
17
+
18
+ skipPrevious: `<path d="M6 6h2v12H6V6zm3 6l8.5 6V6L9 12z"/>`,
19
+
20
+ skipNext: `<path d="M16 6h2v12h-2V6zM6 6l8.5 6L6 18V6z"/>`,
21
+
22
+ restart: `<path d="M12 5V1L7 6l5 5V7c3.31 0 6 2.69 6 6s-2.69 6-6 6-6-2.69-6-6H4c0 4.42 3.58 8 8 8s8-3.58 8-8-3.58-8-8-8z"/>`,
23
+
24
+ volumeHigh: `<path d="M3 9v6h4l5 5V4L7 9H3zm13.5 3c0-1.77-1.02-3.29-2.5-4.03v8.05c1.48-.73 2.5-2.25 2.5-4.02zM14 3.23v2.06c2.89.86 5 3.54 5 6.71s-2.11 5.85-5 6.71v2.06c4.01-.91 7-4.49 7-8.77s-2.99-7.86-7-8.77z"/>`,
25
+
26
+ volumeMedium: `<path d="M3 9v6h4l5 5V4L7 9H3zm13.5 3c0-1.77-1.02-3.29-2.5-4.03v8.05c1.48-.73 2.5-2.25 2.5-4.02z"/>`,
27
+
28
+ volumeLow: `<path d="M7 9v6h4l5 5V4l-5 5H7z"/>`,
29
+
30
+ volumeMuted: `<path d="M16.5 12c0-1.77-1.02-3.29-2.5-4.03v2.21l2.45 2.45c.03-.2.05-.41.05-.63zm2.5 0c0 .94-.2 1.82-.54 2.64l1.51 1.51C20.63 14.91 21 13.5 21 12c0-4.28-2.99-7.86-7-8.77v2.06c2.89.86 5 3.54 5 6.71zM4.27 3L3 4.27 7.73 9H3v6h4l5 5v-6.73l4.25 4.25c-.67.52-1.42.93-2.25 1.18v2.06c1.38-.31 2.63-.95 3.69-1.81L19.73 21 21 19.73l-9-9L4.27 3zM12 4L9.91 6.09 12 8.18V4z"/>`,
31
+
32
+ fullscreen: `<path d="M7 14H5v5h5v-2H7v-3zm-2-4h2V7h3V5H5v5zm12 7h-3v2h5v-5h-2v3zM14 5v2h3v3h2V5h-5z"/>`,
33
+
34
+ fullscreenExit: `<path d="M5 16h3v3h2v-5H5v2zm3-8H5v2h5V5H8v3zm6 11h2v-3h3v-2h-5v5zm2-11V5h-2v5h5V8h-3z"/>`,
35
+
36
+ settings: `<path d="M19.14 12.94c.04-.3.06-.61.06-.94 0-.32-.02-.64-.07-.94l2.03-1.58c.18-.14.23-.41.12-.61l-1.92-3.32c-.12-.22-.37-.29-.59-.22l-2.39.96c-.5-.38-1.03-.7-1.62-.94L14.4 2.81c-.04-.24-.24-.41-.48-.41h-3.84c-.24 0-.43.17-.47.41l-.36 2.54c-.59.24-1.13.57-1.62.94l-2.39-.96c-.22-.08-.47 0-.59.22L2.74 8.87c-.12.21-.08.47.12.61l2.03 1.58c-.05.3-.09.63-.09.94s.02.64.07.94l-2.03 1.58c-.18.14-.23.41-.12.61l1.92 3.32c.12.22.37.29.59.22l2.39-.96c.5.38 1.03.7 1.62.94l.36 2.54c.05.24.24.41.48.41h3.84c.24 0 .44-.17.47-.41l.36-2.54c.59-.24 1.13-.56 1.62-.94l2.39.96c.22.08.47 0 .59-.22l1.92-3.32c.12-.22.07-.47-.12-.61l-2.01-1.58zM12 15.6c-1.98 0-3.6-1.62-3.6-3.6s1.62-3.6 3.6-3.6 3.6 1.62 3.6 3.6-1.62 3.6-3.6 3.6z"/>`,
37
+
38
+ captions: `<path d="M19 4H5c-1.11 0-2 .9-2 2v12c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2zm-8 7H9.5v-.5h-2v3h2V13H11v1c0 .55-.45 1-1 1H7c-.55 0-1-.45-1-1v-4c0-.55.45-1 1-1h3c.55 0 1 .45 1 1v1zm7 0h-1.5v-.5h-2v3h2V13H18v1c0 .55-.45 1-1 1h-3c-.55 0-1-.45-1-1v-4c0-.55.45-1 1-1h3c.55 0 1 .45 1 1v1z"/>`,
39
+
40
+ captionsOff: `<path d="M19 4H5c-1.11 0-2 .9-2 2v12c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2zm-8 7H9.5v-.5h-2v3h2V13H11v1c0 .55-.45 1-1 1H7c-.55 0-1-.45-1-1v-4c0-.55.45-1 1-1h3c.55 0 1 .45 1 1v1zm7 0h-1.5v-.5h-2v3h2V13H18v1c0 .55-.45 1-1 1h-3c-.55 0-1-.45-1-1v-4c0-.55.45-1 1-1h3c.55 0 1 .45 1 1v1z"/><path d="M0 0h24v24H0z" fill="none"/>`,
41
+
42
+ pip: `<path d="M19 7h-8v6h8V7zm2-4H3c-1.1 0-2 .9-2 2v14c0 1.1.9 1.98 2 1.98h18c1.1 0 2-.88 2-1.98V5c0-1.1-.9-2-2-2zm0 16.01H3V4.98h18v14.03z"/>`,
43
+
44
+ speed: `<path d="M20.38 8.57l-1.23 1.85a8 8 0 0 1-.22 7.58H5.07A8 8 0 0 1 15.58 6.85l1.85-1.23A10 10 0 0 0 3.35 19a2 2 0 0 0 1.72 1h13.85a2 2 0 0 0 1.74-1 10 10 0 0 0-.27-10.44z"/><path d="M10.59 15.41a2 2 0 0 0 2.83 0l5.66-8.49-8.49 5.66a2 2 0 0 0 0 2.83z"/>`,
45
+
46
+ close: `<path d="M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12z"/>`,
47
+
48
+ check: `<path d="M9 16.17L4.83 12l-1.42 1.41L9 19 21 7l-1.41-1.41z"/>`,
49
+
50
+ arrowUp: `<path d="M7 14l5-5 5 5z"/>`,
51
+
52
+ arrowDown: `<path d="M7 10l5 5 5-5z"/>`,
53
+
54
+ arrowLeft: `<path d="M15.41 7.41L14 6l-6 6 6 6 1.41-1.41L10.83 12z"/>`,
55
+
56
+ arrowRight: `<path d="M10 6L8.59 7.41 13.17 12l-4.58 4.59L10 18l6-6z"/>`,
57
+
58
+ loading: `<path d="M12 4V1L8 5l4 4V6c3.31 0 6 2.69 6 6 0 1.01-.25 1.97-.7 2.8l1.46 1.46C19.54 15.03 20 13.57 20 12c0-4.42-3.58-8-8-8zm0 14c-3.31 0-6-2.69-6-6 0-1.01.25-1.97.7-2.8L5.24 7.74C4.46 8.97 4 10.43 4 12c0 4.42 3.58 8 8 8v3l4-4-4-4v3z"/>`,
59
+
60
+ error: `<path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm1 15h-2v-2h2v2zm0-4h-2V7h2v6z"/>`,
61
+
62
+ download: `<path d="M19 9h-4V3H9v6H5l7 7 7-7zM5 18v2h14v-2H5z"/>`,
63
+
64
+ link: `<path d="M3.9 12c0-1.71 1.39-3.1 3.1-3.1h4V7H7c-2.76 0-5 2.24-5 5s2.24 5 5 5h4v-1.9H7c-1.71 0-3.1-1.39-3.1-3.1zM8 13h8v-2H8v2zm9-6h-4v1.9h4c1.71 0 3.1 1.39 3.1 3.1s-1.39 3.1-3.1 3.1h-4V17h4c2.76 0 5-2.24 5-5s-2.24-5-5-5z"/>`,
65
+
66
+ playlist: `<path d="M15 6H3v2h12V6zm0 4H3v2h12v-2zM3 16h8v-2H3v2zM17 6v8.18c-.31-.11-.65-.18-1-.18-1.66 0-3 1.34-3 3s1.34 3 3 3 3-1.34 3-3V8h3V6h-5z"/>`,
67
+
68
+ language: `<path d="M11.99 2C6.47 2 2 6.48 2 12s4.47 10 9.99 10C17.52 22 22 17.52 22 12S17.52 2 11.99 2zm6.93 6h-2.95c-.32-1.25-.78-2.45-1.38-3.56 1.84.63 3.37 1.91 4.33 3.56zM12 4.04c.83 1.2 1.48 2.53 1.91 3.96h-3.82c.43-1.43 1.08-2.76 1.91-3.96zM4.26 14C4.1 13.36 4 12.69 4 12s.1-1.36.26-2h3.38c-.08.66-.14 1.32-.14 2 0 .68.06 1.34.14 2H4.26zm.82 2h2.95c.32 1.25.78 2.45 1.38 3.56-1.84-.63-3.37-1.9-4.33-3.56zm2.95-8H5.08c.96-1.66 2.49-2.93 4.33-3.56C8.81 5.55 8.35 6.75 8.03 8zM12 19.96c-.83-1.2-1.48-2.53-1.91-3.96h3.82c-.43 1.43-1.08 2.76-1.91 3.96zM14.34 14H9.66c-.09-.66-.16-1.32-.16-2 0-.68.07-1.35.16-2h4.68c.09.65.16 1.32.16 2 0 .68-.07 1.34-.16 2zm.25 5.56c.6-1.11 1.06-2.31 1.38-3.56h2.95c-.96 1.65-2.49 2.93-4.33 3.56zM16.36 14c.08-.66.14-1.32.14-2 0-.68-.06-1.34-.14-2h3.38c.16.64.26 1.31.26 2s-.1 1.36-.26 2h-3.38z"/>`,
69
+
70
+ hd: `<path d="M19 3H5c-1.11 0-2 .9-2 2v14c0 1.1.89 2 2 2h14c1.11 0 2-.9 2-2V5c0-1.1-.89-2-2-2zm-8 12H9.5v-2h-2v2H6V9h1.5v2.5h2V9H11v6zm7-1c0 .55-.45 1-1 1h-.75v1.5h-1.5V15H14c-.55 0-1-.45-1-1v-4c0-.55.45-1 1-1h3c.55 0 1 .45 1 1v4zm-3.5-.5h2v-3h-2v3z"/>`,
71
+
72
+ transcript: `<path d="M14 2H6c-1.1 0-1.99.9-1.99 2L4 20c0 1.1.89 2 1.99 2H18c1.1 0 2-.9 2-2V8l-6-6zm2 16H8v-2h8v2zm0-4H8v-2h8v2zm-3-5V3.5L18.5 9H13z"/>`,
73
+
74
+ audioDescription: `<path d="M12 3v9.28c-.47-.17-.97-.28-1.5-.28C8.01 12 6 14.01 6 16.5S8.01 21 10.5 21c2.31 0 4.2-1.75 4.45-4H15V6h4V3h-7z"/><path d="M10.5 19c-1.38 0-2.5-1.12-2.5-2.5s1.12-2.5 2.5-2.5 2.5 1.12 2.5 2.5-1.12 2.5-2.5 2.5z"/>`,
75
+
76
+ audioDescriptionOn: `<path d="M12 3v9.28c-.47-.17-.97-.28-1.5-.28C8.01 12 6 14.01 6 16.5S8.01 21 10.5 21c2.31 0 4.2-1.75 4.45-4H15V6h4V3h-7z"/><path d="M10.5 19c-1.38 0-2.5-1.12-2.5-2.5s1.12-2.5 2.5-2.5 2.5 1.12 2.5 2.5-1.12 2.5-2.5 2.5z"/><circle cx="19" cy="16" r="3" fill="#3b82f6"/><path d="M18.5 17.5l1-1 1.5 1.5" stroke="white" stroke-width="1.5" fill="none" stroke-linecap="round" stroke-linejoin="round"/>`,
77
+
78
+ signLanguage: `<g transform="scale(1.5)"><path d="M16 11.3c-.1-.9-4.8 1.3-5.4 1.1-2.6-1 5.8-1.3 5.1-2.9s-5.1 1.5-6 1.4C6.5 9.4 16.5 9.1 13.5 8c-1.9-.6-8.8 2.9-6.8.4.7-.6.7-1.9-.7-1.7-9.7 7.2-.7 12.2 8.8 7 0-1.3-3.5.4-4.1.4-2.6 0 5.6-2 5.4-3ZM3.9 7.8c3.2-4.2 3.7 1.2 6 .1s.2-.2.2-.3c.7-2.7 2.5-7.5-1.5-1.3-1.6 0 1.1-4 1-4.6C8.9-1 7.3 4.4 7.2 4.9c-1.6.7-.9-1.4-.7-1.5 3-6-.6-3.1-.9.4-2.5 1.8 0-2.8 0-3.5C2.8-.9 4 9.4 1.1 4.9S.1 4.6 0 5c-.4 2.7 2.6 7.2 3.9 2.8Z"/></g>`,
79
+
80
+ signLanguageOn: `<g transform="scale(1.5)"><path d="M16 11.3c-.1-.9-4.8 1.3-5.4 1.1-2.6-1 5.8-1.3 5.1-2.9s-5.1 1.5-6 1.4C6.5 9.4 16.5 9.1 13.5 8c-1.9-.6-8.8 2.9-6.8.4.7-.6.7-1.9-.7-1.7-9.7 7.2-.7 12.2 8.8 7 0-1.3-3.5.4-4.1.4-2.6 0 5.6-2 5.4-3ZM3.9 7.8c3.2-4.2 3.7 1.2 6 .1s.2-.2.2-.3c.7-2.7 2.5-7.5-1.5-1.3-1.6 0 1.1-4 1-4.6C8.9-1 7.3 4.4 7.2 4.9c-1.6.7-.9-1.4-.7-1.5 3-6-.6-3.1-.9.4-2.5 1.8 0-2.8 0-3.5C2.8-.9 4 9.4 1.1 4.9S.1 4.6 0 5c-.4 2.7 2.6 7.2 3.9 2.8Z"/></g>`,
81
+
82
+ speaker: `<path d="M3 9v6h4l5 5V4L7 9H3zm13.5 3c0-1.77-1.02-3.29-2.5-4.03v8.05c1.48-.73 2.5-2.25 2.5-4.02z"/>`,
83
+
84
+ music: `<path d="M12 3v9.28c-.47-.17-.97-.28-1.5-.28C8.01 12 6 14.01 6 16.5S8.01 21 10.5 21c2.31 0 4.2-1.75 4.45-4H15V6h4V3h-7zm-1.5 16c-1.38 0-2.5-1.12-2.5-2.5s1.12-2.5 2.5-2.5 2.5 1.12 2.5 2.5-1.12 2.5-2.5 2.5z"/>`,
85
+
86
+ moreVertical: `<path d="M12 8c1.1 0 2-.9 2-2s-.9-2-2-2-2 .9-2 2 .9 2 2 2zm0 2c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm0 6c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2z"/>`,
87
+
88
+ moreHorizontal: `<path d="M6 10c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm12 0c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm-6 0c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2z"/>`
89
+ };
90
+
91
+ // Optimized wrapper that adds common SVG attributes
92
+ const svgWrapper = (paths) => `<svg viewBox="0 0 24 24" fill="currentColor">${paths}</svg>`;
93
+
94
+ // Export Icons object with SVG wrappers
95
+ export const Icons = Object.fromEntries(
96
+ Object.entries(iconPaths).map(([key, value]) => [key, svgWrapper(value)])
97
+ );
98
+
99
+ export function getIcon(name) {
100
+ return Icons[name] || Icons.play;
101
+ }
102
+
103
+ export function createIconElement(name, className = '') {
104
+ const wrapper = document.createElement('span');
105
+ wrapper.className = `vidply-icon ${className}`.trim();
106
+ wrapper.innerHTML = getIcon(name);
107
+ wrapper.setAttribute('aria-hidden', 'true');
108
+ return wrapper;
109
+ }
110
+
111
+ /**
112
+ * Create the large centered play button overlay (complete SVG)
113
+ * @returns {SVGElement} Complete SVG element with circle background and play icon
114
+ */
115
+ export function createPlayOverlay() {
116
+ const svg = document.createElementNS('http://www.w3.org/2000/svg', 'svg');
117
+ svg.setAttribute('class', 'vidply-play-overlay');
118
+ svg.setAttribute('viewBox', '0 0 80 80');
119
+ svg.setAttribute('width', '80');
120
+ svg.setAttribute('height', '80');
121
+ svg.setAttribute('aria-hidden', 'true');
122
+ svg.setAttribute('role', 'presentation');
123
+ svg.style.cursor = 'pointer';
124
+
125
+ // Create filter for drop shadow
126
+ const defs = document.createElementNS('http://www.w3.org/2000/svg', 'defs');
127
+ const filterId = `vidply-play-shadow-${Math.random().toString(36).substr(2, 9)}`;
128
+ const filter = document.createElementNS('http://www.w3.org/2000/svg', 'filter');
129
+ filter.setAttribute('id', filterId);
130
+ filter.setAttribute('x', '-50%');
131
+ filter.setAttribute('y', '-50%');
132
+ filter.setAttribute('width', '200%');
133
+ filter.setAttribute('height', '200%');
134
+
135
+ const feGaussianBlur = document.createElementNS('http://www.w3.org/2000/svg', 'feGaussianBlur');
136
+ feGaussianBlur.setAttribute('in', 'SourceAlpha');
137
+ feGaussianBlur.setAttribute('stdDeviation', '3');
138
+
139
+ const feOffset = document.createElementNS('http://www.w3.org/2000/svg', 'feOffset');
140
+ feOffset.setAttribute('dx', '0');
141
+ feOffset.setAttribute('dy', '2');
142
+ feOffset.setAttribute('result', 'offsetblur');
143
+
144
+ const feComponentTransfer = document.createElementNS('http://www.w3.org/2000/svg', 'feComponentTransfer');
145
+ const feFuncA = document.createElementNS('http://www.w3.org/2000/svg', 'feFuncA');
146
+ feFuncA.setAttribute('type', 'linear');
147
+ feFuncA.setAttribute('slope', '0.3');
148
+ feComponentTransfer.appendChild(feFuncA);
149
+
150
+ const feMerge = document.createElementNS('http://www.w3.org/2000/svg', 'feMerge');
151
+ const feMergeNode1 = document.createElementNS('http://www.w3.org/2000/svg', 'feMergeNode');
152
+ const feMergeNode2 = document.createElementNS('http://www.w3.org/2000/svg', 'feMergeNode');
153
+ feMergeNode2.setAttribute('in', 'SourceGraphic');
154
+ feMerge.appendChild(feMergeNode1);
155
+ feMerge.appendChild(feMergeNode2);
156
+
157
+ filter.appendChild(feGaussianBlur);
158
+ filter.appendChild(feOffset);
159
+ filter.appendChild(feComponentTransfer);
160
+ filter.appendChild(feMerge);
161
+ defs.appendChild(filter);
162
+ svg.appendChild(defs);
163
+
164
+ // White circle background
165
+ const circle = document.createElementNS('http://www.w3.org/2000/svg', 'circle');
166
+ circle.setAttribute('cx', '40');
167
+ circle.setAttribute('cy', '40');
168
+ circle.setAttribute('r', '40');
169
+ circle.setAttribute('fill', 'rgba(255, 255, 255, 0.95)');
170
+ circle.setAttribute('filter', `url(#${filterId})`);
171
+ circle.setAttribute('class', 'vidply-play-overlay-bg');
172
+ svg.appendChild(circle);
173
+
174
+ // Play icon triangle (centered with optical adjustment)
175
+ const playTriangle = document.createElementNS('http://www.w3.org/2000/svg', 'polygon');
176
+ playTriangle.setAttribute('points', '32,28 32,52 54,40');
177
+ playTriangle.setAttribute('fill', '#0a406e');
178
+ playTriangle.setAttribute('class', 'vidply-play-overlay-icon');
179
+ svg.appendChild(playTriangle);
180
+
181
+ return svg;
182
+ }
183
+
package/src/index.js CHANGED
@@ -1,95 +1,95 @@
1
- /**
2
- * VidPly - Universal Video Player
3
- * Main Entry Point
4
- */
5
-
6
- import { Player } from './core/Player.js';
7
- import { PlaylistManager } from './features/PlaylistManager.js';
8
-
9
- // Auto-initialize players
10
- function initializePlayers() {
11
- const elements = document.querySelectorAll('[data-vidply]');
12
-
13
- elements.forEach(element => {
14
- // Parse options from data attribute (JSON format)
15
- const options = element.dataset.vidplyOptions
16
- ? JSON.parse(element.dataset.vidplyOptions)
17
- : {};
18
-
19
- // Parse individual data attributes and merge with options
20
- // This allows for easier HTML-based configuration
21
- const dataOptions = parseDataAttributes(element.dataset);
22
- const mergedOptions = { ...dataOptions, ...options };
23
-
24
- // Create player instance
25
- new Player(element, mergedOptions);
26
- });
27
- }
28
-
29
- // Helper function to parse data attributes into options
30
- function parseDataAttributes(dataset) {
31
- const options = {};
32
-
33
- // Map of data attribute names to option keys (camelCase conversion)
34
- const attributeMap = {
35
- // Sign Language
36
- 'signLanguageSrc': 'signLanguageSrc',
37
- 'signLanguageButton': 'signLanguageButton',
38
- 'signLanguagePosition': 'signLanguagePosition',
39
-
40
- // Audio Description
41
- 'audioDescriptionSrc': 'audioDescriptionSrc',
42
- 'audioDescriptionButton': 'audioDescriptionButton',
43
-
44
- // Other common options
45
- 'autoplay': 'autoplay',
46
- 'loop': 'loop',
47
- 'muted': 'muted',
48
- 'controls': 'controls',
49
- 'poster': 'poster',
50
- 'width': 'width',
51
- 'height': 'height',
52
- 'language': 'language',
53
- 'captions': 'captions',
54
- 'captionsDefault': 'captionsDefault',
55
- 'transcript': 'transcript',
56
- 'transcriptButton': 'transcriptButton',
57
- 'keyboard': 'keyboard',
58
- 'responsive': 'responsive',
59
- 'pipButton': 'pipButton',
60
- 'fullscreenButton': 'fullscreenButton'
61
- };
62
-
63
- // Parse each data attribute
64
- Object.keys(attributeMap).forEach(dataKey => {
65
- const optionKey = attributeMap[dataKey];
66
- const value = dataset[dataKey];
67
-
68
- if (value !== undefined) {
69
- // Convert string values to appropriate types
70
- if (value === 'true') {
71
- options[optionKey] = true;
72
- } else if (value === 'false') {
73
- options[optionKey] = false;
74
- } else if (!isNaN(value) && value !== '') {
75
- options[optionKey] = Number(value);
76
- } else {
77
- options[optionKey] = value;
78
- }
79
- }
80
- });
81
-
82
- return options;
83
- }
84
-
85
- // Auto-initialize on DOM ready
86
- if (document.readyState === 'loading') {
87
- document.addEventListener('DOMContentLoaded', initializePlayers);
88
- } else {
89
- initializePlayers();
90
- }
91
-
92
- // Export for manual initialization
93
- export { Player, PlaylistManager };
94
- export default Player;
95
-
1
+ /**
2
+ * VidPly - Universal Video Player
3
+ * Main Entry Point
4
+ */
5
+
6
+ import { Player } from './core/Player.js';
7
+ import { PlaylistManager } from './features/PlaylistManager.js';
8
+
9
+ // Auto-initialize players
10
+ function initializePlayers() {
11
+ const elements = document.querySelectorAll('[data-vidply]');
12
+
13
+ elements.forEach(element => {
14
+ // Parse options from data attribute (JSON format)
15
+ const options = element.dataset.vidplyOptions
16
+ ? JSON.parse(element.dataset.vidplyOptions)
17
+ : {};
18
+
19
+ // Parse individual data attributes and merge with options
20
+ // This allows for easier HTML-based configuration
21
+ const dataOptions = parseDataAttributes(element.dataset);
22
+ const mergedOptions = { ...dataOptions, ...options };
23
+
24
+ // Create player instance
25
+ new Player(element, mergedOptions);
26
+ });
27
+ }
28
+
29
+ // Helper function to parse data attributes into options
30
+ function parseDataAttributes(dataset) {
31
+ const options = {};
32
+
33
+ // Map of data attribute names to option keys (camelCase conversion)
34
+ const attributeMap = {
35
+ // Sign Language
36
+ 'signLanguageSrc': 'signLanguageSrc',
37
+ 'signLanguageButton': 'signLanguageButton',
38
+ 'signLanguagePosition': 'signLanguagePosition',
39
+
40
+ // Audio Description
41
+ 'audioDescriptionSrc': 'audioDescriptionSrc',
42
+ 'audioDescriptionButton': 'audioDescriptionButton',
43
+
44
+ // Other common options
45
+ 'autoplay': 'autoplay',
46
+ 'loop': 'loop',
47
+ 'muted': 'muted',
48
+ 'controls': 'controls',
49
+ 'poster': 'poster',
50
+ 'width': 'width',
51
+ 'height': 'height',
52
+ 'language': 'language',
53
+ 'captions': 'captions',
54
+ 'captionsDefault': 'captionsDefault',
55
+ 'transcript': 'transcript',
56
+ 'transcriptButton': 'transcriptButton',
57
+ 'keyboard': 'keyboard',
58
+ 'responsive': 'responsive',
59
+ 'pipButton': 'pipButton',
60
+ 'fullscreenButton': 'fullscreenButton'
61
+ };
62
+
63
+ // Parse each data attribute
64
+ Object.keys(attributeMap).forEach(dataKey => {
65
+ const optionKey = attributeMap[dataKey];
66
+ const value = dataset[dataKey];
67
+
68
+ if (value !== undefined) {
69
+ // Convert string values to appropriate types
70
+ if (value === 'true') {
71
+ options[optionKey] = true;
72
+ } else if (value === 'false') {
73
+ options[optionKey] = false;
74
+ } else if (!isNaN(value) && value !== '') {
75
+ options[optionKey] = Number(value);
76
+ } else {
77
+ options[optionKey] = value;
78
+ }
79
+ }
80
+ });
81
+
82
+ return options;
83
+ }
84
+
85
+ // Auto-initialize on DOM ready
86
+ if (document.readyState === 'loading') {
87
+ document.addEventListener('DOMContentLoaded', initializePlayers);
88
+ } else {
89
+ initializePlayers();
90
+ }
91
+
92
+ // Export for manual initialization
93
+ export { Player, PlaylistManager };
94
+ export default Player;
95
+