TurboGears - Messages Flash

TurboGears fournit un système de messagerie très pratique pour notifier des informations à l'utilisateur d'une manière non intrusive. La classe TGFlash du module tg prend en charge les messages clignotants stockés dans un cookie simple. Cette classe prend en charge la récupération des messages flash côté serveur et côté client via JavaScript.

le render()La méthode de la classe TGFlash, lorsqu'elle est utilisée à partir de Python lui-même, peut être appelée à partir du modèle pour rendre un message flash. S'il est utilisé sur JavaScript, il fournit un objet WebFlash. Il exposepayload() et render() méthodes pour récupérer le message flash actuel et le rendre à partir de JavaScript.

Lorsqu'un projet TurboGears est créé à l'aide de 'quickstart', il dispose d'un modèle Master.html. Il contient la définition d'une variable de cet objet flash. Le contenu de ce message flash reçu du contrôleur remplace l'espace réservé marqué dans ce modèle.

<py:with vars = "flash = tg.flash_obj.render('flash', use_js = False)">
   <div py:if = "flash" py:replace = "Markup(flash)" />
</py:with>

le tg.flash_obj est l'objet WebFlash, qui est disponible dans tout modèle rendu en incluant master.htmlmodèle. Cet objet permet de récupérer le message flash actuel et de l'afficher.

Les messages Flash sont stockés dans un cookie (dont le nom par défaut est webflash) en utilisant tg.flash()méthode. Le message et les paramètres d'état lui sont ensuite transmis.

tg.flash('Message', 'status')

Si la méthode appelée flash effectue une redirection, le flash sera visible à l'intérieur de la page redirigée. Si la méthode expose directement un modèle, le flash sera visible à l'intérieur du modèle lui-même.

L'apparence du message flash peut être personnalisée en appliquant un style CSS au code d'état. Un projet «quickstarted» contient des codes d'erreur, d'avertissement, d'informations et d'état ok personnalisés par une feuille de style public / css / style.css. D'autres codes d'état avec des styles peuvent également être ajoutés.

#flash > .warning {
   color: #c09853;
   background-color: #fcf8e3;
   border-color: #fbeed5;
}

#flash > .ok {
   color: #468847;
   background-color: #dff0d8;
   border-color: #d6e9c6;
}

#flash > .error {
   color: #b94a48;
   background-color: #f2dede;
   border-color: #eed3d7;
}

#flash > .info {
   color: #3a87ad;
   background-color: #d9edf7;
   border-color: #bce8f1;
}

Cette feuille de style externe doit être incluse dans le modèle -

<link rel = "stylesheet" type = "text/css" media = "screen" 
   href = "${tg.url('/css/style.css')}" />

La configuration de n'importe quel support de message Flash peut être réalisée en définissant les paramètres de la méthode configure () de l'objet TGFlash ou dans app_cfg.py (dans le dossier config). Les paramètres configurables sont -

N ° Sr. Paramètres et description
1

flash.cookie_name

Nom du cookie utilisé pour stocker les messages flash. La valeur par défaut estwebflash.

2

flash.default_status

État du message par défaut s'il n'est pas spécifié (ok par défaut)

3

flash.template

Utilisé comme flash template lors du rendu.

4

flash.allow_html

Se tourne on/off escaping in flash messages, par défaut, le HTML n'est pas autorisé.

5

flash.js_call

Code JavaScript qui sera exécuté lors de l'affichage du flash à partir de JavaScript. La valeur par défaut estwebflash.render()

6

flash.js_template

string.Template instance utilisée pour remplacer la prise en charge complète de JavaScript pour les messages flash.

  • pop_payload() - fonction fetches current flash message, statuset informations connexes. Obtenir le message flash supprimera le cookie.

  • render(container_id, use_js=True) - Rendre le message flash à l'intérieur du modèle ou fournir un support Javascript pour eux.

  • container_id est le DIV où les messages seront affichés, tandis que use_js bascule entre le rendu du flash au format HTML ou pour l'utilisation de JavaScript.

  • status - Obtenez uniquement l'état actuel du flash, obtenir l'état du flash supprimera le cookie.

  • message - Obtenez uniquement le message flash actuel, obtenir le message flash supprimera le cookie.

Comment faire un simple message flash?

Dans l'exemple suivant, une méthode flash () est fournie dans la classe de contrôleur racine. Il appelle un message flash () qui est rendu sur le modèle exposé, flash.html

from hello.lib.base import BaseController
from tg import expose, flash, redirect, request

class RootController(BaseController):
   @expose('hello.templates.flash')
   def flash(self, user = None):
      
      if user:
         flash(message = "Welcome "+user,status = "ok")
      else:
         flash(message = "Welcome Guest",status = "info")
      return {}

Le code pour faire flash.html dans le dossier des modèles est comme suit

<html xmlns = "http://www.w3.org/1999/xhtml"
   xmlns:py = "http://genshi.edgewall.org/"
   xmlns:xi = "http://www.w3.org/2001/XInclude">

   <head>
      <title>TurboGears 2.3: Flash messages>/title>
      <link rel = "stylesheet" type = "text/css" media = "screen"
         href = "${tg.url('/css/style.css')}" />
			
      <py:with vars = "flash = tg.flash_obj.render('flash', use_js = False)">
         <div py:if = "flash" py:replace = "Markup(flash)" />
      </py:with>
		
   </head>

   <body>
      <h2>Hello TurboGears</h2>
   </body>
	
</html>

Démarrez le serveur et entrez http://localhost:8080/flash?user=MVL dans le navigateur

Remplacez l'URL par http://localhost:8080/flash et voir le message flash mis en forme différemment selon la définition dans style.css