From eaf72ad0ed99a732eda093b53c9acc910cb71179 Mon Sep 17 00:00:00 2001 From: Sli Date: Fri, 20 Dec 2024 18:34:27 +0100 Subject: [PATCH] Don't use codes as a primary key in counter click --- .../bundled/counter/counter-click-index.ts | 16 +++++----------- counter/templates/counter/counter_click.jinja | 14 +++++++------- counter/views/click.py | 13 +++++-------- 3 files changed, 17 insertions(+), 26 deletions(-) diff --git a/counter/static/bundled/counter/counter-click-index.ts b/counter/static/bundled/counter/counter-click-index.ts index bd82f6ca..a33dfa25 100644 --- a/counter/static/bundled/counter/counter-click-index.ts +++ b/counter/static/bundled/counter/counter-click-index.ts @@ -11,6 +11,7 @@ interface CounterConfig { } interface Product { + id: string; code: string; name: string; price: number; @@ -56,18 +57,11 @@ exportToHtml("loadCounter", (config: CounterConfig) => { .setAttribute(":value", "getBasketSize()"); }, - getItemIdFromCode(code: string): string { - return Object.keys(config.products).find( - (key) => config.products[key].code === code, - ); + removeFromBasket(id: string) { + delete this.basket[id]; }, - removeFromBasket(code: string) { - delete this.basket[this.getItemIdFromCode(code)]; - }, - - addToBasket(code: string, quantity: number): [boolean, string] { - const id = this.getItemIdFromCode(code); + addToBasket(id: string, quantity: number): [boolean, string] { const item: BasketItem = this.basket[id] || new BasketItem(config.products[id], 0); @@ -126,7 +120,7 @@ exportToHtml("loadCounter", (config: CounterConfig) => { }); }, - handleCode(event: SubmitEvent) { + handleCode() { const [quantity, code] = this.codeField.getSelectedProduct() as [ number, string, diff --git a/counter/templates/counter/counter_click.jinja b/counter/templates/counter/counter_click.jinja index ced83eec..cfc4794f 100644 --- a/counter/templates/counter/counter_click.jinja +++ b/counter/templates/counter/counter_click.jinja @@ -63,7 +63,7 @@ {% for category in categories.keys() %} {% for product in categories[category] %} - + {% endfor %} {% endfor %} @@ -86,17 +86,17 @@ @@ -149,7 +149,7 @@
{{ category }}
{% for product in categories[category] -%} -