[scrobbles] Refactor run time sec to be blank by default
This commit is contained in:
File diff suppressed because one or more lines are too long
@ -0,0 +1,26 @@
|
|||||||
|
# Generated by Django 4.2.19 on 2025-10-30 01:52
|
||||||
|
|
||||||
|
from django.db import migrations, models
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('beers', '0005_alter_beer_run_time_seconds'),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.RemoveField(
|
||||||
|
model_name='beer',
|
||||||
|
name='run_time_seconds',
|
||||||
|
),
|
||||||
|
migrations.RemoveField(
|
||||||
|
model_name='beer',
|
||||||
|
name='run_time_ticks',
|
||||||
|
),
|
||||||
|
migrations.AddField(
|
||||||
|
model_name='beer',
|
||||||
|
name='base_run_time_seconds',
|
||||||
|
field=models.IntegerField(blank=True, null=True),
|
||||||
|
),
|
||||||
|
]
|
||||||
@ -0,0 +1,26 @@
|
|||||||
|
# Generated by Django 4.2.19 on 2025-10-30 01:52
|
||||||
|
|
||||||
|
from django.db import migrations, models
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('boardgames', '0010_boardgame_published_year'),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.RemoveField(
|
||||||
|
model_name='boardgame',
|
||||||
|
name='run_time_seconds',
|
||||||
|
),
|
||||||
|
migrations.RemoveField(
|
||||||
|
model_name='boardgame',
|
||||||
|
name='run_time_ticks',
|
||||||
|
),
|
||||||
|
migrations.AddField(
|
||||||
|
model_name='boardgame',
|
||||||
|
name='base_run_time_seconds',
|
||||||
|
field=models.IntegerField(blank=True, null=True),
|
||||||
|
),
|
||||||
|
]
|
||||||
@ -0,0 +1,39 @@
|
|||||||
|
# Generated by Django 4.2.19 on 2025-10-30 01:52
|
||||||
|
|
||||||
|
from django.db import migrations, models
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('books', '0031_book_next_readcomics_url'),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.RemoveField(
|
||||||
|
model_name='book',
|
||||||
|
name='run_time_seconds',
|
||||||
|
),
|
||||||
|
migrations.RemoveField(
|
||||||
|
model_name='book',
|
||||||
|
name='run_time_ticks',
|
||||||
|
),
|
||||||
|
migrations.RemoveField(
|
||||||
|
model_name='paper',
|
||||||
|
name='run_time_seconds',
|
||||||
|
),
|
||||||
|
migrations.RemoveField(
|
||||||
|
model_name='paper',
|
||||||
|
name='run_time_ticks',
|
||||||
|
),
|
||||||
|
migrations.AddField(
|
||||||
|
model_name='book',
|
||||||
|
name='base_run_time_seconds',
|
||||||
|
field=models.IntegerField(blank=True, null=True),
|
||||||
|
),
|
||||||
|
migrations.AddField(
|
||||||
|
model_name='paper',
|
||||||
|
name='base_run_time_seconds',
|
||||||
|
field=models.IntegerField(blank=True, null=True),
|
||||||
|
),
|
||||||
|
]
|
||||||
@ -0,0 +1,26 @@
|
|||||||
|
# Generated by Django 4.2.19 on 2025-10-30 01:52
|
||||||
|
|
||||||
|
from django.db import migrations, models
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('bricksets', '0002_alter_brickset_run_time_seconds'),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.RemoveField(
|
||||||
|
model_name='brickset',
|
||||||
|
name='run_time_seconds',
|
||||||
|
),
|
||||||
|
migrations.RemoveField(
|
||||||
|
model_name='brickset',
|
||||||
|
name='run_time_ticks',
|
||||||
|
),
|
||||||
|
migrations.AddField(
|
||||||
|
model_name='brickset',
|
||||||
|
name='base_run_time_seconds',
|
||||||
|
field=models.IntegerField(blank=True, null=True),
|
||||||
|
),
|
||||||
|
]
|
||||||
@ -0,0 +1,26 @@
|
|||||||
|
# Generated by Django 4.2.19 on 2025-10-30 01:52
|
||||||
|
|
||||||
|
from django.db import migrations, models
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('foods', '0003_food_calories'),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.RemoveField(
|
||||||
|
model_name='food',
|
||||||
|
name='run_time_seconds',
|
||||||
|
),
|
||||||
|
migrations.RemoveField(
|
||||||
|
model_name='food',
|
||||||
|
name='run_time_ticks',
|
||||||
|
),
|
||||||
|
migrations.AddField(
|
||||||
|
model_name='food',
|
||||||
|
name='base_run_time_seconds',
|
||||||
|
field=models.IntegerField(blank=True, null=True),
|
||||||
|
),
|
||||||
|
]
|
||||||
@ -0,0 +1,26 @@
|
|||||||
|
# Generated by Django 4.2.19 on 2025-10-30 01:52
|
||||||
|
|
||||||
|
from django.db import migrations, models
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('lifeevents', '0002_alter_lifeevent_run_time_seconds'),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.RemoveField(
|
||||||
|
model_name='lifeevent',
|
||||||
|
name='run_time_seconds',
|
||||||
|
),
|
||||||
|
migrations.RemoveField(
|
||||||
|
model_name='lifeevent',
|
||||||
|
name='run_time_ticks',
|
||||||
|
),
|
||||||
|
migrations.AddField(
|
||||||
|
model_name='lifeevent',
|
||||||
|
name='base_run_time_seconds',
|
||||||
|
field=models.IntegerField(blank=True, null=True),
|
||||||
|
),
|
||||||
|
]
|
||||||
@ -0,0 +1,26 @@
|
|||||||
|
# Generated by Django 4.2.19 on 2025-10-30 01:52
|
||||||
|
|
||||||
|
from django.db import migrations, models
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('locations', '0007_alter_geolocation_run_time_seconds'),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.RemoveField(
|
||||||
|
model_name='geolocation',
|
||||||
|
name='run_time_seconds',
|
||||||
|
),
|
||||||
|
migrations.RemoveField(
|
||||||
|
model_name='geolocation',
|
||||||
|
name='run_time_ticks',
|
||||||
|
),
|
||||||
|
migrations.AddField(
|
||||||
|
model_name='geolocation',
|
||||||
|
name='base_run_time_seconds',
|
||||||
|
field=models.IntegerField(blank=True, null=True),
|
||||||
|
),
|
||||||
|
]
|
||||||
File diff suppressed because one or more lines are too long
@ -0,0 +1,26 @@
|
|||||||
|
# Generated by Django 4.2.19 on 2025-10-30 01:52
|
||||||
|
|
||||||
|
from django.db import migrations, models
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('moods', '0003_alter_mood_run_time_seconds'),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.RemoveField(
|
||||||
|
model_name='mood',
|
||||||
|
name='run_time_seconds',
|
||||||
|
),
|
||||||
|
migrations.RemoveField(
|
||||||
|
model_name='mood',
|
||||||
|
name='run_time_ticks',
|
||||||
|
),
|
||||||
|
migrations.AddField(
|
||||||
|
model_name='mood',
|
||||||
|
name='base_run_time_seconds',
|
||||||
|
field=models.IntegerField(blank=True, null=True),
|
||||||
|
),
|
||||||
|
]
|
||||||
@ -0,0 +1,26 @@
|
|||||||
|
# Generated by Django 4.2.19 on 2025-10-30 01:52
|
||||||
|
|
||||||
|
from django.db import migrations, models
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('music', '0028_alter_track_albums'),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.RemoveField(
|
||||||
|
model_name='track',
|
||||||
|
name='run_time_seconds',
|
||||||
|
),
|
||||||
|
migrations.RemoveField(
|
||||||
|
model_name='track',
|
||||||
|
name='run_time_ticks',
|
||||||
|
),
|
||||||
|
migrations.AddField(
|
||||||
|
model_name='track',
|
||||||
|
name='base_run_time_seconds',
|
||||||
|
field=models.IntegerField(blank=True, null=True),
|
||||||
|
),
|
||||||
|
]
|
||||||
@ -0,0 +1,26 @@
|
|||||||
|
# Generated by Django 4.2.19 on 2025-10-30 01:52
|
||||||
|
|
||||||
|
from django.db import migrations, models
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('podcasts', '0017_podcast_podcastindex_id'),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.RemoveField(
|
||||||
|
model_name='podcastepisode',
|
||||||
|
name='run_time_seconds',
|
||||||
|
),
|
||||||
|
migrations.RemoveField(
|
||||||
|
model_name='podcastepisode',
|
||||||
|
name='run_time_ticks',
|
||||||
|
),
|
||||||
|
migrations.AddField(
|
||||||
|
model_name='podcastepisode',
|
||||||
|
name='base_run_time_seconds',
|
||||||
|
field=models.IntegerField(blank=True, null=True),
|
||||||
|
),
|
||||||
|
]
|
||||||
@ -0,0 +1,26 @@
|
|||||||
|
# Generated by Django 4.2.19 on 2025-10-30 01:52
|
||||||
|
|
||||||
|
from django.db import migrations, models
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('puzzles', '0003_rename_igdb_id_puzzle_ipdb_id_and_more'),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.RemoveField(
|
||||||
|
model_name='puzzle',
|
||||||
|
name='run_time_seconds',
|
||||||
|
),
|
||||||
|
migrations.RemoveField(
|
||||||
|
model_name='puzzle',
|
||||||
|
name='run_time_ticks',
|
||||||
|
),
|
||||||
|
migrations.AddField(
|
||||||
|
model_name='puzzle',
|
||||||
|
name='base_run_time_seconds',
|
||||||
|
field=models.IntegerField(blank=True, null=True),
|
||||||
|
),
|
||||||
|
]
|
||||||
@ -57,14 +57,20 @@ class ScrobblableMixin(TimeStampedModel):
|
|||||||
|
|
||||||
uuid = models.UUIDField(default=uuid4, editable=False, **BNULL)
|
uuid = models.UUIDField(default=uuid4, editable=False, **BNULL)
|
||||||
title = models.CharField(max_length=255, **BNULL)
|
title = models.CharField(max_length=255, **BNULL)
|
||||||
run_time_seconds = models.IntegerField(default=900)
|
base_run_time_seconds = models.IntegerField(**BNULL)
|
||||||
run_time_ticks = models.PositiveBigIntegerField(**BNULL)
|
|
||||||
|
|
||||||
genre = TaggableManager(through=ObjectWithGenres, blank=True)
|
genre = TaggableManager(through=ObjectWithGenres, blank=True)
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
abstract = True
|
abstract = True
|
||||||
|
|
||||||
|
@property
|
||||||
|
def run_time_seconds(self) -> int:
|
||||||
|
run_time = 900
|
||||||
|
if self.base_run_time_seconds:
|
||||||
|
run_time = self.base_run_time_seconds
|
||||||
|
return run_time
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
def is_long_play_media(cls) -> bool:
|
def is_long_play_media(cls) -> bool:
|
||||||
return False
|
return False
|
||||||
|
|||||||
@ -0,0 +1,26 @@
|
|||||||
|
# Generated by Django 4.2.19 on 2025-10-30 01:52
|
||||||
|
|
||||||
|
from django.db import migrations, models
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('sports', '0015_alter_sportevent_run_time_seconds'),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.RemoveField(
|
||||||
|
model_name='sportevent',
|
||||||
|
name='run_time_seconds',
|
||||||
|
),
|
||||||
|
migrations.RemoveField(
|
||||||
|
model_name='sportevent',
|
||||||
|
name='run_time_ticks',
|
||||||
|
),
|
||||||
|
migrations.AddField(
|
||||||
|
model_name='sportevent',
|
||||||
|
name='base_run_time_seconds',
|
||||||
|
field=models.IntegerField(blank=True, null=True),
|
||||||
|
),
|
||||||
|
]
|
||||||
@ -0,0 +1,26 @@
|
|||||||
|
# Generated by Django 4.2.19 on 2025-10-30 01:52
|
||||||
|
|
||||||
|
from django.db import migrations, models
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('tasks', '0004_alter_task_run_time_seconds'),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.RemoveField(
|
||||||
|
model_name='task',
|
||||||
|
name='run_time_seconds',
|
||||||
|
),
|
||||||
|
migrations.RemoveField(
|
||||||
|
model_name='task',
|
||||||
|
name='run_time_ticks',
|
||||||
|
),
|
||||||
|
migrations.AddField(
|
||||||
|
model_name='task',
|
||||||
|
name='base_run_time_seconds',
|
||||||
|
field=models.IntegerField(blank=True, null=True),
|
||||||
|
),
|
||||||
|
]
|
||||||
@ -0,0 +1,26 @@
|
|||||||
|
# Generated by Django 4.2.19 on 2025-10-30 01:52
|
||||||
|
|
||||||
|
from django.db import migrations, models
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('trails', '0005_trail_alltrails_id_trail_gaiagps_id'),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.RemoveField(
|
||||||
|
model_name='trail',
|
||||||
|
name='run_time_seconds',
|
||||||
|
),
|
||||||
|
migrations.RemoveField(
|
||||||
|
model_name='trail',
|
||||||
|
name='run_time_ticks',
|
||||||
|
),
|
||||||
|
migrations.AddField(
|
||||||
|
model_name='trail',
|
||||||
|
name='base_run_time_seconds',
|
||||||
|
field=models.IntegerField(blank=True, null=True),
|
||||||
|
),
|
||||||
|
]
|
||||||
@ -0,0 +1,26 @@
|
|||||||
|
# Generated by Django 4.2.19 on 2025-10-30 01:52
|
||||||
|
|
||||||
|
from django.db import migrations, models
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('videogames', '0012_alter_videogame_run_time_seconds'),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.RemoveField(
|
||||||
|
model_name='videogame',
|
||||||
|
name='run_time_seconds',
|
||||||
|
),
|
||||||
|
migrations.RemoveField(
|
||||||
|
model_name='videogame',
|
||||||
|
name='run_time_ticks',
|
||||||
|
),
|
||||||
|
migrations.AddField(
|
||||||
|
model_name='videogame',
|
||||||
|
name='base_run_time_seconds',
|
||||||
|
field=models.IntegerField(blank=True, null=True),
|
||||||
|
),
|
||||||
|
]
|
||||||
@ -205,7 +205,7 @@ class VideoGame(LongPlayScrobblableMixin):
|
|||||||
|
|
||||||
@property
|
@property
|
||||||
def seconds_for_completion(self) -> int:
|
def seconds_for_completion(self) -> int:
|
||||||
completion_time = self.run_time_ticks
|
completion_time = self.run_time_seconds
|
||||||
if not completion_time:
|
if not completion_time:
|
||||||
# Default to 10 hours, why not
|
# Default to 10 hours, why not
|
||||||
completion_time = 10 * 60 * 60
|
completion_time = 10 * 60 * 60
|
||||||
@ -237,7 +237,7 @@ class VideoGame(LongPlayScrobblableMixin):
|
|||||||
if self.igdb_id:
|
if self.igdb_id:
|
||||||
load_game_data_from_igdb(self.id, self.igdb_id)
|
load_game_data_from_igdb(self.id, self.igdb_id)
|
||||||
|
|
||||||
if (not self.run_time_ticks or force_update) and self.main_story_time:
|
if force_update and self.main_story_time:
|
||||||
self.run_time_seconds = self.main_story_time
|
self.run_time_seconds = self.main_story_time
|
||||||
self.save(update_fields=["run_time_seconds"])
|
self.save(update_fields=["run_time_seconds"])
|
||||||
|
|
||||||
|
|||||||
@ -0,0 +1,26 @@
|
|||||||
|
# Generated by Django 4.2.19 on 2025-10-30 01:52
|
||||||
|
|
||||||
|
from django.db import migrations, models
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('videos', '0023_video_tmdb_rating'),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.RemoveField(
|
||||||
|
model_name='video',
|
||||||
|
name='run_time_seconds',
|
||||||
|
),
|
||||||
|
migrations.RemoveField(
|
||||||
|
model_name='video',
|
||||||
|
name='run_time_ticks',
|
||||||
|
),
|
||||||
|
migrations.AddField(
|
||||||
|
model_name='video',
|
||||||
|
name='base_run_time_seconds',
|
||||||
|
field=models.IntegerField(blank=True, null=True),
|
||||||
|
),
|
||||||
|
]
|
||||||
@ -0,0 +1,26 @@
|
|||||||
|
# Generated by Django 4.2.19 on 2025-10-30 01:52
|
||||||
|
|
||||||
|
from django.db import migrations, models
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('webpages', '0005_alter_webpage_run_time_seconds'),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.RemoveField(
|
||||||
|
model_name='webpage',
|
||||||
|
name='run_time_seconds',
|
||||||
|
),
|
||||||
|
migrations.RemoveField(
|
||||||
|
model_name='webpage',
|
||||||
|
name='run_time_ticks',
|
||||||
|
),
|
||||||
|
migrations.AddField(
|
||||||
|
model_name='webpage',
|
||||||
|
name='base_run_time_seconds',
|
||||||
|
field=models.IntegerField(blank=True, null=True),
|
||||||
|
),
|
||||||
|
]
|
||||||
Reference in New Issue
Block a user