Allow multiple file upload and add title

This commit is contained in:
Patrick Jentsch 2019-08-01 12:16:31 +02:00
parent 716ebdfa7c
commit 3964fe5444
3 changed files with 56 additions and 50 deletions

View File

@ -1,25 +1,17 @@
from flask_wtf import FlaskForm from flask_wtf import FlaskForm
from flask_wtf.file import FileAllowed, FileRequired from wtforms import MultipleFileField, SelectField, StringField, SubmitField
from wtforms import FileField, SelectField, StringField, SubmitField
from wtforms.validators import DataRequired, Length from wtforms.validators import DataRequired, Length
class OCRJobForm(FlaskForm): class CreateOCRJobForm(FlaskForm):
description = StringField( description = StringField(
'Description', 'Description',
validators=[DataRequired(), Length(1, 64)] validators=[DataRequired(), Length(1, 64)]
) )
file = FileField( files = MultipleFileField('Files', validators=[DataRequired()])
'File',
validators=[
FileAllowed(['pdf', 'tif', 'tiff']),
FileRequired()
]
)
language = SelectField( language = SelectField(
'Language', 'Language',
choices=[ choices=[('', 'Choose your option'),
('', 'Choose your option'),
('eng', 'English'), ('eng', 'English'),
('enm', 'English, Middle (1100-1500)'), ('enm', 'English, Middle (1100-1500)'),
('fra', 'French'), ('fra', 'French'),
@ -32,4 +24,8 @@ class OCRJobForm(FlaskForm):
], ],
validators=[DataRequired()] validators=[DataRequired()]
) )
submit = SubmitField('Submit') submit = SubmitField('Create OCR job')
title = StringField(
'Title',
validators=[DataRequired(), Length(1, 32)]
)

View File

@ -2,7 +2,7 @@ from datetime import datetime
from flask import current_app, flash, redirect, render_template, url_for from flask import current_app, flash, redirect, render_template, url_for
from . import services from . import services
from flask_login import current_user, login_required from flask_login import current_user, login_required
from .forms import OCRJobForm from .forms import CreateOCRJobForm
from ..import swarm from ..import swarm
from threading import Thread from threading import Thread
import hashlib import hashlib
@ -12,8 +12,8 @@ import os
@services.route('/ocr', methods=['GET', 'POST']) @services.route('/ocr', methods=['GET', 'POST'])
@login_required @login_required
def ocr(): def ocr():
ocr_job_form = OCRJobForm() create_ocr_job_form = CreateOCRJobForm()
if ocr_job_form.validate_on_submit(): if create_ocr_job_form.validate_on_submit():
app = current_app._get_current_object() app = current_app._get_current_object()
id = hashlib.md5( id = hashlib.md5(
(current_user.username + '_' + datetime.now().isoformat()).encode() (current_user.username + '_' + datetime.now().isoformat()).encode()
@ -27,7 +27,7 @@ def ocr():
'requested_cpus': 2, 'requested_cpus': 2,
'requested_memory': 2048, 'requested_memory': 2048,
'service': 'ocr', 'service': 'ocr',
'service_args': {'lang': ocr_job_form.language.data, 'service_args': {'lang': create_ocr_job_form.language.data,
'version': 'latest' 'version': 'latest'
}, },
'status': 'queued' 'status': 'queued'
@ -39,7 +39,7 @@ def ocr():
except OSError: except OSError:
flash('OSError!') flash('OSError!')
else: else:
file = ocr_job_form.file.data for file in create_ocr_job_form.files.data:
file.save(os.path.join(dir, file.filename)) file.save(os.path.join(dir, file.filename))
''' '''
' TODO: Let the scheduler run this job in the background. ' TODO: Let the scheduler run this job in the background.
@ -55,5 +55,5 @@ def ocr():
return render_template( return render_template(
'services/ocr.html.j2', 'services/ocr.html.j2',
title='Optical Character Recognition', title='Optical Character Recognition',
ocr_job_form=ocr_job_form create_ocr_job_form=create_ocr_job_form
) )

View File

@ -79,44 +79,54 @@
<div class="card"> <div class="card">
<div class="card-content"> <div class="card-content">
<form method="POST" enctype="multipart/form-data"> <form method="POST" enctype="multipart/form-data">
{{ ocr_job_form.hidden_tag() }} {{ create_ocr_job_form.hidden_tag() }}
<div class="row"> <div class="row">
<div class="col s8"> <div class="col s12 m4">
<div class="input-field">
<i class="material-icons prefix">title</i>
{{ create_ocr_job_form.title() }}
{{ create_ocr_job_form.title.label }}
{% for error in create_ocr_job_form.title.errors %}
<span class="helper-text red-text">{{ error }}</span>
{% endfor %}
</div>
</div>
<div class="col s12 m8">
<div class="input-field"> <div class="input-field">
<i class="material-icons prefix">description</i> <i class="material-icons prefix">description</i>
{{ ocr_job_form.description(placeholder='Job description') }} {{ create_ocr_job_form.description() }}
{{ ocr_job_form.description.label }} {{ create_ocr_job_form.description.label }}
{% for error in ocr_job_form.description.errors %} {% for error in create_ocr_job_form.description.errors %}
<span class="helper-text red-text">{{ error }}</span> <span class="helper-text red-text">{{ error }}</span>
{% endfor %} {% endfor %}
</div> </div>
</div> </div>
<div class="col s4"> <div class="col s12 m8">
<div class="input-field">
<i class="material-icons prefix">language</i>
{{ ocr_job_form.language() }}
{{ ocr_job_form.language.label }}
{% for error in ocr_job_form.language.errors %}
<span class="helper-text red-text">{{ error }}</span>
{% endfor %}
</div>
</div>
<div class="col s8">
<div class="file-field input-field"> <div class="file-field input-field">
<div class="btn"> <div class="btn">
<span>{{ ocr_job_form.file.label.text }}</span> <span>{{ create_ocr_job_form.files.label.text }}</span>
{{ ocr_job_form.file() }} {{ create_ocr_job_form.files(accept='application/pdf, image/tiff') }}
</div> </div>
<div class="file-path-wrapper"> <div class="file-path-wrapper">
<input class="file-path validate" type="text"> <input class="file-path validate" type="text">
</div> </div>
{% for error in ocr_job_form.file.errors %} {% for error in create_ocr_job_form.files.errors %}
<span class="helper-text red-text">{{ error }}</span>
{% endfor %}
</div>
</div>
<div class="col s12 m4">
<div class="input-field">
<i class="material-icons prefix">language</i>
{{ create_ocr_job_form.language() }}
{{ create_ocr_job_form.language.label }}
{% for error in create_ocr_job_form.language.errors %}
<span class="helper-text red-text">{{ error }}</span> <span class="helper-text red-text">{{ error }}</span>
{% endfor %} {% endfor %}
</div> </div>
</div> </div>
</div> </div>
{{ ocr_job_form.submit(class='btn') }} {{ create_ocr_job_form.submit(class='btn') }}
</form> </form>
</div> </div>
</div> </div>