forked from ScoDoc/DocScoDoc
fix decorator for GET forms
This commit is contained in:
parent
0ec41c48f3
commit
6847bb8fd5
@ -62,7 +62,14 @@ class ZRequest(object):
|
||||
if k.endswith(":list"):
|
||||
self.form[k[:-5]] = request.form.getlist(k)
|
||||
elif request.method == "GET":
|
||||
self.form = {k: v for (k, v) in request.args.items()}
|
||||
self.form = {}
|
||||
for k in request.args:
|
||||
current_app.logger.debug("%s\t%s" % (k, request.args.getlist(k)))
|
||||
if k.endswith(":list"):
|
||||
self.form[k[:-5]] = request.args.getlist(k)
|
||||
else:
|
||||
self.form[k] = request.args[k]
|
||||
current_app.logger.info("ZRequest.form=%s" % str(self.form))
|
||||
self.RESPONSE = ZResponse()
|
||||
|
||||
def __str__(self):
|
||||
|
@ -45,7 +45,7 @@ except ImportError:
|
||||
import flask
|
||||
from flask import request, render_template, redirect
|
||||
from flask_login import login_required
|
||||
|
||||
import werkzeug
|
||||
|
||||
from app.main import bp
|
||||
from app.decorators import scodoc7func, admin_required
|
||||
@ -65,7 +65,11 @@ context = None # temporaire pour #sco8
|
||||
@bp.route("/index")
|
||||
def index():
|
||||
return render_template(
|
||||
"main/index.html", title=u"Essai Flask", current_app=flask.current_app
|
||||
"main/index.html",
|
||||
title=u"Essai Flask",
|
||||
current_app=flask.current_app,
|
||||
flask=flask,
|
||||
werzeug=werkzeug,
|
||||
)
|
||||
|
||||
|
||||
|
@ -455,7 +455,9 @@ def _notes_add(context, uid, evaluation_id, notes, comment=None, do_it=True):
|
||||
Return number of changed notes
|
||||
"""
|
||||
uid = str(uid)
|
||||
now = psycopg2.Timestamp(*time.localtime()[:6]) # datetime.datetime.now().isoformat()
|
||||
now = psycopg2.Timestamp(
|
||||
*time.localtime()[:6]
|
||||
) # datetime.datetime.now().isoformat()
|
||||
# Verifie inscription et valeur note
|
||||
_ = {}.fromkeys(
|
||||
sco_groups.do_evaluation_listeetuds_groups(
|
||||
@ -1194,6 +1196,7 @@ def _form_saisie_notes(context, E, M, group_ids, destination="", REQUEST=None):
|
||||
initvalues=initvalues,
|
||||
submitlabel="Terminer",
|
||||
formid="formnotes",
|
||||
method="GET",
|
||||
)
|
||||
H.append(tf.getform()) # check and init
|
||||
if tf.canceled():
|
||||
|
@ -537,10 +537,6 @@ def sendPDFFile(REQUEST, data, filename):
|
||||
|
||||
class ScoDocJSONEncoder(json.JSONEncoder):
|
||||
def default(self, o): # pylint: disable=E0202
|
||||
# ScoDoc 7.22 n'utilise plus mx:
|
||||
if str(type(o)) == "<type 'mx.DateTime.DateTime'>":
|
||||
log("Warning: mx.DateTime object detected !")
|
||||
return o.strftime("%Y-%m-%dT%H:%M:%S")
|
||||
if isinstance(o, (datetime.date, datetime.datetime)):
|
||||
return o.isoformat()
|
||||
elif isinstance(o, ApoEtapeVDI):
|
||||
@ -550,7 +546,7 @@ class ScoDocJSONEncoder(json.JSONEncoder):
|
||||
|
||||
|
||||
def sendJSON(REQUEST, data):
|
||||
js = json.dumps(data, encoding=SCO_ENCODING, indent=1, cls=ScoDocJSONEncoder)
|
||||
js = json.dumps(data, indent=1, cls=ScoDocJSONEncoder)
|
||||
if REQUEST:
|
||||
REQUEST.RESPONSE.setHeader("content-type", JSON_MIMETYPE)
|
||||
return js
|
||||
|
25
app/templates/essais/testcheckbox.html
Normal file
25
app/templates/essais/testcheckbox.html
Normal file
@ -0,0 +1,25 @@
|
||||
{% extends 'base.html' %}
|
||||
|
||||
{% block app_content %}
|
||||
|
||||
<h1>Essai checkbox</h1>
|
||||
|
||||
<p>
|
||||
<tt>request.args={{ request.args }}</tt>
|
||||
</p>
|
||||
<form method="get">
|
||||
<fieldset>
|
||||
<legend>Choose your interests</legend>
|
||||
<div>
|
||||
<input type="checkbox" id="coding" name="interest" value="coding">
|
||||
<label for="coding">Coding</label>
|
||||
</div>
|
||||
<div>
|
||||
<input type="checkbox" id="music" name="interest" value="music">
|
||||
<label for="music">Music</label>
|
||||
</div>
|
||||
</fieldset>
|
||||
<input type="submit" name="OK" />
|
||||
</form>
|
||||
|
||||
{% endblock %}
|
@ -12,6 +12,10 @@
|
||||
|
||||
<h2>Essais divers</h2>
|
||||
|
||||
<p>
|
||||
<tt>flask v{{ flask.__version__ }}</tt><br />
|
||||
<tt>werzeug v{{ werzeug.__version__ }}</tt>
|
||||
</p>
|
||||
<h3>Avec login requis</h3>
|
||||
<ul>
|
||||
<li><a href="{{ url_for('main.test_vue') }}"><tt>test_vue</tt>, login requis</a></li>
|
||||
|
@ -5,8 +5,12 @@ Module Essais: divers essais pour la migration vers Flask
|
||||
Emmanuel Viennet, 2021
|
||||
"""
|
||||
|
||||
import flask
|
||||
|
||||
from flask import g
|
||||
from flask import current_app
|
||||
from flask import render_template
|
||||
from flask import request
|
||||
|
||||
from app.decorators import (
|
||||
scodoc7func,
|
||||
@ -79,9 +83,13 @@ def sco_test_view(REQUEST=None):
|
||||
return """Vous avez vu sco_test_view !"""
|
||||
|
||||
|
||||
import flask
|
||||
|
||||
|
||||
@bp.route("/essrep")
|
||||
def essrep():
|
||||
return flask.Response(status=200, response="Bonjour pépé %s" + u"papa")
|
||||
|
||||
|
||||
# Tests formulaires avec checkbox et GET
|
||||
@bp.route("/testcheckbox", methods=["GET"])
|
||||
def testcheckbox():
|
||||
# args = request.args
|
||||
return render_template("essais/testcheckbox.html")
|
||||
|
Loading…
x
Reference in New Issue
Block a user