mirror of https://github.com/xwiki-labs/cryptpad
274 lines
5.9 KiB
JavaScript
274 lines
5.9 KiB
JavaScript
// dark #326599
|
|
// light #4591c4
|
|
define([], function () {
|
|
var loadingStyle = (function(){/*
|
|
#cp-loading {
|
|
visibility: visible;
|
|
position: fixed;
|
|
z-index: 10000000;
|
|
top: 0px;
|
|
bottom: 0px;
|
|
left: 0px;
|
|
right: 0px;
|
|
background: linear-gradient(to right, #326599 0%, #326599 50%, #4591c4 50%, #4591c4 100%);
|
|
color: #fafafa;
|
|
font-size: 1.3em;
|
|
line-height: 120%;
|
|
opacity: 1;
|
|
display: flex;
|
|
flex-flow: column;
|
|
justify-content: center;
|
|
align-items: center;
|
|
}
|
|
#cp-loading.cp-loading-hidden {
|
|
opacity: 0;
|
|
visibility: hidden;
|
|
transition: opacity 0.75s, visibility 0s 0.75s;
|
|
}
|
|
#cp-loading .cp-loading-logo {
|
|
height: 300px;
|
|
width: 300px;
|
|
margin-top: 50px;
|
|
flex: 0 1 auto;
|
|
min-height: 0;
|
|
text-align: center;
|
|
}
|
|
#cp-loading .cp-loading-logo img {
|
|
max-width: 100%;
|
|
max-height: 100%;
|
|
}
|
|
#cp-loading .cp-loading-container {
|
|
width: 700px;
|
|
max-width: 90vw;
|
|
height: 500px;
|
|
max-height: calc(100vh - 20px);
|
|
margin: 50px;
|
|
flex-shrink: 0;
|
|
display: flex;
|
|
flex-flow: column;
|
|
justify-content: space-around;
|
|
align-items: center;
|
|
}
|
|
@media screen and (max-height: 800px) {
|
|
#cp-loading .cp-loading-container {
|
|
height: auto;
|
|
}
|
|
}
|
|
@media screen and (max-width: 600px) {
|
|
#cp-loading .cp-loading-container {
|
|
height: auto;
|
|
}
|
|
}
|
|
#cp-loading .cp-loading-cryptofist {
|
|
margin-left: auto;
|
|
margin-right: auto;
|
|
//height: 300px;
|
|
max-width: 90vw;
|
|
max-height: 300px;
|
|
width: auto;
|
|
height: auto;
|
|
margin-bottom: 2em;
|
|
}
|
|
@media screen and (max-height: 500px) {
|
|
#cp-loading .cp-loading-logo {
|
|
display: none;
|
|
}
|
|
}
|
|
#cp-loading-message {
|
|
background: #FFF;
|
|
padding: 20px;
|
|
width: 100%;
|
|
color: #3F4141;
|
|
text-align: left;
|
|
display: none;
|
|
}
|
|
|
|
#cp-loading-password-prompt p.cp-password-error {
|
|
color: white;
|
|
background: #9e0000;
|
|
padding: 5px;
|
|
margin-bottom: 15px;
|
|
}
|
|
#cp-loading-password-prompt .cp-password-info {
|
|
text-align: left;
|
|
margin-bottom: 15px;
|
|
}
|
|
#cp-loading-burn-after-reading .cp-password-info {
|
|
margin-bottom: 15px;
|
|
}
|
|
|
|
p.cp-password-info{
|
|
text-align: left;
|
|
}
|
|
#cp-loading-password-prompt .cp-password-form {
|
|
display: flex;
|
|
flex-wrap: wrap;
|
|
}
|
|
#cp-loading-password-prompt .cp-password-form button{
|
|
background-color: #4591c4;
|
|
color: white;
|
|
border: 1px solid #4591c4;
|
|
}
|
|
|
|
.cp-password-input{
|
|
font-size:16px;
|
|
border: 1px solid #4591c4;
|
|
background-color: white;
|
|
border-radius 0;
|
|
}
|
|
|
|
.cp-password-form button{
|
|
padding: 8px 12px;
|
|
font-weight: bold;
|
|
text-transform: uppercase;
|
|
}
|
|
|
|
#cp-loading-password-prompt .cp-password-form{
|
|
width: 100%;
|
|
}
|
|
|
|
#cp-loading-password-prompt .cp-password-form .cp-password-container {
|
|
flex-shrink: 1;
|
|
min-width: 0;
|
|
}
|
|
|
|
#cp-loading-password-prompt .cp-password-form .cp-password-container .cp-password-reveal{
|
|
color: #4591c4;
|
|
padding: 0px 24px;
|
|
}
|
|
|
|
#cp-loading-password-prompt .cp-password-form input {
|
|
flex: 1;
|
|
padding: 12px;
|
|
min-width: 0;
|
|
text-overflow: ellipsis;
|
|
}
|
|
#cp-loading-password-prompt .cp-password-form button:hover {
|
|
background-color: #326599;
|
|
}
|
|
#cp-loading-password-prompt ::placeholder {
|
|
color: #999999;
|
|
opacity: 1;
|
|
}
|
|
#cp-loading-password-prompt :-ms-input-placeholder {
|
|
color: #d9d9d9;
|
|
}
|
|
#cp-loading-password-prompt ::-ms-input-placeholder {
|
|
color: #d9d9d9;
|
|
}
|
|
#cp-loading .cp-loading-spinner-container {
|
|
position: relative;
|
|
height: 100px;
|
|
}
|
|
#cp-loading .cp-loading-spinner-container > div {
|
|
height: 100px;
|
|
}
|
|
#cp-loading-tip {
|
|
position: fixed;
|
|
z-index: 10000000;
|
|
top: 80%;
|
|
left: 0;
|
|
right: 0;
|
|
text-align: center;
|
|
transition: opacity 750ms;
|
|
transition-delay: 3000ms;
|
|
}
|
|
@media screen and (max-height: 600px) {
|
|
#cp-loading-tip {
|
|
display: none;
|
|
}
|
|
}
|
|
#cp-loading-tip span {
|
|
background: #222;
|
|
color: #fafafa;
|
|
text-align: center;
|
|
font-size: 1.3em;
|
|
opacity: 0.7;
|
|
font-family: 'Open Sans', 'Helvetica Neue', sans-serif;
|
|
padding: 15px;
|
|
max-width: 60%;
|
|
display: inline-block;
|
|
}
|
|
.cp-loading-progress {
|
|
width: 100%;
|
|
margin: 20px;
|
|
}
|
|
.cp-loading-progress p {
|
|
margin: 5px;
|
|
overflow: hidden;
|
|
white-space: nowrap;
|
|
text-overflow: ellipsis;
|
|
}
|
|
.cp-loading-progress-bar {
|
|
height: 24px;
|
|
background: white;
|
|
}
|
|
.cp-loading-progress-bar-value {
|
|
height: 100%;
|
|
background: #5cb85c;
|
|
}
|
|
|
|
@keyframes spin {
|
|
from {
|
|
transform: rotate(0deg);
|
|
}
|
|
to {
|
|
transform: rotate(1800deg);
|
|
}
|
|
}
|
|
|
|
.cp-spinner {
|
|
display: inline-block;
|
|
box-sizing: border-box;
|
|
width: 80px;
|
|
height: 80px;
|
|
border: 11px solid white;
|
|
border-radius: 50%;
|
|
border-top-color: transparent;
|
|
animation: spin infinite 3s;
|
|
animation-timing-function: cubic-bezier(.6,0.15,0.4,0.85);
|
|
}
|
|
|
|
button.primary{
|
|
border: 1px solid #4591c4;
|
|
padding: 8px 12px;
|
|
text-transform: uppercase;
|
|
background-color: #4591c4;
|
|
color: white;
|
|
font-weight: bold;
|
|
}
|
|
|
|
button.primary:hover{
|
|
background-color: rgb(52, 118, 162);
|
|
}
|
|
|
|
*/}).toString().slice(14, -3);
|
|
var urlArgs = window.location.href.replace(/^.*\?([^\?]*)$/, function (all, x) { return x; });
|
|
var elem = document.createElement('div');
|
|
elem.setAttribute('id', 'cp-loading');
|
|
elem.innerHTML = [
|
|
'<style>',
|
|
loadingStyle,
|
|
'</style>',
|
|
'<div class="cp-loading-logo">',
|
|
'<img class="cp-loading-cryptofist" src="/customize/loading-logo.png?' + urlArgs + '">',
|
|
'</div>',
|
|
'<div class="cp-loading-container">',
|
|
'<div class="cp-loading-spinner-container">',
|
|
'<span class="cp-spinner"></span>',
|
|
'</div>',
|
|
'<p id="cp-loading-message"></p>',
|
|
'</div>'
|
|
].join('');
|
|
return function () {
|
|
var intr;
|
|
var append = function () {
|
|
if (!document.body) { return; }
|
|
clearInterval(intr);
|
|
document.body.appendChild(elem);
|
|
};
|
|
intr = setInterval(append, 100);
|
|
append();
|
|
};
|
|
});
|