Merge remote-tracking branch 'gitorious/master'
This commit is contained in:
commit
d022d9f93f
34
mediagoblin/messages.py
Normal file
34
mediagoblin/messages.py
Normal file
@ -0,0 +1,34 @@
|
|||||||
|
# GNU MediaGoblin -- federated, autonomous media hosting
|
||||||
|
# Copyright (C) 2011 Free Software Foundation, Inc
|
||||||
|
#
|
||||||
|
# This program is free software: you can redistribute it and/or modify
|
||||||
|
# it under the terms of the GNU Affero General Public License as published by
|
||||||
|
# the Free Software Foundation, either version 3 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 Affero General Public License for more details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU Affero General Public License
|
||||||
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
DEBUG = 'debug'
|
||||||
|
INFO = 'info'
|
||||||
|
SUCCESS = 'success'
|
||||||
|
WARNING = 'warning'
|
||||||
|
ERROR = 'error'
|
||||||
|
|
||||||
|
def add_message(request, level, text):
|
||||||
|
messages = request.session.setdefault('messages', [])
|
||||||
|
messages.append({'level': level, 'text': text})
|
||||||
|
request.session.save()
|
||||||
|
|
||||||
|
def fetch_messages(request, clear_from_session=True):
|
||||||
|
messages = request.session.get('messages')
|
||||||
|
if messages and clear_from_session:
|
||||||
|
# Save that we removed the messages from the session
|
||||||
|
request.session['messages'] = []
|
||||||
|
request.session.save()
|
||||||
|
return messages
|
@ -73,6 +73,47 @@ label {
|
|||||||
padding-bottom:74px;
|
padding-bottom:74px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ul.mediagoblin_messages {
|
||||||
|
list-style:none inside;
|
||||||
|
color:#393932;
|
||||||
|
margin:2px;
|
||||||
|
padding:2px;
|
||||||
|
}
|
||||||
|
|
||||||
|
ul.mediagoblin_messages li {
|
||||||
|
background-color:#d4d4d4;
|
||||||
|
border-style:solid;
|
||||||
|
border-width:3px;
|
||||||
|
border-color:#959595;
|
||||||
|
margin:5px;
|
||||||
|
padding:8px;
|
||||||
|
}
|
||||||
|
|
||||||
|
ul.mediagoblin_messages li.message_success {
|
||||||
|
background-color: #88d486;
|
||||||
|
border-color: #5bba59;
|
||||||
|
}
|
||||||
|
|
||||||
|
ul.mediagoblin_messages li.message_warning {
|
||||||
|
background-color: #d4c686;
|
||||||
|
border-color: #baa959;
|
||||||
|
}
|
||||||
|
|
||||||
|
ul.mediagoblin_messages li.message_error {
|
||||||
|
background-color: #d48686;
|
||||||
|
border-color: #ba5959;
|
||||||
|
}
|
||||||
|
|
||||||
|
ul.mediagoblin_messages li.message_info {
|
||||||
|
background-color: #86b9d4;
|
||||||
|
border-color: #5998ba;
|
||||||
|
}
|
||||||
|
|
||||||
|
ul.mediagoblin_messages li.message_debug {
|
||||||
|
background-color: #aa86d4;
|
||||||
|
border-color: #8659ba;
|
||||||
|
}
|
||||||
|
|
||||||
a.mediagoblin_logo {
|
a.mediagoblin_logo {
|
||||||
width:34px;
|
width:34px;
|
||||||
height:25px;
|
height:25px;
|
||||||
|
@ -52,6 +52,8 @@
|
|||||||
</div>
|
</div>
|
||||||
{% endblock %}
|
{% endblock %}
|
||||||
|
|
||||||
|
{% include "mediagoblin/utils/messages.html" %}
|
||||||
|
|
||||||
<div class="container_12 mediagoblin_content">
|
<div class="container_12 mediagoblin_content">
|
||||||
<div class="grid_12">
|
<div class="grid_12">
|
||||||
{% block mediagoblin_content %}
|
{% block mediagoblin_content %}
|
||||||
|
32
mediagoblin/templates/mediagoblin/utils/messages.html
Normal file
32
mediagoblin/templates/mediagoblin/utils/messages.html
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
{#
|
||||||
|
# GNU MediaGoblin -- federated, autonomous media hosting
|
||||||
|
# Copyright (C) 2011 Free Software Foundation, Inc
|
||||||
|
#
|
||||||
|
# This program is free software: you can redistribute it and/or modify
|
||||||
|
# it under the terms of the GNU Affero General Public License as published by
|
||||||
|
# the Free Software Foundation, either version 3 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 Affero General Public License for more details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU Affero General Public License
|
||||||
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
#}
|
||||||
|
|
||||||
|
{# Display any queued messages #}
|
||||||
|
{% set messages = fetch_messages(request) %}
|
||||||
|
{% if messages %}
|
||||||
|
<div class="container_12 mediagoblin_messages">
|
||||||
|
<div class="grid_12">
|
||||||
|
<ul class="mediagoblin_messages">
|
||||||
|
{% for msg in messages %}
|
||||||
|
<li class="message_{{ msg.level }}">{{ msg.text }}</li>
|
||||||
|
{% endfor %}
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
{% endif %}
|
||||||
|
|
44
mediagoblin/tests/test_messages.py
Normal file
44
mediagoblin/tests/test_messages.py
Normal file
@ -0,0 +1,44 @@
|
|||||||
|
# GNU MediaGoblin -- federated, autonomous media hosting
|
||||||
|
# Copyright (C) 2011 Free Software Foundation, Inc
|
||||||
|
#
|
||||||
|
# This program is free software: you can redistribute it and/or modify
|
||||||
|
# it under the terms of the GNU Affero General Public License as published by
|
||||||
|
# the Free Software Foundation, either version 3 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 Affero General Public License for more details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU Affero General Public License
|
||||||
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
from mediagoblin.messages import fetch_messages, add_message
|
||||||
|
from mediagoblin.tests.tools import setup_fresh_app
|
||||||
|
from mediagoblin import util
|
||||||
|
|
||||||
|
|
||||||
|
@setup_fresh_app
|
||||||
|
def test_messages(test_app):
|
||||||
|
"""
|
||||||
|
Added messages should show up in the request.session,
|
||||||
|
fetched messages should be the same as the added ones,
|
||||||
|
and fetching should clear the message list.
|
||||||
|
"""
|
||||||
|
# Aquire a request object
|
||||||
|
test_app.get('/')
|
||||||
|
context = util.TEMPLATE_TEST_CONTEXT['mediagoblin/root.html']
|
||||||
|
request = context['request']
|
||||||
|
|
||||||
|
# The message queue should be empty
|
||||||
|
assert request.session.get('messages', []) == []
|
||||||
|
|
||||||
|
# Adding a message should modify the session accordingly
|
||||||
|
add_message(request, 'herp_derp', 'First!')
|
||||||
|
test_msg_queue = [{'text': 'First!', 'level': 'herp_derp'}]
|
||||||
|
assert request.session['messages'] == test_msg_queue
|
||||||
|
|
||||||
|
# fetch_messages should return and empty the queue
|
||||||
|
assert fetch_messages(request) == test_msg_queue
|
||||||
|
assert request.session.get('messages') == []
|
@ -32,6 +32,7 @@ from lxml.html.clean import Cleaner
|
|||||||
import markdown
|
import markdown
|
||||||
|
|
||||||
from mediagoblin import mg_globals
|
from mediagoblin import mg_globals
|
||||||
|
from mediagoblin import messages
|
||||||
from mediagoblin.db.util import ObjectId
|
from mediagoblin.db.util import ObjectId
|
||||||
|
|
||||||
TESTS_ENABLED = False
|
TESTS_ENABLED = False
|
||||||
@ -104,6 +105,10 @@ def get_jinja_env(template_loader, locale):
|
|||||||
mg_globals.translations.gettext,
|
mg_globals.translations.gettext,
|
||||||
mg_globals.translations.ngettext)
|
mg_globals.translations.ngettext)
|
||||||
|
|
||||||
|
# All templates will know how to ...
|
||||||
|
# ... fetch all waiting messages and remove them from the queue
|
||||||
|
template_env.globals['fetch_messages'] = messages.fetch_messages
|
||||||
|
|
||||||
if exists(locale):
|
if exists(locale):
|
||||||
SETUP_JINJA_ENVS[locale] = template_env
|
SETUP_JINJA_ENVS[locale] = template_env
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user