<!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%; font-family: Arial, Helvetica, "Helvetica Neue", sans-serif; } body { background: #fff; color: #333; font-size: 12px; font-weight: normal; height: 100%; margin: 0; overflow-y: hidden; padding: 0; text-decoration: none; } .form { height: 100%; display: flex; align-items: center; justify-content: center; } .content { display: flex; flex-direction: column; align-items: center; justify-content: flex-end; } .title { font-style: normal; font-weight: 400; font-size: 18px; line-height: 160%; display: flex; align-items: center; text-align: center; color: #333333; } .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(""); } #error .icon { margin-bottom: 107px; } .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); } } .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; text-align: center; text-transform: uppercase; } 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; } .button.orange:disabled, .button.orange[disabled]{ background: #EDC2B3; border: 1px solid #EDC2B3; cursor: default; } </style> </head> <body> <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> </div> </div> </div> <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) { document.getElementById('progress').style.display = 'none'; document.getElementById('success').style.display = 'block'; document.getElementById('btn_end').onclick = function() { redirect(url); }; } function error() { document.getElementById('progress').style.display = 'none'; document.getElementById('error').style.display = 'block'; } 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>