From 1499c0bcedb8bc4502986d1497e56ace50b039f7 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Aur=C3=A9lien=20Delobelle?= Date: Mon, 12 Jun 2017 01:51:10 +0200 Subject: [PATCH] =?UTF-8?q?Improvements=20for=20K-F=C3=AAt=20CMS.?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit K-Fêt - Wagtail - Page content becomes a StreamField. - GroupTeam snippet becomes a block for stream field. - Navigation menu moved becomes a "flatmenu", preventing possible future conflicts. - Page layout can be modified in wagtail admin. K-Fêt - Add shorthands for ukf account balance/article price. - Cleaning stylesheets and templates. --- kfet/cms/apps.py | 3 + kfet/cms/context_processors.py | 2 +- kfet/cms/fixtures/kfet_wagtail_17_05.json | 371 +++++--------- kfet/cms/hooks.py | 12 + kfet/cms/migrations/0001_initial.py | 52 +- kfet/cms/models.py | 263 +++++----- kfet/cms/static/kfetcms/css/base.css | 93 ++++ kfet/cms/static/kfetcms/css/editor.css | 18 + kfet/cms/static/kfetcms/css/index.css | 158 +----- .../static/kfetcms/css/menu.css} | 0 kfet/cms/static/kfetcms/css/team.css | 47 ++ kfet/cms/templates/kfetcms/base.html | 67 +-- kfet/cms/templates/kfetcms/block_menu.html | 11 + .../kfetcms/block_menu_category.html | 12 + .../{equipe.html => block_teamgroup.html} | 45 +- kfet/cms/templates/kfetcms/carte.html | 46 -- kfet/forms.py | 29 +- kfet/models.py | 15 +- kfet/signals.py | 2 +- kfet/static/kfet/css/base/buttons.css | 88 ++++ kfet/static/kfet/css/base/fixed.css | 151 ++++++ kfet/static/kfet/css/{ => base}/footer.css | 3 +- kfet/static/kfet/css/base/main.css | 138 +++++ kfet/static/kfet/css/base/messages.css | 36 ++ kfet/static/kfet/css/base/misc.css | 107 ++++ kfet/static/kfet/css/{ => base}/nav.css | 0 kfet/static/kfet/css/index.css | 470 ++++-------------- kfet/static/kfet/css/libs/columns.css | 43 ++ .../kfet/css/{ => libs}/jconfirm-kfet.css | 23 +- .../kfet/css/libs/multiple-select-kfet.css | 14 + kfet/static/kfet/js/kfet.js | 12 +- kfet/static/kfet/js/statistic.js | 15 +- kfet/templates/kfet/account.html | 48 +- kfet/templates/kfet/account_create.html | 8 +- .../kfet/account_create_special.html | 2 +- kfet/templates/kfet/account_group.html | 66 +-- kfet/templates/kfet/account_group_form.html | 14 +- kfet/templates/kfet/account_negative.html | 114 +++-- kfet/templates/kfet/account_read.html | 55 +- kfet/templates/kfet/account_update.html | 10 +- kfet/templates/kfet/article.html | 97 ++-- kfet/templates/kfet/article_create.html | 8 +- .../kfet/article_inventories_snippet.html | 22 + kfet/templates/kfet/article_read.html | 180 ++++--- .../kfet/article_suppliers_snippet.html | 22 + kfet/templates/kfet/article_update.html | 8 +- kfet/templates/kfet/base.html | 13 +- kfet/templates/kfet/base_col_1.html | 8 +- kfet/templates/kfet/base_col_2.html | 14 +- kfet/templates/kfet/base_col_mult.html | 18 + kfet/templates/kfet/base_footer.html | 2 +- kfet/templates/kfet/base_form.html | 17 +- kfet/templates/kfet/base_nav.html | 4 +- kfet/templates/kfet/category.html | 69 ++- kfet/templates/kfet/category_update.html | 8 +- kfet/templates/kfet/checkout.html | 76 +-- kfet/templates/kfet/checkout_create.html | 7 +- kfet/templates/kfet/checkout_read.html | 11 +- kfet/templates/kfet/checkout_update.html | 14 +- .../kfet/checkoutstatement_create.html | 51 +- .../kfet/checkoutstatement_update.html | 8 +- .../kfet/form_authentication_snippet.html | 2 +- kfet/templates/kfet/form_full_snippet.html | 8 + kfet/templates/kfet/history.html | 95 ++-- kfet/templates/kfet/inventory.html | 65 +-- kfet/templates/kfet/inventory_create.html | 7 +- kfet/templates/kfet/inventory_read.html | 101 ++-- kfet/templates/kfet/kpsul.html | 14 +- kfet/templates/kfet/left_account.html | 132 +++-- kfet/templates/kfet/left_checkout.html | 38 +- kfet/templates/kfet/nav_item.html | 2 +- kfet/templates/kfet/order.html | 29 +- kfet/templates/kfet/order_create.html | 6 +- kfet/templates/kfet/order_read.html | 60 ++- kfet/templates/kfet/order_to_inventory.html | 4 +- kfet/templates/kfet/settings.html | 12 +- kfet/templates/kfet/settings_update.html | 8 +- kfet/templates/kfet/supplier_form.html | 8 +- kfet/templates/kfet/transfers.html | 65 +-- kfet/templates/kfet/transfers_create.html | 4 +- kfet/templatetags/kfet_tags.py | 21 +- kfet/tests/test_statistic.py | 3 +- kfet/tests/test_views.py | 6 +- kfet/utils.py | 10 + 84 files changed, 2126 insertions(+), 1894 deletions(-) create mode 100644 kfet/cms/hooks.py create mode 100644 kfet/cms/static/kfetcms/css/base.css create mode 100644 kfet/cms/static/kfetcms/css/editor.css rename kfet/{static/kfet/css/home.css => cms/static/kfetcms/css/menu.css} (100%) create mode 100644 kfet/cms/static/kfetcms/css/team.css create mode 100644 kfet/cms/templates/kfetcms/block_menu.html create mode 100644 kfet/cms/templates/kfetcms/block_menu_category.html rename kfet/cms/templates/kfetcms/{equipe.html => block_teamgroup.html} (51%) delete mode 100644 kfet/cms/templates/kfetcms/carte.html create mode 100644 kfet/static/kfet/css/base/buttons.css create mode 100644 kfet/static/kfet/css/base/fixed.css rename kfet/static/kfet/css/{ => base}/footer.css (85%) create mode 100644 kfet/static/kfet/css/base/main.css create mode 100644 kfet/static/kfet/css/base/messages.css create mode 100644 kfet/static/kfet/css/base/misc.css rename kfet/static/kfet/css/{ => base}/nav.css (100%) create mode 100644 kfet/static/kfet/css/libs/columns.css rename kfet/static/kfet/css/{ => libs}/jconfirm-kfet.css (81%) create mode 100644 kfet/static/kfet/css/libs/multiple-select-kfet.css create mode 100644 kfet/templates/kfet/article_inventories_snippet.html create mode 100644 kfet/templates/kfet/article_suppliers_snippet.html create mode 100644 kfet/templates/kfet/base_col_mult.html create mode 100644 kfet/templates/kfet/form_full_snippet.html create mode 100644 kfet/utils.py diff --git a/kfet/cms/apps.py b/kfet/cms/apps.py index f7276ae8..1db0e043 100644 --- a/kfet/cms/apps.py +++ b/kfet/cms/apps.py @@ -5,3 +5,6 @@ class KFetCMSAppConfig(AppConfig): name = 'kfet.cms' label = 'kfetcms' verbose_name = 'CMS K-Fêt' + + def ready(self): + from . import hooks diff --git a/kfet/cms/context_processors.py b/kfet/cms/context_processors.py index 0cf7a649..34f175d1 100644 --- a/kfet/cms/context_processors.py +++ b/kfet/cms/context_processors.py @@ -1,7 +1,7 @@ from kfet.models import Article -def get_articles(request): +def get_articles(request=None): articles = ( Article.objects .filter(is_sold=True, hidden=False) diff --git a/kfet/cms/fixtures/kfet_wagtail_17_05.json b/kfet/cms/fixtures/kfet_wagtail_17_05.json index a0651c79..f6a46c30 100644 --- a/kfet/cms/fixtures/kfet_wagtail_17_05.json +++ b/kfet/cms/fixtures/kfet_wagtail_17_05.json @@ -281,7 +281,7 @@ { "fields": { "name": "Root", - "numchild": 0, + "numchild": 1, "path": "0001", "depth": 1 }, @@ -289,151 +289,20 @@ "model": "wagtailcore.collection" }, { - "model": "kfetcms.kfetpage", "fields": { - "custom_template": "", - "no_header": false, - "content": "

La K-F\u00eat, c'est quoi ?

\n\n

\n Eh bien la K-F\u00eat, c'est le bar des \u00e9l\u00e8ves de l'\u00c9cole normale\n sup\u00e9rieure. Elle est situ\u00e9e dans les locaux de l'\u00c9cole, au pied de\n l'escalier C (plan). On y trouve \u00e0 boire, bien s\u00fbr,\n des bi\u00e8res en nombre pl\u00e9thorique mais aussi caf\u00e9s, th\u00e9s, softs et de quoi\n grignoter. Ah oui un point important, on ne va pas \u00e0 la K-F\u00eat, on va EN K-F\u00eat.\n

\n\n

Mais on n'y fait que boire et manger ?

\n\n

\n Que nenni, \u00f4 jeune et innocent conscrit-e ! La K-F\u00eat n'est pas un bouge\n sordide o\u00f9 des piliers de bar passent leurs journ\u00e9es \u00e0 picoler. Enfin pas\n uniquement. C'est aussi un lieu de divertissement avec\n son flipper (la mythique, la seule, l'unique,\n la g\u00e9niale Amazon Hunt), son baby-foot et le lieu d'\u00e9lection des \nbridgeur-se-s, du club jeux, des joueur-se-s de poker voire des quelques\n irr\u00e9ductibles du boulot qui y viennent bosser en profitant du point \nd'acc\u00e8s wifi. \n

\n\n

Ah \u00e7a a l'air bien mais... qui s'en occupe ? C'est ouvert quand ?

\n\n

\n L'\u00e9quipe d'\u00e9l\u00e8ves motiv\u00e9-e-s qui s'occupent de la K-F\u00eat s'appelle, en toute logique, l'\u00e9quipe K-F\u00eat.\n Elle est men\u00e9e par un-e leader charismatique et bien-aim\u00e9-e, \naccompagn\u00e9-e de ses troupes de fid\u00e8les, les K-F\u00eat wo-men, boys et girls.\n Le local de la K-F\u00eat n'est ouvert que si un-e K-F\u00eat wo-man est \npr\u00e9sente. \u00c0 savoir la plupart du temps entre 12h et 3h du matin.\n

\n\n

Et je peux y faire ce que je veux ?

\n\n

\n Oui et non. Nous ne sommes pas ta grand-m\u00e8re et nous n'allons\n certainement pas t'emp\u00eacher de faire la f\u00eate, ni de d\u00e9guster des pintes\n jusqu'au petit p\u00f4t. Par contre nous attendons de toi que tu ne sois pas\n un-e gros-se con-ne. A priori pas de raison de le croire, mais jette tout de m\u00eame\n un \u0153il sur le mode d'emploi de la K-F\u00eat, \u00e7a\n pourrait t'\u00e9viter de perdre un genoux ou deux...\n

\n\n

J'adore la K-F\u00eat, j'aimerais y organiser une soir\u00e9e, c'est possible ?

\n\n

\n Bien s\u00fbr\u00a0! Pour cela commence par lire ce petit\n guide histoire de savoir dans quoi tu t'engages puis contacte ton-ta chef-fe K-F\u00eat ador\u00e9-e pour v\u00e9rifier que la date de ta\n soir\u00e9e n'est pas d\u00e9j\u00e0 prise par une autre f\u00eate et obtenir son\n accord.\n

\n\n

J'ai une question \u00e0 vous poser. O\u00f9 puis-je vous contacter ?

\n\n

\n Commence d\u00e9j\u00e0 par jeter un oeil sur le mode\n d'emploi de la K-F\u00eat. Si la r\u00e9ponse \u00e0 tes interrogations ne s'y\n trouve pas, rien n'est perdu. En effet le service informatique de \nl'\u00c9cole, dans sa grande mansu\u00e9tude, a mis \u00e0 disposition de l'\u00e9quipe \nK-F\u00eat une adresse e-mail, k-fet@ens.fr. Mais sinon, passe en K-F\u00eat, il y aura sans doute un K-F\u00eat wo-man qui saura r\u00e9pondre \u00e0 ta question.\n

" + "name": "K-F\u00eat", + "numchild": 0, + "path": "00010001", + "depth": 2 }, - "pk": 3 -}, -{ - "model": "kfetcms.kfetpage", - "fields": { - "custom_template": "", - "no_header": false, - "content": "

Article 0 : La K-F\u00eat n'existe pas.

La K-F\u00eat, c'est magique, comment \u00e7a marche ?

La K-F\u00eat n'a rien de magique, il n'y a pas de petits d\u00e9mons qui font le m\u00e9nage, pas plus que d'arbustes g\u00e9n\u00e9tiquement modifi\u00e9s aux OGM sur lesquels poussent les bouteilles de bi\u00e8res. La K-F\u00eat c'est avant tout une \u00e9quipe qui sacrifie une partie de son temps libre pour que tout se passe pour le mieux.

Que puis-je faire pour vous aider un peu ?

D\u00e9j\u00e0 ne pas poser de probl\u00e8mes, c'est \u00e0 dire ne pas r\u00e9veiller tout l'internat en sortant, essayer de ne pas finir dans un \u00e9tat trop avanc\u00e9 d'alcoolisation, etc... Mine de rien \u00e7a nous \u00e9viterait quelques probl\u00e8mes.

Ensuite, comme tu le sais s\u00fbrement les bi\u00e8res sont consign\u00e9es, il est donc pr\u00e9f\u00e9rable pour nous que tu n'embarques pas les bouteilles en souvenir dans ta thurne. Mieux, tu peux nous faire gagner du temps de rangement en les ramenant au bar en partant. Et encore mieux, tu peux jeter tes d\u00e9chets (gobelets, boite de pringles, etc...). Si tu fais d\u00e9j\u00e0 tout \u00e7a tu nous simplifieras grandement la vie.

Le syst\u00e8me mon\u00e9taire de la K-F\u00eat

En bon \u00e9tat souverain et ind\u00e9pendant, la K-F\u00eat a sa propre monnaie : l'unit\u00e9 K-F\u00eat (UKF). Elle vaut 10 centimes d'euro. La K-F\u00eat ne battant pas monnaie, les UKF que tu poss\u00e8des sont not\u00e9es sur ton compte, identifi\u00e9 par un trigramme (une suite de trois caract\u00e8res) et que tu peux recharger en liquide ou par ch\u00e8que. Note que si tu y tiens vraiment, tu peux payer en liquide, mais poss\u00e9der un compte est bien plus pratique.

Comment commander \u00e0 boire ou \u00e0 manger ?

Pour commander \u00e0 boire ou \u00e0 manger, il suffit de demander \u00e0 un membre de l'\u00e9quipe K-F\u00eat. Et \u00e7a marche encore mieux si la demande est effectu\u00e9e avec le sourire au d\u00e9but et un merci \u00e0 la fin : l'\u00e9quipe est constitu\u00e9e de volontaires b\u00e9n\u00e9voles, et mieux vaut ne pas les prendre pour des chiens. EN AUCUN CAS on ne passe derri\u00e8re le bar si on n'est pas membre de l'\u00e9quipe K-F\u00eat.

Puis-je fumer en K-F\u00eat ?

Non ! Imagine-toi les jours de soir\u00e9es, la K-F\u00eat remplie et tout le monde qui fume... On finirait tous avec des poumons aussi crades que le sol de la K-F\u00eat. Ce serait quand m\u00eame dommage pour la recherche fran\u00e7aise qu'on cr\u00e8ve tous avant 30 ans, non ?

Par contre tu peux fumer dehors, il y a m\u00eame des cendriers juste pour toi, par contre tu remarqueras que les chambres de l'internat se trouvent juste au dessus de toi. T\u00e2che donc de ne pas faire trop de bruit.

Et amener ma propre bouteille ?

D\u00e9j\u00e0 c'est apporter, enfin en tout cas avant de la boire. Ensuite la K-F\u00eat est un lieu de convivialit\u00e9 o\u00f9 les bi\u00e8res te sont vendues au prix co\u00fbtant,\n franchement ce serait pas fair-play de te la jouer solo. Alors \u00e9videment il y a des exceptions, par exemple si tu reviens de Belgique et que tu veux faire go\u00fbter de la Wesvleteren \u00e0 tes amis de l'\u00e9quipe K-F\u00eat, ou si tu veux organiser une d\u00e9gustation de vins avec la charcuterie qui va bien. Tu comprendras qu'un pack de Kro c'est quand m\u00eame pas la m\u00eame classe...

Je peux passer ma musique ?

Bien s\u00fbr, nous sommes tr\u00e8s loin de penser tout conna\u00eetre en mati\u00e8re de musique. Mais comme nous sommes entre gens civilis\u00e9s, et que je te rappelle que tu n'as pas le droit de passer derri\u00e8re le bar, il convient de demander \u00e0 un-e membre de l'\u00e9quipe K-F\u00eat afin qu'ille t'indique qui est \u00e0 l'origine de ces chansons que tu n'appr\u00e9cies apparemment pas. Apr\u00e8s avoir obtenu son accord tu peux demander \u00e0 quelqu'un de mettre ta playlist, qui peut-\u00eatre sur un lecteur mp3, sur Deezer ou juste sur l'ordi, mais dans ce dernier cas ce sera plus dur puisque tu n'y aura pas acc\u00e8s directement.

Le plus simple pour toi (et pour nous) est donc de pr\u00e9voir des playlists sur Deezer d'avance et de nous les proposer. Par contre, sois gentil-le, n'insiste pas si nous ne voulons pas de ta musique traditionnelle hongroise. Par ailleurs, si un trop grand nombre de personnes nous demande de passer de la musique, l'\u00e9quipe K-F\u00eat peut ne pas acc\u00e9der \u00e0 ta requ\u00eate.

Comment organiser une soir\u00e9e en K-F\u00eat ?

Tout membre du COF peut organiser une soir\u00e9e en K-F\u00eat \u00e0 la condition qu'elle soit publique et annonc\u00e9e une semaine \u00e0 l'avance par des affiches dans l'\u00e9cole et un mot dans le BOcal. Il faut bien sur aussi l'accord du COF qui s'occupe de voir si \u00e7a ne pose pas de probl\u00e8me \u00e0 l'admin, celui de la K-F\u00eat team pour qu'il y ait des K-F\u00eat wo-men pour servir et s\u00fbrement du BOUM pour qu'il s'occupe de la musique. Nous t'avons tout r\u00e9sum\u00e9 ici ; merci qui ? Une fois que tu as accompli ces formalit\u00e9s, il ne te reste plus qu'\u00e0 imprimer et coller des affiches pour que ta soir\u00e9e soit un succ\u00e8s !

D'autres remarques ?

Des tonnes, en voici quelques unes :

" - }, - "pk": 4 -}, -{ - "model": "kfetcms.kfetpage", - "fields": { - "custom_template": "kfetcms/equipe.html", - "no_header": false, - "content": "

Les K-F\u00eat boys et girls

\n\n

Les K-F\u00eat boys and girls font de main d'\u0153uvre bon march\u00e9 pour la \nK-F\u00eat, illes peuvent passer derri\u00e8re le bar, prendre vos commandes et \nrecharger votre compte si par malheur il est \u00e0 sec. La liste de \ncelleux-ci est trop longue pour tou-te-s les citer, pour les reconna\u00eetre\n regarde les gens qui passent derri\u00e8re le bar tout en conservant leur \nint\u00e9grit\u00e9 physique.

\n\n

Comment devient-on K-F\u00eat people ?

\n\n

Grande question que tout le monde se pose un jour ou l'autre. Pour \nacc\u00e9der au titre prestigieux de K-F\u00eat boy-girl, il est n\u00e9cessaire mais \npas suffisant d'\u00eatre assid\u00fbment pr\u00e9sent-e en K-F\u00eat, et d'\u00eatre pr\u00eat-e \u00e0 \ntrimer pour elle. Si tu es souvent en K-F\u00eat, que tu es sympathique et \nmotiv\u00e9-e, et surtout en fin de compte si le-la chef-fe le veut bien, tu \npourras devenir K-F\u00eat boy-girl et passer derri\u00e8re le bar pour servir. \nEnsuite, si tu es motiv\u00e9-e et efficace, ou simplement si t'es un-e pote \ndu-de la chef-fe et qu'ille n'a aucun scrupule, tu pourras devenir K-F\u00eat\n wo-man et avoir la cl\u00e9.

\n\n

Et comme la K-F\u00eat c'est avant tout beaucoup d'emmerdes on a pas envie\n de te forcer la main, on veut que cela vienne de toi. Donc si tu te \nsens pr\u00eat-e \u00e0 participer \u00e0 la vie mouvement\u00e9e de la K-F\u00eat fais-en part \nau-\u00e0 la chef-fe. Ille ne va pas te manger.

" - }, - "pk": 5 -}, -{ - "model": "kfetcms.kfetpage", - "fields": { - "custom_template": "kfetcms/carte.html", - "no_header": false, - "content": "

\n\tLe service de la bi\u00e8re est, historiquement, la mission et le sacerdoce \ndu K-F\u00eat people. Ille y est d\u00e9vou\u00e9-e corps et \u00e2me, et accomplit sa t\u00e2che\n avec ardeur et passion. Voyons comment se d\u00e9clinent les occasions \nd'approcher du nirvana brassicole. Les prix donn\u00e9s sont en UKF. Si tu \nn'as pas compris, va voir par ici.

" - }, - "pk": 6 -}, -{ - "model": "kfetcms.kfetpage", - "fields": { - "custom_template": "", - "no_header": false, - "content": "

\n Tu veux organiser une soir\u00e9e en K-F\u00eat ? Pas de probl\u00e8me !\n

\n\n

Quand puis-je organiser une soir\u00e9e ?

\n\n

\n Tu peux organiser une soir\u00e9e le jour que tu souhaites, \u00e0 condition que la\n date ne soit pas d\u00e9j\u00e0 prise par quelqu'un d'autre. Sache par contre que la\n K-F\u00eat ne te sera pas enti\u00e8rement d\u00e9di\u00e9e et que les utilisateur-rice-s habituel-le-s\n continueront de la fr\u00e9quenter (et risquent fortement de squatter ta\n soir\u00e9e). Donc si tu veux un peu d'intimit\u00e9 les soir\u00e9es du week-end sont plus\n conseill\u00e9es (mais l'\u00e9quipe risque de ne pas \u00eatre pr\u00e9sente), mais aussi\n plus pris\u00e9es, d\u00e9p\u00eache-toi de r\u00e9server la tienne.\n

\n\n

Quelles d\u00e9marches dois-je effectuer ?

\n

\n D\u00e9j\u00e0 pr\u00e9venir poliment l'\u00e9quipe K-F\u00eat, et\n surtout le-la chef-fe pour v\u00e9rifier que la date est encore libre, et qu'il y\n aura au moins quelqu'un pour t'ouvrir la K-F\u00eat. Ensuite, si ta soir\u00e9e\n n'est pas une simple bouffe qui finit avant minuit il faut pr\u00e9venir les\n vigiles via l'administration au moyen d'une demande d'autorisation de\n soir\u00e9e qui se trouve sur la section du p\u00f4le Pr\u00e9vention et S\u00e9curit\u00e9 sur l'intranet : demande d'autorisation de soir\u00e9e.\n \u00c0 faire au moins une semaine avant ta soir\u00e9e.\n

\n

\n Si en plus tu as besoin que le BOUM s'occupe de la musique et/ou PLS des\n lumi\u00e8res c'est elleux qu'il faut contacter. Histoire de t'\u00e9viter\n d'avoir \u00e0 chercher voici leur adresse\u00a0: boum (at) ens (point) fr\n et pls (at) ens (point) fr.\n

\n\n

C'est enfin le grand jour, je fais quoi ?

\n

\n D\u00e9j\u00e0 le m\u00e9nage, oui je sais c'est chiant mais c'est le prix \u00e0 payer pour\n profiter du local. Demande \u00e0 ce qu'un-e K-F\u00eat wo-man t'ouvre et tu devrais avoir\n \u00e0 ta disposition tout ce qu'il faut pour faire briller la K-F\u00eat (ou au moins on essaiera de\n trouver ce qu'il faut). Fais par\n contre attention aux bouteilles de bi\u00e8re qui sont consign\u00e9es, s'il n'y a\n personne pour les ranger contente-toi de les mettre sur le bar, quelqu'un\n s'en chargera plus tard. Les meubles peuvent \u00eatre d\u00e9plac\u00e9s dans une salle\n voisine si tu le souhaites, il faudra juste penser \u00e0 les remettre en place.\n

\n

\n Ensuite dans l'id\u00e9al tu connais tous tes potes, donc en donner une liste \u00e0\n la loge permet d'\u00e9viter quelques probl\u00e8mes et quelques aller-retours.\n Au-del\u00e0 de 21h, les ext\u00e9rieur-e-s ne peuvent rentrer qu'avec un-e Ulmien-ne ayant sa carte\n sur lui-elle.\n

\n\n

Je pourrai passer ma musique ?

\n\n

\n Si le BOUM est pr\u00e9sent, faut voir avec elleux : boum (at) ens (point) fr
\n Sinon, pr\u00e9pare ta musique sur un lecteur mp3 ou une playlist\n Deezer. Lors de la soir\u00e9e,\n demande \u00e0 un-e K-F\u00eat wo-man de passer ce que tu as pr\u00e9par\u00e9.\n

\n\n\n

Et pour ce qui est de la nourriture, des boissons ?

\n

\n Tu peux apporter toute la nourriture que tu souhaites\u00a0; pr\u00e9vois assez\n large, il y a beaucoup de K-F\u00eat people \u00e0 nourrir. Pour ce qui est de la\n boisson, il faut te limiter aux boissons de cat\u00e9gorie 2, c'est \u00e0 dire\n bi\u00e8res, vins et boissons \u00e0 base de vin, champagne et bien s\u00fbr les boissons sans alcool.\n

\n\n

Et pendant la soir\u00e9e ?

\n

\n Ce soir c'est ton soir, il est donc bien s\u00fbr \u00e9vident que tu dois\n rester pr\u00e9sent-e et joignable du d\u00e9but \u00e0 la fin de la soir\u00e9e. Id\u00e9alement ce\n doit aussi \u00eatre le cas de tes \"Responsables ordre et discipline\". Vous ne serez pas\n trop de deux ou trois pour r\u00e9gler les probl\u00e8mes qui pourraient survenir,\n tes potes bourr\u00e9-e-s, tes potes qui fument, tes potes qui font du bordel dans la cage d'escalier,\n etc... Tous les probl\u00e8mes qui pourraient survenir te seront imput\u00e9s donc\n pr\u00e9viens-les, c'est tes potes apr\u00e8s tout, non ?\n

\n\n

Apr\u00e8s c'est bon ?

\n

\n Eh non, pas encore, apr\u00e8s (ou le lendemain de) ta soir\u00e9e il te faudra encore ranger,\n faire le m\u00e9nage et passer un coup de javel. Oui encore, mais bon, pense \u00e0 toutes les fois o\u00f9\n c'est nous qui le faisons pour le bien de tou-te-s. Une fois n'est pas\n coutume demande \u00e0 un-e K-F\u00eat wo-man de t'ouvrir et de te fournir tout le\n mat\u00e9riel dont tu pourrais avoir besoin, et l\u00e0 o\u00f9 c'est vraiment classe\n c'est que tu peux m\u00eame faire \u00e7a en musique si tu le souhaites. N'oublie\n pas non plus de rapporter les meubles que tu pourrais avoir sortis et que\n les poubelles ne disparaissent pas toutes seules.\n

\n\n

Une derni\u00e8re remarque ?

\n\n

\n Ouais, la K-F\u00eat c'est pas chez m\u00e9m\u00e9, alors c'est peut-\u00eatre ta soir\u00e9e mais\n si un-e membre de l'\u00e9quipe K-F\u00eat te dit quelque\n chose (de baisser le son, de virer telle ou telle personne...) tu acceptes avec le sourire.\n En particulier tu ne passes pas derri\u00e8re le bar.\n

\n\n

Je ne parle pas bien fran\u00e7ais, vous pourriez me faire un r\u00e9sum\u00e9 ?

\n

\n Organiser ta soir\u00e9e c'est facile :\n

\n \n

\n Voila, facile, non ?\n

" - }, - "pk": 7 -}, -{ - "model": "kfetcms.kfetpage", - "fields": { - "custom_template": "", - "no_header": false, - "content": "

Et le baby-foot

\n\n

LE flipper

\n\n\n\n

\n\tIl existe en K-F\u00eat une machine unique, inimitable, tout droit venue des\n ann\u00e9es folles et b\u00e9nies o\u00f9 les concepteurs de flippers connaissaient \nencore leur m\u00e9tier, o\u00f9 les tilts \u00e9taient m\u00e9rit\u00e9s et le jeu un art de \nvivre. L'esth\u00e8te appr\u00e9cie et reconna\u00eet imm\u00e9diatement la beaut\u00e9 sobre et \nsauvage de l'Amazon Hunt II. D'admirateur, il se m\u00e9tamorphose \nin\u00e9luctablement en joueur-se, puis en amant-e. Car l'Amazon est une \nfemme, fatale \u00e0 bien des \u00e9gards, tou-te-s les grand-e-s joueur-euse-s \nvous le diront. Dans la pr\u00e9histoire de la K-F\u00eat, des demi-dieux-d\u00e9esses \ndu flipper d\u00e9sormais pass\u00e9-e-s dans la l\u00e9gende ont r\u00e9dig\u00e9 un trait\u00e9 \n(certain-e-s diront une bible, voire la Bible) disponible ici (en pdf).

Le baby-foot

\n\n

\n\t\n

\n\n\n

La d\u00e9funte fun machine

\n\n\n\nCette machine n'est plus. Mais elle reste dans le coeur de ceux qui \nl'ont connue. C'est pourquoi cette section n'a pas \u00e9t\u00e9 retir\u00e9e.

Pour attaquer le cas \u00e9trange de la machine bizarre qui tra\u00eene \u00e0 c\u00f4t\u00e9, \ndisons simplement qu'elle s'appelle Monster Bash. On me souffle en r\u00e9gie\n que pour une fun machine, elle n'est pas si mal. De fait, elle t\u00e9moigne\n d'un humour d\u00e9cal\u00e9, absurde et parfois involontaire : ainsi, la \ntraduction oscille entre le path\u00e9tique et l'ignoble, en passant par le \nburlesque. Le but est de r\u00e9veiller et vaincre six monstres, parmi \nlesquels Dracula et Frankenstein, pour les asservir et les rassembler \ndans le plus grand groupe de rock de l'histoire : les \u00abmonsters of rock\u00bb\n (traduction : \u00abmonstres du rocher\u00bb). Il n'y a pas pour le moment de \ntrait\u00e9 th\u00e9orique de la Monster Bash, la jeu se r\u00e9sumant de toute fa\u00e7on \u00e0\n \u00abmoi voir, moi actionner flip\u00bb. Ce qui n'emp\u00eache pas la machine en \nquestion d'avoir son public d'habitu\u00e9-e-s, bien au contraire. \n

" - }, - "pk": 8 -}, -{ - "model": "kfetcms.kfetpage", - "fields": { - "custom_template": "", - "no_header": false, - "content": "

Responsable de la publication

Informations prestataires

" - }, - "pk": 10 -}, -{ - "model": "kfetcms.kfetpagegroupteam", - "fields": { - "content": "

Les ancien-ne-s Chef-fe-s K-F\u00eat doivent bien \u00eatre pr\u00e9sent\u00e9-e-s avant \nl'\u00e9quipe actuelle. C'est gr\u00e2ce \u00e0 elleux qu'elle tourne encore, gr\u00e2ce \u00e0 \nelleux qu'elle a bien tourn\u00e9, et puis, de pr\u00e8s comme de loin, illes \nveillent encore sur nous. Ce sont les diff\u00e9rentes facettes de la K-F\u00eat \nhistorique, bien que d'un certain point de vue, illes se ressemblent \ntou-te-s : les Chef-fe-s K-F\u00eat sont une dynastie, ils n'ont pas \u00e9t\u00e9 \nChef-fe-s apr\u00e8s avoir prouv\u00e9 quoi que ce soit, illes l'ont \u00e9t\u00e9 parce que\n ce r\u00f4le leur revenait de droit. On na\u00eet Chef-fe K-F\u00eat, on ne le devient\n pas. Et on le reste toujours, dans l'\u00e2me.

", - "sort_order": 0, - "page": 5, - "title": "Les ancien-ne-s Chef-fe-s K-F\u00eat", - "group": 3, - "show_only": 12 - }, - "pk": 1 -}, -{ - "model": "kfetcms.kfetpagegroupteam", - "fields": { - "content": "

Le-la chef-fe K-F\u00eat, celui-celle qui a le droit de vie et de mort sur les \u00e2mes \u00e9gar\u00e9es qui fr\u00e9quentent la K-F\u00eat.

", - "sort_order": 1, - "page": 5, - "title": "Le chef", - "group": 1, - "show_only": null - }, - "pk": 2 -}, -{ - "model": "kfetcms.kfetpagegroupteam", - "fields": { - "content": "

Les K-F\u00eat wo-men poss\u00e8dent les cl\u00e9s de la K-F\u00eat. Ce sont elleux qui peuvent d\u00e9cider ou non d'ouvrir la K-F\u00eat.

", - "sort_order": 2, - "page": 5, - "title": "Les K-F\u00eat Wo-Men", - "group": 2, - "show_only": null - }, - "pk": 3 -}, -{ - "model": "kfetcms.kfetpagegroupteam", - "fields": { - "content": "

Les vieux-illes sont d'ancien-ne-s K-F\u00eat wo-men qui ne viennent plus \naussi souvent qu'avant, illes servent toujours, mais n'ont en g\u00e9n\u00e9ral \nplus les cl\u00e9s. Illes existent n\u00e9anmoins, et on les garde (pour \ncertain-e-s) parce qu'au fond, on les aime quand m\u00eame, et qu'en plus, \nilles en savent plus que n'importe qui sur la K-F\u00eat.

", - "sort_order": 3, - "page": 5, - "title": "Les Vieux-illes", - "group": 4, - "show_only": 12 - }, - "pk": 4 -}, -{ - "model": "kfetcms.groupteam", - "fields": { - "name": "Chef-fe-s" - }, - "pk": 1 -}, -{ - "model": "kfetcms.groupteam", - "fields": { - "name": "Wo-Men" - }, - "pk": 2 -}, -{ - "model": "kfetcms.groupteam", - "fields": { - "name": "Ancien-ne-s chef-fe-s" - }, - "pk": 3 -}, -{ - "model": "kfetcms.groupteam", - "fields": { - "name": "Ancien-ne-s wo-men" - }, - "pk": 4 + "pk": 2, + "model": "wagtailcore.collection" }, { "pk": 1, "model": "kfetcms.memberteam", "fields": { - "sort_order": 0, "first_name": "Hugo", - "group": 1, "nick_name": "", "photo": 3, "last_name": "Manet" @@ -443,9 +312,7 @@ "pk": 2, "model": "kfetcms.memberteam", "fields": { - "sort_order": 1, "first_name": "Lisa", - "group": 1, "nick_name": "", "photo": 4, "last_name": "Gourdon" @@ -455,9 +322,7 @@ "pk": 3, "model": "kfetcms.memberteam", "fields": { - "sort_order": 0, "first_name": "Pierre", - "group": 2, "nick_name": "", "photo": 5, "last_name": "Quesselaire" @@ -467,9 +332,7 @@ "pk": 4, "model": "kfetcms.memberteam", "fields": { - "sort_order": 1, "first_name": "Thibault", - "group": 2, "nick_name": "", "photo": 6, "last_name": "Scoquard" @@ -479,9 +342,7 @@ "pk": 5, "model": "kfetcms.memberteam", "fields": { - "sort_order": 2, "first_name": "Arnaud", - "group": 2, "nick_name": "", "photo": 7, "last_name": "Fanthomme" @@ -491,9 +352,7 @@ "pk": 6, "model": "kfetcms.memberteam", "fields": { - "sort_order": 3, "first_name": "Vincent", - "group": 2, "nick_name": "", "photo": 8, "last_name": "Balerdi" @@ -503,9 +362,7 @@ "pk": 7, "model": "kfetcms.memberteam", "fields": { - "sort_order": 4, "first_name": "Nathana\u00ebl", - "group": 2, "nick_name": "", "photo": 9, "last_name": "Willaime" @@ -515,9 +372,7 @@ "pk": 8, "model": "kfetcms.memberteam", "fields": { - "sort_order": 5, "first_name": "\u00c9lisabeth", - "group": 2, "nick_name": "", "photo": 10, "last_name": "Miller" @@ -527,9 +382,7 @@ "pk": 9, "model": "kfetcms.memberteam", "fields": { - "sort_order": 6, "first_name": "Arthur", - "group": 2, "nick_name": "B2O", "photo": 11, "last_name": "Lesage" @@ -539,9 +392,7 @@ "pk": 10, "model": "kfetcms.memberteam", "fields": { - "sort_order": 7, "first_name": "Sarah", - "group": 2, "nick_name": "", "photo": 12, "last_name": "Asset" @@ -551,9 +402,7 @@ "pk": 11, "model": "kfetcms.memberteam", "fields": { - "sort_order": 8, "first_name": "Alexandre", - "group": 2, "nick_name": "", "photo": 13, "last_name": "Legrand" @@ -563,9 +412,7 @@ "pk": 12, "model": "kfetcms.memberteam", "fields": { - "sort_order": 9, "first_name": "\u00c9tienne", - "group": 2, "nick_name": "", "photo": 14, "last_name": "Baudel" @@ -575,9 +422,7 @@ "pk": 13, "model": "kfetcms.memberteam", "fields": { - "sort_order": 0, "first_name": "Marine", - "group": 3, "nick_name": "", "photo": 15, "last_name": "Snape" @@ -587,9 +432,7 @@ "pk": 14, "model": "kfetcms.memberteam", "fields": { - "sort_order": 1, "first_name": "Anatole", - "group": 3, "nick_name": "", "photo": 16, "last_name": "Gosset" @@ -599,9 +442,7 @@ "pk": 15, "model": "kfetcms.memberteam", "fields": { - "sort_order": 2, "first_name": "Jacko", - "group": 3, "nick_name": "", "photo": 17, "last_name": "Rastikian" @@ -611,9 +452,7 @@ "pk": 16, "model": "kfetcms.memberteam", "fields": { - "sort_order": 3, "first_name": "Alexandre", - "group": 3, "nick_name": "", "photo": 18, "last_name": "Jannaud" @@ -623,9 +462,7 @@ "pk": 17, "model": "kfetcms.memberteam", "fields": { - "sort_order": 4, "first_name": "Aur\u00e9lien", - "group": 3, "nick_name": "", "photo": 19, "last_name": "Delobelle" @@ -635,9 +472,7 @@ "pk": 18, "model": "kfetcms.memberteam", "fields": { - "sort_order": 5, "first_name": "Sylvain", - "group": 3, "nick_name": "", "photo": 20, "last_name": "Douteau" @@ -647,9 +482,7 @@ "pk": 19, "model": "kfetcms.memberteam", "fields": { - "sort_order": 6, "first_name": "Rapha\u00ebl", - "group": 3, "nick_name": "", "photo": 21, "last_name": "Lescanne" @@ -659,9 +492,7 @@ "pk": 20, "model": "kfetcms.memberteam", "fields": { - "sort_order": 7, "first_name": "Romain", - "group": 3, "nick_name": "", "photo": 22, "last_name": "Gourvil" @@ -671,9 +502,7 @@ "pk": 21, "model": "kfetcms.memberteam", "fields": { - "sort_order": 8, "first_name": "Marie", - "group": 3, "nick_name": "", "photo": 23, "last_name": "Labeye" @@ -683,9 +512,7 @@ "pk": 22, "model": "kfetcms.memberteam", "fields": { - "sort_order": 9, "first_name": "Oscar", - "group": 3, "nick_name": "", "photo": 24, "last_name": "Blumberg" @@ -695,9 +522,7 @@ "pk": 23, "model": "kfetcms.memberteam", "fields": { - "sort_order": 10, "first_name": "Za\u00efd", - "group": 3, "nick_name": "", "photo": 25, "last_name": "Allybokus" @@ -707,9 +532,7 @@ "pk": 24, "model": "kfetcms.memberteam", "fields": { - "sort_order": 11, "first_name": "Damien", - "group": 3, "nick_name": "", "photo": 26, "last_name": "Garreau" @@ -719,9 +542,7 @@ "pk": 25, "model": "kfetcms.memberteam", "fields": { - "sort_order": 12, "first_name": "Andr\u00e9a", - "group": 3, "nick_name": "", "photo": 27, "last_name": "Londonez-Lopez" @@ -731,9 +552,7 @@ "pk": 26, "model": "kfetcms.memberteam", "fields": { - "sort_order": 13, "first_name": "Tristan", - "group": 3, "nick_name": "", "photo": 28, "last_name": "Roussel" @@ -743,9 +562,7 @@ "pk": 27, "model": "kfetcms.memberteam", "fields": { - "sort_order": 14, "first_name": "Guillaume", - "group": 3, "nick_name": "", "photo": 29, "last_name": "Vernade" @@ -755,9 +572,7 @@ "pk": 28, "model": "kfetcms.memberteam", "fields": { - "sort_order": 15, "first_name": "Lucas", - "group": 3, "nick_name": "", "photo": 30, "last_name": "Mercier" @@ -767,9 +582,7 @@ "pk": 29, "model": "kfetcms.memberteam", "fields": { - "sort_order": 16, "first_name": "Fran\u00e7ois", - "group": 3, "nick_name": "M\u00e9talleux", "photo": 31, "last_name": "Maillot" @@ -779,14 +592,89 @@ "pk": 30, "model": "kfetcms.memberteam", "fields": { - "sort_order": 17, "first_name": "Fabrice", - "group": 3, "nick_name": "", "photo": 32, "last_name": "Catoire" } }, +{ + "pk": 3, + "model": "kfetcms.kfetpage", + "fields": { + "main_size": "", + "content": "[{\"value\": \"

La K-F\\u00eat, c'est quoi ?

\\n\\n

\\n Eh bien la K-F\\u00eat, c'est le bar des \\u00e9l\\u00e8ves de l'\\u00c9cole normale\\n sup\\u00e9rieure. Elle est situ\\u00e9e dans les locaux de l'\\u00c9cole, au pied de\\n l'escalier C (plan). On y trouve \\u00e0 boire, bien s\\u00fbr,\\n des bi\\u00e8res en nombre pl\\u00e9thorique mais aussi caf\\u00e9s, th\\u00e9s, softs et de quoi\\n grignoter. Ah oui un point important, on ne va pas \\u00e0 la K-F\\u00eat, on va EN K-F\\u00eat.\\n

\", \"type\": \"rich\"}, {\"value\": \"

Mais on n'y fait que boire et manger ?

\\n\\n

\\n Que nenni, \\u00f4 jeune et innocent conscrit-e ! La K-F\\u00eat n'est pas un bouge\\n sordide o\\u00f9 des piliers de bar passent leurs journ\\u00e9es \\u00e0 picoler. Enfin pas\\n uniquement. C'est aussi un lieu de divertissement avec\\n son flipper (la mythique, la seule, l'unique,\\n la g\\u00e9niale Amazon Hunt), son baby-foot et le lieu d'\\u00e9lection des \\nbridgeur-se-s, du club jeux, des joueur-se-s de poker voire des quelques\\n irr\\u00e9ductibles du boulot qui y viennent bosser en profitant du point \\nd'acc\\u00e8s wifi. \\n

\", \"type\": \"rich\"}, {\"value\": \"

Ah \\u00e7a a l'air bien mais... qui s'en occupe ? C'est ouvert quand ?

\\n\\n

\\n L'\\u00e9quipe d'\\u00e9l\\u00e8ves motiv\\u00e9-e-s qui s'occupent de la K-F\\u00eat s'appelle, en toute logique, l'\\u00e9quipe K-F\\u00eat.\\n Elle est men\\u00e9e par un-e leader charismatique et bien-aim\\u00e9-e, \\naccompagn\\u00e9-e de ses troupes de fid\\u00e8les, les K-F\\u00eat wo-men, boys et girls.\\n Le local de la K-F\\u00eat n'est ouvert que si un-e K-F\\u00eat wo-man est \\npr\\u00e9sente. \\u00c0 savoir la plupart du temps entre 12h et 3h du matin.\\n

\", \"type\": \"rich\"}, {\"value\": \"

Et je peux y faire ce que je veux ?

\\n\\n

\\n Oui et non. Nous ne sommes pas ta grand-m\\u00e8re et nous n'allons\\n certainement pas t'emp\\u00eacher de faire la f\\u00eate, ni de d\\u00e9guster des pintes\\n jusqu'au petit p\\u00f4t. Par contre nous attendons de toi que tu ne sois pas\\n un-e gros-se con-ne. A priori pas de raison de le croire, mais jette tout de m\\u00eame\\n un \\u0153il sur le mode d'emploi de la K-F\\u00eat, \\u00e7a\\n pourrait t'\\u00e9viter de perdre un genoux ou deux...\\n

\", \"type\": \"rich\"}, {\"value\": \"

J'adore la K-F\\u00eat, j'aimerais y organiser une soir\\u00e9e, c'est possible ?

\\n\\n

\\n Bien s\\u00fbr\\u00a0! Pour cela commence par lire ce petit\\n guide histoire de savoir dans quoi tu t'engages puis contacte ton-ta chef-fe K-F\\u00eat ador\\u00e9-e pour v\\u00e9rifier que la date de ta\\n soir\\u00e9e n'est pas d\\u00e9j\\u00e0 prise par une autre f\\u00eate et obtenir son\\n accord.\\n

\", \"type\": \"rich\"}, {\"value\": \"

J'ai une question \\u00e0 vous poser. O\\u00f9 puis-je vous contacter ?

\\n\\n

\\n Commence d\\u00e9j\\u00e0 par jeter un oeil sur le mode\\n d'emploi de la K-F\\u00eat. Si la r\\u00e9ponse \\u00e0 tes interrogations ne s'y\\n trouve pas, rien n'est perdu. En effet le service informatique de \\nl'\\u00c9cole, dans sa grande mansu\\u00e9tude, a mis \\u00e0 disposition de l'\\u00e9quipe \\nK-F\\u00eat une adresse e-mail, k-fet@ens.fr. Mais sinon, passe en K-F\\u00eat, il y aura sans doute un K-F\\u00eat wo-man qui saura r\\u00e9pondre \\u00e0 ta question.\\n

\", \"type\": \"rich\"}]", + "layout": "kfet/base_col_mult.html", + "no_header": false, + "col_count": "" + } +}, +{ + "pk": 4, + "model": "kfetcms.kfetpage", + "fields": { + "main_size": "", + "content": "[{\"value\": \"

Article 0 : La K-F\\u00eat n'existe pas.

\", \"type\": \"rich\"}, {\"value\": \"

La K-F\\u00eat, c'est magique, comment \\u00e7a marche ?

La K-F\\u00eat n'a \\nrien de magique, il n'y a pas de petits d\\u00e9mons qui font le m\\u00e9nage, pas \\nplus que d'arbustes g\\u00e9n\\u00e9tiquement modifi\\u00e9s aux OGM sur lesquels poussent\\n les bouteilles de bi\\u00e8res. La K-F\\u00eat c'est avant tout une \\u00e9quipe qui sacrifie une partie de son temps libre pour que tout se passe pour le mieux.

\", \"type\": \"rich\"}, {\"value\": \"

Que puis-je faire pour vous aider un peu ?

D\\u00e9j\\u00e0 ne pas poser \\nde probl\\u00e8mes, c'est \\u00e0 dire ne pas r\\u00e9veiller tout l'internat en sortant, \\nessayer de ne pas finir dans un \\u00e9tat trop avanc\\u00e9 d'alcoolisation, etc...\\n Mine de rien \\u00e7a nous \\u00e9viterait quelques probl\\u00e8mes.

Ensuite, comme\\n tu le sais s\\u00fbrement les bi\\u00e8res sont consign\\u00e9es, il est donc pr\\u00e9f\\u00e9rable \\npour nous que tu n'embarques pas les bouteilles en souvenir dans ta \\nthurne. Mieux, tu peux nous faire gagner du temps de rangement en les \\nramenant au bar en partant. Et encore mieux, tu peux jeter tes d\\u00e9chets \\n(gobelets, boite de pringles, etc...). Si tu fais d\\u00e9j\\u00e0 tout \\u00e7a tu nous \\nsimplifieras grandement la vie.

\", \"type\": \"rich\"}, {\"value\": \"

Le syst\\u00e8me mon\\u00e9taire de la K-F\\u00eat

En bon \\u00e9tat souverain et \\nind\\u00e9pendant, la K-F\\u00eat a sa propre monnaie : l'unit\\u00e9 K-F\\u00eat (UKF). Elle \\nvaut 10 centimes d'euro. La K-F\\u00eat ne battant pas monnaie, les UKF que tu\\n poss\\u00e8des sont not\\u00e9es sur ton compte, identifi\\u00e9 par un trigramme (une \\nsuite de trois caract\\u00e8res) et que tu peux recharger en liquide ou par \\nch\\u00e8que. Note que si tu y tiens vraiment, tu peux payer en liquide, mais \\nposs\\u00e9der un compte est bien plus pratique.

\", \"type\": \"rich\"}, {\"value\": \"

Comment commander \\u00e0 boire ou \\u00e0 manger ?

Pour commander \\u00e0 boire ou \\u00e0 manger, il suffit de demander \\u00e0 un membre de l'\\u00e9quipe K-F\\u00eat.\\n Et \\u00e7a marche encore mieux si la demande est effectu\\u00e9e avec le sourire \\nau d\\u00e9but et un merci \\u00e0 la fin : l'\\u00e9quipe est constitu\\u00e9e de volontaires \\nb\\u00e9n\\u00e9voles, et mieux vaut ne pas les prendre pour des chiens. EN AUCUN \\nCAS on ne passe derri\\u00e8re le bar si on n'est pas membre de l'\\u00e9quipe K-F\\u00eat.

\", \"type\": \"rich\"}, {\"value\": \"

Puis-je fumer en K-F\\u00eat ?

Non ! Imagine-toi les jours de \\nsoir\\u00e9es, la K-F\\u00eat remplie et tout le monde qui fume... On finirait tous \\navec des poumons aussi crades que le sol de la K-F\\u00eat. Ce serait quand \\nm\\u00eame dommage pour la recherche fran\\u00e7aise qu'on cr\\u00e8ve tous avant 30 ans, \\nnon ?

Par contre tu peux fumer dehors, il y a m\\u00eame des cendriers \\njuste pour toi, par contre tu remarqueras que les chambres de l'internat\\n se trouvent juste au dessus de toi. T\\u00e2che donc de ne pas faire trop de \\nbruit.

\", \"type\": \"rich\"}, {\"value\": \"

Et amener ma propre bouteille ?

D\\u00e9j\\u00e0 c'est apporter, enfin en\\n tout cas avant de la boire. Ensuite la K-F\\u00eat est un lieu de \\nconvivialit\\u00e9 o\\u00f9 les bi\\u00e8res te sont vendues au prix co\\u00fbtant,\\n franchement ce serait pas fair-play de te la jouer solo. Alors \\n\\u00e9videment il y a des exceptions, par exemple si tu reviens de Belgique \\net que tu veux faire go\\u00fbter de la Wesvleteren \\u00e0 tes amis de l'\\u00e9quipe K-F\\u00eat,\\n ou si tu veux organiser une d\\u00e9gustation de vins avec la charcuterie qui\\n va bien. Tu comprendras qu'un pack de Kro c'est quand m\\u00eame pas la m\\u00eame \\nclasse...

\", \"type\": \"rich\"}, {\"value\": \"

Je peux passer ma musique ?

Bien s\\u00fbr, nous sommes tr\\u00e8s loin \\nde penser tout conna\\u00eetre en mati\\u00e8re de musique. Mais comme nous sommes \\nentre gens civilis\\u00e9s, et que je te rappelle que tu n'as pas le droit de \\npasser derri\\u00e8re le bar, il convient de demander \\u00e0 un-e membre de l'\\u00e9quipe K-F\\u00eat\\n afin qu'ille t'indique qui est \\u00e0 l'origine de ces chansons que tu \\nn'appr\\u00e9cies apparemment pas. Apr\\u00e8s avoir obtenu son accord tu peux \\ndemander \\u00e0 quelqu'un de mettre ta playlist, qui peut-\\u00eatre sur un lecteur\\n mp3, sur Deezer ou juste sur l'ordi, mais dans ce dernier cas ce sera plus dur puisque tu n'y aura pas acc\\u00e8s directement.

Le plus simple pour toi (et pour nous) est donc de pr\\u00e9voir des playlists sur Deezer\\n d'avance et de nous les proposer. Par contre, sois gentil-le, n'insiste\\n pas si nous ne voulons pas de ta musique traditionnelle hongroise. Par \\nailleurs, si un trop grand nombre de personnes nous demande de passer de\\n la musique, l'\\u00e9quipe K-F\\u00eat peut ne pas acc\\u00e9der \\u00e0 ta requ\\u00eate.

\", \"type\": \"rich\"}, {\"value\": \"

Comment organiser une soir\\u00e9e en K-F\\u00eat ?

Tout membre du COF \\npeut organiser une soir\\u00e9e en K-F\\u00eat \\u00e0 la condition qu'elle soit publique \\net annonc\\u00e9e une semaine \\u00e0 l'avance par des affiches dans l'\\u00e9cole et un \\nmot dans le BOcal. Il faut bien sur aussi l'accord du COF qui s'occupe \\nde voir si \\u00e7a ne pose pas de probl\\u00e8me \\u00e0 l'admin, celui de la K-F\\u00eat team \\npour qu'il y ait des K-F\\u00eat wo-men pour servir et s\\u00fbrement du BOUM pour \\nqu'il s'occupe de la musique. Nous t'avons tout r\\u00e9sum\\u00e9 ici\\n ; merci qui ? Une fois que tu as accompli ces formalit\\u00e9s, il ne te \\nreste plus qu'\\u00e0 imprimer et coller des affiches pour que ta soir\\u00e9e soit \\nun succ\\u00e8s !

\", \"type\": \"rich\"}, {\"value\": \"

D'autres remarques ?

Des tonnes, en voici quelques unes :

\", \"type\": \"rich\"}]", + "layout": "kfet/base_col_mult.html", + "no_header": false, + "col_count": "" + } +}, +{ + "pk": 5, + "model": "kfetcms.kfetpage", + "fields": { + "main_size": "", + "content": "[{\"value\": [{\"value\": \"

Les ancien-ne-s Chef-fe-s K-F\\u00eat

Les ancien-ne-s Chef-fe-s K-F\\u00eat doivent bien \\u00eatre pr\\u00e9sent\\u00e9-e-s avant \\nl'\\u00e9quipe actuelle. C'est gr\\u00e2ce \\u00e0 elleux qu'elle tourne encore, gr\\u00e2ce \\u00e0 \\nelleux qu'elle a bien tourn\\u00e9, et puis, de pr\\u00e8s comme de loin, illes \\nveillent encore sur nous. Ce sont les diff\\u00e9rentes facettes de la K-F\\u00eat \\nhistorique, bien que d'un certain point de vue, illes se ressemblent \\ntou-te-s : les Chef-fe-s K-F\\u00eat sont une dynastie, ils n'ont pas \\u00e9t\\u00e9 \\nChef-fe-s apr\\u00e8s avoir prouv\\u00e9 quoi que ce soit, illes l'ont \\u00e9t\\u00e9 parce que\\n ce r\\u00f4le leur revenait de droit. On na\\u00eet Chef-fe K-F\\u00eat, on ne le devient\\n pas. Et on le reste toujours, dans l'\\u00e2me.

\", \"type\": \"rich\"}, {\"value\": {\"members\": [13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30], \"show_only\": 12}, \"type\": \"group_team\"}], \"type\": \"group\"}, {\"value\": [{\"value\": \"

Le chef

Le-la chef-fe K-F\\u00eat, celui-celle qui a le droit de vie et de mort sur les \\u00e2mes \\u00e9gar\\u00e9es qui fr\\u00e9quentent la K-F\\u00eat.

\", \"type\": \"rich\"}, {\"value\": {\"members\": [1, 2], \"show_only\": null}, \"type\": \"group_team\"}], \"type\": \"group\"}, {\"value\": [{\"value\": \"

Les K-F\\u00eat Wo-Men

Les K-F\\u00eat wo-men poss\\u00e8dent les cl\\u00e9s de la K-F\\u00eat. Ce sont elleux qui peuvent d\\u00e9cider ou non d'ouvrir la K-F\\u00eat.

\", \"type\": \"rich\"}, {\"value\": {\"members\": [3, 4, 5, 6, 7, 8, 9, 10, 11, 12], \"show_only\": null}, \"type\": \"group_team\"}], \"type\": \"group\"}, {\"value\": [{\"value\": \"

Les Vieux-illes

Les vieux-illes sont d'ancien-ne-s K-F\\u00eat wo-men qui ne viennent plus \\naussi souvent qu'avant, illes servent toujours, mais n'ont en g\\u00e9n\\u00e9ral \\nplus les cl\\u00e9s. Illes existent n\\u00e9anmoins, et on les garde (pour \\ncertain-e-s) parce qu'au fond, on les aime quand m\\u00eame, et qu'en plus, \\nilles en savent plus que n'importe qui sur la K-F\\u00eat.

\", \"type\": \"rich\"}], \"type\": \"group\"}, {\"value\": \"

Les K-F\\u00eat boys et girls

\\n\\n

Les K-F\\u00eat boys and girls font de main d'\\u0153uvre bon march\\u00e9 pour la \\nK-F\\u00eat, illes peuvent passer derri\\u00e8re le bar, prendre vos commandes et \\nrecharger votre compte si par malheur il est \\u00e0 sec. La liste de \\ncelleux-ci est trop longue pour tou-te-s les citer, pour les reconna\\u00eetre\\n regarde les gens qui passent derri\\u00e8re le bar tout en conservant leur \\nint\\u00e9grit\\u00e9 physique.

\", \"type\": \"rich\"}, {\"value\": \"

Comment devient-on K-F\\u00eat people ?

Grande question que tout le monde se pose un jour ou l'autre. Pour \\nacc\\u00e9der au titre prestigieux de K-F\\u00eat boy-girl, il est n\\u00e9cessaire mais \\npas suffisant d'\\u00eatre assid\\u00fbment pr\\u00e9sent-e en K-F\\u00eat, et d'\\u00eatre pr\\u00eat-e \\u00e0 \\ntrimer pour elle. Si tu es souvent en K-F\\u00eat, que tu es sympathique et \\nmotiv\\u00e9-e, et surtout en fin de compte si le-la chef-fe le veut bien, tu \\npourras devenir K-F\\u00eat boy-girl et passer derri\\u00e8re le bar pour servir. \\nEnsuite, si tu es motiv\\u00e9-e et efficace, ou simplement si t'es un-e pote \\ndu-de la chef-fe et qu'ille n'a aucun scrupule, tu pourras devenir K-F\\u00eat\\n wo-man et avoir la cl\\u00e9.

Et comme la K-F\\u00eat c'est avant tout beaucoup d'emmerdes on a pas envie\\n de te forcer la main, on veut que cela vienne de toi. Donc si tu te \\nsens pr\\u00eat-e \\u00e0 participer \\u00e0 la vie mouvement\\u00e9e de la K-F\\u00eat fais-en part \\nau-\\u00e0 la chef-fe. Ille ne va pas te manger.

\", \"type\": \"rich\"}]", + "layout": "kfet/base_col_mult.html", + "no_header": false, + "col_count": "" + } +}, +{ + "pk": 6, + "model": "kfetcms.kfetpage", + "fields": { + "main_size": "", + "content": "[{\"value\": \"

Le service de la bi\\u00e8re est, historiquement, la mission et le sacerdoce \\ndu K-F\\u00eat people. Ille y est d\\u00e9vou\\u00e9-e corps et \\u00e2me, et accomplit sa t\\u00e2che\\n avec ardeur et passion. Voyons comment se d\\u00e9clinent les occasions \\nd'approcher du nirvana brassicole. Les prix donn\\u00e9s sont en UKF. Si tu \\nn'as pas compris, va voir par ici.

\", \"type\": \"rich\"}, {\"value\": null, \"type\": \"carte\"}]", + "layout": "kfet/base_col_mult.html", + "no_header": false, + "col_count": "column-md-2 column-lg-3" + } +}, +{ + "pk": 7, + "model": "kfetcms.kfetpage", + "fields": { + "main_size": "", + "content": "[{\"value\": \"

Tu veux organiser une soir\\u00e9e en K-F\\u00eat ? Pas de probl\\u00e8me !

\", \"type\": \"rich\"}, {\"value\": \"

Quand puis-je organiser une soir\\u00e9e ?

\\n\\n

\\n Tu peux organiser une soir\\u00e9e le jour que tu souhaites, \\u00e0 condition que la\\n date ne soit pas d\\u00e9j\\u00e0 prise par quelqu'un d'autre. Sache par contre que la\\n K-F\\u00eat ne te sera pas enti\\u00e8rement d\\u00e9di\\u00e9e et que les utilisateur-rice-s habituel-le-s\\n continueront de la fr\\u00e9quenter (et risquent fortement de squatter ta\\n soir\\u00e9e). Donc si tu veux un peu d'intimit\\u00e9 les soir\\u00e9es du week-end sont plus\\n conseill\\u00e9es (mais l'\\u00e9quipe risque de ne pas \\u00eatre pr\\u00e9sente), mais aussi\\n plus pris\\u00e9es, d\\u00e9p\\u00eache-toi de r\\u00e9server la tienne.\\n

\", \"type\": \"rich\"}, {\"value\": \"

Quelles d\\u00e9marches dois-je effectuer ?

\\n

\\n D\\u00e9j\\u00e0 pr\\u00e9venir poliment l'\\u00e9quipe K-F\\u00eat, et\\n surtout le-la chef-fe pour v\\u00e9rifier que la date est encore libre, et qu'il y\\n aura au moins quelqu'un pour t'ouvrir la K-F\\u00eat. Ensuite, si ta soir\\u00e9e\\n n'est pas une simple bouffe qui finit avant minuit il faut pr\\u00e9venir les\\n vigiles via l'administration au moyen d'une demande d'autorisation de\\n soir\\u00e9e qui se trouve sur la section du p\\u00f4le Pr\\u00e9vention et S\\u00e9curit\\u00e9 sur l'intranet : demande d'autorisation de soir\\u00e9e.\\n \\u00c0 faire au moins une semaine avant ta soir\\u00e9e.\\n

\\n

\\n Si en plus tu as besoin que le BOUM s'occupe de la musique et/ou PLS des\\n lumi\\u00e8res c'est elleux qu'il faut contacter. Histoire de t'\\u00e9viter\\n d'avoir \\u00e0 chercher voici leur adresse\\u00a0: boum (at) ens (point) fr\\n et pls (at) ens (point) fr.\\n

\", \"type\": \"rich\"}, {\"value\": \"

C'est enfin le grand jour, je fais quoi ?

\\n

\\n D\\u00e9j\\u00e0 le m\\u00e9nage, oui je sais c'est chiant mais c'est le prix \\u00e0 payer pour\\n profiter du local. Demande \\u00e0 ce qu'un-e K-F\\u00eat wo-man t'ouvre et tu devrais avoir\\n \\u00e0 ta disposition tout ce qu'il faut pour faire briller la K-F\\u00eat (ou au moins on essaiera de\\n trouver ce qu'il faut). Fais par\\n contre attention aux bouteilles de bi\\u00e8re qui sont consign\\u00e9es, s'il n'y a\\n personne pour les ranger contente-toi de les mettre sur le bar, quelqu'un\\n s'en chargera plus tard. Les meubles peuvent \\u00eatre d\\u00e9plac\\u00e9s dans une salle\\n voisine si tu le souhaites, il faudra juste penser \\u00e0 les remettre en place.\\n

\\n

\\n Ensuite dans l'id\\u00e9al tu connais tous tes potes, donc en donner une liste \\u00e0\\n la loge permet d'\\u00e9viter quelques probl\\u00e8mes et quelques aller-retours.\\n Au-del\\u00e0 de 21h, les ext\\u00e9rieur-e-s ne peuvent rentrer qu'avec un-e Ulmien-ne ayant sa carte\\n sur lui-elle.\\n

\", \"type\": \"rich\"}, {\"value\": \"

Je pourrai passer ma musique ?

\\n\\n

\\n Si le BOUM est pr\\u00e9sent, faut voir avec elleux : boum (at) ens (point) fr
\\n Sinon, pr\\u00e9pare ta musique sur un lecteur mp3 ou une playlist\\n Deezer. Lors de la soir\\u00e9e,\\n demande \\u00e0 un-e K-F\\u00eat wo-man de passer ce que tu as pr\\u00e9par\\u00e9.\\n

\", \"type\": \"rich\"}, {\"value\": \"

Et pour ce qui est de la nourriture, des boissons ?

\\n

\\n Tu peux apporter toute la nourriture que tu souhaites\\u00a0; pr\\u00e9vois assez\\n large, il y a beaucoup de K-F\\u00eat people \\u00e0 nourrir. Pour ce qui est de la\\n boisson, il faut te limiter aux boissons de cat\\u00e9gorie 2, c'est \\u00e0 dire\\n bi\\u00e8res, vins et boissons \\u00e0 base de vin, champagne et bien s\\u00fbr les boissons sans alcool.\\n

\", \"type\": \"rich\"}, {\"value\": \"

Et pendant la soir\\u00e9e ?

\\n

\\n Ce soir c'est ton soir, il est donc bien s\\u00fbr \\u00e9vident que tu dois\\n rester pr\\u00e9sent-e et joignable du d\\u00e9but \\u00e0 la fin de la soir\\u00e9e. Id\\u00e9alement ce\\n doit aussi \\u00eatre le cas de tes \\\"Responsables ordre et discipline\\\". Vous ne serez pas\\n trop de deux ou trois pour r\\u00e9gler les probl\\u00e8mes qui pourraient survenir,\\n tes potes bourr\\u00e9-e-s, tes potes qui fument, tes potes qui font du bordel dans la cage d'escalier,\\n etc... Tous les probl\\u00e8mes qui pourraient survenir te seront imput\\u00e9s donc\\n pr\\u00e9viens-les, c'est tes potes apr\\u00e8s tout, non ?\\n

\", \"type\": \"rich\"}, {\"value\": \"

Apr\\u00e8s c'est bon ?

\\n

\\n Eh non, pas encore, apr\\u00e8s (ou le lendemain de) ta soir\\u00e9e il te faudra encore ranger,\\n faire le m\\u00e9nage et passer un coup de javel. Oui encore, mais bon, pense \\u00e0 toutes les fois o\\u00f9\\n c'est nous qui le faisons pour le bien de tou-te-s. Une fois n'est pas\\n coutume demande \\u00e0 un-e K-F\\u00eat wo-man de t'ouvrir et de te fournir tout le\\n mat\\u00e9riel dont tu pourrais avoir besoin, et l\\u00e0 o\\u00f9 c'est vraiment classe\\n c'est que tu peux m\\u00eame faire \\u00e7a en musique si tu le souhaites. N'oublie\\n pas non plus de rapporter les meubles que tu pourrais avoir sortis et que\\n les poubelles ne disparaissent pas toutes seules.\\n

\", \"type\": \"rich\"}, {\"value\": \"

Une derni\\u00e8re remarque ?

\\n\\n

\\n Ouais, la K-F\\u00eat c'est pas chez m\\u00e9m\\u00e9, alors c'est peut-\\u00eatre ta soir\\u00e9e mais\\n si un-e membre de l'\\u00e9quipe K-F\\u00eat te dit quelque\\n chose (de baisser le son, de virer telle ou telle personne...) tu acceptes avec le sourire.\\n En particulier tu ne passes pas derri\\u00e8re le bar.\\n

\", \"type\": \"rich\"}, {\"value\": \"

Je ne parle pas bien fran\\u00e7ais, vous pourriez me faire un r\\u00e9sum\\u00e9 ?

\\n

\\n Organiser ta soir\\u00e9e c'est facile :\\n

\\n \\n

\\n Voila, facile, non ?\\n

\", \"type\": \"rich\"}]", + "layout": "kfet/base_col_mult.html", + "no_header": false, + "col_count": "" + } +}, +{ + "pk": 8, + "model": "kfetcms.kfetpage", + "fields": { + "main_size": "", + "content": "[{\"value\": \"

Et le baby-foot

\", \"type\": \"rich\"}, {\"value\": \"

LE flipper

\\n\\n\\n\\n

\\n\\tIl existe en K-F\\u00eat une machine unique, inimitable, tout droit venue des\\n ann\\u00e9es folles et b\\u00e9nies o\\u00f9 les concepteurs de flippers connaissaient \\nencore leur m\\u00e9tier, o\\u00f9 les tilts \\u00e9taient m\\u00e9rit\\u00e9s et le jeu un art de \\nvivre. L'esth\\u00e8te appr\\u00e9cie et reconna\\u00eet imm\\u00e9diatement la beaut\\u00e9 sobre et \\nsauvage de l'Amazon Hunt II. D'admirateur, il se m\\u00e9tamorphose \\nin\\u00e9luctablement en joueur-se, puis en amant-e. Car l'Amazon est une \\nfemme, fatale \\u00e0 bien des \\u00e9gards, tou-te-s les grand-e-s joueur-euse-s \\nvous le diront. Dans la pr\\u00e9histoire de la K-F\\u00eat, des demi-dieux-d\\u00e9esses \\ndu flipper d\\u00e9sormais pass\\u00e9-e-s dans la l\\u00e9gende ont r\\u00e9dig\\u00e9 un trait\\u00e9 \\n(certain-e-s diront une bible, voire la Bible).

\", \"type\": \"rich\"}, {\"value\": \"

Le baby-foot

\", \"type\": \"rich\"}, {\"value\": \"

La d\\u00e9funte fun machine

\\n\\n\\n\\nCette machine n'est plus. Mais elle reste dans le coeur de ceux qui \\nl'ont connue. C'est pourquoi cette section n'a pas \\u00e9t\\u00e9 retir\\u00e9e.

Pour attaquer le cas \\u00e9trange de la machine bizarre qui tra\\u00eene \\u00e0 c\\u00f4t\\u00e9, \\ndisons simplement qu'elle s'appelle Monster Bash. On me souffle en r\\u00e9gie\\n que pour une fun machine, elle n'est pas si mal. De fait, elle t\\u00e9moigne\\n d'un humour d\\u00e9cal\\u00e9, absurde et parfois involontaire : ainsi, la \\ntraduction oscille entre le path\\u00e9tique et l'ignoble, en passant par le \\nburlesque. Le but est de r\\u00e9veiller et vaincre six monstres, parmi \\nlesquels Dracula et Frankenstein, pour les asservir et les rassembler \\ndans le plus grand groupe de rock de l'histoire : les \\u00abmonsters of rock\\u00bb\\n (traduction : \\u00abmonstres du rocher\\u00bb). Il n'y a pas pour le moment de \\ntrait\\u00e9 th\\u00e9orique de la Monster Bash, la jeu se r\\u00e9sumant de toute fa\\u00e7on \\u00e0\\n \\u00abmoi voir, moi actionner flip\\u00bb. Ce qui n'emp\\u00eache pas la machine en \\nquestion d'avoir son public d'habitu\\u00e9-e-s, bien au contraire. \\n

\", \"type\": \"rich\"}]", + "layout": "kfet/base_col_mult.html", + "no_header": false, + "col_count": "" + } +}, +{ + "pk": 10, + "model": "kfetcms.kfetpage", + "fields": { + "main_size": "", + "content": "[{\"value\": \"

Responsable de la publication

\", \"type\": \"rich\"}, {\"value\": \"

Informations prestataires

\", \"type\": \"rich\"}]", + "layout": "kfet/base_col_mult.html", + "no_header": false, + "col_count": "" + } +}, { "model": "wagtaildocs.document", "pk": 1, @@ -795,7 +683,7 @@ "uploaded_by_user": [ "root" ], - "collection": 1, + "collection": 2, "title": "K-F\u00eat - Plan d'acc\u00e8s", "file": "documents/kfet_acces.pdf" } @@ -808,7 +696,7 @@ "uploaded_by_user": [ "root" ], - "collection": 1, + "collection": 2, "title": "K-F\u00eat - Demande d'autorisation", "file": "documents/kfet_autorisation.pdf" } @@ -821,7 +709,7 @@ "uploaded_by_user": [ "root" ], - "collection": 1, + "collection": 2, "title": "K-F\u00eat - Trait\u00e9 de Flipper Th\u00e9orique", "file": "documents/kfet_flipper.pdf" } @@ -834,7 +722,7 @@ "focal_point_width": null, "height": 300, "file": "original_images/kfet_amazon.jpg", - "collection": 1, + "collection": 2, "focal_point_x": null, "file_size": null, "focal_point_height": null, @@ -854,7 +742,7 @@ "focal_point_width": null, "height": 300, "file": "original_images/kfet_funmachine.jpg", - "collection": 1, + "collection": 2, "focal_point_x": null, "file_size": null, "focal_point_height": null, @@ -877,7 +765,7 @@ "focal_point_width": null, "focal_point_y": null, "title": "Hugo Manet", - "collection": 1, + "collection": 2, "uploaded_by_user": [ "root" ], @@ -897,7 +785,7 @@ "focal_point_width": null, "focal_point_y": null, "title": "Lisa Gourdon", - "collection": 1, + "collection": 2, "uploaded_by_user": [ "root" ], @@ -917,7 +805,7 @@ "focal_point_width": null, "focal_point_y": null, "title": "Pierre Quesselaire", - "collection": 1, + "collection": 2, "uploaded_by_user": [ "root" ], @@ -937,7 +825,7 @@ "focal_point_width": null, "focal_point_y": null, "title": "Thibault Scoquard", - "collection": 1, + "collection": 2, "uploaded_by_user": [ "root" ], @@ -957,7 +845,7 @@ "focal_point_width": null, "focal_point_y": null, "title": "Arnaud Fanthomme", - "collection": 1, + "collection": 2, "uploaded_by_user": [ "root" ], @@ -977,7 +865,7 @@ "focal_point_width": null, "focal_point_y": null, "title": "Vincent Balerdi", - "collection": 1, + "collection": 2, "uploaded_by_user": [ "root" ], @@ -997,7 +885,7 @@ "focal_point_width": null, "focal_point_y": null, "title": "Nathana\u00ebl Willaime", - "collection": 1, + "collection": 2, "uploaded_by_user": [ "root" ], @@ -1017,7 +905,7 @@ "focal_point_width": null, "focal_point_y": null, "title": "\u00c9lisabeth Miller", - "collection": 1, + "collection": 2, "uploaded_by_user": [ "root" ], @@ -1037,7 +925,7 @@ "focal_point_width": null, "focal_point_y": null, "title": "Arthur Lesage", - "collection": 1, + "collection": 2, "uploaded_by_user": [ "root" ], @@ -1057,7 +945,7 @@ "focal_point_width": null, "focal_point_y": null, "title": "Sarah Asset", - "collection": 1, + "collection": 2, "uploaded_by_user": [ "root" ], @@ -1077,7 +965,7 @@ "focal_point_width": null, "focal_point_y": null, "title": "Alexandre Legrand", - "collection": 1, + "collection": 2, "uploaded_by_user": [ "root" ], @@ -1097,7 +985,7 @@ "focal_point_width": null, "focal_point_y": null, "title": "\u00c9tienne Baudel", - "collection": 1, + "collection": 2, "uploaded_by_user": [ "root" ], @@ -1117,7 +1005,7 @@ "focal_point_width": null, "focal_point_y": null, "title": "Marine Snape", - "collection": 1, + "collection": 2, "uploaded_by_user": [ "root" ], @@ -1137,7 +1025,7 @@ "focal_point_width": null, "focal_point_y": null, "title": "Anatole Gosset", - "collection": 1, + "collection": 2, "uploaded_by_user": [ "root" ], @@ -1157,7 +1045,7 @@ "focal_point_width": null, "focal_point_y": null, "title": "Jacko Rastikian", - "collection": 1, + "collection": 2, "uploaded_by_user": [ "root" ], @@ -1177,7 +1065,7 @@ "focal_point_width": null, "focal_point_y": null, "title": "Alexandre Jannaud", - "collection": 1, + "collection": 2, "uploaded_by_user": [ "root" ], @@ -1197,7 +1085,7 @@ "focal_point_width": null, "focal_point_y": null, "title": "Aur\u00e9lien Delobelle", - "collection": 1, + "collection": 2, "uploaded_by_user": [ "root" ], @@ -1217,7 +1105,7 @@ "focal_point_width": null, "focal_point_y": null, "title": "Sylvain Douteau", - "collection": 1, + "collection": 2, "uploaded_by_user": [ "root" ], @@ -1237,7 +1125,7 @@ "focal_point_width": null, "focal_point_y": null, "title": "Rapha\u00ebl Lescanne", - "collection": 1, + "collection": 2, "uploaded_by_user": [ "root" ], @@ -1257,7 +1145,7 @@ "focal_point_width": null, "focal_point_y": null, "title": "Romain Gourvil", - "collection": 1, + "collection": 2, "uploaded_by_user": [ "root" ], @@ -1277,7 +1165,7 @@ "focal_point_width": null, "focal_point_y": null, "title": "Marie Labeye", - "collection": 1, + "collection": 2, "uploaded_by_user": [ "root" ], @@ -1297,7 +1185,7 @@ "focal_point_width": null, "focal_point_y": null, "title": "Oscar Blumberg", - "collection": 1, + "collection": 2, "uploaded_by_user": [ "root" ], @@ -1317,7 +1205,7 @@ "focal_point_width": null, "focal_point_y": null, "title": "Za\u00efd Allybokus", - "collection": 1, + "collection": 2, "uploaded_by_user": [ "root" ], @@ -1337,7 +1225,7 @@ "focal_point_width": null, "focal_point_y": null, "title": "Damien Garreau", - "collection": 1, + "collection": 2, "uploaded_by_user": [ "root" ], @@ -1357,7 +1245,7 @@ "focal_point_width": null, "focal_point_y": null, "title": "Andr\u00e9a Londono-Lopez", - "collection": 1, + "collection": 2, "uploaded_by_user": [ "root" ], @@ -1377,7 +1265,7 @@ "focal_point_width": null, "focal_point_y": null, "title": "Tristan Roussel", - "collection": 1, + "collection": 2, "uploaded_by_user": [ "root" ], @@ -1397,7 +1285,7 @@ "focal_point_width": null, "focal_point_y": null, "title": "Guillaume Vernade", - "collection": 1, + "collection": 2, "uploaded_by_user": [ "root" ], @@ -1417,7 +1305,7 @@ "focal_point_width": null, "focal_point_y": null, "title": "Lucas Mercier", - "collection": 1, + "collection": 2, "uploaded_by_user": [ "root" ], @@ -1437,7 +1325,7 @@ "focal_point_width": null, "focal_point_y": null, "title": "Fran\u00e7ois Maillot", - "collection": 1, + "collection": 2, "uploaded_by_user": [ "root" ], @@ -1457,7 +1345,7 @@ "focal_point_width": null, "focal_point_y": null, "title": "Fabrice Catoire", - "collection": 1, + "collection": 2, "uploaded_by_user": [ "root" ], @@ -1467,16 +1355,19 @@ "pk": 32 }, { - "pk": 1, + "model": "wagtailmenus.flatmenu", "fields": { + "max_levels": 1, + "handle": "kfet-nav", "site": [ "localhost", 8000 ], "use_specific": 1, - "max_levels": 2 + "heading": "", + "title": "K-F\u00eat - Navigation" }, - "model": "wagtailmenus.mainmenu" + "pk": 1 }, { "pk": 1, @@ -1490,7 +1381,7 @@ "sort_order": 0, "url_append": "" }, - "model": "wagtailmenus.mainmenuitem" + "model": "wagtailmenus.flatmenuitem" }, { "pk": 2, @@ -1504,7 +1395,7 @@ "sort_order": 1, "url_append": "" }, - "model": "wagtailmenus.mainmenuitem" + "model": "wagtailmenus.flatmenuitem" }, { "pk": 3, @@ -1518,7 +1409,7 @@ "sort_order": 2, "url_append": "" }, - "model": "wagtailmenus.mainmenuitem" + "model": "wagtailmenus.flatmenuitem" }, { "pk": 4, @@ -1532,7 +1423,7 @@ "sort_order": 3, "url_append": "" }, - "model": "wagtailmenus.mainmenuitem" + "model": "wagtailmenus.flatmenuitem" }, { "pk": 5, @@ -1546,7 +1437,7 @@ "sort_order": 4, "url_append": "" }, - "model": "wagtailmenus.mainmenuitem" + "model": "wagtailmenus.flatmenuitem" }, { "pk": 6, @@ -1560,6 +1451,6 @@ "sort_order": 5, "url_append": "" }, - "model": "wagtailmenus.mainmenuitem" + "model": "wagtailmenus.flatmenuitem" } ] diff --git a/kfet/cms/hooks.py b/kfet/cms/hooks.py new file mode 100644 index 00000000..e58aeef5 --- /dev/null +++ b/kfet/cms/hooks.py @@ -0,0 +1,12 @@ +from django.contrib.staticfiles.templatetags.staticfiles import static +from django.utils.html import format_html + +from wagtail.wagtailcore import hooks + + +@hooks.register('insert_editor_css') +def editor_css(): + return format_html( + '', + static('kfetcms/css/editor.css'), + ) diff --git a/kfet/cms/migrations/0001_initial.py b/kfet/cms/migrations/0001_initial.py index 6798aecc..951637c7 100644 --- a/kfet/cms/migrations/0001_initial.py +++ b/kfet/cms/migrations/0001_initial.py @@ -2,9 +2,11 @@ from __future__ import unicode_literals from django.db import migrations, models -import modelcluster.fields +import wagtail.wagtailsnippets.blocks +import wagtail.wagtailcore.blocks import wagtail.wagtailcore.fields import django.db.models.deletion +import kfet.cms.models class Migration(migrations.Migration): @@ -15,24 +17,15 @@ class Migration(migrations.Migration): ] operations = [ - migrations.CreateModel( - name='GroupTeam', - fields=[ - ('id', models.AutoField(primary_key=True, verbose_name='ID', auto_created=True, serialize=False)), - ('name', models.CharField(max_length=255, verbose_name='Nom')), - ], - options={ - 'verbose_name': 'Groupe de K-Fêt-eux-ses', - 'verbose_name_plural': 'Groupes de K-Fêt-eux-ses', - }, - ), migrations.CreateModel( name='KFetPage', fields=[ - ('page_ptr', models.OneToOneField(primary_key=True, to='wagtailcore.Page', parent_link=True, auto_created=True, serialize=False)), + ('page_ptr', models.OneToOneField(serialize=False, primary_key=True, parent_link=True, auto_created=True, to='wagtailcore.Page')), ('no_header', models.BooleanField(verbose_name='Sans en-tête', help_text="Coché, l'en-tête (avec le titre) de la page n'est pas affiché.", default=False)), - ('content', wagtail.wagtailcore.fields.RichTextField(verbose_name='Contenu')), - ('custom_template', models.CharField(max_length=255, verbose_name='Template personnalisé', blank=True)), + ('content', wagtail.wagtailcore.fields.StreamField((('rich', wagtail.wagtailcore.blocks.RichTextBlock(label='Éditeur')), ('carte', kfet.cms.models.MenuBlock()), ('group_team', wagtail.wagtailcore.blocks.StructBlock((('show_only', wagtail.wagtailcore.blocks.IntegerBlock(help_text='Nombre initial de membres affichés. Laisser vide pour tou-te-s les afficher.', required=False, label='Montrer seulement')), ('members', wagtail.wagtailcore.blocks.ListBlock(wagtail.wagtailsnippets.blocks.SnippetChooserBlock(kfet.cms.models.MemberTeam), classname='team-group', label='K-Fêt-eux-ses'))))), ('group', wagtail.wagtailcore.blocks.StreamBlock((('rich', wagtail.wagtailcore.blocks.RichTextBlock(label='Éditeur')), ('carte', kfet.cms.models.MenuBlock()), ('group_team', wagtail.wagtailcore.blocks.StructBlock((('show_only', wagtail.wagtailcore.blocks.IntegerBlock(help_text='Nombre initial de membres affichés. Laisser vide pour tou-te-s les afficher.', required=False, label='Montrer seulement')), ('members', wagtail.wagtailcore.blocks.ListBlock(wagtail.wagtailsnippets.blocks.SnippetChooserBlock(kfet.cms.models.MemberTeam), classname='team-group', label='K-Fêt-eux-ses')))))), label='Contenu groupé'))), verbose_name='Contenu')), + ('layout', models.CharField(max_length=255, choices=[('kfet/base_col_1.html', 'Une colonne : centrée sur la page'), ('kfet/base_col_2.html', 'Deux colonnes : fixe à gauche, contenu à droite'), ('kfet/base_col_mult.html', 'Contenu scindé sur plusieurs colonnes')], help_text='Comment cette page devrait être affichée ?', verbose_name='Template', default='kfet/base_col_mult.html')), + ('main_size', models.CharField(max_length=255, blank=True, verbose_name='Taille de la colonne de contenu')), + ('col_count', models.CharField(max_length=255, blank=True, verbose_name='Nombre de colonnes', help_text="S'applique au page dont le contenu est scindé sur plusieurs colonnes")), ], options={ 'verbose_name': 'page K-Fêt', @@ -40,33 +33,14 @@ class Migration(migrations.Migration): }, bases=('wagtailcore.page',), ), - migrations.CreateModel( - name='KFetPageGroupTeam', - fields=[ - ('id', models.AutoField(primary_key=True, verbose_name='ID', auto_created=True, serialize=False)), - ('sort_order', models.IntegerField(editable=False, null=True, blank=True)), - ('title', models.CharField(max_length=255, verbose_name='Titre du groupe', blank=True)), - ('content', wagtail.wagtailcore.fields.RichTextField(verbose_name='Texte de présentation du groupe')), - ('group', models.ForeignKey(related_name='+', verbose_name='Groupe de K-Fêt-eux-ses', to='kfetcms.GroupTeam')), - ('page', modelcluster.fields.ParentalKey(related_name='team_groups', to='kfetcms.KFetPage')), - ('show_only', models.IntegerField(default=None, verbose_name='Montrer seulement', blank=True, null=True, help_text='Nombre de membres du groupe affichés initialement. Laisser vide pour tou-te-s les afficher.')), - - ], - options={ - 'abstract': False, - 'ordering': ['sort_order'], - }, - ), migrations.CreateModel( name='MemberTeam', fields=[ - ('id', models.AutoField(primary_key=True, verbose_name='ID', auto_created=True, serialize=False)), - ('sort_order', models.IntegerField(editable=False, null=True, blank=True)), - ('first_name', models.CharField(max_length=255, verbose_name='Prénom', blank=True, default='')), - ('last_name', models.CharField(max_length=255, verbose_name='Nom', blank=True, default='')), - ('nick_name', models.CharField(max_length=255, verbose_name='Alias', blank=True, default='')), - ('group', modelcluster.fields.ParentalKey(related_name='members', verbose_name='Groupe de K-Fêt-eux-ses', to='kfetcms.GroupTeam')), - ('photo', models.ForeignKey(related_name='+', on_delete=django.db.models.deletion.SET_NULL, blank=True, verbose_name='Photo', to='wagtailimages.Image', null=True)), + ('id', models.AutoField(verbose_name='ID', auto_created=True, serialize=False, primary_key=True)), + ('first_name', models.CharField(blank=True, max_length=255, verbose_name='Prénom', default='')), + ('last_name', models.CharField(blank=True, max_length=255, verbose_name='Nom', default='')), + ('nick_name', models.CharField(verbose_name='Alias', blank=True, default='', max_length=255)), + ('photo', models.ForeignKey(null=True, related_name='+', on_delete=django.db.models.deletion.SET_NULL, verbose_name='Photo', blank=True, to='wagtailimages.Image')), ], options={ 'verbose_name': 'K-Fêt-eux-se', diff --git a/kfet/cms/models.py b/kfet/cms/models.py index 8b80f175..0dff183f 100644 --- a/kfet/cms/models.py +++ b/kfet/cms/models.py @@ -1,142 +1,32 @@ from django.db import models from django.utils.translation import ugettext_lazy as _ -from modelcluster.models import ClusterableModel, ParentalKey -from wagtail.wagtailadmin.edit_handlers import FieldPanel, InlinePanel -from wagtail.wagtailcore.fields import RichTextField -from wagtail.wagtailcore.models import Orderable, Page +from wagtail.wagtailadmin.edit_handlers import ( + FieldPanel, FieldRowPanel, MultiFieldPanel, StreamFieldPanel +) +from wagtail.wagtailcore import blocks +from wagtail.wagtailcore.fields import StreamField +from wagtail.wagtailcore.models import Page from wagtail.wagtailimages.edit_handlers import ImageChooserPanel -from wagtail.wagtailsnippets.edit_handlers import SnippetChooserPanel +from wagtail.wagtailsnippets.blocks import SnippetChooserBlock from wagtail.wagtailsnippets.models import register_snippet from kfet.cms.context_processors import get_articles -class KFetPage(Page): - no_header = models.BooleanField( - verbose_name=_('Sans en-tête'), - default=False, - help_text=_( - "Coché, l'en-tête (avec le titre) de la page n'est pas affiché." - ), - ) - content = RichTextField(verbose_name=_('Contenu')) - custom_template = models.CharField( - verbose_name=_('Template personnalisé'), - max_length=255, - blank=True, - ) - - content_panels = Page.content_panels + [ - FieldPanel('no_header'), - FieldPanel('content', classname='full'), - InlinePanel('team_groups', label=_("Groupes de K-Fêt-eux-ses")), - ] - - settings_panels = Page.settings_panels + [ - FieldPanel('custom_template'), - ] - - class Meta: - verbose_name = _('page K-Fêt') - verbose_name_plural = _('pages K-Fêt') - - def __init__(self, *args, **kwargs): - super().__init__(*args, **kwargs) - self.template = "kfetcms/base.html" - - def get_context(self, request, *args, **kwargs): - context = super().get_context(request, *args, **kwargs) - - page = context['page'] - - if not page.seo_title: - page.seo_title = page.title - - if self.slug == "carte": - context.update(get_articles(request)) - - return context - - def get_template(self, request, *args, **kwargs): - return self.custom_template or ( - super().get_template(request, *args, **kwargs)) - - -class KFetPageGroupTeam(Orderable, models.Model): - page = ParentalKey(KFetPage, related_name='team_groups') - group = models.ForeignKey( - 'kfetcms.GroupTeam', - verbose_name=_('Groupe de K-Fêt-eux-ses'), - related_name='+', - ) - title = models.CharField( - verbose_name=_('Titre du groupe'), - max_length=255, - blank=True, - ) - content = RichTextField( - verbose_name=_('Texte de présentation du groupe'), - ) - show_only = models.IntegerField( - verbose_name=_('Montrer seulement'), - blank=True, null=True, default=None, - help_text=_( - 'Nombre de membres du groupe affichés initialement. Laisser vide ' - 'pour tou-te-s les afficher.' - ), - ) - - panels = [ - FieldPanel('title', classname='full'), - FieldPanel('show_only', classname='full'), - FieldPanel('content', classname='full'), - SnippetChooserPanel('group'), - ] - - @register_snippet -class GroupTeam(ClusterableModel): - name = models.CharField( - verbose_name=_('Nom'), - max_length=255, - ) - - class Meta: - verbose_name = _('Groupe de K-Fêt-eux-ses') - verbose_name_plural = _('Groupes de K-Fêt-eux-ses') - - def __str__(self): - return self.name - - panels = [ - FieldPanel('name', classname='full'), - InlinePanel('members', label=_('Membres du groupe')), - ] - - -@register_snippet -class MemberTeam(Orderable, models.Model): - group = ParentalKey( - GroupTeam, - verbose_name=_("Groupe de K-Fêt-eux-ses"), - on_delete=models.CASCADE, - related_name='members', - ) +class MemberTeam(models.Model): first_name = models.CharField( verbose_name=_('Prénom'), - max_length=255, - blank=True, default='', + blank=True, default='', max_length=255, ) last_name = models.CharField( verbose_name=_('Nom'), - max_length=255, - blank=True, default='', + blank=True, default='', max_length=255, ) nick_name = models.CharField( verbose_name=_('Alias'), - max_length=255, - blank=True, default='', + blank=True, default='', max_length=255, ) photo = models.ForeignKey( 'wagtailimages.Image', @@ -149,17 +39,136 @@ class MemberTeam(Orderable, models.Model): class Meta: verbose_name = _('K-Fêt-eux-se') - def __str__(self): - return self.get_full_name() - panels = [ FieldPanel('first_name'), FieldPanel('last_name'), FieldPanel('nick_name'), - FieldPanel('group'), ImageChooserPanel('photo'), ] + def __str__(self): + return self.get_full_name() + def get_full_name(self): - full_name = '{} {}'.format(self.first_name, self.last_name) - return full_name.strip() + return '{} {}'.format(self.first_name, self.last_name).strip() + + +class MenuBlock(blocks.StaticBlock): + class Meta: + icon = 'list-ul' + label = _('Carte') + template = 'kfetcms/block_menu.html' + + def get_context(self, *args, **kwargs): + context = super().get_context(*args, **kwargs) + context.update(get_articles()) + return context + + +class GroupTeamBlock(blocks.StructBlock): + show_only = blocks.IntegerBlock( + label=_('Montrer seulement'), + required=False, + help_text=_( + 'Nombre initial de membres affichés. Laisser vide pour tou-te-s ' + 'les afficher.' + ), + ) + members = blocks.ListBlock( + SnippetChooserBlock(MemberTeam), + label=_('K-Fêt-eux-ses'), + classname='team-group', + ) + + class Meta: + icon = 'group' + label = _('Groupe de K-Fêt-eux-ses') + template = 'kfetcms/block_teamgroup.html' + + +class ChoicesStreamBlock(blocks.StreamBlock): + rich = blocks.RichTextBlock(label=_('Éditeur')) + carte = MenuBlock() + group_team = GroupTeamBlock() + + +class KFetStreamBlock(ChoicesStreamBlock): + group = ChoicesStreamBlock(label=_('Contenu groupé')) + + +class KFetPage(Page): + + content = StreamField(KFetStreamBlock, verbose_name=_('Contenu')) + + # Layout fields + + TEMPLATE_COL_1 = 'kfet/base_col_1.html' + TEMPLATE_COL_2 = 'kfet/base_col_2.html' + TEMPLATE_COL_MULT = 'kfet/base_col_mult.html' + + no_header = models.BooleanField( + verbose_name=_('Sans en-tête'), + default=False, + help_text=_( + "Coché, l'en-tête (avec le titre) de la page n'est pas affiché." + ), + ) + layout = models.CharField( + verbose_name=_('Template'), + choices=[ + (TEMPLATE_COL_1, _('Une colonne : centrée sur la page')), + (TEMPLATE_COL_2, _('Deux colonnes : fixe à gauche, contenu à droite')), + (TEMPLATE_COL_MULT, _('Contenu scindé sur plusieurs colonnes')), + ], + default=TEMPLATE_COL_MULT, max_length=255, + help_text=_( + "Comment cette page devrait être affichée ?" + ), + ) + main_size = models.CharField( + verbose_name=_('Taille de la colonne de contenu'), + blank=True, max_length=255, + ) + col_count = models.CharField( + verbose_name=_('Nombre de colonnes'), + blank=True, max_length=255, + help_text=_( + "S'applique au page dont le contenu est scindé sur plusieurs colonnes." + ), + ) + + # Panels + + content_panels = Page.content_panels + [ + StreamFieldPanel('content'), + ] + + layout_panel = [ + FieldPanel('no_header'), + FieldPanel('layout'), + FieldRowPanel([ + FieldPanel('main_size'), + FieldPanel('col_count'), + ]), + ] + + settings_panels = [ + MultiFieldPanel(layout_panel, _('Affichage')) + ] + Page.settings_panels + + # Base template + template = "kfetcms/base.html" + + class Meta: + verbose_name = _('page K-Fêt') + verbose_name_plural = _('pages K-Fêt') + + def get_context(self, request, *args, **kwargs): + context = super().get_context(request, *args, **kwargs) + + page = context['page'] + + if not page.seo_title: + page.seo_title = page.title + + return context diff --git a/kfet/cms/static/kfetcms/css/base.css b/kfet/cms/static/kfetcms/css/base.css new file mode 100644 index 00000000..b580ef94 --- /dev/null +++ b/kfet/cms/static/kfetcms/css/base.css @@ -0,0 +1,93 @@ +.main.cms { + padding: 20px 15px; +} + +@media (min-width: 768px) { + .main.cms { + padding: 35px 30px; + } +} + +.cms { + text-align: justify; + font-size: 1.1em; +} + +@media (min-width:768px) { + .cms { + font-size: 1.2em; + line-height: 1.6em; + } +} + +/* Titles */ + +.cms h2, .cms h3 { + clear: both; + margin: 0 0 15px; + padding-bottom: 10px; + border-bottom: 1px solid #c8102e; + text-align: left; + font-weight: bold; +} + +@media (min-width: 768px) { + .cms h2, .cms h3 { + padding-bottom: 15px; + } +} + +/* Paragraphs */ + +.cms p { + margin-bottom: 20px; + text-indent: 2em; +} + +.cms p + :not(h2):not(h3):not(div) { + margin-top: -10px; +} + +@media (min-width: 768px) { + .cms p { + padding-bottom: 15px; + } + + .cms p + :not(h2):not(h3):not(div) { + margin-top: -30px; + } +} + + +/* Lists */ + +.cms ol, .cms ul { + padding: 0 0 0 15px; + margin: 0 0 10px; +} + +.cms ul { + list-style-type: square; +} + +.cms ol > li, .cms ul > li { + padding-left: 5px; +} + + +/* Images */ + +.cms .richtext-image { + max-height: 100%; + margin: 5px 0 15px; +} + +.cms .richtext-image.left { + float: left; + margin-right: 30px; +} + +.cms .richtext-image.right { + float: right; + margin-left: 30px; +} diff --git a/kfet/cms/static/kfetcms/css/editor.css b/kfet/cms/static/kfetcms/css/editor.css new file mode 100644 index 00000000..f97e9895 --- /dev/null +++ b/kfet/cms/static/kfetcms/css/editor.css @@ -0,0 +1,18 @@ +.snippets.listing thead, .snippets.listing thead tr { + border: 0; +} + +.snippets.listing tbody { + display: block; + column-count: 2; +} + +.snippets.listing tbody tr { + display: block; +} + +@media (min-width: 992px) { + .snippets.listing tbody { + column-count: 3; + } +} diff --git a/kfet/cms/static/kfetcms/css/index.css b/kfet/cms/static/kfetcms/css/index.css index ff175df6..647515e3 100644 --- a/kfet/cms/static/kfetcms/css/index.css +++ b/kfet/cms/static/kfetcms/css/index.css @@ -1,155 +1,3 @@ -.cms-content { - text-align: justify; - font-size: 1.1em; -} - -@media (min-width:768px) { - .cms-content { - font-size: 1.2em; - line-height: 1.6em; - } -} - -.cms-column { - column-gap: 45px; - - padding: 20px 15px; - background: white; -} - -@media (min-width: 768px) { - .cms-column { - padding: 35px 30px; - } -} - -@media (min-width: 992px) { - .cms-column { - margin: 0 15px; - } -} - - -/* Titles */ - -.cms-content h2, .cms-content h3 { - clear: both; - margin: 0 0 15px; - padding-bottom: 10px; - border-bottom: 1px solid #c8102e; - text-align: left; - font-weight: bold; -} - -@media (min-width: 768px) { - .cms-content h2, .cms-content h3 { - padding-bottom: 15px; - } -} - -/* Paragraphs */ - -.cms-content p { - margin-bottom: 20px; - text-indent: 2em; -} - -.cms-content p + :not(h2):not(h3):not(div) { - margin-top: -10px; -} - -@media (min-width: 768px) { - .cms-content p { - padding-bottom: 15px; - } - - .cms-content p + :not(h2):not(h3):not(div) { - margin-top: -30px; - } -} - - -/* Lists */ - -.cms-content ol, .cms-content ul { - padding: 0 0 0 15px; - margin: 0 0 10px; -} - -.cms-content ul { - list-style-type: square; -} - -.cms-content ol > li, .cms-content ul > li { - padding-left: 5px; -} - - -/* Images */ - -.cms-content .richtext-image { - max-height: 100%; - margin: 5px 0 15px; -} - -.cms-content .richtext-image.left { - float: left; - margin-right: 30px; -} - -.cms-content .richtext-image.right { - float: right; - margin-left: 30px; -} - - -/* Team groups & members */ - -.team-group { - margin-bottom: 20px; -} - -.team-group .col-btn { - margin-bottom: 20px; -} - -.team-group .member-more { - display: none; -} - -.team-member { - padding: 0; - margin-bottom: 20px; - min-height: 190px; - background-color: inherit; - border: 0; -} - -.team-member img { - max-width: 100%; - max-height: 125px; - width: auto; - height: auto; - display: block; -} - -.team-member .infos { - height: 50px; - margin-top: 15px; -} - -@media (min-width: 768px) { - .team-group { - margin-left: 20px; - margin-right: 20px; - } - - .team-member { - min-height: 215px; - } - - .team-member img { - max-height: 150px; - } -} - +@import url("base.css"); +@import url("menu.css"); +@import url("team.css"); diff --git a/kfet/static/kfet/css/home.css b/kfet/cms/static/kfetcms/css/menu.css similarity index 100% rename from kfet/static/kfet/css/home.css rename to kfet/cms/static/kfetcms/css/menu.css diff --git a/kfet/cms/static/kfetcms/css/team.css b/kfet/cms/static/kfetcms/css/team.css new file mode 100644 index 00000000..e663fc66 --- /dev/null +++ b/kfet/cms/static/kfetcms/css/team.css @@ -0,0 +1,47 @@ +.team-group { + margin-bottom: 20px; +} + +.team-group .col-btn { + margin-bottom: 20px; +} + +.team-group .member-more { + display: none; +} + +.team-member { + padding: 0; + margin-bottom: 20px; + min-height: 190px; + background-color: inherit; + border: 0; +} + +.team-member img { + max-width: 100%; + max-height: 125px; + width: auto; + height: auto; + display: block; +} + +.team-member .infos { + height: 50px; + margin-top: 15px; +} + +@media (min-width: 768px) { + .team-group { + margin-left: 20px; + margin-right: 20px; + } + + .team-member { + min-height: 215px; + } + + .team-member img { + max-height: 150px; + } +} diff --git a/kfet/cms/templates/kfetcms/base.html b/kfet/cms/templates/kfetcms/base.html index 043c9ba5..3b9f40d6 100644 --- a/kfet/cms/templates/kfetcms/base.html +++ b/kfet/cms/templates/kfetcms/base.html @@ -1,68 +1,41 @@ -{% extends "kfet/base.html" %} -{% load static %} -{% load wagtailuserbar %} -{% load wagtailcore_tags %} +{% extends page.layout %} +{% load static wagtailcore_tags wagtailuserbar %} + +{# CSS/JS #} {% block extra_head %} +{{ block.super }} {% endblock %} -{% block title %}{{ page.seo_title }}{% endblock %} +{# Titles #} -{% block header-class %}text-center{% endblock %} +{% block title %}{{ page.seo_title }}{% endblock %} {% block header-title %}{{ page.title }}{% endblock %} -{% block content %} +{# Layout #} -
- {% include "kfet/base_messages.html" %} -
+{% block main-size %}{{ page.main_size|default:block.super }}{% endblock %} +{% block mult-count %}{{ page.col_count|default:block.super }}{% endblock %} -
-
-
- {% block block1-content %} - {% endblock %} +{% block main-class %}cms main-bg{% endblock %} - {% block block2-content %} - {{ page.content|richtext }} - {% endblock %} +{# Content #} - {% block block3-content %} - {% endblock %} -
+{% block main %} + +{% for block in page.content %} +
+ {% include_block block %}
-
+{% endfor %} {% wagtailuserbar %} - - {% endblock %} +{# Footer #} + {% block footer %} {% include "kfet/base_footer.html" %} {% endblock %} diff --git a/kfet/cms/templates/kfetcms/block_menu.html b/kfet/cms/templates/kfetcms/block_menu.html new file mode 100644 index 00000000..382a7770 --- /dev/null +++ b/kfet/cms/templates/kfetcms/block_menu.html @@ -0,0 +1,11 @@ +{% load static %} + +{% if pressions %} + {% include "kfetcms/block_menu_category.html" with title="Pressions du moment" articles=pressions class="carte-inverted" %} +{% endif %} + +{% regroup articles by category as categories %} + +{% for category in categories %} + {% include "kfetcms/block_menu_category.html" with title=category.grouper.name articles=category.list %} +{% endfor %} diff --git a/kfet/cms/templates/kfetcms/block_menu_category.html b/kfet/cms/templates/kfetcms/block_menu_category.html new file mode 100644 index 00000000..ef7d4ce0 --- /dev/null +++ b/kfet/cms/templates/kfetcms/block_menu_category.html @@ -0,0 +1,12 @@ +
+

{{ title }}

+
    + {% for article in articles %} +
  • +
    + {{ article.name }} + {{ article.price_ukf }} UKF +
  • + {% endfor %} +
+
diff --git a/kfet/cms/templates/kfetcms/equipe.html b/kfet/cms/templates/kfetcms/block_teamgroup.html similarity index 51% rename from kfet/cms/templates/kfetcms/equipe.html rename to kfet/cms/templates/kfetcms/block_teamgroup.html index 2295957f..fab43d68 100644 --- a/kfet/cms/templates/kfetcms/equipe.html +++ b/kfet/cms/templates/kfetcms/block_teamgroup.html @@ -1,27 +1,32 @@ -{% extends "kfetcms/base.html" %} -{% load wagtailcore_tags %} -{% load wagtailimages_tags %} +{% load wagtailcore_tags wagtailimages_tags %} -{% block block1-content %} -{% for group_block in page.team_groups.all %} -

{{ group_block.title }}

-
- {{ group_block.content|richtext }} -
+{% with groupteam=value len=value.members|length %} -{% with members=group_block.group.members.all %} -{% with len=members|length %} - -{% if len > 0 %}
{% if len == 2 %}
{% endif %} - {% for member in members %} -
+ {% for member in groupteam.members %} +
{% image member.photo max-200x500 %}
@@ -35,10 +40,10 @@
{% endfor %} - {% if group_block.show_only != None and len > group_block.show_only %} + {% if groupteam.show_only != None and len > groupteam.show_only %}
-{% endif %} {% endwith %} -{% endwith %} - -{% endfor %} - -{% endblock %} diff --git a/kfet/cms/templates/kfetcms/carte.html b/kfet/cms/templates/kfetcms/carte.html deleted file mode 100644 index 3a32624b..00000000 --- a/kfet/cms/templates/kfetcms/carte.html +++ /dev/null @@ -1,46 +0,0 @@ -{% extends "kfetcms/base.html" %} -{% load static %} -{% load kfet_tags %} - -{% block extra_head %} -{{ block.super }} - -{% endblock %} - -{% block col-size %}column-sm-2 column-md-3{% endblock %} - -{% block block3-content %} - -{% if pressions %} -
-

Pressions du moment

-
    - {% for article in pressions %} -
  • -
    - {{ article.name }} - {{ article.price | ukf:False}} UKF -
  • - {% endfor %} -
-
-{% endif %} - -{% regroup articles by category as categories %} - -{% for category in categories %} -
-

{{ category.grouper.name }}

-
    - {% for article in category.list %} -
  • -
    - {{ article.name }} - {{ article.price | ukf:False}} UKF -
  • - {% endfor %} -
-
-{% endfor %} - -{% endblock %} diff --git a/kfet/forms.py b/kfet/forms.py index 95e97d56..85391992 100644 --- a/kfet/forms.py +++ b/kfet/forms.py @@ -25,18 +25,22 @@ from gestioncof.models import CofProfile # ----- class DateTimeWidget(forms.DateTimeInput): - def __init__(self, attrs = None): - super(DateTimeWidget, self).__init__(attrs) + def __init__(self, *args, **kwargs): + super().__init__(*args, **kwargs) self.attrs['format'] = '%Y-%m-%d %H:%M' + class Media: css = { - 'all': ('kfet/css/bootstrap-datetimepicker.min.css',) - } - js = ( - 'kfet/js/moment.js', - 'kfet/js/moment-fr.js', - 'kfet/js/bootstrap-datetimepicker.min.js', - ) + 'all': ('kfet/css/bootstrap-datetimepicker.min.css',) + } + js = ( + 'kfet/js/moment.js', + 'kfet/js/moment-fr.js', + 'kfet/js/moment-timezone-with-data-2010-2020.js', + 'kfet/js/bootstrap-datetimepicker.min.js', + ) + + # ----- # Account forms # ----- @@ -459,8 +463,11 @@ class KFetConfigForm(ConfigForm): class FilterHistoryForm(forms.Form): - checkouts = forms.ModelMultipleChoiceField(queryset = Checkout.objects.all()) - accounts = forms.ModelMultipleChoiceField(queryset = Account.objects.all()) + checkouts = forms.ModelMultipleChoiceField(queryset=Checkout.objects.all()) + accounts = forms.ModelMultipleChoiceField(queryset=Account.objects.all()) + from_date = forms.DateTimeField(widget=DateTimeWidget) + to_date = forms.DateTimeField(widget=DateTimeWidget) + # ----- # Transfer forms diff --git a/kfet/models.py b/kfet/models.py index eb33daf7..162d1e90 100644 --- a/kfet/models.py +++ b/kfet/models.py @@ -14,7 +14,8 @@ from datetime import date import re import hashlib -from kfet.config import kfet_config +from .config import kfet_config +from .utils import to_ukf def choices_length(choices): return reduce(lambda m, choice: max(m, len(choice[0])), choices, 0) @@ -102,6 +103,10 @@ class Account(models.Model): return self.cofprofile.is_cof # Propriétés supplémentaires + @property + def balance_ukf(self): + return to_ukf(self.balance, is_cof=self.is_cof) + @property def real_balance(self): if hasattr(self, 'negative') and self.negative.balance_offset: @@ -309,6 +314,10 @@ class AccountNegative(models.Model): ('view_negs', 'Voir la liste des négatifs'), ) + @property + def until_default(self): + return self.start + kfet_config.overdraft_duration + class Checkout(models.Model): created_by = models.ForeignKey( @@ -461,6 +470,10 @@ class Article(models.Model): def get_absolute_url(self): return reverse('kfet.article.read', kwargs={'pk': self.pk}) + def price_ukf(self): + return to_ukf(self.price) + + class ArticleRule(models.Model): article_on = models.OneToOneField( Article, on_delete = models.PROTECT, diff --git a/kfet/signals.py b/kfet/signals.py index 6bbbbbb0..374e0dca 100644 --- a/kfet/signals.py +++ b/kfet/signals.py @@ -4,7 +4,7 @@ from django.contrib import messages from django.contrib.auth.signals import user_logged_in from django.core.urlresolvers import reverse from django.dispatch import receiver -from django.utils.html import mark_safe +from django.utils.safestring import mark_safe @receiver(user_logged_in) diff --git a/kfet/static/kfet/css/base/buttons.css b/kfet/static/kfet/css/base/buttons.css new file mode 100644 index 00000000..e7498022 --- /dev/null +++ b/kfet/static/kfet/css/base/buttons.css @@ -0,0 +1,88 @@ +/* General ------------------------- */ + +.btn { + border: 0; + outline: none !important; + + transition: background-color, border, color, opacity; + transition-duration: 0.15s; + + text-overflow: ellipsis; + white-space: nowrap; + overflow: hidden; + + font-family: "Roboto Slab"; +} + +.btn, .btn-lg, .btn-group-lg>.btn { + border-radius:0; +} + + +/* Default ------------------------- */ + +.btn-default { + background-color: transparent !important; + color: #555; +} + +.btn-default:hover, +.btn-default.focus, .btn-default:focus { + color: #c8102e; +} + +.btn-default[disabled]:hover, .btn-default.disabled:hover { + color: inherit !important; +} + + +/* Primary ------------------------- */ + +.btn-primary { + background-color:#c63b52; + color:#FFF; +} + +.btn-primary:hover, +.btn-primary.focus, .btn-primary:focus, +.btn-primary.active.focus, .btn-primary.active:focus, .btn-primary.active:hover, +.btn-primary:active.focus, .btn-primary:active:focus, .btn-primary:active:hover { + background-color:#c8102e; + color:#FFF; +} + + +/* Primary + White background ------ */ + +.btn-primary-w { + background: white; + color: black; +} + +.btn-primary-w:hover { + background: #c63b52; + color: white; +} + +.btn-primary-w.focus, .btn-primary-w:focus, +.btn-primary-w.active.focus, .btn-primary-w.active:focus, .btn-primary-w.active:hover, +.btn-primary-w:active.focus, .btn-primary-w:active:focus, .btn-primary-w:active:hover { + background: #c8102e; + color: white; +} + + +/* Nav ----------------------------- */ + +.btn-nav { + background-color: transparent !important; + color: inherit; + border-bottom: 1px solid #ddd; +} + +.btn-nav:hover, +.btn-nav.focus, .btn-nav:focus, +.btn-nav.active.focus, .btn-nav.active:focus, .btn-nav.active:hover, +.btn-nav:active.focus, .btn-nav:active:focus, .btn-nav:active:hover { + border-bottom: 1px solid #c8102e; +} diff --git a/kfet/static/kfet/css/base/fixed.css b/kfet/static/kfet/css/base/fixed.css new file mode 100644 index 00000000..d198c50f --- /dev/null +++ b/kfet/static/kfet/css/base/fixed.css @@ -0,0 +1,151 @@ +.fixed > * + * { + margin-top: 15px; +} + + +/* Aside --------------------------- */ + +/* Aside - Block */ + +aside { + background: white; + padding: 15px; +} + +aside > * + * { + margin-top: 15px; +} + +/* Aside - Misc */ + +aside .glyphicon-question-sign { + font-size: 0.8; +} + +aside h4 { + font-weight: bold; +} + +/* Aside - Heading */ + +aside .heading { + font-family: "Roboto Slab"; + font-size: 25px; + font-weight: bold; + line-height: 1.1; + text-align: center; +} + +aside .heading .big { + font-size: 2em; +} + +aside .heading .sub { + font-size: 0.7em; + font-weight: normal; +} + +@media (min-width: 992px) { + aside .heading { + font-size: 32px; + line-height: 1.3; + } +} + +/* Aside - Buttons */ + +aside .buttons { + margin-left: -15px; + margin-right: -15px; +} + +aside .buttons > * { + flex: 0 1 auto !important; +} + + +/* Aside - Text */ + +aside .text { + line-height: 1.3; + font-size: 14px; +} + +@media (min-width: 992px) { + aside .text { + line-height: 1.6; + font-size: 16px; + } +} + +aside .text ul { + margin-bottom: 0; +} + + +/* Buttons ------------------------- */ + +.fixed .buttons { + display: flex; + flex-flow: row wrap; + justify-content: center; + + text-align: center; +} + +.fixed .buttons > * { + flex: 0 1 auto; + overflow: hidden; +} + +.fixed .buttons > .solo { + flex: 1 100%; +} + +@media (min-width: 768px) { + .fixed .buttons > * { + flex: 1 auto; + } + + .fixed .buttons > .full > * { + width: 100%; + } +} + +.fixed .buttons .btn { + padding: 8px 12px; +} + +@media (min-width: 992px) { + .fixed .buttons .btn { + font-size: 16px; + } +} + + +/* Tabs ---------------------------- */ + +.fixed .tabs-buttons { + margin-bottom: -5px; +} + +.fixed .tabs-buttons > * { + margin-bottom: 5px; +} + +.fixed .tabs-buttons .glyphicon-chevron-right { + margin-left: 5px; + line-height: 1.4; + color: white; +} + +@media (min-width: 768px) { + .fixed .tabs-buttons { + text-align: right; + justify-content: flex-end; + } + + .fixed .tabs-buttons > * { + flex: 1 100%; + } +} diff --git a/kfet/static/kfet/css/footer.css b/kfet/static/kfet/css/base/footer.css similarity index 85% rename from kfet/static/kfet/css/footer.css rename to kfet/static/kfet/css/base/footer.css index 5e8d1474..abdf98ed 100644 --- a/kfet/static/kfet/css/footer.css +++ b/kfet/static/kfet/css/base/footer.css @@ -10,10 +10,9 @@ } .footer a { - color: inherit; + color: inherit !important; } .footer a:hover, .footer a:focus { - color: inherit; text-decoration: underline; } diff --git a/kfet/static/kfet/css/base/main.css b/kfet/static/kfet/css/base/main.css new file mode 100644 index 00000000..2ebc90d8 --- /dev/null +++ b/kfet/static/kfet/css/base/main.css @@ -0,0 +1,138 @@ +/* Global layout ------------------- */ + +.main-col, .fixed-col { + padding: 0 0 15px; +} + +@media (min-width: 768px) { + .fixed-col { + position: sticky; + top: 35px; + padding-top: 15px; + } + + .fixed-col + .main-col { + padding: 15px 0 15px 15px; + } +} + +@media (min-width: 992px) { + .main-col { + padding: 15px; + } +} + +.main-col-mult { + column-gap: 45px; +} + +.main-bg { + background: white; +} + +.main-padding { + padding: 15px; +} + +@media (min-width: 768px) { + .main-padding { + padding: 30px; + } +} + + +/* Section ------------------------- */ + +section { + margin-bottom: 15px; + position:relative; +} + +section:last-child { + margin-bottom: 0; +} + + +/* Section - Elements -------------- */ + +section > * { + background: white; + padding: 15px; +} + +section > .full, +section > table, +section > .table-responsive { + padding: 0 !important; + margin-left: 0 !important; + margin-right: 0 !important; +} + +section .full { + margin-left: -15px; + margin-right: -15px; +} + +@media (min-width: 992px) { + section > * { + padding: 30px; + } + + section .full { + margin-left: -30px; + margin-right: -30px; + } +} + +section .row > div:last-child { + margin-bottom: 0 !important; +} + +@media (max-width: 768px) { + section .row > div { + margin-bottom: 10px; + } +} + +@media (max-width: 1200px) { + section .row > div { + margin-bottom: 20px; + } +} + +section ul ul { + padding-left: 30px; +} + +/* Titles & Heading */ + +section h2, +section .heading { + background: transparent; + margin: 20px 15px 15px; + padding: 0; + border-bottom: 3px solid #c8102e; + font-family: "Roboto Slab"; + font-size: 40px; + line-height: 1.1; +} + +section h3 { + border-bottom: 2px solid #c8102e; + margin: 0 0 10px; + padding: 10px 0 10px; + font-size: 25px; + font-weight: bold; +} + +section .heading .buttons { + opacity: 0.7; + top: 10px; + float: right; +} + +section h2:first-child, +section h3:first-child { + padding-top: 0; + margin-top: 0; +} diff --git a/kfet/static/kfet/css/base/messages.css b/kfet/static/kfet/css/base/messages.css new file mode 100644 index 00000000..268f514d --- /dev/null +++ b/kfet/static/kfet/css/base/messages.css @@ -0,0 +1,36 @@ +.messages .alert { + padding:10px 15px; + margin:0; + border:0; + border-radius:0; +} + +.messages .alert:last-child { + margin-bottom: 15px; +} + +.messages .alert .close { + top:0; + right:0; +} + +.messages .alert-info { + color:inherit; + background-color:#ccc; +} + +.messages .alert-error { + color: white; + background-color: #c63b52; +} + +.messages .alert-success { + color: white; + background: #3d9947; +} + +.messages a { + font-weight: bold; + text-decoration: none; +} + diff --git a/kfet/static/kfet/css/base/misc.css b/kfet/static/kfet/css/base/misc.css new file mode 100644 index 00000000..9b09edae --- /dev/null +++ b/kfet/static/kfet/css/base/misc.css @@ -0,0 +1,107 @@ +/* General ------------------------- */ + +body { + margin-top:50px; + font-family:Roboto; + background:#ddd; +} + +.glyphicon + span, span + .glyphicon { + margin-left: 10px; +} + +/* Titles */ + +h1,h2,h3,h4,h5,h6 { + font-family:"Roboto Slab"; +} + +/* Links */ + +a { + color:#C8202E; +} + +a:focus, a:hover { + color:#C8102E; +} + +/* Inputs */ + +:focus { + outline:none; +} + +textarea { + font-family:'Roboto Mono'; + border-radius:0 !important; +} + +/* Lists */ + +ul, ol { + padding-left: 30px; +} + +ul { + list-style-type: square; +} + +/* Tables */ + +.table { + margin-bottom:0; + border-bottom:1px solid #ddd; + width:100%; + background-color: #FFF; +} + +.table td { + vertical-align:middle !important; +} + +.table td.no-padding { + padding:0; +} + +.table thead { + background:#c8102e; + color:#fff; + font-weight:bold; + font-size:16px; +} + +.table thead td { + padding:8px !important; +} + +.table tr.section { + background: #c63b52 !important; + color:#fff; + font-weight:bold; +} + +.table tr.section td { + border-top:0; + font-size:16px; + padding:8px 30px; +} + +.table tr.more td { + padding: 0; +} + +.table-responsive { + border: 0; + margin-bottom: 0; +} + +/* Toggle on hover ----------------- */ + +.toggle:not(:hover) .hover { + display: none; +} + +.toggle:hover .base { + display: none; +} diff --git a/kfet/static/kfet/css/nav.css b/kfet/static/kfet/css/base/nav.css similarity index 100% rename from kfet/static/kfet/css/nav.css rename to kfet/static/kfet/css/base/nav.css diff --git a/kfet/static/kfet/css/index.css b/kfet/static/kfet/css/index.css index 04fbaeb1..8e28cce0 100644 --- a/kfet/static/kfet/css/index.css +++ b/kfet/static/kfet/css/index.css @@ -1,306 +1,64 @@ -@import url("nav.css"); -@import url("footer.css"); +/* Libs */ +@import url("libs/columns.css"); + +/* Libs customizations */ +@import url("libs/jconfirm-kfet.css"); +@import url("libs/multiple-select-kfet.css"); + +/* Base */ +@import url("base/misc.css"); +@import url("base/buttons.css"); + +/* Blocks */ +@import url("base/main.css"); +@import url("base/nav.css"); +@import url("base/messages.css"); +@import url("base/fixed.css"); +@import url("base/footer.css"); + +/* Components */ @import url("kpsul.css"); -@import url("jconfirm-kfet.css"); @import url("history.css"); -body { - margin-top:50px; - font-family:Roboto; - background:#ddd; + + +.header { + padding: 15px 20px; + + background-color: rgba(200,16,46,1); + color: #FFF; } -h1,h2,h3,h4,h5,h6 { - font-family:"Roboto Slab"; -} - -a { - color:#C8202E; -} - -a:focus, a:hover { - color:#C8102E; -} - -:focus { - outline:none; -} - -textarea { - font-family:'Roboto Mono'; - border-radius:0 !important; -} - -.glyphicon + span, span + .glyphicon { - margin-left: 10px; -} - -.table { - margin-bottom:0; - border-bottom:1px solid #ddd; - width:100%; - background-color: #FFF; -} - -.table td { - vertical-align:middle !important; -} - -.table td.no-padding { - padding:0; -} - -.table thead { - background:#c8102e; - color:#fff; - font-weight:bold; - font-size:16px; -} - -.table thead td { - padding:8px !important; -} - -.table tr.section { - background:#c8102e; - color:#fff; - font-weight:bold; -} - -.table tr.section td { - border-top:0; - font-size:16px; - padding:8px 30px; -} - -.table-hover > tbody > tr.section:hover { - background:#c8102e; -} - -.table-responsive { - border: 0; - margin-bottom: 0; -} - -.btn { - border: 0; - - transition: background-color, color; - transition-duration: 0.15s; - - text-overflow: ellipsis; - white-space: nowrap; - overflow: hidden; - - font-family: "Roboto Slab"; -} - -.btn, .btn-lg, .btn-group-lg>.btn { - border-radius:0; -} - -.btn-primary { - background-color:#c63b52; - color:#FFF; - border:0; -} - -.btn-primary:hover, -.btn-primary.focus, .btn-primary:focus, -.btn-primary.active.focus, .btn-primary.active:focus, .btn-primary.active:hover, -.btn-primary:active.focus, .btn-primary:active:focus, .btn-primary:active:hover, -.nav-pills>li.active>a, .nav-pills>li.active>a:focus, .nav-pills>li.active>a:hover { - outline: 0; - background-color:#bf0f2c; - background-color:#c8102e; - color:#FFF; -} - -.btn-primary[disabled]:hover, -.btn-primary[disabled]:focus { - background-color: #000; - color: #666; -} - -.nav-pills>li>a { - border-radius:0; -} - -.nav-pills>li>a:focus, .nav-pills>li>a:hover { - outline: 0; - background-color:rgba(200,16,46,1); - color:#FFF; -} - -.header-row { - background-color:rgba(200,16,46,1); - color:#FFF; -} - -.page-header { - border:0; - padding:0; - margin:15px 20px; - font-weight:bold; +.header h1 { + padding: 0; + margin: 0; + font-weight: bold; } .nopadding { padding: 0 !important; } -.col-content-left, .col-content-right { - padding:0; -} - - -@media (min-width: 768px) { - .col-content-left { - position: sticky; - top:50px; - margin-bottom: 15px; - } -} - -.content-left-top { - background:#fff; - padding:15px; -} - -@media (min-width: 1200px) { - .content-left-top { - padding: 30px; - } -} - -.content-left .btn-lg { - font-size: 16px; -} - -.btn-actions { - margin: 0 -15px; -} - -.btn-actions .btn { - color: inherit; -} - -.btn-actions .btn:not([disabled]):hover, .btn-actions .btn:not([disabled]):focus { - color: #c8102e; -} - -.content-left-top.frozen-account { +.frozen-account { background:#5072e0; color:#fff; } -.content-left .block { - padding-top:15px; + +.main .table a:not(.btn) { + color: inherit; } -.content-left .block .line { - font-size:16px; - line-height:30px; +.main .table a:not(.btn):focus , +.main .table a:not(.btn):hover { + color: #C81022; } -.content-left .line.line-big { - font-family:"Roboto Slab"; - font-size:60px; - font-weight:bold; - text-align:center; - overflow:hidden; -} - -.content-left .line.line-bigsub { - font-size:25px; - font-weight:bold; - text-align:center; -} - -.content-left .line.balance { - font-size:45px; - text-align:center; -} - -@media (min-width: 1200px) { - .content-left .line.line-big { - margin-top: -15px; - } -} - -@media (min-width: 768px) { - .content-right { - margin: 15px; - } -} - -.content-right-block { - margin-top: 15px; - position:relative; -} - -.content-right-block > *:not(.buttons-title) { - background: #fff; -} - -.content-right-block > h2 { - background: transparent !important; -} - -.content-right-block .buttons-title { - position:absolute; - top:8px; - right:20px; -} - -.content-right-block > div.row { - margin:0; -} - -.content-right-block h2 { - margin:20px 20px 15px; - padding-bottom:5px; - border-bottom:3px solid #c8102e; - font-size:40px; -} - -.content-right-block h3 { - border-bottom: 1px solid #c8102e; - margin: 0px 15px 15px; - padding: 20px 20px 10px; - font-size:25px; -} - -.content-right-block a:not(.btn) { - color:#000; -} - -.content-right-block a:not(.btn):focus , -.content-right-block a:not(.btn):hover { - color:#C81022; -} /* * Pages tableaux seuls */ -.content-center > *:not(.content-right-block) { - background: #fff; -} - -@media (min-width: 992px) { - .content-center { - margin: 15px 0; - } - - .column-row { - margin-top: 15px; - margin-bottom: 15px; - } -} - -.content-center tbody tr:not(.section) td { - padding:0px 5px; -} .table .form-control { padding: 1px 12px ; @@ -313,6 +71,10 @@ textarea { background: #f5f5f5; } +.table-condensed-input tbody tr:not(.section) td { + padding:0px 5px; +} + .table-condensed input.form-control { margin: 0 !important; border-top: 0; @@ -320,19 +82,34 @@ textarea { border-radius: 0; } -.content-center .auth-form { - margin:15px; +.auth-form { + padding: 15px 0; + background: #d86c7e; + color: white; +} + +.auth-form.form-horizontal { + padding: 0; + margin: 0; +} + +.auth-form .form-group { + margin-bottom: 0; +} + +.auth-form input { + box-shadow: none !important; + background: transparent; + color: white; + border: 0 !important; + border-radius: 0; + border-bottom: 1px solid white !important; } /* * Pages formulaires seuls */ -.content-form { - background-color: #fff; - padding: 15px; -} - .account_create #id_trigramme { display:block; width:200px; @@ -395,40 +172,48 @@ textarea { padding:5px 20px; } -/* - * Messages +/* Account autocomplete window */ + +#account_results ul { + list-style-type:none; + background:rgba(255,255,255,0.9); + padding:0; +} + +#account_results li { + display:block; + padding:5px 20px; + height:100%; + width:100%; +} + +#account_results .hilight { + background:rgba(200,16,46,0.9); + color:#fff; + text-decoration:none; +} + +/** + * Stats (graphs) */ -.messages .alert { - padding:10px 15px; - margin:0; - border:0; - border-radius:0; +.stat-nav { + margin-bottom: 10px; + font-family: Roboto; } -.messages .alert .close { - top:0; - right:0; +.stat-nav li { + float: left; } -.messages .alert-info { - color:inherit; - background-color:#ccc; +.stat-nav a { + opacity: 0.6; + font-family: Roboto; } -.messages .alert-error { - color: white; - background-color: #c63b52; -} - -.messages .alert-success { - color: white; - background: #3d9947; -} - -.messages a { - font-weight: bold; - text-decoration: none; +.stat-nav a:hover, +.stat-nav a.focus, .stat-nav a:focus { + opacity: 1; } /* @@ -488,57 +273,10 @@ thead .tooltip { height: 100px; } -/* - * Responsive Columns - */ - -.unbreakable { - display:inline-block; - width: 100%; -} - -.column-xs-1, .column-sm-1, .column-md-1, .column-lg-1, -.column-xs-2, .column-sm-2, .column-md-2, .column-lg-2, -.column-xs-3, .column-sm-3, .column-md-3, .column-lg-3, -.column-xs-4, .column-sm-4, .column-md-4, .column-lg-4, -.column-xs-5, .column-sm-5, .column-md-5, .column-lg-5 { - column-count: 1; - column-gap: 0; -} - -.column-xs-1 { column-count: 1; } -.column-xs-2 { column-count: 2; } -.column-xs-3 { column-count: 3; } -.column-xs-4 { column-count: 4; } -.column-xs-5 { column-count: 5; } - -@media (min-width: 768px) { - .column-sm-1 { column-count: 1; } - .column-sm-2 { column-count: 2; } - .column-sm-3 { column-count: 3; } - .column-sm-4 { column-count: 4; } - .column-sm-5 { column-count: 5; } -} - -@media (min-width: 992px) { - .column-md-1 { column-count: 1; } - .column-md-2 { column-count: 2; } - .column-md-3 { column-count: 3; } - .column-md-4 { column-count: 4; } - .column-md-5 { column-count: 5; } -} - -@media (min-width: 1200px) { - .column-lg-1 { column-count: 1; } - .column-lg-2 { column-count: 2; } - .column-lg-3 { column-count: 3; } - .column-lg-4 { column-count: 4; } - .column-lg-5 { column-count: 5; } -} /* Inventaires */ -#inventoryform input[type=number] { +.table-condensed-input input[type=number] { text-align: center; } @@ -557,18 +295,6 @@ thead .tooltip { margin: 0 auto; } -/* Multiple select customizations */ - -.ms-choice { - height: 34px !important; - line-height: 34px !important; - border: 1px solid #ccc !important; - box-shadow: inset 0 1px 1px rgba(0,0,0,.075) !important; -} - -.ms-choice > div { - top: 4px !important; -} /* Checkbox select multiple */ diff --git a/kfet/static/kfet/css/libs/columns.css b/kfet/static/kfet/css/libs/columns.css new file mode 100644 index 00000000..34591061 --- /dev/null +++ b/kfet/static/kfet/css/libs/columns.css @@ -0,0 +1,43 @@ +.unbreakable { + display:inline-block; + width: 100%; +} + +.column-xs-1, .column-sm-1, .column-md-1, .column-lg-1, +.column-xs-2, .column-sm-2, .column-md-2, .column-lg-2, +.column-xs-3, .column-sm-3, .column-md-3, .column-lg-3, +.column-xs-4, .column-sm-4, .column-md-4, .column-lg-4, +.column-xs-5, .column-sm-5, .column-md-5, .column-lg-5 { + column-count: 1; +} + +.column-xs-1 { column-count: 1; } +.column-xs-2 { column-count: 2; } +.column-xs-3 { column-count: 3; } +.column-xs-4 { column-count: 4; } +.column-xs-5 { column-count: 5; } + +@media (min-width: 768px) { + .column-sm-1 { column-count: 1; } + .column-sm-2 { column-count: 2; } + .column-sm-3 { column-count: 3; } + .column-sm-4 { column-count: 4; } + .column-sm-5 { column-count: 5; } +} + +@media (min-width: 992px) { + .column-md-1 { column-count: 1; } + .column-md-2 { column-count: 2; } + .column-md-3 { column-count: 3; } + .column-md-4 { column-count: 4; } + .column-md-5 { column-count: 5; } +} + +@media (min-width: 1200px) { + .column-lg-1 { column-count: 1; } + .column-lg-2 { column-count: 2; } + .column-lg-3 { column-count: 3; } + .column-lg-4 { column-count: 4; } + .column-lg-5 { column-count: 5; } +} + diff --git a/kfet/static/kfet/css/jconfirm-kfet.css b/kfet/static/kfet/css/libs/jconfirm-kfet.css similarity index 81% rename from kfet/static/kfet/css/jconfirm-kfet.css rename to kfet/static/kfet/css/libs/jconfirm-kfet.css index 1e05a816..d2803434 100644 --- a/kfet/static/kfet/css/jconfirm-kfet.css +++ b/kfet/static/kfet/css/libs/jconfirm-kfet.css @@ -49,7 +49,7 @@ } .jconfirm .jconfirm-box .buttons button { - width:40px; + min-width:40px; height:100%; margin:0; margin:0 !important; @@ -85,24 +85,3 @@ padding-right: 50px; padding-left: 50px; } - -/* Account autocomplete window */ - -#account_results ul { - list-style-type:none; - background:rgba(255,255,255,0.9); - padding:0; -} - -#account_results li { - display:block; - padding:5px 20px; - height:100%; - width:100%; -} - -#account_results .hilight { - background:rgba(200,16,46,0.9); - color:#fff; - text-decoration:none; -} diff --git a/kfet/static/kfet/css/libs/multiple-select-kfet.css b/kfet/static/kfet/css/libs/multiple-select-kfet.css new file mode 100644 index 00000000..145968d3 --- /dev/null +++ b/kfet/static/kfet/css/libs/multiple-select-kfet.css @@ -0,0 +1,14 @@ +/** + * Multiple Select plugin customizations + */ + +.ms-choice { + height: 34px !important; + line-height: 34px !important; + border: 1px solid #ccc !important; + box-shadow: inset 0 1px 1px rgba(0,0,0,.075) !important; +} + +.ms-choice > div { + top: 4px !important; +} diff --git a/kfet/static/kfet/js/kfet.js b/kfet/static/kfet/js/kfet.js index 72ae675a..c977d534 100644 --- a/kfet/static/kfet/js/kfet.js +++ b/kfet/static/kfet/js/kfet.js @@ -30,7 +30,7 @@ class KfetWebsocket { constructor(data) { $.extend(this, this.constructor.defaults, data); } - + get url() { var websocket_protocol = window.location.protocol == 'https:' ? 'wss' : 'ws'; var location_host = window.location.host; @@ -184,3 +184,13 @@ function requestAuth(data, callback, focus_next = null) { }); } + + +/** + * Setup jquery-confirm + */ + +jconfirm.defaults = { + confirmButton: '', + cancelButton: '' +}; diff --git a/kfet/static/kfet/js/statistic.js b/kfet/static/kfet/js/statistic.js index d185b604..9baa08c4 100644 --- a/kfet/static/kfet/js/statistic.js +++ b/kfet/static/kfet/js/statistic.js @@ -7,7 +7,7 @@ var self = this; var element = $(target); - var content = $("
"); + var content = $("
"); var buttons; function dictToArray (dict, start) { @@ -153,9 +153,8 @@ // initialize the interface function initialize (data) { // creates the bar with the buttons - buttons = $("
", - {class: "btn-group btn-group-justified", - role: "group", + buttons = $("
    ", + {class: "nav stat-nav", "aria-label": "select-period"}); var to_click; @@ -163,11 +162,9 @@ for (var i = 0; i < context.length; i++) { // creates the button - var btn_wrapper = $("
    ", - {class: "btn-group", - role:"group"}); - var btn = $("
{% endif %} {% endblock %} -{% block main-content %} +{% block main %} -
-

Liste des comptes en négatifs

-
- - - - - - - - - - - - - - - {% for neg in negatives %} - - - - - - - - - - - {% endfor %} - -
Tri.NomBalanceRéelleDébutDécouvert autoriséJusqu'auBalance offset
- - {{ neg.account.trigramme }} - - {{ neg.account.name }}{{ neg.account.balance|floatformat:2 }}€ - {% if neg.balance_offset %} - {{ neg.account.real_balance|floatformat:2 }}€ - {% endif %} - {{ neg.start|date:'d/m/Y H:i:s'}}{{ neg.authz_overdraft_amount|default_if_none:'' }}{{ neg.authz_overdrafy_until|default_if_none:'' }}{{ neg.balance_offset|default_if_none:'' }}
-
+
+ + + + + + + + + + + + + + + {% for neg in negatives %} + + + + + + + + + + + {% endfor %} + +
Tri.NomBalanceRéelleDébutDécouvert autoriséJusqu'auBalance offset
+ + {{ neg.account.trigramme }} + + {{ neg.account.name }}{{ neg.account.balance|floatformat:2 }}€ + {% if neg.balance_offset %} + {{ neg.account.real_balance|floatformat:2 }}€ + {% endif %} + {{ neg.start|date:'d/m/Y H:i:s'}}{{ neg.authz_overdraft_amount|default_if_none:'' }}{{ neg.authz_overdrafy_until|default_if_none:'' }}{{ neg.balance_offset|default_if_none:'' }}
{% endblock %} diff --git a/kfet/templates/kfet/account_read.html b/kfet/templates/kfet/account_read.html index fc8babc5..15238b64 100644 --- a/kfet/templates/kfet/account_read.html +++ b/kfet/templates/kfet/account_read.html @@ -48,38 +48,43 @@ $(document).ready(function() { {% include "kfet/base_footer.html" %} {% endblock %} -{% block fixed-content %} +{% block fixed %} {% include "kfet/left_account.html" %} {% endblock %} -{% block main-content %} +{% block main %}
+ {% if account.user == request.user %} -
-

Statistiques

-
-

Ma balance

-
-

Ma consommation

-
-
-
+
+
+
+

Ma balance

+
+

Ma consommation

+
+
+
+
{% endif %} -
- {% if addcosts %} -

Gagné des majorations

-
-
    - {% for addcost in addcosts %} -
  • {{ addcost.date|date:'l j F' }}: +{{ addcost.sum_addcosts }}€
  • - {% endfor %} -
-
- {% endif %} -

Historique

-
-
+ +
+
+ {% if addcosts %} +

Gagné des majorations

+
+
    + {% for addcost in addcosts %} +
  • {{ addcost.date|date:'l j F' }}: +{{ addcost.sum_addcosts }}€
  • + {% endfor %} +
+
+ {% endif %} +
+
+
+
@@ -9,96 +9,104 @@ {% block title %}Article - {{ article.name }}{% endblock %} {% block header-title %}Informations sur l'article {{ article.name }}{% endblock %} -{% block fixed-content %} +{% block fixed %} -
-
{{ article.name }}
-
{{ article.category }}
-
- + + + {% endblock %} -{% block main-content %} +{% block main %} -
-

Historique

-
-
-

Inventaires

-
- - - - - - - - - - {% for inventoryart in inventoryarts %} - - - - - - {% endfor %} - -
DateStockErreur
- - {{ inventoryart.inventory.at }} - - {{ inventoryart.stock_new }}{{ inventoryart.stock_error }}
-
-
-
-

Prix fournisseurs

-
- - - - - - - - - - - - {% for supplierart in supplierarts %} - - - - - - - - {% endfor %} - -
DateFournisseurHTTVADroits
{{ supplierart.at }}{{ supplierart.supplier.name }}{{ supplierart.price_HT }}{{ supplierart.TVA }}{{ supplierart.rights }}
-
-
-
-
-
-

Statistiques

+
+ +
+ +
+
+
+
+ +

Inventaires récents

+
+ {% include "kfet/article_inventories_snippet.html" with inventoryarts=inventoryarts|slice:5 %} +
+ +
+
+ +

Derniers prix fournisseurs

+
+ {% include "kfet/article_suppliers_snippet.html" with supplierarts=supplierarts|slice:5 %} +
+ +
+
+
+
+ +

Ventes

+
+ +
+ +
+
+ {% include "kfet/article_inventories_snippet.html" %} +
+
+ +
+
+ {% include "kfet/article_suppliers_snippet.html" %} +
+
+
diff --git a/kfet/templates/kfet/article_suppliers_snippet.html b/kfet/templates/kfet/article_suppliers_snippet.html new file mode 100644 index 00000000..bd5970fd --- /dev/null +++ b/kfet/templates/kfet/article_suppliers_snippet.html @@ -0,0 +1,22 @@ + + + + + + + + + + + + {% for supplierart in supplierarts %} + + + + + + + + {% endfor %} + +
DateFournisseurHTTVADroits
{{ supplierart.at }}{{ supplierart.supplier.name }}{{ supplierart.price_HT|default_if_none:"" }}{{ supplierart.TVA|default_if_none:"" }}{{ supplierart.rights|default_if_none:"" }}
diff --git a/kfet/templates/kfet/article_update.html b/kfet/templates/kfet/article_update.html index d451df94..3f09e48e 100644 --- a/kfet/templates/kfet/article_update.html +++ b/kfet/templates/kfet/article_update.html @@ -1,12 +1,10 @@ -{% extends "kfet/base_col_1.html" %} +{% extends "kfet/base_form.html" %} {% block title %}{{ article.name }} - Édition{% endblock %} {% block header-title %}Édition de l'article {{ article.name }}{% endblock %} -{% block main-class %}content-form{% endblock %} +{% block main %} -{% block main-content %} - -{% include "kfet/base_form.html" with authz=perms.kfet.change_article submit_text="Mettre à jour"%} +{% include "kfet/form_full_snippet.html" with authz=perms.kfet.change_article submit_text="Mettre à jour"%} {% endblock %} diff --git a/kfet/templates/kfet/base.html b/kfet/templates/kfet/base.html index b18ee719..ecd69c3d 100644 --- a/kfet/templates/kfet/base.html +++ b/kfet/templates/kfet/base.html @@ -1,5 +1,4 @@ -{% load staticfiles %} -{% load menu_tags %} +{% load static menu_tags %} @@ -33,17 +32,17 @@ - {% main_menu template="kfet/base_nav.html" %} + {% flat_menu "kfet-nav" template="kfet/base_nav.html" apply_active_classes=True %}
{% block header %} {% if not page or not page.no_header %} -
-
-

+
+
+

{% block header-title %}{% endblock %}

-

+ {% endif %} {% endblock %} diff --git a/kfet/templates/kfet/base_col_1.html b/kfet/templates/kfet/base_col_1.html index 6bd6dd5c..03fea5e7 100644 --- a/kfet/templates/kfet/base_col_1.html +++ b/kfet/templates/kfet/base_col_1.html @@ -4,11 +4,11 @@ {% block content %} -
-
+
+
{% include "kfet/base_messages.html" %} -
- {% block main-content %}{% endblock %} +
+ {% block main %}{% endblock %}
diff --git a/kfet/templates/kfet/base_col_2.html b/kfet/templates/kfet/base_col_2.html index 2a1f8cd4..d0ac45b7 100644 --- a/kfet/templates/kfet/base_col_2.html +++ b/kfet/templates/kfet/base_col_2.html @@ -2,16 +2,16 @@ {% block content %} -
-
-
- {% block fixed-content %}{% endblock %} +
+
+
+ {% block fixed %}{% endblock %}
-
+
{% include "kfet/base_messages.html" %} -
- {% block main-content %}{% endblock %} +
+ {% block main %}{% endblock %}
diff --git a/kfet/templates/kfet/base_col_mult.html b/kfet/templates/kfet/base_col_mult.html new file mode 100644 index 00000000..e5bafc19 --- /dev/null +++ b/kfet/templates/kfet/base_col_mult.html @@ -0,0 +1,18 @@ +{% extends "kfet/base.html" %} + +{% block header-class %}text-center{% endblock %} + +{% block content %} + +
+
+ {% include "kfet/base_messages.html" %} +
+
+ {% block main %}{% endblock %} +
+
+
+
+ +{% endblock %} diff --git a/kfet/templates/kfet/base_footer.html b/kfet/templates/kfet/base_footer.html index be524139..c5333476 100644 --- a/kfet/templates/kfet/base_footer.html +++ b/kfet/templates/kfet/base_footer.html @@ -2,7 +2,7 @@ {% with "k-fet@ens.fr" as kfet_mail %} -