Embed rework
This commit is contained in:
parent
98054f268f
commit
ac7659614a
58 changed files with 8278 additions and 49187 deletions
131
embed/skins/default.css
Normal file
131
embed/skins/default.css
Normal file
|
@ -0,0 +1,131 @@
|
|||
.mistvideo {
|
||||
line-height: 1.2;
|
||||
font-size: 14.5px;
|
||||
}
|
||||
.mistvideo svg {
|
||||
margin: 2.5px;
|
||||
}
|
||||
.mistvideo-background { background-color: $background; }
|
||||
.mistvideo-totalTime:before {
|
||||
content: '/';
|
||||
margin: 0.2em;
|
||||
}
|
||||
.mistvideo-progress {
|
||||
padding: 10px 0;
|
||||
margin: -10px 0;
|
||||
z-index: 2; /*keep above control bar*/
|
||||
}
|
||||
.mistvideo-progress > * {
|
||||
height: 2px;
|
||||
background-color: $progressBackground;
|
||||
opacity: 0.95;
|
||||
position: relative;
|
||||
}
|
||||
.mistvideo-novideo .mistvideo-progress > *,
|
||||
.mistvideo-progress:hover > * {
|
||||
height: 10px;
|
||||
}
|
||||
|
||||
.mistvideo-progress:not(:hover) > * {
|
||||
transition: height 0.25s ease-in 0.5s;
|
||||
}
|
||||
.mistvideo-progress .bar {
|
||||
height: inherit;
|
||||
width: 0;
|
||||
position: absolute;
|
||||
border-right: inherit;
|
||||
background-color: $accent;
|
||||
z-index: 2; /*keep above buffer bar(s)*/
|
||||
}
|
||||
.mistvideo-progress .buffer {
|
||||
height: inherit;
|
||||
width: 0;
|
||||
position: absolute;
|
||||
background-color: $semiFill;
|
||||
}
|
||||
.mistvideo-progress .bar:after {
|
||||
content: '';
|
||||
border: 5px solid $accent;
|
||||
border-radius: 5px;
|
||||
position: absolute;
|
||||
right: -5px;
|
||||
top: 50%;
|
||||
transform: translateY(-50%);
|
||||
}
|
||||
|
||||
.mistvideo-play[data-state="playing"] svg.play {
|
||||
display: none;
|
||||
}
|
||||
.mistvideo-play[data-state="paused"] svg.pause {
|
||||
display: none;
|
||||
}
|
||||
.mistvideo-main { align-items: center; }
|
||||
|
||||
svg.icon.timeout {
|
||||
display: inline-block;
|
||||
height: 1em;
|
||||
width: 1em;
|
||||
margin: 0;
|
||||
margin-right: 0.25em;
|
||||
vertical-align: top;
|
||||
}
|
||||
|
||||
.mist.largeplay, .mist.muted {
|
||||
position: absolute;
|
||||
opacity: 0.5;
|
||||
}
|
||||
.mist.largeplay {
|
||||
top: 50%;
|
||||
left: 0;
|
||||
right: 0;
|
||||
margin: auto;
|
||||
transform: translateY(-50%);
|
||||
}
|
||||
.mist.muted {
|
||||
top: 0;
|
||||
right: 0;
|
||||
margin: 1em;
|
||||
}
|
||||
.mistvideo-secondaryVideo {
|
||||
z-index: 1;
|
||||
width: 50%;
|
||||
height: 50%;
|
||||
}
|
||||
.mistvideo-polling {
|
||||
display: inline-block;
|
||||
position: relative;
|
||||
width: 25px;
|
||||
height: 25px;
|
||||
}
|
||||
.mistvideo-polling svg.icon.loading {
|
||||
z-index: 0;
|
||||
opacity: 1;
|
||||
}
|
||||
.mistvideo[data-show-submenu] .mistvideo-submenu {
|
||||
right: 5px;
|
||||
}
|
||||
.mistvideo[data-show-submenu] .mistvideo-controls {
|
||||
bottom: 0;
|
||||
}
|
||||
.mistvideo-error[data-passive] {
|
||||
bottom: auto;
|
||||
left: auto;
|
||||
margin: 0.5em;
|
||||
padding: 0.5em;
|
||||
}
|
||||
.mistvideo-error[data-passive] .message {
|
||||
max-width: none;
|
||||
}
|
||||
.mistvideo-error .mistvideo-buttoncontainer {
|
||||
display: flex;
|
||||
flex-flow: row nowrap;
|
||||
justify-content: center;
|
||||
}
|
||||
.mistvideo-error .mistvideo-buttoncontainer .mistvideo-button {
|
||||
white-space: nowrap;
|
||||
}
|
||||
.browser-ie .mist.icon.loading {
|
||||
animation: spin 1.5s infinite linear;
|
||||
transform-origin: 50% 50%;
|
||||
}
|
||||
.browser-ie .mist.icon.loading .spin { animation: none; }
|
105
embed/skins/dev.css
Normal file
105
embed/skins/dev.css
Normal file
|
@ -0,0 +1,105 @@
|
|||
.mistvideo-log {
|
||||
margin: 0.5em 0;
|
||||
}
|
||||
.mistvideo-log .logs {
|
||||
max-height: 10em;
|
||||
min-height: 5em;
|
||||
width: 100%;
|
||||
padding: 0.2em 0;
|
||||
padding-right: 1em; /*for scrollbar*/
|
||||
overflow-y: auto;
|
||||
overflow-x: hidden;
|
||||
font-size: 0.9em;
|
||||
}
|
||||
.mistvideo-log .logs table td {
|
||||
vertical-align: top;
|
||||
padding: 0;
|
||||
}
|
||||
.mistvideo-log .logs .entry .message {
|
||||
margin: 0 0.2em;
|
||||
}
|
||||
.mistvideo-log .logs .entry.type-error {
|
||||
color: $accent;
|
||||
}
|
||||
.mistvideo-log .logs .timestamp,
|
||||
.mistvideo-log .logs .counter {
|
||||
color: $semiFill;
|
||||
}
|
||||
.mistvideo-log .logs .timestamp:before { content: '['; }
|
||||
.mistvideo-log .logs .timestamp:after { content: ']'; }
|
||||
.mistvideo-log .logs .counter:before { content: '('; }
|
||||
.mistvideo-log .logs .counter:after { content: '\00d7)'; }
|
||||
|
||||
.mistvideo-devbuttons { font-size: 0.9em; }
|
||||
.mistvideo-devbuttons button {
|
||||
font-size: 0.8em;
|
||||
margin: 0.1em;
|
||||
padding: 0.2em 0.4em;
|
||||
}
|
||||
.mistvideo-forceSource > span,
|
||||
.mistvideo-forceType > span,
|
||||
.mistvideo-forcePlayer > span { display: inline-block; width: 7em; }
|
||||
.mistvideo-forceSource > select,
|
||||
.mistvideo-forceType > select,
|
||||
.mistvideo-forcePlayer > select {
|
||||
width: 15em;
|
||||
min-width: auto;
|
||||
}
|
||||
.mistvideo-devcontrols {
|
||||
margin: 0.5em 0;
|
||||
}
|
||||
|
||||
.mistvideo-decodingIssues > * {
|
||||
display: flex;
|
||||
width: 50%;
|
||||
max-width: 20em;
|
||||
flex-flow: row nowrap;
|
||||
align-items: flex-end;
|
||||
justify-content: space-between;
|
||||
}
|
||||
.mistvideo-decodingIssues > * > :last-child {
|
||||
margin-right: 0.5em;
|
||||
}
|
||||
.mistvideo-decodingIssues {
|
||||
display: flex;
|
||||
flex-flow: row wrap;
|
||||
justify-content: space-between;
|
||||
}
|
||||
.mistvideo-decodingIssues label {
|
||||
position: relative;
|
||||
}
|
||||
.mistvideo-decodingIssues label .value {
|
||||
font-size: 0.8em;
|
||||
}
|
||||
svg.icon.graph {
|
||||
position: absolute;
|
||||
right: 0;
|
||||
top: 0;
|
||||
bottom: 0;
|
||||
width: 6em;
|
||||
}
|
||||
select {
|
||||
border-radius: 0;
|
||||
}
|
||||
input[type="checkbox"] {
|
||||
margin: 0;
|
||||
margin-right: 0.2em;
|
||||
border: 1px solid $semiFill;
|
||||
border-radius: 0;
|
||||
-webkit-appearance: none;
|
||||
-moz-appearance: none;
|
||||
-ms-appearance: none;
|
||||
appearance: none;
|
||||
width: 0.8em;
|
||||
height: 0.8em;
|
||||
color: inherit;
|
||||
position: relative;
|
||||
cursor: pointer;
|
||||
}
|
||||
input[type="checkbox"]:checked:after {
|
||||
content: "\2713";
|
||||
position: absolute;
|
||||
bottom: -0.2em;
|
||||
left: 0;
|
||||
font-size: 1.2em;
|
||||
}
|
224
embed/skins/general.css
Normal file
224
embed/skins/general.css
Normal file
|
@ -0,0 +1,224 @@
|
|||
.mistvideo {
|
||||
display: inline-block;
|
||||
position: relative;
|
||||
color: $stroke;
|
||||
font-family: sans-serif;
|
||||
background-color: #000;
|
||||
justify-content: center;
|
||||
align-items: center;
|
||||
}
|
||||
.mistvideo-controls {
|
||||
-webkit-user-select: none;
|
||||
-moz-user-select: none;
|
||||
-ms-user-select: none;
|
||||
user-select: none;
|
||||
}
|
||||
.mistvideo.novideo {
|
||||
overflow: visible;
|
||||
}
|
||||
.mistvideo-video {
|
||||
overflow: hidden;
|
||||
}
|
||||
svg.icon.loading {
|
||||
z-index: -1; /* don't use display: none because of transition for [data-loading=stalled] */
|
||||
position: absolute;
|
||||
top: 0;
|
||||
left: 0;
|
||||
right: 0;
|
||||
bottom: 0;
|
||||
margin: auto;
|
||||
opacity: 0;
|
||||
}
|
||||
[data-loading] {
|
||||
position: relative;
|
||||
}
|
||||
|
||||
/*wait before showing icon when stalled*/
|
||||
[data-loading="stalled"] svg.icon.loading {
|
||||
transition: opacity 0s 3s;
|
||||
}
|
||||
[data-loading] svg.icon.loading {
|
||||
z-index: 2;
|
||||
opacity: 1;
|
||||
}
|
||||
[data-loading-css] .mistvideo-controls {
|
||||
display: none;
|
||||
}
|
||||
[data-hidecursor],
|
||||
[data-hidecursor] .mistvideo-pointer,
|
||||
[data-hidecursor] *
|
||||
{ cursor: none }
|
||||
.mistvideo-error {
|
||||
display: none;
|
||||
position: absolute;
|
||||
top: 0;
|
||||
left: 0;
|
||||
right: 0;
|
||||
bottom: 0;
|
||||
background-color: $background;
|
||||
align-items: center;
|
||||
justify-content: center;
|
||||
text-align: center;
|
||||
z-index: 2; /*above progress bar*/
|
||||
cursor: default; /*cursor won't show up if it was hidden because the mousemove event can no longer reach the video element*/
|
||||
min-height: fit-content; /*overflow if needed*/
|
||||
min-width: fit-content;
|
||||
}
|
||||
.mistvideo-error.show { display: flex; }
|
||||
.mistvideo-error .message { max-width: 80%; }
|
||||
.mistvideo-error .message .details table { text-align: left; }
|
||||
.mistvideo-video:not(.video-js) button,
|
||||
.mistvideo-error button,
|
||||
.mistvideo-controls button
|
||||
{
|
||||
color: $stroke;
|
||||
border: 1px solid $semiFill;
|
||||
background-color: $background;
|
||||
margin: 0.25em;
|
||||
padding: 0.5em 1em;
|
||||
opacity: 0.5;
|
||||
cursor: pointer;
|
||||
}
|
||||
button:hover { opacity: 1; }
|
||||
select {
|
||||
background-color: transparent;
|
||||
color: $stroke;
|
||||
border: none;
|
||||
margin: 0 0.5em;
|
||||
font-size: inherit;
|
||||
cursor: pointer;
|
||||
-ms-background-color: red;
|
||||
}
|
||||
select > option {
|
||||
background-color: $background;
|
||||
}
|
||||
|
||||
.browser-edge select, .browser-safari select {
|
||||
/*These browsers don't show an arrow for select boxes, causing them to be invisible when a border is not applied */
|
||||
border: 1px solid $semiFill;
|
||||
border-top: none;
|
||||
border-left: none;
|
||||
margin-top: 2px;
|
||||
}
|
||||
|
||||
@keyframes spin { 0% { transform: rotate(0deg); } 100% { transform: rotate(360deg); } }
|
||||
[data-fullscreen] {
|
||||
position: fixed;
|
||||
top: 0;
|
||||
left: 0;
|
||||
right: 0;
|
||||
bottom: 0;
|
||||
width: 100% !important;
|
||||
height: 100% !important;
|
||||
}
|
||||
video {
|
||||
display: block;
|
||||
flex-shrink: 0;
|
||||
}
|
||||
table { color: inherit; font-size: inherit; font-style: inherit; }
|
||||
audio:not([controls]) { display: block !important; }
|
||||
.mistvideo-padding { padding: 5px 10px; }
|
||||
.mistvideo-pointer { cursor: pointer; }
|
||||
.description {
|
||||
color: $semiFill;
|
||||
font-size: 0.9em;
|
||||
}
|
||||
.mistvideo-container {
|
||||
display: flex;
|
||||
flex-wrap: nowrap;
|
||||
}
|
||||
.mistvideo-container.mistvideo { display: inline-flex; max-width: 100%; }
|
||||
.mistvideo-container.mistvideo-row { flex-direction: row; }
|
||||
.mistvideo-container.mistvideo-column { flex-direction: column; }
|
||||
.mistvideo-container.mistvideo-center { justify-content: center; }
|
||||
|
||||
.mistvideo-align-right {
|
||||
margin-left: auto;
|
||||
margin-right: 0;
|
||||
}
|
||||
|
||||
.hover_window_container.pos > .outer_window {
|
||||
position: absolute;
|
||||
pointer-events: none;
|
||||
overflow: hidden;
|
||||
}
|
||||
.hover_window_container.pos > .outer_window > .inner_window {
|
||||
position: absolute;
|
||||
pointer-events: all;
|
||||
}
|
||||
.hover_window_container:not(:hover) > .outer_window > .inner_window,
|
||||
.hover_window_container > .outer_window[data-hidecursor] > .inner_window
|
||||
{ transition: all 0.5s ease-in 0.5s; }
|
||||
.outer_window > .inner_window { flex-grow: 1; }
|
||||
.hover_window_container > .outer_window > .inner_window > * { flex-shrink: 0; }
|
||||
|
||||
.mistvideo-draggable {
|
||||
overflow: hidden;
|
||||
}
|
||||
|
||||
.mistvideo-tooltip {
|
||||
position: absolute;
|
||||
background-color: $background;
|
||||
padding: 0.5em 1em;
|
||||
z-index: 2;
|
||||
}
|
||||
*:not(:hover) > .mistvideo-tooltip { transition: opacity 0.25s ease-in; }
|
||||
.mistvideo-tooltip .triangle {
|
||||
border: 10px solid $background;
|
||||
position: absolute;
|
||||
}
|
||||
.mistvideo-tracks label {
|
||||
display: block;
|
||||
}
|
||||
.mistvideo-tracks label > span {
|
||||
margin-right: 1em;
|
||||
}
|
||||
|
||||
a {
|
||||
color: $accent;
|
||||
}
|
||||
.mistvideo-log .logs {
|
||||
-webkit-user-select: text;
|
||||
-moz-user-select: text;
|
||||
-ms-user-select: text;
|
||||
user-select: text;
|
||||
}
|
||||
.mistvideo-placeholder {
|
||||
max-width: 100%;
|
||||
max-height: 100%;
|
||||
}
|
||||
|
||||
.mistvideo-topright {
|
||||
position: absolute;
|
||||
top: 0;
|
||||
right: 0;
|
||||
}
|
||||
.mistvideo-topleft {
|
||||
position: absolute;
|
||||
top: 0;
|
||||
left: 0;
|
||||
}
|
||||
.mistvideo-delay-display {
|
||||
animation: appear 1s;
|
||||
animation-iteration-count: 1;
|
||||
animation-timing-function: steps(1,end);
|
||||
}
|
||||
@keyframes appear { from { opacity: 0; } to { opacity: 1; } }
|
||||
|
||||
svg.icon {
|
||||
display: block;
|
||||
stroke-width: $strokeWidth;
|
||||
fill: none;
|
||||
stroke: none;
|
||||
}
|
||||
svg.icon.fill, svg.icon .fill { fill: $fill; }
|
||||
svg.icon.semiFill, svg.icon .semiFill { fill: $semiFill; }
|
||||
svg.icon.stroke, svg.icon .stroke { stroke: $stroke; vector-effect: non-scaling-stroke; }
|
||||
svg.icon.off .toggle.fill,
|
||||
svg.icon.off .toggle.semiFill,
|
||||
svg.icon.off .toggle .fill,
|
||||
svg.icon.off .toggle .semiFill { fill: none; }
|
||||
svg.icon.spin, svg.icon .spin {
|
||||
animation: spin 1.5s infinite linear;
|
||||
transform-origin: 50% 50%;
|
||||
}
|
1279
embed/skins/video-js.css
Normal file
1279
embed/skins/video-js.css
Normal file
File diff suppressed because one or more lines are too long
Loading…
Add table
Add a link
Reference in a new issue