Files
com.xaymar.www/_sass/_block-media.scss
T
Michael Fabian 'Xaymar' Dirks 58d126287e Significant video player improvements
2022-11-26 05:12:02 +01:00

194 lines
3.9 KiB
SCSS

// --------------------------------------------------------------------------------
// Block: Media
// --------------------------------------------------------------------------------
.block-media {
position: relative;
overflow: hidden;
}
.block-media > a > .content,
.block-media > .content {
}
.block-media > figcaption {
display: block;
margin: 0;
padding: .25em .5em;
text-align: center;
font-size: 0.9em;
background: rgba(0, 0, 0, 0.5);
}
// --------------------------------------------------------------------------------
// Block: Media Player
// --------------------------------------------------------------------------------
.block-media.hide {
cursor: none;
}
.block-media > .top,
.block-media > .bottom {
margin: 0;
padding: 0.5rem .5rem;
}
.block-media > .top {
background: linear-gradient(to top, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.8) 80%);
position: absolute;
top: 0;
left: 0;
right: 0;
display: grid;
grid-template-columns: 1;
grid-template-rows: 1;
justify-content: stretch;
align-items: stretch;
gap: 0;
transition: top ease-in-out 333ms, opacity ease-in-out 333ms;
opacity: 1.0;
}
.block-media.hide > .top {
top: -100%;
opacity: 0.0;
}
.block-media > .top > .variant {
// ToDo: Style this
}
.block-media > .bottom {
background: linear-gradient(to bottom, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.8) 80%);
position: absolute;
bottom: 0;
left: 0;
right: 0;
display: grid;
grid-template-columns: max-content 1fr max-content max-content;
justify-content: stretch;
align-items: stretch;
gap: 0.5rem;
overflow: hidden;
user-select: none;
transition: bottom ease-in-out 333ms, opacity ease-in-out 333ms;
opacity: 1.0;
}
.block-media.hide > .bottom {
bottom: -100%;
}
.block-media > .bottom > .play {
width: 2rem;
height: 2rem;
margin: 0;
padding: 0;
font-size: 2rem;
line-height: 2rem;
text-align: center;
user-select: none;
}
.block-media > .bottom > .play.playing {
}
.block-media > .bottom > .playback {
margin: 0;
padding: 0;
display: grid;
grid-template-columns: max-content 1fr max-content;
justify-content: stretch;
align-items: stretch;
gap: 0.5rem;
user-select: none;
}
.block-media > .bottom > .playback > .time {
display: block;
height: 2rem;
margin: 0;
padding: 0;
text-align: right;
line-height: 2rem;
user-select: auto;
}
.block-media > .bottom > .playback > .progress {
display: block;
margin: 0;
padding: 0;
width: auto;
height: 100%;
user-select: none;
}
.block-media > .bottom > .audio {
margin: 0;
padding: 0;
display: grid;
grid-template-columns: max-content 1fr;
justify-content: stretch;
align-items: stretch;
gap: 0.5rem;
user-select: none;
}
.block-media > .bottom > .audio > .mute {
display: block;
margin: 0;
padding: 0;
width: 2rem;
height: 2rem;
font-size: 2rem;
line-height: 2rem;
text-align: center;
user-select: none;
}
.block-media > .bottom > .audio > .mute.muted {
}
.block-media > .bottom > .audio > .volume {
display: block;
margin: 0;
padding: 0;
width: auto;
height: 100%;
user-select: none;
}
.block-media > .bottom > .fullscreen {
width: 2rem;
height: 2rem;
margin: 0;
padding: 0;
font-size: 2rem;
line-height: 2rem;
text-align: center;
user-select: none;
}
// --------------------------------------------------------------------------------
// Block: Media > Audio
// --------------------------------------------------------------------------------
// --------------------------------------------------------------------------------
// Block: Media > Video
// --------------------------------------------------------------------------------
.block-media > a > video,
.block-media > video {
display: block;
width: 100%;
object-fit: contain;
object-position: center;
}
// --------------------------------------------------------------------------------
// Block: Media > Picture
// --------------------------------------------------------------------------------
.block-media > a > .content > img,
.block-media > .content > img {
display: block;
width: 100%;
}