diff --git a/core/management/commands/populate.py b/core/management/commands/populate.py
index 9557ab6c..2cf0bbeb 100644
--- a/core/management/commands/populate.py
+++ b/core/management/commands/populate.py
@@ -52,6 +52,7 @@ class Command(BaseCommand):
c.edit_groups = [g]
c.save()
self.reset_index("counter")
+ Counter(name="Eboutic", club=main_club, type='EBOUTIC').save()
p = Page(name='Index')
p.set_lock(root)
p.save()
@@ -132,6 +133,18 @@ Welcome to the wiki page!
p.save()
PageRev(page=p, title="Aide sur la syntaxe", author=skia, content="""
Cette page vise à documenter la syntaxe *Markdown* utilisée sur le site.
+""").save()
+ p = Page(name='Services')
+ p.save()
+ p.set_lock(skia)
+ p.view_groups=[settings.SITH_GROUPS['public']['id']]
+ p.save()
+ PageRev(page=p, title="Services", author=skia, content="""
+| | | |
+| :---: | :---: | :---: |
+| [Eboutic](/eboutic) | [Laverie](/launderette) | Matmat |
+| SAS | Weekmail | Forum|
+
""").save()
# Adding README
p = Page(name='README')
diff --git a/core/models.py b/core/models.py
index a0834330..e919acf5 100644
--- a/core/models.py
+++ b/core/models.py
@@ -447,7 +447,7 @@ class Page(models.Model):
return '/'.join([self.parent.get_full_name(), self.name])
def get_display_name(self):
- return self.get_full_name()
+ return self.revisions.last().title
class PageRev(models.Model):
"""
diff --git a/core/static/core/style.css b/core/static/core/style.css
index 7ef55ccd..55ae5f08 100644
--- a/core/static/core/style.css
+++ b/core/static/core/style.css
@@ -166,6 +166,11 @@ tbody>tr:hover {
padding: 4px;
line-height: 120%;
}
+textarea {
+ white-space: pre;
+ width: 98%;
+ margin-top: 10px;
+}
/*--------------------------------FOOTER-------------------------------*/
footer{
diff --git a/core/templates/core/login.jinja b/core/templates/core/login.jinja
index 68397ae5..c30f0b18 100644
--- a/core/templates/core/login.jinja
+++ b/core/templates/core/login.jinja
@@ -17,19 +17,9 @@
{# Assumes you setup the password_reset view in your URLconf #}
diff --git a/core/templates/core/page.jinja b/core/templates/core/page.jinja
index be504a8e..ab97da42 100644
--- a/core/templates/core/page.jinja
+++ b/core/templates/core/page.jinja
@@ -15,7 +15,7 @@
{% macro print_page_name(page) %}
{% if page %}
{{ print_page_name(page.parent) }} >
-{{ page.name }}
+{{ page.get_display_name() }}
{% endif %}
{% endmacro %}
diff --git a/counter/migrations/0010_auto_20160728_1820.py b/counter/migrations/0010_auto_20160728_1820.py
new file mode 100644
index 00000000..3b17255b
--- /dev/null
+++ b/counter/migrations/0010_auto_20160728_1820.py
@@ -0,0 +1,38 @@
+# -*- coding: utf-8 -*-
+from __future__ import unicode_literals
+
+from django.db import migrations, models
+
+
+class Migration(migrations.Migration):
+
+ dependencies = [
+ ('counter', '0009_auto_20160721_1902'),
+ ]
+
+ operations = [
+ migrations.AlterModelOptions(
+ name='counter',
+ options={'verbose_name': 'counter'},
+ ),
+ migrations.AlterModelOptions(
+ name='permanency',
+ options={'verbose_name': 'permanency'},
+ ),
+ migrations.AlterModelOptions(
+ name='product',
+ options={'verbose_name': 'product'},
+ ),
+ migrations.AlterModelOptions(
+ name='producttype',
+ options={'verbose_name': 'product type'},
+ ),
+ migrations.AlterModelOptions(
+ name='refilling',
+ options={'verbose_name': 'refilling'},
+ ),
+ migrations.AlterModelOptions(
+ name='selling',
+ options={'verbose_name': 'selling'},
+ ),
+ ]
diff --git a/launderette/__init__.py b/launderette/__init__.py
new file mode 100644
index 00000000..e69de29b
diff --git a/launderette/admin.py b/launderette/admin.py
new file mode 100644
index 00000000..8c38f3f3
--- /dev/null
+++ b/launderette/admin.py
@@ -0,0 +1,3 @@
+from django.contrib import admin
+
+# Register your models here.
diff --git a/launderette/migrations/0001_initial.py b/launderette/migrations/0001_initial.py
new file mode 100644
index 00000000..deacb3bd
--- /dev/null
+++ b/launderette/migrations/0001_initial.py
@@ -0,0 +1,47 @@
+# -*- coding: utf-8 -*-
+from __future__ import unicode_literals
+
+from django.db import migrations, models
+
+
+class Migration(migrations.Migration):
+
+ dependencies = [
+ ]
+
+ operations = [
+ migrations.CreateModel(
+ name='Launderette',
+ fields=[
+ ('id', models.AutoField(serialize=False, auto_created=True, verbose_name='ID', primary_key=True)),
+ ('name', models.CharField(max_length=30, verbose_name='name')),
+ ],
+ options={
+ 'verbose_name': 'Launderette',
+ },
+ ),
+ migrations.CreateModel(
+ name='Machine',
+ fields=[
+ ('id', models.AutoField(serialize=False, auto_created=True, verbose_name='ID', primary_key=True)),
+ ('name', models.CharField(max_length=30, verbose_name='name')),
+ ('is_working', models.BooleanField(default=True, verbose_name='is working')),
+ ('launderette', models.ForeignKey(to='launderette.Launderette', related_name='machines', verbose_name='launderette')),
+ ],
+ options={
+ 'verbose_name': 'Machine',
+ },
+ ),
+ migrations.CreateModel(
+ name='Token',
+ fields=[
+ ('id', models.AutoField(serialize=False, auto_created=True, verbose_name='ID', primary_key=True)),
+ ('name', models.CharField(max_length=30, verbose_name='name')),
+ ('type', models.CharField(choices=[('WASHING', 'Washing'), ('DRYING', 'Drying')], max_length=10, verbose_name='type')),
+ ('launderette', models.ForeignKey(to='launderette.Launderette', related_name='tokens', verbose_name='launderette')),
+ ],
+ options={
+ 'verbose_name': 'Token',
+ },
+ ),
+ ]
diff --git a/launderette/migrations/0002_auto_20160728_1858.py b/launderette/migrations/0002_auto_20160728_1858.py
new file mode 100644
index 00000000..f8aa6b6d
--- /dev/null
+++ b/launderette/migrations/0002_auto_20160728_1858.py
@@ -0,0 +1,39 @@
+# -*- coding: utf-8 -*-
+from __future__ import unicode_literals
+
+from django.db import migrations, models
+
+
+class Migration(migrations.Migration):
+
+ dependencies = [
+ ('subscription', '0002_auto_20160718_1805'),
+ ('launderette', '0001_initial'),
+ ]
+
+ operations = [
+ migrations.CreateModel(
+ name='Slot',
+ fields=[
+ ('id', models.AutoField(primary_key=True, serialize=False, verbose_name='ID', auto_created=True)),
+ ('start_date', models.DateTimeField(verbose_name='start date')),
+ ('type', models.CharField(max_length=10, verbose_name='type', choices=[('WASHING', 'Washing'), ('DRYING', 'Drying')])),
+ ('machine', models.ForeignKey(verbose_name='machine', related_name='slots', to='launderette.Machine')),
+ ],
+ ),
+ migrations.AlterField(
+ model_name='token',
+ name='name',
+ field=models.IntegerField(verbose_name='name'),
+ ),
+ migrations.AddField(
+ model_name='slot',
+ name='token',
+ field=models.ForeignKey(verbose_name='token', related_name='slots', to='launderette.Token'),
+ ),
+ migrations.AddField(
+ model_name='slot',
+ name='user',
+ field=models.ForeignKey(verbose_name='user', related_name='slots', to='subscription.Subscriber'),
+ ),
+ ]
diff --git a/launderette/migrations/0003_launderette_sellers.py b/launderette/migrations/0003_launderette_sellers.py
new file mode 100644
index 00000000..de418c0f
--- /dev/null
+++ b/launderette/migrations/0003_launderette_sellers.py
@@ -0,0 +1,20 @@
+# -*- coding: utf-8 -*-
+from __future__ import unicode_literals
+
+from django.db import migrations, models
+
+
+class Migration(migrations.Migration):
+
+ dependencies = [
+ ('subscription', '0002_auto_20160718_1805'),
+ ('launderette', '0002_auto_20160728_1858'),
+ ]
+
+ operations = [
+ migrations.AddField(
+ model_name='launderette',
+ name='sellers',
+ field=models.ManyToManyField(to='subscription.Subscriber', verbose_name='sellers', related_name='launderettes'),
+ ),
+ ]
diff --git a/launderette/migrations/0004_auto_20160728_1922.py b/launderette/migrations/0004_auto_20160728_1922.py
new file mode 100644
index 00000000..6bcbdbe8
--- /dev/null
+++ b/launderette/migrations/0004_auto_20160728_1922.py
@@ -0,0 +1,19 @@
+# -*- coding: utf-8 -*-
+from __future__ import unicode_literals
+
+from django.db import migrations, models
+
+
+class Migration(migrations.Migration):
+
+ dependencies = [
+ ('launderette', '0003_launderette_sellers'),
+ ]
+
+ operations = [
+ migrations.AlterField(
+ model_name='launderette',
+ name='sellers',
+ field=models.ManyToManyField(blank=True, to='subscription.Subscriber', verbose_name='sellers', related_name='launderettes'),
+ ),
+ ]
diff --git a/launderette/migrations/__init__.py b/launderette/migrations/__init__.py
new file mode 100644
index 00000000..e69de29b
diff --git a/launderette/models.py b/launderette/models.py
new file mode 100644
index 00000000..945a9766
--- /dev/null
+++ b/launderette/models.py
@@ -0,0 +1,76 @@
+from django.db import models
+from django.utils.translation import ugettext_lazy as _
+from django.conf import settings
+from django.core.urlresolvers import reverse
+
+from core.models import User
+from subscription.models import Subscriber
+
+# Create your models here.
+
+class Launderette(models.Model):
+ name = models.CharField(_('name'), max_length=30)
+ sellers = models.ManyToManyField(Subscriber, verbose_name=_('sellers'), related_name='launderettes', blank=True)
+
+ class Meta:
+ verbose_name = _('Launderette')
+
+ def is_owned_by(self, user):
+ """
+ Method to see if that object can be edited by the given user
+ """
+ if user.is_in_group(settings.SITH_GROUPS['launderette-admin']['name']):
+ return True
+ return False
+
+ def can_be_viewed_by(self, user):
+ return user.is_in_group(settings.SITH_MAIN_MEMBERS_GROUP)
+
+ def __str__(self):
+ return self.name
+
+ def get_absolute_url(self):
+ return reverse('launderette:launderette_list')
+
+class Machine(models.Model):
+ name = models.CharField(_('name'), max_length=30)
+ launderette = models.ForeignKey(Launderette, related_name='machines', verbose_name=_('launderette'))
+ is_working = models.BooleanField(_('is working'), default=True)
+
+ class Meta:
+ verbose_name = _('Machine')
+
+ def is_owned_by(self, user):
+ """
+ Method to see if that object can be edited by the given user
+ """
+ if user.is_in_group(settings.SITH_GROUPS['launderette-admin']['name']):
+ return True
+ return False
+
+class Token(models.Model):
+ name = models.IntegerField(_('name'))
+ launderette = models.ForeignKey(Launderette, related_name='tokens', verbose_name=_('launderette'))
+ type = models.CharField(_('type'), max_length=10, choices=[('WASHING', _('Washing')), ('DRYING', _('Drying'))])
+
+ class Meta:
+ verbose_name = _('Token')
+
+ def is_owned_by(self, user):
+ """
+ Method to see if that object can be edited by the given user
+ """
+ if user.is_in_group(settings.SITH_GROUPS['launderette-admin']['name']):
+ return True
+ return False
+
+class Slot(models.Model):
+ start_date = models.DateTimeField(_('start date'))
+ type = models.CharField(_('type'), max_length=10, choices=[('WASHING', _('Washing')), ('DRYING', _('Drying'))])
+ machine = models.ForeignKey(Machine, related_name='slots', verbose_name=_('machine'))
+ token = models.ForeignKey(Token, related_name='slots', verbose_name=_('token'))
+ user = models.ForeignKey(Subscriber, related_name='slots', verbose_name=_('user'))
+
+ def full_clean(self):
+ return super(Slot, self).full_clean()
+
diff --git a/launderette/templates/launderette/counter_click.jinja b/launderette/templates/launderette/counter_click.jinja
new file mode 100644
index 00000000..317a1b36
--- /dev/null
+++ b/launderette/templates/launderette/counter_click.jinja
@@ -0,0 +1,79 @@
+{% extends "core/base.jinja" %}
+
+{% macro add_product(id, content) %}
+
+{% endmacro %}
+
+{% macro del_product(id, content) %}
+
+{% endmacro %}
+
+{% block content %}
+{% trans %}Counter{% endtrans %}
+{{ counter }}
+{% trans %}Club: {% endtrans %} {{ counter.club }}
+
+
+
{% trans %}Customer{% endtrans %}
+
{{ customer.user.get_display_name() }}, {{ customer.amount }} €
+
+{% if counter.type == 'BAR' %}
+
+
{% trans %}Refilling{% endtrans %}
+
+
+{% endif %}
+
+
{% trans %}Selling{% endtrans %}
+ {% if request.session['not_enough'] %}
+
{% trans %}Not enough money{% endtrans %}
+ {% endif %}
+
+
{% trans %}Basket: {% endtrans %}
+
+ {% for id,infos in request.session['basket']|dictsort %}
+ {% set product = counter.products.filter(id=id).first() %}
+ {% set s = infos['qty'] * infos['price'] / 100 %}
+ - {{ del_product(id, '-') }} {{ infos['qty'] }} {{ add_product(id, '+') }} {{ product.name }}: {{ "%0.2f"|format(s) }} €
+ {% endfor %}
+
+
{% trans %}Total: {% endtrans %}{{ "%0.2f"|format(basket_total) }} €
+
+
+
{% trans %}Products: {% endtrans %}
+ {% for p in counter.products.all() %}
+ {{ add_product(p.id, p.name) }}
+ {% endfor %}
+
+
+
+{% endblock %}
+
+
+
diff --git a/launderette/templates/launderette/counter_edit.jinja b/launderette/templates/launderette/counter_edit.jinja
new file mode 100644
index 00000000..865ed1f3
--- /dev/null
+++ b/launderette/templates/launderette/counter_edit.jinja
@@ -0,0 +1,13 @@
+{% extends "core/base.jinja" %}
+
+{% block content %}
+{% trans %}Edit counter{% endtrans %}
+
+{% endblock %}
+
+
+
diff --git a/launderette/templates/launderette/counter_main.jinja b/launderette/templates/launderette/counter_main.jinja
new file mode 100644
index 00000000..1dcbd143
--- /dev/null
+++ b/launderette/templates/launderette/counter_main.jinja
@@ -0,0 +1,55 @@
+{% extends "core/base.jinja" %}
+
+{% macro barman_logout_link(user) %}
+
+{% endmacro %}
+
+{% block content %}
+{% trans counter_name=counter %}{{ counter_name }} counter{% endtrans %}
+
+
+
{% trans %}Sellings{% endtrans %}
+ {% if last_basket %}
+
{% trans %}Last selling: {% endtrans %}
+
{% trans %}Client: {% endtrans %}{{ last_customer }} - {% trans %}New amount: {% endtrans %}{{ new_customer_amount }} €.
+
+ {% for s in last_basket %}
+ - {{ s }}
+ {% endfor %}
+
+
{% trans %}Total: {% endtrans %}{{ last_total }} €
+ {% endif %}
+ {% if barmen %}
+
{% trans %}Enter client code:{% endtrans %}
+
+ {% else %}
+
{% trans %}Please, login{% endtrans %}
+ {% endif %}
+
+ {% if counter.type == 'BAR' %}
+
+
{% trans %}Barman: {% endtrans %}
+
+ {% for b in barmen %}
+ - {{ barman_logout_link(b) }}
+ {% endfor %}
+
+
+
+ {% endif %}
+{% endblock %}
+
+
+
diff --git a/launderette/templates/launderette/launderette_book.jinja b/launderette/templates/launderette/launderette_book.jinja
new file mode 100644
index 00000000..af30c6c1
--- /dev/null
+++ b/launderette/templates/launderette/launderette_book.jinja
@@ -0,0 +1,21 @@
+{% extends "core/base.jinja" %}
+
+{% block title %}
+{% trans %}Launderette{% endtrans %}
+{% endblock %}
+
+{% block content %}
+{% if request.user.is_in_group(settings.SITH_MAIN_MEMBERS_GROUP) %}
+
+ {% for l in launderette_list %}
+ - {{ l }}
+ {% endfor %}
+
+{% endif %}
+{% endblock %}
+
+
+
+
+
+
diff --git a/launderette/templates/launderette/launderette_detail.jinja b/launderette/templates/launderette/launderette_detail.jinja
new file mode 100644
index 00000000..44885117
--- /dev/null
+++ b/launderette/templates/launderette/launderette_detail.jinja
@@ -0,0 +1,13 @@
+{% extends "core/base.jinja" %}
+
+{% block title %}
+{% trans %}Launderette admin{% endtrans %}
+{% endblock %}
+
+{% block content %}
+Admin
+{% endblock %}
+
+
+
+
diff --git a/launderette/templates/launderette/launderette_list.jinja b/launderette/templates/launderette/launderette_list.jinja
new file mode 100644
index 00000000..009bc19a
--- /dev/null
+++ b/launderette/templates/launderette/launderette_list.jinja
@@ -0,0 +1,23 @@
+{% extends "core/base.jinja" %}
+
+{% block title %}
+{% trans %}Launderette admin list{% endtrans %}
+{% endblock %}
+
+{% block content %}
+{% trans %}New launderette{% endtrans %}
+{% if launderette_list %}
+{% trans %}Launderette admin list{% endtrans %}
+
+{% else %}
+{% trans %}There is no launderette in this website.{% endtrans %}
+{% endif %}
+{% endblock %}
+
+
+
diff --git a/launderette/templates/launderette/launderette_main.jinja b/launderette/templates/launderette/launderette_main.jinja
new file mode 100644
index 00000000..d3f7653e
--- /dev/null
+++ b/launderette/templates/launderette/launderette_main.jinja
@@ -0,0 +1,21 @@
+{% extends "core/base.jinja" %}
+
+{% block title %}
+{% trans %}Launderette{% endtrans %}
+{% endblock %}
+
+{% block content %}
+{% if request.user.is_in_group(settings.SITH_GROUPS['launderette-admin']['name']) %}
+{% trans %}Edit presentation page{% endtrans %}
+{% endif %}
+{% if request.user.is_in_group(settings.SITH_MAIN_MEMBERS_GROUP) %}
+{% trans %}Book launderette slot{% endtrans %}
+{% endif %}
+
+{{ page.revisions.last().content|markdown }}
+{% endblock %}
+
+
+
+
+
diff --git a/launderette/templates/launderette/product_list.jinja b/launderette/templates/launderette/product_list.jinja
new file mode 100644
index 00000000..f9a50085
--- /dev/null
+++ b/launderette/templates/launderette/product_list.jinja
@@ -0,0 +1,23 @@
+{% extends "core/base.jinja" %}
+
+{% block title %}
+{% trans %}Product list{% endtrans %}
+{% endblock %}
+
+{% block content %}
+{% trans %}New product{% endtrans %}
+{% if product_list %}
+{% trans %}Product list{% endtrans %}
+
+ {% for p in product_list %}
+ - {{ p }}
+ {% endfor %}
+
+{% else %}
+{% trans %}There is no products in this website.{% endtrans %}
+{% endif %}
+{% endblock %}
+
+
+
+
diff --git a/launderette/templates/launderette/producttype_list.jinja b/launderette/templates/launderette/producttype_list.jinja
new file mode 100644
index 00000000..9a686dc8
--- /dev/null
+++ b/launderette/templates/launderette/producttype_list.jinja
@@ -0,0 +1,24 @@
+{% extends "core/base.jinja" %}
+
+{% block title %}
+{% trans %}Product type list{% endtrans %}
+{% endblock %}
+
+{% block content %}
+{% trans %}New product type{% endtrans %}
+{% if producttype_list %}
+{% trans %}Product type list{% endtrans %}
+
+ {% for t in producttype_list %}
+ - {{ t }}
+ {% endfor %}
+
+{% else %}
+{% trans %}There is no product types in this website.{% endtrans %}
+{% endif %}
+{% endblock %}
+
+
+
+
+
diff --git a/launderette/templates/launderette/user_account.jinja b/launderette/templates/launderette/user_account.jinja
new file mode 100644
index 00000000..02283eb3
--- /dev/null
+++ b/launderette/templates/launderette/user_account.jinja
@@ -0,0 +1,86 @@
+{% extends "core/user_base.jinja" %}
+
+{% block title %}
+{% trans user_name=profile.get_display_name() %}{{ user_name }}'s account{% endtrans %}
+{% endblock %}
+
+{% block infos %}
+{% trans %}User account{% endtrans %}
+{% trans %}Amount: {% endtrans %}{{ customer.amount }} €
+{% if customer.refillings.exists() %}
+{% trans %}Refillings{% endtrans %}
+
+
+
+ {% trans %}Date{% endtrans %} |
+ {% trans %}Barman{% endtrans %} |
+ {% trans %}Amount{% endtrans %} |
+
+
+
+ {% for i in customer.refillings.all() %}
+
+ {{ i.date|localtime|date(DATETIME_FORMAT) }} - {{ i.date|localtime|time(DATETIME_FORMAT) }} |
+ {{ i.operator }} |
+ {{ i.amount }} € |
+
+{% endfor %}
+
+
+{% endif %}
+{% if customer.buyings.exists() %}
+{% trans %}Buyings{% endtrans %}
+
+
+
+ {% trans %}Date{% endtrans %} |
+ {% trans %}Barman{% endtrans %} |
+ {% trans %}Product{% endtrans %} |
+ {% trans %}Quantity{% endtrans %} |
+ {% trans %}Total{% endtrans %} |
+
+
+
+ {% for i in customer.buyings.all() %}
+
+ {{ i.date|localtime|date(DATETIME_FORMAT) }} - {{ i.date|localtime|time(DATETIME_FORMAT) }} |
+ {{ i.seller }} |
+ {{ i.product }} |
+ {{ i.quantity }} |
+ {{ i.quantity * i.unit_price }} € |
+
+{% endfor %}
+
+
+{% endif %}
+{% if customer.user.invoices.exists() %}
+{% trans %}Invoices{% endtrans %}
+
+
+
+ {% trans %}Date{% endtrans %} |
+ {% trans %}Items{% endtrans %} |
+ {% trans %}Amount{% endtrans %} |
+
+
+
+ {% for i in customer.user.invoices.all() %}
+
+ {{ i.date|localtime|date(DATETIME_FORMAT) }} - {{ i.date|localtime|time(DATETIME_FORMAT) }} |
+
+
+ {% for it in i.items.all() %}
+ - {{ it.product_name }} - {{ it.product_unit_price }} €
+ {% endfor %}
+
+ |
+ {{ i.get_total() }} € |
+
+{% endfor %}
+
+
+{% endif %}
+{% endblock %}
+
+
+
diff --git a/launderette/tests.py b/launderette/tests.py
new file mode 100644
index 00000000..7ce503c2
--- /dev/null
+++ b/launderette/tests.py
@@ -0,0 +1,3 @@
+from django.test import TestCase
+
+# Create your tests here.
diff --git a/launderette/urls.py b/launderette/urls.py
new file mode 100644
index 00000000..fe045885
--- /dev/null
+++ b/launderette/urls.py
@@ -0,0 +1,17 @@
+from django.conf.urls import url, include
+
+from launderette.views import *
+
+urlpatterns = [
+ # views
+ url(r'^$', LaunderetteMainView.as_view(), name='launderette_main'),
+ url(r'^book$', LaunderetteBookMainView.as_view(), name='book_main'),
+ url(r'^book/(?P[0-9]+)$', LaunderetteBookView.as_view(), name='book_slot'),
+ url(r'^admin$', LaunderetteListView.as_view(), name='launderette_list'),
+ url(r'^admin/(?P[0-9]+)$', LaunderetteDetailView.as_view(), name='launderette_details'),
+ url(r'^admin/(?P[0-9]+)/edit$', LaunderetteEditView.as_view(), name='launderette_edit'),
+ url(r'^admin/new$', LaunderetteCreateView.as_view(), name='launderette_new'),
+]
+
+
+
diff --git a/launderette/views.py b/launderette/views.py
new file mode 100644
index 00000000..9862d3a7
--- /dev/null
+++ b/launderette/views.py
@@ -0,0 +1,62 @@
+from django.shortcuts import render
+from django.views.generic import ListView, DetailView, RedirectView, TemplateView
+from django.views.generic.edit import UpdateView, CreateView, DeleteView, ProcessFormView, FormMixin
+from django.forms.models import modelform_factory
+from django.forms import CheckboxSelectMultiple
+from django.utils.translation import ugettext as _
+from django.conf import settings
+
+from core.models import Page
+from core.views import CanViewMixin, CanEditMixin, CanEditPropMixin, CanCreateMixin
+from launderette.models import Launderette, Token, Machine, Slot
+
+# For users
+
+class LaunderetteMainView(TemplateView):
+ """Main presentation view"""
+ template_name = 'launderette/launderette_main.jinja'
+
+ def get_context_data(self, **kwargs):
+ """ Add page to the context """
+ kwargs = super(LaunderetteMainView, self).get_context_data(**kwargs)
+ kwargs['page'] = Page.objects.filter(name='launderette').first()
+ return kwargs
+
+class LaunderetteBookMainView(CanViewMixin, ListView):
+ """Choose which launderette to book"""
+ model = Launderette
+ template_name = 'launderette/launderette_book.jinja'
+
+class LaunderetteBookView(TemplateView):
+ """Display the launderette schedule"""
+ model = Launderette
+ pk_url_kwarg = "launderette_id"
+ template_name = 'launderette/launderette_book.jinja'
+
+
+# For admins
+
+class LaunderetteListView(CanViewMixin, ListView):
+ """Choose which launderette to administer"""
+ model = Launderette
+ template_name = 'launderette/launderette_list.jinja'
+
+class LaunderetteDetailView(CanViewMixin, DetailView):
+ """The admin page of the launderette"""
+ model = Launderette
+ pk_url_kwarg = "launderette_id"
+ template_name = 'launderette/launderette_detail.jinja'
+
+class LaunderetteEditView(CanViewMixin, UpdateView):
+ """Edit a launderette"""
+ model = Launderette
+ pk_url_kwarg = "launderette_id"
+ form_class = modelform_factory(Launderette, fields=['name', 'sellers'],
+ widgets={'sellers':CheckboxSelectMultiple})
+ template_name = 'core/edit.jinja'
+
+class LaunderetteCreateView(CanCreateMixin, CreateView):
+ """Create a new launderette"""
+ model = Launderette
+ fields = ['name', 'sellers']
+ template_name = 'core/create.jinja'
diff --git a/locale/fr/LC_MESSAGES/django.mo b/locale/fr/LC_MESSAGES/django.mo
index 091b46c0..29621bbb 100644
Binary files a/locale/fr/LC_MESSAGES/django.mo and b/locale/fr/LC_MESSAGES/django.mo differ
diff --git a/locale/fr/LC_MESSAGES/django.po b/locale/fr/LC_MESSAGES/django.po
index abc65c51..ddb49138 100644
--- a/locale/fr/LC_MESSAGES/django.po
+++ b/locale/fr/LC_MESSAGES/django.po
@@ -6,7 +6,7 @@
msgid ""
msgstr ""
"Report-Msgid-Bugs-To: \n"
-"POT-Creation-Date: 2016-07-27 19:57+0200\n"
+"POT-Creation-Date: 2016-07-28 20:02+0200\n"
"PO-Revision-Date: 2016-07-18\n"
"Last-Translator: Skia \n"
"Language-Team: AE info \n"
@@ -18,7 +18,8 @@ msgstr ""
#: accounting/models.py:32 accounting/models.py:55 accounting/models.py:94
#: club/models.py:18 counter/models.py:38 counter/models.py:63
-#: counter/models.py:91
+#: counter/models.py:91 launderette/models.py:12 launderette/models.py:36
+#: launderette/models.py:52
msgid "name"
msgstr "nom"
@@ -31,6 +32,7 @@ msgid "account number"
msgstr "numero de compte"
#: accounting/models.py:92 club/models.py:109 counter/models.py:237
+#: launderette/models.py:68
msgid "start date"
msgstr "date de début"
@@ -149,6 +151,7 @@ msgstr "Nouveau compte club"
#: core/templates/core/user_tools.jinja:32
#: counter/templates/counter/counter_list.jinja:15
#: counter/templates/counter/counter_list.jinja:18
+#: launderette/templates/launderette/launderette_list.jinja:14
msgid "Edit"
msgstr "Éditer"
@@ -203,6 +206,8 @@ msgstr "Fin"
#: accounting/templates/accounting/journal_details.jinja:23
#: counter/templates/counter/user_account.jinja:17
#: counter/templates/counter/user_account.jinja:63
+#: launderette/templates/launderette/user_account.jinja:17
+#: launderette/templates/launderette/user_account.jinja:63
msgid "Amount"
msgstr "Montant"
@@ -236,6 +241,7 @@ msgstr "Voir"
#: accounting/templates/accounting/journal_details.jinja:10
#: counter/templates/counter/user_account.jinja:9
+#: launderette/templates/launderette/user_account.jinja:9
msgid "Amount: "
msgstr "Montant: "
@@ -259,6 +265,9 @@ msgstr "No"
#: counter/templates/counter/user_account.jinja:15
#: counter/templates/counter/user_account.jinja:36
#: counter/templates/counter/user_account.jinja:61
+#: launderette/templates/launderette/user_account.jinja:15
+#: launderette/templates/launderette/user_account.jinja:36
+#: launderette/templates/launderette/user_account.jinja:61
msgid "Date"
msgstr "Date"
@@ -311,6 +320,7 @@ msgid "You can not make loops in clubs"
msgstr "Vous ne pouvez pas faire de boucles dans les clubs"
#: club/models.py:107 eboutic/models.py:12 eboutic/models.py:45
+#: launderette/models.py:72
msgid "user"
msgstr "nom d'utilisateur"
@@ -366,6 +376,7 @@ msgstr "Éditer le club"
#: core/templates/core/page_prop.jinja:8
#: core/templates/core/pagerev_edit.jinja:24
#: counter/templates/counter/counter_edit.jinja:8
+#: launderette/templates/launderette/counter_edit.jinja:8
#: subscription/templates/subscription/subscription.jinja:12
msgid "Save"
msgstr "Sauver"
@@ -374,8 +385,7 @@ msgstr "Sauver"
msgid "Edit club properties"
msgstr "Éditer les propriétés du club"
-#: club/templates/club/club_list.jinja:4
-#: club/templates/club/club_list.jinja:24
+#: club/templates/club/club_list.jinja:4 club/templates/club/club_list.jinja:24
msgid "Club list"
msgstr "Liste des clubs"
@@ -576,6 +586,7 @@ msgid "Site made by good people"
msgstr "Site réalisé par des gens biens"
#: core/templates/core/create.jinja:4
+#, python-format
msgid "Create %(name)s"
msgstr "Créer %(name)s"
@@ -594,6 +605,7 @@ msgstr "Confirmation"
#: core/templates/core/delete_confirm.jinja:8
#: counter/templates/counter/counter_click.jinja:67
+#: launderette/templates/launderette/counter_click.jinja:67
msgid "Cancel"
msgstr "Annuler"
@@ -606,8 +618,7 @@ msgstr "Éditer %(obj)s"
msgid "Edit group"
msgstr "Éditer le groupe"
-#: core/templates/core/group_edit.jinja:9
-#: core/templates/core/user_edit.jinja:8
+#: core/templates/core/group_edit.jinja:9 core/templates/core/user_edit.jinja:8
#: core/templates/core/user_group.jinja:8
msgid "Update"
msgstr "Mettre à jour"
@@ -643,12 +654,13 @@ msgstr ""
msgid "Please login to see this page."
msgstr "Merci de vous identifier pour voir cette page."
-#: core/templates/core/login.jinja:31
+#: core/templates/core/login.jinja:22
#: counter/templates/counter/counter_main.jinja:48
+#: launderette/templates/launderette/counter_main.jinja:48
msgid "login"
msgstr "login"
-#: core/templates/core/login.jinja:36
+#: core/templates/core/login.jinja:26
msgid "Lost password?"
msgstr "Mot de passe perdu ?"
@@ -981,56 +993,70 @@ msgid "permanency"
msgstr "permanence"
#: counter/templates/counter/counter_click.jinja:20
+#: launderette/templates/launderette/counter_click.jinja:20
msgid "Counter"
msgstr "Comptoir"
#: counter/templates/counter/counter_click.jinja:22
+#: launderette/templates/launderette/counter_click.jinja:22
msgid "Club: "
msgstr "Club : "
#: counter/templates/counter/counter_click.jinja:25
+#: launderette/templates/launderette/counter_click.jinja:25
msgid "Customer"
msgstr "Client"
#: counter/templates/counter/counter_click.jinja:30
+#: launderette/templates/launderette/counter_click.jinja:30
msgid "Refilling"
msgstr "Rechargement"
#: counter/templates/counter/counter_click.jinja:35
#: counter/templates/counter/counter_click.jinja:48
+#: launderette/templates/launderette/counter_click.jinja:35
+#: launderette/templates/launderette/counter_click.jinja:48
msgid "Go"
msgstr "Valider"
#: counter/templates/counter/counter_click.jinja:40
+#: launderette/templates/launderette/counter_click.jinja:40
msgid "Selling"
msgstr "Vente"
#: counter/templates/counter/counter_click.jinja:42
+#: launderette/templates/launderette/counter_click.jinja:42
msgid "Not enough money"
msgstr "Solde insuffisant"
#: counter/templates/counter/counter_click.jinja:50
#: eboutic/templates/eboutic/eboutic_main.jinja:23
#: eboutic/templates/eboutic/eboutic_makecommand.jinja:7
+#: launderette/templates/launderette/counter_click.jinja:50
msgid "Basket: "
msgstr "Panier : "
#: counter/templates/counter/counter_click.jinja:58
#: counter/templates/counter/counter_main.jinja:24
#: eboutic/templates/eboutic/eboutic_main.jinja:30
+#: launderette/templates/launderette/counter_click.jinja:58
+#: launderette/templates/launderette/counter_main.jinja:24
msgid "Total: "
msgstr "Total : "
#: counter/templates/counter/counter_click.jinja:62
+#: launderette/templates/launderette/counter_click.jinja:62
msgid "Finish"
msgstr "Terminer"
#: counter/templates/counter/counter_click.jinja:69
#: eboutic/templates/eboutic/eboutic_main.jinja:37
+#: launderette/templates/launderette/counter_click.jinja:69
msgid "Products: "
msgstr "Produits : "
#: counter/templates/counter/counter_edit.jinja:4
+#: launderette/templates/launderette/counter_edit.jinja:4
msgid "Edit counter"
msgstr "Éditer le comptoir"
@@ -1048,107 +1074,135 @@ msgid "There is no counters in this website."
msgstr "Il n'y a pas de comptoirs dans ce site web."
#: counter/templates/counter/counter_main.jinja:12
+#: launderette/templates/launderette/counter_main.jinja:12
#, python-format
msgid "%(counter_name)s counter"
msgstr "Comptoir %(counter_name)s"
#: counter/templates/counter/counter_main.jinja:15
+#: launderette/templates/launderette/counter_main.jinja:15
msgid "Sellings"
msgstr "Ventes"
#: counter/templates/counter/counter_main.jinja:17
+#: launderette/templates/launderette/counter_main.jinja:17
msgid "Last selling: "
msgstr "Dernière vente : "
#: counter/templates/counter/counter_main.jinja:18
+#: launderette/templates/launderette/counter_main.jinja:18
msgid "Client: "
msgstr "Client : "
#: counter/templates/counter/counter_main.jinja:18
+#: launderette/templates/launderette/counter_main.jinja:18
msgid "New amount: "
msgstr "Nouveau montant : "
#: counter/templates/counter/counter_main.jinja:27
+#: launderette/templates/launderette/counter_main.jinja:27
msgid "Enter client code:"
msgstr "Entrez un code client : "
#: counter/templates/counter/counter_main.jinja:31
+#: launderette/templates/launderette/counter_main.jinja:31
msgid "validate"
msgstr "valider"
#: counter/templates/counter/counter_main.jinja:34
+#: launderette/templates/launderette/counter_main.jinja:34
msgid "Please, login"
msgstr "Merci de vous identifier"
#: counter/templates/counter/counter_main.jinja:39
+#: launderette/templates/launderette/counter_main.jinja:39
msgid "Barman: "
msgstr "Barman : "
#: counter/templates/counter/product_list.jinja:4
#: counter/templates/counter/product_list.jinja:10
+#: launderette/templates/launderette/product_list.jinja:4
+#: launderette/templates/launderette/product_list.jinja:10
msgid "Product list"
msgstr "Liste des produits"
#: counter/templates/counter/product_list.jinja:8
+#: launderette/templates/launderette/product_list.jinja:8
msgid "New product"
msgstr "Nouveau produit"
#: counter/templates/counter/product_list.jinja:17
+#: launderette/templates/launderette/product_list.jinja:17
msgid "There is no products in this website."
msgstr "Il n'y a pas de produits dans ce site web."
#: counter/templates/counter/producttype_list.jinja:4
#: counter/templates/counter/producttype_list.jinja:10
+#: launderette/templates/launderette/producttype_list.jinja:4
+#: launderette/templates/launderette/producttype_list.jinja:10
msgid "Product type list"
msgstr "Liste des types de produit"
#: counter/templates/counter/producttype_list.jinja:8
+#: launderette/templates/launderette/producttype_list.jinja:8
msgid "New product type"
msgstr "Nouveau type de produit"
#: counter/templates/counter/producttype_list.jinja:17
+#: launderette/templates/launderette/producttype_list.jinja:17
msgid "There is no product types in this website."
msgstr "Il n'y a pas de types de produit dans ce site web."
#: counter/templates/counter/user_account.jinja:4
+#: launderette/templates/launderette/user_account.jinja:4
#, python-format
msgid "%(user_name)s's account"
msgstr "Compte de %(user_name)s"
#: counter/templates/counter/user_account.jinja:8
+#: launderette/templates/launderette/user_account.jinja:8
msgid "User account"
msgstr "Compte utilisateur"
#: counter/templates/counter/user_account.jinja:11
+#: launderette/templates/launderette/user_account.jinja:11
msgid "Refillings"
msgstr "Rechargements"
#: counter/templates/counter/user_account.jinja:16
#: counter/templates/counter/user_account.jinja:37
+#: launderette/templates/launderette/user_account.jinja:16
+#: launderette/templates/launderette/user_account.jinja:37
msgid "Barman"
msgstr "Barman"
#: counter/templates/counter/user_account.jinja:32
+#: launderette/templates/launderette/user_account.jinja:32
msgid "Buyings"
msgstr "Achats"
#: counter/templates/counter/user_account.jinja:38
+#: launderette/templates/launderette/user_account.jinja:38
msgid "Product"
msgstr "Produit"
#: counter/templates/counter/user_account.jinja:39
+#: launderette/templates/launderette/user_account.jinja:39
msgid "Quantity"
msgstr "Quantité"
#: counter/templates/counter/user_account.jinja:40
+#: launderette/templates/launderette/user_account.jinja:40
msgid "Total"
msgstr "Total"
#: counter/templates/counter/user_account.jinja:57
+#: launderette/templates/launderette/user_account.jinja:57
msgid "Invoices"
msgstr "Factures"
#: counter/templates/counter/user_account.jinja:62
+#: launderette/templates/launderette/user_account.jinja:62
msgid "Items"
msgstr "Articles"
@@ -1168,7 +1222,7 @@ msgstr "ANN"
msgid "You have not enough money to buy all the basket"
msgstr "Vous n'avez pas assez d'argent pour acheter le panier"
-#: eboutic/models.py:47 sith/settings.py:243 sith/settings_sample.py:231
+#: eboutic/models.py:47 sith/settings.py:240 sith/settings_sample.py:243
msgid "Credit card"
msgstr "Carte banquaire"
@@ -1235,75 +1289,146 @@ msgstr "Retourner à l'eboutic"
msgid "You do not have enough money to buy the basket"
msgstr "Vous n'avez pas assez d'argent pour acheter le panier"
-#: sith/settings.py:240 sith/settings.py:247 sith/settings.py:259
-#: sith/settings_sample.py:228 sith/settings_sample.py:235
-#: sith/settings_sample.py:247
+#: launderette/models.py:13
+msgid "sellers"
+msgstr "vendeurs"
+
+#: launderette/models.py:16
+#: launderette/templates/launderette/launderette_book.jinja:4
+#: launderette/templates/launderette/launderette_main.jinja:4
+msgid "Launderette"
+msgstr "Laverie"
+
+#: launderette/models.py:37 launderette/models.py:53
+msgid "launderette"
+msgstr "laverie"
+
+#: launderette/models.py:38
+msgid "is working"
+msgstr "est HS"
+
+#: launderette/models.py:41
+msgid "Machine"
+msgstr "Machine"
+
+#: launderette/models.py:54 launderette/models.py:69
+msgid "type"
+msgstr "type"
+
+#: launderette/models.py:54 launderette/models.py:69
+msgid "Washing"
+msgstr "Lavage"
+
+#: launderette/models.py:54 launderette/models.py:69
+msgid "Drying"
+msgstr "Séchage"
+
+#: launderette/models.py:57
+msgid "Token"
+msgstr "Jeton"
+
+#: launderette/models.py:70
+msgid "machine"
+msgstr "machine"
+
+#: launderette/models.py:71
+msgid "token"
+msgstr "jeton"
+
+#: launderette/templates/launderette/launderette_detail.jinja:4
+msgid "Launderette admin"
+msgstr "Gestion de la laverie"
+
+#: launderette/templates/launderette/launderette_list.jinja:4
+#: launderette/templates/launderette/launderette_list.jinja:10
+msgid "Launderette admin list"
+msgstr "Liste des laveries"
+
+#: launderette/templates/launderette/launderette_list.jinja:8
+msgid "New launderette"
+msgstr "Nouvelle laverie"
+
+#: launderette/templates/launderette/launderette_list.jinja:18
+msgid "There is no launderette in this website."
+msgstr "Il n'y a pas de laverie dans ce site web."
+
+#: launderette/templates/launderette/launderette_main.jinja:9
+msgid "Edit presentation page"
+msgstr "Éditer la page de présentation"
+
+#: launderette/templates/launderette/launderette_main.jinja:12
+msgid "Book launderette slot"
+msgstr "Réserver un créneau de laverie"
+
+#: sith/settings.py:237 sith/settings.py:244 sith/settings.py:256
+#: sith/settings_sample.py:240 sith/settings_sample.py:247
+#: sith/settings_sample.py:259
msgid "Check"
msgstr "Chèque"
-#: sith/settings.py:241 sith/settings.py:248 sith/settings.py:260
-#: sith/settings_sample.py:229 sith/settings_sample.py:236
-#: sith/settings_sample.py:248
+#: sith/settings.py:238 sith/settings.py:245 sith/settings.py:257
+#: sith/settings_sample.py:241 sith/settings_sample.py:248
+#: sith/settings_sample.py:260
msgid "Cash"
msgstr "Espèces"
-#: sith/settings.py:242 sith/settings_sample.py:230
+#: sith/settings.py:239 sith/settings_sample.py:242
msgid "Transfert"
msgstr "Virement"
-#: sith/settings.py:249 sith/settings_sample.py:237
+#: sith/settings.py:246 sith/settings_sample.py:249
msgid "Other"
msgstr "Autre"
-#: sith/settings.py:273 sith/settings_sample.py:261
+#: sith/settings.py:270 sith/settings_sample.py:273
msgid "One semester"
msgstr "Un semestre"
-#: sith/settings.py:278 sith/settings_sample.py:266
+#: sith/settings.py:275 sith/settings_sample.py:278
msgid "Two semesters"
msgstr "Deux semestres"
-#: sith/settings.py:283 sith/settings_sample.py:271
+#: sith/settings.py:280 sith/settings_sample.py:283
msgid "Common core cursus"
msgstr "Cursus tronc commun"
-#: sith/settings.py:288 sith/settings_sample.py:276
+#: sith/settings.py:285 sith/settings_sample.py:288
msgid "Branch cursus"
msgstr "Cursus branche"
-#: sith/settings.py:296 sith/settings_sample.py:284
+#: sith/settings.py:293 sith/settings_sample.py:296
msgid "President"
msgstr "Président"
-#: sith/settings.py:297 sith/settings_sample.py:285
+#: sith/settings.py:294 sith/settings_sample.py:297
msgid "Vice-President"
msgstr "Vice-Président"
-#: sith/settings.py:298 sith/settings_sample.py:286
+#: sith/settings.py:295 sith/settings_sample.py:298
msgid "Treasurer"
msgstr "Trésorier"
-#: sith/settings.py:299 sith/settings_sample.py:287
+#: sith/settings.py:296 sith/settings_sample.py:299
msgid "Communication supervisor"
msgstr "Responsable com"
-#: sith/settings.py:300 sith/settings_sample.py:288
+#: sith/settings.py:297 sith/settings_sample.py:300
msgid "Secretary"
msgstr "Secrétaire"
-#: sith/settings.py:301 sith/settings_sample.py:289
+#: sith/settings.py:298 sith/settings_sample.py:301
msgid "IT supervisor"
msgstr "Responsable info"
-#: sith/settings.py:302 sith/settings_sample.py:290
+#: sith/settings.py:299 sith/settings_sample.py:302
msgid "Board member"
msgstr "Membre du bureau"
-#: sith/settings.py:303 sith/settings_sample.py:291
+#: sith/settings.py:300 sith/settings_sample.py:303
msgid "Active member"
msgstr "Membre actif"
-#: sith/settings.py:304 sith/settings_sample.py:292
+#: sith/settings.py:301 sith/settings_sample.py:304
msgid "Curious"
msgstr "Curieux"
@@ -1339,18 +1464,3 @@ msgstr "Un utilisateur avec cette adresse email existe déjà"
msgid "You must either choose an existing user or create a new one properly"
msgstr ""
"Vous devez soit choisir un utilisateur existant, ou en créer un proprement."
-
-#~ msgid "Create"
-#~ msgstr "Créer"
-
-#~ msgid "%(c)s counter"
-#~ msgstr "Comptoir %(c)s"
-
-#~ msgid "Page"
-#~ msgstr "Page"
-
-#~ msgid "You're seeing the page %(page_name)s"
-#~ msgstr "Vous consultez la page %(page_name)s"
-
-#~ msgid "Back to page"
-#~ msgstr "Retour à la page"
diff --git a/sith/settings_sample.py b/sith/settings_sample.py
index 9dbc305b..ebd3a363 100644
--- a/sith/settings_sample.py
+++ b/sith/settings_sample.py
@@ -48,6 +48,7 @@ INSTALLED_APPS = (
'accounting',
'counter',
'eboutic',
+ 'launderette',
)
MIDDLEWARE_CLASSES = (
@@ -215,10 +216,18 @@ SITH_GROUPS = {
'id': 3,
'name': "Accounting admin",
},
- 'counter-admin': {
+ 'communication-admin': {
'id': 4,
+ 'name': "Communication admin",
+ },
+ 'counter-admin': {
+ 'id': 5,
'name': "Counter admin",
},
+ 'launderette-admin': {
+ 'id': 6,
+ 'name': "Launderette admin",
+ },
}
SITH_BOARD_SUFFIX="-board"
diff --git a/sith/urls.py b/sith/urls.py
index 60de79eb..39cd5245 100644
--- a/sith/urls.py
+++ b/sith/urls.py
@@ -28,5 +28,6 @@ urlpatterns = [
url(r'^counter/', include('counter.urls', namespace="counter", app_name="counter")),
url(r'^accounting/', include('accounting.urls', namespace="accounting", app_name="accounting")),
url(r'^eboutic/', include('eboutic.urls', namespace="eboutic", app_name="eboutic")),
+ url(r'^launderette/', include('launderette.urls', namespace="launderette", app_name="launderette")),
url(r'^admin/', include(admin.site.urls)),
] + static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT) # TODO: remove me for production!!!