mirror of
https://gitlab.ub.uni-bielefeld.de/sfb1288inf/nopaque.git
synced 2025-01-18 22:00:35 +00:00
Rework job page input file view
This commit is contained in:
parent
6e26e38326
commit
7e34892147
27
web/app/jobs/tables.py
Normal file
27
web/app/jobs/tables.py
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
from flask_table import Table, Col, LinkCol
|
||||||
|
|
||||||
|
|
||||||
|
class JobInputTable(Table):
|
||||||
|
"""
|
||||||
|
Declares the table describing colum by column.
|
||||||
|
"""
|
||||||
|
classes = ['highlight', 'responsive-table']
|
||||||
|
filename = Col('Filename', column_html_attrs={'class': 'filename'},
|
||||||
|
th_html_attrs={'class': 'sort',
|
||||||
|
'data-sort': 'filename'})
|
||||||
|
url = LinkCol('Download', 'jobs.download_job_input',
|
||||||
|
url_kwargs=dict(job_id='job.id',
|
||||||
|
job_input_id='input_id'),
|
||||||
|
anchor_attrs={'class': 'waves-effect waves-light btn-small',
|
||||||
|
'download': ''})
|
||||||
|
|
||||||
|
|
||||||
|
class JobInputItem(object):
|
||||||
|
"""
|
||||||
|
Describes one item like one row per table.
|
||||||
|
"""
|
||||||
|
|
||||||
|
def __init__(self, filename, job, input_id):
|
||||||
|
self.filename = filename
|
||||||
|
self.job = job
|
||||||
|
self.input_id = input_id
|
@ -3,6 +3,7 @@ from flask import (abort, current_app, flash, redirect, render_template,
|
|||||||
from flask_login import current_user, login_required
|
from flask_login import current_user, login_required
|
||||||
from . import jobs
|
from . import jobs
|
||||||
from . import tasks
|
from . import tasks
|
||||||
|
from . tables import JobInputItem, JobInputTable
|
||||||
from ..models import Job, JobInput, JobResult
|
from ..models import Job, JobInput, JobResult
|
||||||
import os
|
import os
|
||||||
|
|
||||||
@ -13,7 +14,16 @@ def job(job_id):
|
|||||||
job = Job.query.get_or_404(job_id)
|
job = Job.query.get_or_404(job_id)
|
||||||
if not (job.creator == current_user or current_user.is_administrator()):
|
if not (job.creator == current_user or current_user.is_administrator()):
|
||||||
abort(403)
|
abort(403)
|
||||||
return render_template('jobs/job.html.j2', job=job, title='Job')
|
items = [JobInputItem(input.filename, job, input.id)
|
||||||
|
for input in job.inputs]
|
||||||
|
# Convert table object to html string
|
||||||
|
job_input_table = JobInputTable(items).__html__()
|
||||||
|
# Add class "list" to tbody element. Needed for "List.js"
|
||||||
|
job_input_table = job_input_table.replace('tbody', 'tbody class="list"', 1)
|
||||||
|
return render_template('jobs/job.html.j2',
|
||||||
|
job=job,
|
||||||
|
job_input_table=job_input_table,
|
||||||
|
title='Job')
|
||||||
|
|
||||||
|
|
||||||
@jobs.route('/<int:job_id>/delete')
|
@jobs.route('/<int:job_id>/delete')
|
||||||
|
@ -21,9 +21,19 @@
|
|||||||
|
|
||||||
<script>
|
<script>
|
||||||
var options = {page: 10,
|
var options = {page: 10,
|
||||||
pagination: [{name: "paginationTop",
|
pagination: [
|
||||||
paginationClass: "paginationTop",},
|
{
|
||||||
{paginationClass: "paginationBottom"}],
|
name: "paginationTop",
|
||||||
|
paginationClass: "paginationTop",
|
||||||
|
innerWindow: 8,
|
||||||
|
outerWindow: 1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
paginationClass: "paginationBottom",
|
||||||
|
innerWindow: 8,
|
||||||
|
outerWindow: 1
|
||||||
|
}
|
||||||
|
],
|
||||||
valueNames: ['username', 'email', 'role', 'confirmed', 'id']};
|
valueNames: ['username', 'email', 'role', 'confirmed', 'id']};
|
||||||
var userList = new List('users', options);
|
var userList = new List('users', options);
|
||||||
</script>
|
</script>
|
||||||
|
@ -79,7 +79,7 @@
|
|||||||
|
|
||||||
<div class="col s12">
|
<div class="col s12">
|
||||||
<div class="card">
|
<div class="card">
|
||||||
<div class="card-content">
|
<div class="card-content" id="inputs">
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col s12 m2">
|
<div class="col s12 m2">
|
||||||
<span class="card-title"><i class="left material-icons" style="font-size: inherit;">input</i>Inputs</span>
|
<span class="card-title"><i class="left material-icons" style="font-size: inherit;">input</i>Inputs</span>
|
||||||
@ -87,13 +87,9 @@
|
|||||||
</div>
|
</div>
|
||||||
<div class="col s12 m10">
|
<div class="col s12 m10">
|
||||||
<div class="inputs row">
|
<div class="inputs row">
|
||||||
{% for input in job.inputs %}
|
<ul class="pagination paginationTop"></ul>
|
||||||
<div class="col s12 m6">
|
{{ job_input_table }}
|
||||||
<a class="btn waves-effect waves-light" download href="{{ url_for('jobs.download_job_input', job_id=job.id, job_input_id=input.id) }}">
|
<ul class="pagination paginationBottom"></ul>
|
||||||
<i class="material-icons left">file_download</i>{{ input.filename }}
|
|
||||||
</a>
|
|
||||||
</div>
|
|
||||||
{% endfor %}
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@ -137,6 +133,25 @@
|
|||||||
|
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
|
// job_input_table code
|
||||||
|
var options = {page: 5,
|
||||||
|
pagination: [
|
||||||
|
{
|
||||||
|
name: "paginationTop",
|
||||||
|
paginationClass: "paginationTop",
|
||||||
|
innerWindow: 8,
|
||||||
|
outerWindow: 1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
paginationClass: "paginationBottom",
|
||||||
|
innerWindow: 8,
|
||||||
|
outerWindow: 1
|
||||||
|
}
|
||||||
|
],
|
||||||
|
valueNames: ['filename']};
|
||||||
|
var jobInputList = new List('inputs', options);
|
||||||
|
|
||||||
|
|
||||||
class InformationUpdater {
|
class InformationUpdater {
|
||||||
constructor(jobId, foreignJobFlag) {
|
constructor(jobId, foreignJobFlag) {
|
||||||
this.jobId = jobId;
|
this.jobId = jobId;
|
||||||
@ -209,6 +224,8 @@
|
|||||||
resultType = "VRT";
|
resultType = "VRT";
|
||||||
} else if (result.filename.endsWith(".xml.zip")) {
|
} else if (result.filename.endsWith(".xml.zip")) {
|
||||||
resultType = "XML";
|
resultType = "XML";
|
||||||
|
} else if (result.filename.endsWith(".poco.zip")) {
|
||||||
|
resultType = "POCO";
|
||||||
} else {
|
} else {
|
||||||
resultType = "ALL";
|
resultType = "ALL";
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user