Page d'accueil + bouton feedback

This commit is contained in:
champeno 2015-09-22 19:31:26 +02:00
parent ea619696dd
commit 3d437624ca
6 changed files with 169 additions and 6 deletions

View file

@ -4,7 +4,7 @@
text-align:center;
}
.entrer a {
.entrer a, a.btn {
display:inline-block;
background:#FFA41E;
color:#fff;
@ -13,6 +13,16 @@
border-radius:5px;
}
a.btn {
display:inline-block;
background:#FFA41E;
color:#fff;
font-size:1.2em;
padding:10px;
margin-top:12px;
border-radius:5px;
}
.explications {
background:#348d68;
display:table-row;
@ -29,3 +39,24 @@
font-size:1.1em;
text-align:center;
}
.homeh1 p {
float:right;
}
.homeh1 h1 {
display:inline-block;
margin-bottom:3px;
}
.homeh1 {
border-bottom:1px solid #888;
overflow:hidden;
margin-bottom:15px;
}
.betacadre {
background:#bbb;
padding:20px;
margin:20px 0;
}

View file

@ -72,6 +72,14 @@ header .username {
font-weight:normal;
}
.footer {
clear:both;
font-size:14px;
color:#555;
text-align:right;
margin-top:25px;
}
#content {
width:80%;
max-width:700px;
@ -112,6 +120,10 @@ form textarea, form input, form select {
float:right;
}
form textarea {
resize:vertical;
}
form textarea {
width:90%;
}
@ -257,3 +269,69 @@ ul.bigger li:hover{
.changestage {
color:#B8741A;
}
/* feedback */
#feedback_bg {
display:none;
position:fixed;
width:100%;
height:100%;
background:rgba(0,0,0,0.6);
z-index:300;
top:0;
left:0;
}
#feedback_centrer {
display:table-cell;
vertical-align:middle;
text-align:center;
overflow-y:auto;
}
#feedback_close {
float:right;
}
#feedback_win {
text-align:left;
display:inline-block;
padding:0;
max-width:500px;
background:#fff;
}
#feedback_win h2 {
background:#000;
color:#fff;
padding:20px;
margin-top:0;
}
#feedback_win textarea {
min-height:150px;
}
#feedback_btn {
position:fixed;
top:65%;
left:0;
z-index:40;
background:#000;
color:#fff;
padding:20px;
transform:rotate(-90deg);
font-weight:bold;
transform-origin:top left;
}
.success {
background:#9f9;
padding:5px;
}
.failure {
padding:5px;
background:#f99;
}

View file

@ -6,19 +6,29 @@
{% endblock %}
{% block content %}
<h1>ExperiENS<span class="beta">beta</span></h1>
<p>Partagez vos expériences de stages !</p>
<div class="homeh1">
<h1>ExperiENS<span class="beta">beta</span></h1>
<p>Partagez vos expériences de stages !</p>
</div>
<div class="betacadre">
Ce site est en cours de développement, et fait l'objet de mises à jours régulières. N'hésitez pas cependant à remplir une fiche pour vos stages, utiliser la recherche, et donner votre avis en utilisant le bouton "feedback".
</div>
{% if not user.username %}
<div class="entrer">
<p><a href="{% url 'monstage:home' %}">Partagez VOTRE expérience</a></p>
<p><a href="{% url 'login' %}">Connexion</a></p>
<p class="helptext">Connexion via le serveur central d'authentification ENS (identifiants clipper)</p>
</div>
{% endif %}
<div class="explications">
<p>Ne partez plus en stage en terre inconnue : nourrissez-vous de l'expérience de {{ stats.num_stages }} stages effectués par la communauté normalienne, repérez les bons plans, et ne faites pas les mêmes erreurs&nbsp;!</p>
<p>Ne partez plus en stage en terre inconnue : nourrissez-vous de l'expérience de {{ stats.num_stages }} stages effectués par la communauté normalienne, repérez les bons plans, et ne faites pas les mêmes erreurs&nbsp;!
{% if user.username %}<br /><a href="{% url 'monstage:search' %}" class="btn">Rechercher des stages</a>{% endif %}</p>
<img src="{% static 'home2.jpg' %}" width="350"/>
</div>
<div class="explications">
<img src="{% static 'home1.jpg' %}" width="350"/>
<p>Vous revenez du bout du monde (ou de la rue d'à côté)&nbsp;? N'attendez plus, rédigez un avis sur votre stage pour que votre expérience profite à d'autres&nbsp;!</p>
<p>Vous revenez du bout du monde (ou de la rue d'à côté)&nbsp;? N'attendez plus, rédigez un avis sur votre stage pour que votre expérience profite à d'autres&nbsp;!
{% if user.username %}<br /><a href="{% url 'monstage:home' %}" class="btn">Partager ses stages</a>{% endif %}</p>
</div>
<div class="footer">Propulsé par Django, <a href="http://evarin.fr" target="_blank">Evarin</a> et Damien</div>
{% endblock %}

View file

@ -5,6 +5,7 @@
<title>{% block title %}ExperiENS{% endblock %}</title>
<link type="text/css" rel="stylesheet" href="{% static 'style.css' %}" />
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<script type="text/javascript">function showFeedback(show){document.getElementById("feedback_bg").style.display=show?"table":"none";}</script>
{% block extra_head %}{% endblock %}
</head>
@ -27,7 +28,29 @@
</ul>
</nav>
</header>
{% if user.username %}
<div id="feedback_bg">
<div id="feedback_centrer">
<div id="feedback_win">
<h2>Envoyer un avis sur le site<a id="feedback_close" href="javascript:showFeedback(false)">X</a></h2>
<form method="POST" action="{% url 'monstage:send_feedback' %}?next={{ request.path|urlencode }}">
{% csrf_token %}
<p>Connecté en tant que {{ user.profil }}</p>
<p><label for="id_feedback-message">Commentaire :</label><textarea name="feedback-message" id="id_feedback-message"></textarea></p>
<input type="submit" />
</form>
</div>
</div>
</div>
<a id="feedback_btn" href="javascript:showFeedback(true)">
Feedback
</a>
{% endif %}
<div id="content">
{% if request.GET.feedback_sent %}<p class="success">Merci pour votre message !</p>{% endif %}
{% if request.GET.feedback_error %}<p class="failure">Erreur lors de l'envoi du message.</p>{% endif %}
{% block content %}{% endblock %}
</div>
</body>

View file

@ -15,4 +15,5 @@ urlpatterns = patterns('',
url(r'^stage/(?P<stage_id>\d+)/edit/avis/$', views.stage_edit_feedback, name='stage_edit_feedback'),
url(r'^stage/(?P<stage_id>\d+)/edit/publish/$', views.stage_publish, name='stage_publish'),
url(r'^recherche/$', views.search, name='search'),
url(r'^feedback/send/$', views.send_feedback, name='send_feedback'),
)

View file

@ -5,9 +5,11 @@ from django.contrib.auth.decorators import login_required
from django.http import HttpResponseRedirect, HttpResponse, HttpResponseForbidden, HttpResponseNotFound
from django.core.urlresolvers import reverse
from django import forms
from django.conf import settings
from django.contrib.gis.geos import GEOSGeometry
from django.contrib.gis import measure
from django.forms.widgets import HiddenInput
from django.core.mail import send_mail
from monstage.models import *
@ -317,3 +319,21 @@ def search(request):
form = SearchForm()
return render(request, 'monstage/search.html', {'form':form, 'resultats':stages})
#
# Feedback
#
class FeedbackForm(forms.Form):
message = forms.CharField(label='Commentaire')
@login_required
def send_feedback(request):
redirection = request.GET.get('next', reverse('monstage:index')) if request.GET else reverse('monstage:index')
if request.POST:
form = FeedbackForm(request.POST, prefix="feedback")
if form.is_valid():
dests = [ mail for (nom, mail) in settings.ADMINS ]
send_mail('Commentaire à propos d\'experiENS', form.cleaned_data["message"], ("%s@clipper.ens.fr" % (request.user.username,)), dests)
return HttpResponseRedirect(redirection+"?feedback_sent=1")
return HttpResponseRedirect(redirection+"?feedback_error=1")
return HttpResponseRedirect(redirection)