mirror of
https://gitlab.crans.org/bde/nk20
synced 2025-10-31 23:54:30 +01:00
246 lines
7.3 KiB
Python
246 lines
7.3 KiB
Python
# Copyright (C) 2018-2025 by BDE ENS Paris-Saclay
|
|
# SPDX-License-Identifier: GPL-3.0-or-later
|
|
|
|
from random import shuffle
|
|
|
|
from bootstrap_datepicker_plus.widgets import DateTimePickerInput
|
|
from crispy_forms.helper import FormHelper
|
|
from django import forms
|
|
from django.forms.widgets import NumberInput
|
|
from django.utils.translation import gettext_lazy as _
|
|
from member.models import Club
|
|
from note_kfet.inputs import Autocomplete, AmountInput
|
|
from note_kfet.middlewares import get_current_request
|
|
from permission.backends import PermissionBackend
|
|
|
|
from .models import Food, BasicFood, TransformedFood, QRCode, Dish, Supplement, Order
|
|
|
|
|
|
class QRCodeForms(forms.ModelForm):
|
|
"""
|
|
Form for create QRCode for container
|
|
"""
|
|
def __init__(self, *args, **kwargs):
|
|
super().__init__(*args, **kwargs)
|
|
self.fields['food_container'].queryset = self.fields['food_container'].queryset.filter(
|
|
end_of_life__isnull=True,
|
|
polymorphic_ctype__model='transformedfood',
|
|
).filter(PermissionBackend.filter_queryset(
|
|
get_current_request(),
|
|
TransformedFood,
|
|
"view",
|
|
))
|
|
|
|
class Meta:
|
|
model = QRCode
|
|
fields = ('food_container',)
|
|
|
|
|
|
class BasicFoodForms(forms.ModelForm):
|
|
"""
|
|
Form for add basicfood
|
|
"""
|
|
def __init__(self, *args, **kwargs):
|
|
super().__init__(*args, **kwargs)
|
|
self.fields['name'].widget.attrs.update({"autofocus": "autofocus"})
|
|
self.fields['name'].required = True
|
|
self.fields['owner'].required = True
|
|
|
|
# Some example
|
|
self.fields['name'].widget.attrs.update({"placeholder": _("Pasta METRO 5kg")})
|
|
clubs = list(Club.objects.filter(PermissionBackend.filter_queryset(get_current_request(), Club, "change")).all())
|
|
shuffle(clubs)
|
|
self.fields['owner'].widget.attrs["placeholder"] = ", ".join(club.name for club in clubs[:4]) + ", ..."
|
|
self.fields['order'].widget.attrs["placeholder"] = _("Specific order given to GCKs")
|
|
|
|
class Meta:
|
|
model = BasicFood
|
|
fields = ('name', 'owner', 'date_type', 'expiry_date', 'allergens', 'order',)
|
|
widgets = {
|
|
"owner": Autocomplete(
|
|
model=Club,
|
|
attrs={"api_url": "/api/members/club/"},
|
|
),
|
|
"expiry_date": DateTimePickerInput(),
|
|
}
|
|
|
|
|
|
class TransformedFoodForms(forms.ModelForm):
|
|
"""
|
|
Form for add transformedfood
|
|
"""
|
|
def __init__(self, *args, **kwargs):
|
|
super().__init__(*args, **kwargs)
|
|
self.fields['name'].required = True
|
|
self.fields['owner'].required = True
|
|
|
|
# Some example
|
|
self.fields['name'].widget.attrs.update({"placeholder": _("Lasagna")})
|
|
clubs = list(Club.objects.filter(PermissionBackend.filter_queryset(get_current_request(), Club, "change")).all())
|
|
shuffle(clubs)
|
|
self.fields['owner'].widget.attrs["placeholder"] = ", ".join(club.name for club in clubs[:4]) + ", ..."
|
|
self.fields['order'].widget.attrs["placeholder"] = _("Specific order given to GCKs")
|
|
|
|
class Meta:
|
|
model = TransformedFood
|
|
fields = ('name', 'owner', 'order',)
|
|
widgets = {
|
|
"owner": Autocomplete(
|
|
model=Club,
|
|
attrs={"api_url": "/api/members/club/"},
|
|
),
|
|
}
|
|
|
|
|
|
class BasicFoodUpdateForms(forms.ModelForm):
|
|
"""
|
|
Form for update basicfood object
|
|
"""
|
|
class Meta:
|
|
model = BasicFood
|
|
fields = ('name', 'owner', 'date_type', 'expiry_date', 'end_of_life', 'is_ready', 'order', 'allergens')
|
|
widgets = {
|
|
"owner": Autocomplete(
|
|
model=Club,
|
|
attrs={"api_url": "/api/members/club/"},
|
|
),
|
|
"expiry_date": DateTimePickerInput(),
|
|
}
|
|
|
|
|
|
class TransformedFoodUpdateForms(forms.ModelForm):
|
|
"""
|
|
Form for update transformedfood object
|
|
"""
|
|
def __init__(self, *args, **kwargs):
|
|
super().__init__(*args, **kwargs)
|
|
self.fields['shelf_life'].label = _('Shelf life (in hours)')
|
|
|
|
class Meta:
|
|
model = TransformedFood
|
|
fields = ('name', 'owner', 'end_of_life', 'is_ready', 'order', 'shelf_life')
|
|
widgets = {
|
|
"owner": Autocomplete(
|
|
model=Club,
|
|
attrs={"api_url": "/api/members/club/"},
|
|
),
|
|
"expiry_date": DateTimePickerInput(),
|
|
"shelf_life": NumberInput(),
|
|
}
|
|
|
|
|
|
class AddIngredientForms(forms.ModelForm):
|
|
"""
|
|
Form for add an ingredient
|
|
"""
|
|
fully_used = forms.BooleanField()
|
|
fully_used.initial = True
|
|
fully_used.required = False
|
|
fully_used.label = _("Fully used")
|
|
|
|
def __init__(self, *args, **kwargs):
|
|
super().__init__(*args, **kwargs)
|
|
# TODO find a better way to get pk (be not url scheme dependant)
|
|
pk = get_current_request().path.split('/')[-1]
|
|
self.fields['ingredients'].queryset = self.fields['ingredients'].queryset.filter(
|
|
polymorphic_ctype__model="transformedfood",
|
|
is_ready=False,
|
|
end_of_life='',
|
|
).filter(PermissionBackend.filter_queryset(get_current_request(), Food, "change")).exclude(pk=pk)
|
|
|
|
class Meta:
|
|
model = TransformedFood
|
|
fields = ('ingredients',)
|
|
|
|
|
|
class ManageIngredientsForm(forms.Form):
|
|
"""
|
|
Form to manage ingredient
|
|
"""
|
|
fully_used = forms.BooleanField()
|
|
fully_used.initial = True
|
|
fully_used.required = True
|
|
fully_used.label = _('Fully used')
|
|
|
|
name = forms.CharField()
|
|
name.widget = Autocomplete(
|
|
model=Food,
|
|
resetable=True,
|
|
attrs={"api_url": "/api/food/food",
|
|
"class": "autocomplete"},
|
|
)
|
|
name.label = _('Name')
|
|
|
|
qrcode = forms.IntegerField()
|
|
qrcode.widget = Autocomplete(
|
|
model=QRCode,
|
|
resetable=True,
|
|
attrs={"api_url": "/api/food/qrcode/",
|
|
"name_field": "qr_code_number",
|
|
"class": "autocomplete"},
|
|
)
|
|
qrcode.label = _('QR code number')
|
|
|
|
|
|
ManageIngredientsFormSet = forms.formset_factory(
|
|
ManageIngredientsForm,
|
|
extra=1,
|
|
)
|
|
|
|
|
|
class DishForm(forms.ModelForm):
|
|
"""
|
|
Form to create a dish
|
|
"""
|
|
class Meta:
|
|
model = Dish
|
|
fields = ('main', 'price', 'available')
|
|
widgets = {
|
|
"price": AmountInput(),
|
|
}
|
|
|
|
|
|
class SupplementForm(forms.ModelForm):
|
|
"""
|
|
Form to create a dish
|
|
"""
|
|
class Meta:
|
|
model = Supplement
|
|
fields = '__all__'
|
|
widgets = {
|
|
"price": AmountInput(),
|
|
}
|
|
|
|
|
|
# The 2 following classes are copied from treasury app
|
|
# Add a subform per supplement in the dish form, and manage correctly the link between the dish and
|
|
# its supplements. The FormSet will search automatically the ForeignKey in the Supplement model.
|
|
SupplementFormSet = forms.inlineformset_factory(
|
|
Dish,
|
|
Supplement,
|
|
form=SupplementForm,
|
|
extra=0,
|
|
)
|
|
|
|
|
|
class SupplementFormSetHelper(FormHelper):
|
|
"""
|
|
Specify some template information for the supplement form
|
|
"""
|
|
|
|
def __init__(self, form=None):
|
|
super().__init__(form)
|
|
self.form_tag = False
|
|
self.form_method = 'POST'
|
|
self.form_class = 'form-inline'
|
|
self.template = 'bootstrap4/table_inline_formset.html'
|
|
|
|
|
|
class OrderForm(forms.ModelForm):
|
|
"""
|
|
Form to order food
|
|
"""
|
|
class Meta:
|
|
model = Order
|
|
exclude = ("activity", "number", "ordered_at", "served", "served_at")
|