Added UI to create, build and delete documents
This commit is contained in:
parent
3a3edd3651
commit
df476d9865
@ -12,10 +12,13 @@ def create_app():
|
||||
from api import api_document
|
||||
app.register_blueprint(api_document.bp)
|
||||
|
||||
from web import web_admin
|
||||
app.register_blueprint(web_admin.bp)
|
||||
|
||||
from web import web_document
|
||||
app.register_blueprint(web_document.bp)
|
||||
|
||||
from web.admin import admin
|
||||
app.register_blueprint(admin.bp)
|
||||
|
||||
from web.admin import admin_document
|
||||
app.register_blueprint(admin_document.bp)
|
||||
|
||||
return app
|
||||
|
@ -52,6 +52,13 @@ class Document:
|
||||
def pull(self):
|
||||
return run("cd \"" + self.doc_path + "/repo\" && git pull")
|
||||
|
||||
def delete(self):
|
||||
shutil.rmtree(self.doc_path)
|
||||
|
||||
def delete_folder(self):
|
||||
doc_path = Document.make_doc_path(self.doc_name, self.branch)
|
||||
shutil.rmtree(doc_path)
|
||||
|
||||
def get_url(self):
|
||||
return "/doc/" + sanitize_name(self.doc_name)+'/'+sanitize_name(self.branch) + "/index.html"
|
||||
|
||||
|
8
src/static/app.js
Normal file
8
src/static/app.js
Normal file
@ -0,0 +1,8 @@
|
||||
var confirm_elements = document.querySelectorAll('a[data-confirm]');
|
||||
for (let elt of confirm_elements)
|
||||
{
|
||||
elt.addEventListener('click', (e) => {
|
||||
if(!confirm(elt.getAttribute('data-confirm')))
|
||||
e.preventDefault();
|
||||
}, false);
|
||||
}
|
0
src/static/style.css
Normal file
0
src/static/style.css
Normal file
8
src/templates/admin/command_output.html
Normal file
8
src/templates/admin/command_output.html
Normal file
@ -0,0 +1,8 @@
|
||||
{% extends 'base.html' %}
|
||||
|
||||
{% block title %}Exécution...{% endblock %}
|
||||
|
||||
{% block content %}
|
||||
<pre>{{ output }}</pre>
|
||||
<a href="{{ next }}" class="button">OK</a>
|
||||
{% endblock %}
|
11
src/templates/admin/document/manage.html
Normal file
11
src/templates/admin/document/manage.html
Normal file
@ -0,0 +1,11 @@
|
||||
{% extends 'base.html' %}
|
||||
|
||||
{% block title %}{{ doc.doc_name }} / {{ doc.branch }} (admin){% endblock %}
|
||||
|
||||
{% block content %}
|
||||
<h1>Gestion de {{ doc.doc_name }} / {{ doc.branch }}</h1>
|
||||
<a href="{{doc.get_url()}}" class="button">Consulter</a><br/>
|
||||
<a href="{{ url_for('api_document.build', doc = doc.doc_name, branch = doc.branch) }}" class="button">Compiler</a><br/>
|
||||
<br/>
|
||||
<a href="{{ url_for('admin_document.delete', doc_name = doc.doc_name, branch = doc.branch) }}" class="button danger" data-confirm="Êtes-vous sûr de vouloir supprimer le document {{ doc.doc_name }} / {{ doc.branch }} ?">Supprimer</a>
|
||||
{% endblock %}
|
14
src/templates/admin/document/new.html
Normal file
14
src/templates/admin/document/new.html
Normal file
@ -0,0 +1,14 @@
|
||||
{% extends 'base.html' %}
|
||||
|
||||
{% block title %}Nouveau document{% endblock %}
|
||||
|
||||
{% block content %}
|
||||
<form method="POST">
|
||||
<label for="repo">Dépôt git :</label> <input type="text" id="repo" name="repo"><br/>
|
||||
<label for="branch">Branche :</label> <input type="text" id="branch" name="branch" value="master"><br/>
|
||||
<label for="doc">Nom :</label> <input type="text" id="doc" name="doc"> (laisser vide pour utiliser le nom du dépôt)<br/>
|
||||
<label for="source">Dossier source :</label> <input type="text" id="source" name="source" value="source"> (chemin dans le dépôt du dossier contenant les sources du document)<br/>
|
||||
|
||||
<input type="submit" value="Créer le document"/>
|
||||
</form>
|
||||
{% endblock %}
|
22
src/templates/admin/index.html
Normal file
22
src/templates/admin/index.html
Normal file
@ -0,0 +1,22 @@
|
||||
{% extends 'base.html' %}
|
||||
|
||||
{% block title %}Documentation (admin){% endblock %}
|
||||
|
||||
{% block content %}
|
||||
<h1>Administration des documents</h1>
|
||||
<a href="{{ url_for('admin_document.new') }}">Nouveau document...</a>
|
||||
<h2>Liste des documents</h2>
|
||||
{% if documents|length > 0 %}
|
||||
<ul>
|
||||
{% for doc in documents %}
|
||||
{% if doc.valid %}
|
||||
<li>{{ doc.doc_name }} / {{ doc.branch }} <a href="{{ doc.get_url() }}">Consulter</a> <a href="{{ url_for('admin_document.manage', doc_name = doc.doc_name, branch = doc.branch) }}" class="button">Gérer</a></li>
|
||||
{% else %}
|
||||
<li>{{ doc.doc_name }} / {{ doc.branch }} (document invalide) <a href="{{ url_for('admin_document.delete_invalid', doc_name = doc.doc_name, branch = doc.branch) }}" class="confirm danger">Supprimer le dossier</a></li>
|
||||
{% endif %}
|
||||
{% endfor %}
|
||||
</ul>
|
||||
{% else %}
|
||||
<p>Aucun document</p>
|
||||
{% endif %}
|
||||
{% endblock %}
|
14
src/templates/base.html
Normal file
14
src/templates/base.html
Normal file
@ -0,0 +1,14 @@
|
||||
<!DOCTYPE html>
|
||||
<html lang="fr">
|
||||
|
||||
<head>
|
||||
<meta charset="utf-8">
|
||||
<title>{% block title %}{% endblock %}</title>
|
||||
<link rel="stylesheet" href="{{ url_for('static', filename='style.css') }}">
|
||||
</head>
|
||||
|
||||
<body>
|
||||
{% block content %}{% endblock %}
|
||||
|
||||
<script type="text/javascript" src="{{ url_for('static', filename='app.js') }}"></script>
|
||||
</body>
|
@ -1,24 +0,0 @@
|
||||
<!DOCTYPE html>
|
||||
<html lang="fr">
|
||||
|
||||
<head>
|
||||
<meta charset="utf-8">
|
||||
<title>Documentation (admin)</title>
|
||||
</head>
|
||||
|
||||
<body>
|
||||
<h1>Administration des documents</h1>
|
||||
<a href="">Nouveau document...</a>
|
||||
<h2>Liste des documents</h2>
|
||||
<ul>
|
||||
{% for doc in documents %}
|
||||
{% if doc.valid %}
|
||||
<li>{{ doc.doc_name }} / {{ doc.branch }} <a href="{{ doc.get_url() }}">Consulter</a></li>
|
||||
{% else %}
|
||||
<li>{{ doc.doc_name }} / {{ doc.branch }} (document invalide)</li>
|
||||
{% endif %}
|
||||
{% endfor %}
|
||||
</ul>
|
||||
|
||||
<script type="text/javascript" src="/static/index.js"></script>
|
||||
</body>
|
9
src/web/admin/admin.py
Normal file
9
src/web/admin/admin.py
Normal file
@ -0,0 +1,9 @@
|
||||
from flask import Blueprint, render_template
|
||||
|
||||
from data.document import Document
|
||||
|
||||
bp = Blueprint('admin', __name__, url_prefix='/admin')
|
||||
|
||||
@bp.route('/')
|
||||
def index():
|
||||
return render_template("admin/index.html", documents=Document.list())
|
41
src/web/admin/admin_document.py
Normal file
41
src/web/admin/admin_document.py
Normal file
@ -0,0 +1,41 @@
|
||||
import os
|
||||
from flask import Blueprint, render_template, redirect, url_for, request
|
||||
|
||||
from web_utils.get_arg import get_arg
|
||||
|
||||
from data.document import Document
|
||||
|
||||
bp = Blueprint('admin_document', __name__, url_prefix='/admin/doc')
|
||||
|
||||
@bp.route('/new', methods=['GET', 'POST'])
|
||||
def new():
|
||||
if request.method == 'POST':
|
||||
repo = request.form.get('repo')
|
||||
doc_name = request.form.get('doc')
|
||||
branch = request.form.get('branch')
|
||||
source_dir = request.form.get('source')
|
||||
|
||||
if doc_name == "":
|
||||
doc_name = os.path.splitext(os.path.basename(repo))[0]
|
||||
|
||||
output = Document.clone(repo, branch, doc_name, source_dir)
|
||||
|
||||
return render_template("admin/command_output.html", output = output, next = url_for('admin_document.manage', doc_name = doc_name, branch = branch))
|
||||
else:
|
||||
return render_template("admin/document/new.html")
|
||||
|
||||
@bp.route('/manage/<doc_name>/<branch>')
|
||||
def manage(doc_name, branch):
|
||||
return render_template("admin/document/manage.html", doc=Document(doc_name, branch))
|
||||
|
||||
@bp.route('/delete/<doc_name>/<branch>')
|
||||
def delete(doc_name, branch):
|
||||
doc = Document(doc_name, branch)
|
||||
doc.delete()
|
||||
return redirect(url_for('admin.index'), code=302)
|
||||
|
||||
@bp.route('/delete_invalid/<doc_name>/<branch>')
|
||||
def delete_invalid(doc_name, branch):
|
||||
doc = Document(doc_name, branch, allow_invalid = True)
|
||||
doc.delete_folder()
|
||||
return redirect(url_for('admin.index'), code=302)
|
@ -1,9 +0,0 @@
|
||||
from flask import Blueprint, render_template
|
||||
|
||||
from data.document import Document
|
||||
|
||||
bp = Blueprint('web_admin', __name__, url_prefix='/admin')
|
||||
|
||||
@bp.route('/')
|
||||
def index():
|
||||
return render_template("index.html", documents=Document.list())
|
Loading…
Reference in New Issue
Block a user