2022-09-07 10:58:16 +00:00
|
|
|
<!DOCTYPE html>
|
|
|
|
<html>
|
|
|
|
<head runat="server">
|
|
|
|
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
|
|
|
|
<meta http-equiv="X-UA-Compatible" content="IE=edge" />
|
|
|
|
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, minimum-scale=1, user-scalable=no" />
|
|
|
|
<meta name="apple-mobile-web-app-capable" content="yes" />
|
|
|
|
<meta name="mobile-web-app-capable" content="yes" />
|
|
|
|
<!--
|
|
|
|
*
|
|
|
|
* (c) Copyright Ascensio System SIA 2021
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*
|
|
|
|
-->
|
|
|
|
<title>ONLYOFFICE</title>
|
|
|
|
<style type="text/css">
|
|
|
|
html {
|
|
|
|
height: 100%;
|
|
|
|
width: 100%;
|
2022-12-06 19:11:07 +00:00
|
|
|
font-family: Arial, Helvetica, "Helvetica Neue", sans-serif;
|
2022-09-07 10:58:16 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
body {
|
|
|
|
background: #fff;
|
|
|
|
color: #333;
|
|
|
|
font-size: 12px;
|
|
|
|
font-weight: normal;
|
|
|
|
height: 100%;
|
|
|
|
margin: 0;
|
|
|
|
overflow-y: hidden;
|
|
|
|
padding: 0;
|
|
|
|
text-decoration: none;
|
|
|
|
}
|
|
|
|
|
|
|
|
.form {
|
2022-12-06 19:11:07 +00:00
|
|
|
height: 60%;
|
|
|
|
display: flex;
|
|
|
|
align-items: flex-end;
|
|
|
|
justify-content: center;
|
2022-09-07 10:58:16 +00:00
|
|
|
}
|
|
|
|
|
2022-12-06 19:11:07 +00:00
|
|
|
.content {
|
|
|
|
display: flex;
|
|
|
|
flex-direction: column;
|
|
|
|
align-items: center;
|
|
|
|
justify-content: flex-end;
|
2022-09-07 10:58:16 +00:00
|
|
|
}
|
|
|
|
|
2022-12-06 19:11:07 +00:00
|
|
|
.title {
|
|
|
|
font-style: normal;
|
|
|
|
font-weight: 400;
|
|
|
|
font-size: 18px;
|
|
|
|
line-height: 160%;
|
|
|
|
display: flex;
|
|
|
|
align-items: center;
|
|
|
|
text-align: center;
|
|
|
|
|
|
|
|
color: #333333;
|
2022-09-07 10:58:16 +00:00
|
|
|
}
|
|
|
|
|
2022-12-06 19:11:07 +00:00
|
|
|
.description {
|
|
|
|
font-style: normal;
|
|
|
|
font-weight: 400;
|
|
|
|
font-size: 14px;
|
|
|
|
line-height: 160%;
|
|
|
|
|
|
|
|
display: flex;
|
|
|
|
align-items: center;
|
|
|
|
text-align: center;
|
|
|
|
|
|
|
|
margin-top: 8px;
|
|
|
|
|
|
|
|
color: #333333;
|
|
|
|
}
|
|
|
|
|
|
|
|
.icon {
|
|
|
|
margin-top: 49px;
|
|
|
|
width: 34px;
|
|
|
|
height: 48px;
|
|
|
|
}
|
|
|
|
|
|
|
|
.icon-succes {
|
|
|
|
background-image: url("");
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
.icon-error {
|
|
|
|
background-image: url("");
|
|
|
|
}
|
|
|
|
|
|
|
|
.spiner-image {
|
|
|
|
background-image: url("");
|
|
|
|
margin-top: 49px;
|
|
|
|
width: 48px;
|
|
|
|
height: 48px;
|
|
|
|
}
|
|
|
|
|
|
|
|
#spiner {
|
|
|
|
animation-duration: .8s;
|
|
|
|
animation-name: rotation;
|
|
|
|
animation-iteration-count: infinite;
|
|
|
|
animation-timing-function: linear;
|
|
|
|
}
|
|
|
|
|
|
|
|
@keyframes rotation {
|
|
|
|
from {
|
|
|
|
transform: rotate(0);
|
|
|
|
}
|
|
|
|
|
|
|
|
to {
|
|
|
|
transform: rotate(360deg);
|
|
|
|
}
|
2022-09-07 10:58:16 +00:00
|
|
|
}
|
|
|
|
|
2022-12-06 19:11:07 +00:00
|
|
|
.button {
|
|
|
|
margin-top: 50px;
|
|
|
|
cursor: pointer;
|
|
|
|
display: inline-block;
|
|
|
|
border-width: 0px;
|
|
|
|
border-radius: 3px;
|
|
|
|
font-weight: 600;
|
|
|
|
line-height: 133%;
|
|
|
|
letter-spacing: 0.04em;
|
|
|
|
padding: 19px 24px;
|
2022-09-07 10:58:16 +00:00
|
|
|
text-align: center;
|
2022-12-06 19:11:07 +00:00
|
|
|
text-transform: uppercase;
|
2022-09-07 10:58:16 +00:00
|
|
|
}
|
|
|
|
|
2022-12-06 19:11:07 +00:00
|
|
|
button:disabled, button[disabled]{
|
|
|
|
cursor: default;
|
|
|
|
}
|
|
|
|
|
|
|
|
.button.gray {
|
|
|
|
color: #AAAAAA;
|
|
|
|
background: #444444;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.button.orange {
|
|
|
|
color: #FFFFFF;
|
|
|
|
border: 1px solid #FF6F3D;
|
|
|
|
background: #FF6F3D;
|
|
|
|
}
|
|
|
|
|
|
|
|
.button.orange:not(:disabled):hover {
|
|
|
|
background: #ff7a4b;
|
2022-09-07 10:58:16 +00:00
|
|
|
}
|
|
|
|
|
2022-12-06 19:11:07 +00:00
|
|
|
.button.orange:disabled, .button.orange[disabled]{
|
|
|
|
background: #EDC2B3;
|
|
|
|
border: 1px solid #EDC2B3;
|
|
|
|
cursor: default;
|
2022-09-07 10:58:16 +00:00
|
|
|
}
|
|
|
|
|
2022-12-06 19:11:07 +00:00
|
|
|
|
|
|
|
|
2022-09-07 10:58:16 +00:00
|
|
|
</style>
|
|
|
|
</head>
|
|
|
|
<body>
|
2022-12-06 19:11:07 +00:00
|
|
|
<div class="form">
|
|
|
|
<div id="progress">
|
|
|
|
<div class="content">
|
|
|
|
<div class="title">Converting your file so you can edit it...</div>
|
|
|
|
<i id="spiner" class="spiner-image"></i>
|
|
|
|
<button class="button orange" disabled>Open converted file</button>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div id="success" style="display: none;">
|
|
|
|
<div class="content">
|
|
|
|
<div class="title">Converting your file so you can edit it...</div>
|
|
|
|
<i class="icon icon-succes"></i>
|
|
|
|
<button class="button orange" id="btn_end">Open converted file</button>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div id="error" style="display: none;">
|
|
|
|
<div class="content">
|
|
|
|
<div class="title">Conversion failed</div>
|
|
|
|
<div class="description">Sorry, we weren't able to convert the file for editing.</div>
|
|
|
|
<i class="icon icon-error"></i>
|
|
|
|
<button class="button gray" id="btn_back">Try again</button>
|
|
|
|
</div>
|
|
|
|
</div>
|
2022-09-07 10:58:16 +00:00
|
|
|
</div>
|
2022-12-06 19:11:07 +00:00
|
|
|
|
2022-09-07 10:58:16 +00:00
|
|
|
<script type="text/javascript" language="javascript">
|
|
|
|
|
|
|
|
function redirect(url) {
|
|
|
|
try {
|
|
|
|
window.top.location.replace(url);
|
|
|
|
}
|
|
|
|
catch (err) {
|
|
|
|
console.err(err);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function makeXHRRequest(url, success, error) {
|
|
|
|
var xhr = new XMLHttpRequest;
|
|
|
|
xhr.onreadystatechange = function() {
|
|
|
|
if (xhr.readyState == 4)
|
|
|
|
if (xhr.status == 200) {
|
|
|
|
success(xhr.responseText)
|
|
|
|
} else {
|
|
|
|
error()
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
;
|
|
|
|
xhr.open("GET", url, !0);
|
|
|
|
xhr.send();
|
|
|
|
}
|
|
|
|
|
|
|
|
function checkStatus(url, success, error) {
|
|
|
|
makeXHRRequest(url, function(responseText) {
|
|
|
|
let data = JSON.parse(responseText);
|
|
|
|
if(undefined !== data.error) {
|
|
|
|
error();
|
|
|
|
} else if(data.endConvert) {
|
|
|
|
success(data.fileUrl);
|
|
|
|
} else {
|
|
|
|
setTimeout(function(){
|
|
|
|
checkStatus(url, success, error);
|
|
|
|
}, 1000);
|
|
|
|
}
|
|
|
|
}, error);
|
|
|
|
}
|
|
|
|
|
|
|
|
function success(url) {
|
2022-12-06 19:11:07 +00:00
|
|
|
document.getElementById('progress').style.display = 'none';
|
|
|
|
document.getElementById('success').style.display = 'block';
|
|
|
|
document.getElementById('btn_end').onclick = function() {
|
2022-09-07 10:58:16 +00:00
|
|
|
redirect(url);
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
function error() {
|
|
|
|
document.getElementById('progress').style.display = 'none';
|
|
|
|
document.getElementById('error').style.display = 'block';
|
2022-12-06 19:11:07 +00:00
|
|
|
document.getElementById('btn_back').onclick = function() {
|
|
|
|
window.location.reload();
|
|
|
|
};
|
2022-09-07 10:58:16 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
var convertFile = function () {
|
|
|
|
|
|
|
|
let statusHandler = <%- JSON.stringify(statusHandler) %>;
|
|
|
|
|
|
|
|
if(!statusHandler) {
|
|
|
|
error();
|
|
|
|
}
|
|
|
|
|
|
|
|
checkStatus(statusHandler, success, error);
|
|
|
|
};
|
|
|
|
|
|
|
|
if (window.addEventListener) {
|
|
|
|
window.addEventListener("load", convertFile);
|
|
|
|
} else if (window.attachEvent) {
|
|
|
|
window.attachEvent("onload", convertFile);
|
|
|
|
}
|
|
|
|
</script>
|
|
|
|
</body>
|
|
|
|
</html>
|