Files
com.xaymar.www/_sass/_block_figure-player.scss
T

187 lines
3.6 KiB
SCSS
Raw Normal View History

2022-11-26 05:12:02 +01:00
// --------------------------------------------------------------------------------
// Block: Media Player
// --------------------------------------------------------------------------------
2022-11-27 00:53:36 +01:00
$media-player-button-size: 1.5rem;
2022-11-26 05:12:02 +01:00
2023-04-04 20:50:04 +02:00
figure.block-media.hide {
2022-11-26 05:12:02 +01:00
cursor: none;
}
2023-04-04 20:50:04 +02:00
figure.block-media > .top,
figure.block-media > .bottom {
2022-11-27 00:53:36 +01:00
display: block;
2022-11-26 05:12:02 +01:00
margin: 0;
2022-11-27 00:53:36 +01:00
padding: 0.2rem 0.5rem;
2022-11-27 08:11:02 +01:00
z-index: 1;
2022-11-26 05:12:02 +01:00
}
2023-04-04 20:50:04 +02:00
figure.block-media > .top {
2022-11-26 05:12:02 +01:00
position: absolute;
top: 0;
left: 0;
right: 0;
2022-11-27 00:53:36 +01:00
display: flex;
2022-11-27 06:04:27 +01:00
padding-bottom: 1rem;
2022-11-27 00:53:36 +01:00
flex-flow: row nowrap;
justify-content: space-between;
2022-11-26 05:12:02 +01:00
align-items: stretch;
2022-11-27 00:53:36 +01:00
align-content: stretch;
gap: 0.5rem;
background: linear-gradient(to top, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.8) 80%);
transition: top ease-in-out 100ms, opacity ease-in-out 100s;
2022-11-26 05:12:02 +01:00
opacity: 1.0;
2022-11-27 00:53:36 +01:00
overflow: hidden;
user-select: none;
2022-11-26 05:12:02 +01:00
}
2023-04-04 20:50:04 +02:00
figure.block-media.hide > .top {
2022-11-26 05:12:02 +01:00
top: -100%;
opacity: 0.0;
2022-11-27 00:53:36 +01:00
transition: top ease-in-out 500ms, opacity ease-in-out 500s;
2022-11-26 05:12:02 +01:00
}
2023-04-04 20:50:04 +02:00
figure.block-media > .top > .variant {
2022-11-27 00:53:36 +01:00
flex-grow: 1;
2022-11-26 05:12:02 +01:00
}
2023-04-04 20:50:04 +02:00
figure.block-media > .bottom {
2022-11-26 05:12:02 +01:00
position: absolute;
bottom: 0;
left: 0;
right: 0;
2022-11-27 00:53:36 +01:00
display: flex;
2022-11-27 06:04:27 +01:00
padding-top: 1rem;
2022-11-27 00:53:36 +01:00
flex-flow: row nowrap;
justify-content: space-between;
2022-11-26 05:12:02 +01:00
align-items: stretch;
2022-11-27 00:53:36 +01:00
align-content: stretch;
2022-11-26 05:12:02 +01:00
gap: 0.5rem;
2022-11-27 00:53:36 +01:00
background: linear-gradient(to bottom, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.8) 80%);
transition: top ease-in-out 100ms, opacity ease-in-out 100s;
opacity: 1.0;
2022-11-26 05:12:02 +01:00
overflow: hidden;
user-select: none;
}
2023-04-04 20:50:04 +02:00
figure.block-media.hide > .bottom {
2022-11-26 05:12:02 +01:00
bottom: -100%;
2022-11-27 00:53:36 +01:00
opacity: 0.0;
transition: top ease-in-out 500ms, opacity ease-in-out 500s;
2022-11-26 05:12:02 +01:00
}
2023-04-04 20:50:04 +02:00
figure.block-media > .bottom > .play {
2022-11-27 00:53:36 +01:00
display: block;
2022-11-27 06:04:27 +01:00
flex-grow: 0;
2022-11-26 05:12:02 +01:00
margin: 0;
padding: 0;
2022-11-27 00:53:36 +01:00
width: $media-player-button-size;
height: $media-player-button-size;
2022-11-27 06:04:27 +01:00
2022-11-27 00:53:36 +01:00
font-size: $media-player-button-size;
line-height: $media-player-button-size;
2022-11-26 05:12:02 +01:00
text-align: center;
user-select: none;
}
2023-04-04 20:50:04 +02:00
figure.block-media > .bottom > .play.playing {
2022-11-26 05:12:02 +01:00
}
2023-04-04 20:50:04 +02:00
figure.block-media > .bottom > .time {
2022-11-27 06:04:27 +01:00
display: block;
2022-11-26 05:12:02 +01:00
margin: 0;
padding: 0;
2022-11-27 00:53:36 +01:00
width: auto;
height: $media-player-button-size;
flex-grow: 0;
flex-shrink: 0;
flex-basis: auto;
2022-11-26 05:12:02 +01:00
text-align: right;
2022-11-27 00:53:36 +01:00
line-height: $media-player-button-size;
2022-11-26 05:12:02 +01:00
user-select: auto;
}
2023-04-04 20:50:04 +02:00
figure.block-media > .bottom > .progress {
2022-11-26 05:12:02 +01:00
margin: 0;
padding: 0;
width: auto;
2022-11-27 00:53:36 +01:00
min-width: 5rem;
2022-11-26 05:12:02 +01:00
height: 100%;
2022-11-27 00:53:36 +01:00
flex-grow: 5;
flex-shrink: 1;
display: block;
2022-11-26 05:12:02 +01:00
user-select: none;
}
2023-04-04 20:50:04 +02:00
figure.block-media > .bottom > .mute {
2022-11-27 06:04:27 +01:00
display: block;
2022-11-26 05:12:02 +01:00
margin: 0;
padding: 0;
2022-11-27 00:53:36 +01:00
width: $media-player-button-size;
height: $media-player-button-size;
flex-grow: 0;
flex-shrink: 0;
flex-basis: auto;
2022-11-26 05:12:02 +01:00
2022-11-27 00:53:36 +01:00
font-size: $media-player-button-size;
line-height: $media-player-button-size;
2022-11-26 05:12:02 +01:00
text-align: center;
user-select: none;
}
2023-04-04 20:50:04 +02:00
figure.block-media > .bottom > .mute.muted {
2022-11-26 05:12:02 +01:00
}
2023-04-04 20:50:04 +02:00
figure.block-media > .bottom > .volume {
2022-11-27 06:04:27 +01:00
display: block;
2022-11-26 05:12:02 +01:00
margin: 0;
padding: 0;
width: auto;
2022-11-27 00:53:36 +01:00
min-width: 3rem;
max-width: 6rem;
2022-11-26 05:12:02 +01:00
height: 100%;
2022-11-27 00:53:36 +01:00
flex-grow: 1;
flex-shrink: 5;
flex-basis: auto;
2022-11-26 05:12:02 +01:00
user-select: none;
}
2023-04-04 20:50:04 +02:00
figure.block-media > .bottom > .fullscreen {
2022-11-27 06:04:27 +01:00
display: block;
2022-11-26 05:12:02 +01:00
margin: 0;
padding: 0;
2022-11-27 00:53:36 +01:00
width: $media-player-button-size;
height: $media-player-button-size;
flex-grow: 0;
flex-shrink: 0;
flex-basis: auto;
font-size: $media-player-button-size;
line-height: $media-player-button-size;
2022-11-26 05:12:02 +01:00
text-align: center;
user-select: none;
}
2022-11-27 00:53:36 +01:00
@media (max-width: 500px) {
2023-04-04 20:50:04 +02:00
figure.block-media > .bottom > .time {
2022-11-27 00:53:36 +01:00
display: none;
}
}
@media (max-width: 350px) {
2023-04-04 20:50:04 +02:00
figure.block-media > .bottom > .volume {
2022-11-27 00:53:36 +01:00
display: none;
}
}
@media (max-width: 250px) {
2023-04-04 20:50:04 +02:00
figure.block-media > .bottom > .play,
figure.block-media > .bottom > .mute,
figure.block-media > .bottom > .fullscreen {
2022-11-27 00:53:36 +01:00
display: none;
}
}