180 lines
7.6 KiB
HTML
180 lines
7.6 KiB
HTML
{% load i18n static %}
|
|
|
|
<!DOCTYPE html>
|
|
<html>
|
|
<head>
|
|
<meta name="viewport" content="width=device-width, initial-scale=1">
|
|
<title>{% block title %}{% endblock %}</title>
|
|
|
|
<link rel="shortcut icon" href="{% static 'img/favicon.png' %}">
|
|
|
|
<script src="https://code.jquery.com/jquery-3.7.1.min.js"></script>
|
|
<script src="https://cdn.jsdelivr.net/npm/vue@2.7.16/dist/vue.js"></script>
|
|
<script src="https://cdn.jsdelivr.net/npm/sweetalert2@11"></script>
|
|
<script src="https://cdn.jsdelivr.net/npm/vue-resource@1.5.3"></script>
|
|
<script src="https://cdn.jsdelivr.net/npm/js-cookie@3.0.5/dist/js.cookie.min.js"></script>
|
|
<script src="https://unpkg.com/vue-router@3/dist/vue-router.js"></script>
|
|
|
|
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.3/dist/css/bootstrap.min.css" rel="stylesheet" integrity="sha384-QWTKZyjpPEjISv5WaRU9OFeRpok6YctnYmDr5pNlyT2bRjXh0JMhjY6hW+ALEwIH" crossorigin="anonymous">
|
|
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.3/dist/js/bootstrap.bundle.min.js" integrity="sha384-YvpcrYf0tY3lHB60NNkmXc5s9fDVZLESaAA55NDzOxhy9GkcIdslK1eN7N6jIeHz" crossorigin="anonymous"></script>
|
|
|
|
<link href="https://cdn.jsdelivr.net/npm/bootswatch@5.3.3/dist/lux/bootstrap.min.css " rel="stylesheet">
|
|
<script src="{% url 'reverse_js' %}" type="text/javascript"></script>
|
|
|
|
<link href="https://cdn.jsdelivr.net/npm/vuetify@2.x/dist/vuetify.min.css" rel="stylesheet">
|
|
<script src="https://cdn.jsdelivr.net/npm/vuetify@2.x/dist/vuetify.js"></script>
|
|
|
|
<link href="https://cdn.jsdelivr.net/npm/@mdi/font@7.4.47/css/materialdesignicons.min.css" rel="stylesheet">
|
|
|
|
<link href="https://fonts.cdnfonts.com/css/jetbrains-mono" rel="stylesheet">
|
|
<style>
|
|
.font {
|
|
font-family: 'JetBrains Mono', sans-serif;
|
|
}
|
|
</style>
|
|
|
|
</head>
|
|
<body>
|
|
<v-app class="font">
|
|
<div id="main" data-app>
|
|
|
|
<nav class="navbar navbar-expand-lg bg-primary" data-bs-theme="dark">
|
|
<div class="container-fluid">
|
|
<a href="#" @click="lock_me" class="navbar-brand">{% trans "Lock" %}</a>
|
|
|
|
<button class="navbar-toggler" type="button" data-bs-toggle="collapse" data-bs-target="#navbarColor01" aria-controls="navbarColor01" aria-expanded="false" aria-label="Toggle navigation">
|
|
<span class="navbar-toggler-icon"></span>
|
|
</button>
|
|
|
|
<div class="collapse navbar-collapse" id="navbarColor01">
|
|
<ul class="navbar-nav me-auto">
|
|
<li class="nav-item">
|
|
<router-link href="#" to="{% url 'main:home' %}" class="nav-link active" to="{% url 'main:home' %}">
|
|
{% trans "K356" %}
|
|
<span class="visually-hidden"></span>
|
|
</router-link>
|
|
</li>
|
|
<li class="nav-item">
|
|
<router-link class="nav-link" to="/ItemView">{% trans "Items" %}</router-link>
|
|
</li>
|
|
<li class="nav-item">
|
|
<a class="nav-link" href="#">{% trans "Properties" %}</a>
|
|
</li>
|
|
<li class="nav-item">
|
|
<router-link class="nav-link" to="/EncryptionTesting">{% trans "Encryption" %}</router-link>
|
|
</li>
|
|
<li class="nav-item dropdown">
|
|
<a class="nav-link dropdown-toggle" data-bs-toggle="dropdown" href="#" role="button" aria-haspopup="true" aria-expanded="false">{% trans "More" %}</a>
|
|
<div class="dropdown-menu">
|
|
<a class="dropdown-item" href="#">Action</a>
|
|
<a class="dropdown-item" href="#">Another action</a>
|
|
<a class="dropdown-item" href="#">Something else here</a>
|
|
<div class="dropdown-divider"></div>
|
|
<a class="dropdown-item" href="/admin/">{% trans "Admin" %}</a>
|
|
</div>
|
|
</li>
|
|
</ul>
|
|
<form class="d-flex">
|
|
<input class="form-control me-sm-2" type="search" placeholder="Search">
|
|
<button class="btn btn-secondary my-2 my-sm-0" type="submit">Search</button>
|
|
</form>
|
|
</div>
|
|
</div>
|
|
</nav>
|
|
|
|
<div id="app" class="container">
|
|
<Loading :crypto_key="key" @update_key="update_key" v-if="locked"></Loading>
|
|
<template v-if="!locked">
|
|
<router-view :crypto_key="key"></router-view>
|
|
</template>
|
|
</div>
|
|
|
|
</div>
|
|
</v-app>
|
|
|
|
<script type="text/javascript">
|
|
{% include 'scripts.js' %}
|
|
</script>
|
|
|
|
{% for name, path in templates.items %}
|
|
<script type="text/x-template" id="{{ name }}">
|
|
{% include path %}
|
|
</script>
|
|
{% endfor %}
|
|
|
|
<script type="text/javascript">
|
|
Vue.use(VueRouter);
|
|
|
|
Vue.config.delimiters = ["[[", "]]"];
|
|
|
|
{% for name, path in components.items %}
|
|
{% include path %}
|
|
Vue.component("{{ name }}", {{ name }});
|
|
{% endfor %}
|
|
|
|
const routes = [
|
|
{ path: '/', component: null },
|
|
{% for name, path in components.items %}
|
|
{
|
|
path: "/{{ name }}",
|
|
component: {{ name }},
|
|
},
|
|
{% endfor %}
|
|
];
|
|
|
|
const router = new VueRouter({routes});
|
|
|
|
const approuter = new Vue({
|
|
router,
|
|
vuetify: new Vuetify(),
|
|
el: "#main",
|
|
data: {
|
|
key: {
|
|
key: null,
|
|
uuid: "{{ user_settings.id }}",
|
|
},
|
|
locked: true,
|
|
},
|
|
methods: {
|
|
update_key: function(key) {
|
|
this.key.key = key;
|
|
this.locked = key == null;
|
|
},
|
|
|
|
lock_me: function() {
|
|
this.locked = true;
|
|
this.key.key = null;
|
|
}
|
|
}
|
|
});
|
|
|
|
router.beforeEach((to, from, next) => {
|
|
// Prevent from routing if key is not present.
|
|
next(approuter.key.key != null);
|
|
});
|
|
|
|
</script>
|
|
|
|
<script type="text/javascript">
|
|
function refresh_csrftoken() {
|
|
var csrftoken = Cookies.get('csrftoken');
|
|
Vue.http.headers.common['X-CSRFTOKEN'] = csrftoken;
|
|
}
|
|
|
|
refresh_csrftoken();
|
|
</script>
|
|
|
|
<script type="module">
|
|
import { useDate } from './vuetify.js'
|
|
|
|
const date = useDate()
|
|
|
|
const formatted = date.format('2010-04-13', 'fullDateWithWeekday')
|
|
|
|
console.log(formatted) // Tuesday, April 13, 2010
|
|
</script>
|
|
|
|
|
|
</body>
|
|
</html>
|