From 1a65aec74016ee2fac3e88b07b1f632cca211b0c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E2=80=9DNyymix=E2=80=9D?= Date: Sun, 29 Dec 2024 23:25:03 +0200 Subject: [PATCH] Add Album model --- gallery/admin.py | 16 +++++++++++----- gallery/migrations/0001_initial.py | 17 ++++++++++++++++- gallery/models.py | 26 ++++++++++++++++++++++++-- 3 files changed, 51 insertions(+), 8 deletions(-) diff --git a/gallery/admin.py b/gallery/admin.py index 6053468..716a0c7 100644 --- a/gallery/admin.py +++ b/gallery/admin.py @@ -1,11 +1,10 @@ from django.contrib import admin -from gallery.models import City, Location +from gallery.models import Album, City, Location # Register your models here. - class CityAdmin(admin.ModelAdmin): list_display = ('name',) search_fields = ('name',) @@ -13,9 +12,6 @@ class CityAdmin(admin.ModelAdmin): list_per_page = 30 -admin.site.register(City, CityAdmin) - - class LocationAdmin(admin.ModelAdmin): list_display = ('city', 'place') list_filter = ('city',) @@ -23,5 +19,15 @@ class LocationAdmin(admin.ModelAdmin): search_fields = ('place', 'city__name',) list_per_page = 30 +class AlbumAdmin(admin.ModelAdmin): + prepopulated_fields = {'slug': ('name',)} + list_display = ('__str__',) + search_fields = ('name',) + ordering = ('name',) + list_per_page = 30 + +admin.site.register(City, CityAdmin) admin.site.register(Location, LocationAdmin) +admin.site.register(Album, AlbumAdmin) + diff --git a/gallery/migrations/0001_initial.py b/gallery/migrations/0001_initial.py index 85dd0de..395758a 100644 --- a/gallery/migrations/0001_initial.py +++ b/gallery/migrations/0001_initial.py @@ -1,5 +1,6 @@ -# Generated by Django 5.1.4 on 2024-12-29 13:38 +# Generated by Django 5.1.4 on 2024-12-29 21:23 +import datetime import django.db.models.deletion from django.db import migrations, models @@ -34,4 +35,18 @@ class Migration(migrations.Migration): 'unique_together': {('place', 'city')}, }, ), + migrations.CreateModel( + name='Album', + fields=[ + ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), + ('name', models.CharField(max_length=150, unique=True, verbose_name='Album')), + ('slug', models.SlugField(max_length=150, unique=True, verbose_name='Slug')), + ('album_date', models.DateField(default=datetime.datetime.now, verbose_name='Album Date')), + ('is_public', models.BooleanField(default=False, verbose_name='Published')), + ('location', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, related_name='albums', to='gallery.location', verbose_name='Location')), + ], + options={ + 'verbose_name_plural': 'Albums', + }, + ), ] diff --git a/gallery/models.py b/gallery/models.py index 14e1acb..2e35bab 100644 --- a/gallery/models.py +++ b/gallery/models.py @@ -1,7 +1,11 @@ +from datetime import datetime + from django.db import models +from django.utils.text import slugify # Create your models here. + class City(models.Model): name = models.CharField(max_length=150, unique=True, verbose_name="City") @@ -10,9 +14,8 @@ class City(models.Model): def __str__(self): return '{}'.format(self.name) - - + class Location(models.Model): place = models.CharField(max_length=250, blank=True, null=False, verbose_name="Place") city = models.ForeignKey(City, on_delete=models.CASCADE, related_name='places', verbose_name="City") @@ -26,3 +29,22 @@ class Location(models.Model): return '{0}, {1}'.format(self.city, self.place) else: return '{}'.format(self.city) + + +class Album(models.Model): + name = models.CharField(max_length=150, unique=True, verbose_name="Album") + slug = models.SlugField(max_length=150, unique=True, verbose_name="Slug") + location = models.ForeignKey(Location, blank=True, null=True, on_delete=models.SET_NULL, related_name='albums', verbose_name="Location") + album_date = models.DateField(default=datetime.now, verbose_name="Album Date") + is_public = models.BooleanField(default=False, verbose_name="Published") + + def save(self, *args, **kwargs): + if not self.slug: + self.slug = slugify(self.name) + super(Album, self).save(*args, **kwargs) + + class Meta: + verbose_name_plural = "Albums" + + def __str__(self): + return '{}'.format(self.name)