diff --git a/.gitignore b/.gitignore
new file mode 100644
index 0000000..c93bba9
--- /dev/null
+++ b/.gitignore
@@ -0,0 +1,164 @@
+# Created by https://www.gitignore.io
+
+### OSX ###
+.DS_Store
+.AppleDouble
+.LSOverride
+
+# Icon must end with two \r
+Icon
+
+
+# Thumbnails
+._*
+
+# Files that might appear on external disk
+.Spotlight-V100
+.Trashes
+
+# Directories potentially created on remote AFP share
+.AppleDB
+.AppleDesktop
+Network Trash Folder
+Temporary Items
+.apdisk
+
+
+### Python ###
+# Byte-compiled / optimized / DLL files
+__pycache__/
+*.py[cod]
+
+# C extensions
+*.so
+
+# Distribution / packaging
+.Python
+env/
+build/
+develop-eggs/
+dist/
+downloads/
+eggs/
+lib/
+lib64/
+parts/
+sdist/
+var/
+*.egg-info/
+.installed.cfg
+*.egg
+
+# PyInstaller
+# Usually these files are written by a python script from a template
+# before PyInstaller builds the exe, so as to inject date/other infos into it.
+*.manifest
+*.spec
+
+# Installer logs
+pip-log.txt
+pip-delete-this-directory.txt
+
+# Unit test / coverage reports
+htmlcov/
+.tox/
+.coverage
+.cache
+nosetests.xml
+coverage.xml
+
+# Translations
+*.mo
+*.pot
+
+# Sphinx documentation
+docs/_build/
+
+# PyBuilder
+target/
+
+
+### Django ###
+*.log
+*.pot
+*.pyc
+__pycache__/
+local_settings.py
+static/
+media/
+
+
+.env
+db.sqlite3
+
+# Covers JetBrains IDEs: IntelliJ, RubyMine, PhpStorm, AppCode, PyCharm, CLion, Android Studio and WebStorm
+# Reference: https://intellij-support.jetbrains.com/hc/en-us/articles/206544839
+
+# User-specific stuff
+.idea/**/workspace.xml
+.idea/**/tasks.xml
+.idea/**/usage.statistics.xml
+.idea/**/dictionaries
+.idea/**/shelf
+
+# Generated files
+.idea/**/contentModel.xml
+
+# Sensitive or high-churn files
+.idea/**/dataSources/
+.idea/**/dataSources.ids
+.idea/**/dataSources.local.xml
+.idea/**/sqlDataSources.xml
+.idea/**/dynamic.xml
+.idea/**/uiDesigner.xml
+.idea/**/dbnavigator.xml
+
+# Gradle
+.idea/**/gradle.xml
+.idea/**/libraries
+
+# Gradle and Maven with auto-import
+# When using Gradle or Maven with auto-import, you should exclude module files,
+# since they will be recreated, and may cause churn. Uncomment if using
+# auto-import.
+# .idea/artifacts
+# .idea/compiler.xml
+# .idea/jarRepositories.xml
+# .idea/modules.xml
+# .idea/*.iml
+# .idea/modules
+# *.iml
+# *.ipr
+
+# CMake
+cmake-build-*/
+
+# Mongo Explorer plugin
+.idea/**/mongoSettings.xml
+
+# File-based project format
+*.iws
+
+# IntelliJ
+out/
+
+# mpeltonen/sbt-idea plugin
+.idea_modules/
+
+# JIRA plugin
+atlassian-ide-plugin.xml
+
+# Cursive Clojure plugin
+.idea/replstate.xml
+
+# Crashlytics plugin (for Android Studio and IntelliJ)
+com_crashlytics_export_strings.xml
+crashlytics.properties
+crashlytics-build.properties
+fabric.properties
+
+# Editor-based Rest Client
+.idea/httpRequests
+
+# Android studio 3.1+ serialized cache file
+.idea/caches/build_file_checksums.ser
\ No newline at end of file
diff --git a/.idea/.gitignore b/.idea/.gitignore
deleted file mode 100644
index 0e40fe8..0000000
--- a/.idea/.gitignore
+++ /dev/null
@@ -1,3 +0,0 @@
-
-# Default ignored files
-/workspace.xml
\ No newline at end of file
diff --git a/.idea/codeStyles/codeStyleConfig.xml b/.idea/codeStyles/codeStyleConfig.xml
new file mode 100644
index 0000000..a55e7a1
--- /dev/null
+++ b/.idea/codeStyles/codeStyleConfig.xml
@@ -0,0 +1,5 @@
+
+
+
+
+
\ No newline at end of file
diff --git a/.idea/dataSources.xml b/.idea/dataSources.xml
new file mode 100644
index 0000000..af8df27
--- /dev/null
+++ b/.idea/dataSources.xml
@@ -0,0 +1,13 @@
+
+
+
+
+ mysql.8
+ true
+ true
+ $PROJECT_DIR$/gnousEU/settings.py
+ com.mysql.cj.jdbc.Driver
+ jdbc:mysql://127.0.0.1:3306/tuxbot
+
+
+
\ No newline at end of file
diff --git a/.idea/gnousEU.iml b/.idea/gnousEU.iml
new file mode 100644
index 0000000..b69a62b
--- /dev/null
+++ b/.idea/gnousEU.iml
@@ -0,0 +1,31 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/.idea/gnousdoteu.iml b/.idea/gnousdoteu.iml
deleted file mode 100644
index d6ebd48..0000000
--- a/.idea/gnousdoteu.iml
+++ /dev/null
@@ -1,9 +0,0 @@
-
-
-
-
-
-
-
-
-
\ No newline at end of file
diff --git a/.idea/inspectionProfiles/profiles_settings.xml b/.idea/inspectionProfiles/profiles_settings.xml
new file mode 100644
index 0000000..105ce2d
--- /dev/null
+++ b/.idea/inspectionProfiles/profiles_settings.xml
@@ -0,0 +1,6 @@
+
+
+
+
+
+
\ No newline at end of file
diff --git a/.idea/misc.xml b/.idea/misc.xml
index 28a804d..1ce7ec9 100644
--- a/.idea/misc.xml
+++ b/.idea/misc.xml
@@ -3,4 +3,5 @@
+
\ No newline at end of file
diff --git a/.idea/modules.xml b/.idea/modules.xml
index a4a2af0..e4e62ab 100644
--- a/.idea/modules.xml
+++ b/.idea/modules.xml
@@ -2,7 +2,7 @@
-
+
\ No newline at end of file
diff --git a/.idea/vcs.xml b/.idea/vcs.xml
index 35eb1dd..94a25f7 100644
--- a/.idea/vcs.xml
+++ b/.idea/vcs.xml
@@ -1,6 +1,6 @@
-
+
\ No newline at end of file
diff --git a/.idea/watcherTasks.xml b/.idea/watcherTasks.xml
new file mode 100644
index 0000000..73e170a
--- /dev/null
+++ b/.idea/watcherTasks.xml
@@ -0,0 +1,25 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/LICENSE b/LICENSE
deleted file mode 100644
index 15f64ac..0000000
--- a/LICENSE
+++ /dev/null
@@ -1,7 +0,0 @@
-Copyright 2019 Maël G.
-
-Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
-
-The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
-
-THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
diff --git a/README.md b/README.md
deleted file mode 100644
index b424647..0000000
--- a/README.md
+++ /dev/null
@@ -1,66 +0,0 @@
-# Gnous.eu
-
-![https://git.gnous.eu/gnouseu/gnousdoteu/raw/branch/master/public/img/gnous.png](https://git.gnous.eu/gnouseu/gnousdoteu/raw/branch/master/public/img/gnous.png)
-
-[![forthebadge](https://forthebadge.com/images/badges/built-with-love.svg)](https://forthebadge.com) [![forthebadge](https://forthebadge.com/images/badges/uses-html.svg)](https://forthebadge.com)
-
-Main website of [Gnous.eu](https://gnous.eu/?lang=en), the French speaking community of free software enthusiasts since 2017.
-
-This website use Smarty template engine and Spectre CSS framework.
-
-This project is **stable** and is already in production.
-
-## Deployment
-
-### Requirements :
-
-To deploy this website you need :
-
-1. PHP7+
-2. Composer (only for **developpement**)
-3. A webserver (NGINX is recommanded)
-4. At least 1.5 Gb of hard drive
-5. modrewrite and .htaccess enabled (in the case of apache)
-6. Git
-
-### Installation :
-
-* Clone the Git repository :
-``git clone https://git.gnous.eu/gnouseu/gnousdoteu``
-
-* Make our webserver pointing to ``public`` folder. The main folder should'nt be accessible.
-
-* Allow ``/public/index.php`` to write ``/public/templates_c``.
-
-* Make our webserver serve ``/public/index.php`` for all pages **and conserving args** :
-
-eg for NGINX (in ``server{``) :
-
-```
- location / {
- try_files $uri $uri/ /index.php?$args;
- }
-```
-
-* Make our webserver serve it for 404 and 403 too :
-
-eg for NGINX (in ``server{``) :
-
-```
- error_page 404 /index.php;
- error_page 403 /index.php;
-```
-
-* If you use modpagespeed, disable it for ``/img/gnous.svg``:
-
-eg for NGINX-modpagespeed (in ``server{``) :
-
-```
- pagespeed Disallow "*/img/gnous.svg";
-```
-
-* Reload your webserver and check if all is working
-
-### License :
-
-This project is under [MIT license](LICENSE)
diff --git a/public/qtx6okr.txt b/apps/__init__.py
similarity index 100%
rename from public/qtx6okr.txt
rename to apps/__init__.py
diff --git a/apps/gnous_eu/__init__.py b/apps/gnous_eu/__init__.py
new file mode 100644
index 0000000..e69de29
diff --git a/apps/gnous_eu/admin.py b/apps/gnous_eu/admin.py
new file mode 100644
index 0000000..4729efc
--- /dev/null
+++ b/apps/gnous_eu/admin.py
@@ -0,0 +1,23 @@
+from django.contrib import admin
+
+from apps.gnous_eu.models import Service
+
+
+class ServicesAdmin(admin.ModelAdmin):
+ list_display = (
+ "id",
+ "name",
+ "sources",
+ "hosted",
+ "domain_tag",
+ "image_tag",
+ "hidden",
+ )
+ fieldsets = [
+ ("Global", {"fields": ["name", "domain", "photo", "description"]}),
+ ("Types", {"fields": ["sources", "hosted"]}),
+ ("Misc", {"fields": ["hidden"]}),
+ ]
+
+
+admin.site.register(Service, ServicesAdmin)
diff --git a/apps/gnous_eu/apps.py b/apps/gnous_eu/apps.py
new file mode 100644
index 0000000..2d83180
--- /dev/null
+++ b/apps/gnous_eu/apps.py
@@ -0,0 +1,10 @@
+from django.apps import AppConfig
+from suit.apps import DjangoSuitConfig
+
+
+class GnousEuConfig(AppConfig):
+ name = "apps.gnous_eu"
+
+
+class SuitConfig(DjangoSuitConfig):
+ layout = "vertical"
diff --git a/apps/gnous_eu/migrations/0001_initial.py b/apps/gnous_eu/migrations/0001_initial.py
new file mode 100644
index 0000000..6d4924d
--- /dev/null
+++ b/apps/gnous_eu/migrations/0001_initial.py
@@ -0,0 +1,48 @@
+# Generated by Django 3.0.2 on 2020-05-15 16:59
+
+from django.db import migrations, models
+
+
+class Migration(migrations.Migration):
+
+ initial = True
+
+ dependencies = []
+
+ operations = [
+ migrations.CreateModel(
+ name="Service",
+ fields=[
+ ("id", models.AutoField(primary_key=True, serialize=False)),
+ ("name", models.CharField(max_length=150)),
+ ("description", models.TextField()),
+ ("photo", models.ImageField(upload_to="services")),
+ (
+ "sources",
+ models.CharField(
+ choices=[
+ ("CLOSED", "Sources closes"),
+ ("OPEN", "Sources ouvertes"),
+ ("UNK", "Inconnu"),
+ ],
+ default="UNK",
+ max_length=10,
+ ),
+ ),
+ (
+ "hosted",
+ models.CharField(
+ choices=[
+ ("FED", "Fédéré"),
+ ("CENT", "Centralisé"),
+ ("UNK", "Inconnu"),
+ ],
+ default="UNK",
+ max_length=10,
+ ),
+ ),
+ ("domain", models.CharField(max_length=150)),
+ ("hidden", models.BooleanField(default=False)),
+ ],
+ ),
+ ]
diff --git a/apps/gnous_eu/migrations/__init__.py b/apps/gnous_eu/migrations/__init__.py
new file mode 100644
index 0000000..e69de29
diff --git a/apps/gnous_eu/models.py b/apps/gnous_eu/models.py
new file mode 100644
index 0000000..927abdf
--- /dev/null
+++ b/apps/gnous_eu/models.py
@@ -0,0 +1,43 @@
+from django.db import models
+from django.conf import settings
+from django.utils.safestring import mark_safe
+from django.utils.translation import gettext
+
+
+class Service(models.Model):
+ class SourcesType(models.TextChoices):
+ closed = "CLOSED", gettext("Sources closes")
+ open = "OPEN", gettext("Sources ouvertes")
+ unknown = "UNK", gettext("Inconnu")
+
+ class HostedType(models.TextChoices):
+ federated = "FED", gettext("Fédéré")
+ centralized = "CENT", gettext("Centralisé")
+ unknown = "UNK", gettext("Inconnu")
+
+ id = models.AutoField(primary_key=True)
+ name = models.CharField(max_length=150)
+ description = models.TextField()
+ photo = models.ImageField(upload_to="services")
+
+ sources = models.CharField(
+ max_length=10, choices=SourcesType.choices, default=SourcesType.unknown,
+ )
+ hosted = models.CharField(
+ max_length=10, choices=HostedType.choices, default=HostedType.unknown,
+ )
+
+ domain = models.CharField(max_length=150)
+ hidden = models.BooleanField(default=False)
+
+ def domain_tag(self):
+ return mark_safe(
+ f'{self.domain}'
+ )
+
+ def image_tag(self):
+ return mark_safe(
+ f"'
+ )
diff --git a/apps/gnous_eu/templates/about.html b/apps/gnous_eu/templates/about.html
new file mode 100644
index 0000000..a4c1cfc
--- /dev/null
+++ b/apps/gnous_eu/templates/about.html
@@ -0,0 +1,23 @@
+{% extends 'layouts/base.html' %}
+{% load static %}
+{% load i18n %}
+
+{% block content %}
+
+
+
+
+
{% trans 'À propos' %}
+
+
+
+
{% trans "GnousEU est une communauté de passionnés du libre ayant débuté en Février 2017 sur la plateforme Discord. Depuis elle s'est diversifiée sur plusieurs plateformes hébergées par elle même en favoirsant les instances déscentralisées. Elle ne cesse de grandir de jour en jour et est ouverte à tous nouveaux membres. Un système de recensemment des membre et d'interconnexion des plateformes est toujours à l'étude pour permettre une meilleure continuité au sein de la communauté. Actuellement la grande majorité de ses membres se trouvent sur le serveur Discord." %}
+
{% trans "Cette communauté à été créée par Mael G. aka Outout et est administrée par lui même mais aussi par Romain J., Rick Krict, DoomQuakeKeen et Orakle au design." %}
+
{% trans "GnousEU est hébergé sur l'infrastructure EnPLS.org disposant de serveurs en France, Pays-Bas, Allemagne et Guadeloupe." %}
\ No newline at end of file
diff --git a/apps/gnous_eu/templates/services.html b/apps/gnous_eu/templates/services.html
new file mode 100644
index 0000000..313f2d5
--- /dev/null
+++ b/apps/gnous_eu/templates/services.html
@@ -0,0 +1,123 @@
+{% extends 'layouts/base.html' %}
+{% load static %}
+{% load i18n %}
+
+{% block content %}
+
+
+
+
+
{% trans 'Nos services' %}
+
{% trans "GnousEU propose à tous des services gratuits et libre d'utilisations à tous. Ces services sont majoritairement opensource et ne volent pas vos précieuses données personnelles." %}
+ {% trans 'Vous souhaitez nous donner du materiel ?' %}
+
+
{% trans 'Vous disposez de materiel réseau ou serveur usagé et vous ne savez pas quoi en faire ?' %}
+
+ {% trans 'Contactez nous par mail à ' %}
+ dons@gnous.eu
+
+
+
+
+
+ {% trans 'Vous êtes fournisseur de services ?' %}
+
+
{% trans 'Discutons plus en détails de votre proposition ! Nous sommes ouvert à tout partenariat.' %}
+
+ {% trans 'Contactez nous par mail à ' %}
+ mael@gnous.eu
+
+
+
+
+
+{% endblock %}
diff --git a/apps/gnous_eu/tests.py b/apps/gnous_eu/tests.py
new file mode 100644
index 0000000..7ce503c
--- /dev/null
+++ b/apps/gnous_eu/tests.py
@@ -0,0 +1,3 @@
+from django.test import TestCase
+
+# Create your tests here.
diff --git a/apps/gnous_eu/urls.py b/apps/gnous_eu/urls.py
new file mode 100644
index 0000000..cb033bd
--- /dev/null
+++ b/apps/gnous_eu/urls.py
@@ -0,0 +1,13 @@
+from django.urls import path, include
+from django.views.generic import TemplateView
+
+from .views import ServicesView
+
+app_name = "gnous_eu"
+
+urlpatterns = [
+ path("", TemplateView.as_view(template_name="index.html"), name="index"),
+ path("about", TemplateView.as_view(template_name="about.html"), name="about"),
+ path("tips", TemplateView.as_view(template_name="tips.html"), name="tips"),
+ path("services", ServicesView.index, name="services"),
+]
diff --git a/apps/gnous_eu/views.py b/apps/gnous_eu/views.py
new file mode 100644
index 0000000..1798dbf
--- /dev/null
+++ b/apps/gnous_eu/views.py
@@ -0,0 +1,37 @@
+from django.http import HttpResponse, HttpResponseNotFound, HttpRequest
+from django.shortcuts import render
+from django.core.paginator import Paginator
+from django.db.models import Q
+
+from apps.gnous_eu.models import Service
+
+TEMPLATE_PATH = "./"
+
+
+class ServicesView:
+ @staticmethod
+ def index(request: HttpRequest, *args, **kwargs) -> HttpResponse:
+ search: str = request.GET.get("search", False)
+
+ if search:
+ data_services = Service.objects.all().filter(
+ Q(id__exact=int(search) if search.isdigit() else 0)
+ | Q(name__icontains=search)
+ | Q(description__icontains=search)
+ | Q(sources__icontains=search)
+ | Q(hosted__icontains=search)
+ | Q(domain__icontains=search)
+ | Q(sources__icontains=search)
+ | Q(hosted__icontains=search)
+ )
+ else:
+ data_services = Service.objects.all().filter(hidden=False)
+ paginator = Paginator(data_services, 30)
+
+ page = request.GET.get("page")
+
+ return render(
+ request,
+ TEMPLATE_PATH + "services.html",
+ {"services": paginator.get_page(page), "search": search},
+ )
diff --git a/composer.json b/composer.json
deleted file mode 100644
index 3920766..0000000
--- a/composer.json
+++ /dev/null
@@ -1,5 +0,0 @@
-{
- "require": {
- "smarty/smarty": "^3.1"
- }
-}
diff --git a/composer.lock b/composer.lock
deleted file mode 100644
index 16cfa5b..0000000
--- a/composer.lock
+++ /dev/null
@@ -1,71 +0,0 @@
-{
- "_readme": [
- "This file locks the dependencies of your project to a known state",
- "Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies",
- "This file is @generated automatically"
- ],
- "content-hash": "99bccada065081929698167137529f9f",
- "packages": [
- {
- "name": "smarty/smarty",
- "version": "v3.1.33",
- "source": {
- "type": "git",
- "url": "https://github.com/smarty-php/smarty.git",
- "reference": "dd55b23121e55a3b4f1af90a707a6c4e5969530f"
- },
- "dist": {
- "type": "zip",
- "url": "https://api.github.com/repos/smarty-php/smarty/zipball/dd55b23121e55a3b4f1af90a707a6c4e5969530f",
- "reference": "dd55b23121e55a3b4f1af90a707a6c4e5969530f",
- "shasum": ""
- },
- "require": {
- "php": ">=5.2"
- },
- "type": "library",
- "extra": {
- "branch-alias": {
- "dev-master": "3.1.x-dev"
- }
- },
- "autoload": {
- "files": [
- "libs/bootstrap.php"
- ]
- },
- "notification-url": "https://packagist.org/downloads/",
- "license": [
- "LGPL-3.0"
- ],
- "authors": [
- {
- "name": "Monte Ohrt",
- "email": "monte@ohrt.com"
- },
- {
- "name": "Uwe Tews",
- "email": "uwe.tews@googlemail.com"
- },
- {
- "name": "Rodney Rehm",
- "email": "rodney.rehm@medialize.de"
- }
- ],
- "description": "Smarty - the compiling PHP template engine",
- "homepage": "http://www.smarty.net",
- "keywords": [
- "templating"
- ],
- "time": "2018-09-12T20:54:16+00:00"
- }
- ],
- "packages-dev": [],
- "aliases": [],
- "minimum-stability": "stable",
- "stability-flags": [],
- "prefer-stable": false,
- "prefer-lowest": false,
- "platform": [],
- "platform-dev": []
-}
diff --git a/gnousEU/__init__.py b/gnousEU/__init__.py
new file mode 100644
index 0000000..e69de29
diff --git a/gnousEU/asgi.py b/gnousEU/asgi.py
new file mode 100644
index 0000000..84cb72b
--- /dev/null
+++ b/gnousEU/asgi.py
@@ -0,0 +1,16 @@
+"""
+ASGI config for gnousEU project.
+
+It exposes the ASGI callable as a module-level variable named ``application``.
+
+For more information on this file, see
+https://docs.djangoproject.com/en/3.0/howto/deployment/asgi/
+"""
+
+import os
+
+from django.core.asgi import get_asgi_application
+
+os.environ.setdefault("DJANGO_SETTINGS_MODULE", "gnousEU.settings")
+
+application = get_asgi_application()
diff --git a/gnousEU/settings.py b/gnousEU/settings.py
new file mode 100644
index 0000000..ff19e29
--- /dev/null
+++ b/gnousEU/settings.py
@@ -0,0 +1,126 @@
+"""
+Django settings for gnousEU project.
+
+Generated by 'django-admin startproject' using Django 3.0.2.
+
+For more information on this file, see
+https://docs.djangoproject.com/en/3.0/topics/settings/
+
+For the full list of settings and their values, see
+https://docs.djangoproject.com/en/3.0/ref/settings/
+"""
+
+import os
+
+# Build paths inside the project like this: os.path.join(BASE_DIR, ...)
+BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
+
+# Quick-start development settings - unsuitable for production
+# See https://docs.djangoproject.com/en/3.0/howto/deployment/checklist/
+
+# SECURITY WARNING: keep the secret key used in production secret!
+SECRET_KEY = "*0q64%2cb!f@w(o@b74yyi2#x1d2r#%uul+hc1=gne^8u+*3)k"
+
+# SECURITY WARNING: don't run with debug turned on in production!
+DEBUG = True
+
+ALLOWED_HOSTS = ["127.0.0.1", "localhost"]
+
+# Application definition
+
+INSTALLED_APPS = [
+ "django.contrib.auth",
+ "django.contrib.contenttypes",
+ "django.contrib.sessions",
+ "django.contrib.messages",
+ "django.contrib.staticfiles",
+ "markdownify",
+ "apps.gnous_eu",
+ "apps.gnous_eu.apps.SuitConfig",
+ "django.contrib.admin",
+]
+
+MIDDLEWARE = [
+ "django.middleware.security.SecurityMiddleware",
+ "django.contrib.sessions.middleware.SessionMiddleware",
+ 'django.middleware.locale.LocaleMiddleware',
+ "django.middleware.common.CommonMiddleware",
+ "django.middleware.csrf.CsrfViewMiddleware",
+ "django.contrib.auth.middleware.AuthenticationMiddleware",
+ "django.contrib.messages.middleware.MessageMiddleware",
+ "django.middleware.clickjacking.XFrameOptionsMiddleware",
+]
+
+ROOT_URLCONF = "gnousEU.urls"
+
+TEMPLATES = [
+ {
+ "BACKEND": "django.template.backends.django.DjangoTemplates",
+ "DIRS": [os.path.join(BASE_DIR, "apps/gnous_eu/templates")],
+ "APP_DIRS": True,
+ "OPTIONS": {
+ "context_processors": [
+ "django.template.context_processors.debug",
+ "django.template.context_processors.request",
+ "django.contrib.auth.context_processors.auth",
+ "django.contrib.messages.context_processors.messages",
+ ],
+ },
+ },
+]
+
+WSGI_APPLICATION = "gnousEU.wsgi.application"
+
+# Database
+# https://docs.djangoproject.com/en/3.0/ref/settings/#databases
+
+DATABASES = {
+ "default": {
+ "ENGINE": "django.db.backends.mysql",
+ "NAME": "gnouseu",
+ "USER": "root",
+ "PASSWORD": "root",
+ "OPTIONS": {"charset": "utf8mb4"},
+ }
+}
+
+# Password validation
+# https://docs.djangoproject.com/en/3.0/ref/settings/#auth-password-validators
+
+AUTH_PASSWORD_VALIDATORS = [
+ {
+ "NAME": "django.contrib.auth.password_validation.UserAttributeSimilarityValidator",
+ },
+ {"NAME": "django.contrib.auth.password_validation.MinimumLengthValidator",},
+ {"NAME": "django.contrib.auth.password_validation.CommonPasswordValidator",},
+ {"NAME": "django.contrib.auth.password_validation.NumericPasswordValidator",},
+]
+
+# Internationalization
+# https://docs.djangoproject.com/en/3.0/topics/i18n/
+
+LANGUAGE_CODE = "fr"
+
+TIME_ZONE = "UTC"
+
+USE_I18N = True
+
+USE_L10N = True
+
+USE_TZ = True
+
+LOCALE_PATHS = (os.path.join(BASE_DIR, "locale"),)
+
+LANGUAGES = (
+ ("fr", "FR"),
+ ("en", "EN"),
+)
+
+# Static files (CSS, JavaScript, Images)
+# https://docs.djangoproject.com/en/3.0/howto/static-files/
+
+STATIC_URL = "/static/"
+STATIC_ROOT = os.path.join(BASE_DIR, "static")
+
+MEDIA_URL = "/media/"
+MEDIA_ROOT = os.path.join(BASE_DIR, "media")
diff --git a/gnousEU/urls.py b/gnousEU/urls.py
new file mode 100644
index 0000000..dd38a05
--- /dev/null
+++ b/gnousEU/urls.py
@@ -0,0 +1,25 @@
+"""gnousEU URL Configuration
+
+The `urlpatterns` list routes URLs to views. For more information please see:
+ https://docs.djangoproject.com/en/3.0/topics/http/urls/
+Examples:
+Function views
+ 1. Add an import: from my_app import views
+ 2. Add a URL to urlpatterns: path('', views.home, name='home')
+Class-based views
+ 1. Add an import: from other_app.views import Home
+ 2. Add a URL to urlpatterns: path('', Home.as_view(), name='home')
+Including another URLconf
+ 1. Import the include() function: from django.urls import include, path
+ 2. Add a URL to urlpatterns: path('blog/', include('blog.urls'))
+"""
+from django.contrib import admin
+from django.urls import path, include
+from django.conf.urls.static import static
+from django.conf import settings
+
+urlpatterns = [
+ path("admin/", admin.site.urls),
+ path("", include("apps.gnous_eu.urls", namespace="gnous_eu")),
+ path("i18n/", include("django.conf.urls.i18n")),
+] + static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT)
diff --git a/gnousEU/wsgi.py b/gnousEU/wsgi.py
new file mode 100644
index 0000000..5d227f9
--- /dev/null
+++ b/gnousEU/wsgi.py
@@ -0,0 +1,16 @@
+"""
+WSGI config for gnousEU project.
+
+It exposes the WSGI callable as a module-level variable named ``application``.
+
+For more information on this file, see
+https://docs.djangoproject.com/en/3.0/howto/deployment/wsgi/
+"""
+
+import os
+
+from django.core.wsgi import get_wsgi_application
+
+os.environ.setdefault("DJANGO_SETTINGS_MODULE", "gnousEU.settings")
+
+application = get_wsgi_application()
diff --git a/languages/en.json b/languages/en.json
deleted file mode 100644
index 6a10eaa..0000000
--- a/languages/en.json
+++ /dev/null
@@ -1,55 +0,0 @@
-{
- "nav_item_home": "Home",
- "nav_item_services": "Services",
- "nav_item_about": "About",
- "nav_item_donate": "Donate",
-
- "home_title": "GnousEU",
- "home_description": "French speaking community of free software enthusiasts since 2017.",
- "home_btn_1": "Join us by discovering our services",
-
- "services_title": "Our services",
- "services_description_1": "GnousEU offers all services free and free of uses to all.",
- "services_description_2": "These services are mostly open source and don't steal your valuable personal data.",
- "services_text_lead": "What are your preferences",
- "services_choice_all": "I like everything",
- "services_choice_opensource": "I am a pure librist",
- "services_btn_closedsource": "Closed source",
- "services_btn_centralised": "Censtralised",
- "services_btn_opensource": "OpenSource",
- "services_btn_federated": "Federated",
- "services_btn_unknown": "Unknown",
- "services_btn_join": "Join !",
- "services_discord_description": "Join the original discord server of GnousEU ! Active since 2017.",
- "services_mastodon_description": "Create your account on the Twitter descentralised alternative, Mastodon.",
- "services_matrix_description": "Get your Matrix identifier, an descentralised and federated alternative to Slack and Discord.",
- "services_git_description": "Publish your git projects on the public Gitea instance of GnousEU !",
- "services_mail_description": "Get an @gnous.eu email adress for free now !",
- "services_talk_description": "Create videoconference and screenshare freely using GnousTalk. This is an alternative to Skype or MicroSoft Teams.",
- "services_tube_description": "Create, watch and comment videos on PeerTube federation from GnousEU's instance ! An alternative to Youtube, Vimeo, ...",
- "services_purpose_title": "Submit",
- "services_purpose_description" : "You want to see a new service ? Submit it !",
- "services_purpose_btn": "Share my idea !",
-
- "about_title": "About",
- "about_description_1": "GnousEU is a community of free software enthusiasts who started in February 2017 on the Discord platform. Since then it has diversified on several platforms hosted by itself by supporting decentralized bodies. It keeps growing day by day and is open to new members. A system of census membership and interconnection of platforms is still under study to allow for better continuity within the community. Currently the vast majority of its members are on the Discord server.",
- "about_description_2": "This community was created by Mael G. aka Outout and he is administrated by itself with Romain J., Rick Krict and DoomQuakeKeen.",
- "about_description_3": "",
-
- "donate_title": "Donate to GnousEU",
- "donate_tipeee": "Participate in the development of the GnousEU community via a monetary donation via the Tipeee.",
- "donate_hardware_title": "You want to give us hardware ?",
- "donate_hardware_text": "You have network hardware or an old server and you don't know what to do with it ?",
- "donate_hardware_mail": "Contact us at dons@gnous.eu",
- "donate_services_title": "You're a service provider ?",
- "donate_services_text": "Let's discuss your proposal in more detail! We are open to any partnership.",
- "donate_services_mail": "Contact us at mael@gnous.eu",
-
- "404_title": "Oups...",
- "404_text_1": "Sorry but we can't display this page.",
- "404_text_2": "If you think isn't normal please contact an administrator",
- "404_btn": "Return to a safe place",
- "notfound": "Page not found"
-
-
-}
\ No newline at end of file
diff --git a/languages/fr.json b/languages/fr.json
deleted file mode 100644
index 81c1bf9..0000000
--- a/languages/fr.json
+++ /dev/null
@@ -1,54 +0,0 @@
-{
- "nav_item_home": "Accueil",
- "nav_item_services": "Services",
- "nav_item_about": "A propos",
- "nav_item_donate": "Donner",
-
- "home_title": "GnousEU",
- "home_description": "Communauté francophone de passionnés du libre depuis 2017.",
- "home_btn_1": "Adhérez en découvrant nos services",
-
- "services_title": "Nos Services",
- "services_description_1": "GnousEU propose à tous des services gratuits et libre d'utilisations à tous.",
- "services_description_2": "Ces services sont majoritairement opensource et ne volent pas vos précieuses données personnelles.",
- "services_text_lead": "Quelles sont vos préférences",
- "services_choice_all": "J'aime de tout",
- "services_choice_opensource": "Je suis un pur libriste",
- "services_btn_closedsource": "Closed source",
- "services_btn_centralised": "Centralisé",
- "services_btn_opensource": "OpenSource",
- "services_btn_federated": "Fédéré",
- "services_btn_unknown": "Inconnu",
- "services_btn_join": "Rejoindre !",
- "services_discord_description": "Rejoignez le serveur discord original de GnousEU ! Présent depuis 2017.",
- "services_mastodon_description": "Créez votre compte sur l'alternative à Twitter descentralisée, Mastodon.",
- "services_matrix_description": "Obtenez votre identifiant Matrix, une alternative descentralisée à Slack et Discord.",
- "services_git_description": "Publiez vos projets Git sur l'instance Gitea publique de GnousEU !",
- "services_mail_description": "Obtenez votre compte email en @gnous.eu dès maintenant et gratuitement !",
- "services_talk_description": "Effectuez gratuitement des visioconférences et des partages d'écran de façon libre et gratuite ! Alternative à Skype ou M$ Team.",
- "services_tube_description": "Partagez, visionnez et commentez des vidéos sur la fédération PeerTube à partir de l'instance de GnousEU ! Alternative à Youtube, Vimeo, ...",
- "services_purpose_title": "Proposez",
- "services_purpose_description" : "Vous souhaitez voir apparaître un nouveaux service ? Proposez le !",
- "services_purpose_btn": "Partager mon idée !",
-
- "about_title": "A propos",
- "about_description_1": "GnousEU est une communauté de passionnés du libre ayant débuté en Février 2017 sur la plateforme Discord. Depuis elle s'est diversifiée sur plusieurs plateformes hébergées par elle même en favoirsant les instances déscentralisées. Elle ne cesse de grandir de jour en jour et est ouverte à tous nouveaux membres. Un système de recensemment des membre et d'interconnexion des plateformes est toujours à l'étude pour permettre une meilleure continuité au sein de la communauté. Actuellement la grande majorité de ses membres se trouvent sur le serveur Discord.",
- "about_description_2": "Cette communauté à été créée par Mael G. aka Outout et est administrée par lui même mais aussi par Romain J., Rick Krict, DoomQuakeKeen et Orakle au design.",
- "about_description_3": "GnousEU est hébergé sur l'infrastructure EnPLS.org disposant de serveurs en France, Pays-Bas, Allemagne et Guadeloupe.",
- "donate_title": "Donnez à GnousEU",
- "donate_tipeee": "Participez au développement de la communauté de GnousEU via un don monétaire via le site Tipeee.",
- "donate_hardware_title": "Vous souhaitez nous donner du materiel ?",
- "donate_hardware_text": "Vous disposez de materiel réseau ou serveur usagé et vous ne savez pas quoi en faire ?",
- "donate_hardware_mail": "Contactez nous par mail à dons@gnous.eu",
- "donate_services_title": "Vous êtes fournisseur de services ?",
- "donate_services_text": "Discutons plus en détails de votre proposition ! Nous sommes ouvert à tout partenariat.",
- "donate_services_mail": "Contactez nous par mail à mael@gnous.eu",
-
- "404_title": "Oups...",
- "404_text_1": "Désolé mais nous ne sommes pas en mesure d'afficher cette page.",
- "404_text_2": "Vous pensez que ce n'est pas normal ? Essayez de rentrer en contact avec un administrateur.",
- "404_btn": "Retourner en lieu sûr",
- "notfound": "Page introuvable"
-
-
-}
\ No newline at end of file
diff --git a/locale/en/LC_MESSAGES/django.po b/locale/en/LC_MESSAGES/django.po
new file mode 100644
index 0000000..4465d17
--- /dev/null
+++ b/locale/en/LC_MESSAGES/django.po
@@ -0,0 +1,179 @@
+# SOME DESCRIPTIVE TITLE.
+# Copyright (C) YEAR THE PACKAGE'S COPYRIGHT HOLDER
+# This file is distributed under the same license as the PACKAGE package.
+# FIRST AUTHOR , YEAR.
+#
+#, fuzzy
+msgid ""
+msgstr ""
+"Project-Id-Version: PACKAGE VERSION\n"
+"Report-Msgid-Bugs-To: \n"
+"POT-Creation-Date: 2020-05-15 21:59+0000\n"
+"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
+"Last-Translator: FULL NAME \n"
+"Language-Team: LANGUAGE \n"
+"Language: \n"
+"MIME-Version: 1.0\n"
+"Content-Type: text/plain; charset=UTF-8\n"
+"Content-Transfer-Encoding: 8bit\n"
+"Plural-Forms: nplurals=2; plural=(n > 1);\n"
+
+#: apps/gnous_eu/models.py:9
+msgid "Sources closes"
+msgstr "Closed sources"
+
+#: apps/gnous_eu/models.py:10
+msgid "Sources ouvertes"
+msgstr "Open sources"
+
+#: apps/gnous_eu/models.py:11 apps/gnous_eu/models.py:16
+msgid "Inconnu"
+msgstr "Unknown"
+
+#: apps/gnous_eu/models.py:14
+msgid "Fédéré"
+msgstr "Federated"
+
+#: apps/gnous_eu/models.py:15
+msgid "Centralisé"
+msgstr "Centralized"
+
+#: apps/gnous_eu/templates/index.html:12
+msgid "Communauté francophone de passionnés du libre depuis 2017."
+msgstr "French community of free software enthusiasts since 2017."
+
+#: apps/gnous_eu/templates/index.html:21
+#: apps/gnous_eu/templates/services.html:10
+msgid "Nos services"
+msgstr "Our services"
+
+#: apps/gnous_eu/templates/index.html:22
+#: apps/gnous_eu/templates/about.html:11
+#: apps/gnous_eu/templates/layouts/head.html:13
+#: apps/gnous_eu/templates/layouts/header.html:33
+#: apps/gnous_eu/templates/layouts/sidebar.html:26
+msgid "À propos"
+msgstr "About"
+
+#: apps/gnous_eu/templates/about.html:16
+msgid ""
+"GnousEU est une communauté de passionnés du libre ayant débuté en Février 2017 sur la plateforme Discord."
+"Depuis elle s'est diversifiée sur plusieurs plateformes hébergées par elle même en favoirsant les instances déscentralisées."
+"Elle ne cesse de grandir de jour en jour et est ouverte à tous nouveaux membres."
+"Un système de recensemment des membre et d'interconnexion des plateformes est toujours à l'étude pour permettre une meilleure continuité au sein de la communauté."
+"Actuellement la grande majorité de ses membres se trouvent sur le serveur Discord."
+msgstr ""
+"GnousEU is a community of free software enthusiasts that started in February 2017 on the Discord platform."
+"Since then, it has diversified on several platforms hosted by itself, favouring de-centralized instances."
+"It continues to grow day by day and is open to all new members."
+"A system for identifying members and interconnecting platforms is still under study to allow for better continuity within the community."
+"Currently the vast majority of its members are on the Discord server."
+
+#: apps/gnous_eu/templates/about.html:17
+msgid ""
+"Cette communauté à été créée par Mael G. aka Outout et est administrée par lui même "
+"mais aussi par Romain J., Rick Krict, DoomQuakeKeen et Orakle au design."
+msgstr ""
+"This community was created by Mael G. aka Outout and is administered by itself "
+"but also by Romain J., Rick Krict, DoomQuakeKeen and Orakle in design."
+
+#: apps/gnous_eu/templates/about.html:18
+msgid ""
+"GnousEU est hébergé sur l'infrastructure EnPLS.org disposant de serveurs en France, Pays-Bas, Allemagne et Guadeloupe."
+msgstr "GnousEU est hébergé sur l'infrastructure EnPLS.org disposant de serveurs en France, Pays-Bas, Allemagne et Guadeloupe."
+
+
+#: apps/gnous_eu/templates/layouts/footer.html:6
+msgid "Designé par"
+msgstr "Designed by"
+
+#: apps/gnous_eu/templates/layouts/footer.html:9
+msgid "Crée par"
+msgstr "Created by"
+
+#: apps/gnous_eu/templates/layouts/footer.html:12
+msgid "Fait avec"
+msgstr "Built with"
+
+#: apps/gnous_eu/templates/layouts/head.html:11
+#: apps/gnous_eu/templates/layouts/header.html:17
+#: apps/gnous_eu/templates/layouts/sidebar.html:12
+msgid "Accueil"
+msgstr "Home"
+
+#: apps/gnous_eu/templates/layouts/head.html:12
+#: apps/gnous_eu/templates/layouts/header.html:23
+#: apps/gnous_eu/templates/layouts/sidebar.html:19
+msgid "Services"
+msgstr "Services"
+
+#: apps/gnous_eu/templates/layouts/head.html:14
+msgid "Dons"
+msgstr "Tips"
+
+#: apps/gnous_eu/templates/layouts/header.html:39
+#: apps/gnous_eu/templates/layouts/sidebar.html:31
+msgid "Donner"
+msgstr "Tips"
+
+#: apps/gnous_eu/templates/layouts/sidebar.html:37
+msgid "Langue"
+msgstr "Language"
+
+#: apps/gnous_eu/templates/services.html:11
+msgid ""
+"GnousEU propose à tous des services gratuits et libre d'utilisations à tous. "
+"Ces services sont majoritairement opensource et ne volent pas vos précieuses données personnelles."
+msgstr ""
+"GnousEU offers free and free to use services to all. "
+"These services are mostly open source and do not steal your precious personal data."
+
+#: apps/gnous_eu/templates/services.html:20
+msgid "Rechercher..."
+msgstr "Search..."
+
+#: apps/gnous_eu/templates/services.html:74
+msgid "Précédent"
+msgstr "Previous"
+
+#: apps/gnous_eu/templates/services.html:89
+msgid "Suivant"
+msgstr "Next"
+
+#: apps/gnous_eu/templates/services.html:100
+msgid "Aucun service trouvé pour la recheche: "
+msgstr "No services found for the search: "
+
+#: apps/gnous_eu/templates/tips.html:12
+msgid "Donnez à GnousEU"
+msgstr "Give to GnousEU"
+
+#: apps/gnous_eu/templates/tips.html:14
+msgid "Participez au développement de la communauté de GnousEU via un don monétaire via le site Tipeee."
+msgstr "Participate in the development of the GnousEU community by making a monetary donation via the Tipeee website."
+
+#: apps/gnous_eu/templates/tips.html:25
+msgid "Vous souhaitez nous donner du materiel ?"
+msgstr "Would you like to give us some material?"
+
+#: apps/gnous_eu/templates/tips.html:27
+msgid "Vous disposez de materiel réseau ou serveur usagé et vous ne savez pas quoi en faire ?"
+msgstr "You have used network or server hardware and you don't know what to do with it?"
+
+#: apps/gnous_eu/templates/tips.html:29 apps/gnous_eu/templates/tips.html:41
+msgid "Contactez nous par mail à "
+msgstr "Contact us by mail at "
+
+#: apps/gnous_eu/templates/tips.html:37
+msgid "Vous êtes fournisseur de services ?"
+msgstr "Are you a service provider?"
+
+#: apps/gnous_eu/templates/tips.html:39
+msgid "Discutons plus en détails de votre proposition ! Nous sommes ouvert à tout partenariat."
+msgstr "Let's discuss your proposal in more detail! We are open to any partnership."
+
+
+#: apps/gnous_eu/templates/layouts/base.html:42
+msgid "Bla bla bla... bannière alakon pour dire qu&on utilise des cookies (pour la langue et cette bannière)"
+msgstr "Bla bla bla... shitty banner to say that we\\'re using cookies (for the language and this banner)"
+
diff --git a/locale/fr/LC_MESSAGES/django.po b/locale/fr/LC_MESSAGES/django.po
new file mode 100644
index 0000000..9f36edc
--- /dev/null
+++ b/locale/fr/LC_MESSAGES/django.po
@@ -0,0 +1,170 @@
+# SOME DESCRIPTIVE TITLE.
+# Copyright (C) YEAR THE PACKAGE'S COPYRIGHT HOLDER
+# This file is distributed under the same license as the PACKAGE package.
+# FIRST AUTHOR , YEAR.
+#
+#, fuzzy
+msgid ""
+msgstr ""
+"Project-Id-Version: PACKAGE VERSION\n"
+"Report-Msgid-Bugs-To: \n"
+"POT-Creation-Date: 2020-05-15 21:59+0000\n"
+"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
+"Last-Translator: FULL NAME \n"
+"Language-Team: LANGUAGE \n"
+"Language: \n"
+"MIME-Version: 1.0\n"
+"Content-Type: text/plain; charset=UTF-8\n"
+"Content-Transfer-Encoding: 8bit\n"
+"Plural-Forms: nplurals=2; plural=(n > 1);\n"
+
+#: apps/gnous_eu/models.py:9
+msgid "Sources closes"
+msgstr ""
+
+#: apps/gnous_eu/models.py:10
+msgid "Sources ouvertes"
+msgstr ""
+
+#: apps/gnous_eu/models.py:11 apps/gnous_eu/models.py:16
+msgid "Inconnu"
+msgstr ""
+
+#: apps/gnous_eu/models.py:14
+msgid "Fédéré"
+msgstr ""
+
+#: apps/gnous_eu/models.py:15
+msgid "Centralisé"
+msgstr ""
+
+
+#: apps/gnous_eu/templates/index.html:12
+msgid "Communauté francophone de passionnés du libre depuis 2017."
+msgstr ""
+
+#: apps/gnous_eu/templates/index.html:21
+#: apps/gnous_eu/templates/services.html:10
+msgid "Nos services"
+msgstr ""
+
+#: apps/gnous_eu/templates/index.html:22
+#: apps/gnous_eu/templates/about.html:11
+#: apps/gnous_eu/templates/layouts/head.html:13
+#: apps/gnous_eu/templates/layouts/header.html:33
+#: apps/gnous_eu/templates/layouts/sidebar.html:26
+msgid "À propos"
+msgstr ""
+
+#: apps/gnous_eu/templates/about.html:16
+msgid ""
+"GnousEU est une communauté de passionnés du libre ayant débuté en Février 2017 sur la plateforme Discord."
+"Depuis elle s'est diversifiée sur plusieurs plateformes hébergées par elle même en favoirsant les instances déscentralisées."
+"Elle ne cesse de grandir de jour en jour et est ouverte à tous nouveaux membres."
+"Un système de recensemment des membre et d'interconnexion des plateformes est toujours à l'étude pour permettre une meilleure continuité au sein de la communauté."
+"Actuellement la grande majorité de ses membres se trouvent sur le serveur Discord."
+msgstr ""
+
+#: apps/gnous_eu/templates/about.html:17
+msgid ""
+"Cette communauté à été créée par Mael G. aka Outout et est administrée par lui même "
+"mais aussi par Romain J., Rick Krict, DoomQuakeKeen et Orakle au design."
+msgstr ""
+"Cette communauté à été créée par Mael G. aka Outout et est administrée par lui même "
+"mais aussi par Romain J., Rick Krict, DoomQuakeKeen et Orakle au design."
+
+#: apps/gnous_eu/templates/about.html:18
+msgid ""
+"GnousEU est hébergé sur l'infrastructure EnPLS.org disposant de serveurs en France, Pays-Bas, Allemagne et Guadeloupe."
+msgstr "GnousEU est hébergé sur l'infrastructure EnPLS.org disposant de serveurs en France, Pays-Bas, Allemagne et Guadeloupe."
+
+#: apps/gnous_eu/templates/layouts/footer.html:6
+msgid "Designé par"
+msgstr ""
+
+#: apps/gnous_eu/templates/layouts/footer.html:9
+msgid "Crée par"
+msgstr ""
+
+#: apps/gnous_eu/templates/layouts/footer.html:12
+msgid "Fait avec"
+msgstr ""
+
+#: apps/gnous_eu/templates/layouts/head.html:11
+#: apps/gnous_eu/templates/layouts/header.html:17
+#: apps/gnous_eu/templates/layouts/sidebar.html:12
+msgid "Accueil"
+msgstr ""
+
+#: apps/gnous_eu/templates/layouts/head.html:12
+#: apps/gnous_eu/templates/layouts/header.html:23
+#: apps/gnous_eu/templates/layouts/sidebar.html:19
+msgid "Services"
+msgstr ""
+
+#: apps/gnous_eu/templates/layouts/head.html:14
+msgid "Dons"
+msgstr ""
+
+#: apps/gnous_eu/templates/layouts/header.html:39
+#: apps/gnous_eu/templates/layouts/sidebar.html:31
+msgid "Donner"
+msgstr ""
+
+#: apps/gnous_eu/templates/layouts/sidebar.html:37
+msgid "Langue"
+msgstr ""
+
+#: apps/gnous_eu/templates/services.html:11
+msgid ""
+"GnousEU propose à tous des services gratuits et libre d'utilisations à tous. "
+"Ces services sont majoritairement opensource et ne volent pas vos précieuses données personnelles."
+msgstr ""
+
+#: apps/gnous_eu/templates/services.html:20
+msgid "Rechercher..."
+msgstr ""
+
+#: apps/gnous_eu/templates/services.html:74
+msgid "Précédent"
+msgstr ""
+
+#: apps/gnous_eu/templates/services.html:89
+msgid "Suivant"
+msgstr ""
+
+#: apps/gnous_eu/templates/services.html:100
+msgid "Aucun service trouvé pour la recheche: "
+msgstr ""
+
+#: apps/gnous_eu/templates/tips.html:12
+msgid "Donnez à GnousEU"
+msgstr ""
+
+#: apps/gnous_eu/templates/tips.html:14
+msgid "Participez au développement de la communauté de GnousEU via un don monétaire via le site Tipeee."
+msgstr ""
+
+#: apps/gnous_eu/templates/tips.html:25
+msgid "Vous souhaitez nous donner du materiel ?"
+msgstr ""
+
+#: apps/gnous_eu/templates/tips.html:27
+msgid "Vous disposez de materiel réseau ou serveur usagé et vous ne savez pas quoi en faire ?"
+msgstr ""
+
+#: apps/gnous_eu/templates/tips.html:29 apps/gnous_eu/templates/tips.html:41
+msgid "Contactez nous par mail à "
+msgstr ""
+
+#: apps/gnous_eu/templates/tips.html:37
+msgid "Vous êtes fournisseur de services ?"
+msgstr ""
+
+#: apps/gnous_eu/templates/tips.html:39
+msgid "Discutons plus en détails de votre proposition ! Nous sommes ouvert à tout partenariat."
+msgstr ""
+
+#: apps/gnous_eu/templates/layouts/base.html:42
+msgid "Bla bla bla... bannière alakon pour dire qu&on utilise des cookies (pour la langue et cette bannière)"
+msgstr "Bla bla bla... bannière alakon pour dire qu\\'on utilise des cookies (pour la langue et cette bannière)"
diff --git a/manage.py b/manage.py
new file mode 100755
index 0000000..8c337b7
--- /dev/null
+++ b/manage.py
@@ -0,0 +1,21 @@
+#!/usr/bin/env python
+"""Django's command-line utility for administrative tasks."""
+import os
+import sys
+
+
+def main():
+ os.environ.setdefault("DJANGO_SETTINGS_MODULE", "gnousEU.settings")
+ try:
+ from django.core.management import execute_from_command_line
+ except ImportError as exc:
+ raise ImportError(
+ "Couldn't import Django. Are you sure it's installed and "
+ "available on your PYTHONPATH environment variable? Did you "
+ "forget to activate a virtual environment?"
+ ) from exc
+ execute_from_command_line(sys.argv)
+
+
+if __name__ == "__main__":
+ main()
diff --git a/php/config.php b/php/config.php
deleted file mode 100644
index 2b947e0..0000000
--- a/php/config.php
+++ /dev/null
@@ -1,21 +0,0 @@
-=0&&n0&&t-1 in e)}var E=function(e){var t,n,r,i,o,a,s,u,l,c,f,p,d,h,g,y,v,m,x,b="sizzle"+1*new Date,w=e.document,T=0,C=0,E=ae(),k=ae(),S=ae(),D=function(e,t){return e===t&&(f=!0),0},N={}.hasOwnProperty,A=[],j=A.pop,q=A.push,L=A.push,H=A.slice,O=function(e,t){for(var n=0,r=e.length;n+~]|"+M+")"+M+"*"),z=new RegExp("="+M+"*([^\\]'\"]*?)"+M+"*\\]","g"),X=new RegExp(W),U=new RegExp("^"+R+"$"),V={ID:new RegExp("^#("+R+")"),CLASS:new RegExp("^\\.("+R+")"),TAG:new RegExp("^("+R+"|[*])"),ATTR:new RegExp("^"+I),PSEUDO:new RegExp("^"+W),CHILD:new RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\("+M+"*(even|odd|(([+-]|)(\\d*)n|)"+M+"*(?:([+-]|)"+M+"*(\\d+)|))"+M+"*\\)|)","i"),bool:new RegExp("^(?:"+P+")$","i"),needsContext:new RegExp("^"+M+"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\("+M+"*((?:-\\d)?\\d*)"+M+"*\\)|)(?=[^-]|$)","i")},G=/^(?:input|select|textarea|button)$/i,Y=/^h\d$/i,Q=/^[^{]+\{\s*\[native \w/,J=/^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,K=/[+~]/,Z=new RegExp("\\\\([\\da-f]{1,6}"+M+"?|("+M+")|.)","ig"),ee=function(e,t,n){var r="0x"+t-65536;return r!==r||n?t:r<0?String.fromCharCode(r+65536):String.fromCharCode(r>>10|55296,1023&r|56320)},te=/([\0-\x1f\x7f]|^-?\d)|^-$|[^\0-\x1f\x7f-\uFFFF\w-]/g,ne=function(e,t){return t?"\0"===e?"\ufffd":e.slice(0,-1)+"\\"+e.charCodeAt(e.length-1).toString(16)+" ":"\\"+e},re=function(){p()},ie=me(function(e){return!0===e.disabled&&("form"in e||"label"in e)},{dir:"parentNode",next:"legend"});try{L.apply(A=H.call(w.childNodes),w.childNodes),A[w.childNodes.length].nodeType}catch(e){L={apply:A.length?function(e,t){q.apply(e,H.call(t))}:function(e,t){var n=e.length,r=0;while(e[n++]=t[r++]);e.length=n-1}}}function oe(e,t,r,i){var o,s,l,c,f,h,v,m=t&&t.ownerDocument,T=t?t.nodeType:9;if(r=r||[],"string"!=typeof e||!e||1!==T&&9!==T&&11!==T)return r;if(!i&&((t?t.ownerDocument||t:w)!==d&&p(t),t=t||d,g)){if(11!==T&&(f=J.exec(e)))if(o=f[1]){if(9===T){if(!(l=t.getElementById(o)))return r;if(l.id===o)return r.push(l),r}else if(m&&(l=m.getElementById(o))&&x(t,l)&&l.id===o)return r.push(l),r}else{if(f[2])return L.apply(r,t.getElementsByTagName(e)),r;if((o=f[3])&&n.getElementsByClassName&&t.getElementsByClassName)return L.apply(r,t.getElementsByClassName(o)),r}if(n.qsa&&!S[e+" "]&&(!y||!y.test(e))){if(1!==T)m=t,v=e;else if("object"!==t.nodeName.toLowerCase()){(c=t.getAttribute("id"))?c=c.replace(te,ne):t.setAttribute("id",c=b),s=(h=a(e)).length;while(s--)h[s]="#"+c+" "+ve(h[s]);v=h.join(","),m=K.test(e)&&ge(t.parentNode)||t}if(v)try{return L.apply(r,m.querySelectorAll(v)),r}catch(e){}finally{c===b&&t.removeAttribute("id")}}}return u(e.replace(B,"$1"),t,r,i)}function ae(){var e=[];function t(n,i){return e.push(n+" ")>r.cacheLength&&delete t[e.shift()],t[n+" "]=i}return t}function se(e){return e[b]=!0,e}function ue(e){var t=d.createElement("fieldset");try{return!!e(t)}catch(e){return!1}finally{t.parentNode&&t.parentNode.removeChild(t),t=null}}function le(e,t){var n=e.split("|"),i=n.length;while(i--)r.attrHandle[n[i]]=t}function ce(e,t){var n=t&&e,r=n&&1===e.nodeType&&1===t.nodeType&&e.sourceIndex-t.sourceIndex;if(r)return r;if(n)while(n=n.nextSibling)if(n===t)return-1;return e?1:-1}function fe(e){return function(t){return"input"===t.nodeName.toLowerCase()&&t.type===e}}function pe(e){return function(t){var n=t.nodeName.toLowerCase();return("input"===n||"button"===n)&&t.type===e}}function de(e){return function(t){return"form"in t?t.parentNode&&!1===t.disabled?"label"in t?"label"in t.parentNode?t.parentNode.disabled===e:t.disabled===e:t.isDisabled===e||t.isDisabled!==!e&&ie(t)===e:t.disabled===e:"label"in t&&t.disabled===e}}function he(e){return se(function(t){return t=+t,se(function(n,r){var i,o=e([],n.length,t),a=o.length;while(a--)n[i=o[a]]&&(n[i]=!(r[i]=n[i]))})})}function ge(e){return e&&"undefined"!=typeof e.getElementsByTagName&&e}n=oe.support={},o=oe.isXML=function(e){var t=e&&(e.ownerDocument||e).documentElement;return!!t&&"HTML"!==t.nodeName},p=oe.setDocument=function(e){var t,i,a=e?e.ownerDocument||e:w;return a!==d&&9===a.nodeType&&a.documentElement?(d=a,h=d.documentElement,g=!o(d),w!==d&&(i=d.defaultView)&&i.top!==i&&(i.addEventListener?i.addEventListener("unload",re,!1):i.attachEvent&&i.attachEvent("onunload",re)),n.attributes=ue(function(e){return e.className="i",!e.getAttribute("className")}),n.getElementsByTagName=ue(function(e){return e.appendChild(d.createComment("")),!e.getElementsByTagName("*").length}),n.getElementsByClassName=Q.test(d.getElementsByClassName),n.getById=ue(function(e){return h.appendChild(e).id=b,!d.getElementsByName||!d.getElementsByName(b).length}),n.getById?(r.filter.ID=function(e){var t=e.replace(Z,ee);return function(e){return e.getAttribute("id")===t}},r.find.ID=function(e,t){if("undefined"!=typeof t.getElementById&&g){var n=t.getElementById(e);return n?[n]:[]}}):(r.filter.ID=function(e){var t=e.replace(Z,ee);return function(e){var n="undefined"!=typeof e.getAttributeNode&&e.getAttributeNode("id");return n&&n.value===t}},r.find.ID=function(e,t){if("undefined"!=typeof t.getElementById&&g){var n,r,i,o=t.getElementById(e);if(o){if((n=o.getAttributeNode("id"))&&n.value===e)return[o];i=t.getElementsByName(e),r=0;while(o=i[r++])if((n=o.getAttributeNode("id"))&&n.value===e)return[o]}return[]}}),r.find.TAG=n.getElementsByTagName?function(e,t){return"undefined"!=typeof t.getElementsByTagName?t.getElementsByTagName(e):n.qsa?t.querySelectorAll(e):void 0}:function(e,t){var n,r=[],i=0,o=t.getElementsByTagName(e);if("*"===e){while(n=o[i++])1===n.nodeType&&r.push(n);return r}return o},r.find.CLASS=n.getElementsByClassName&&function(e,t){if("undefined"!=typeof t.getElementsByClassName&&g)return t.getElementsByClassName(e)},v=[],y=[],(n.qsa=Q.test(d.querySelectorAll))&&(ue(function(e){h.appendChild(e).innerHTML="",e.querySelectorAll("[msallowcapture^='']").length&&y.push("[*^$]="+M+"*(?:''|\"\")"),e.querySelectorAll("[selected]").length||y.push("\\["+M+"*(?:value|"+P+")"),e.querySelectorAll("[id~="+b+"-]").length||y.push("~="),e.querySelectorAll(":checked").length||y.push(":checked"),e.querySelectorAll("a#"+b+"+*").length||y.push(".#.+[+~]")}),ue(function(e){e.innerHTML="";var t=d.createElement("input");t.setAttribute("type","hidden"),e.appendChild(t).setAttribute("name","D"),e.querySelectorAll("[name=d]").length&&y.push("name"+M+"*[*^$|!~]?="),2!==e.querySelectorAll(":enabled").length&&y.push(":enabled",":disabled"),h.appendChild(e).disabled=!0,2!==e.querySelectorAll(":disabled").length&&y.push(":enabled",":disabled"),e.querySelectorAll("*,:x"),y.push(",.*:")})),(n.matchesSelector=Q.test(m=h.matches||h.webkitMatchesSelector||h.mozMatchesSelector||h.oMatchesSelector||h.msMatchesSelector))&&ue(function(e){n.disconnectedMatch=m.call(e,"*"),m.call(e,"[s!='']:x"),v.push("!=",W)}),y=y.length&&new RegExp(y.join("|")),v=v.length&&new RegExp(v.join("|")),t=Q.test(h.compareDocumentPosition),x=t||Q.test(h.contains)?function(e,t){var n=9===e.nodeType?e.documentElement:e,r=t&&t.parentNode;return e===r||!(!r||1!==r.nodeType||!(n.contains?n.contains(r):e.compareDocumentPosition&&16&e.compareDocumentPosition(r)))}:function(e,t){if(t)while(t=t.parentNode)if(t===e)return!0;return!1},D=t?function(e,t){if(e===t)return f=!0,0;var r=!e.compareDocumentPosition-!t.compareDocumentPosition;return r||(1&(r=(e.ownerDocument||e)===(t.ownerDocument||t)?e.compareDocumentPosition(t):1)||!n.sortDetached&&t.compareDocumentPosition(e)===r?e===d||e.ownerDocument===w&&x(w,e)?-1:t===d||t.ownerDocument===w&&x(w,t)?1:c?O(c,e)-O(c,t):0:4&r?-1:1)}:function(e,t){if(e===t)return f=!0,0;var n,r=0,i=e.parentNode,o=t.parentNode,a=[e],s=[t];if(!i||!o)return e===d?-1:t===d?1:i?-1:o?1:c?O(c,e)-O(c,t):0;if(i===o)return ce(e,t);n=e;while(n=n.parentNode)a.unshift(n);n=t;while(n=n.parentNode)s.unshift(n);while(a[r]===s[r])r++;return r?ce(a[r],s[r]):a[r]===w?-1:s[r]===w?1:0},d):d},oe.matches=function(e,t){return oe(e,null,null,t)},oe.matchesSelector=function(e,t){if((e.ownerDocument||e)!==d&&p(e),t=t.replace(z,"='$1']"),n.matchesSelector&&g&&!S[t+" "]&&(!v||!v.test(t))&&(!y||!y.test(t)))try{var r=m.call(e,t);if(r||n.disconnectedMatch||e.document&&11!==e.document.nodeType)return r}catch(e){}return oe(t,d,null,[e]).length>0},oe.contains=function(e,t){return(e.ownerDocument||e)!==d&&p(e),x(e,t)},oe.attr=function(e,t){(e.ownerDocument||e)!==d&&p(e);var i=r.attrHandle[t.toLowerCase()],o=i&&N.call(r.attrHandle,t.toLowerCase())?i(e,t,!g):void 0;return void 0!==o?o:n.attributes||!g?e.getAttribute(t):(o=e.getAttributeNode(t))&&o.specified?o.value:null},oe.escape=function(e){return(e+"").replace(te,ne)},oe.error=function(e){throw new Error("Syntax error, unrecognized expression: "+e)},oe.uniqueSort=function(e){var t,r=[],i=0,o=0;if(f=!n.detectDuplicates,c=!n.sortStable&&e.slice(0),e.sort(D),f){while(t=e[o++])t===e[o]&&(i=r.push(o));while(i--)e.splice(r[i],1)}return c=null,e},i=oe.getText=function(e){var t,n="",r=0,o=e.nodeType;if(o){if(1===o||9===o||11===o){if("string"==typeof e.textContent)return e.textContent;for(e=e.firstChild;e;e=e.nextSibling)n+=i(e)}else if(3===o||4===o)return e.nodeValue}else while(t=e[r++])n+=i(t);return n},(r=oe.selectors={cacheLength:50,createPseudo:se,match:V,attrHandle:{},find:{},relative:{">":{dir:"parentNode",first:!0}," ":{dir:"parentNode"},"+":{dir:"previousSibling",first:!0},"~":{dir:"previousSibling"}},preFilter:{ATTR:function(e){return e[1]=e[1].replace(Z,ee),e[3]=(e[3]||e[4]||e[5]||"").replace(Z,ee),"~="===e[2]&&(e[3]=" "+e[3]+" "),e.slice(0,4)},CHILD:function(e){return e[1]=e[1].toLowerCase(),"nth"===e[1].slice(0,3)?(e[3]||oe.error(e[0]),e[4]=+(e[4]?e[5]+(e[6]||1):2*("even"===e[3]||"odd"===e[3])),e[5]=+(e[7]+e[8]||"odd"===e[3])):e[3]&&oe.error(e[0]),e},PSEUDO:function(e){var t,n=!e[6]&&e[2];return V.CHILD.test(e[0])?null:(e[3]?e[2]=e[4]||e[5]||"":n&&X.test(n)&&(t=a(n,!0))&&(t=n.indexOf(")",n.length-t)-n.length)&&(e[0]=e[0].slice(0,t),e[2]=n.slice(0,t)),e.slice(0,3))}},filter:{TAG:function(e){var t=e.replace(Z,ee).toLowerCase();return"*"===e?function(){return!0}:function(e){return e.nodeName&&e.nodeName.toLowerCase()===t}},CLASS:function(e){var t=E[e+" "];return t||(t=new RegExp("(^|"+M+")"+e+"("+M+"|$)"))&&E(e,function(e){return t.test("string"==typeof e.className&&e.className||"undefined"!=typeof e.getAttribute&&e.getAttribute("class")||"")})},ATTR:function(e,t,n){return function(r){var i=oe.attr(r,e);return null==i?"!="===t:!t||(i+="","="===t?i===n:"!="===t?i!==n:"^="===t?n&&0===i.indexOf(n):"*="===t?n&&i.indexOf(n)>-1:"$="===t?n&&i.slice(-n.length)===n:"~="===t?(" "+i.replace($," ")+" ").indexOf(n)>-1:"|="===t&&(i===n||i.slice(0,n.length+1)===n+"-"))}},CHILD:function(e,t,n,r,i){var o="nth"!==e.slice(0,3),a="last"!==e.slice(-4),s="of-type"===t;return 1===r&&0===i?function(e){return!!e.parentNode}:function(t,n,u){var l,c,f,p,d,h,g=o!==a?"nextSibling":"previousSibling",y=t.parentNode,v=s&&t.nodeName.toLowerCase(),m=!u&&!s,x=!1;if(y){if(o){while(g){p=t;while(p=p[g])if(s?p.nodeName.toLowerCase()===v:1===p.nodeType)return!1;h=g="only"===e&&!h&&"nextSibling"}return!0}if(h=[a?y.firstChild:y.lastChild],a&&m){x=(d=(l=(c=(f=(p=y)[b]||(p[b]={}))[p.uniqueID]||(f[p.uniqueID]={}))[e]||[])[0]===T&&l[1])&&l[2],p=d&&y.childNodes[d];while(p=++d&&p&&p[g]||(x=d=0)||h.pop())if(1===p.nodeType&&++x&&p===t){c[e]=[T,d,x];break}}else if(m&&(x=d=(l=(c=(f=(p=t)[b]||(p[b]={}))[p.uniqueID]||(f[p.uniqueID]={}))[e]||[])[0]===T&&l[1]),!1===x)while(p=++d&&p&&p[g]||(x=d=0)||h.pop())if((s?p.nodeName.toLowerCase()===v:1===p.nodeType)&&++x&&(m&&((c=(f=p[b]||(p[b]={}))[p.uniqueID]||(f[p.uniqueID]={}))[e]=[T,x]),p===t))break;return(x-=i)===r||x%r==0&&x/r>=0}}},PSEUDO:function(e,t){var n,i=r.pseudos[e]||r.setFilters[e.toLowerCase()]||oe.error("unsupported pseudo: "+e);return i[b]?i(t):i.length>1?(n=[e,e,"",t],r.setFilters.hasOwnProperty(e.toLowerCase())?se(function(e,n){var r,o=i(e,t),a=o.length;while(a--)e[r=O(e,o[a])]=!(n[r]=o[a])}):function(e){return i(e,0,n)}):i}},pseudos:{not:se(function(e){var t=[],n=[],r=s(e.replace(B,"$1"));return r[b]?se(function(e,t,n,i){var o,a=r(e,null,i,[]),s=e.length;while(s--)(o=a[s])&&(e[s]=!(t[s]=o))}):function(e,i,o){return t[0]=e,r(t,null,o,n),t[0]=null,!n.pop()}}),has:se(function(e){return function(t){return oe(e,t).length>0}}),contains:se(function(e){return e=e.replace(Z,ee),function(t){return(t.textContent||t.innerText||i(t)).indexOf(e)>-1}}),lang:se(function(e){return U.test(e||"")||oe.error("unsupported lang: "+e),e=e.replace(Z,ee).toLowerCase(),function(t){var n;do{if(n=g?t.lang:t.getAttribute("xml:lang")||t.getAttribute("lang"))return(n=n.toLowerCase())===e||0===n.indexOf(e+"-")}while((t=t.parentNode)&&1===t.nodeType);return!1}}),target:function(t){var n=e.location&&e.location.hash;return n&&n.slice(1)===t.id},root:function(e){return e===h},focus:function(e){return e===d.activeElement&&(!d.hasFocus||d.hasFocus())&&!!(e.type||e.href||~e.tabIndex)},enabled:de(!1),disabled:de(!0),checked:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&!!e.checked||"option"===t&&!!e.selected},selected:function(e){return e.parentNode&&e.parentNode.selectedIndex,!0===e.selected},empty:function(e){for(e=e.firstChild;e;e=e.nextSibling)if(e.nodeType<6)return!1;return!0},parent:function(e){return!r.pseudos.empty(e)},header:function(e){return Y.test(e.nodeName)},input:function(e){return G.test(e.nodeName)},button:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&"button"===e.type||"button"===t},text:function(e){var t;return"input"===e.nodeName.toLowerCase()&&"text"===e.type&&(null==(t=e.getAttribute("type"))||"text"===t.toLowerCase())},first:he(function(){return[0]}),last:he(function(e,t){return[t-1]}),eq:he(function(e,t,n){return[n<0?n+t:n]}),even:he(function(e,t){for(var n=0;n=0;)e.push(r);return e}),gt:he(function(e,t,n){for(var r=n<0?n+t:n;++r1?function(t,n,r){var i=e.length;while(i--)if(!e[i](t,n,r))return!1;return!0}:e[0]}function be(e,t,n){for(var r=0,i=t.length;r-1&&(o[l]=!(a[l]=f))}}else v=we(v===a?v.splice(h,v.length):v),i?i(null,a,v,u):L.apply(a,v)})}function Ce(e){for(var t,n,i,o=e.length,a=r.relative[e[0].type],s=a||r.relative[" "],u=a?1:0,c=me(function(e){return e===t},s,!0),f=me(function(e){return O(t,e)>-1},s,!0),p=[function(e,n,r){var i=!a&&(r||n!==l)||((t=n).nodeType?c(e,n,r):f(e,n,r));return t=null,i}];u1&&xe(p),u>1&&ve(e.slice(0,u-1).concat({value:" "===e[u-2].type?"*":""})).replace(B,"$1"),n,u0,i=e.length>0,o=function(o,a,s,u,c){var f,h,y,v=0,m="0",x=o&&[],b=[],w=l,C=o||i&&r.find.TAG("*",c),E=T+=null==w?1:Math.random()||.1,k=C.length;for(c&&(l=a===d||a||c);m!==k&&null!=(f=C[m]);m++){if(i&&f){h=0,a||f.ownerDocument===d||(p(f),s=!g);while(y=e[h++])if(y(f,a||d,s)){u.push(f);break}c&&(T=E)}n&&((f=!y&&f)&&v--,o&&x.push(f))}if(v+=m,n&&m!==v){h=0;while(y=t[h++])y(x,b,a,s);if(o){if(v>0)while(m--)x[m]||b[m]||(b[m]=j.call(u));b=we(b)}L.apply(u,b),c&&!o&&b.length>0&&v+t.length>1&&oe.uniqueSort(u)}return c&&(T=E,l=w),x};return n?se(o):o}return s=oe.compile=function(e,t){var n,r=[],i=[],o=S[e+" "];if(!o){t||(t=a(e)),n=t.length;while(n--)(o=Ce(t[n]))[b]?r.push(o):i.push(o);(o=S(e,Ee(i,r))).selector=e}return o},u=oe.select=function(e,t,n,i){var o,u,l,c,f,p="function"==typeof e&&e,d=!i&&a(e=p.selector||e);if(n=n||[],1===d.length){if((u=d[0]=d[0].slice(0)).length>2&&"ID"===(l=u[0]).type&&9===t.nodeType&&g&&r.relative[u[1].type]){if(!(t=(r.find.ID(l.matches[0].replace(Z,ee),t)||[])[0]))return n;p&&(t=t.parentNode),e=e.slice(u.shift().value.length)}o=V.needsContext.test(e)?0:u.length;while(o--){if(l=u[o],r.relative[c=l.type])break;if((f=r.find[c])&&(i=f(l.matches[0].replace(Z,ee),K.test(u[0].type)&&ge(t.parentNode)||t))){if(u.splice(o,1),!(e=i.length&&ve(u)))return L.apply(n,i),n;break}}}return(p||s(e,d))(i,t,!g,n,!t||K.test(e)&&ge(t.parentNode)||t),n},n.sortStable=b.split("").sort(D).join("")===b,n.detectDuplicates=!!f,p(),n.sortDetached=ue(function(e){return 1&e.compareDocumentPosition(d.createElement("fieldset"))}),ue(function(e){return e.innerHTML="","#"===e.firstChild.getAttribute("href")})||le("type|href|height|width",function(e,t,n){if(!n)return e.getAttribute(t,"type"===t.toLowerCase()?1:2)}),n.attributes&&ue(function(e){return e.innerHTML="",e.firstChild.setAttribute("value",""),""===e.firstChild.getAttribute("value")})||le("value",function(e,t,n){if(!n&&"input"===e.nodeName.toLowerCase())return e.defaultValue}),ue(function(e){return null==e.getAttribute("disabled")})||le(P,function(e,t,n){var r;if(!n)return!0===e[t]?t.toLowerCase():(r=e.getAttributeNode(t))&&r.specified?r.value:null}),oe}(e);w.find=E,w.expr=E.selectors,w.expr[":"]=w.expr.pseudos,w.uniqueSort=w.unique=E.uniqueSort,w.text=E.getText,w.isXMLDoc=E.isXML,w.contains=E.contains,w.escapeSelector=E.escape;var k=function(e,t,n){var r=[],i=void 0!==n;while((e=e[t])&&9!==e.nodeType)if(1===e.nodeType){if(i&&w(e).is(n))break;r.push(e)}return r},S=function(e,t){for(var n=[];e;e=e.nextSibling)1===e.nodeType&&e!==t&&n.push(e);return n},D=w.expr.match.needsContext;function N(e,t){return e.nodeName&&e.nodeName.toLowerCase()===t.toLowerCase()}var A=/^<([a-z][^\/\0>:\x20\t\r\n\f]*)[\x20\t\r\n\f]*\/?>(?:<\/\1>|)$/i;function j(e,t,n){return g(t)?w.grep(e,function(e,r){return!!t.call(e,r,e)!==n}):t.nodeType?w.grep(e,function(e){return e===t!==n}):"string"!=typeof t?w.grep(e,function(e){return u.call(t,e)>-1!==n}):w.filter(t,e,n)}w.filter=function(e,t,n){var r=t[0];return n&&(e=":not("+e+")"),1===t.length&&1===r.nodeType?w.find.matchesSelector(r,e)?[r]:[]:w.find.matches(e,w.grep(t,function(e){return 1===e.nodeType}))},w.fn.extend({find:function(e){var t,n,r=this.length,i=this;if("string"!=typeof e)return this.pushStack(w(e).filter(function(){for(t=0;t1?w.uniqueSort(n):n},filter:function(e){return this.pushStack(j(this,e||[],!1))},not:function(e){return this.pushStack(j(this,e||[],!0))},is:function(e){return!!j(this,"string"==typeof e&&D.test(e)?w(e):e||[],!1).length}});var q,L=/^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]+))$/;(w.fn.init=function(e,t,n){var i,o;if(!e)return this;if(n=n||q,"string"==typeof e){if(!(i="<"===e[0]&&">"===e[e.length-1]&&e.length>=3?[null,e,null]:L.exec(e))||!i[1]&&t)return!t||t.jquery?(t||n).find(e):this.constructor(t).find(e);if(i[1]){if(t=t instanceof w?t[0]:t,w.merge(this,w.parseHTML(i[1],t&&t.nodeType?t.ownerDocument||t:r,!0)),A.test(i[1])&&w.isPlainObject(t))for(i in t)g(this[i])?this[i](t[i]):this.attr(i,t[i]);return this}return(o=r.getElementById(i[2]))&&(this[0]=o,this.length=1),this}return e.nodeType?(this[0]=e,this.length=1,this):g(e)?void 0!==n.ready?n.ready(e):e(w):w.makeArray(e,this)}).prototype=w.fn,q=w(r);var H=/^(?:parents|prev(?:Until|All))/,O={children:!0,contents:!0,next:!0,prev:!0};w.fn.extend({has:function(e){var t=w(e,this),n=t.length;return this.filter(function(){for(var e=0;e-1:1===n.nodeType&&w.find.matchesSelector(n,e))){o.push(n);break}return this.pushStack(o.length>1?w.uniqueSort(o):o)},index:function(e){return e?"string"==typeof e?u.call(w(e),this[0]):u.call(this,e.jquery?e[0]:e):this[0]&&this[0].parentNode?this.first().prevAll().length:-1},add:function(e,t){return this.pushStack(w.uniqueSort(w.merge(this.get(),w(e,t))))},addBack:function(e){return this.add(null==e?this.prevObject:this.prevObject.filter(e))}});function P(e,t){while((e=e[t])&&1!==e.nodeType);return e}w.each({parent:function(e){var t=e.parentNode;return t&&11!==t.nodeType?t:null},parents:function(e){return k(e,"parentNode")},parentsUntil:function(e,t,n){return k(e,"parentNode",n)},next:function(e){return P(e,"nextSibling")},prev:function(e){return P(e,"previousSibling")},nextAll:function(e){return k(e,"nextSibling")},prevAll:function(e){return k(e,"previousSibling")},nextUntil:function(e,t,n){return k(e,"nextSibling",n)},prevUntil:function(e,t,n){return k(e,"previousSibling",n)},siblings:function(e){return S((e.parentNode||{}).firstChild,e)},children:function(e){return S(e.firstChild)},contents:function(e){return N(e,"iframe")?e.contentDocument:(N(e,"template")&&(e=e.content||e),w.merge([],e.childNodes))}},function(e,t){w.fn[e]=function(n,r){var i=w.map(this,t,n);return"Until"!==e.slice(-5)&&(r=n),r&&"string"==typeof r&&(i=w.filter(r,i)),this.length>1&&(O[e]||w.uniqueSort(i),H.test(e)&&i.reverse()),this.pushStack(i)}});var M=/[^\x20\t\r\n\f]+/g;function R(e){var t={};return w.each(e.match(M)||[],function(e,n){t[n]=!0}),t}w.Callbacks=function(e){e="string"==typeof e?R(e):w.extend({},e);var t,n,r,i,o=[],a=[],s=-1,u=function(){for(i=i||e.once,r=t=!0;a.length;s=-1){n=a.shift();while(++s-1)o.splice(n,1),n<=s&&s--}),this},has:function(e){return e?w.inArray(e,o)>-1:o.length>0},empty:function(){return o&&(o=[]),this},disable:function(){return i=a=[],o=n="",this},disabled:function(){return!o},lock:function(){return i=a=[],n||t||(o=n=""),this},locked:function(){return!!i},fireWith:function(e,n){return i||(n=[e,(n=n||[]).slice?n.slice():n],a.push(n),t||u()),this},fire:function(){return l.fireWith(this,arguments),this},fired:function(){return!!r}};return l};function I(e){return e}function W(e){throw e}function $(e,t,n,r){var i;try{e&&g(i=e.promise)?i.call(e).done(t).fail(n):e&&g(i=e.then)?i.call(e,t,n):t.apply(void 0,[e].slice(r))}catch(e){n.apply(void 0,[e])}}w.extend({Deferred:function(t){var n=[["notify","progress",w.Callbacks("memory"),w.Callbacks("memory"),2],["resolve","done",w.Callbacks("once memory"),w.Callbacks("once memory"),0,"resolved"],["reject","fail",w.Callbacks("once memory"),w.Callbacks("once memory"),1,"rejected"]],r="pending",i={state:function(){return r},always:function(){return o.done(arguments).fail(arguments),this},"catch":function(e){return i.then(null,e)},pipe:function(){var e=arguments;return w.Deferred(function(t){w.each(n,function(n,r){var i=g(e[r[4]])&&e[r[4]];o[r[1]](function(){var e=i&&i.apply(this,arguments);e&&g(e.promise)?e.promise().progress(t.notify).done(t.resolve).fail(t.reject):t[r[0]+"With"](this,i?[e]:arguments)})}),e=null}).promise()},then:function(t,r,i){var o=0;function a(t,n,r,i){return function(){var s=this,u=arguments,l=function(){var e,l;if(!(t=o&&(r!==W&&(s=void 0,u=[e]),n.rejectWith(s,u))}};t?c():(w.Deferred.getStackHook&&(c.stackTrace=w.Deferred.getStackHook()),e.setTimeout(c))}}return w.Deferred(function(e){n[0][3].add(a(0,e,g(i)?i:I,e.notifyWith)),n[1][3].add(a(0,e,g(t)?t:I)),n[2][3].add(a(0,e,g(r)?r:W))}).promise()},promise:function(e){return null!=e?w.extend(e,i):i}},o={};return w.each(n,function(e,t){var a=t[2],s=t[5];i[t[1]]=a.add,s&&a.add(function(){r=s},n[3-e][2].disable,n[3-e][3].disable,n[0][2].lock,n[0][3].lock),a.add(t[3].fire),o[t[0]]=function(){return o[t[0]+"With"](this===o?void 0:this,arguments),this},o[t[0]+"With"]=a.fireWith}),i.promise(o),t&&t.call(o,o),o},when:function(e){var t=arguments.length,n=t,r=Array(n),i=o.call(arguments),a=w.Deferred(),s=function(e){return function(n){r[e]=this,i[e]=arguments.length>1?o.call(arguments):n,--t||a.resolveWith(r,i)}};if(t<=1&&($(e,a.done(s(n)).resolve,a.reject,!t),"pending"===a.state()||g(i[n]&&i[n].then)))return a.then();while(n--)$(i[n],s(n),a.reject);return a.promise()}});var B=/^(Eval|Internal|Range|Reference|Syntax|Type|URI)Error$/;w.Deferred.exceptionHook=function(t,n){e.console&&e.console.warn&&t&&B.test(t.name)&&e.console.warn("jQuery.Deferred exception: "+t.message,t.stack,n)},w.readyException=function(t){e.setTimeout(function(){throw t})};var F=w.Deferred();w.fn.ready=function(e){return F.then(e)["catch"](function(e){w.readyException(e)}),this},w.extend({isReady:!1,readyWait:1,ready:function(e){(!0===e?--w.readyWait:w.isReady)||(w.isReady=!0,!0!==e&&--w.readyWait>0||F.resolveWith(r,[w]))}}),w.ready.then=F.then;function _(){r.removeEventListener("DOMContentLoaded",_),e.removeEventListener("load",_),w.ready()}"complete"===r.readyState||"loading"!==r.readyState&&!r.documentElement.doScroll?e.setTimeout(w.ready):(r.addEventListener("DOMContentLoaded",_),e.addEventListener("load",_));var z=function(e,t,n,r,i,o,a){var s=0,u=e.length,l=null==n;if("object"===x(n)){i=!0;for(s in n)z(e,t,s,n[s],!0,o,a)}else if(void 0!==r&&(i=!0,g(r)||(a=!0),l&&(a?(t.call(e,r),t=null):(l=t,t=function(e,t,n){return l.call(w(e),n)})),t))for(;s1,null,!0)},removeData:function(e){return this.each(function(){K.remove(this,e)})}}),w.extend({queue:function(e,t,n){var r;if(e)return t=(t||"fx")+"queue",r=J.get(e,t),n&&(!r||Array.isArray(n)?r=J.access(e,t,w.makeArray(n)):r.push(n)),r||[]},dequeue:function(e,t){t=t||"fx";var n=w.queue(e,t),r=n.length,i=n.shift(),o=w._queueHooks(e,t),a=function(){w.dequeue(e,t)};"inprogress"===i&&(i=n.shift(),r--),i&&("fx"===t&&n.unshift("inprogress"),delete o.stop,i.call(e,a,o)),!r&&o&&o.empty.fire()},_queueHooks:function(e,t){var n=t+"queueHooks";return J.get(e,n)||J.access(e,n,{empty:w.Callbacks("once memory").add(function(){J.remove(e,[t+"queue",n])})})}}),w.fn.extend({queue:function(e,t){var n=2;return"string"!=typeof e&&(t=e,e="fx",n--),arguments.length\x20\t\r\n\f]+)/i,he=/^$|^module$|\/(?:java|ecma)script/i,ge={option:[1,""],thead:[1,"