diff options
Diffstat (limited to '')
20 files changed, 346 insertions, 0 deletions
| diff --git a/pydis_site/apps/events/__init__.py b/pydis_site/apps/events/__init__.py new file mode 100644 index 00000000..e69de29b --- /dev/null +++ b/pydis_site/apps/events/__init__.py diff --git a/pydis_site/apps/events/apps.py b/pydis_site/apps/events/apps.py new file mode 100644 index 00000000..a1cf09ef --- /dev/null +++ b/pydis_site/apps/events/apps.py @@ -0,0 +1,7 @@ +from django.apps import AppConfig + + +class EventsConfig(AppConfig): +    """Django AppConfig for events app.""" + +    name = 'events' diff --git a/pydis_site/apps/events/migrations/__init__.py b/pydis_site/apps/events/migrations/__init__.py new file mode 100644 index 00000000..e69de29b --- /dev/null +++ b/pydis_site/apps/events/migrations/__init__.py diff --git a/pydis_site/apps/events/tests/__init__.py b/pydis_site/apps/events/tests/__init__.py new file mode 100644 index 00000000..e69de29b --- /dev/null +++ b/pydis_site/apps/events/tests/__init__.py diff --git a/pydis_site/apps/events/tests/test_views.py b/pydis_site/apps/events/tests/test_views.py new file mode 100644 index 00000000..0db0ef9a --- /dev/null +++ b/pydis_site/apps/events/tests/test_views.py @@ -0,0 +1,42 @@ +from pathlib import Path + +from django.conf import settings +from django.test import TestCase, override_settings +from django_hosts.resolvers import reverse + + +PAGES_PATH = Path(settings.BASE_DIR, "pydis_site", "templates", "events", "test-pages") + + +class IndexTests(TestCase): +    def test_events_index_response_200(self): +        """Should return response code 200 when visiting index of events.""" +        url = reverse("events:index") +        resp = self.client.get(url) +        self.assertEqual(resp.status_code, 200) + + +class PageTests(TestCase): +    @override_settings(PAGES_PATH=PAGES_PATH) +    def test_valid_event_page_reponse_200(self): +        """Should return response code 200 when visiting valid event page.""" +        pages = ( +            reverse("events:page", ("my-event",)), +            reverse("events:page", ("my-event/subpage",)), +        ) +        for page in pages: +            with self.subTest(page=page): +                resp = self.client.get(page) +                self.assertEqual(resp.status_code, 200) + +    @override_settings(PAGES_PATH=PAGES_PATH) +    def test_invalid_event_page_404(self): +        """Should return response code 404 when visiting invalid event page.""" +        pages = ( +            reverse("events:page", ("invalid",)), +            reverse("events:page", ("invalid/invalid",)) +        ) +        for page in pages: +            with self.subTest(page=page): +                resp = self.client.get(page) +                self.assertEqual(resp.status_code, 404) diff --git a/pydis_site/apps/events/urls.py b/pydis_site/apps/events/urls.py new file mode 100644 index 00000000..9a65cf1f --- /dev/null +++ b/pydis_site/apps/events/urls.py @@ -0,0 +1,9 @@ +from django.urls import path + +from pydis_site.apps.events.views import IndexView, PageView + +app_name = "events" +urlpatterns = [ +    path("", IndexView.as_view(), name="index"), +    path("<path:path>/", PageView.as_view(), name="page"), +] diff --git a/pydis_site/apps/events/views/__init__.py b/pydis_site/apps/events/views/__init__.py new file mode 100644 index 00000000..8a107e2f --- /dev/null +++ b/pydis_site/apps/events/views/__init__.py @@ -0,0 +1,4 @@ +from .index import IndexView +from .page import PageView + +__all__ = ["IndexView", "PageView"] diff --git a/pydis_site/apps/events/views/index.py b/pydis_site/apps/events/views/index.py new file mode 100644 index 00000000..7ffba74a --- /dev/null +++ b/pydis_site/apps/events/views/index.py @@ -0,0 +1,7 @@ +from django.views.generic import TemplateView + + +class IndexView(TemplateView): +    """Events index page view.""" + +    template_name = "events/index.html" diff --git a/pydis_site/apps/events/views/page.py b/pydis_site/apps/events/views/page.py new file mode 100644 index 00000000..f4c37aeb --- /dev/null +++ b/pydis_site/apps/events/views/page.py @@ -0,0 +1,25 @@ +from typing import List + +from django.conf import settings +from django.http import Http404 +from django.views.generic import TemplateView + + +class PageView(TemplateView): +    """Handles event pages showing.""" + +    def get_template_names(self) -> List[str]: +        """Get specific template names.""" +        path: str = self.kwargs['path'] +        page_path = settings.PAGES_PATH / path +        if page_path.is_dir(): +            page_path = page_path / "_index.html" +            path = f"{path}/_index.html" +        else: +            page_path = settings.PAGES_PATH / f"{path}.html" +            path = f"{path}.html" + +        if not page_path.exists(): +            raise Http404 + +        return [f"events/{settings.PAGES_PATH.name}/{path}"] diff --git a/pydis_site/apps/home/urls.py b/pydis_site/apps/home/urls.py index d2172c40..bd7c0625 100644 --- a/pydis_site/apps/home/urls.py +++ b/pydis_site/apps/home/urls.py @@ -9,4 +9,5 @@ urlpatterns = [      path('admin/', admin.site.urls),      path('resources/', include('pydis_site.apps.resources.urls')),      path('articles/', include('pydis_site.apps.content.urls')), +    path('events/', include('pydis_site.apps.events.urls', namespace='events')),  ] diff --git a/pydis_site/settings.py b/pydis_site/settings.py index 20707570..d509d980 100644 --- a/pydis_site/settings.py +++ b/pydis_site/settings.py @@ -86,6 +86,7 @@ INSTALLED_APPS = [      'pydis_site.apps.staff',      'pydis_site.apps.resources',      'pydis_site.apps.content', +    'pydis_site.apps.events',      'django.contrib.admin',      'django.contrib.auth', @@ -118,6 +119,9 @@ MIDDLEWARE = [  ]  ROOT_URLCONF = 'pydis_site.urls' +# Path for events pages +PAGES_PATH = Path(BASE_DIR, "pydis_site", "templates", "events", "pages") +  TEMPLATES = [      {          'BACKEND': 'django.template.backends.django.DjangoTemplates', diff --git a/pydis_site/static/css/events/base.css b/pydis_site/static/css/events/base.css new file mode 100644 index 00000000..b4f233f7 --- /dev/null +++ b/pydis_site/static/css/events/base.css @@ -0,0 +1,3 @@ +.breadcrumb-section { +    padding: 1rem; +} diff --git a/pydis_site/templates/events/base.html b/pydis_site/templates/events/base.html new file mode 100644 index 00000000..4aa5056d --- /dev/null +++ b/pydis_site/templates/events/base.html @@ -0,0 +1,38 @@ +{% extends "base/base.html" %} +{% load static %} + +{% block head %} +    <link rel="stylesheet" href="{% static "css/events/base.css" %}"> +{% endblock %} + +{% block content %} +    {% include "base/navbar.html" %} + +    <section class="breadcrumb-section section"> +        <div class="container"> +            <nav class="breadcrumb is-pulled-left" aria-label="breadcrumbs"> +                <ul> +                    {% block breadcrumb %}{% endblock %} +                </ul> +            </nav> +        </div> +    </section> + +    <section class="section"> +        <div class="container"> +            <div class="content"> +                <h1>{% block title %}{% endblock %}</h1> +                <div> +                    <div class="columns is-variable is-8"> +                        <div class="column is-two-thirds"> +                            {% block event_content %}{% endblock %} +                        </div> +                        <div class="column"> +                            {% block sidebar %}{% endblock %} +                        </div> +                    </div> +                </div> +            </div> +        </div> +    </section> +{% endblock %} diff --git a/pydis_site/templates/events/index.html b/pydis_site/templates/events/index.html new file mode 100644 index 00000000..72a47557 --- /dev/null +++ b/pydis_site/templates/events/index.html @@ -0,0 +1,17 @@ +{% extends "events/base.html" %} + +{% block title %}Events{% endblock %} + +{% block breadcrumb %} +    <li class="is-active"><a href="#">Events</a></li> +{% endblock %} + +{% block event_content %} +    <div class="box"> +        <h2 class="title is-4">Code Jams</h2> +        <p>Each year, we organize a Winter Code Jam and a Summer Code Jam. During these events, members of our community will work together in teams to create something amazing using a technology we picked for them. One such technology that was picked for the Winter Code Jam 2020 was Kivy, a cross-platform GUI framework.</p> +        <p>To help fuel the creative process, we provide a specific theme, like <strong>Ancient Technology</strong> or <strong>This App Hates You</strong>. At the end of the Code Jam, the projects are judged by Python Discord server staff members and guest judges from the larger Python community. The judges will consider creativity, code quality, teamwork, and adherence to the theme.</p> +        <p>If you want to read more about Code Jams, visit our <a href="{% url "events:page" path="code-jams" %}">Code Jam info page</a> or watch this video showcasing the best projects created during the <strong>Winter Code Jam 2020: Ancient Technology</strong>:</p> +        <iframe width="560" height="315" src="https://www.youtube.com/embed/8fbZsGrqBzo" frameborder="0" allow="accelerometer; autoplay; encrypted-media; gyroscope; picture-in-picture" allowfullscreen=""></iframe> +    </div> +{% endblock %} diff --git a/pydis_site/templates/events/pages/code-jams/7/_index.html b/pydis_site/templates/events/pages/code-jams/7/_index.html new file mode 100644 index 00000000..ac86b0c9 --- /dev/null +++ b/pydis_site/templates/events/pages/code-jams/7/_index.html @@ -0,0 +1,102 @@ +{% extends "events/base.html" %} + +{% block title %}Summer Code Jam 2020{% endblock %} + +{% block breadcrumb %} +    <li><a href="{% url "events:index" %}">Events</a></li> +    <li><a href="{% url "events:page" path="code-jams" %}">Code Jams</a></li> +    <li class="is-active"><a href="#">Summer Code Jam 2020</a></li> +{% endblock %} + +{% block event_content %} +    <p> +        Ladies and gentlemen, it’s that time of year again! The 7<sub>th</sub> Python Discord Code Jam is imminent. +        This code jam will be held from <strong>Friday, July 31<sup>st</sup> to Sunday, August 9<sup>th</sup></strong> +        where you will complete in teams of five for the elusive title of Code Jam Champion and win some of the many prizes listed. +    </p> +    <p> +        Web development is one of the most popular areas for Python software and development. +        For this code jam, you will be utilizing the <strong>Django</strong> framework to create a web application. +        The Django Software Foundation has even decided to sponsor this event, +        allowing us to add more prizes to our prize pool. +    </p> +    <p> +        Are you unsure of what a code jam is? If so, check out our <a href="/events/code-jams">general code jam page</a>. +    </p> + +    <article class="message is-warning"> +        <div class="message-header"> +            <p>Signups are closed</p> +        </div> + +        <div class="message-body"> +            <p> +                The sign-up period for the Summer Code Jam 2020 is over, +                which means that you can no longer sign up for the Code Jam. +                You can still take a look at +                <a href="https://github.com/python-discord/summer-code-jam-2020-qualifier">the qualifier</a> +                to get an idea of the task we asked the participants to complete in order to qualify for the jam. +                If you want to compete in the next Code Jam, +                subscribe to the announcements posted in our community by using the +                <code>!subscribe</code> command in the <code>#bot-commands</code> channel of our server. +            </p> +        </div> +    </article> + +    <h3>New to Django?</h3> +    <p> +        Don't worry! This code jam will be the perfect opportunity for you to get to know one of the most popular web frameworks for Python. +        Whether it be a REST API or full fledged website, Django can do it! +    </p> +    <p> +        During the event, feel free to ask Django-specific questions in the code jam channels +        or <code>#web-development</code>. As always, our helpers will be there to help you with all the +        other Python-related questions that you have via our <a href="/pages/resources/guides/help-channels">help channel system</a>. <!-- Change help channels page link after content app is ready. --> +    </p> +    <p> +        If you want to get familiar with Django before the event starts, be sure to check out <a href="https://docs.djangoproject.com/en/3.0/intro/">the tutorial in the official +        Django documentation</a>. Alternatively, you could have a look at Corey Schafer's <a href="https://www.youtube.com/playlist?list=PL-osiE80TeTtoQCKZ03TU5fNfx2UY6U4p">Django Tutorials playlist</a> on YouTube. +    </p> + +    <h3>Prizes</h3> +    <p>This year's prize pool includes:</p> +    <ul> +        <li>5 JetBrains 1-year any product licenses</li> +        <li>5 Django hoodies</li> +        <li>Python Discord t-shirts</li> +    </ul> +    <p> +        We will award as many Python Discord t-shirts as we can afford! +        We want to thank all of our Patrons over at our +        <a href="https://www.patreon.com/python_discord">Patreon account</a> for making this possible. +        We literally couldn't do this without you! +    </p> +    <h3>Qualifier & Signups</h3> +    <p> +        It is no longer possible to sign up for the Summer Code Jam 2020. +        If you would like to attempt the qualifier assignment as a personal challenge, you can find it on +        <a href="https://github.com/python-discord/summer-code-jam-2020-qualifier">GitHub</a>. +        The repository also includes a test suite and a solution. +    </p> +    <p> +        If you would like to participate in one of our future events and don't want to risk missing it, +        subscribe to our announcements by using the <code>!subscribe</code> command in the <code>#bot-commands</code> channel on our Discord server. +    </p> +    <h3>Theme</h3> +    <p> +        Similarly to our previous code jams, the theme was chosen by our community! +        By the end of our two-step voting process, +        <strong>Early Internet</strong> came out on top and is the official theme for this code jam. +    </p> +{% endblock %} + +{% block sidebar %} +    {% include "events/sidebar/code-jams/7.html" %} +    <div class="box"> +        <p class="menu-label">Relevant Links</p> +        <ul class="menu-list"> +            <!-- Add other items when they become available --> +            <li><a class="has-text-link" href="{% url "events:page" path="code-jams/7/rules" %}">Rules</a></li> +        </ul> +    </div> +{% endblock %} diff --git a/pydis_site/templates/events/pages/code-jams/7/rules.html b/pydis_site/templates/events/pages/code-jams/7/rules.html new file mode 100644 index 00000000..f77d7129 --- /dev/null +++ b/pydis_site/templates/events/pages/code-jams/7/rules.html @@ -0,0 +1,68 @@ +{% extends "events/base.html" %} + +{% block title %}Rules{% endblock %} + +{% block breadcrumb %} +    <li><a href="{% url "events:index" %}">Events</a></li> +    <li><a href="{% url "events:page" path="code-jams" %}">Code Jams</a></li> +    <li><a href="{% url "events:page" path="code-jams/7" %}">Summer Code Jam 2020</a></li> +    <li class="is-active"><a href="#">Rules</a></li> +{% endblock %} + +{% block event_content %} +    <ol> +        <li><p>Your solution must use the Django framework. It is not permitted to circumvent this rule by e.g. using Django as a wrapper for another framework.</p></li> +        <li><p>Your solution should be platform agnostic. For example, if you use filepaths in your submission, use <code>pathlib</code> to create platform agnostic Path objects instead of hardcoding the paths.</p></li> +        <li><p>Your project should be a web app which can be run in a <em>standard web browser</em>.</p></li> +        <li> +            <p> +                You must document precisely how to install and run your project. +                This should be as easy as possible, which means you should consider using dependency managers like <code>pipenv</code>, and <code>npm</code>. +                We would also encourage you to use <code>docker</code> and <code>docker-compose</code> to containerize your project, but this isn't a requirement. +            </p> +        </li> +        <li> +            You must get contributions from every member of your team, if you have an issue with someone on your team please contact a member of the administration team. +            These contributions do not necessarily have to be code, for example it's absolutely fine for someone to contribute management, documentation, graphics or audio. +            <strong> +                Team members that do not contribute will be removed from the Code Jam, and will not receive their share of any prizes the team may win. +                They may also be barred from entering future events. +            </strong> +        </li> +        <li><p>You must use GitHub as source control.</p></li> +        <li> +            <p> +                All code and assets must be compatible with the <a href="https://en.wikipedia.org/wiki/MIT_License">MIT license</a>. +                This is because we will be merging your submission into our <code>summer-code-jam-2020</code> repo at the end of the jam, +                and this repo is licensed with the MIT license. +                <strong>Projects that include assets that are incompatible with this license may be disqualified.</strong> +            </p> +        </li> +        <li><p>All code must be written and committed within the time constrictions of the jam. Late commits may be reverted, so make sure you leave enough time to bug test your program.</p></li> +        <li> +            <p> +                Use English as the main language for your project, including names, comments, documentation, and commit messages. +                The text displayed in your web application should also be in English, +                although you are allowed to provide the user with options for internationalisation and translation. +            </p> +        </li> +    </ol> + +    <!-- Change links after migrating them is done. --> +    <blockquote> +        Please note that our regular +        <a href="/pages/rules">community rules</a> and <a href="/pages/code-of-conduct">code of conduct</a> +        also apply during the event and that we reserve the right to make changes to these rules at any time. +    </blockquote> +{% endblock %} + +{% block sidebar %} +    {% include "events/sidebar/code-jams/7.html" %} +    <div class="box"> +        <p class="menu-label">Relevant Links</p> +        <ul class="menu-list"> +            <li><a class="has-text-link" href="{% url "events:page" path="code-jams/7" %}">Summer Code Jam 2020</a></li> +            <li><a class="has-text-link" href="https://github.com/python-discord/summer-code-jam-2020-qualifier/">Code Jam Qualifier</a></li> +        </ul> +    </div> +{% endblock %} diff --git a/pydis_site/templates/events/pages/code-jams/_index.html b/pydis_site/templates/events/pages/code-jams/_index.html new file mode 100644 index 00000000..5df3807c --- /dev/null +++ b/pydis_site/templates/events/pages/code-jams/_index.html @@ -0,0 +1,5 @@ +{% extends "events/base.html" %} + +{% block event_content %} +    <p>ToDo!</p> +{% endblock %} diff --git a/pydis_site/templates/events/sidebar/code-jams/7.html b/pydis_site/templates/events/sidebar/code-jams/7.html new file mode 100644 index 00000000..d4615c2a --- /dev/null +++ b/pydis_site/templates/events/sidebar/code-jams/7.html @@ -0,0 +1,12 @@ +{% load static %} + +<div class="box"> +    <img src="https://raw.githubusercontent.com/python-discord/branding/master/events/summer_code_jam_2020/summer%20cj%202020%20discord%20banner.png" alt="Summer Code Jam 2020"> +    <p class="menu-label">Sponsors</p> +    <a href="https://www.djangoproject.com/" target="_blank"> +        <img src="https://static.djangoproject.com/img/logos/django-logo-positive.png" alt="Django"> +    </a> +    <a href="https://jetbrains.com" target="_blank"> +        <img src="{% static "images/sponsors/jetbrains.png" %}" alt="JetBrains"> +    </a> +</div> diff --git a/pydis_site/templates/events/test-pages/my-event/_index.html b/pydis_site/templates/events/test-pages/my-event/_index.html new file mode 100644 index 00000000..1a859fdd --- /dev/null +++ b/pydis_site/templates/events/test-pages/my-event/_index.html @@ -0,0 +1 @@ +{% extends "events/base.html" %} diff --git a/pydis_site/templates/events/test-pages/my-event/subpage.html b/pydis_site/templates/events/test-pages/my-event/subpage.html new file mode 100644 index 00000000..1a859fdd --- /dev/null +++ b/pydis_site/templates/events/test-pages/my-event/subpage.html @@ -0,0 +1 @@ +{% extends "events/base.html" %} | 
