muistox/gallery/migrations/0001_initial.py

81 lines
4.2 KiB
Python
Raw Normal View History

2025-01-18 09:40:47 +02:00
# Generated by Django 5.1.4 on 2025-01-18 07:39
2024-12-29 17:35:10 +02:00
2024-12-29 23:25:03 +02:00
import datetime
2024-12-29 17:35:10 +02:00
import django.db.models.deletion
2025-01-09 20:18:43 +02:00
import gallery.models.photo
2024-12-29 17:35:10 +02:00
from django.db import migrations, models
class Migration(migrations.Migration):
initial = True
dependencies = [
]
operations = [
migrations.CreateModel(
name='City',
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='City')),
],
options={
'verbose_name_plural': 'Cities',
},
),
migrations.CreateModel(
name='Location',
fields=[
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('place', models.CharField(blank=True, max_length=250, verbose_name='Place')),
('city', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='places', to='gallery.city', verbose_name='City')),
],
options={
'verbose_name_plural': 'Locations',
'unique_together': {('place', 'city')},
},
),
2024-12-29 23:25:03 +02:00
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')),
2025-01-18 09:40:47 +02:00
('parent', models.ForeignKey(blank=True, limit_choices_to={'parent__isnull': True}, null=True, on_delete=django.db.models.deletion.SET_NULL, related_name='children', to='gallery.album', verbose_name='Parent Album')),
2024-12-29 23:25:03 +02:00
('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',
2025-01-18 09:40:47 +02:00
'ordering': ('album_date',),
2024-12-29 23:25:03 +02:00
},
),
2025-01-05 17:26:09 +02:00
migrations.CreateModel(
name='Photo',
fields=[
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('slug', models.CharField(editable=False, max_length=15, verbose_name='Photo Slug')),
2025-01-09 20:18:43 +02:00
('photo', models.ImageField(height_field='height', upload_to=gallery.models.photo.Photo._get_upload_path, verbose_name='Photo', width_field='width')),
2025-01-05 17:26:09 +02:00
('width', models.PositiveIntegerField(default=0, editable=False, verbose_name='Photo Width')),
('height', models.PositiveIntegerField(default=0, editable=False, verbose_name='Photo Height')),
('taken_at', models.DateTimeField(blank=True, editable=False, null=True, verbose_name='Taken at')),
('exif', models.JSONField(blank=True, editable=False, null=True, verbose_name='Exif Metadata')),
2025-01-09 20:18:43 +02:00
('is_favorite', models.BooleanField(default=False, verbose_name='Is Favorite')),
('views', models.PositiveIntegerField(default=0, verbose_name='Views')),
2025-01-13 22:49:12 +02:00
('likes', models.PositiveIntegerField(default=0, verbose_name='Likes')),
2025-01-05 17:26:09 +02:00
('album', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='photos', to='gallery.album', verbose_name='Album')),
],
2025-01-18 09:40:47 +02:00
options={
'verbose_name_plural': 'Photos',
'ordering': ('-taken_at',),
},
2025-01-05 17:26:09 +02:00
),
2025-01-15 20:31:41 +02:00
migrations.AddField(
model_name='album',
name='cover',
field=models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, related_name='cover_to', to='gallery.photo', verbose_name='Album cover'),
),
2024-12-29 17:35:10 +02:00
]