You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

75 lines
3.3KB

  1. # @name: practice.py
  2. # @creation_date: 2021-11-03
  3. # @license: The MIT License <https://opensource.org/licenses/MIT>
  4. # @author: Simon Bowie <ad7588@coventry.ac.uk>
  5. # @purpose: practice route for practice-related functions and pages
  6. # @acknowledgements:
  7. # https://www.digitalocean.com/community/tutorials/how-to-make-a-web-application-using-flask-in-python-3
  8. from flask import Blueprint, render_template, request, flash, redirect, url_for
  9. from flask_login import login_required, current_user
  10. from .models import Resource
  11. from .resources import *
  12. from .relationships import *
  13. from . import db
  14. import os
  15. practice = Blueprint('practice', __name__)
  16. # route for displaying all practices in database
  17. @practice.route('/practices')
  18. def get_practices():
  19. view = request.args.get('view')
  20. practices = Resource.query.filter_by(type='practice').all()
  21. # reorder practices by practice name
  22. practices = sorted(practices, key=lambda d: d.__dict__['name'])
  23. # get number of practices
  24. count = len(practices)
  25. if view != 'list':
  26. # append relationships to each practice
  27. append_relationships_multiple(practices)
  28. return render_template('resources.html', resources=practices, type='practice', count=count, view=view)
  29. # route for displaying a single practice based on the ID in the database
  30. @practice.route('/practices/<int:practice_id>')
  31. def show_practice(practice_id):
  32. practice = get_full_resource(practice_id)
  33. practice.references = replace_urls(practice.references)
  34. return render_template('resource.html', resource=practice)
  35. # route for editing a single practice based on the ID in the database
  36. @practice.route('/practices/<int:practice_id>/edit', methods=('GET', 'POST'))
  37. @login_required
  38. def edit_practice(practice_id):
  39. practice = get_resource(practice_id)
  40. resource_dropdown = Resource.query
  41. existing_relationships = get_relationships(practice_id)
  42. if request.method == 'POST':
  43. if not request.form['name']:
  44. flash('Name is required!')
  45. else:
  46. practice = Resource.query.get(practice_id)
  47. practice.name = request.form['name']
  48. practice.description = request.form['description']
  49. practice.longDescription = request.form['longDescription']
  50. practice.experimental = request.form['experimental']
  51. practice.considerations = request.form['considerations']
  52. practice.references = request.form['references']
  53. db.session.commit()
  54. linked_resources = request.form.getlist('linked_resources')
  55. remove_linked_resources = request.form.getlist('remove_linked_resources')
  56. edit_relationships(practice_id, linked_resources, remove_linked_resources, existing_relationships)
  57. return redirect(url_for('practice.get_practices',_external=True,_scheme=os.environ.get('SSL_SCHEME')))
  58. return render_template('edit.html', resource=practice, resource_dropdown=resource_dropdown, relationships=existing_relationships)
  59. # route for function to delete a single practice from the edit page
  60. @practice.route('/practices/<int:practice_id>/delete', methods=('POST',))
  61. @login_required
  62. def delete_practice(practice_id):
  63. delete_resource(practice_id)
  64. return redirect(url_for('practice.get_practices',_external=True,_scheme=os.environ.get('SSL_SCHEME')))