mirror of
				https://gitlab.ub.uni-bielefeld.de/sfb1288inf/nopaque.git
				synced 2025-11-03 20:02:47 +00:00 
			
		
		
		
	Add macros and use them
This commit is contained in:
		@@ -1,9 +1,7 @@
 | 
			
		||||
from app import logger
 | 
			
		||||
from flask import (abort, current_app, flash, make_response, redirect, request,
 | 
			
		||||
                   render_template, url_for, send_from_directory)
 | 
			
		||||
from flask_login import current_user, login_required
 | 
			
		||||
from threading import Thread
 | 
			
		||||
from werkzeug.utils import secure_filename
 | 
			
		||||
from . import corpora
 | 
			
		||||
from .background_functions import (delete_corpus_, delete_corpus_file_,
 | 
			
		||||
                                   edit_corpus_file_)
 | 
			
		||||
@@ -129,10 +127,10 @@ def add_corpus_file(corpus_id):
 | 
			
		||||
        return make_response(
 | 
			
		||||
            {'redirect_url': url_for('corpora.corpus', corpus_id=corpus.id)},
 | 
			
		||||
            201)
 | 
			
		||||
        # return redirect(url_for('corpora.corpus', corpus_id=corpus_id))
 | 
			
		||||
    return render_template('corpora/add_corpus_file.html.j2',
 | 
			
		||||
                           corpus=corpus,
 | 
			
		||||
                           add_corpus_file_form=add_corpus_file_form,
 | 
			
		||||
                           corpus=corpus, title='Add corpus file')
 | 
			
		||||
                           title='Add corpus file')
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
@corpora.route('/<int:corpus_id>/files/<int:corpus_file_id>/delete')
 | 
			
		||||
@@ -170,25 +168,28 @@ def download_corpus_file(corpus_id, corpus_file_id):
 | 
			
		||||
               methods=['GET', 'POST'])
 | 
			
		||||
@login_required
 | 
			
		||||
def edit_corpus_file(corpus_id, corpus_file_id):
 | 
			
		||||
    corpus = Corpus.query.get_or_404(corpus_id)
 | 
			
		||||
    corpus_file = CorpusFile.query.get_or_404(corpus_file_id)
 | 
			
		||||
    if not corpus_file.corpus_id == corpus_id:
 | 
			
		||||
        abort(404)
 | 
			
		||||
    if not (corpus_file.corpus.creator == current_user
 | 
			
		||||
            or current_user.is_administrator()):
 | 
			
		||||
        abort(403)
 | 
			
		||||
    edit_corpus_file_form = EditCorpusFileForm()
 | 
			
		||||
    edit_corpus_file_form = EditCorpusFileForm(prefix='edit-corpus-file-form')
 | 
			
		||||
    if edit_corpus_file_form.validate_on_submit():
 | 
			
		||||
        ids = [field.id for field in edit_corpus_file_form if not
 | 
			
		||||
               (field.id == 'submit'
 | 
			
		||||
                or field.id == "csrf_token"
 | 
			
		||||
                or field.id == "file")]
 | 
			
		||||
        data = [field.data for field in edit_corpus_file_form if not
 | 
			
		||||
                (field.id == 'submit'
 | 
			
		||||
                 or field.id == "csrf_token"
 | 
			
		||||
                 or field.id == "file")]
 | 
			
		||||
        field_dict = dict(zip(ids, data))
 | 
			
		||||
        stmt = db.update(CorpusFile).where(CorpusFile.id==corpus_file_id).values(**field_dict)
 | 
			
		||||
        db.session.execute(stmt)
 | 
			
		||||
        corpus_file.address = edit_corpus_file_form.address.data
 | 
			
		||||
        corpus_file.author = edit_corpus_file_form.author.data
 | 
			
		||||
        corpus_file.booktitle = edit_corpus_file_form.booktitle.data
 | 
			
		||||
        corpus_file.chapter = edit_corpus_file_form.chapter.data
 | 
			
		||||
        corpus_file.editor = edit_corpus_file_form.editor.data
 | 
			
		||||
        corpus_file.institution = edit_corpus_file_form.institution.data
 | 
			
		||||
        corpus_file.journal = edit_corpus_file_form.journal.data
 | 
			
		||||
        corpus_file.pages = edit_corpus_file_form.pages.data
 | 
			
		||||
        corpus_file.publisher = edit_corpus_file_form.publisher.data
 | 
			
		||||
        corpus_file.publishing_year = \
 | 
			
		||||
            edit_corpus_file_form.publishing_year.data
 | 
			
		||||
        corpus_file.school = edit_corpus_file_form.school.data
 | 
			
		||||
        corpus_file.title = edit_corpus_file_form.title.data
 | 
			
		||||
        db.session.commit()
 | 
			
		||||
        thread = Thread(target=edit_corpus_file_,
 | 
			
		||||
                        args=(current_app._get_current_object(),
 | 
			
		||||
@@ -196,9 +197,23 @@ def edit_corpus_file(corpus_id, corpus_file_id):
 | 
			
		||||
        thread.start()
 | 
			
		||||
        flash('Corpus file edited!')
 | 
			
		||||
        return redirect(url_for('corpora.corpus', corpus_id=corpus_id))
 | 
			
		||||
    # If no form is submitted or valid, fill out fields with current values
 | 
			
		||||
    edit_corpus_file_form.address.data = corpus_file.address
 | 
			
		||||
    edit_corpus_file_form.author.data = corpus_file.author
 | 
			
		||||
    edit_corpus_file_form.booktitle.data = corpus_file.booktitle
 | 
			
		||||
    edit_corpus_file_form.chapter.data = corpus_file.chapter
 | 
			
		||||
    edit_corpus_file_form.editor.data = corpus_file.editor
 | 
			
		||||
    edit_corpus_file_form.institution.data = corpus_file.institution
 | 
			
		||||
    edit_corpus_file_form.journal.data = corpus_file.journal
 | 
			
		||||
    edit_corpus_file_form.pages.data = corpus_file.pages
 | 
			
		||||
    edit_corpus_file_form.publisher.data = corpus_file.publisher
 | 
			
		||||
    edit_corpus_file_form.publishing_year.data = corpus_file.publishing_year
 | 
			
		||||
    edit_corpus_file_form.school.data = corpus_file.school
 | 
			
		||||
    edit_corpus_file_form.title.data = corpus_file.title
 | 
			
		||||
    return render_template('corpora/edit_corpus_file.html.j2',
 | 
			
		||||
                           corpus_file=corpus_file, corpus=corpus,
 | 
			
		||||
                           edit_corpus_file_form=edit_corpus_file_form,
 | 
			
		||||
                           corpus_file=corpus_file, title='Edit corpus file')
 | 
			
		||||
                           title='Edit corpus file')
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
@corpora.route('/<int:corpus_id>/prepare')
 | 
			
		||||
@@ -207,7 +222,7 @@ def prepare_corpus(corpus_id):
 | 
			
		||||
    corpus = Corpus.query.get_or_404(corpus_id)
 | 
			
		||||
    if not (corpus.creator == current_user or current_user.is_administrator()):
 | 
			
		||||
        abort(403)
 | 
			
		||||
    if len(corpus.files.all()) > 0:
 | 
			
		||||
    if corpus.files.all():
 | 
			
		||||
        corpus.status = 'submitted'
 | 
			
		||||
        db.session.commit()
 | 
			
		||||
        flash('Corpus marked for preparation!')
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user