mirror of https://github.com/Ombi-app/Ombi
parent
94b103f4d4
commit
35a4c2ab5a
@ -0,0 +1,85 @@
|
||||
/*
|
||||
* Usage:
|
||||
*
|
||||
<div class="sk-folding-cube">
|
||||
<div class="sk-cube1 sk-cube"></div>
|
||||
<div class="sk-cube2 sk-cube"></div>
|
||||
<div class="sk-cube4 sk-cube"></div>
|
||||
<div class="sk-cube3 sk-cube"></div>
|
||||
</div>
|
||||
*
|
||||
*/
|
||||
.sk-folding-cube {
|
||||
margin: 40px auto;
|
||||
width: 40px;
|
||||
height: 40px;
|
||||
position: relative;
|
||||
-webkit-transform: rotateZ(45deg);
|
||||
transform: rotateZ(45deg); }
|
||||
.sk-folding-cube .sk-cube {
|
||||
float: left;
|
||||
width: 50%;
|
||||
height: 50%;
|
||||
position: relative;
|
||||
-webkit-transform: scale(1.1);
|
||||
-ms-transform: scale(1.1);
|
||||
transform: scale(1.1); }
|
||||
.sk-folding-cube .sk-cube:before {
|
||||
content: '';
|
||||
position: absolute;
|
||||
top: 0;
|
||||
left: 0;
|
||||
width: 100%;
|
||||
height: 100%;
|
||||
background-color: #333;
|
||||
-webkit-animation: sk-foldCubeAngle 2.4s infinite linear both;
|
||||
animation: sk-foldCubeAngle 2.4s infinite linear both;
|
||||
-webkit-transform-origin: 100% 100%;
|
||||
-ms-transform-origin: 100% 100%;
|
||||
transform-origin: 100% 100%; }
|
||||
.sk-folding-cube .sk-cube2 {
|
||||
-webkit-transform: scale(1.1) rotateZ(90deg);
|
||||
transform: scale(1.1) rotateZ(90deg); }
|
||||
.sk-folding-cube .sk-cube3 {
|
||||
-webkit-transform: scale(1.1) rotateZ(180deg);
|
||||
transform: scale(1.1) rotateZ(180deg); }
|
||||
.sk-folding-cube .sk-cube4 {
|
||||
-webkit-transform: scale(1.1) rotateZ(270deg);
|
||||
transform: scale(1.1) rotateZ(270deg); }
|
||||
.sk-folding-cube .sk-cube2:before {
|
||||
-webkit-animation-delay: 0.3s;
|
||||
animation-delay: 0.3s; }
|
||||
.sk-folding-cube .sk-cube3:before {
|
||||
-webkit-animation-delay: 0.6s;
|
||||
animation-delay: 0.6s; }
|
||||
.sk-folding-cube .sk-cube4:before {
|
||||
-webkit-animation-delay: 0.9s;
|
||||
animation-delay: 0.9s; }
|
||||
|
||||
@-webkit-keyframes sk-foldCubeAngle {
|
||||
0%, 10% {
|
||||
-webkit-transform: perspective(140px) rotateX(-180deg);
|
||||
transform: perspective(140px) rotateX(-180deg);
|
||||
opacity: 0; }
|
||||
25%, 75% {
|
||||
-webkit-transform: perspective(140px) rotateX(0deg);
|
||||
transform: perspective(140px) rotateX(0deg);
|
||||
opacity: 1; }
|
||||
90%, 100% {
|
||||
-webkit-transform: perspective(140px) rotateY(180deg);
|
||||
transform: perspective(140px) rotateY(180deg);
|
||||
opacity: 0; } }
|
||||
|
||||
@keyframes sk-foldCubeAngle {
|
||||
0%, 10% {
|
||||
-webkit-transform: perspective(140px) rotateX(-180deg);
|
||||
transform: perspective(140px) rotateX(-180deg);
|
||||
opacity: 0; }
|
||||
25%, 75% {
|
||||
-webkit-transform: perspective(140px) rotateX(0deg);
|
||||
transform: perspective(140px) rotateX(0deg);
|
||||
opacity: 1; }
|
||||
90%, 100% {
|
||||
-webkit-transform: perspective(140px) rotateY(180deg);
|
||||
transform: perspective(140px) rotateY(180deg);
|
||||
opacity: 0; } }
|
@ -0,0 +1,161 @@
|
||||
/* line 17, ../src/please-wait.scss */
|
||||
body.pg-loading {
|
||||
overflow: hidden;
|
||||
}
|
||||
|
||||
/* line 21, ../src/please-wait.scss */
|
||||
.pg-loading-screen {
|
||||
position: fixed;
|
||||
bottom: 0;
|
||||
left: 0;
|
||||
right: 0;
|
||||
top: 0;
|
||||
z-index: 1000000;
|
||||
opacity: 1;
|
||||
background-color: #FFF;
|
||||
-webkit-transition: background-color 0.4s ease-in-out 0s;
|
||||
-moz-transition: background-color 0.4s ease-in-out 0s;
|
||||
-ms-transition: background-color 0.4s ease-in-out 0s;
|
||||
-o-transition: background-color 0.4s ease-in-out 0s;
|
||||
transition: background-color 0.4s ease-in-out 0s;
|
||||
}
|
||||
/* line 32, ../src/please-wait.scss */
|
||||
.pg-loading-screen.pg-loaded {
|
||||
opacity: 0;
|
||||
-webkit-animation: pgAnimLoaded 0.5s cubic-bezier(0.7, 0, 0.3, 1) both;
|
||||
-moz-animation: pgAnimLoaded 0.5s cubic-bezier(0.7, 0, 0.3, 1) both;
|
||||
-ms-animation: pgAnimLoaded 0.5s cubic-bezier(0.7, 0, 0.3, 1) both;
|
||||
-o-animation: pgAnimLoaded 0.5s cubic-bezier(0.7, 0, 0.3, 1) both;
|
||||
animation: pgAnimLoaded 0.5s cubic-bezier(0.7, 0, 0.3, 1) both;
|
||||
}
|
||||
/* line 38, ../src/please-wait.scss */
|
||||
.pg-loading-screen.pg-loading .pg-loading-logo-header, .pg-loading-screen.pg-loading .pg-loading-html {
|
||||
opacity: 1;
|
||||
}
|
||||
/* line 42, ../src/please-wait.scss */
|
||||
.pg-loading-screen.pg-loading .pg-loading-logo-header, .pg-loading-screen.pg-loading .pg-loading-html:not(.pg-loaded) {
|
||||
-webkit-animation: pgAnimLoading 1s cubic-bezier(0.7, 0, 0.3, 1) both;
|
||||
-moz-animation: pgAnimLoading 1s cubic-bezier(0.7, 0, 0.3, 1) both;
|
||||
-ms-animation: pgAnimLoading 1s cubic-bezier(0.7, 0, 0.3, 1) both;
|
||||
-o-animation: pgAnimLoading 1s cubic-bezier(0.7, 0, 0.3, 1) both;
|
||||
animation: pgAnimLoading 1s cubic-bezier(0.7, 0, 0.3, 1) both;
|
||||
}
|
||||
/* line 46, ../src/please-wait.scss */
|
||||
.pg-loading-screen.pg-loading .pg-loading-html:not(.pg-loaded) {
|
||||
-webkit-animation-delay: 0.3s;
|
||||
-moz-animation-delay: 0.3s;
|
||||
-ms-animation-delay: 0.3s;
|
||||
-o-animation-delay: 0.3s;
|
||||
animation-delay: 0.3s;
|
||||
}
|
||||
/* line 51, ../src/please-wait.scss */
|
||||
.pg-loading-screen .pg-loading-inner {
|
||||
height: 100%;
|
||||
width: 100%;
|
||||
margin: 0;
|
||||
padding: 0;
|
||||
position: static;
|
||||
}
|
||||
/* line 59, ../src/please-wait.scss */
|
||||
.pg-loading-screen .pg-loading-center-outer {
|
||||
width: 100%;
|
||||
padding: 0;
|
||||
display: table !important;
|
||||
height: 100%;
|
||||
position: absolute;
|
||||
top: 0;
|
||||
left: 0;
|
||||
margin: 0;
|
||||
}
|
||||
/* line 70, ../src/please-wait.scss */
|
||||
.pg-loading-screen .pg-loading-center-middle {
|
||||
padding: 0;
|
||||
vertical-align: middle;
|
||||
display: table-cell !important;
|
||||
margin: 0;
|
||||
text-align: center;
|
||||
}
|
||||
/* line 78, ../src/please-wait.scss */
|
||||
.pg-loading-screen .pg-loading-logo-header, .pg-loading-screen .pg-loading-html {
|
||||
width: 100%;
|
||||
opacity: 0;
|
||||
}
|
||||
/* line 83, ../src/please-wait.scss */
|
||||
.pg-loading-screen .pg-loading-logo-header {
|
||||
text-align: center;
|
||||
}
|
||||
/* line 86, ../src/please-wait.scss */
|
||||
.pg-loading-screen .pg-loading-logo-header img {
|
||||
display: inline-block !important;
|
||||
}
|
||||
/* line 91, ../src/please-wait.scss */
|
||||
.pg-loading-screen .pg-loading-html {
|
||||
margin-top: 90px;
|
||||
}
|
||||
/* line 94, ../src/please-wait.scss */
|
||||
.pg-loading-screen .pg-loading-html.pg-loaded {
|
||||
-webkit-transition: opacity 0.5s cubic-bezier(0.7, 0, 0.3, 1);
|
||||
-moz-transition: opacity 0.5s cubic-bezier(0.7, 0, 0.3, 1);
|
||||
-ms-transition: opacity 0.5s cubic-bezier(0.7, 0, 0.3, 1);
|
||||
-o-transition: opacity 0.5s cubic-bezier(0.7, 0, 0.3, 1);
|
||||
transition: opacity 0.5s cubic-bezier(0.7, 0, 0.3, 1);
|
||||
}
|
||||
/* line 97, ../src/please-wait.scss */
|
||||
.pg-loading-screen .pg-loading-html.pg-loaded.pg-removing {
|
||||
opacity: 0;
|
||||
}
|
||||
/* line 101, ../src/please-wait.scss */
|
||||
.pg-loading-screen .pg-loading-html.pg-loaded.pg-loading {
|
||||
opacity: 1;
|
||||
}
|
||||
|
||||
@-webkit-keyframes pgAnimLoading {
|
||||
from {
|
||||
opacity: 0;
|
||||
}
|
||||
}
|
||||
@-moz-keyframes pgAnimLoading {
|
||||
from {
|
||||
opacity: 0;
|
||||
}
|
||||
}
|
||||
@-o-keyframes pgAnimLoading {
|
||||
from {
|
||||
opacity: 0;
|
||||
}
|
||||
}
|
||||
@-ms-keyframes pgAnimLoading {
|
||||
from {
|
||||
opacity: 0;
|
||||
}
|
||||
}
|
||||
@keyframes pgAnimLoading {
|
||||
from {
|
||||
opacity: 0;
|
||||
}
|
||||
}
|
||||
@-webkit-keyframes pgAnimLoaded {
|
||||
from {
|
||||
opacity: 1;
|
||||
}
|
||||
}
|
||||
@-moz-keyframes pgAnimLoaded {
|
||||
from {
|
||||
opacity: 1;
|
||||
}
|
||||
}
|
||||
@-o-keyframes pgAnimLoaded {
|
||||
from {
|
||||
opacity: 1;
|
||||
}
|
||||
}
|
||||
@-ms-keyframes pgAnimLoaded {
|
||||
from {
|
||||
opacity: 1;
|
||||
}
|
||||
}
|
||||
@keyframes pgAnimLoaded {
|
||||
from {
|
||||
opacity: 1;
|
||||
}
|
||||
}
|
@ -0,0 +1,292 @@
|
||||
/**
|
||||
* please-wait
|
||||
* Display a nice loading screen while your app loads
|
||||
|
||||
* @author Pathgather <tech@pathgather.com>
|
||||
* @copyright Pathgather 2015
|
||||
* @license MIT <http://opensource.org/licenses/mit-license.php>
|
||||
* @link https://github.com/Pathgather/please-wait
|
||||
* @module please-wait
|
||||
* @version 0.0.5
|
||||
*/
|
||||
(function(root, factory) {
|
||||
if (typeof exports === "object") {
|
||||
factory(exports);
|
||||
} else if (typeof define === "function" && define.amd) {
|
||||
define(["exports"], factory);
|
||||
} else {
|
||||
factory(root);
|
||||
}
|
||||
})(this, function(exports) {
|
||||
var PleaseWait, addClass, animationEvent, animationSupport, domPrefixes, elm, key, pfx, pleaseWait, removeClass, transEndEventNames, transitionEvent, transitionSupport, val, _i, _len;
|
||||
elm = document.createElement('fakeelement');
|
||||
animationSupport = false;
|
||||
transitionSupport = false;
|
||||
animationEvent = 'animationend';
|
||||
transitionEvent = null;
|
||||
domPrefixes = 'Webkit Moz O ms'.split(' ');
|
||||
transEndEventNames = {
|
||||
'WebkitTransition': 'webkitTransitionEnd',
|
||||
'MozTransition': 'transitionend',
|
||||
'OTransition': 'oTransitionEnd',
|
||||
'msTransition': 'MSTransitionEnd',
|
||||
'transition': 'transitionend'
|
||||
};
|
||||
for (key in transEndEventNames) {
|
||||
val = transEndEventNames[key];
|
||||
if (elm.style[key] != null) {
|
||||
transitionEvent = val;
|
||||
transitionSupport = true;
|
||||
break;
|
||||
}
|
||||
}
|
||||
if (elm.style.animationName != null) {
|
||||
animationSupport = true;
|
||||
}
|
||||
if (!animationSupport) {
|
||||
for (_i = 0, _len = domPrefixes.length; _i < _len; _i++) {
|
||||
pfx = domPrefixes[_i];
|
||||
if (elm.style["" + pfx + "AnimationName"] != null) {
|
||||
switch (pfx) {
|
||||
case 'Webkit':
|
||||
animationEvent = 'webkitAnimationEnd';
|
||||
break;
|
||||
case 'Moz':
|
||||
animationEvent = 'animationend';
|
||||
break;
|
||||
case 'O':
|
||||
animationEvent = 'oanimationend';
|
||||
break;
|
||||
case 'ms':
|
||||
animationEvent = 'MSAnimationEnd';
|
||||
}
|
||||
animationSupport = true;
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
addClass = function(classname, elem) {
|
||||
if (elem.classList) {
|
||||
return elem.classList.add(classname);
|
||||
} else {
|
||||
return elem.className += " " + classname;
|
||||
}
|
||||
};
|
||||
removeClass = function(classname, elem) {
|
||||
if (elem.classList) {
|
||||
return elem.classList.remove(classname);
|
||||
} else {
|
||||
return elem.className = elem.className.replace(classname, "").trim();
|
||||
}
|
||||
};
|
||||
PleaseWait = (function() {
|
||||
PleaseWait._defaultOptions = {
|
||||
backgroundColor: null,
|
||||
logo: null,
|
||||
loadingHtml: null,
|
||||
template: "<div class='pg-loading-inner'>\n <div class='pg-loading-center-outer'>\n <div class='pg-loading-center-middle'>\n <h1 class='pg-loading-logo-header'>\n <img class='pg-loading-logo'></img>\n </h1>\n <div class='pg-loading-html'>\n </div>\n </div>\n </div>\n</div>",
|
||||
onLoadedCallback: null
|
||||
};
|
||||
|
||||
function PleaseWait(options) {
|
||||
var defaultOptions, k, listener, v;
|
||||
defaultOptions = this.constructor._defaultOptions;
|
||||
this.options = {};
|
||||
this.loaded = false;
|
||||
this.finishing = false;
|
||||
for (k in defaultOptions) {
|
||||
v = defaultOptions[k];
|
||||
this.options[k] = options[k] != null ? options[k] : v;
|
||||
}
|
||||
this._loadingElem = document.createElement("div");
|
||||
this._loadingHtmlToDisplay = [];
|
||||
this._loadingElem.className = "pg-loading-screen";
|
||||
if (this.options.backgroundColor != null) {
|
||||
this._loadingElem.style.backgroundColor = this.options.backgroundColor;
|
||||
}
|
||||
this._loadingElem.innerHTML = this.options.template;
|
||||
this._loadingHtmlElem = this._loadingElem.getElementsByClassName("pg-loading-html")[0];
|
||||
if (this._loadingHtmlElem != null) {
|
||||
this._loadingHtmlElem.innerHTML = this.options.loadingHtml;
|
||||
}
|
||||
this._readyToShowLoadingHtml = false;
|
||||
this._logoElem = this._loadingElem.getElementsByClassName("pg-loading-logo")[0];
|
||||
if (this._logoElem != null) {
|
||||
this._logoElem.src = this.options.logo;
|
||||
}
|
||||
removeClass("pg-loaded", document.body);
|
||||
addClass("pg-loading", document.body);
|
||||
document.body.appendChild(this._loadingElem);
|
||||
addClass("pg-loading", this._loadingElem);
|
||||
this._onLoadedCallback = this.options.onLoadedCallback;
|
||||
listener = (function(_this) {
|
||||
return function(evt) {
|
||||
_this.loaded = true;
|
||||
_this._readyToShowLoadingHtml = true;
|
||||
addClass("pg-loaded", _this._loadingHtmlElem);
|
||||
if (animationSupport) {
|
||||
_this._loadingHtmlElem.removeEventListener(animationEvent, listener);
|
||||
}
|
||||
if (_this._loadingHtmlToDisplay.length > 0) {
|
||||
_this._changeLoadingHtml();
|
||||
}
|
||||
if (_this.finishing) {
|
||||
if (evt != null) {
|
||||
evt.stopPropagation();
|
||||
}
|
||||
return _this._finish();
|
||||
}
|
||||
};
|
||||
})(this);
|
||||
if (this._loadingHtmlElem != null) {
|
||||
if (animationSupport) {
|
||||
this._loadingHtmlElem.addEventListener(animationEvent, listener);
|
||||
} else {
|
||||
listener();
|
||||
}
|
||||
this._loadingHtmlListener = (function(_this) {
|
||||
return function() {
|
||||
_this._readyToShowLoadingHtml = true;
|
||||
removeClass("pg-loading", _this._loadingHtmlElem);
|
||||
if (transitionSupport) {
|
||||
_this._loadingHtmlElem.removeEventListener(transitionEvent, _this._loadingHtmlListener);
|
||||
}
|
||||
if (_this._loadingHtmlToDisplay.length > 0) {
|
||||
return _this._changeLoadingHtml();
|
||||
}
|
||||
};
|
||||
})(this);
|
||||
this._removingHtmlListener = (function(_this) {
|
||||
return function() {
|
||||
_this._loadingHtmlElem.innerHTML = _this._loadingHtmlToDisplay.shift();
|
||||
removeClass("pg-removing", _this._loadingHtmlElem);
|
||||
addClass("pg-loading", _this._loadingHtmlElem);
|
||||
if (transitionSupport) {
|
||||
_this._loadingHtmlElem.removeEventListener(transitionEvent, _this._removingHtmlListener);
|
||||
return _this._loadingHtmlElem.addEventListener(transitionEvent, _this._loadingHtmlListener);
|
||||
} else {
|
||||
return _this._loadingHtmlListener();
|
||||
}
|
||||
};
|
||||
})(this);
|
||||
}
|
||||
}
|
||||
|
||||
PleaseWait.prototype.finish = function(immediately, onLoadedCallback) {
|
||||
if (immediately == null) {
|
||||
immediately = false;
|
||||
}
|
||||
if (window.document.hidden) {
|
||||
immediately = true;
|
||||
}
|
||||
this.finishing = true;
|
||||
if (onLoadedCallback != null) {
|
||||
this.updateOption('onLoadedCallback', onLoadedCallback);
|
||||
}
|
||||
if (this.loaded || immediately) {
|
||||
return this._finish(immediately);
|
||||
}
|
||||
};
|
||||
|
||||
PleaseWait.prototype.updateOption = function(option, value) {
|
||||
switch (option) {
|
||||
case 'backgroundColor':
|
||||
return this._loadingElem.style.backgroundColor = value;
|
||||
case 'logo':
|
||||
return this._logoElem.src = value;
|
||||
case 'loadingHtml':
|
||||
return this.updateLoadingHtml(value);
|
||||
case 'onLoadedCallback':
|
||||
return this._onLoadedCallback = value;
|
||||
default:
|
||||
throw new Error("Unknown option '" + option + "'");
|
||||
}
|
||||
};
|
||||
|
||||
PleaseWait.prototype.updateOptions = function(options) {
|
||||
var k, v, _results;
|
||||
if (options == null) {
|
||||
options = {};
|
||||
}
|
||||
_results = [];
|
||||
for (k in options) {
|
||||
v = options[k];
|
||||
_results.push(this.updateOption(k, v));
|
||||
}
|
||||
return _results;
|
||||
};
|
||||
|
||||
PleaseWait.prototype.updateLoadingHtml = function(loadingHtml, immediately) {
|
||||
if (immediately == null) {
|
||||
immediately = false;
|
||||
}
|
||||
if (this._loadingHtmlElem == null) {
|
||||
throw new Error("The loading template does not have an element of class 'pg-loading-html'");
|
||||
}
|
||||
if (immediately) {
|
||||
this._loadingHtmlToDisplay = [loadingHtml];
|
||||
this._readyToShowLoadingHtml = true;
|
||||
} else {
|
||||
this._loadingHtmlToDisplay.push(loadingHtml);
|
||||
}
|
||||
if (this._readyToShowLoadingHtml) {
|
||||
return this._changeLoadingHtml();
|
||||
}
|
||||
};
|
||||
|
||||
PleaseWait.prototype._changeLoadingHtml = function() {
|
||||
this._readyToShowLoadingHtml = false;
|
||||
this._loadingHtmlElem.removeEventListener(transitionEvent, this._loadingHtmlListener);
|
||||
this._loadingHtmlElem.removeEventListener(transitionEvent, this._removingHtmlListener);
|
||||
removeClass("pg-loading", this._loadingHtmlElem);
|
||||
removeClass("pg-removing", this._loadingHtmlElem);
|
||||
if (transitionSupport) {
|
||||
addClass("pg-removing", this._loadingHtmlElem);
|
||||
return this._loadingHtmlElem.addEventListener(transitionEvent, this._removingHtmlListener);
|
||||
} else {
|
||||
return this._removingHtmlListener();
|
||||
}
|
||||
};
|
||||
|
||||
PleaseWait.prototype._finish = function(immediately) {
|
||||
var listener;
|
||||
if (immediately == null) {
|
||||
immediately = false;
|
||||
}
|
||||
if (this._loadingElem == null) {
|
||||
return;
|
||||
}
|
||||
addClass("pg-loaded", document.body);
|
||||
if (typeof this._onLoadedCallback === "function") {
|
||||
this._onLoadedCallback.apply(this);
|
||||
}
|
||||
listener = (function(_this) {
|
||||
return function() {
|
||||
document.body.removeChild(_this._loadingElem);
|
||||
removeClass("pg-loading", document.body);
|
||||
if (animationSupport) {
|
||||
_this._loadingElem.removeEventListener(animationEvent, listener);
|
||||
}
|
||||
return _this._loadingElem = null;
|
||||
};
|
||||
})(this);
|
||||
if (!immediately && animationSupport) {
|
||||
addClass("pg-loaded", this._loadingElem);
|
||||
return this._loadingElem.addEventListener(animationEvent, listener);
|
||||
} else {
|
||||
return listener();
|
||||
}
|
||||
};
|
||||
|
||||
return PleaseWait;
|
||||
|
||||
})();
|
||||
pleaseWait = function(options) {
|
||||
if (options == null) {
|
||||
options = {};
|
||||
}
|
||||
return new PleaseWait(options);
|
||||
};
|
||||
exports.pleaseWait = pleaseWait;
|
||||
return pleaseWait;
|
||||
});
|
@ -0,0 +1,770 @@
|
||||
/*
|
||||
* Usage:
|
||||
*
|
||||
<div class="sk-rotating-plane"></div>
|
||||
*
|
||||
*/
|
||||
.sk-rotating-plane {
|
||||
width: 40px;
|
||||
height: 40px;
|
||||
background-color: #333;
|
||||
margin: 40px auto;
|
||||
-webkit-animation: sk-rotatePlane 1.2s infinite ease-in-out;
|
||||
animation: sk-rotatePlane 1.2s infinite ease-in-out; }
|
||||
|
||||
@-webkit-keyframes sk-rotatePlane {
|
||||
0% {
|
||||
-webkit-transform: perspective(120px) rotateX(0deg) rotateY(0deg);
|
||||
transform: perspective(120px) rotateX(0deg) rotateY(0deg); }
|
||||
50% {
|
||||
-webkit-transform: perspective(120px) rotateX(-180.1deg) rotateY(0deg);
|
||||
transform: perspective(120px) rotateX(-180.1deg) rotateY(0deg); }
|
||||
100% {
|
||||
-webkit-transform: perspective(120px) rotateX(-180deg) rotateY(-179.9deg);
|
||||
transform: perspective(120px) rotateX(-180deg) rotateY(-179.9deg); } }
|
||||
|
||||
@keyframes sk-rotatePlane {
|
||||
0% {
|
||||
-webkit-transform: perspective(120px) rotateX(0deg) rotateY(0deg);
|
||||
transform: perspective(120px) rotateX(0deg) rotateY(0deg); }
|
||||
50% {
|
||||
-webkit-transform: perspective(120px) rotateX(-180.1deg) rotateY(0deg);
|
||||
transform: perspective(120px) rotateX(-180.1deg) rotateY(0deg); }
|
||||
100% {
|
||||
-webkit-transform: perspective(120px) rotateX(-180deg) rotateY(-179.9deg);
|
||||
transform: perspective(120px) rotateX(-180deg) rotateY(-179.9deg); } }
|
||||
|
||||
/*
|
||||
* Usage:
|
||||
*
|
||||
<div class="sk-double-bounce">
|
||||
<div class="sk-child sk-double-bounce1"></div>
|
||||
<div class="sk-child sk-double-bounce2"></div>
|
||||
</div>
|
||||
*
|
||||
*/
|
||||
.sk-double-bounce {
|
||||
width: 40px;
|
||||
height: 40px;
|
||||
position: relative;
|
||||
margin: 40px auto; }
|
||||
.sk-double-bounce .sk-child {
|
||||
width: 100%;
|
||||
height: 100%;
|
||||
border-radius: 50%;
|
||||
background-color: #333;
|
||||
opacity: 0.6;
|
||||
position: absolute;
|
||||
top: 0;
|
||||
left: 0;
|
||||
-webkit-animation: sk-doubleBounce 2s infinite ease-in-out;
|
||||
animation: sk-doubleBounce 2s infinite ease-in-out; }
|
||||
.sk-double-bounce .sk-double-bounce2 {
|
||||
-webkit-animation-delay: -1.0s;
|
||||
animation-delay: -1.0s; }
|
||||
|
||||
@-webkit-keyframes sk-doubleBounce {
|
||||
0%, 100% {
|
||||
-webkit-transform: scale(0);
|
||||
transform: scale(0); }
|
||||
50% {
|
||||
-webkit-transform: scale(1);
|
||||
transform: scale(1); } }
|
||||
|
||||
@keyframes sk-doubleBounce {
|
||||
0%, 100% {
|
||||
-webkit-transform: scale(0);
|
||||
transform: scale(0); }
|
||||
50% {
|
||||
-webkit-transform: scale(1);
|
||||
transform: scale(1); } }
|
||||
|
||||
/*
|
||||
* Usage:
|
||||
*
|
||||
<div class="sk-wave">
|
||||
<div class="sk-rect sk-rect1"></div>
|
||||
<div class="sk-rect sk-rect2"></div>
|
||||
<div class="sk-rect sk-rect3"></div>
|
||||
<div class="sk-rect sk-rect4"></div>
|
||||
<div class="sk-rect sk-rect5"></div>
|
||||
</div>
|
||||
*
|
||||
*/
|
||||
.sk-wave {
|
||||
margin: 40px auto;
|
||||
width: 50px;
|
||||
height: 40px;
|
||||
text-align: center;
|
||||
font-size: 10px; }
|
||||
.sk-wave .sk-rect {
|
||||
background-color: #333;
|
||||
height: 100%;
|
||||
width: 6px;
|
||||
display: inline-block;
|
||||
-webkit-animation: sk-waveStretchDelay 1.2s infinite ease-in-out;
|
||||
animation: sk-waveStretchDelay 1.2s infinite ease-in-out; }
|
||||
.sk-wave .sk-rect1 {
|
||||
-webkit-animation-delay: -1.2s;
|
||||
animation-delay: -1.2s; }
|
||||
.sk-wave .sk-rect2 {
|
||||
-webkit-animation-delay: -1.1s;
|
||||
animation-delay: -1.1s; }
|
||||
.sk-wave .sk-rect3 {
|
||||
-webkit-animation-delay: -1s;
|
||||
animation-delay: -1s; }
|
||||
.sk-wave .sk-rect4 {
|
||||
-webkit-animation-delay: -0.9s;
|
||||
animation-delay: -0.9s; }
|
||||
.sk-wave .sk-rect5 {
|
||||
-webkit-animation-delay: -0.8s;
|
||||
animation-delay: -0.8s; }
|
||||
|
||||
@-webkit-keyframes sk-waveStretchDelay {
|
||||
0%, 40%, 100% {
|
||||
-webkit-transform: scaleY(0.4);
|
||||
transform: scaleY(0.4); }
|
||||
20% {
|
||||
-webkit-transform: scaleY(1);
|
||||
transform: scaleY(1); } }
|
||||
|
||||
@keyframes sk-waveStretchDelay {
|
||||
0%, 40%, 100% {
|
||||
-webkit-transform: scaleY(0.4);
|
||||
transform: scaleY(0.4); }
|
||||
20% {
|
||||
-webkit-transform: scaleY(1);
|
||||
transform: scaleY(1); } }
|
||||
|
||||
/*
|
||||
* Usage:
|
||||
*
|
||||
<div class="sk-wandering-cubes">
|
||||
<div class="sk-cube sk-cube1"></div>
|
||||
<div class="sk-cube sk-cube2"></div>
|
||||
</div>
|
||||
*
|
||||
*/
|
||||
.sk-wandering-cubes {
|
||||
margin: 40px auto;
|
||||
width: 40px;
|
||||
height: 40px;
|
||||
position: relative; }
|
||||
.sk-wandering-cubes .sk-cube {
|
||||
background-color: #333;
|
||||
width: 10px;
|
||||
height: 10px;
|
||||
position: absolute;
|
||||
top: 0;
|
||||
left: 0;
|
||||
-webkit-animation: sk-wanderingCube 1.8s ease-in-out -1.8s infinite both;
|
||||
animation: sk-wanderingCube 1.8s ease-in-out -1.8s infinite both; }
|
||||
.sk-wandering-cubes .sk-cube2 {
|
||||
-webkit-animation-delay: -0.9s;
|
||||
animation-delay: -0.9s; }
|
||||
|
||||
@-webkit-keyframes sk-wanderingCube {
|
||||
0% {
|
||||
-webkit-transform: rotate(0deg);
|
||||
transform: rotate(0deg); }
|
||||
25% {
|
||||
-webkit-transform: translateX(30px) rotate(-90deg) scale(0.5);
|
||||
transform: translateX(30px) rotate(-90deg) scale(0.5); }
|
||||
50% {
|
||||
/* Hack to make FF rotate in the right direction */
|
||||
-webkit-transform: translateX(30px) translateY(30px) rotate(-179deg);
|
||||
transform: translateX(30px) translateY(30px) rotate(-179deg); }
|
||||
50.1% {
|
||||
-webkit-transform: translateX(30px) translateY(30px) rotate(-180deg);
|
||||
transform: translateX(30px) translateY(30px) rotate(-180deg); }
|
||||
75% {
|
||||
-webkit-transform: translateX(0) translateY(30px) rotate(-270deg) scale(0.5);
|
||||
transform: translateX(0) translateY(30px) rotate(-270deg) scale(0.5); }
|
||||
100% {
|
||||
-webkit-transform: rotate(-360deg);
|
||||
transform: rotate(-360deg); } }
|
||||
|
||||
@keyframes sk-wanderingCube {
|
||||
0% {
|
||||
-webkit-transform: rotate(0deg);
|
||||
transform: rotate(0deg); }
|
||||
25% {
|
||||
-webkit-transform: translateX(30px) rotate(-90deg) scale(0.5);
|
||||
transform: translateX(30px) rotate(-90deg) scale(0.5); }
|
||||
50% {
|
||||
/* Hack to make FF rotate in the right direction */
|
||||
-webkit-transform: translateX(30px) translateY(30px) rotate(-179deg);
|
||||
transform: translateX(30px) translateY(30px) rotate(-179deg); }
|
||||
50.1% {
|
||||
-webkit-transform: translateX(30px) translateY(30px) rotate(-180deg);
|
||||
transform: translateX(30px) translateY(30px) rotate(-180deg); }
|
||||
75% {
|
||||
-webkit-transform: translateX(0) translateY(30px) rotate(-270deg) scale(0.5);
|
||||
transform: translateX(0) translateY(30px) rotate(-270deg) scale(0.5); }
|
||||
100% {
|
||||
-webkit-transform: rotate(-360deg);
|
||||
transform: rotate(-360deg); } }
|
||||
|
||||
/*
|
||||
* Usage:
|
||||
*
|
||||
<div class="sk-spinner sk-spinner-pulse"></div>
|
||||
*
|
||||
*/
|
||||
.sk-spinner-pulse {
|
||||
width: 40px;
|
||||
height: 40px;
|
||||
margin: 40px auto;
|
||||
background-color: #333;
|
||||
border-radius: 100%;
|
||||
-webkit-animation: sk-pulseScaleOut 1s infinite ease-in-out;
|
||||
animation: sk-pulseScaleOut 1s infinite ease-in-out; }
|
||||
|
||||
@-webkit-keyframes sk-pulseScaleOut {
|
||||
0% {
|
||||
-webkit-transform: scale(0);
|
||||
transform: scale(0); }
|
||||
100% {
|
||||
-webkit-transform: scale(1);
|
||||
transform: scale(1);
|
||||
opacity: 0; } }
|
||||
|
||||
@keyframes sk-pulseScaleOut {
|
||||
0% {
|
||||
-webkit-transform: scale(0);
|
||||
transform: scale(0); }
|
||||
100% {
|
||||
-webkit-transform: scale(1);
|
||||
transform: scale(1);
|
||||
opacity: 0; } }
|
||||
|
||||
/*
|
||||
* Usage:
|
||||
*
|
||||
<div class="sk-chasing-dots">
|
||||
<div class="sk-child sk-dot1"></div>
|
||||
<div class="sk-child sk-dot2"></div>
|
||||
</div>
|
||||
*
|
||||
*/
|
||||
.sk-chasing-dots {
|
||||
margin: 40px auto;
|
||||
width: 40px;
|
||||
height: 40px;
|
||||
position: relative;
|
||||
text-align: center;
|
||||
-webkit-animation: sk-chasingDotsRotate 2s infinite linear;
|
||||
animation: sk-chasingDotsRotate 2s infinite linear; }
|
||||
.sk-chasing-dots .sk-child {
|
||||
width: 60%;
|
||||
height: 60%;
|
||||
display: inline-block;
|
||||
position: absolute;
|
||||
top: 0;
|
||||
background-color: #333;
|
||||
border-radius: 100%;
|
||||
-webkit-animation: sk-chasingDotsBounce 2s infinite ease-in-out;
|
||||
animation: sk-chasingDotsBounce 2s infinite ease-in-out; }
|
||||
.sk-chasing-dots .sk-dot2 {
|
||||
top: auto;
|
||||
bottom: 0;
|
||||
-webkit-animation-delay: -1s;
|
||||
animation-delay: -1s; }
|
||||
|
||||
@-webkit-keyframes sk-chasingDotsRotate {
|
||||
100% {
|
||||
-webkit-transform: rotate(360deg);
|
||||
transform: rotate(360deg); } }
|
||||
|
||||
@keyframes sk-chasingDotsRotate {
|
||||
100% {
|
||||
-webkit-transform: rotate(360deg);
|
||||
transform: rotate(360deg); } }
|
||||
|
||||
@-webkit-keyframes sk-chasingDotsBounce {
|
||||
0%, 100% {
|
||||
-webkit-transform: scale(0);
|
||||
transform: scale(0); }
|
||||
50% {
|
||||
-webkit-transform: scale(1);
|
||||
transform: scale(1); } }
|
||||
|
||||
@keyframes sk-chasingDotsBounce {
|
||||
0%, 100% {
|
||||
-webkit-transform: scale(0);
|
||||
transform: scale(0); }
|
||||
50% {
|
||||
-webkit-transform: scale(1);
|
||||
transform: scale(1); } }
|
||||
|
||||
/*
|
||||
* Usage:
|
||||
*
|
||||
<div class="sk-three-bounce">
|
||||
<div class="sk-child sk-bounce1"></div>
|
||||
<div class="sk-child sk-bounce2"></div>
|
||||
<div class="sk-child sk-bounce3"></div>
|
||||
</div>
|
||||
*
|
||||
*/
|
||||
.sk-three-bounce {
|
||||
margin: 40px auto;
|
||||
width: 80px;
|
||||
text-align: center; }
|
||||
.sk-three-bounce .sk-child {
|
||||
width: 20px;
|
||||
height: 20px;
|
||||
background-color: #333;
|
||||
border-radius: 100%;
|
||||
display: inline-block;
|
||||
-webkit-animation: sk-three-bounce 1.4s ease-in-out 0s infinite both;
|
||||
animation: sk-three-bounce 1.4s ease-in-out 0s infinite both; }
|
||||
.sk-three-bounce .sk-bounce1 {
|
||||
-webkit-animation-delay: -0.32s;
|
||||
animation-delay: -0.32s; }
|
||||
.sk-three-bounce .sk-bounce2 {
|
||||
-webkit-animation-delay: -0.16s;
|
||||
animation-delay: -0.16s; }
|
||||
|
||||
@-webkit-keyframes sk-three-bounce {
|
||||
0%, 80%, 100% {
|
||||
-webkit-transform: scale(0);
|
||||
transform: scale(0); }
|
||||
40% {
|
||||
-webkit-transform: scale(1);
|
||||
transform: scale(1); } }
|
||||
|
||||
@keyframes sk-three-bounce {
|
||||
0%, 80%, 100% {
|
||||
-webkit-transform: scale(0);
|
||||
transform: scale(0); }
|
||||
40% {
|
||||
-webkit-transform: scale(1);
|
||||
transform: scale(1); } }
|
||||
|
||||
/*
|
||||
* Usage:
|
||||
*
|
||||
<div class="sk-circle">
|
||||
<div class="sk-circle1 sk-child"></div>
|
||||
<div class="sk-circle2 sk-child"></div>
|
||||
<div class="sk-circle3 sk-child"></div>
|
||||
<div class="sk-circle4 sk-child"></div>
|
||||
<div class="sk-circle5 sk-child"></div>
|
||||
<div class="sk-circle6 sk-child"></div>
|
||||
<div class="sk-circle7 sk-child"></div>
|
||||
<div class="sk-circle8 sk-child"></div>
|
||||
<div class="sk-circle9 sk-child"></div>
|
||||
<div class="sk-circle10 sk-child"></div>
|
||||
<div class="sk-circle11 sk-child"></div>
|
||||
<div class="sk-circle12 sk-child"></div>
|
||||
</div>
|
||||
*
|
||||
*/
|
||||
.sk-circle {
|
||||
margin: 40px auto;
|
||||
width: 40px;
|
||||
height: 40px;
|
||||
position: relative; }
|
||||
.sk-circle .sk-child {
|
||||
width: 100%;
|
||||
height: 100%;
|
||||
position: absolute;
|
||||
left: 0;
|
||||
top: 0; }
|
||||
.sk-circle .sk-child:before {
|
||||
content: '';
|
||||
display: block;
|
||||
margin: 0 auto;
|
||||
width: 15%;
|
||||
height: 15%;
|
||||
background-color: #333;
|
||||
border-radius: 100%;
|
||||
-webkit-animation: sk-circleBounceDelay 1.2s infinite ease-in-out both;
|
||||
animation: sk-circleBounceDelay 1.2s infinite ease-in-out both; }
|
||||
.sk-circle .sk-circle2 {
|
||||
-webkit-transform: rotate(30deg);
|
||||
-ms-transform: rotate(30deg);
|
||||
transform: rotate(30deg); }
|
||||
.sk-circle .sk-circle3 {
|
||||
-webkit-transform: rotate(60deg);
|
||||
-ms-transform: rotate(60deg);
|
||||
transform: rotate(60deg); }
|
||||
.sk-circle .sk-circle4 {
|
||||
-webkit-transform: rotate(90deg);
|
||||
-ms-transform: rotate(90deg);
|
||||
transform: rotate(90deg); }
|
||||
.sk-circle .sk-circle5 {
|
||||
-webkit-transform: rotate(120deg);
|
||||
-ms-transform: rotate(120deg);
|
||||
transform: rotate(120deg); }
|
||||
.sk-circle .sk-circle6 {
|
||||
-webkit-transform: rotate(150deg);
|
||||
-ms-transform: rotate(150deg);
|
||||
transform: rotate(150deg); }
|
||||
.sk-circle .sk-circle7 {
|
||||
-webkit-transform: rotate(180deg);
|
||||
-ms-transform: rotate(180deg);
|
||||
transform: rotate(180deg); }
|
||||
.sk-circle .sk-circle8 {
|
||||
-webkit-transform: rotate(210deg);
|
||||
-ms-transform: rotate(210deg);
|
||||
transform: rotate(210deg); }
|
||||
.sk-circle .sk-circle9 {
|
||||
-webkit-transform: rotate(240deg);
|
||||
-ms-transform: rotate(240deg);
|
||||
transform: rotate(240deg); }
|
||||
.sk-circle .sk-circle10 {
|
||||
-webkit-transform: rotate(270deg);
|
||||
-ms-transform: rotate(270deg);
|
||||
transform: rotate(270deg); }
|
||||
.sk-circle .sk-circle11 {
|
||||
-webkit-transform: rotate(300deg);
|
||||
-ms-transform: rotate(300deg);
|
||||
transform: rotate(300deg); }
|
||||
.sk-circle .sk-circle12 {
|
||||
-webkit-transform: rotate(330deg);
|
||||
-ms-transform: rotate(330deg);
|
||||
transform: rotate(330deg); }
|
||||
.sk-circle .sk-circle2:before {
|
||||
-webkit-animation-delay: -1.1s;
|
||||
animation-delay: -1.1s; }
|
||||
.sk-circle .sk-circle3:before {
|
||||
-webkit-animation-delay: -1s;
|
||||
animation-delay: -1s; }
|
||||
.sk-circle .sk-circle4:before {
|
||||
-webkit-animation-delay: -0.9s;
|
||||
animation-delay: -0.9s; }
|
||||
.sk-circle .sk-circle5:before {
|
||||
-webkit-animation-delay: -0.8s;
|
||||
animation-delay: -0.8s; }
|
||||
.sk-circle .sk-circle6:before {
|
||||
-webkit-animation-delay: -0.7s;
|
||||
animation-delay: -0.7s; }
|
||||
.sk-circle .sk-circle7:before {
|
||||
-webkit-animation-delay: -0.6s;
|
||||
animation-delay: -0.6s; }
|
||||
.sk-circle .sk-circle8:before {
|
||||
-webkit-animation-delay: -0.5s;
|
||||
animation-delay: -0.5s; }
|
||||
.sk-circle .sk-circle9:before {
|
||||
-webkit-animation-delay: -0.4s;
|
||||
animation-delay: -0.4s; }
|
||||
.sk-circle .sk-circle10:before {
|
||||
-webkit-animation-delay: -0.3s;
|
||||
animation-delay: -0.3s; }
|
||||
.sk-circle .sk-circle11:before {
|
||||
-webkit-animation-delay: -0.2s;
|
||||
animation-delay: -0.2s; }
|
||||
.sk-circle .sk-circle12:before {
|
||||
-webkit-animation-delay: -0.1s;
|
||||
animation-delay: -0.1s; }
|
||||
|
||||
@-webkit-keyframes sk-circleBounceDelay {
|
||||
0%, 80%, 100% {
|
||||
-webkit-transform: scale(0);
|
||||
transform: scale(0); }
|
||||
40% {
|
||||
-webkit-transform: scale(1);
|
||||
transform: scale(1); } }
|
||||
|
||||
@keyframes sk-circleBounceDelay {
|
||||
0%, 80%, 100% {
|
||||
-webkit-transform: scale(0);
|
||||
transform: scale(0); }
|
||||
40% {
|
||||
-webkit-transform: scale(1);
|
||||
transform: scale(1); } }
|
||||
|
||||
/*
|
||||
* Usage:
|
||||
*
|
||||
<div class="sk-cube-grid">
|
||||
<div class="sk-cube sk-cube1"></div>
|
||||
<div class="sk-cube sk-cube2"></div>
|
||||
<div class="sk-cube sk-cube3"></div>
|
||||
<div class="sk-cube sk-cube4"></div>
|
||||
<div class="sk-cube sk-cube5"></div>
|
||||
<div class="sk-cube sk-cube6"></div>
|
||||
<div class="sk-cube sk-cube7"></div>
|
||||
<div class="sk-cube sk-cube8"></div>
|
||||
<div class="sk-cube sk-cube9"></div>
|
||||
</div>
|
||||
*
|
||||
*/
|
||||
.sk-cube-grid {
|
||||
width: 40px;
|
||||
height: 40px;
|
||||
margin: 40px auto;
|
||||
/*
|
||||
* Spinner positions
|
||||
* 1 2 3
|
||||
* 4 5 6
|
||||
* 7 8 9
|
||||
*/ }
|
||||
.sk-cube-grid .sk-cube {
|
||||
width: 33.33%;
|
||||
height: 33.33%;
|
||||
background-color: #333;
|
||||
float: left;
|
||||
-webkit-animation: sk-cubeGridScaleDelay 1.3s infinite ease-in-out;
|
||||
animation: sk-cubeGridScaleDelay 1.3s infinite ease-in-out; }
|
||||
.sk-cube-grid .sk-cube1 {
|
||||
-webkit-animation-delay: 0.2s;
|
||||
animation-delay: 0.2s; }
|
||||
.sk-cube-grid .sk-cube2 {
|
||||
-webkit-animation-delay: 0.3s;
|
||||
animation-delay: 0.3s; }
|
||||
.sk-cube-grid .sk-cube3 {
|
||||
-webkit-animation-delay: 0.4s;
|
||||
animation-delay: 0.4s; }
|
||||
.sk-cube-grid .sk-cube4 {
|
||||
-webkit-animation-delay: 0.1s;
|
||||
animation-delay: 0.1s; }
|
||||
.sk-cube-grid .sk-cube5 {
|
||||
-webkit-animation-delay: 0.2s;
|
||||
animation-delay: 0.2s; }
|
||||
.sk-cube-grid .sk-cube6 {
|
||||
-webkit-animation-delay: 0.3s;
|
||||
animation-delay: 0.3s; }
|
||||
.sk-cube-grid .sk-cube7 {
|
||||
-webkit-animation-delay: 0.0s;
|
||||
animation-delay: 0.0s; }
|
||||
.sk-cube-grid .sk-cube8 {
|
||||
-webkit-animation-delay: 0.1s;
|
||||
animation-delay: 0.1s; }
|
||||
.sk-cube-grid .sk-cube9 {
|
||||
-webkit-animation-delay: 0.2s;
|
||||
animation-delay: 0.2s; }
|
||||
|
||||
@-webkit-keyframes sk-cubeGridScaleDelay {
|
||||
0%, 70%, 100% {
|
||||
-webkit-transform: scale3D(1, 1, 1);
|
||||
transform: scale3D(1, 1, 1); }
|
||||
35% {
|
||||
-webkit-transform: scale3D(0, 0, 1);
|
||||
transform: scale3D(0, 0, 1); } }
|
||||
|
||||
@keyframes sk-cubeGridScaleDelay {
|
||||
0%, 70%, 100% {
|
||||
-webkit-transform: scale3D(1, 1, 1);
|
||||
transform: scale3D(1, 1, 1); }
|
||||
35% {
|
||||
-webkit-transform: scale3D(0, 0, 1);
|
||||
transform: scale3D(0, 0, 1); } }
|
||||
|
||||
/*
|
||||
* Usage:
|
||||
*
|
||||
<div class="sk-fading-circle">
|
||||
<div class="sk-circle1 sk-circle"></div>
|
||||
<div class="sk-circle2 sk-circle"></div>
|
||||
<div class="sk-circle3 sk-circle"></div>
|
||||
<div class="sk-circle4 sk-circle"></div>
|
||||
<div class="sk-circle5 sk-circle"></div>
|
||||
<div class="sk-circle6 sk-circle"></div>
|
||||
<div class="sk-circle7 sk-circle"></div>
|
||||
<div class="sk-circle8 sk-circle"></div>
|
||||
<div class="sk-circle9 sk-circle"></div>
|
||||
<div class="sk-circle10 sk-circle"></div>
|
||||
<div class="sk-circle11 sk-circle"></div>
|
||||
<div class="sk-circle12 sk-circle"></div>
|
||||
</div>
|
||||
*
|
||||
*/
|
||||
.sk-fading-circle {
|
||||
margin: 40px auto;
|
||||
width: 40px;
|
||||
height: 40px;
|
||||
position: relative; }
|
||||
.sk-fading-circle .sk-circle {
|
||||
width: 100%;
|
||||
height: 100%;
|
||||
position: absolute;
|
||||
left: 0;
|
||||
top: 0; }
|
||||
.sk-fading-circle .sk-circle:before {
|
||||
content: '';
|
||||
display: block;
|
||||
margin: 0 auto;
|
||||
width: 15%;
|
||||
height: 15%;
|
||||
background-color: #333;
|
||||
border-radius: 100%;
|
||||
-webkit-animation: sk-circleFadeDelay 1.2s infinite ease-in-out both;
|
||||
animation: sk-circleFadeDelay 1.2s infinite ease-in-out both; }
|
||||
.sk-fading-circle .sk-circle2 {
|
||||
-webkit-transform: rotate(30deg);
|
||||
-ms-transform: rotate(30deg);
|
||||
transform: rotate(30deg); }
|
||||
.sk-fading-circle .sk-circle3 {
|
||||
-webkit-transform: rotate(60deg);
|
||||
-ms-transform: rotate(60deg);
|
||||
transform: rotate(60deg); }
|
||||
.sk-fading-circle .sk-circle4 {
|
||||
-webkit-transform: rotate(90deg);
|
||||
-ms-transform: rotate(90deg);
|
||||
transform: rotate(90deg); }
|
||||
.sk-fading-circle .sk-circle5 {
|
||||
-webkit-transform: rotate(120deg);
|
||||
-ms-transform: rotate(120deg);
|
||||
transform: rotate(120deg); }
|
||||
.sk-fading-circle .sk-circle6 {
|
||||
-webkit-transform: rotate(150deg);
|
||||
-ms-transform: rotate(150deg);
|
||||
transform: rotate(150deg); }
|
||||
.sk-fading-circle .sk-circle7 {
|
||||
-webkit-transform: rotate(180deg);
|
||||
-ms-transform: rotate(180deg);
|
||||
transform: rotate(180deg); }
|
||||
.sk-fading-circle .sk-circle8 {
|
||||
-webkit-transform: rotate(210deg);
|
||||
-ms-transform: rotate(210deg);
|
||||
transform: rotate(210deg); }
|
||||
.sk-fading-circle .sk-circle9 {
|
||||
-webkit-transform: rotate(240deg);
|
||||
-ms-transform: rotate(240deg);
|
||||
transform: rotate(240deg); }
|
||||
.sk-fading-circle .sk-circle10 {
|
||||
-webkit-transform: rotate(270deg);
|
||||
-ms-transform: rotate(270deg);
|
||||
transform: rotate(270deg); }
|
||||
.sk-fading-circle .sk-circle11 {
|
||||
-webkit-transform: rotate(300deg);
|
||||
-ms-transform: rotate(300deg);
|
||||
transform: rotate(300deg); }
|
||||
.sk-fading-circle .sk-circle12 {
|
||||
-webkit-transform: rotate(330deg);
|
||||
-ms-transform: rotate(330deg);
|
||||
transform: rotate(330deg); }
|
||||
.sk-fading-circle .sk-circle2:before {
|
||||
-webkit-animation-delay: -1.1s;
|
||||
animation-delay: -1.1s; }
|
||||
.sk-fading-circle .sk-circle3:before {
|
||||
-webkit-animation-delay: -1s;
|
||||
animation-delay: -1s; }
|
||||
.sk-fading-circle .sk-circle4:before {
|
||||
-webkit-animation-delay: -0.9s;
|
||||
animation-delay: -0.9s; }
|
||||
.sk-fading-circle .sk-circle5:before {
|
||||
-webkit-animation-delay: -0.8s;
|
||||
animation-delay: -0.8s; }
|
||||
.sk-fading-circle .sk-circle6:before {
|
||||
-webkit-animation-delay: -0.7s;
|
||||
animation-delay: -0.7s; }
|
||||
.sk-fading-circle .sk-circle7:before {
|
||||
-webkit-animation-delay: -0.6s;
|
||||
animation-delay: -0.6s; }
|
||||
.sk-fading-circle .sk-circle8:before {
|
||||
-webkit-animation-delay: -0.5s;
|
||||
animation-delay: -0.5s; }
|
||||
.sk-fading-circle .sk-circle9:before {
|
||||
-webkit-animation-delay: -0.4s;
|
||||
animation-delay: -0.4s; }
|
||||
.sk-fading-circle .sk-circle10:before {
|
||||
-webkit-animation-delay: -0.3s;
|
||||
animation-delay: -0.3s; }
|
||||
.sk-fading-circle .sk-circle11:before {
|
||||
-webkit-animation-delay: -0.2s;
|
||||
animation-delay: -0.2s; }
|
||||
.sk-fading-circle .sk-circle12:before {
|
||||
-webkit-animation-delay: -0.1s;
|
||||
animation-delay: -0.1s; }
|
||||
|
||||
@-webkit-keyframes sk-circleFadeDelay {
|
||||
0%, 39%, 100% {
|
||||
opacity: 0; }
|
||||
40% {
|
||||
opacity: 1; } }
|
||||
|
||||
@keyframes sk-circleFadeDelay {
|
||||
0%, 39%, 100% {
|
||||
opacity: 0; }
|
||||
40% {
|
||||
opacity: 1; } }
|
||||
|
||||
/*
|
||||
* Usage:
|
||||
*
|
||||
<div class="sk-folding-cube">
|
||||
<div class="sk-cube1 sk-cube"></div>
|
||||
<div class="sk-cube2 sk-cube"></div>
|
||||
<div class="sk-cube4 sk-cube"></div>
|
||||
<div class="sk-cube3 sk-cube"></div>
|
||||
</div>
|
||||
*
|
||||
*/
|
||||
.sk-folding-cube {
|
||||
margin: 40px auto;
|
||||
width: 40px;
|
||||
height: 40px;
|
||||
position: relative;
|
||||
-webkit-transform: rotateZ(45deg);
|
||||
transform: rotateZ(45deg); }
|
||||
.sk-folding-cube .sk-cube {
|
||||
float: left;
|
||||
width: 50%;
|
||||
height: 50%;
|
||||
position: relative;
|
||||
-webkit-transform: scale(1.1);
|
||||
-ms-transform: scale(1.1);
|
||||
transform: scale(1.1); }
|
||||
.sk-folding-cube .sk-cube:before {
|
||||
content: '';
|
||||
position: absolute;
|
||||
top: 0;
|
||||
left: 0;
|
||||
width: 100%;
|
||||
height: 100%;
|
||||
background-color: #333;
|
||||
-webkit-animation: sk-foldCubeAngle 2.4s infinite linear both;
|
||||
animation: sk-foldCubeAngle 2.4s infinite linear both;
|
||||
-webkit-transform-origin: 100% 100%;
|
||||
-ms-transform-origin: 100% 100%;
|
||||
transform-origin: 100% 100%; }
|
||||
.sk-folding-cube .sk-cube2 {
|
||||
-webkit-transform: scale(1.1) rotateZ(90deg);
|
||||
transform: scale(1.1) rotateZ(90deg); }
|
||||
.sk-folding-cube .sk-cube3 {
|
||||
-webkit-transform: scale(1.1) rotateZ(180deg);
|
||||
transform: scale(1.1) rotateZ(180deg); }
|
||||
.sk-folding-cube .sk-cube4 {
|
||||
-webkit-transform: scale(1.1) rotateZ(270deg);
|
||||
transform: scale(1.1) rotateZ(270deg); }
|
||||
.sk-folding-cube .sk-cube2:before {
|
||||
-webkit-animation-delay: 0.3s;
|
||||
animation-delay: 0.3s; }
|
||||
.sk-folding-cube .sk-cube3:before {
|
||||
-webkit-animation-delay: 0.6s;
|
||||
animation-delay: 0.6s; }
|
||||
.sk-folding-cube .sk-cube4:before {
|
||||
-webkit-animation-delay: 0.9s;
|
||||
animation-delay: 0.9s; }
|
||||
|
||||
@-webkit-keyframes sk-foldCubeAngle {
|
||||
0%, 10% {
|
||||
-webkit-transform: perspective(140px) rotateX(-180deg);
|
||||
transform: perspective(140px) rotateX(-180deg);
|
||||
opacity: 0; }
|
||||
25%, 75% {
|
||||
-webkit-transform: perspective(140px) rotateX(0deg);
|
||||
transform: perspective(140px) rotateX(0deg);
|
||||
opacity: 1; }
|
||||
90%, 100% {
|
||||
-webkit-transform: perspective(140px) rotateY(180deg);
|
||||
transform: perspective(140px) rotateY(180deg);
|
||||
opacity: 0; } }
|
||||
|
||||
@keyframes sk-foldCubeAngle {
|
||||
0%, 10% {
|
||||
-webkit-transform: perspective(140px) rotateX(-180deg);
|
||||
transform: perspective(140px) rotateX(-180deg);
|
||||
opacity: 0; }
|
||||
25%, 75% {
|
||||
-webkit-transform: perspective(140px) rotateX(0deg);
|
||||
transform: perspective(140px) rotateX(0deg);
|
||||
opacity: 1; }
|
||||
90%, 100% {
|
||||
-webkit-transform: perspective(140px) rotateY(180deg);
|
||||
transform: perspective(140px) rotateY(180deg);
|
||||
opacity: 0; } }
|
Loading…
Reference in new issue