2022-10-13 14:26:43 +00:00
|
|
|
{% load static %}
|
|
|
|
{% load has_plan %}
|
|
|
|
|
|
|
|
<!DOCTYPE html>
|
|
|
|
<html lang="en-GB">
|
|
|
|
<head>
|
|
|
|
<meta charset="utf-8">
|
|
|
|
<meta name="viewport" content="width=device-width, initial-scale=1">
|
|
|
|
<title>XF - {{ request.path_info }}</title>
|
|
|
|
<link rel="shortcut icon" href="{% static 'favicon.ico' %}">
|
|
|
|
<link rel="manifest" href="{% static 'manifest.webmanifest' %}">
|
|
|
|
<link rel="stylesheet" href="{% static 'css/bulma.min.css' %}">
|
|
|
|
<link rel="stylesheet" href="{% static 'css/bulma-tooltip.min.css' %}">
|
|
|
|
<link rel="stylesheet" href="https://site-assets.fontawesome.com/releases/v6.1.1/css/all.css">
|
|
|
|
<link rel="stylesheet" href="{% static 'css/gridstack.min.css' %}">
|
|
|
|
<script src="{% static 'js/htmx.min.js' %}" integrity="sha384-cZuAZ+ZbwkNRnrKi05G/fjBX+azI9DNOkNYysZ0I/X5ZFgsmMiBXgDZof30F5ofc" crossorigin="anonymous"></script>
|
|
|
|
<script defer src="{% static 'js/hyperscript.min.js' %}" integrity="sha384-6GYN8BDHOJkkru6zcpGOUa//1mn+5iZ/MyT6mq34WFIpuOeLF52kSi721q0SsYF9" crossorigin="anonymous"></script>
|
|
|
|
<script defer src="{% static 'js/remove-me.js' %}" integrity="sha384-6fHcFNoQ8QEI3ZDgw9Z/A6Brk64gF7AnFbLgdrumo8/kBbsKQ/wo7wPegj5WkzuG" crossorigin="anonymous"></script>
|
|
|
|
<script src="{% static 'js/gridstack-all.js' %}"></script>
|
|
|
|
<script defer src="{% static 'js/magnet.min.js' %}"></script>
|
|
|
|
<script>
|
|
|
|
document.addEventListener("restore-scroll", function(event) {
|
|
|
|
var scrollpos = localStorage.getItem('scrollpos');
|
|
|
|
if (scrollpos) {
|
|
|
|
window.scrollTo(0, scrollpos)
|
|
|
|
};
|
|
|
|
});
|
|
|
|
|
|
|
|
document.addEventListener("htmx:beforeSwap", function(event) {
|
|
|
|
localStorage.setItem('scrollpos', window.scrollY);
|
|
|
|
|
|
|
|
});
|
|
|
|
</script>
|
|
|
|
<script>
|
|
|
|
document.addEventListener('DOMContentLoaded', () => {
|
|
|
|
|
|
|
|
// Get all "navbar-burger" elements
|
|
|
|
const $navbarBurgers = Array.prototype.slice.call(document.querySelectorAll('.navbar-burger'), 0);
|
|
|
|
|
|
|
|
// Add a click event on each of them
|
|
|
|
$navbarBurgers.forEach( el => {
|
|
|
|
el.addEventListener('click', () => {
|
|
|
|
|
|
|
|
// Get the target from the "data-target" attribute
|
|
|
|
const target = el.dataset.target;
|
|
|
|
const $target = document.getElementById(target);
|
|
|
|
|
|
|
|
// Toggle the "is-active" class on both the "navbar-burger" and the "navbar-menu"
|
|
|
|
el.classList.toggle('is-active');
|
|
|
|
$target.classList.toggle('is-active');
|
|
|
|
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|
|
|
|
</script>
|
|
|
|
<style>
|
|
|
|
.icon { border-bottom: 0px !important;}
|
|
|
|
.wrap {
|
|
|
|
word-wrap: break-word;
|
|
|
|
}
|
|
|
|
.nowrap-parent {
|
|
|
|
white-space: nowrap;
|
|
|
|
}
|
|
|
|
.nowrap-child {
|
|
|
|
display: inline-block;
|
|
|
|
}
|
|
|
|
.htmx-indicator{
|
|
|
|
opacity:0;
|
|
|
|
transition: opacity 500ms ease-in;
|
|
|
|
}
|
|
|
|
.htmx-request .htmx-indicator{
|
|
|
|
opacity:1
|
|
|
|
}
|
|
|
|
.htmx-request.htmx-indicator{
|
|
|
|
opacity:1
|
|
|
|
}
|
|
|
|
|
|
|
|
.tooltiptext {
|
|
|
|
visibility: hidden;
|
|
|
|
background-color: black;
|
|
|
|
color: #fff;
|
|
|
|
text-align: center;
|
|
|
|
padding: 5px 0;
|
|
|
|
border-radius: 6px;
|
|
|
|
position: absolute;
|
|
|
|
z-index: 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
.rounded-tooltip:hover .tooltiptext {
|
|
|
|
visibility: visible;
|
|
|
|
}
|
|
|
|
|
|
|
|
.table {
|
|
|
|
background: transparent !important;
|
|
|
|
}
|
|
|
|
|
|
|
|
tr {
|
|
|
|
transition: all 0.2s ease-in-out;
|
|
|
|
}
|
|
|
|
|
|
|
|
tr:hover {
|
|
|
|
cursor:pointer;
|
|
|
|
background-color:rgba(221, 224, 255, 0.3) !important;
|
|
|
|
}
|
|
|
|
|
|
|
|
a.panel-block {
|
|
|
|
transition: all 0.2s ease-in-out;
|
|
|
|
}
|
|
|
|
|
|
|
|
a.panel-block:hover {
|
|
|
|
cursor:pointer;
|
|
|
|
background-color:rgba(221, 224, 255, 0.3) !important;
|
|
|
|
}
|
|
|
|
|
|
|
|
.panel, .box, .modal {
|
|
|
|
background-color:rgba(250, 250, 250, 0.5) !important;
|
|
|
|
}
|
|
|
|
.modal, .modal.box{
|
|
|
|
background-color:rgba(210, 210, 210, 0.9) !important;
|
|
|
|
}
|
|
|
|
.modal-background{
|
|
|
|
background-color:rgba(255, 255, 255, 0.3) !important;
|
|
|
|
}
|
|
|
|
|
|
|
|
.has-background-grey-lighter{
|
|
|
|
background-color:rgba(219, 219, 219, 0.5) !important;
|
|
|
|
}
|
|
|
|
.navbar {
|
|
|
|
background-color:rgba(0, 0, 0, 0.03) !important;
|
|
|
|
}
|
|
|
|
|
|
|
|
.grid-stack-item-content {
|
|
|
|
display: flex !important;
|
|
|
|
flex-direction: column !important;
|
|
|
|
overflow-x: hidden !important;
|
|
|
|
overflow-y: hidden !important;
|
|
|
|
}
|
|
|
|
|
|
|
|
.panel {
|
|
|
|
display: flex !important;
|
|
|
|
flex-direction: column !important;
|
|
|
|
overflow: hidden;
|
|
|
|
}
|
|
|
|
|
|
|
|
.panel-block {
|
|
|
|
overflow-y:auto;
|
|
|
|
overflow-x:auto;
|
|
|
|
min-height: 90%;
|
|
|
|
display: block;
|
|
|
|
}
|
|
|
|
|
|
|
|
.floating-window {
|
|
|
|
/* background-color:rgba(210, 210, 210, 0.6) !important; */
|
|
|
|
display: flex !important;
|
|
|
|
flex-direction: column !important;
|
|
|
|
overflow-x: hidden !important;
|
|
|
|
overflow-y: hidden !important;
|
|
|
|
max-height: 300px;
|
|
|
|
z-index: 9000;
|
|
|
|
position: absolute;
|
|
|
|
top: 50px;
|
|
|
|
left: 50px;
|
|
|
|
}
|
|
|
|
|
|
|
|
.floating-window .panel {
|
|
|
|
background-color:rgba(250, 250, 250, 0.8) !important;
|
|
|
|
}
|
|
|
|
|
|
|
|
.float-right {
|
|
|
|
float: right;
|
|
|
|
padding-right: 5px;
|
|
|
|
padding-left: 5px;
|
|
|
|
}
|
|
|
|
.grid-stack-item:hover .ui-resizable-handle {
|
|
|
|
display: block !important;
|
|
|
|
}
|
|
|
|
.ui-resizable-handle {
|
|
|
|
z-index: 39 !important;
|
|
|
|
}
|
|
|
|
|
|
|
|
</style>
|
|
|
|
</head>
|
|
|
|
<body>
|
|
|
|
|
|
|
|
<nav class="navbar" role="navigation" aria-label="main navigation">
|
|
|
|
<div class="navbar-brand">
|
|
|
|
<a class="navbar-item" href="{% url 'home' %}">
|
|
|
|
<img src="{% static 'logo.svg' %}" width="112" height="28" alt="logo">
|
|
|
|
</a>
|
|
|
|
|
|
|
|
<a role="button" class="navbar-burger" aria-label="menu" aria-expanded="false" data-target="bar">
|
|
|
|
<span aria-hidden="true"></span>
|
|
|
|
<span aria-hidden="true"></span>
|
|
|
|
<span aria-hidden="true"></span>
|
|
|
|
</a>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div id="bar" class="navbar-menu">
|
|
|
|
<div class="navbar-start">
|
|
|
|
<a class="navbar-item" href="{% url 'home' %}">
|
|
|
|
Home
|
|
|
|
</a>
|
2022-10-14 06:20:30 +00:00
|
|
|
{% if user.is_authenticated %}
|
|
|
|
<a class="navbar-item" href="{% url 'hooks' type='page' %}">
|
|
|
|
Hooks
|
|
|
|
</a>
|
|
|
|
{% endif %}
|
2022-10-15 20:51:47 +00:00
|
|
|
{% if user.is_authenticated %}
|
|
|
|
<a class="navbar-item" href="{% url 'callbacks' type='page' %}">
|
|
|
|
Callbacks
|
|
|
|
</a>
|
|
|
|
{% endif %}
|
2022-10-13 17:20:30 +00:00
|
|
|
{% if settings.STRIPE_ENABLED %}
|
|
|
|
{% if user.is_authenticated %}
|
|
|
|
<a class="navbar-item" href="{% url 'billing' %}">
|
|
|
|
Billing
|
|
|
|
</a>
|
|
|
|
{% endif %}
|
2022-10-13 14:26:43 +00:00
|
|
|
{% endif %}
|
|
|
|
{% if user.is_superuser %}
|
|
|
|
<div class="navbar-item has-dropdown is-hoverable">
|
|
|
|
<a class="navbar-link">
|
|
|
|
Admin
|
|
|
|
</a>
|
|
|
|
|
|
|
|
<div class="navbar-dropdown">
|
|
|
|
<a class="navbar-item" href="#">
|
|
|
|
Admin1
|
|
|
|
</a>
|
|
|
|
<a class="navbar-item" href="#">
|
|
|
|
Admin2
|
|
|
|
</a>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
{% endif %}
|
|
|
|
<a class="navbar-item add-button">
|
|
|
|
Install
|
|
|
|
</a>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="navbar-end">
|
|
|
|
<div class="navbar-item">
|
|
|
|
<div class="buttons">
|
|
|
|
{% if not user.is_authenticated %}
|
|
|
|
<a class="button is-info" href="{% url 'signup' %}">
|
|
|
|
<strong>Sign up</strong>
|
|
|
|
</a>
|
|
|
|
<a class="button is-light" href="{% url 'login' %}">
|
|
|
|
Log in
|
|
|
|
</a>
|
|
|
|
{% endif %}
|
|
|
|
|
|
|
|
{% if user.is_authenticated %}
|
|
|
|
<a class="button is-dark" href="{% url 'logout' %}">Logout</a>
|
|
|
|
{% endif %}
|
|
|
|
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</nav>
|
|
|
|
<script>
|
|
|
|
let deferredPrompt;
|
|
|
|
const addBtn = document.querySelector('.add-button');
|
|
|
|
addBtn.style.display = 'none';
|
|
|
|
window.addEventListener('beforeinstallprompt', (e) => {
|
|
|
|
// Prevent Chrome 67 and earlier from automatically showing the prompt
|
|
|
|
e.preventDefault();
|
|
|
|
// Stash the event so it can be triggered later.
|
|
|
|
deferredPrompt = e;
|
|
|
|
// Update UI to notify the user they can add to home screen
|
|
|
|
addBtn.style.display = 'block';
|
|
|
|
|
|
|
|
addBtn.addEventListener('click', (e) => {
|
|
|
|
// hide our user interface that shows our A2HS button
|
|
|
|
addBtn.style.display = 'none';
|
|
|
|
// Show the prompt
|
|
|
|
deferredPrompt.prompt();
|
|
|
|
// Wait for the user to respond to the prompt
|
|
|
|
deferredPrompt.userChoice.then((choiceResult) => {
|
|
|
|
if (choiceResult.outcome === 'accepted') {
|
|
|
|
console.log('User accepted the A2HS prompt');
|
|
|
|
} else {
|
|
|
|
console.log('User dismissed the A2HS prompt');
|
|
|
|
}
|
|
|
|
deferredPrompt = null;
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
</script>
|
|
|
|
{% block outer_content %}
|
|
|
|
{% endblock %}
|
|
|
|
<section class="section">
|
|
|
|
<div class="container">
|
|
|
|
{% block content %}
|
|
|
|
{% endblock %}
|
2022-10-14 06:20:30 +00:00
|
|
|
<div id="modals-here">
|
|
|
|
</div>
|
|
|
|
<div id="items-here">
|
|
|
|
</div>
|
|
|
|
<div id="widgets-here" style="display: none;">
|
|
|
|
</div>
|
2022-10-13 14:26:43 +00:00
|
|
|
</div>
|
|
|
|
</section>
|
|
|
|
</body>
|
|
|
|
</html>
|