vuetify
Version:
Vue Material Component Framework
221 lines • 6.44 kB
CSS
@layer vuetify-components {
.v-snackbar {
justify-content: center;
z-index: 10000;
margin: 8px;
margin-inline-end: calc(8px + var(--v-scrollbar-offset));
padding: var(--v-layout-top) var(--v-layout-right) var(--v-layout-bottom) var(--v-layout-left);
--v-snackbar-current-offset: var(--v-snackbar-offset);
transform: translateY(calc(var(--v-snackbar-direction) * (var(--v-snackbar-current-offset) + var(--v-snackbar-mobile-notch, 0px))));
transition: transform 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}
.v-snackbar:not(.v-snackbar--center):not(.v-snackbar--top) {
align-items: flex-end;
}
.v-snackbar__wrapper {
align-items: center;
display: flex;
flex-wrap: wrap;
max-width: 672px;
min-height: 48px;
min-width: 344px;
overflow: hidden;
padding: 0;
transition: 0.35s cubic-bezier(0.4, 0, 0.2, 1);
transition-property: height, width;
}
.v-snackbar__wrapper {
border-radius: 4px;
}
.v-snackbar--variant-plain, .v-snackbar--variant-outlined, .v-snackbar--variant-text, .v-snackbar--variant-tonal {
background: transparent;
color: inherit;
}
.v-snackbar--variant-plain {
opacity: 0.62;
}
.v-snackbar--variant-plain:focus, .v-snackbar--variant-plain:hover {
opacity: 1;
}
.v-snackbar--variant-plain .v-snackbar__overlay {
display: none;
}
.v-snackbar--variant-elevated, .v-snackbar--variant-flat {
background: rgb(var(--v-theme-surface-variant));
color: rgb(var(--v-theme-on-surface-variant));
}
.v-snackbar--variant-elevated {
box-shadow: 0px 1px 2px 0px rgba(var(--v-shadow-color), var(--v-shadow-key-opacity, 0.3)), 0px 2px 6px 2px rgba(var(--v-shadow-color), var(--v-shadow-ambient-opacity, 0.15));
--v-elevation-overlay: color-mix(in srgb, var(--v-elevation-overlay-color) 4%, transparent);
}
.v-snackbar--variant-flat {
box-shadow: 0px 0px 0px 0px rgba(var(--v-shadow-color), var(--v-shadow-key-opacity, 0.3)), 0px 0px 0px 0px rgba(var(--v-shadow-color), var(--v-shadow-ambient-opacity, 0.15));
--v-elevation-overlay: color-mix(in srgb, var(--v-elevation-overlay-color) 0%, transparent);
}
.v-snackbar--variant-outlined {
border: thin solid currentColor;
}
.v-snackbar--variant-text .v-snackbar__overlay {
background: currentColor;
}
.v-snackbar--variant-tonal .v-snackbar__underlay {
background: currentColor;
opacity: var(--v-activated-opacity);
border-radius: inherit;
top: 0;
right: 0;
bottom: 0;
left: 0;
pointer-events: none;
}
.v-snackbar .v-snackbar__underlay {
position: absolute;
}
.v-snackbar--variant-outlined, .v-snackbar--variant-tonal {
background: rgb(var(--v-theme-surface));
}
@media (forced-colors: active) {
.v-snackbar__wrapper {
border: thick solid;
}
}
.v-snackbar__header {
flex-basis: 100%;
}
.v-snackbar__header:after {
content: "";
display: block;
flex-basis: 100%;
}
.v-snackbar__prepend {
align-self: center;
display: flex;
margin-inline: 16px 12px;
}
.v-snackbar__prepend + .v-snackbar__content {
padding-inline-start: 0;
}
.v-snackbar__title {
font-weight: 700;
}
.v-snackbar__content {
flex: 1 1;
font-size: 0.875rem;
font-weight: 400;
letter-spacing: 0.0178571429em;
line-height: 1.4285714286;
margin-right: auto;
padding: 14px 16px;
text-align: initial;
}
.v-snackbar__actions {
align-items: center;
align-self: center;
display: flex;
margin-inline-end: 8px;
}
.v-snackbar__actions > .v-btn {
padding: 0 8px;
min-width: auto;
}
.v-snackbar__timer {
width: 100%;
position: absolute;
}
.v-snackbar__timer--top {
top: 0;
}
.v-snackbar__timer--bottom {
bottom: 0;
}
.v-snackbar__timer .v-progress-linear {
transition: 0.2s linear;
}
.v-snackbar--absolute {
position: absolute;
z-index: 1;
}
.v-snackbar--vertical .v-snackbar__actions {
flex-basis: 100%;
justify-content: end;
margin-bottom: 8px;
}
.v-snackbar--vertical .v-snackbar__actions:before {
content: "";
display: block;
flex-basis: 100%;
}
.v-snackbar--center {
align-items: center;
justify-content: center;
}
.v-snackbar--top {
align-items: flex-start;
}
@media (max-width: 839.98px) {
.v-snackbar--top {
--v-snackbar-mobile-notch: max(env(safe-area-inset-top), 0px);
}
}
.v-snackbar--bottom {
align-items: flex-end;
}
@media (max-width: 839.98px) {
.v-snackbar--bottom {
--v-snackbar-mobile-notch: max(env(safe-area-inset-bottom), 0px);
}
}
.v-snackbar--left, .v-snackbar--start {
justify-content: flex-start;
}
.v-snackbar--right, .v-snackbar--end {
justify-content: flex-end;
}
.v-snackbar--collapsed {
--v-snackbar-current-offset: calc(var(--v-snackbar-gap) * var(--v-snackbar-index, 0));
}
.v-snackbar--collapsed .v-snackbar__wrapper {
min-width: 0;
width: calc(var(--v-snackbar-collapsed-width) - 2 * var(--v-snackbar-gap) * var(--v-snackbar-index, 0));
height: var(--v-snackbar-collapsed-height);
}
.v-snackbar--collapsed .v-snackbar__wrapper > * {
opacity: 0;
}
.v-snackbar--collapsed.v-snackbar--start .v-snackbar__wrapper, .v-snackbar--collapsed.v-snackbar--left .v-snackbar__wrapper {
transform: translateX(calc(var(--v-snackbar-gap) * var(--v-snackbar-index, 0)));
}
.v-snackbar--collapsed.v-snackbar--end .v-snackbar__wrapper, .v-snackbar--collapsed.v-snackbar--right .v-snackbar__wrapper {
transform: translateX(calc(-1 * var(--v-snackbar-gap) * var(--v-snackbar-index, 0)));
}
.v-snackbar--collapsed .v-progress-linear {
opacity: 0;
}
.v-snackbar .v-avatar {
background: transparent;
}
}
@layer vuetify-final.transitions {
.v-snackbar-transition-enter-active, .v-snackbar-transition-leave-active {
transition-duration: 0.15s;
transition-timing-function: cubic-bezier(0, 0, 0.2, 1);
}
.v-snackbar-transition-enter-active {
transition-property: opacity, transform;
}
@media (prefers-reduced-motion: reduce) {
.v-snackbar-transition-enter-active {
transition-property: opacity;
}
}
.v-snackbar-transition-enter-from {
opacity: 0;
transform: scale(0.8);
}
.v-snackbar-transition-leave-active {
transition-property: opacity;
}
.v-snackbar-transition-leave-to {
opacity: 0;
}
}