<!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>