manager: configure partial bookings agenda (#78056)

This commit is contained in:
Valentin Deniaud 2023-05-31 10:16:46 +02:00
parent 640466742c
commit 21c0d0da1f
3 changed files with 86 additions and 0 deletions

View File

@ -79,10 +79,21 @@ class AgendaAddForm(forms.ModelForm):
edit_role = forms.ModelChoiceField(label=_('Edit Role'), required=False, queryset=get_role_queryset())
view_role = forms.ModelChoiceField(label=_('View Role'), required=False, queryset=get_role_queryset())
def __init__(self, *args, **kwargs):
super().__init__(*args, **kwargs)
if settings.PARTIAL_BOOKINGS_ENABLED:
self.fields['kind'].choices += [('partial-bookings', _('Partial bookings'))]
class Meta:
model = Agenda
fields = ['label', 'kind', 'category', 'edit_role', 'view_role']
def clean(self):
super().clean()
if self.cleaned_data.get('kind') == 'partial-bookings':
self.cleaned_data['kind'] = 'events'
self.instance.partial_bookings = True
def save(self, *args, **kwargs):
create = self.instance.pk is None
super().save()
@ -187,6 +198,7 @@ class NewEventForm(forms.ModelForm):
fields = [
'label',
'start_datetime',
'end_time',
'frequency',
'recurrence_days',
'recurrence_week_interval',
@ -199,14 +211,26 @@ class NewEventForm(forms.ModelForm):
}
widgets = {
'recurrence_end_date': forms.DateInput(attrs={'type': 'date'}, format='%Y-%m-%d'),
'end_time': widgets.TimeWidget,
}
def __init__(self, *args, **kwargs):
super().__init__(*args, **kwargs)
if self.instance.agenda.partial_bookings:
del self.fields['duration']
else:
del self.fields['end_time']
def clean(self):
super().clean()
if self.cleaned_data.get('frequency') == 'unique':
self.cleaned_data['recurrence_days'] = None
self.cleaned_data['recurrence_end_date'] = None
end_time = self.cleaned_data.get('end_time')
if end_time and self.cleaned_data['start_datetime'].time() > end_time:
self.add_error('end_time', _('End time must be greater than start time.'))
def clean_start_datetime(self):
start_datetime = self.cleaned_data['start_datetime']
if start_datetime.year < 2000:
@ -242,6 +266,7 @@ class EventForm(NewEventForm):
protected_fields = (
'slug',
'start_datetime',
'end_time',
'frequency',
'recurrence_days',
'recurrence_week_interval',
@ -251,11 +276,13 @@ class EventForm(NewEventForm):
model = Event
widgets = {
'recurrence_end_date': forms.DateInput(attrs={'type': 'date'}, format='%Y-%m-%d'),
'end_time': widgets.TimeWidget,
}
fields = [
'label',
'slug',
'start_datetime',
'end_time',
'frequency',
'recurrence_days',
'recurrence_week_interval',
@ -284,6 +311,8 @@ class EventForm(NewEventForm):
)
if self.instance.recurrence_days and self.instance.has_recurrences_booked():
for field in self.protected_fields:
if field not in self.fields:
continue
self.fields[field].disabled = True
self.fields[field].help_text = _(
'This field cannot be modified because some recurrences have bookings attached to them.'

View File

@ -199,6 +199,7 @@ REST_FRAMEWORK = {'EXCEPTION_HANDLER': 'chrono.api.utils.exception_handler'}
SHARED_CUSTODY_ENABLED = False
LEGACY_FILLSLOTS_ENABLED = False
PARTIAL_BOOKINGS_ENABLED = False
local_settings_file = os.environ.get(
'CHRONO_SETTINGS_FILE', os.path.join(os.path.dirname(__file__), 'local_settings.py')

View File

@ -0,0 +1,56 @@
import datetime
import pytest
from chrono.agendas.models import Agenda, Booking, Event
from tests.utils import login
pytestmark = pytest.mark.django_db
def test_manager_partial_bookings_add_agenda(app, admin_user, settings):
app = login(app)
resp = app.get('/manage/agendas/add/')
assert 'partial-bookings' not in resp.text
settings.PARTIAL_BOOKINGS_ENABLED = True
resp = app.get('/manage/agendas/add/')
resp.form['label'] = 'Foo bar'
resp.form['kind'] = 'partial-bookings'
resp = resp.form.submit().follow()
agenda = Agenda.objects.get(label='Foo bar')
assert agenda.kind == 'events'
assert agenda.partial_bookings is True
def test_manager_partial_bookings_add_event(app, admin_user):
agenda = Agenda.objects.create(label='Foo bar', kind='events', partial_bookings=True)
app = login(app)
resp = app.get('/manage/agendas/%s/settings' % agenda.pk)
resp = resp.click('New Event')
assert 'duration' not in resp.form.fields
resp.form['start_datetime_0'] = '2023-02-15'
resp.form['start_datetime_1'] = '08:00'
resp.form['end_time'] = '18:00'
resp.form['places'] = 10
resp = resp.form.submit().follow()
event = Event.objects.get()
assert event.end_time == datetime.time(18, 00)
assert event.duration is None
resp = app.get('/manage/agendas/%s/events/%s/edit' % (agenda.pk, event.pk))
assert 'duration' not in resp.form.fields
assert resp.form['end_time'].value == '18:00'
resp.form['end_time'] = '08:01'
resp = resp.form.submit().follow()
resp = app.get('/manage/agendas/%s/events/%s/edit' % (agenda.pk, event.pk))
resp.form['end_time'] = '07:59'
resp = resp.form.submit()
assert 'End time must be greater than start time.' in resp.text