Dwinzo_dev/app/src/styles/components/simulation/simulation.scss

663 lines
15 KiB
SCSS

@use "../../abstracts/variables" as *;
@use "../../abstracts/mixins" as *;
.simulation-player-wrapper {
position: fixed;
bottom: 32px;
left: 50%;
z-index: 2;
transform: translate(-50%, 0);
width: 70vw;
transition: all 0.3s;
&.hide {
width: fit-content;
.simulation-player-container
.controls-container
.simulation-button-container {
width: 32px;
height: 24px;
}
}
.simulation-player-container {
background: var(--background-color);
padding: 7px;
border-radius: #{$border-radius-xlarge};
display: flex;
flex-direction: column;
gap: 8px;
backdrop-filter: blur(10px);
outline: 1px solid var(--border-color);
.progresser-wrapper {
outline: 1px solid var(--border-color);
background: var(--background-color);
border-radius: #{$border-radius-large};
display: flex;
flex-direction: column;
gap: 12px;
padding: 12px 5px;
padding-top: 38px;
transition: height 0.2s linear;
}
.controls-container {
@include flex-space-between;
gap: 12px;
justify-content: space-between;
.header {
@include flex-center;
gap: 6px;
padding: 0 8px;
svg {
scale: 1.3;
}
}
.production-details,
.controls-wrapper {
@include flex-center;
gap: 6px;
}
.production-details {
.production-wrapper {
display: flex;
align-items: center;
flex-direction: column;
gap: 6px;
.header {
display: flex;
flex-direction: row;
gap: 6px;
}
.progress-wrapper {
width: 164px;
height: 8px;
border-radius: #{$border-radius-small};
background: var(--background-color-solid);
.progress {
border-radius: #{$border-radius-small};
height: 100%;
background-color: var(--background-color-accent);
}
}
}
}
.expand-icon-container {
@include flex-center;
padding: 0 8px;
cursor: pointer;
}
.simulation-button-container {
@include flex-center;
gap: 2px;
padding: 4px 8px;
width: 64px;
background: var(--background-color);
border-radius: #{$border-radius-extra-large};
height: fit-content;
cursor: pointer;
transition: all 0.2s;
outline: 1px solid transparent;
&:hover {
outline: 1px solid var(--border-color);
background: var(--background-color);
color: var(--accent-color);
path {
stroke: var(--accent-color);
}
}
}
}
.speed-control-container {
@include flex-center;
gap: 32px;
padding: 5px 16px;
border-radius: #{$border-radius-medium};
box-sizing: #{$box-shadow-medium};
position: relative;
.min-value,
.max-value {
display: flex;
align-items: center;
font-weight: var(--font-weight-bold);
}
.slider-container {
width: 100%;
max-width: 80vw;
height: 28px;
border-radius: #{$border-radius-small};
position: relative;
.speed-label {
font-size: var(--font-size-tiny);
position: absolute;
bottom: -7px;
transform: translate(-50%, -0%);
&:first-child {
left: 0;
}
&:last-child {
right: -10px;
}
}
&::after {
content: "";
background: var(--background-color-solid);
opacity: 0.4;
position: absolute;
top: 50%;
transform: translate(0, -50%);
width: 100%;
height: 3px;
}
.custom-slider-wrapper {
height: 100%;
width: 100%;
padding: 0 26px;
background: transparent;
border-radius: #{$border-radius-large};
}
.custom-slider {
height: 100%;
width: 100%;
position: relative;
.slider-input {
position: absolute;
width: 100%;
height: 100%;
opacity: 0;
z-index: 3;
cursor: pointer;
}
.slider-handle {
position: absolute;
top: 50%;
min-width: 44px;
padding: 0 8px;
line-height: 20px;
text-align: center;
background: var(--background-color-button);
color: var(--text-button-color);
border-radius: #{$border-radius-large};
transform: translate(-50%, -50%);
font-size: var(--font-size-small);
cursor: pointer;
z-index: 2;
}
}
.marker {
position: absolute;
background: var(--background-color-solid);
opacity: 0.6;
width: 2px;
height: 12px;
top: 8px;
z-index: 1;
}
.marker.marker-10 {
left: 10%;
}
.marker.marker-20 {
left: 20%;
}
.marker.marker-30 {
left: 30%;
}
.marker.marker-40 {
left: 40%;
}
.marker.marker-50 {
left: 50%;
}
.marker.marker-60 {
left: 60%;
}
.marker.marker-70 {
left: 70%;
}
.marker.marker-80 {
left: 80%;
}
.marker.marker-90 {
left: 90%;
}
}
}
.time-displayer {
@include flex-space-between;
gap: 24px;
height: auto;
opacity: 1;
transition: all 0.5s ease;
.start-time-wrappper,
.end-time-wrappper {
@include flex-center;
gap: 4px;
.icon {
@include flex-center;
}
}
.time-progresser {
flex: 1;
.timeline {
padding: 16px;
outline: 1px solid var(--border-color);
background: var(--background-color);
border-radius: #{$border-radius-xxx};
display: flex;
align-items: center;
width: 100%;
height: 33px;
.label-dot-wrapper {
@include flex-center;
position: relative;
.label {
position: absolute;
top: -36px;
transform: translate(0, -0);
font-size: 12px;
color: var(--text-color);
white-space: nowrap;
}
.dot {
width: 14px;
height: 14px;
border-radius: #{$border-radius-circle};
background-color: #d3d3e2;
&.filled {
background-color: var(--accent-color);
border: 4px solid #8f5cf2;
}
}
}
.line {
flex-grow: 1;
height: 4px;
background-color: #d3d3e2;
margin: 0 4px;
&.filled {
background-color: #8f5cf2;
}
}
}
}
}
}
.open {
.start-displayer,
.end-displayer {
display: none;
}
.timmer {
display: none;
}
.progresser-wrapper {
padding-top: 4px;
}
.time-displayer {
height: 0;
opacity: 0;
pointer-events: none;
display: none;
}
.processDisplayer {
padding: 0 8px;
background: transparent;
.process-player {
width: 0;
display: none !important;
}
}
}
}
.controls-player-container {
min-width: 26vw;
max-width: 80vw;
border-radius: 15px;
gap: 40px;
background: var(--background-color);
backdrop-filter: blur(20px);
cursor: pointer;
@include flex-center;
justify-content: space-between;
position: fixed;
bottom: 32px;
left: 50%;
transform: translate(-50%, 0);
color: var(--accent-color);
z-index: 100;
isolation: isolate;
font-weight: 700;
padding: 8px;
transition: all 0.2s;
&.hide {
min-width: auto;
width: 92px;
}
.controls-left,
.controls-right {
display: flex;
align-items: center;
gap: 12px;
font-size: var(--font-size-small);
.label {
text-transform: capitalize;
font-size: var(--font-size-small);
}
.walkMode-wrapper {
display: flex;
align-items: center;
gap: 4px;
.input-toggle-container {
padding: 0;
gap: 4px;
.label {
font-size: var(--font-size-small);
}
}
}
.btn-wrapper {
@include flex-center;
gap: 2px;
padding: 4px 8px;
width: 64px;
background: var(--background-color);
border-radius: 20px;
height: fit-content;
cursor: pointer;
transition: all 0.2s;
outline: 1px solid transparent;
&:hover {
outline: 1px solid var(--border-color);
color: var(--accent-color);
}
&.hide {
width: 32px;
}
.icon {
width: 16px;
height: 16px;
@include flex-center;
}
}
}
}
.processDisplayer {
border-radius: #{$border-radius-large};
outline: 1px solid var(--border-color);
background: var(--background-color);
padding: 20px 6px;
position: relative;
.timmer {
width: auto;
position: absolute;
bottom: 0;
font-size: var(--font-size-tiny);
}
.start-displayer {
bottom: 4px;
left: 16px;
}
.end-displayer {
bottom: 4px;
width: auto;
right: 16px;
}
.process-player {
position: absolute;
top: 50%;
transform: translate(0, -50%);
width: 3.946108102798462px;
height: 26px;
left: 86.81px;
border-radius: #{$border-radius-large};
border-width: 1px;
background: var(--background-color-accent, #6f42c1);
}
.process-wrapper {
.process-container {
position: relative;
display: flex;
width: 100%;
.process {
height: 5px;
border-radius: #{$border-radius-small};
color: white;
text-align: center;
line-height: 30px;
transition: width 0.3s ease;
}
}
}
}
.asset-details-card-wrapper {
pointer-events: none;
.asset-details-card-container {
position: relative;
padding: 8px;
background: var(--background-color);
backdrop-filter: blur(6px);
border-radius: #{$border-radius-large};
transform: translate(0, -100%);
z-index: 0;
box-shadow: inset 0px 10px 50px #80808075;
min-width: 124px;
&::before {
content: "";
position: absolute;
inset: 0;
border-radius: inherit;
background: linear-gradient(135deg, var(--accent-color), #ff00f000);
background-size: 400% 400%;
animation: borderAnimation 5s linear infinite;
-webkit-mask: linear-gradient(#fff 0 0) content-box,
linear-gradient(#fff 0 0);
mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
-webkit-mask-composite: xor;
mask-composite: exclude;
z-index: -1;
padding: 1px;
}
.asset-details-header {
@include flex-space-between;
gap: 12px;
.content {
.name {
text-wrap: nowrap;
max-width: 140px;
overflow: hidden;
text-overflow: ellipsis;
margin-bottom: 4px;
text-transform: capitalize;
}
.status-container {
.status {
display: flex;
align-items: center;
gap: 6px;
.icon {
@include flex-center;
}
}
}
.storage-container {
font-size: var(--font-size-tiny);
color: var(--highlight-text-color);
}
}
}
.process-running-container {
width: 100%;
height: 8px;
background: var(--background-color-solid);
margin-top: 12px;
border-radius: #{$border-radius-small};
overflow: hidden;
position: relative;
.process-running {
height: 100%;
width: 35%;
border-radius: #{$border-radius-small};
background: var(--process-color);
animation: playing-process 1s ease-in-out infinite;
}
}
.indication-arrow {
position: absolute;
left: 50%;
bottom: 0;
transform: translate(-50%, 10px);
filter: drop-shadow(0px 0px 4px #ffffff);
}
.count-ui-wrapper {
position: absolute;
right: -16px;
top: -2px;
padding: 4px;
padding-right: 8px;
.count-ui-container {
background: var(--background-color-solid);
padding: 8px;
outline: 1px solid var(--border-color);
border-radius: #{$border-radius-large};
box-shadow: inset 0px 10px 50px #8080803a;
max-width: 80px;
position: absolute;
left: 0;
.content {
@include flex-center;
gap: 2px;
.icon {
@include flex-center;
}
.display {
font-size: var(--font-size-small);
}
}
.value-container {
@include flex-center;
gap: 4px;
.progress-bar {
display: flex;
align-items: center;
gap: 1px;
height: 10px;
}
.block {
width: 5px;
height: 100%;
border-radius: 2px;
transition: background-color 0.3s;
background: var(--background-color);
overflow: hidden;
position: relative;
.fill {
height: 100%;
background: linear-gradient(
to top,
var(--background-color-accent) var(--process-fill-percentage),
transparent var(--process-fill-percentage)
);
}
}
.value {
font-size: var(--font-size-tiny);
color: var(--input-text-color);
}
}
}
}
}
}
@keyframes playing-process {
from {
transform: translateX(-100%);
}
to {
transform: translateX(300%);
}
}
@keyframes borderAnimation {
0% {
background-position: 0% 50%;
}
50% {
background-position: 100% 50%;
}
100% {
background-position: 0% 50%;
}
}