mirror of
https://github.com/simon987/Simple-Incremental-Search-Tool.git
synced 2025-10-24 12:36:52 +00:00
176 lines
6.4 KiB
HTML
176 lines
6.4 KiB
HTML
{% extends "layout.html" %}
|
|
{% set active_page = "directory" %}
|
|
|
|
{% block title %}{{ directory.name }}{% endblock title %}
|
|
|
|
{% block body %}
|
|
|
|
<script>
|
|
|
|
function swapToForm(elem, fields, formAction, inputName) {
|
|
|
|
let form = document.createElement("form");
|
|
form.setAttribute("action", formAction);
|
|
|
|
for (let i in fields) {
|
|
|
|
let hiddenInput = document.createElement("input");
|
|
hiddenInput.setAttribute("type", "hidden");
|
|
hiddenInput.setAttribute("value", fields[i].value);
|
|
hiddenInput.setAttribute("name", fields[i].name);
|
|
form.appendChild(hiddenInput);
|
|
}
|
|
|
|
let input = document.createElement("input");
|
|
input.setAttribute("class", "form-control");
|
|
input.setAttribute("type", "text");
|
|
input.setAttribute("name", inputName);
|
|
input.value = elem.innerHTML;
|
|
form.appendChild(input);
|
|
|
|
elem.parentNode.insertBefore(form, elem);
|
|
elem.remove();
|
|
|
|
input.focus();
|
|
input.addEventListener("focusout", function () {
|
|
form.submit();
|
|
});
|
|
|
|
return input;
|
|
}
|
|
|
|
function modifyVal(optId, key) {
|
|
swapToForm(document.getElementById("val-" + optId), [
|
|
{name: "id", value: optId},
|
|
{name: "key", value: key},
|
|
{name: "dir_id", value: {{ directory.id }}}
|
|
], "/directory/{{ directory.id }}/update_opt", "value");
|
|
}
|
|
|
|
function modifyDisplayName() {
|
|
swapToForm(document.getElementById("display-name"), [],
|
|
"/directory/{{ directory.id }}/update", "name");
|
|
}
|
|
|
|
function modifyPath() {
|
|
swapToForm(document.getElementById("path"), [],
|
|
"/directory/{{ directory.id }}/update", "path");
|
|
}
|
|
|
|
</script>
|
|
|
|
<div class="container">
|
|
|
|
<div class="card">
|
|
|
|
<div class="card-header">Summary</div>
|
|
<div class="card-body">
|
|
|
|
<table class="info-table">
|
|
<tr onclick="modifyDisplayName()">
|
|
<th style="width: 20%">Display name</th>
|
|
<td>
|
|
<pre id="display-name" title="Click to update">{{ directory.name }}</pre>
|
|
</td>
|
|
</tr>
|
|
|
|
<tr onclick="modifyPath()">
|
|
<th style="width: 20%">Path</th>
|
|
<td>
|
|
<pre id="path" title="Click to update">{{ directory.path }}</pre>
|
|
</td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<th style="width: 20%">Enabled</th>
|
|
<td>
|
|
<form action="/directory/{{ directory.id }}/update"
|
|
style="display: inline;margin-left: 6px;">
|
|
<input type="hidden" name="enabled" value="{{ "0" if directory.enabled else "1" }}">
|
|
<button class="btn btn-sm {{ "btn-danger" if directory.enabled else "btn-success" }}">
|
|
<i class="far {{ "fa-check-square" if directory.enabled else "fa-square" }}"></i>
|
|
{{ "Disable" if directory.enabled else "Enable" }}
|
|
</button>
|
|
</form>
|
|
</td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<th>Thumbnail cache size</th>
|
|
<td>
|
|
<pre>{{ tn_size_formatted }} ({{ tn_size }} bytes)</pre>
|
|
</td>
|
|
</tr>
|
|
</table>
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div class="card">
|
|
<div class="card-header">Actions</div>
|
|
<div class="card-body">
|
|
|
|
<div class="d-flex">
|
|
|
|
<form action="/task/add" class="p-2">
|
|
<input type="hidden" value="1" name="type">
|
|
<input type="hidden" value="{{ directory.id }}" name="directory">
|
|
<button class="btn btn-primary" href="/task/">
|
|
<i class="fas fa-book"></i> Generate index
|
|
</button>
|
|
</form>
|
|
|
|
<form action="/task/add" class="p-2">
|
|
<input type="hidden" value="2" name="type">
|
|
<input type="hidden" value="{{ directory.id }}" name="directory">
|
|
<button class="btn btn-primary" href="/task/">
|
|
<i class="far fa-images"></i> Generate thumbnails
|
|
</button>
|
|
</form>
|
|
|
|
<div class="dropdown p-2">
|
|
<button class="btn dropdown-toggle btn-danger" data-toggle="dropdown">Action</button>
|
|
|
|
<div class="dropdown-menu">
|
|
<a class="dropdown-item" href="/directory/{{ directory.id }}/del">Delete directory</a>
|
|
<a class="dropdown-item" href="/directory/{{ directory.id }}/reset">Reset to default settings</a>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
|
|
</div>
|
|
</div>
|
|
|
|
<div class="card">
|
|
<div class="card-header">Options <a href="#" style="float:right">Learn more <i
|
|
class="fas fa-external-link-alt"></i></a></div>
|
|
<div class="card-body">
|
|
<table class="info-table table-striped table-hover">
|
|
<thead>
|
|
<tr>
|
|
<th>Option</th>
|
|
<th>Value</th>
|
|
</tr>
|
|
</thead>
|
|
<tbody>
|
|
{% for option in directory.options %}
|
|
|
|
<tr>
|
|
<td style="width: 30%"><span>{{ option.key }}</span></td>
|
|
<td onclick="modifyVal({{ option.id }}, '{{ option.key }}')" title="Click to update">
|
|
<pre id="val-{{ option.id }}">{{ option.value }}</pre>
|
|
</td>
|
|
</tr>
|
|
|
|
{% endfor %}
|
|
|
|
</tbody>
|
|
</table>
|
|
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
|
|
{% endblock body %} |