mirror of
https://github.com/ONLYOFFICE/document-server-integration.git
synced 2026-04-07 14:06:11 +08:00
350 lines
24 KiB
HTML
Executable File
350 lines
24 KiB
HTML
Executable File
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
|
||
<html xmlns:th="http://www.thymeleaf.org">
|
||
<head>
|
||
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
|
||
<!--
|
||
*
|
||
* (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>
|
||
<link rel="icon" type="image/ico" href="/favicon.ico"/>
|
||
<link rel="stylesheet" type="text/css" href="https://fonts.googleapis.com/css?family=Open+Sans:900,800,700,600,500,400,300&subset=latin,cyrillic-ext,cyrillic,latin-ext" />
|
||
<link rel="stylesheet" type="text/css" href="css/stylesheet.css" />
|
||
<link rel="stylesheet" type="text/css" href="css/jquery-ui.css" />
|
||
<link rel="stylesheet" type="text/css" href="css/media.css">
|
||
</head>
|
||
<body>
|
||
<header>
|
||
<div class="center">
|
||
<a href="">
|
||
<img src ="css/img/logo.svg" alt="ONLYOFFICE" />
|
||
</a>
|
||
</div>
|
||
</header>
|
||
|
||
<div class="center main">
|
||
<table class="table-main">
|
||
<tbody>
|
||
<tr>
|
||
<td class="left-panel section">
|
||
<div class="help-block">
|
||
<span>Create new</span>
|
||
<div class="clearFix">
|
||
<div class="create-panel clearFix">
|
||
<ul class="try-editor-list clearFix">
|
||
<li>
|
||
<a class="try-editor word" data-type="docx">Document</a>
|
||
</li>
|
||
<li>
|
||
<a class="try-editor cell" data-type="xlsx">Spreadsheet</a>
|
||
</li>
|
||
<li>
|
||
<a class="try-editor slide" data-type="pptx">Presentation</a>
|
||
</li>
|
||
<li>
|
||
<a class="try-editor form" data-type="docxf">Master form</a>
|
||
</li>
|
||
</ul>
|
||
<label class="create-sample">
|
||
<input id="createSample" class="checkbox" type="checkbox" />With sample content
|
||
</label>
|
||
</div>
|
||
|
||
<form method="POST" action="/upload" enctype="multipart/form-data" class="upload-panel clearFix">
|
||
<a class="file-upload">Upload file
|
||
<input type="file" id="fileupload" name="file" />
|
||
</a>
|
||
</form>
|
||
|
||
<table class="user-block-table" cellspacing="0" cellpadding="0">
|
||
<tbody>
|
||
<tr>
|
||
<td valign="middle">
|
||
<span class="select-user">Username</span>
|
||
<img class="info" src="css/img/info.svg"/>
|
||
<select class="select-user" id="user">
|
||
<option th:each="user : ${users}"
|
||
th:value="${user.id}"
|
||
th:text="${user.name}"/>
|
||
</select>
|
||
</td>
|
||
</tr>
|
||
<tr>
|
||
<td valign="middle">
|
||
<span class="select-user">Language editors interface</span>
|
||
<select class="select-user" id="language">
|
||
<option value="en" selected="selected">English</option>
|
||
<option value="be">Belarusian</option>
|
||
<option value="bg">Bulgarian</option>
|
||
<option value="ca">Catalan</option>
|
||
<option value="zh">Chinese</option>
|
||
<option value="cs">Czech</option>
|
||
<option value="da">Danish</option>
|
||
<option value="nl">Dutch</option>
|
||
<option value="fi">Finnish</option>
|
||
<option value="fr">French</option>
|
||
<option value="de">German</option>
|
||
<option value="el">Greek</option>
|
||
<option value="hu">Hungarian</option>
|
||
<option value="id">Indonesian</option>
|
||
<option value="it">Italian</option>
|
||
<option value="ja">Japanese</option>
|
||
<option value="ko">Korean</option>
|
||
<option value="lv">Latvian</option>
|
||
<option value="lo">Lao</option>
|
||
<option value="nb">Norwegian</option>
|
||
<option value="pl">Polish</option>
|
||
<option value="pt">Portuguese</option>
|
||
<option value="ro">Romanian</option>
|
||
<option value="ru">Russian</option>
|
||
<option value="sk">Slovak</option>
|
||
<option value="sl">Slovenian</option>
|
||
<option value="sv">Swedish</option>
|
||
<option value="es">Spanish</option>
|
||
<option value="tr">Turkish</option>
|
||
<option value="uk">Ukrainian</option>
|
||
<option value="vi">Vietnamese</option>
|
||
</select>
|
||
</td>
|
||
</tr>
|
||
</tbody>
|
||
</table>
|
||
</div>
|
||
</div>
|
||
</td>
|
||
<td class="section">
|
||
<div class="main-panel">
|
||
<div id="portal-info" th:attr="tooltip=${tooltip}" th:style="${not #lists.isEmpty(files)} ? 'display: none' : 'display: block' ">
|
||
<span class="portal-name">ONLYOFFICE Document Editors – Welcome!</span>
|
||
<span class="portal-descr">
|
||
Get started with a demo-sample of ONLYOFFICE Document Editors, the first html5-based editors.
|
||
<br /> You may upload your own documents for testing using the "<b>Upload file</b>" button and <b>selecting</b> the necessary files on your PC.
|
||
</span>
|
||
<span class="portal-descr">You can open the same document using different users in different Web browser sessions, so you can check out multi-user editing functions.</span>
|
||
</div>
|
||
<th:block th:if="${not #lists.isEmpty(files)}">
|
||
<div class="stored-list">
|
||
<span class="header-list">Your documents</span>
|
||
<table class="tableHeader" cellspacing="0" cellpadding="0" width="100%">
|
||
<thead>
|
||
<tr>
|
||
<td class="tableHeaderCell tableHeaderCellFileName">Filename</td>
|
||
<td class="tableHeaderCell tableHeaderCellEditors contentCells-shift">Editors</td>
|
||
<td class="tableHeaderCell tableHeaderCellViewers">Viewers</td>
|
||
<td class="tableHeaderCell tableHeaderCellDownload">Download</td>
|
||
<td class="tableHeaderCell tableHeaderCellRemove">Remove</td>
|
||
</tr>
|
||
</thead>
|
||
</table>
|
||
<div class="scroll-table-body">
|
||
<table cellspacing="0" cellpadding="0" width="100%">
|
||
<tbody>
|
||
<tr th:each="file,iState : ${files}" class="tableRow" th:title="${files[iState.index].getName() + versions[iState.index]}">
|
||
<td class="contentCells">
|
||
<a class="stored-edit" th:classappend="${docTypes[iState.index]}"
|
||
th:href="@{/editor(fileName=${files[iState.index].getName()})}" target="_blank">
|
||
<span th:text="${files[iState.index].getName()}"></span>
|
||
</a>
|
||
</td>
|
||
<th:block th:if="${filesEditable[iState.index]}">
|
||
<td class="contentCells contentCells-icon">
|
||
<a th:href="@{/editor(fileName=${files[iState.index].getName()},type='desktop',action='edit')}" target="_blank">
|
||
<img src="css/img/desktop.svg" alt="Open in editor for full size screens" title="Open in editor for full size screens"/>
|
||
</a>
|
||
</td>
|
||
<td class="contentCells contentCells-icon">
|
||
<a th:href="@{/editor(fileName=${files[iState.index].getName()},type='mobile',action='edit')}" target="_blank">
|
||
<img src="css/img/mobile.svg" alt="Open in editor for mobile devices" title="Open in editor for mobile devices"/>
|
||
</a>
|
||
</td>
|
||
<td class="contentCells contentCells-icon">
|
||
<a th:href="@{/editor(fileName=${files[iState.index].getName()},type='desktop',action='comment')}" target="_blank">
|
||
<img src="css/img/comment.svg" alt="Open in editor for comment" title="Open in editor for comment"/>
|
||
</a>
|
||
</td>
|
||
<div th:if="${docTypes[iState.index]} eq 'word'">
|
||
<td class="contentCells contentCells-icon">
|
||
<a th:href="@{/editor(fileName=${files[iState.index].getName()},type='desktop',action='review')}" target="_blank">
|
||
<img src="css/img/review.svg" alt="Open in editor for review" title="Open in editor for review"/>
|
||
</a>
|
||
</td>
|
||
</div>
|
||
<div th:if="${docTypes[iState.index]} eq 'cell'">
|
||
<td class="contentCells contentCells-icon">
|
||
<a th:href="@{/editor(fileName=${files[iState.index].getName()},type='desktop',action='filter')}" target="_blank">
|
||
<img src="css/img/filter.svg" alt="Open in editor without access to change the filter" title="Open in editor without access to change the filter" />
|
||
</a>
|
||
</td>
|
||
</div>
|
||
<div th:if="${docTypes[iState.index]} eq 'slide'">
|
||
<td class="contentCells contentCells-icon contentCellsEmpty"></td>
|
||
</div>
|
||
<div th:if="${docTypes[iState.index]} eq 'word'">
|
||
<td class="contentCells contentCells-icon">
|
||
<a th:href="@{/editor(fileName=${files[iState.index].getName()},type='desktop',action='blockcontent')}" target="_blank">
|
||
<img src="css/img/block-content.svg" alt="Open in editor without content control modification" title="Open in editor without content control modification"/>
|
||
</a>
|
||
</td>
|
||
</div>
|
||
<div th:if="not (${docTypes[iState.index]} eq 'word')">
|
||
<td class="contentCells contentCells-icon"></td>
|
||
</div>
|
||
<div th:if="${docTypes[iState.index]} eq 'slide'">
|
||
<td class="contentCells contentCells-icon "></td>
|
||
</div>
|
||
<div th:if="${isFillFormDoc[iState.index]}">
|
||
<td class="contentCells contentCells-shift contentCells-icon firstContentCellShift">
|
||
<a th:href="@{/editor(fileName=${files[iState.index].getName()},type='desktop',action='fillForms')}" target="_blank">
|
||
<img src="css/img/fill-forms.svg" alt="Open in editor for filling in forms" title="Open in editor for filling in forms"/>
|
||
</a>
|
||
</td>
|
||
</div>
|
||
<div th:if="${not isFillFormDoc[iState.index]}">
|
||
<td class="contentCells contentCells-shift contentCells-icon firstContentCellShift"></td>
|
||
</div>
|
||
</th:block>
|
||
<th:block th:if="${isFillFormDoc[iState.index] and not filesEditable[iState.index]}">
|
||
<td class="contentCells contentCells-icon "></td>
|
||
<td class="contentCells contentCells-icon">
|
||
<a th:href="@{/editor(fileName=${files[iState.index].getName()},type='mobile',action='fillForms')}" target="_blank">
|
||
<img src="css/img/mobile-fill-forms.svg" alt="Open in editor for filling in forms for mobile devices" title="Open in editor for filling in forms for mobile devices" />
|
||
</a>
|
||
</td>
|
||
<td class="contentCells contentCells-icon "></td>
|
||
<td class="contentCells contentCells-icon "></td>
|
||
<td class="contentCells contentCells-icon "></td>
|
||
<td class="contentCells contentCells-shift contentCells-icon firstContentCellShift">
|
||
<a th:href="@{/editor(fileName=${files[iState.index].getName()},type='desktop',action='fillForms')}" target="_blank">
|
||
<img src="css/img/fill-forms.svg" alt="Open in editor for filling in forms" title="Open in editor for filling in forms"/>
|
||
</a>
|
||
</td>
|
||
</th:block>
|
||
<th:block th:if="${not filesEditable[iState.index]}">
|
||
<td class="contentCells contentCells-shift contentCells-icon contentCellsEmpty" colspan="6"></td>
|
||
</th:block>
|
||
<td class="contentCells contentCells-icon firstContentCellViewers">
|
||
<a th:href="@{/editor(fileName=${files[iState.index].getName()},type='desktop',action='view')}" target="_blank">
|
||
<img src="css/img/desktop.svg" alt="Open in viewer for full size screens" title="Open in viewer for full size screens"/>
|
||
</a>
|
||
</td>
|
||
<td class="contentCells contentCells-icon">
|
||
<a th:href="@{/editor(fileName=${files[iState.index].getName()},type='mobile',action='view')}" target="_blank">
|
||
<img src="css/img/mobile.svg" alt="Open in viewer for mobile devices" title="Open in viewer for mobile devices"/>
|
||
</a>
|
||
</td>
|
||
<td class="contentCells contentCells-icon contentCells-shift">
|
||
<a th:href="@{/editor(fileName=${files[iState.index].getName()},type='embedded',action='embedded')}" target="_blank">
|
||
<img src="css/img/embeded.svg" alt="Open in embedded mode" title="Open in embedded mode"/>
|
||
</a>
|
||
</td>
|
||
<td class="contentCells contentCells-icon contentCells-shift downloadContentCellShift">
|
||
<a th:href="@{/download(fileName=${files[iState.index].getName()})}" target="_blank">
|
||
<img class="icon-download" src="css/img/download.svg" alt="Download" title="Download" />
|
||
</a>
|
||
</td>
|
||
<td class="contentCells contentCells-icon contentCells-shift">
|
||
<a class="delete-file" th:attr="data-filename=${files[iState.index].getName()}">
|
||
<img class="icon-delete" src="css/img/delete.svg" alt="Delete" title="Delete" />
|
||
</a>
|
||
</td>
|
||
</tr>
|
||
</tbody>
|
||
</table>
|
||
</div>
|
||
</div>
|
||
</th:block>
|
||
</div>
|
||
</td>
|
||
</tr>
|
||
</tbody>
|
||
</table>
|
||
</div>
|
||
|
||
<div id="mainProgress">
|
||
<div id="uploadSteps">
|
||
<span id="uploadFileName" class="uploadFileName"></span>
|
||
<div class="describeUpload">After these steps are completed, you can work with your document.</div>
|
||
<span id="step1" class="step">1. Loading the file.</span>
|
||
<span class="step-descr">The loading speed depends on file size and additional elements it contains.</span>
|
||
<br />
|
||
<span id="step2" class="step">2. Conversion.</span>
|
||
<span class="step-descr">The file is converted to OOXML so that you can edit it.</span>
|
||
<br />
|
||
<div id="blockPassword">
|
||
<span class="descrFilePass">The file is password protected.</span>
|
||
<br />
|
||
<div>
|
||
<input id="filePass" type="password"/>
|
||
<div id="enterPass" class="button orange">Enter</div>
|
||
<div id="skipPass" class="button gray">Skip</div>
|
||
</div>
|
||
<span class="errorPass"></span>
|
||
<br />
|
||
</div>
|
||
<span id="step3" class="step">3. Loading editor scripts.</span>
|
||
<span class="step-descr">They are loaded only once, they will be cached on your computer.</span>
|
||
<input type="hidden" name="hiddenFileName" id="hiddenFileName" />
|
||
<br />
|
||
<br />
|
||
<span class="progress-descr">Note the speed of all operations depends on your connection quality and server location.</span>
|
||
<br />
|
||
<br />
|
||
<div class="error-message">
|
||
<b>Upload error: </b><span></span>
|
||
<br />
|
||
Please select another file and try again.
|
||
</div>
|
||
</div>
|
||
<iframe id="embeddedView" src="" height="345px" width="432px" frameborder="0" scrolling="no" allowtransparency></iframe>
|
||
<br />
|
||
<div id="beginEdit" class="button orange disable">Edit</div>
|
||
<div id="beginView" class="button gray disable">View</div>
|
||
<div id="beginEmbedded" class="button gray disable">Embedded view</div>
|
||
<div id="cancelEdit" class="button gray">Cancel</div>
|
||
</div>
|
||
|
||
<span id="loadScripts" th:attr="data-docs=${datadocs}"></span>
|
||
|
||
<footer>
|
||
<div class="center">
|
||
<table>
|
||
<tbody>
|
||
<tr>
|
||
<td>
|
||
<a href="http://api.onlyoffice.com/editors/howitworks" target="_blank">API Documentation</a>
|
||
</td>
|
||
<td>
|
||
<a href="mailto:sales@onlyoffice.com">Submit your request</a>
|
||
</td>
|
||
<td class="copy">
|
||
© Ascensio Systems SIA 2020. All rights reserved.
|
||
</td>
|
||
</tr>
|
||
</tbody>
|
||
</table>
|
||
</div>
|
||
</footer>
|
||
|
||
<script type="text/javascript" src="scripts/jquery-1.8.2.js"></script>
|
||
<script type="text/javascript" src="scripts/jquery-ui.js"></script>
|
||
<script type="text/javascript" src="scripts/jquery.blockUI.js"></script>
|
||
<script type="text/javascript" src="scripts/jquery.iframe-transport.js"></script>
|
||
<script type="text/javascript" src="scripts/jquery.fileupload.js"></script>
|
||
<script type="text/javascript" src="scripts/jquery.dropdownToggle.js"></script>
|
||
<script type="text/javascript" src="scripts/jscript.js"></script>
|
||
<script type="text/javascript" src="scripts/converter.js"></script>
|
||
</body>
|
||
</html> |