/**
* @copyright 2010-2013, The Titon Project
* @license http://opensource.org/licenses/bsd-license.php
* @link http://titon.io
*/
@import "../common";
$modal-transition: $default-transition !default;
/**
* Should be used in conjunction with the JavaScript Titon.Modal module.
*
*
*
*
* Custom content here
*
*
*
*
*/
.modal {
position: fixed;
top: 50%;
left: 50%;
width: 50%;
height: auto;
margin: 0;
padding: 0;
z-index: 610; // higher than blackout
max-width: 700px;
min-width: 350px;
visibility: hidden;
backface-visibility: hidden;
@include transform(translateX(-50%) translateY(-50%));
.close {
position: absolute;
top: -1px;
right: -35px;
}
&.is-loading {
.close { display: none; }
.modal-outer {
background: $gray;
}
}
}
// Used for animations, should also contain the styles
.modal-outer {
position: relative;
margin: 0 auto;
background: $gray;
border: 1px solid $gray-dark;
}
// Reset draggable cursor
.modal.is-draggable {
.modal-inner { cursor: default; }
.modal-head { cursor: move; }
}
// Apply block padding
.modal-head,
.modal-body,
.modal-foot,
.modal-loading,
.modal-error {
padding: $padding;
}
// Remove margins from text elements
.modal-body {
@include content-spacing;
}
//-------------------- Animations --------------------//
.modal {
&.from-above,
&.from-below,
&.slide-in-top,
&.slide-in-bottom,
&.slide-in-left,
&.slide-in-right,
&.flip,
&.flip-vert {
.modal-outer {
opacity: 0;
@include transition(all $modal-transition);
}
&.show .modal-outer {
opacity: 1;
}
}
&.fade {
opacity: 0;
@include transition(opacity $modal-transition);
}
&.from-above {
.modal-outer {
@include transform(scale(1.3));
}
&.show .modal-outer {
@include transform(scale(1));
}
}
&.from-below {
.modal-outer {
@include transform(scale(0.7));
}
&.show .modal-outer {
@include transform(scale(1));
}
}
&.slide-in-top {
.modal-outer {
@include transform(translateY(-50%));
}
&.show .modal-outer {
@include transform(translateY(0));
}
}
&.slide-in-bottom {
.modal-outer {
@include transform(translateY(50%));
}
&.show .modal-outer {
@include transform(translateY(0));
}
}
&.slide-in-left {
.modal-outer {
@include transition(all $modal-transition cubic-bezier(0.25, 0.5, 0.5, 0.9));
@include transform(translateX(-50%));
}
&.show .modal-outer {
@include transform(translateX(0));
}
}
&.slide-in-right {
.modal-outer {
@include transition(all $modal-transition cubic-bezier(0.25, 0.5, 0.5, 0.9));
@include transform(translateX(50%));
}
&.show .modal-outer {
@include transform(translateX(0));
}
}
&.sticky-top {
top: -100%;
opacity: 0;
@include transition(all $modal-transition);
@include transform(translateX(-50%)); // reset to x
&.show {
top: 0;
opacity: 1;
}
}
&.sticky-bottom {
top: auto;
bottom: -100%;
opacity: 0;
@include transition(all $modal-transition);
@include transform(translateX(-50%)); // reset to x
&.show {
bottom: 0;
opacity: 1;
}
}
&.sticky-left {
left: -100%;
opacity: 0;
@include transition(all $modal-transition);
@include transform(translate(0, -50%));
&.show {
left: 0;
opacity: 1;
}
}
&.sticky-right {
left: auto;
right: -100%;
opacity: 0;
@include transition(all $modal-transition);
@include transform(translate(0, -50%));
&.show {
right: 0;
opacity: 1;
}
}
&.flip {
@include perspective(1300px);
.modal-outer {
@include transform-style(preserve-3d);
@include transform(rotateY(-70deg));
}
&.show .modal-outer {
@include transform(rotateY(0deg));
}
}
&.flip-vert {
@include perspective(1300px);
.modal-outer {
@include transform-style(preserve-3d);
@include transform(rotateX(-70deg));
}
&.show .modal-outer {
@include transform(rotateX(0deg));
}
}
}