Compare commits
	
		
			6 Commits
		
	
	
		
			1.0.1
			...
			d4ab0596da
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| d4ab0596da | |||
| 8dcbe2f0ad | |||
| 25bc74eff1 | |||
| 8a7d083fb2 | |||
| 8296ebcf31 | |||
| 04a4f2e0be | 
| @ -1,3 +1,7 @@ | |||||||
|  | ## Unreleased | ||||||
|  |  | ||||||
|  | * Add support for game editions (https://git.kucharczyk.xyz/lukas/timetracker/issues/28) | ||||||
|  |  | ||||||
| ## 1.0.1 / 2023-01-30 22:17+01:00 | ## 1.0.1 / 2023-01-30 22:17+01:00 | ||||||
|  |  | ||||||
| * Make it possible to edit sessions (https://git.kucharczyk.xyz/lukas/timetracker/issues/46) | * Make it possible to edit sessions (https://git.kucharczyk.xyz/lukas/timetracker/issues/46) | ||||||
|  | |||||||
							
								
								
									
										6
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										6
									
								
								Makefile
									
									
									
									
									
								
							| @ -7,11 +7,11 @@ HTMLFILES := $(shell find games/templates -type f) | |||||||
| npm: | npm: | ||||||
| 	npm install | 	npm install | ||||||
|  |  | ||||||
| css: input.css | css: common/input.css | ||||||
| 	npx tailwindcss -i ./input.css -o  ./games/static/base.css | 	npx tailwindcss -i ./common/input.css -o  ./games/static/base.css | ||||||
|  |  | ||||||
| css-dev: css | css-dev: css | ||||||
| 	npx tailwindcss -i ./input.css -o  ./games/static/base.css --watch | 	npx tailwindcss -i ./common/input.css -o  ./games/static/base.css --watch | ||||||
|  |  | ||||||
| makemigrations: | makemigrations: | ||||||
| 	poetry run python manage.py makemigrations | 	poetry run python manage.py makemigrations | ||||||
|  | |||||||
| @ -1,10 +1,12 @@ | |||||||
| from django import forms | from django import forms | ||||||
|  |  | ||||||
| from games.models import Game, Platform, Purchase, Session | from games.models import Game, Platform, Purchase, Session, Edition | ||||||
|  |  | ||||||
|  |  | ||||||
| class SessionForm(forms.ModelForm): | class SessionForm(forms.ModelForm): | ||||||
|     purchase = forms.ModelChoiceField(queryset=Purchase.objects.order_by("game__name")) |     purchase = forms.ModelChoiceField( | ||||||
|  |         queryset=Purchase.objects.order_by("edition__name") | ||||||
|  |     ) | ||||||
|  |  | ||||||
|     class Meta: |     class Meta: | ||||||
|         model = Session |         model = Session | ||||||
| @ -18,12 +20,18 @@ class SessionForm(forms.ModelForm): | |||||||
|  |  | ||||||
|  |  | ||||||
| class PurchaseForm(forms.ModelForm): | class PurchaseForm(forms.ModelForm): | ||||||
|     game = forms.ModelChoiceField(queryset=Game.objects.order_by("name")) |     edition = forms.ModelChoiceField(queryset=Edition.objects.order_by("name")) | ||||||
|     platform = forms.ModelChoiceField(queryset=Platform.objects.order_by("name")) |     platform = forms.ModelChoiceField(queryset=Platform.objects.order_by("name")) | ||||||
|  |  | ||||||
|     class Meta: |     class Meta: | ||||||
|         model = Purchase |         model = Purchase | ||||||
|         fields = ["game", "platform", "date_purchased", "date_refunded"] |         fields = ["edition", "platform", "date_purchased", "date_refunded"] | ||||||
|  |  | ||||||
|  |  | ||||||
|  | class EditionForm(forms.ModelForm): | ||||||
|  |     class Meta: | ||||||
|  |         model = Edition | ||||||
|  |         fields = ["game", "name", "platform"] | ||||||
|  |  | ||||||
|  |  | ||||||
| class GameForm(forms.ModelForm): | class GameForm(forms.ModelForm): | ||||||
|  | |||||||
							
								
								
									
										41
									
								
								games/migrations/0008_edition.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										41
									
								
								games/migrations/0008_edition.py
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,41 @@ | |||||||
|  | # Generated by Django 4.1.5 on 2023-02-18 16:29 | ||||||
|  |  | ||||||
|  | from django.db import migrations, models | ||||||
|  | import django.db.models.deletion | ||||||
|  |  | ||||||
|  |  | ||||||
|  | class Migration(migrations.Migration): | ||||||
|  |  | ||||||
|  |     dependencies = [ | ||||||
|  |         ("games", "0007_alter_purchase_game_alter_purchase_platform_and_more"), | ||||||
|  |     ] | ||||||
|  |  | ||||||
|  |     operations = [ | ||||||
|  |         migrations.CreateModel( | ||||||
|  |             name="Edition", | ||||||
|  |             fields=[ | ||||||
|  |                 ( | ||||||
|  |                     "id", | ||||||
|  |                     models.BigAutoField( | ||||||
|  |                         auto_created=True, | ||||||
|  |                         primary_key=True, | ||||||
|  |                         serialize=False, | ||||||
|  |                         verbose_name="ID", | ||||||
|  |                     ), | ||||||
|  |                 ), | ||||||
|  |                 ("name", models.CharField(max_length=255)), | ||||||
|  |                 ( | ||||||
|  |                     "game", | ||||||
|  |                     models.ForeignKey( | ||||||
|  |                         on_delete=django.db.models.deletion.CASCADE, to="games.game" | ||||||
|  |                     ), | ||||||
|  |                 ), | ||||||
|  |                 ( | ||||||
|  |                     "platform", | ||||||
|  |                     models.ForeignKey( | ||||||
|  |                         on_delete=django.db.models.deletion.CASCADE, to="games.platform" | ||||||
|  |                     ), | ||||||
|  |                 ), | ||||||
|  |             ], | ||||||
|  |         ), | ||||||
|  |     ] | ||||||
							
								
								
									
										34
									
								
								games/migrations/0009_create_editions.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										34
									
								
								games/migrations/0009_create_editions.py
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,34 @@ | |||||||
|  | # Generated by Django 4.1.5 on 2023-02-18 18:51 | ||||||
|  |  | ||||||
|  | from django.db import migrations | ||||||
|  |  | ||||||
|  |  | ||||||
|  | def create_edition_of_game(apps, schema_editor): | ||||||
|  |     Game = apps.get_model("games", "Game") | ||||||
|  |     Edition = apps.get_model("games", "Edition") | ||||||
|  |     Platform = apps.get_model("games", "Platform") | ||||||
|  |     first_platform = Platform.objects.first() | ||||||
|  |     all_games = Game.objects.all() | ||||||
|  |     all_editions = Edition.objects.all() | ||||||
|  |     for game in all_games: | ||||||
|  |         existing_edition = None | ||||||
|  |         try: | ||||||
|  |             existing_edition = all_editions.objects.get(game=game.id) | ||||||
|  |         except: | ||||||
|  |             pass | ||||||
|  |         if existing_edition == None: | ||||||
|  |             edition = Edition() | ||||||
|  |             edition.id = game.id | ||||||
|  |             edition.game = game | ||||||
|  |             edition.name = game.name | ||||||
|  |             edition.platform = first_platform | ||||||
|  |             edition.save() | ||||||
|  |  | ||||||
|  |  | ||||||
|  | class Migration(migrations.Migration): | ||||||
|  |  | ||||||
|  |     dependencies = [ | ||||||
|  |         ("games", "0008_edition"), | ||||||
|  |     ] | ||||||
|  |  | ||||||
|  |     operations = [migrations.RunPython(create_edition_of_game)] | ||||||
							
								
								
									
										21
									
								
								games/migrations/0010_alter_purchase_game.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								games/migrations/0010_alter_purchase_game.py
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,21 @@ | |||||||
|  | # Generated by Django 4.1.5 on 2023-02-18 19:06 | ||||||
|  |  | ||||||
|  | from django.db import migrations, models | ||||||
|  | import django.db.models.deletion | ||||||
|  |  | ||||||
|  |  | ||||||
|  | class Migration(migrations.Migration): | ||||||
|  |  | ||||||
|  |     dependencies = [ | ||||||
|  |         ("games", "0009_create_editions"), | ||||||
|  |     ] | ||||||
|  |  | ||||||
|  |     operations = [ | ||||||
|  |         migrations.AlterField( | ||||||
|  |             model_name="purchase", | ||||||
|  |             name="game", | ||||||
|  |             field=models.ForeignKey( | ||||||
|  |                 on_delete=django.db.models.deletion.CASCADE, to="games.edition" | ||||||
|  |             ), | ||||||
|  |         ), | ||||||
|  |     ] | ||||||
							
								
								
									
										18
									
								
								games/migrations/0011_rename_game_purchase_edition.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										18
									
								
								games/migrations/0011_rename_game_purchase_edition.py
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,18 @@ | |||||||
|  | # Generated by Django 4.1.5 on 2023-02-18 19:18 | ||||||
|  |  | ||||||
|  | from django.db import migrations | ||||||
|  |  | ||||||
|  |  | ||||||
|  | class Migration(migrations.Migration): | ||||||
|  |  | ||||||
|  |     dependencies = [ | ||||||
|  |         ("games", "0010_alter_purchase_game"), | ||||||
|  |     ] | ||||||
|  |  | ||||||
|  |     operations = [ | ||||||
|  |         migrations.RenameField( | ||||||
|  |             model_name="purchase", | ||||||
|  |             old_name="game", | ||||||
|  |             new_name="edition", | ||||||
|  |         ), | ||||||
|  |     ] | ||||||
| @ -16,14 +16,23 @@ class Game(models.Model): | |||||||
|         return self.name |         return self.name | ||||||
|  |  | ||||||
|  |  | ||||||
| class Purchase(models.Model): | class Edition(models.Model): | ||||||
|     game = models.ForeignKey("Game", on_delete=models.CASCADE) |     game = models.ForeignKey("Game", on_delete=models.CASCADE) | ||||||
|  |     name = models.CharField(max_length=255) | ||||||
|  |     platform = models.ForeignKey("Platform", on_delete=models.CASCADE) | ||||||
|  |  | ||||||
|  |     def __str__(self): | ||||||
|  |         return self.name | ||||||
|  |  | ||||||
|  |  | ||||||
|  | class Purchase(models.Model): | ||||||
|  |     edition = models.ForeignKey("Edition", on_delete=models.CASCADE) | ||||||
|     platform = models.ForeignKey("Platform", on_delete=models.CASCADE) |     platform = models.ForeignKey("Platform", on_delete=models.CASCADE) | ||||||
|     date_purchased = models.DateField() |     date_purchased = models.DateField() | ||||||
|     date_refunded = models.DateField(blank=True, null=True) |     date_refunded = models.DateField(blank=True, null=True) | ||||||
|  |  | ||||||
|     def __str__(self): |     def __str__(self): | ||||||
|         return f"{self.game} ({self.platform})" |         return f"{self.edition} ({self.platform})" | ||||||
|  |  | ||||||
|  |  | ||||||
| class Platform(models.Model): | class Platform(models.Model): | ||||||
|  | |||||||
| @ -27,6 +27,9 @@ | |||||||
|                             <li><a class="block py-2 pl-3 pr-4 hover:underline" href="{% url 'add_game' %}">New Game</a></li> |                             <li><a class="block py-2 pl-3 pr-4 hover:underline" href="{% url 'add_game' %}">New Game</a></li> | ||||||
|                             <li><a class="block py-2 pl-3 pr-4 hover:underline" href="{% url 'add_platform' %}">New Platform</a></li> |                             <li><a class="block py-2 pl-3 pr-4 hover:underline" href="{% url 'add_platform' %}">New Platform</a></li> | ||||||
|                             {% if game_available and platform_available %} |                             {% if game_available and platform_available %} | ||||||
|  |                                 <li><a class="block py-2 pl-3 pr-4 hover:underline" href="{% url 'add_edition' %}">New Edition</a></li> | ||||||
|  |                             {% endif %} | ||||||
|  |                             {% if edition_available %} | ||||||
|                                 <li><a class="block py-2 pl-3 pr-4 hover:underline" href="{% url 'add_purchase' %}">New Purchase</a></li> |                                 <li><a class="block py-2 pl-3 pr-4 hover:underline" href="{% url 'add_purchase' %}">New Purchase</a></li> | ||||||
|                             {% endif %} |                             {% endif %} | ||||||
|                             {% if purchase_available %} |                             {% if purchase_available %} | ||||||
|  | |||||||
| @ -10,15 +10,18 @@ | |||||||
|             {% if dataset.count >= 1 %} |             {% if dataset.count >= 1 %} | ||||||
|             <div class="mb-4">Total playtime: {{ total_duration }} over {{ dataset.count }} sessions.</div> |             <div class="mb-4">Total playtime: {{ total_duration }} over {{ dataset.count }} sessions.</div> | ||||||
|             {% endif %} |             {% endif %} | ||||||
|             {% if purchase or platform or game %} |             {% if purchase or platform or edition %} | ||||||
|             <a class="text-red-400 inline" href="{% url 'list_sessions' %}"><svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" stroke-width="1.5" stroke="currentColor" class="w-6 h-6 inline"> |             <span class="block"> | ||||||
|                 <path stroke-linecap="round" stroke-linejoin="round" d="M9.75 9.75l4.5 4.5m0-4.5l-4.5 4.5M21 12a9 9 0 11-18 0 9 9 0 0118 0z" /> |                 <a class="text-red-400 inline" href="{% url 'list_sessions' %}"> | ||||||
|               </svg> |                     <svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" stroke-width="1.5" stroke="currentColor" class="w-6 h-6 inline"> | ||||||
|               </a><span>Filtering by "{% firstof purchase platform game %}"</span> |                         <path stroke-linecap="round" stroke-linejoin="round" d="M9.75 9.75l4.5 4.5m0-4.5l-4.5 4.5M21 12a9 9 0 11-18 0 9 9 0 0118 0z" /> | ||||||
|             {% if purchase %}<a class="dark:text-white hover:underline block" href="{% url 'list_sessions_by_game' purchase.game.id %}">See all platforms</a>{% endif %} |                     </svg> | ||||||
|  |                 </a>Filtering by "{% firstof purchase platform edition %}" | ||||||
|  |             </span> | ||||||
|  |             {% if purchase %}<a class="dark:text-white hover:underline block" href="{% url 'list_sessions_by_edition' purchase.edition.id %}">See all platforms</a>{% endif %} | ||||||
|             {% endif %} |             {% endif %} | ||||||
|             {% if dataset.count >= 1 %} |             {% if dataset.count >= 1 %} | ||||||
|             <a class="clear-both" href="{% url 'start_session' last.purchase.id %}"> |             <a href="{% url 'start_session' last.purchase.id %}"> | ||||||
|                 <button type="button" title="Track last tracked" class="mt-10 py-1 px-2 bg-green-600 hover:bg-green-700 focus:ring-green-500 focus:ring-offset-blue-200 text-white transition ease-in duration-200 text-center text-base font-semibold shadow-md focus:outline-none focus:ring-2 focus:ring-offset-2 rounded-lg "> |                 <button type="button" title="Track last tracked" class="mt-10 py-1 px-2 bg-green-600 hover:bg-green-700 focus:ring-green-500 focus:ring-offset-blue-200 text-white transition ease-in duration-200 text-center text-base font-semibold shadow-md focus:outline-none focus:ring-2 focus:ring-offset-2 rounded-lg "> | ||||||
|                     <svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" stroke-width="1.5" stroke="currentColor" class="self-center w-6 h-6 inline"> |                     <svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" stroke-width="1.5" stroke="currentColor" class="self-center w-6 h-6 inline"> | ||||||
|                         <path stroke-linecap="round" stroke-linejoin="round" d="M5.25 5.653c0-.856.917-1.398 1.667-.986l11.54 6.348a1.125 1.125 0 010 1.971l-11.54 6.347a1.125 1.125 0 01-1.667-.985V5.653z" /> |                         <path stroke-linecap="round" stroke-linejoin="round" d="M5.25 5.653c0-.856.917-1.398 1.667-.986l11.54 6.348a1.125 1.125 0 010 1.971l-11.54 6.347a1.125 1.125 0 01-1.667-.985V5.653z" /> | ||||||
| @ -36,7 +39,7 @@ | |||||||
|         <div class="dark:border-white dark:text-slate-300 text-lg">Duration</div> |         <div class="dark:border-white dark:text-slate-300 text-lg">Duration</div> | ||||||
|         <div class="dark:border-white dark:text-slate-300 text-lg text-right">Manage</div> |         <div class="dark:border-white dark:text-slate-300 text-lg text-right">Manage</div> | ||||||
|         {% for data in dataset %} |         {% for data in dataset %} | ||||||
|             <div class="dark:text-white overflow-hidden text-ellipsis whitespace-nowrap"><a class="hover:underline" href="{% url 'list_sessions_by_purchase' data.purchase.id %}">{{ data.purchase.game }}</a></div> |             <div class="dark:text-white overflow-hidden text-ellipsis whitespace-nowrap"><a class="hover:underline" href="{% url 'list_sessions_by_purchase' data.purchase.id %}">{{ data.purchase.edition }}</a></div> | ||||||
|             <div class="dark:text-white overflow-hidden text-ellipsis whitespace-nowrap"><a class="hover:underline" href="{% url 'list_sessions_by_platform' data.purchase.platform.id %}">{{ data.purchase.platform }}</a></div> |             <div class="dark:text-white overflow-hidden text-ellipsis whitespace-nowrap"><a class="hover:underline" href="{% url 'list_sessions_by_platform' data.purchase.platform.id %}">{{ data.purchase.platform }}</a></div> | ||||||
|             <div class="dark:text-slate-400 text-center">{{ data.timestamp_start | date:"d/m/Y H:i" }}</div> |             <div class="dark:text-slate-400 text-center">{{ data.timestamp_start | date:"d/m/Y H:i" }}</div> | ||||||
|             <div class="dark:text-slate-400 text-center"> |             <div class="dark:text-slate-400 text-center"> | ||||||
|  | |||||||
| @ -3,7 +3,13 @@ from django.urls import path | |||||||
| from games import views | from games import views | ||||||
|  |  | ||||||
| urlpatterns = [ | urlpatterns = [ | ||||||
|     path("", views.list_sessions, {"filter": "recent"}, name="list_sessions_recent"), |     path("", views.index, name="index"), | ||||||
|  |     path( | ||||||
|  |         "list-sessions/recent", | ||||||
|  |         views.list_sessions, | ||||||
|  |         {"filter": "recent"}, | ||||||
|  |         name="list_sessions_recent", | ||||||
|  |     ), | ||||||
|     path("add-game/", views.add_game, name="add_game"), |     path("add-game/", views.add_game, name="add_game"), | ||||||
|     path("add-platform/", views.add_platform, name="add_platform"), |     path("add-platform/", views.add_platform, name="add_platform"), | ||||||
|     path("add-session/", views.add_session, name="add_session"), |     path("add-session/", views.add_session, name="add_session"), | ||||||
| @ -23,6 +29,7 @@ urlpatterns = [ | |||||||
|         name="delete_session", |         name="delete_session", | ||||||
|     ), |     ), | ||||||
|     path("add-purchase/", views.add_purchase, name="add_purchase"), |     path("add-purchase/", views.add_purchase, name="add_purchase"), | ||||||
|  |     path("add-edition/", views.add_edition, name="add_edition"), | ||||||
|     path("edit-session/<int:session_id>", views.edit_session, name="edit_session"), |     path("edit-session/<int:session_id>", views.edit_session, name="edit_session"), | ||||||
|     path("list-sessions/", views.list_sessions, name="list_sessions"), |     path("list-sessions/", views.list_sessions, name="list_sessions"), | ||||||
|     path( |     path( | ||||||
| @ -38,9 +45,9 @@ urlpatterns = [ | |||||||
|         name="list_sessions_by_platform", |         name="list_sessions_by_platform", | ||||||
|     ), |     ), | ||||||
|     path( |     path( | ||||||
|         "list-sessions/by-game/<int:game_id>", |         "list-sessions/by-edition/<int:edition_id>", | ||||||
|         views.list_sessions, |         views.list_sessions, | ||||||
|         {"filter": "game"}, |         {"filter": "edition"}, | ||||||
|         name="list_sessions_by_game", |         name="list_sessions_by_edition", | ||||||
|     ), |     ), | ||||||
| ] | ] | ||||||
|  | |||||||
| @ -6,13 +6,14 @@ from common.time import now as now_with_tz | |||||||
| from django.conf import settings | from django.conf import settings | ||||||
| from django.shortcuts import redirect, render | from django.shortcuts import redirect, render | ||||||
|  |  | ||||||
| from .forms import GameForm, PlatformForm, PurchaseForm, SessionForm | from .forms import GameForm, PlatformForm, PurchaseForm, SessionForm, EditionForm | ||||||
| from .models import Game, Platform, Purchase, Session | from .models import Game, Platform, Purchase, Session, Edition | ||||||
|  |  | ||||||
|  |  | ||||||
| def model_counts(request): | def model_counts(request): | ||||||
|     return { |     return { | ||||||
|         "game_available": Game.objects.count() != 0, |         "game_available": Game.objects.count() != 0, | ||||||
|  |         "edition_available": Edition.objects.count() != 0, | ||||||
|         "platform_available": Platform.objects.count() != 0, |         "platform_available": Platform.objects.count() != 0, | ||||||
|         "purchase_available": Purchase.objects.count() != 0, |         "purchase_available": Purchase.objects.count() != 0, | ||||||
|         "session_count": Session.objects.count(), |         "session_count": Session.objects.count(), | ||||||
| @ -71,7 +72,7 @@ def delete_session(request, session_id=None): | |||||||
|     return redirect("list_sessions") |     return redirect("list_sessions") | ||||||
|  |  | ||||||
|  |  | ||||||
| def list_sessions(request, filter="", purchase_id="", platform_id="", game_id=""): | def list_sessions(request, filter="", purchase_id="", platform_id="", edition_id=""): | ||||||
|     context = {} |     context = {} | ||||||
|     context["title"] = "Sessions" |     context["title"] = "Sessions" | ||||||
|  |  | ||||||
| @ -81,13 +82,13 @@ def list_sessions(request, filter="", purchase_id="", platform_id="", game_id="" | |||||||
|     elif filter == "platform": |     elif filter == "platform": | ||||||
|         dataset = Session.objects.filter(purchase__platform=platform_id) |         dataset = Session.objects.filter(purchase__platform=platform_id) | ||||||
|         context["platform"] = Platform.objects.get(id=platform_id) |         context["platform"] = Platform.objects.get(id=platform_id) | ||||||
|     elif filter == "game": |     elif filter == "edition": | ||||||
|         dataset = Session.objects.filter(purchase__game=game_id) |         dataset = Session.objects.filter(purchase__edition=edition_id) | ||||||
|         context["game"] = Game.objects.get(id=game_id) |         context["edition"] = Edition.objects.get(id=edition_id) | ||||||
|     elif filter == "recent": |     elif filter == "recent": | ||||||
|         dataset = Session.objects.filter( |         dataset = Session.objects.filter( | ||||||
|             timestamp_start__gte=datetime.now() - timedelta(days=30) |             timestamp_start__gte=datetime.now() - timedelta(days=30) | ||||||
|         ) |         ).order_by("-timestamp_start") | ||||||
|         context["title"] = "Last 30 days" |         context["title"] = "Last 30 days" | ||||||
|     else: |     else: | ||||||
|         # by default, sort from newest to oldest |         # by default, sort from newest to oldest | ||||||
| @ -135,6 +136,18 @@ def add_game(request): | |||||||
|     return render(request, "add.html", context) |     return render(request, "add.html", context) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | def add_edition(request): | ||||||
|  |     context = {} | ||||||
|  |     form = EditionForm(request.POST or None) | ||||||
|  |     if form.is_valid(): | ||||||
|  |         form.save() | ||||||
|  |         return redirect("index") | ||||||
|  |  | ||||||
|  |     context["form"] = form | ||||||
|  |     context["title"] = "Add New Edition" | ||||||
|  |     return render(request, "add.html", context) | ||||||
|  |  | ||||||
|  |  | ||||||
| def add_platform(request): | def add_platform(request): | ||||||
|     context = {} |     context = {} | ||||||
|     form = PlatformForm(request.POST or None) |     form = PlatformForm(request.POST or None) | ||||||
| @ -145,3 +158,7 @@ def add_platform(request): | |||||||
|     context["form"] = form |     context["form"] = form | ||||||
|     context["title"] = "Add New Platform" |     context["title"] = "Add New Platform" | ||||||
|     return render(request, "add.html", context) |     return render(request, "add.html", context) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | def index(request): | ||||||
|  |     return redirect("list_sessions_recent") | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user