def deleteSchool(cityid, schoolid): # Удаление текущей записи в БД if session['demo']: pass else: # Ограничение по внешнему ключу FK_Team_School # не позволяет удалить спортивную школу при наличии связанных с ней команд try: School.get(city_ID = cityid, school_ID = schoolid).delete_instance() except IntegrityError: flash('Вы не можете удалить эту спортивную школу, пока в неё добавлена хотя бы одна команда', 'danger') # Редирект на вид list return redirect( url_for('listSchool', cityid = cityid))
def listTeam(cityid, schoolid): # Список городов и их дочерних школ, название текущего города и школы listCity = City.select().order_by(City.cityName) listSchool = School.select().join(City).where(City.city_ID == cityid).order_by(School.schoolName) try: cityname = City.get(city_ID = cityid).cityName schoolname = School.get(school_ID = schoolid).schoolName except DoesNotExist: cityname = None schoolname = None # Список команд в выбранной школе listTeam = Team.select().join(School).where(School.school_ID == schoolid).join(City).where(City.city_ID == cityid).switch(Team).join(Age).order_by(Team.teamName) for lt in listTeam: lt.age_ID.ageName = int(date.today().year) - int(lt.age_ID.ageName) # Список возрастов по состоянию на текущий год listAge = Age.select().order_by(Age.ageName) for age in listAge: age.ageName = int(date.today().year) - int(age.ageName) # Переменные для автозаполнения модальной формы добавления/обновления данных в JS-скрипте шаблона ## Список полей modifyFields = ['teamName', 'filterAge', 'ageName'] ## Список групп радиокнопок modifyRadios = ['filterAge'] ## Заголовки модального окна createHeader = ['"Создать новую юношескую команду"'] updateHeader = ['"Изменить "', 'teamName', '" (возраст "', 'ageName', '")"'] ## Действия формы createAction = ['"/city/"', cityid, '"/school/"', schoolid, '"/team/create"'] updateAction = ['"/city/"', cityid, '"/school/"', schoolid, '"/team/"', 'PK_ID', '"/update"'] deleteAction = ['"/city/"', cityid, '"/school/"', schoolid, '"/team/"', 'PK_ID', '"/delete"'] # Вывод шаблона return render_template( 'Team.jinja.html', listCity = listCity, cityid = cityid, cityname = cityname, listSchool = listSchool, schoolid = schoolid, schoolname = schoolname, listTeam = listTeam, listAge = listAge, modifyFields = modifyFields, modifyRadios = modifyRadios, createHeader = createHeader, updateHeader = updateHeader, createAction = createAction, updateAction = updateAction, deleteAction = deleteAction)