# @name: practice.py # @creation_date: 2021-11-03 # @license: The MIT License # @author: Simon Bowie # @purpose: practice route for practice-related functions and pages # @acknowledgements: # https://www.digitalocean.com/community/tutorials/how-to-make-a-web-application-using-flask-in-python-3 from flask import Blueprint, render_template, request, flash, redirect, url_for from flask_login import login_required, current_user from .models import Resource from .resources import * from .relationships import * from . import db import os import re import markdown from sqlalchemy.sql import func from sqlalchemy import or_, not_ practice = Blueprint('practice', __name__) # route for displaying all practices in database @practice.route('/practices') def get_practices(): # GET PARAMETERS # get URL parameters for views and pages view = request.args.get('view') page = request.args.get('page', 1, type=int) # set resource type resource_type = 'practice' # get introductory paragraph Markdown with open('content/practices.md', 'r') as f: intro_text = f.read() intro_text = markdown.markdown(intro_text) # DATABASE QUERY practices_query = Resource.query.filter_by(type=resource_type) # temporarily removing incomplete practices from main list practices_query = practices_query.filter( not_(or_( Resource.id==52, Resource.id==55, Resource.id==58 ))) # finalise the query and add pagination practices = practices_query.order_by(Resource.name).paginate(page=page, per_page=25) # POST-FILTERING PROCESSING # if view is 'expanded' then append relationships if view != 'list': # append relationships to each book append_relationships_multiple_paginated(practices) return render_template('resources.html', resources=practices, type='practice', view=view, page=page, intro_text=intro_text) # route for displaying a single practice based on the ID in the database @practice.route('/practices/') def show_practice(practice_id): practice = get_full_resource(practice_id) practice_markdown = get_practice_markdown(practice.name) practice_markdown = re.sub('^', '
', practice_markdown) practice_markdown = re.sub('

\s

', '

', practice_markdown) practice_markdown = re.sub('$', '

', practice_markdown) return render_template('resource.html', resource=practice, practice_markdown=practice_markdown) # route for editing a single practice based on the ID in the database @practice.route('/practices//edit', methods=('GET', 'POST')) @login_required def edit_practice(practice_id): practice = get_resource(practice_id) resource_dropdown = Resource.query.order_by(Resource.name) existing_relationships = get_relationships(practice_id) if request.method == 'POST': if not request.form['name']: flash('Name is required!') else: practice = Resource.query.get(practice_id) practice.name = request.form['name'] practice.description = request.form['description'] practice.longDescription = request.form['longDescription'] practice.experimental = request.form['experimental'] practice.considerations = request.form['considerations'] practice.references = request.form['references'] db.session.commit() linked_resources = request.form.getlist('linked_tools') + request.form.getlist('linked_books') remove_linked_resources = request.form.getlist('remove_linked_resources') edit_relationships(practice_id, linked_resources, remove_linked_resources, existing_relationships) return redirect(url_for('practice.get_practices',_external=True,_scheme=os.environ.get('SSL_SCHEME'))) return render_template('edit.html', resource=practice, resource_dropdown=resource_dropdown, relationships=existing_relationships) # route for function to delete a single practice from the edit page @practice.route('/practices//delete', methods=('POST',)) @login_required def delete_practice(practice_id): delete_resource(practice_id) return redirect(url_for('practice.get_practices',_external=True,_scheme=os.environ.get('SSL_SCHEME')))