--- /dev/null
+# -*- coding: utf-8 -*-
+# Generated by Django 1.11.29 on 2020-11-22 20:05
+from __future__ import unicode_literals
+
+from django.db import migrations, models
+
+
+class Migration(migrations.Migration):
+
+ dependencies = [
+ ('panikombo', '0019_soundscell_sound_format'),
+ ]
+
+ operations = [
+ migrations.AddField(
+ model_name='soundscell',
+ name='maximal_duration',
+ field=models.PositiveIntegerField(blank=True, default=None, null=True, verbose_name='Maximal duration (in minutes)'),
+ ),
+ migrations.AddField(
+ model_name='soundscell',
+ name='minimal_duration',
+ field=models.PositiveIntegerField(blank=True, default=None, null=True, verbose_name='Minimal duration (in minutes)'),
+ ),
+ ]
limit_to_focus = models.BooleanField(_('Limit to focused elements'), default=False)
sound_format = models.ForeignKey('emissions.Format',
verbose_name=_('Limit to format'), null=True, blank=True)
+ minimal_duration = models.PositiveIntegerField(
+ _('Minimal duration (in minutes)'),
+ default=None, blank=True, null=True)
+ maximal_duration = models.PositiveIntegerField(
+ _('Maximal duration (in minutes)'),
+ default=None, blank=True, null=True)
count = models.PositiveSmallIntegerField(_('Count'), default=20)
sort_order = models.CharField(_('Sort order'), default='-creation_timestamp',
max_length=30,
soundfiles = soundfiles.filter(got_focus__isnull=False)
if self.sound_format:
soundfiles = soundfiles.filter(format_id=self.sound_format_id)
+ if self.minimal_duration:
+ soundfiles = soundfiles.filter(duration__gte=self.minimal_duration * 60)
+ if self.maximal_duration:
+ soundfiles = soundfiles.filter(duration__lte=self.maximal_duration * 60)
soundfiles = soundfiles.select_related().extra(
select={'first_diffusion': 'emissions_diffusion.datetime', },
select_params=(False, True),