mirror of
				https://gitlab.crans.org/bde/nk20
				synced 2025-10-31 15:50:03 +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")
 |