nopaque/app/templates/base.html.j2

206 lines
9.0 KiB
Plaintext
Raw Normal View History

2019-07-04 11:59:52 +02:00
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
{% if title %}
2019-12-02 11:34:28 +01:00
<title>nopaque {{ title }}</title>
2019-07-04 11:59:52 +02:00
{% else %}
2019-12-02 11:34:28 +01:00
<title>nopaque</title>
2019-07-04 11:59:52 +02:00
{% endif %}
<link href="{{ url_for('static', filename='images/favicon.png') }}" rel="icon" type="image/png">
<link type="text/css" rel="stylesheet" href="{{ url_for('static', filename='fonts/material-icons/material-icons.css') }}">
2019-07-04 14:59:23 +02:00
<link type="text/css" rel="stylesheet" href="{{ url_for('static', filename='css/materialize.min.css') }}" media="screen,projection"/>
2019-12-02 11:34:28 +01:00
<link type="text/css" rel="stylesheet" href="{{ url_for('static', filename='css/nopaque.css') }}" media="screen,projection"/>
2019-11-08 12:21:59 +01:00
<script src="{{ url_for('static', filename='js/add_job.js') }}"></script>
<script src="{{ url_for('static', filename='js/jsonpatch.min.js') }}"></script>
2019-08-30 13:31:00 +02:00
<script src="{{ url_for('static', filename='js/socket.io.js') }}"></script>
2019-08-23 15:05:01 +02:00
<script src="{{ url_for('static', filename='js/list.js') }}"></script>
<script src="{{ url_for('static', filename='js/list.utils.js') }}"></script>
<script src="{{ url_for('static', filename='js/CorpusList.js') }}"></script>
<script src="{{ url_for('static', filename='js/JobList.js') }}"></script>
2019-10-09 16:10:30 +02:00
<script src="{{ url_for('static', filename='js/darkreader.js') }}"></script>
<script>
{% if current_user.is_dark == True %}
DarkReader.enable({
brightness: 100,
contrast: 100,
sepia: 0
2019-10-09 16:10:30 +02:00
});
{% else %}
DarkReader.disable();
{% endif %}
</script>
2019-08-23 15:05:01 +02:00
<script>
var corpora;
var corporaSubscribers = [];
var jobs;
var jobsSubscribers = [];
var socket = io();
socket.on('init-corpora', function(msg) {
corpora = JSON.parse(msg);
2019-11-07 10:44:02 +01:00
for (let subscriber of corporaSubscribers) {subscriber._init(corpora);}
2019-08-23 15:05:01 +02:00
});
socket.on('init-jobs', function(msg) {
jobs = JSON.parse(msg);
2019-11-07 10:44:02 +01:00
for (let subscriber of jobsSubscribers) {subscriber._init(jobs);}
2019-08-23 15:05:01 +02:00
});
socket.on('update-corpora', function(msg) {
2019-11-07 10:44:02 +01:00
var patch;
patch = JSON.parse(msg);
2019-08-30 13:31:00 +02:00
corpora = jsonpatch.apply_patch(corpora, patch);
2019-11-07 10:44:02 +01:00
for (let subscriber of corporaSubscribers) {subscriber._update(patch);}
});
socket.on('update-jobs', function(msg) {
2019-11-07 10:44:02 +01:00
var patch;
patch = JSON.parse(msg);
2019-08-30 13:31:00 +02:00
jobs = jsonpatch.apply_patch(jobs, patch);
2019-11-07 10:44:02 +01:00
for (let subscriber of jobsSubscribers) {subscriber._update(patch);}
});
socket.on('message', function(msg) {
console.log(msg);
});
2019-08-23 15:05:01 +02:00
</script>
2019-09-18 11:33:06 +02:00
<script>
var foreignCorpora;
var foreignCorporaSubscribers = [];
var foreignJobs;
var foreignJobsSubscribers = [];
socket.on('init-foreign-corpora', function(msg) {
foreignCorpora = JSON.parse(msg);
2019-11-07 10:44:02 +01:00
for (let subscriber of foreignCorporaSubscribers) {subscriber._init(foreignCorpora);}
2019-09-18 11:33:06 +02:00
});
socket.on('init-foreign-jobs', function(msg) {
foreignJobs = JSON.parse(msg);
2019-11-07 10:44:02 +01:00
for (let subscriber of foreignJobsSubscribers) {subscriber._init(foreignJobs);}
2019-09-18 11:33:06 +02:00
});
socket.on('update-foreign-corpora', function(msg) {
2019-11-07 10:44:02 +01:00
var patch;
2019-09-18 11:33:06 +02:00
patch = JSON.parse(msg);
foreignCorpora = jsonpatch.apply_patch(foreignCorpora, patch);
2019-11-07 10:44:02 +01:00
for (let subscriber of foreignCorporaSubscribers) {subscriber._update(patch);}
2019-09-18 11:33:06 +02:00
});
socket.on('update-foreign-jobs', function(msg) {
2019-11-07 10:44:02 +01:00
var patch;
2019-09-18 11:33:06 +02:00
patch = JSON.parse(msg);
foreignJobs = jsonpatch.apply_patch(foreignJobs, patch);
2019-11-07 10:44:02 +01:00
for (let subscriber of foreignJobsSubscribers) {subscriber._update(patch);}
2019-09-18 11:33:06 +02:00
});
</script>
2019-07-04 11:59:52 +02:00
<meta name="viewport" content="width=device-width, initial-scale=1.0"/>
</head>
<body>
<header>
2019-07-08 10:07:26 +02:00
<div id="nav-notifications-dropdown" class="dropdown-content grey-text text-darken-4">
<p>Notifications</p>
</div>
2019-07-08 10:07:26 +02:00
<ul id="nav-account-dropdown" class="dropdown-content">
{% if current_user.is_authenticated %}
<li><a href="{{ url_for('profile.index') }}"><i class="material-icons">settings</i>Settings</a></li>
<li><a href="{{ url_for('auth.logout') }}"><i class="material-icons">power_settings_new</i>Log out</a></li>
2019-07-08 10:07:26 +02:00
{% else %}
<li><a href="{{ url_for('auth.login') }}"><i class="material-icons">person</i>Log in</a></li>
<li><a href="{{ url_for('auth.register') }}"><i class="material-icons">person_add</i>Register</a></li>
2019-07-08 10:07:26 +02:00
{% endif %}
</ul>
<div class="navbar-fixed">
<nav>
<div class="nav-wrapper">
2019-12-02 11:34:28 +01:00
<a href="{{ url_for('main.index') }}" class="brand-logo center"><i class="material-icons">opacity</i>nopaque</a>
<a href="#" data-target="slide-out" class="sidenav-trigger"><i class="material-icons">menu</i></a>
<ul class="right hide-on-med-and-down">
<li><a id="nav-notifications" class="dropdown-trigger no-autoinit" href="#!" data-target="nav-notifications-dropdown"><i class="material-icons">notifications</i></a></li>
2019-09-04 13:51:21 +02:00
<li>
<a id="nav-account" class="dropdown-trigger no-autoinit" href="#!" data-target="nav-account-dropdown">
{% if current_user.is_authenticated %}
{{ current_user.username }}<i class="material-icons right">account_circle</i>
{% else %}
<i class="material-icons">account_circle</i>
{% endif %}
</a>
</li>
</ul>
</div>
</nav>
</div>
<ul id="slide-out" class="sidenav sidenav-fixed">
2019-12-02 11:34:28 +01:00
<li><a href="{{ url_for('main.index') }}"><i class="material-icons">opacity</i>nopaque</a></li>
2019-09-11 10:00:52 +02:00
<li><a href="#"><i class="material-icons">linear_scale</i>Workflow</a></li>
2019-08-01 10:33:05 +02:00
<li><a href="{{ url_for('main.dashboard') }}"><i class="material-icons">dashboard</i>Dashboard</a></li>
2019-07-12 17:21:04 +02:00
<li><div class="divider"></div></li>
2019-09-04 13:51:21 +02:00
<li><a class="subheader">Services</a></li>
2020-01-07 14:39:01 +01:00
<li><a href="{{ url_for('services.service', service='merge_images') }}"><i class="material-icons">burst_mode</i>Merge images</a></li>
2019-11-08 12:21:59 +01:00
<li><a href="{{ url_for('services.service', service='nlp') }}"><i class="material-icons">format_textdirection_l_to_r</i>NLP</a></li>
<li><a href="{{ url_for('services.service', service='ocr') }}"><i class="material-icons">find_in_page</i>OCR</a></li>
2019-09-04 13:51:21 +02:00
{% if current_user.is_administrator() %}
<li><div class="divider"></div></li>
<li><a class="subheader">Administration</a></li>
2019-11-15 12:51:53 +01:00
<li><a href="{{ url_for('admin.index') }}"><i class="material-icons">build</i>Administration tools</a></li>
2019-07-10 14:36:31 +02:00
{% endif %}
<div class="hide-on-large-only">
<li><div class="divider"></div></li>
<li><a class="subheader">Account</a></li>
{% if current_user.is_authenticated %}
<li><a href="{{ url_for('profile.index') }}"><i class="material-icons">settings</i>Settings</a></li>
<li><a href="{{ url_for('auth.logout') }}"><i class="material-icons">power_settings_new</i>Log out</a></li>
{% else %}
<li><a href="{{ url_for('auth.login') }}"><i class="material-icons">person</i>Log in</a></li>
<li><a href="{{ url_for('auth.register') }}"><i class="material-icons">person_add</i>Register</a></li>
{% endif %}
</div>
</ul>
</header>
2019-07-04 11:36:23 +02:00
<main class="grey lighten-5">
{% block main_block %}{% endblock %}
2019-07-04 12:23:09 +02:00
</main>
2019-07-04 10:40:23 +02:00
<footer class="page-footer">
<div class="footer-copyright">
<div class="container">
© 2019 Bielefeld University
<a class="grey-text text-lighten-4 right" href="#!">Impress</a>
</div>
</div>
</footer>
2019-07-04 11:59:52 +02:00
<script>
2019-11-15 11:45:04 +01:00
socket.emit('subscribe_user_ressources');
</script>
<script src="{{ url_for('static', filename='js/materialize.min.js') }}"></script>
<script>
M.AutoInit();
M.CharacterCounter.init(document.querySelectorAll('input[data-length][type="text"]'))
M.Dropdown.init(
document.getElementById("nav-notifications"),
{"alignment": "right", "constrainWidth": false, "coverTrigger": false}
);
M.Dropdown.init(
document.getElementById("nav-account"),
{"alignment": "right", "constrainWidth": false, "coverTrigger": false}
);
// Highlight current navigation entry
var entry;
for (entry of document.querySelectorAll("#slide-out a:not(.subheader)")) {
if (entry.href === window.location.href) {
entry.parentNode.classList.add("active");
2019-09-10 16:09:35 +02:00
}
2019-11-15 11:45:04 +01:00
}
{% for message in get_flashed_messages() %}
2020-01-08 10:16:49 +01:00
M.toast({"html": '<span>{{ message }}</span><button class="btn-flat toast-action red-text" data-action="close"><i class="material-icons">close</i></button>'});
2019-11-15 11:45:04 +01:00
{% endfor %}
2020-01-08 10:13:58 +01:00
for (toastActionElement of document.querySelectorAll(".toast-action[data-action='close']")) {
toastActionElement.addEventListener("click", function(event) {
M.Toast.getInstance(toastActionElement.parentElement).dismiss();
});
}
2019-07-04 11:59:52 +02:00
</script>
</body>
2019-07-04 10:40:23 +02:00
</html>