391 lines
8.0 KiB
SCSS
391 lines
8.0 KiB
SCSS
|
// Modals
|
||
|
// *******************************************************************************
|
||
|
//modal header btn close style
|
||
|
.modal {
|
||
|
.btn-close {
|
||
|
background-color: $card-bg;
|
||
|
border-radius: $border-radius-sm;
|
||
|
background-image: str-replace(str-replace($btn-close-bg, '#{$btn-close-color}', $text-muted), '#', '%23');
|
||
|
opacity: 1;
|
||
|
padding: 0.3757rem;
|
||
|
box-shadow: $box-shadow-xs;
|
||
|
transition: all 0.23s ease 0.1s;
|
||
|
@include ltr-style {
|
||
|
transform: translate(23px, -25px);
|
||
|
}
|
||
|
|
||
|
@include rtl-style {
|
||
|
transform: translate(-31px, -25px);
|
||
|
}
|
||
|
|
||
|
// For hover effect of close btn
|
||
|
&:hover,
|
||
|
&:focus,
|
||
|
&:active {
|
||
|
opacity: 1;
|
||
|
outline: none;
|
||
|
|
||
|
@include ltr-style {
|
||
|
transform: translate(20px, -20px);
|
||
|
}
|
||
|
|
||
|
@include rtl-style {
|
||
|
transform: translate(-26px, -20px);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.modal-header {
|
||
|
position: relative;
|
||
|
.btn-close {
|
||
|
position: absolute;
|
||
|
top: $modal-dialog-margin + 0.1875rem;
|
||
|
@include ltr-style() {
|
||
|
right: $modal-footer-margin-between - 0.1875rem;
|
||
|
}
|
||
|
@include rtl-style {
|
||
|
left: $modal-footer-margin-between + 0.3;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
//modal footer
|
||
|
.modal-footer {
|
||
|
padding: $modal-footer-padding;
|
||
|
> * {
|
||
|
margin-block: 0;
|
||
|
@include ltr-style {
|
||
|
&:last-child {
|
||
|
margin-right: 0;
|
||
|
}
|
||
|
&:first-child {
|
||
|
margin-left: 0;
|
||
|
}
|
||
|
}
|
||
|
@include rtl-style {
|
||
|
&:last-child {
|
||
|
margin-left: 0;
|
||
|
}
|
||
|
&:first-child {
|
||
|
margin-right: 0;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// Modal Shadow
|
||
|
.modal-content {
|
||
|
box-shadow: $modal-content-box-shadow-xs;
|
||
|
}
|
||
|
|
||
|
// Modal RTL
|
||
|
// ! remove close button animation & shadow for .modal-dialog-scrollable, .modal-fullscreen, .modal-top modal
|
||
|
.modal-dialog-scrollable,
|
||
|
.modal-fullscreen,
|
||
|
.modal-top {
|
||
|
.btn-close {
|
||
|
box-shadow: none;
|
||
|
@include ltr-style {
|
||
|
transform: translate(0, 0) !important;
|
||
|
}
|
||
|
|
||
|
@include rtl-style {
|
||
|
transform: translate(0, 0) !important;
|
||
|
}
|
||
|
&:hover {
|
||
|
@include ltr-style {
|
||
|
transform: translate(0, 0) !important;
|
||
|
}
|
||
|
|
||
|
@include rtl-style {
|
||
|
transform: translate(0, 0) !important;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// Onboarding Modals
|
||
|
// *******************************************************************************
|
||
|
|
||
|
.modal-onboarding {
|
||
|
.close-label {
|
||
|
font-size: 0.8rem;
|
||
|
position: absolute;
|
||
|
top: 0.85rem;
|
||
|
opacity: $btn-close-opacity;
|
||
|
&:hover {
|
||
|
opacity: $btn-close-hover-opacity;
|
||
|
}
|
||
|
}
|
||
|
.modal-header {
|
||
|
.btn-close {
|
||
|
@include rtl-style {
|
||
|
margin-left: 0;
|
||
|
margin-right: auto;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.onboarding-media {
|
||
|
margin-bottom: 1rem;
|
||
|
img {
|
||
|
margin: 0 auto;
|
||
|
}
|
||
|
}
|
||
|
.onboarding-content {
|
||
|
margin: 2rem;
|
||
|
}
|
||
|
form {
|
||
|
margin-top: 2rem;
|
||
|
text-align: left;
|
||
|
}
|
||
|
|
||
|
// Carousel Inside Modal
|
||
|
.carousel-indicators {
|
||
|
bottom: -10px;
|
||
|
}
|
||
|
|
||
|
.carousel-control-prev,
|
||
|
.carousel-control-next {
|
||
|
top: auto;
|
||
|
bottom: 0.75rem;
|
||
|
opacity: 1;
|
||
|
@include rtl-style {
|
||
|
flex-direction: row-reverse;
|
||
|
}
|
||
|
}
|
||
|
.carousel-control-prev {
|
||
|
left: 1rem;
|
||
|
}
|
||
|
.onboarding-horizontal {
|
||
|
display: flex;
|
||
|
justify-content: space-between;
|
||
|
align-items: center;
|
||
|
.onboarding-media {
|
||
|
margin: 2rem;
|
||
|
margin-top: 0;
|
||
|
}
|
||
|
.carousel-control-prev {
|
||
|
left: 0;
|
||
|
}
|
||
|
}
|
||
|
// Modal animation
|
||
|
&.animated {
|
||
|
.onboarding-media {
|
||
|
transform: translateY(10px) scale(0.8);
|
||
|
transition: all 0.5s cubic-bezier(0.25, 1.1, 0.5, 1.35);
|
||
|
transition-delay: 0.3s;
|
||
|
opacity: 0;
|
||
|
}
|
||
|
.onboarding-content {
|
||
|
transform: translateY(40px);
|
||
|
transition-delay: 0.1s;
|
||
|
transition: all 0.4s ease;
|
||
|
opacity: 0;
|
||
|
}
|
||
|
.onboarding-title {
|
||
|
opacity: 0;
|
||
|
transition-delay: 0.5s;
|
||
|
transition: all 0.5s cubic-bezier(0.25, 1.1, 0.5, 1.35);
|
||
|
transform: translateY(40px);
|
||
|
}
|
||
|
.onboarding-info {
|
||
|
opacity: 0;
|
||
|
transition-delay: 0.6s;
|
||
|
transition: all 0.5s cubic-bezier(0.25, 1.1, 0.5, 1.35);
|
||
|
transform: translateY(40px);
|
||
|
}
|
||
|
form {
|
||
|
opacity: 0;
|
||
|
transition-delay: 0.7s;
|
||
|
transition: all 0.5s ease;
|
||
|
transform: translateY(40px);
|
||
|
}
|
||
|
&.show {
|
||
|
.onboarding-media {
|
||
|
transform: translateY(0) scale(1);
|
||
|
opacity: 1;
|
||
|
}
|
||
|
.onboarding-content {
|
||
|
transform: translateY(0);
|
||
|
opacity: 1;
|
||
|
}
|
||
|
.onboarding-title {
|
||
|
transform: translateY(0);
|
||
|
opacity: 1;
|
||
|
}
|
||
|
.onboarding-info {
|
||
|
opacity: 1;
|
||
|
transform: translateY(0px);
|
||
|
}
|
||
|
form {
|
||
|
opacity: 1;
|
||
|
transform: translateY(0px);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// Top modals
|
||
|
// *******************************************************************************
|
||
|
|
||
|
.modal-top {
|
||
|
.modal-dialog {
|
||
|
margin-top: 0;
|
||
|
}
|
||
|
|
||
|
.modal-content {
|
||
|
@include border-top-radius(0);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// Transparent modals
|
||
|
// ******************************************************************************
|
||
|
|
||
|
.modal-transparent {
|
||
|
.modal-dialog {
|
||
|
display: flex;
|
||
|
margin: 0 auto;
|
||
|
min-height: 100vh;
|
||
|
}
|
||
|
|
||
|
.modal-content {
|
||
|
margin: auto;
|
||
|
width: 100%;
|
||
|
border: 0;
|
||
|
background: transparent;
|
||
|
box-shadow: none;
|
||
|
}
|
||
|
|
||
|
.btn-close {
|
||
|
position: absolute;
|
||
|
top: 0;
|
||
|
right: $modal-inner-padding;
|
||
|
opacity: 1;
|
||
|
padding: $btn-close-padding-y $btn-close-padding-x;
|
||
|
background-image: str-replace(str-replace($btn-close-bg, '#{$btn-close-color}', $white), '#', '%23');
|
||
|
background-color: transparent !important;
|
||
|
box-shadow: none;
|
||
|
@include rtl-style {
|
||
|
right: auto;
|
||
|
left: $modal-header-padding-x;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// Modal Simple (Modal Examples)
|
||
|
// ******************************************************************************
|
||
|
|
||
|
.modal-simple {
|
||
|
.modal-content {
|
||
|
padding: $modal-simple-padding;
|
||
|
@include media-breakpoint-down(md) {
|
||
|
padding: 1rem;
|
||
|
.modal-body {
|
||
|
padding: 1rem;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
.btn-close {
|
||
|
position: absolute;
|
||
|
top: -($modal-simple-padding - $modal-simple-close-position);
|
||
|
@include rtl-style() {
|
||
|
left: -($modal-simple-padding - $modal-simple-close-position);
|
||
|
}
|
||
|
@include ltr-style() {
|
||
|
right: -($modal-simple-padding - $modal-simple-close-position);
|
||
|
}
|
||
|
// For small screen set top, left/right 0 p-3, p-md-5
|
||
|
@include media-breakpoint-down(md) {
|
||
|
top: 0;
|
||
|
@include rtl-style() {
|
||
|
left: 0;
|
||
|
}
|
||
|
@include ltr-style() {
|
||
|
right: 0;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// Refer & Earn Modal Example
|
||
|
.modal-refer-and-earn {
|
||
|
.modal-refer-and-earn-step {
|
||
|
width: 88px;
|
||
|
height: 88px;
|
||
|
display: flex;
|
||
|
justify-content: center;
|
||
|
align-items: center;
|
||
|
border-radius: $card-border-radius;
|
||
|
i {
|
||
|
font-size: 2.5rem;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// Add new address modal
|
||
|
.modal-add-new-address {
|
||
|
.custom-option-icon:not(.checked) svg {
|
||
|
stroke: $headings-color;
|
||
|
}
|
||
|
.custom-option-icon.checked svg {
|
||
|
stroke: $primary;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// Modal Animations
|
||
|
// ******************************************************************************
|
||
|
|
||
|
// Slide from Top
|
||
|
.modal-top.fade .modal-dialog,
|
||
|
.modal-top .modal.fade .modal-dialog {
|
||
|
transform: translateY(-100%);
|
||
|
}
|
||
|
|
||
|
.modal-top.show .modal-dialog,
|
||
|
.modal-top .modal.show .modal-dialog {
|
||
|
transform: translateY(0);
|
||
|
}
|
||
|
|
||
|
// Transparent
|
||
|
.modal-transparent.fade .modal-dialog,
|
||
|
.modal-transparent .modal.fade .modal-dialog {
|
||
|
transform: scale(0.5, 0.5);
|
||
|
}
|
||
|
|
||
|
.modal-transparent.show .modal-dialog,
|
||
|
.modal-transparent .modal.show .modal-dialog {
|
||
|
transform: scale(1, 1);
|
||
|
}
|
||
|
|
||
|
// Responsive
|
||
|
// *******************************************************************************
|
||
|
|
||
|
@include media-breakpoint-down(lg) {
|
||
|
.modal-onboarding .onboarding-horizontal {
|
||
|
flex-direction: column;
|
||
|
}
|
||
|
}
|
||
|
@include media-breakpoint-down(md) {
|
||
|
.modal {
|
||
|
.carousel-control-prev,
|
||
|
.carousel-control-next {
|
||
|
display: none;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
@include media-breakpoint-up(sm) {
|
||
|
.modal-content {
|
||
|
box-shadow: $modal-content-box-shadow-sm-up;
|
||
|
}
|
||
|
|
||
|
.modal-sm .modal-dialog {
|
||
|
max-width: $modal-sm;
|
||
|
}
|
||
|
}
|
||
|
@include media-breakpoint-up(xl) {
|
||
|
.modal-xl .modal-dialog {
|
||
|
max-width: $modal-xl;
|
||
|
}
|
||
|
}
|