From 7071553c3b940377c5f247e07bd0d6e1a017fb9a Mon Sep 17 00:00:00 2001 From: Sli Date: Sun, 22 Dec 2024 02:14:14 +0100 Subject: [PATCH] Optimize product id validation on counter click --- counter/views/click.py | 29 +++++++++++++++-------------- 1 file changed, 15 insertions(+), 14 deletions(-) diff --git a/counter/views/click.py b/counter/views/click.py index 38d4ce57..a214e6c4 100644 --- a/counter/views/click.py +++ b/counter/views/click.py @@ -55,7 +55,7 @@ class ProductForm(Form): self, customer: Customer, counter: Counter, - allowed_products: list[Product], + allowed_products: dict[int, Product], *args, **kwargs, ): @@ -64,25 +64,24 @@ class ProductForm(Form): self.allowed_products = allowed_products super().__init__(*args, **kwargs) - def clean(self): - cleaned_data = super().clean() - if len(self.errors) > 0: - return + def clean_id(self): + data = self.cleaned_data["id"] # We store self.product so we can use it later on the formset validation - self.product = next( - ( - product - for product in self.allowed_products - if product.id == cleaned_data["id"] - ), - None, - ) + # And also in the global clean + self.product = self.allowed_products.get(data, None) if self.product is None: raise ValidationError( _("The selected product isn't available for this user") ) + return data + + def clean(self): + cleaned_data = super().clean() + if len(self.errors) > 0: + return + # Compute prices cleaned_data["bonus_quantity"] = 0 if self.product.tray: @@ -183,7 +182,9 @@ class CounterClick(CounterTabsMixin, CanViewMixin, SingleObjectMixin, FormView): kwargs["form_kwargs"] = { "customer": self.customer, "counter": self.object, - "allowed_products": self.get_products(), + "allowed_products": { + product.id: product for product in self.get_products() + }, } return kwargs