myetv-player 1.2.0 → 1.4.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.
Files changed (47) hide show
  1. package/css/myetv-player.css +242 -168
  2. package/css/myetv-player.min.css +1 -1
  3. package/dist/myetv-player.js +638 -203
  4. package/dist/myetv-player.min.js +548 -170
  5. package/package.json +35 -16
  6. package/plugins/twitch/myetv-player-twitch-plugin.js +125 -11
  7. package/plugins/vimeo/myetv-player-vimeo.js +80 -49
  8. package/plugins/youtube/README.md +5 -2
  9. package/plugins/youtube/myetv-player-youtube-plugin.js +766 -6
  10. package/.github/workflows/codeql.yml +0 -100
  11. package/.github/workflows/npm-publish.yml +0 -30
  12. package/SECURITY.md +0 -50
  13. package/build.js +0 -195
  14. package/scss/README.md +0 -161
  15. package/scss/_audio-player.scss +0 -21
  16. package/scss/_base.scss +0 -116
  17. package/scss/_controls.scss +0 -204
  18. package/scss/_loading.scss +0 -111
  19. package/scss/_menus.scss +0 -432
  20. package/scss/_mixins.scss +0 -112
  21. package/scss/_poster.scss +0 -8
  22. package/scss/_progress-bar.scss +0 -319
  23. package/scss/_resolution.scss +0 -68
  24. package/scss/_responsive.scss +0 -1368
  25. package/scss/_themes.scss +0 -30
  26. package/scss/_title-overlay.scss +0 -60
  27. package/scss/_tooltips.scss +0 -7
  28. package/scss/_variables.scss +0 -49
  29. package/scss/_video.scss +0 -221
  30. package/scss/_volume.scss +0 -122
  31. package/scss/_watermark.scss +0 -128
  32. package/scss/myetv-player.scss +0 -51
  33. package/scss/package.json +0 -16
  34. package/src/README.md +0 -560
  35. package/src/chapters.js +0 -521
  36. package/src/controls.js +0 -1242
  37. package/src/core.js +0 -1922
  38. package/src/events.js +0 -537
  39. package/src/fullscreen.js +0 -82
  40. package/src/i18n.js +0 -374
  41. package/src/playlist.js +0 -177
  42. package/src/plugins.js +0 -384
  43. package/src/quality.js +0 -963
  44. package/src/streaming.js +0 -346
  45. package/src/subtitles.js +0 -524
  46. package/src/utils.js +0 -65
  47. package/src/watermark.js +0 -246
package/scss/_themes.scss DELETED
@@ -1,30 +0,0 @@
1
- // ===================================
2
- // THEMES
3
- // ===================================
4
-
5
- /* ALTERNATIVE THEME - Blue */
6
- .player-theme-blue {
7
- --player-primary-color: #2196F3;
8
- --player-primary-hover: #1976D2;
9
- --player-primary-dark: #1565C0;
10
- }
11
-
12
-
13
-
14
- /* ALTERNATIVE THEME - Green */
15
- .player-theme-green {
16
- --player-primary-color: #4CAF50;
17
- --player-primary-hover: #45a049;
18
- --player-primary-dark: #388e3c;
19
- }
20
-
21
-
22
-
23
- /* ALTERNATIVE THEME - Red */
24
- .player-theme-red {
25
- --player-primary-color: #f44336;
26
- --player-primary-hover: #d32f2f;
27
- --player-primary-dark: #c62828;
28
- }
29
-
30
-
@@ -1,60 +0,0 @@
1
- // ===================================
2
- // TITLE OVERLAY
3
- // ===================================
4
-
5
- @use 'mixins' as *;
6
- @use 'variables' as *;
7
-
8
- /* TITLE OVERLAY - WITH AUTO-HIDE */
9
- .title-overlay {
10
- position: absolute;
11
- top: 0;
12
- left: 0;
13
- right: 0;
14
- background: var(--player-bg-title-overlay);
15
- padding: var(--player-title-overlay-padding);
16
- opacity: 0;
17
- transform: translateY(-100%);
18
- transition: all var(--player-transition-normal);
19
- z-index: 15;
20
- pointer-events: none;
21
- }
22
-
23
- .title-overlay.show {
24
- opacity: 1;
25
- transform: translateY(0);
26
- }
27
-
28
- .title-overlay.show.persistent {
29
- opacity: 1;
30
- transform: translateY(0);
31
- }
32
-
33
- .title-text {
34
- color: var(--player-text-color);
35
- font-size: 18px;
36
- font-weight: 600;
37
- line-height: 1.3;
38
- margin: 0;
39
- white-space: nowrap;
40
- overflow: hidden;
41
- text-overflow: ellipsis;
42
- text-shadow: 0 2px 8px rgba(0, 0, 0, 0.7);
43
- -webkit-font-smoothing: antialiased;
44
- -moz-osx-font-smoothing: grayscale;
45
- }
46
-
47
- .subtitle-text {
48
- color: var(--player-text-color);
49
- font-size: 14px;
50
- font-weight: 400;
51
- line-height: 1.3;
52
- margin: 5px 0 0 0;
53
- white-space: nowrap;
54
- overflow: hidden;
55
- text-overflow: ellipsis;
56
- text-shadow: 0 2px 8px rgba(0, 0, 0, 0.7);
57
- opacity: 0.9;
58
- -webkit-font-smoothing: antialiased;
59
- -moz-osx-font-smoothing: grayscale;
60
- }
@@ -1,7 +0,0 @@
1
- // ===================================
2
- // TOOLTIPS
3
- // ===================================
4
-
5
- @use 'mixins' as *;
6
-
7
-
@@ -1,49 +0,0 @@
1
- // ===================================
2
- // VARIABLES
3
- // ===================================
4
- // Main colors
5
- $player-primary-color: goldenrod !default;
6
- $player-primary-hover: #daa520 !default;
7
- $player-primary-dark: #b8860b !default;
8
-
9
- // Control colors
10
- $player-button-color: white !default;
11
- $player-button-hover: rgba(255, 255, 255, 0.1) !default;
12
- $player-button-active: rgba(255, 255, 255, 0.2) !default;
13
-
14
- // Text colors
15
- $player-text-color: white !default;
16
- $player-text-secondary: rgba(255, 255, 255, 0.8) !default;
17
-
18
- // Background and overlay
19
- $player-bg-primary: #000 !default;
20
- $player-bg-controls: linear-gradient(180deg, transparent 0%, rgba(0, 0, 0, 0.8) 100%) !default;
21
- $player-bg-title-overlay: linear-gradient(180deg, rgba(0, 0, 0, 0.8) 0%, transparent 100%) !default;
22
- $player-bg-menu: rgba(20, 20, 20, 0.95) !default;
23
- $player-bg-loading: rgba(0, 0, 0, 0.7) !default;
24
-
25
- // Dimensions
26
- $player-border-radius: 12px !default;
27
- $player-controls-padding: 20px 15px 15px !default;
28
- $player-title-overlay-padding: 15px 20px 25px !default;
29
- $player-button-padding: 8px !default;
30
- $player-icon-size: 20px !default;
31
-
32
- // Progress and Volume bars
33
- $player-progress-height: 6px !default;
34
- $player-progress-bg: rgba(255, 255, 255, 0.2) !default;
35
- $player-progress-buffer: rgba(255, 255, 255, 0.3) !default;
36
- $player-progress-handle-size: 16px !default;
37
- $player-volume-height: 4px !default;
38
- $player-volume-bg: rgba(255, 255, 255, 0.2) !default;
39
- $player-volume-handle-size: 14px !default;
40
- $player-volume-fill: 100% !default;
41
-
42
- // Transitions
43
- $player-transition-fast: 0.2s ease !default;
44
- $player-transition-normal: 0.3s ease !default;
45
-
46
- // Shadows
47
- $player-shadow-main: 0 8px 32px rgba(0, 0, 0, 0.3) !default;
48
- $player-shadow-menu: 0 4px 16px rgba(0, 0, 0, 0.2) !default;
49
- $player-shadow-tooltip: 0 3px 12px rgba(0, 0, 0, 0.4) !default;
package/scss/_video.scss DELETED
@@ -1,221 +0,0 @@
1
- // ===================================
2
- // VIDEO PLAYER
3
- // ===================================
4
-
5
- @use 'mixins' as *;
6
-
7
- /* SMART VIDEO HIDING */
8
- .video-player {
9
- width: 100%;
10
- height: auto;
11
- display: block;
12
- min-height: 300px;
13
- visibility: hidden;
14
- opacity: 0;
15
- position: relative;
16
- z-index: 1;
17
- transition: none;
18
- }
19
-
20
- .video-wrapper.player-initialized .video-player {
21
- visibility: visible;
22
- opacity: 1;
23
- transition: opacity 0.3s ease;
24
- pointer-events: auto;
25
- }
26
-
27
- /* NATIVE CONTROLS DISABLED */
28
- .video-player::-webkit-media-controls-panel,
29
- .video-player::-webkit-media-controls-play-button,
30
- .video-player::-webkit-media-controls-start-playback-button,
31
- .video-player::-webkit-media-controls-timeline,
32
- .video-player::-webkit-media-controls-current-time-display,
33
- .video-player::-webkit-media-controls-time-remaining-display,
34
- .video-player::-webkit-media-controls-mute-button,
35
- .video-player::-webkit-media-controls-toggle-closed-captions-button,
36
- .video-player::-webkit-media-controls-volume-slider,
37
- .video-player::-webkit-media-controls-fullscreen-button,
38
- .video-player::-webkit-media-controls-seek-back-button,
39
- .video-player::-webkit-media-controls-seek-forward-button,
40
- .video-player::-webkit-media-controls-rewind-button,
41
- .video-player::-webkit-media-controls-return-to-realtime-button,
42
- .video-player::-webkit-media-controls-overlay-play-button {
43
- display: none !important;
44
- visibility: hidden !important;
45
- opacity: 0 !important;
46
- }
47
-
48
- .video-player::-moz-media-controls {
49
- display: none !important;
50
- }
51
-
52
- /* INITIAL LOADING */
53
- .initial-loading {
54
- position: absolute;
55
- top: 0;
56
- left: 0;
57
- width: 100%;
58
- height: 100%;
59
- background: var(--player-bg-primary);
60
- display: flex;
61
- align-items: center;
62
- justify-content: center;
63
- z-index: 20;
64
- }
65
-
66
- .video-wrapper.player-initialized .initial-loading {
67
- opacity: 0;
68
- visibility: hidden;
69
- transition: opacity 0.3s ease, visibility 0.3s ease;
70
- transition-delay: 0.2s;
71
- }
72
-
73
- .video-wrapper.player-initialized .initial-loading {
74
- display: none;
75
- transition-delay: 0.5s;
76
- }
77
-
78
- .loading-overlay {
79
- position: absolute;
80
- top: 0;
81
- left: 0;
82
- width: 100%;
83
- height: 100%;
84
- background: var(--player-bg-loading);
85
- display: flex;
86
- align-items: center;
87
- justify-content: center;
88
- opacity: 0;
89
- visibility: hidden;
90
- transition: opacity var(--player-transition-normal);
91
- z-index: 15;
92
- }
93
-
94
- .loading-overlay.active {
95
- opacity: 1;
96
- visibility: visible;
97
- }
98
-
99
- .loading-spinner {
100
- width: 50px;
101
- height: 50px;
102
- border: 3px solid rgba(255, 255, 255, 0.3);
103
- border-top: 3px solid var(--player-primary-color);
104
- border-radius: 50%;
105
- animation: spin 1s linear infinite;
106
- }
107
-
108
- @keyframes spin {
109
- 0% {
110
- transform: rotate(0deg);
111
- }
112
-
113
- 100% {
114
- transform: rotate(360deg);
115
- }
116
- }
117
-
118
- /* CUSTOM SUBTITLES STYLING */
119
- .video-player::cue {
120
- background: rgba(0, 0, 0, 0.8);
121
- color: white;
122
- font-size: 18px;
123
- font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
124
- font-weight: 500;
125
- text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.8);
126
- padding: 8px 12px;
127
- border-radius: 6px;
128
- line-height: 1.4;
129
- }
130
-
131
- .video-player::cue(.highlight) {
132
- background: var(--player-primary-color);
133
- color: black;
134
- }
135
-
136
- .video-player::cue(b) {
137
- font-weight: 700;
138
- }
139
-
140
- .video-player::cue(i) {
141
- font-style: italic;
142
- }
143
-
144
- /* VIDEO POSTER OVERLAY */
145
- .video-poster-overlay {
146
- position: absolute;
147
- top: 0;
148
- left: 0;
149
- width: 100%;
150
- height: 100%;
151
- background-size: cover;
152
- background-position: center;
153
- background-repeat: no-repeat;
154
- z-index: 1;
155
- cursor: pointer;
156
- opacity: 0;
157
- visibility: hidden;
158
- transition: opacity 0.3s ease, visibility 0.3s ease;
159
- pointer-events: none;
160
- }
161
-
162
- .video-poster-overlay.visible {
163
- opacity: 1;
164
- visibility: visible;
165
- pointer-events: auto;
166
- }
167
-
168
- .video-poster-overlay.hidden {
169
- opacity: 0;
170
- visibility: hidden;
171
- pointer-events: none;
172
- }
173
-
174
- .video-poster-overlay.visible:hover {
175
- opacity: 0.95;
176
- }
177
-
178
- .video-poster-overlay::after {
179
- content: '';
180
- position: absolute;
181
- top: 50%;
182
- left: 50%;
183
- transform: translate(-50%, -50%);
184
- width: 80px;
185
- height: 80px;
186
- background: rgba(0, 0, 0, 0.7);
187
- border-radius: 50%;
188
- border: 3px solid var(--player-primary-color);
189
- opacity: 0;
190
- transition: opacity 0.3s ease, transform 0.3s ease, border-color 0.3s ease;
191
- pointer-events: none;
192
- }
193
-
194
- .video-poster-overlay.visible:hover::after {
195
- opacity: 1;
196
- transform: translate(-50%, -50%) scale(1.1);
197
- border-color: var(--player-primary-hover);
198
- box-shadow: 0 0 20px var(--player-primary-color);
199
- }
200
-
201
- .video-poster-overlay::before {
202
- content: '';
203
- position: absolute;
204
- top: 50%;
205
- left: 50%;
206
- transform: translate(-40%, -50%);
207
- width: 0;
208
- height: 0;
209
- border-style: solid;
210
- border-width: 15px 0 15px 25px;
211
- border-color: transparent transparent transparent var(--player-primary-color);
212
- z-index: 2;
213
- opacity: 0;
214
- transition: opacity 0.3s ease, border-color 0.3s ease;
215
- pointer-events: none;
216
- }
217
-
218
- .video-poster-overlay.visible:hover::before {
219
- opacity: 1;
220
- border-color: transparent transparent transparent var(--player-primary-hover);
221
- }
package/scss/_volume.scss DELETED
@@ -1,122 +0,0 @@
1
- // ===================================
2
- // VOLUME CONTROLS
3
- // ===================================
4
-
5
- @use 'mixins' as *;
6
- @use 'variables' as *;
7
-
8
- /* VOLUME CONTROLS - IMPROVED RESPONSIVE */
9
- .volume-container {
10
- display: flex;
11
- align-items: center;
12
- gap: 8px;
13
- position: relative;
14
- flex-shrink: 2;
15
- min-width: 0;
16
- }
17
-
18
- .volume-slider {
19
- width: 60px;
20
- height: var(--player-volume-height);
21
- background: var(--player-volume-bg);
22
- border-radius: calc(var(--player-volume-height) / 2);
23
- outline: none;
24
- cursor: pointer;
25
- -webkit-appearance: none;
26
- transition: all var(--player-transition-fast);
27
- }
28
-
29
- .volume-tooltip {
30
- position: absolute;
31
- bottom: 210%;
32
- transition: opacity 0.15s ease, transform 0.15s ease;
33
- left: 0;
34
- transform: translateX(-50%);
35
- background: rgba(0, 0, 0, 0.9);
36
- color: white;
37
- padding: 6px 10px;
38
- border-radius: 6px;
39
- font-size: 12px;
40
- font-weight: 500;
41
- white-space: nowrap;
42
- opacity: 0;
43
- visibility: hidden;
44
- z-index: 1000;
45
- box-shadow: var(--player-shadow-tooltip);
46
- pointer-events: none;
47
- backdrop-filter: blur(8px);
48
- border: 1px solid rgba(255, 255, 255, 0.1);
49
- }
50
-
51
- .volume-tooltip::after {
52
- content: '';
53
- position: absolute;
54
- top: 100%;
55
- left: 50%;
56
- transform: translateX(-50%);
57
- width: 0;
58
- height: 0;
59
- border-left: 6px solid transparent;
60
- border-right: 6px solid transparent;
61
- border-top: 6px solid rgba(0, 0, 0, 0.9);
62
- }
63
-
64
- .volume-container:hover .volume-tooltip,
65
- .volume-tooltip.visible {
66
- opacity: 1;
67
- visibility: visible;
68
- }
69
-
70
- .volume-slider::-webkit-slider-thumb {
71
- -webkit-appearance: none;
72
- width: var(--player-volume-handle-size);
73
- height: var(--player-volume-handle-size);
74
- border-radius: 50%;
75
- background: var(--player-primary-dark);
76
- cursor: pointer;
77
- transition: all var(--player-transition-fast);
78
- box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2);
79
- margin-top: calc((var(--player-volume-height) - var(--player-volume-handle-size)) / 2);
80
- transform: translateY(0);
81
- }
82
-
83
- .volume-slider::-webkit-slider-thumb:hover {
84
- transform: translateY(0) scale(1.2);
85
- background: var(--player-primary-color);
86
- }
87
-
88
- .volume-slider::-moz-range-thumb {
89
- width: var(--player-volume-handle-size);
90
- height: var(--player-volume-handle-size);
91
- border-radius: 50%;
92
- background: var(--player-primary-dark);
93
- cursor: pointer;
94
- border: none;
95
- box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2);
96
- transition: all var(--player-transition-fast);
97
- margin-top: 0;
98
- transform: translateY(calc((var(--player-volume-height) - var(--player-volume-handle-size)) / 2));
99
- }
100
-
101
- .volume-slider::-moz-range-thumb:hover {
102
- background: var(--player-primary-color);
103
- transform: translateY(calc((var(--player-volume-height) - var(--player-volume-handle-size)) / 2)) scale(1.1);
104
- }
105
-
106
- .volume-slider::-webkit-slider-runnable-track {
107
- height: var(--player-volume-height);
108
- background: linear-gradient(to right, var(--player-primary-dark) 0%, var(--player-primary-dark) var(--player-volume-fill), var(--player-volume-bg) var(--player-volume-fill), var(--player-volume-bg) 100%);
109
- border-radius: calc(var(--player-volume-height) / 2);
110
- transition: background var(--player-transition-fast);
111
- margin: 0;
112
- border: none;
113
- }
114
-
115
- .volume-slider::-moz-range-track {
116
- height: var(--player-volume-height);
117
- background: linear-gradient(to right, var(--player-primary-dark) 0%, var(--player-primary-dark) var(--player-volume-fill), var(--player-volume-bg) var(--player-volume-fill), var(--player-volume-bg) 100%);
118
- border-radius: calc(var(--player-volume-height) / 2);
119
- border: none;
120
- transition: background var(--player-transition-fast);
121
- margin: 0;
122
- }
@@ -1,128 +0,0 @@
1
- // ===================================
2
- // VIDEO WATERMARK
3
- // ===================================
4
-
5
- @use 'mixins' as *;
6
- @use 'variables' as *;
7
-
8
- .video-watermark {
9
- position: absolute;
10
- z-index: 15;
11
- pointer-events: auto;
12
- opacity: 0.7;
13
- transition: opacity 0.3s ease, visibility 0.3s ease, bottom 0.3s ease;
14
- }
15
-
16
- .video-watermark {
17
- visibility: visible;
18
- opacity: 0.7;
19
- }
20
-
21
- .video-wrapper:not(.has-controls) .video-watermark.hide-on-autohide {
22
- visibility: hidden;
23
- opacity: 0;
24
- }
25
-
26
- .video-wrapper.has-controls .video-watermark {
27
- visibility: visible;
28
- opacity: 0.7;
29
- }
30
-
31
- .video-watermark:hover {
32
- opacity: 1;
33
- }
34
-
35
- .video-watermark img {
36
- display: block;
37
- max-width: 150px;
38
- max-height: 80px;
39
- width: auto;
40
- height: auto;
41
- object-fit: contain;
42
- }
43
-
44
- /* Top positions */
45
- .video-watermark.watermark-topleft {
46
- top: 15px;
47
- left: 15px;
48
- }
49
-
50
- .video-watermark.watermark-topright {
51
- top: 15px;
52
- right: 15px;
53
- }
54
-
55
- /* Bottom positions - Dynamic with controlbar height + spacing */
56
- .video-watermark.watermark-bottomleft {
57
- bottom: calc(var(--player-controls-height, 70px) + 15px);
58
- left: 15px;
59
- }
60
-
61
- .video-watermark.watermark-bottomright {
62
- bottom: calc(var(--player-controls-height, 70px) + 15px);
63
- right: 15px;
64
- }
65
-
66
- /* When controls hidden, move to corner */
67
- .video-wrapper:not(.has-controls) .video-watermark.watermark-bottomleft:not(.hide-on-autohide) {
68
- bottom: 15px;
69
- }
70
-
71
- .video-wrapper:not(.has-controls) .video-watermark.watermark-bottomright:not(.hide-on-autohide) {
72
- bottom: 15px;
73
- }
74
-
75
- /* When controls shown, stay above controlbar */
76
- .video-wrapper.has-controls .video-watermark.watermark-bottomleft,
77
- .video-wrapper.has-controls .video-watermark.watermark-bottomright {
78
- bottom: calc(var(--player-controls-height, 70px) + 15px);
79
- }
80
-
81
- /* Responsive */
82
- @media (max-width: 768px) {
83
- .video-watermark img {
84
- max-width: 100px;
85
- max-height: 50px;
86
- }
87
-
88
- .video-watermark.watermark-topleft,
89
- .video-watermark.watermark-topright {
90
- top: 10px;
91
- }
92
-
93
- .video-watermark.watermark-topleft,
94
- .video-watermark.watermark-bottomleft {
95
- left: 10px;
96
- }
97
-
98
- .video-watermark.watermark-topright,
99
- .video-watermark.watermark-bottomright {
100
- right: 10px;
101
- }
102
-
103
- .video-watermark.watermark-bottomleft,
104
- .video-watermark.watermark-bottomright {
105
- bottom: calc(var(--player-controls-height, 60px) + 10px);
106
- }
107
-
108
- .video-wrapper:not(.has-controls) .video-watermark.watermark-bottomleft:not(.hide-on-autohide),
109
- .video-wrapper:not(.has-controls) .video-watermark.watermark-bottomright:not(.hide-on-autohide) {
110
- bottom: 10px;
111
- }
112
- }
113
-
114
- @media (max-width: 480px) {
115
- .video-watermark.watermark-bottomleft,
116
- .video-watermark.watermark-bottomright {
117
- bottom: calc(var(--player-controls-height, 55px) + 10px);
118
- }
119
-
120
- .video-wrapper:not(.has-controls) .video-watermark.watermark-bottomleft:not(.hide-on-autohide),
121
- .video-wrapper:not(.has-controls) .video-watermark.watermark-bottomright:not(.hide-on-autohide) {
122
- bottom: 8px;
123
- }
124
- }
125
-
126
- .video-watermark[style*="cursor: pointer"] {
127
- cursor: pointer !important;
128
- }
@@ -1,51 +0,0 @@
1
- // ===================================
2
- // MYETV VIDEO PLAYER - SCSS
3
- // Created by https://www.myetv.tv
4
- // https://oskarcosimo.com
5
- // ===================================
6
-
7
- // 1. Core: Variables and Mixins
8
- @use 'variables' as *;
9
- @use 'mixins' as *;
10
-
11
- // 2. Base Styles (includes :root)
12
- @use 'base';
13
-
14
- // 3. Video Element
15
- @use 'video';
16
-
17
- // 4. Loading & Overlays
18
- @use 'loading';
19
-
20
- // 5. Title Overlay
21
- @use 'title-overlay';
22
-
23
- // 6. Controls
24
- @use 'controls';
25
-
26
- // 7. Progress Bar
27
- @use 'progress-bar';
28
-
29
- // 8. Volume Controls
30
- @use 'volume';
31
-
32
- // 9. Menus (Settings, Quality, Speed, Subtitles)
33
- @use 'menus';
34
-
35
- // 10. Poster Overlay
36
- @use 'poster';
37
-
38
- // 11. Tooltips
39
- @use 'tooltips';
40
-
41
- // 12 Audio Player (audiofile + audiowave)
42
- @use 'audio-player';
43
-
44
- // 13. Themes (Blue, Green, Red)
45
- @use 'themes';
46
-
47
- // 14. Watermark
48
- @use 'watermark';
49
-
50
- // 15. Responsive (must be last)
51
- @use 'responsive';
package/scss/package.json DELETED
@@ -1,16 +0,0 @@
1
- {
2
- "name": "myetv-player",
3
- "version": "1.0.0",
4
- "description": "MYETV Video Player - SCSS Source Files",
5
- "scripts": {
6
- "scss": "sass myetv-player.scss myetv-player.css",
7
- "scss:watch": "sass --watch myetv-player.scss:myetv-player.css",
8
- "scss:prod": "sass --style=compressed myetv-player.scss:myetv-player.min.css",
9
- "scss:dev": "sass --watch --source-map myetv-player.scss:myetv-player.css"
10
- },
11
- "devDependencies": {
12
- "sass": "^1.69.0"
13
- },
14
- "author": "MYETV - Oskar Cosimo",
15
- "license": "MIT"
16
- }