# -*- mode: python -*- # -*- coding: utf-8 -*- ############################################################################## # # Gestion scolarite IUT # # Copyright (c) 1999 - 2024 Emmanuel Viennet. All rights reserved. # # This program is free software; you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation; either version 2 of the License, or # (at your option) any later version. # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with this program; if not, write to the Free Software # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA # # Emmanuel Viennet emmanuel.viennet@viennet.net # ############################################################################## """Menu "custom" (défini par l'utilisateur) dans les semestres """ import flask from flask import g, url_for, render_template, request from flask_login import current_user from app.models.config import ScoDocSiteConfig, PersonalizedLink from app.models import FormSemestre import app.scodoc.sco_utils as scu import app.scodoc.notesdb as ndb from app.scodoc.TrivialFormulator import TrivialFormulator from app.scodoc import html_sco_header _custommenuEditor = ndb.EditableTable( "notes_formsemestre_custommenu", "custommenu_id", ("custommenu_id", "formsemestre_id", "title", "url", "idx"), sortkey="idx", ) notes_formsemestre_custommenu_create = _custommenuEditor.create notes_formsemestre_custommenu_list = _custommenuEditor.list notes_formsemestre_custommenu_edit = _custommenuEditor.edit def formsemestre_custommenu_get(formsemestre_id): "returns dict [ { 'title' : xxx, 'url' : xxx } ]" cnx = ndb.GetDBConnexion() vals = notes_formsemestre_custommenu_list(cnx, {"formsemestre_id": formsemestre_id}) return vals def build_context_dict(formsemestre_id: int) -> dict: """returns a dict with "current" ids, to pass to external links""" params = { "dept": g.scodoc_dept, "formsemestre_id": formsemestre_id, "user_name": current_user.user_name, } cas_id = getattr(current_user, "cas_id", None) if cas_id: params["cas_id"] = cas_id etudid = getattr(g, "current_etudid", None) if etudid is not None: params["etudid"] = etudid evaluation_id = getattr(g, "current_evaluation_id", None) if evaluation_id is not None: params["evaluation_id"] = evaluation_id moduleimpl_id = getattr(g, "current_moduleimpl_id", None) if moduleimpl_id is not None: params["moduleimpl_id"] = moduleimpl_id return params def formsemestre_custommenu_html(formsemestre_id): "HTML code for custom menu" menu = [] # Liens globaux (config. générale) params = build_context_dict(formsemestre_id) for link in ScoDocSiteConfig.get_perso_links(): if link.title: menu.append({"title": link.title, "url": link.get_url(params=params)}) # Liens propres à ce semestre menu += formsemestre_custommenu_get(formsemestre_id) menu.append( { "title": "Modifier ce menu...", "endpoint": "notes.formsemestre_custommenu_edit", "args": {"formsemestre_id": formsemestre_id}, } ) return menu def formsemestre_custommenu_edit(formsemestre_id): """Dialog to edit the custom menu""" formsemestre = FormSemestre.get_formsemestre(formsemestre_id) dest_url = url_for( "notes.formsemestre_status", scodoc_dept=g.scodoc_dept, formsemestre_id=formsemestre_id, ) H = [ """
Ce menu, spécifique à chaque semestre, peut être utilisé pour placer des liens vers vos applications préférées.
Les premiers liens du menus sont définis au niveau global (pour tous les départements) et peuvent être modifiés par l'administrateur via la page de configuration principale.
Procédez en plusieurs fois si vous voulez ajouter plusieurs items.
""", ] descr = [ ("formsemestre_id", {"input_type": "hidden"}), ( "sep", { "input_type": "separator", "template": "