From 627924d9af05da354307c258c52bdb0103e59a26 Mon Sep 17 00:00:00 2001 From: AbleKSaju <126228406+AbleKSaju@users.noreply.github.com> Date: Thu, 26 Dec 2024 15:10:24 +0530 Subject: [PATCH 01/12] upd: update POSSettings schema --- schemas/app/Item.json | 7 +++++ .../inventory/Point of Sale/POSSettings.json | 28 +++++++++++++++++++ 2 files changed, 35 insertions(+) diff --git a/schemas/app/Item.json b/schemas/app/Item.json index b3abae23..2f26e880 100644 --- a/schemas/app/Item.json +++ b/schemas/app/Item.json @@ -117,6 +117,13 @@ "placeholder": "HSN/SAC Code", "section": "Inventory" }, + { + "fieldname": "weightBarcode", + "label": "Weight Barcode", + "fieldtype": "Data", + "placeholder": "Weight Barcode", + "section": "Inventory" + }, { "fieldname": "barcode", "label": "Barcode", diff --git a/schemas/app/inventory/Point of Sale/POSSettings.json b/schemas/app/inventory/Point of Sale/POSSettings.json index 5f8d12d5..4899871c 100644 --- a/schemas/app/inventory/Point of Sale/POSSettings.json +++ b/schemas/app/inventory/Point of Sale/POSSettings.json @@ -56,6 +56,34 @@ "default": "Classic", "required": true, "section": "Default" + }, + { + "fieldname": "weightEnabledBarcode", + "label": "Weigth Enabled Barcode", + "fieldtype": "Check", + "default": false, + "section": "Barcode" + }, + { + "fieldname": "randomNumberLength", + "label": "Random Number Length", + "fieldtype": "Int", + "default": 0, + "section": "Barcode" + }, + { + "fieldname": "ItemBarcodeLength", + "label": "Item Barcode Length", + "fieldtype": "Int", + "default": 0, + "section": "Barcode" + }, + { + "fieldname": "quantityBarcodeLength", + "label": "Quantity Barcode Length", + "fieldtype": "Int", + "default": 0, + "section": "Barcode" } ] } From 364173101b1cc144f0f27f9b82250efe9d6e37c9 Mon Sep 17 00:00:00 2001 From: AbleKSaju <126228406+AbleKSaju@users.noreply.github.com> Date: Thu, 26 Dec 2024 15:12:15 +0530 Subject: [PATCH 02/12] feat: hide weight enabled barcode --- models/inventory/Point of Sale/POSSettings.ts | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/models/inventory/Point of Sale/POSSettings.ts b/models/inventory/Point of Sale/POSSettings.ts index 9f8f615a..07e01682 100644 --- a/models/inventory/Point of Sale/POSSettings.ts +++ b/models/inventory/Point of Sale/POSSettings.ts @@ -1,5 +1,5 @@ import { Doc } from 'fyo/model/doc'; -import { FiltersMap } from 'fyo/model/types'; +import { FiltersMap, HiddenMap } from 'fyo/model/types'; import { AccountRootTypeEnum, AccountTypeEnum, @@ -10,6 +10,8 @@ export class POSSettings extends Doc { inventory?: string; cashAccount?: string; writeOffAccount?: string; + weightEnabledBarcode?: boolean; + posUI?: 'Classic' | 'Modern'; static filters: FiltersMap = { @@ -19,4 +21,9 @@ export class POSSettings extends Doc { isGroup: false, }), }; + + hidden: HiddenMap = { + weightEnabledBarcode: () => + !this.fyo.singles.InventorySettings?.enableBarcodes, + }; } From 896b16e08ed9bb5110d3264d70fc2f7719a9ac81 Mon Sep 17 00:00:00 2001 From: AbleKSaju <126228406+AbleKSaju@users.noreply.github.com> Date: Thu, 26 Dec 2024 15:17:49 +0530 Subject: [PATCH 03/12] feat: WeightEnabledBarcode in POS --- .../Controls/weightEnabledBarcode.vue | 198 ++++++++++++++++++ src/pages/POS/ClassicPOS.vue | 19 +- src/pages/POS/ModernPOS.vue | 19 +- 3 files changed, 232 insertions(+), 4 deletions(-) create mode 100644 src/components/Controls/weightEnabledBarcode.vue diff --git a/src/components/Controls/weightEnabledBarcode.vue b/src/components/Controls/weightEnabledBarcode.vue new file mode 100644 index 00000000..cab28f10 --- /dev/null +++ b/src/components/Controls/weightEnabledBarcode.vue @@ -0,0 +1,198 @@ + + + diff --git a/src/pages/POS/ClassicPOS.vue b/src/pages/POS/ClassicPOS.vue index 88e27c9f..a2617bba 100644 --- a/src/pages/POS/ClassicPOS.vue +++ b/src/pages/POS/ClassicPOS.vue @@ -98,7 +98,10 @@ /> + + + + Date: Thu, 26 Dec 2024 15:18:03 +0530 Subject: [PATCH 04/12] feat: update item quantity matching the barcode --- src/pages/POS/POS.vue | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/src/pages/POS/POS.vue b/src/pages/POS/POS.vue index 8987f3e9..a6e04c95 100644 --- a/src/pages/POS/POS.vue +++ b/src/pages/POS/POS.vue @@ -477,7 +477,7 @@ export default defineComponent({ this.transferRefNo = ref; }, - async addItem(item: POSItem | Item | undefined) { + async addItem(item: POSItem | Item | undefined, quantity?: number) { await this.sinvDoc.runFormulas(); if (!item) { @@ -500,7 +500,9 @@ export default defineComponent({ ] ?? 0; if (itemQty < qtyInBatch) { - invItem.quantity = (invItem.quantity as number) + 1; + invItem.quantity = quantity + ? (invItem.quantity as number) + quantity + : (invItem.quantity as number) + 1; invItem.rate = item.rate as Money; await this.applyPricingRule(); @@ -528,7 +530,9 @@ export default defineComponent({ existingItems[0].rate = item.rate as Money; } - existingItems[0].quantity = (existingItems[0].quantity as number) + 1; + existingItems[0].quantity = quantity + ? (existingItems[0].quantity as number) + quantity + : (existingItems[0].quantity as number) + 1; await this.applyPricingRule(); await this.sinvDoc.runFormulas(); @@ -550,6 +554,7 @@ export default defineComponent({ await this.sinvDoc.append('items', { rate: item.rate as Money, item: item.name, + quantity: quantity ? quantity : 0, }); if (this.sinvDoc.priceList) { From 1ea6867e1f3d7b8cd50e87d55ae580383c05ff5b Mon Sep 17 00:00:00 2001 From: AbleKSaju <126228406+AbleKSaju@users.noreply.github.com> Date: Thu, 26 Dec 2024 18:51:51 +0530 Subject: [PATCH 05/12] upd: POSSettings schema --- schemas/app/inventory/Point of Sale/POSSettings.json | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/schemas/app/inventory/Point of Sale/POSSettings.json b/schemas/app/inventory/Point of Sale/POSSettings.json index 4899871c..e23e2a2c 100644 --- a/schemas/app/inventory/Point of Sale/POSSettings.json +++ b/schemas/app/inventory/Point of Sale/POSSettings.json @@ -65,22 +65,22 @@ "section": "Barcode" }, { - "fieldname": "randomNumberLength", - "label": "Random Number Length", + "fieldname": "checkDigit", + "label": "Check Digit", "fieldtype": "Int", "default": 0, "section": "Barcode" }, { - "fieldname": "ItemBarcodeLength", - "label": "Item Barcode Length", + "fieldname": "itemCodeDigits", + "label": "Item Code Digits", "fieldtype": "Int", "default": 0, "section": "Barcode" }, { - "fieldname": "quantityBarcodeLength", - "label": "Quantity Barcode Length", + "fieldname": "itemWeight", + "label": "item Weight", "fieldtype": "Int", "default": 0, "section": "Barcode" From 0eda30623c4732b6f4509752ba80e53678dbdc03 Mon Sep 17 00:00:00 2001 From: AbleKSaju <126228406+AbleKSaju@users.noreply.github.com> Date: Thu, 26 Dec 2024 18:54:19 +0530 Subject: [PATCH 06/12] fix: refactored --- models/inventory/Point of Sale/POSSettings.ts | 6 +++++ .../Controls/weightEnabledBarcode.vue | 23 ++++++++----------- 2 files changed, 15 insertions(+), 14 deletions(-) diff --git a/models/inventory/Point of Sale/POSSettings.ts b/models/inventory/Point of Sale/POSSettings.ts index 07e01682..279b342f 100644 --- a/models/inventory/Point of Sale/POSSettings.ts +++ b/models/inventory/Point of Sale/POSSettings.ts @@ -11,6 +11,9 @@ export class POSSettings extends Doc { cashAccount?: string; writeOffAccount?: string; weightEnabledBarcode?: boolean; + checkDigit?: number; + itemCodeDigits?: number; + itemWeight?: number; posUI?: 'Classic' | 'Modern'; @@ -25,5 +28,8 @@ export class POSSettings extends Doc { hidden: HiddenMap = { weightEnabledBarcode: () => !this.fyo.singles.InventorySettings?.enableBarcodes, + checkDigit: () => !this.fyo.singles.InventorySettings?.enableBarcodes, + itemCodeDigits: () => !this.fyo.singles.InventorySettings?.enableBarcodes, + itemWeight: () => !this.fyo.singles.InventorySettings?.enableBarcodes, }; } diff --git a/src/components/Controls/weightEnabledBarcode.vue b/src/components/Controls/weightEnabledBarcode.vue index cab28f10..4388006e 100644 --- a/src/components/Controls/weightEnabledBarcode.vue +++ b/src/components/Controls/weightEnabledBarcode.vue @@ -73,25 +73,20 @@ export default defineComponent({ const isWeightEnabled = this.fyo.singles.POSSettings?.weightEnabledBarcode; - const randomNumberLength = this.fyo.singles.POSSettings - ?.randomNumberLength as number; - const ItemBarcodeLength = this.fyo.singles.POSSettings - ?.ItemBarcodeLength as number; - const quantityBarcodeLength = this.fyo.singles.POSSettings - ?.quantityBarcodeLength as number; + const checkDigit = this.fyo.singles.POSSettings?.checkDigit as number; + const itemCodeDigits = this.fyo.singles.POSSettings + ?.itemCodeDigits as number; + const itemWeight = this.fyo.singles.POSSettings?.itemWeight as number; - if ( - code.length !== - randomNumberLength + ItemBarcodeLength + quantityBarcodeLength - ) { + if (code.length !== checkDigit + itemCodeDigits + itemWeight) { return this.error(this.t`Barcode ${barcode} has an invalid length.`); } const filters: Record = isWeightEnabled ? { weightBarcode: barcode.slice( - randomNumberLength, - randomNumberLength + ItemBarcodeLength + checkDigit, + checkDigit + itemCodeDigits ), } : { barcode }; @@ -109,7 +104,7 @@ export default defineComponent({ ? this.parseBarcode( barcode, unit as string, - randomNumberLength + ItemBarcodeLength + checkDigit + itemCodeDigits ) : 1; @@ -118,7 +113,7 @@ export default defineComponent({ }, parseBarcode(barcode: string, unitType: string, sliceDigit: number) { - const weightRaw = parseInt(barcode.slice(sliceDigit), sliceDigit); + const weightRaw = parseInt(barcode.slice(sliceDigit)); let itemQuantity = 0; From 6d0300ac1a3217a670539a0236c9adb6982ae4f5 Mon Sep 17 00:00:00 2001 From: AbleKSaju <126228406+AbleKSaju@users.noreply.github.com> Date: Tue, 31 Dec 2024 15:43:19 +0530 Subject: [PATCH 07/12] fix: change barcode text color to white in dark mode --- src/components/Controls/Barcode.vue | 7 ++++++- src/components/Controls/weightEnabledBarcode.vue | 10 +++++----- 2 files changed, 11 insertions(+), 6 deletions(-) diff --git a/src/components/Controls/Barcode.vue b/src/components/Controls/Barcode.vue index ac38f640..4dfd06ab 100644 --- a/src/components/Controls/Barcode.vue +++ b/src/components/Controls/Barcode.vue @@ -8,7 +8,10 @@ border rounded bg-gray-50 - dark:border-gray-800 dark:bg-gray-890 dark:focus-within:bg-gray-900 + dark:text-gray-200 + dark:border-gray-800 + dark:bg-gray-890 + dark:focus-within:bg-gray-900 focus-within:bg-gray-100 " > @@ -84,6 +87,8 @@ export default defineComponent({ })) as { name: string }[]; const name = items?.[0]?.name; + console.log(name, 'name'); + if (!name) { return this.error(this.t`Item with barcode ${barcode} not found.`); } diff --git a/src/components/Controls/weightEnabledBarcode.vue b/src/components/Controls/weightEnabledBarcode.vue index 4388006e..f55cdcd8 100644 --- a/src/components/Controls/weightEnabledBarcode.vue +++ b/src/components/Controls/weightEnabledBarcode.vue @@ -8,7 +8,10 @@ border rounded bg-gray-50 - dark:border-gray-800 dark:bg-gray-890 dark:focus-within:bg-gray-900 + dark:text-gray-200 + dark:border-gray-800 + dark:bg-gray-890 + dark:focus-within:bg-gray-900 focus-within:bg-gray-100 " > @@ -84,10 +87,7 @@ export default defineComponent({ const filters: Record = isWeightEnabled ? { - weightBarcode: barcode.slice( - checkDigit, - checkDigit + itemCodeDigits - ), + barcode: barcode.slice(checkDigit, checkDigit + itemCodeDigits), } : { barcode }; const fields = isWeightEnabled ? ['name', 'unit'] : ['name']; From 59ba64b34154de9e9de01b1046dad0c9566a6208 Mon Sep 17 00:00:00 2001 From: AbleKSaju <126228406+AbleKSaju@users.noreply.github.com> Date: Tue, 31 Dec 2024 15:45:42 +0530 Subject: [PATCH 08/12] fix: set default quantity increment to 1 for barcode --- src/components/Controls/Barcode.vue | 1 - src/pages/POS/POS.vue | 2 +- 2 files changed, 1 insertion(+), 2 deletions(-) diff --git a/src/components/Controls/Barcode.vue b/src/components/Controls/Barcode.vue index 4dfd06ab..fc2e0ff4 100644 --- a/src/components/Controls/Barcode.vue +++ b/src/components/Controls/Barcode.vue @@ -87,7 +87,6 @@ export default defineComponent({ })) as { name: string }[]; const name = items?.[0]?.name; - console.log(name, 'name'); if (!name) { return this.error(this.t`Item with barcode ${barcode} not found.`); diff --git a/src/pages/POS/POS.vue b/src/pages/POS/POS.vue index a6e04c95..6bd2c8eb 100644 --- a/src/pages/POS/POS.vue +++ b/src/pages/POS/POS.vue @@ -554,7 +554,7 @@ export default defineComponent({ await this.sinvDoc.append('items', { rate: item.rate as Money, item: item.name, - quantity: quantity ? quantity : 0, + quantity: quantity ? quantity : 1, }); if (this.sinvDoc.priceList) { From 618457fcfc03c98a858b4cd5db5440fcbed70443 Mon Sep 17 00:00:00 2001 From: AbleKSaju <126228406+AbleKSaju@users.noreply.github.com> Date: Tue, 31 Dec 2024 15:47:06 +0530 Subject: [PATCH 09/12] chore: removed WeightBarcode field; using default Barcode field instead --- schemas/app/Item.json | 7 ------- 1 file changed, 7 deletions(-) diff --git a/schemas/app/Item.json b/schemas/app/Item.json index 2f26e880..b3abae23 100644 --- a/schemas/app/Item.json +++ b/schemas/app/Item.json @@ -117,13 +117,6 @@ "placeholder": "HSN/SAC Code", "section": "Inventory" }, - { - "fieldname": "weightBarcode", - "label": "Weight Barcode", - "fieldtype": "Data", - "placeholder": "Weight Barcode", - "section": "Inventory" - }, { "fieldname": "barcode", "label": "Barcode", From cd45653c911129bc0f9263a70fd24816ef13bb6a Mon Sep 17 00:00:00 2001 From: AbleKSaju <126228406+AbleKSaju@users.noreply.github.com> Date: Thu, 2 Jan 2025 12:02:16 +0530 Subject: [PATCH 10/12] fix: renamed filename & label from itemWeight to itemWeightDigits --- models/inventory/Point of Sale/POSSettings.ts | 8 ++++---- schemas/app/inventory/Point of Sale/POSSettings.json | 8 ++++---- src/components/Controls/weightEnabledBarcode.vue | 11 ++++++----- 3 files changed, 14 insertions(+), 13 deletions(-) diff --git a/models/inventory/Point of Sale/POSSettings.ts b/models/inventory/Point of Sale/POSSettings.ts index 279b342f..79b0b511 100644 --- a/models/inventory/Point of Sale/POSSettings.ts +++ b/models/inventory/Point of Sale/POSSettings.ts @@ -11,9 +11,9 @@ export class POSSettings extends Doc { cashAccount?: string; writeOffAccount?: string; weightEnabledBarcode?: boolean; - checkDigit?: number; + checkDigits?: number; itemCodeDigits?: number; - itemWeight?: number; + itemWeightDigits?: number; posUI?: 'Classic' | 'Modern'; @@ -28,8 +28,8 @@ export class POSSettings extends Doc { hidden: HiddenMap = { weightEnabledBarcode: () => !this.fyo.singles.InventorySettings?.enableBarcodes, - checkDigit: () => !this.fyo.singles.InventorySettings?.enableBarcodes, + checkDigits: () => !this.fyo.singles.InventorySettings?.enableBarcodes, itemCodeDigits: () => !this.fyo.singles.InventorySettings?.enableBarcodes, - itemWeight: () => !this.fyo.singles.InventorySettings?.enableBarcodes, + itemWeightDigits: () => !this.fyo.singles.InventorySettings?.enableBarcodes, }; } diff --git a/schemas/app/inventory/Point of Sale/POSSettings.json b/schemas/app/inventory/Point of Sale/POSSettings.json index e23e2a2c..18caa52e 100644 --- a/schemas/app/inventory/Point of Sale/POSSettings.json +++ b/schemas/app/inventory/Point of Sale/POSSettings.json @@ -65,8 +65,8 @@ "section": "Barcode" }, { - "fieldname": "checkDigit", - "label": "Check Digit", + "fieldname": "checkDigits", + "label": "Check Digits", "fieldtype": "Int", "default": 0, "section": "Barcode" @@ -79,8 +79,8 @@ "section": "Barcode" }, { - "fieldname": "itemWeight", - "label": "item Weight", + "fieldname": "itemWeightDigits", + "label": "item Weight Digits", "fieldtype": "Int", "default": 0, "section": "Barcode" diff --git a/src/components/Controls/weightEnabledBarcode.vue b/src/components/Controls/weightEnabledBarcode.vue index f55cdcd8..19d56638 100644 --- a/src/components/Controls/weightEnabledBarcode.vue +++ b/src/components/Controls/weightEnabledBarcode.vue @@ -76,18 +76,19 @@ export default defineComponent({ const isWeightEnabled = this.fyo.singles.POSSettings?.weightEnabledBarcode; - const checkDigit = this.fyo.singles.POSSettings?.checkDigit as number; + const checkDigits = this.fyo.singles.POSSettings?.checkDigits as number; const itemCodeDigits = this.fyo.singles.POSSettings ?.itemCodeDigits as number; - const itemWeight = this.fyo.singles.POSSettings?.itemWeight as number; + const itemWeightDigits = this.fyo.singles.POSSettings + ?.itemWeightDigits as number; - if (code.length !== checkDigit + itemCodeDigits + itemWeight) { + if (code.length !== checkDigits + itemCodeDigits + itemWeightDigits) { return this.error(this.t`Barcode ${barcode} has an invalid length.`); } const filters: Record = isWeightEnabled ? { - barcode: barcode.slice(checkDigit, checkDigit + itemCodeDigits), + barcode: barcode.slice(checkDigits, checkDigits + itemCodeDigits), } : { barcode }; const fields = isWeightEnabled ? ['name', 'unit'] : ['name']; @@ -104,7 +105,7 @@ export default defineComponent({ ? this.parseBarcode( barcode, unit as string, - checkDigit + itemCodeDigits + checkDigits + itemCodeDigits ) : 1; From a07376b4602a14b6b7d8ca588059b6dc34d7410b Mon Sep 17 00:00:00 2001 From: akshayitzme Date: Thu, 2 Jan 2025 12:54:45 +0530 Subject: [PATCH 11/12] chore: rename component --- .../{weightEnabledBarcode.vue => WeightEnabledBarcode.vue} | 1 + src/pages/POS/ClassicPOS.vue | 2 +- src/pages/POS/ModernPOS.vue | 2 +- 3 files changed, 3 insertions(+), 2 deletions(-) rename src/components/Controls/{weightEnabledBarcode.vue => WeightEnabledBarcode.vue} (99%) diff --git a/src/components/Controls/weightEnabledBarcode.vue b/src/components/Controls/WeightEnabledBarcode.vue similarity index 99% rename from src/components/Controls/weightEnabledBarcode.vue rename to src/components/Controls/WeightEnabledBarcode.vue index 19d56638..7ef3a69c 100644 --- a/src/components/Controls/weightEnabledBarcode.vue +++ b/src/components/Controls/WeightEnabledBarcode.vue @@ -34,6 +34,7 @@ import { showToast } from 'src/utils/interactive'; import { defineComponent } from 'vue'; export default defineComponent({ + name: 'WeightEnabledBarcode', emits: ['item-selected'], data() { return { diff --git a/src/pages/POS/ClassicPOS.vue b/src/pages/POS/ClassicPOS.vue index a2617bba..a2ef00a2 100644 --- a/src/pages/POS/ClassicPOS.vue +++ b/src/pages/POS/ClassicPOS.vue @@ -326,7 +326,7 @@ import ItemsTable from 'src/components/POS/Classic/ItemsTable.vue'; import MultiLabelLink from 'src/components/Controls/MultiLabelLink.vue'; import { SalesInvoice } from 'models/baseModels/SalesInvoice/SalesInvoice'; import SelectedItemTable from 'src/components/POS/Classic/SelectedItemTable.vue'; -import WeightEnabledBarcode from 'src/components/Controls/weightEnabledBarcode.vue'; +import WeightEnabledBarcode from 'src/components/Controls/WeightEnabledBarcode.vue'; import FloatingLabelFloatInput from 'src/components/POS/FloatingLabelFloatInput.vue'; import FloatingLabelCurrencyInput from 'src/components/POS/FloatingLabelCurrencyInput.vue'; import { AppliedCouponCodes } from 'models/baseModels/AppliedCouponCodes/AppliedCouponCodes'; diff --git a/src/pages/POS/ModernPOS.vue b/src/pages/POS/ModernPOS.vue index 27af9af7..390be18a 100644 --- a/src/pages/POS/ModernPOS.vue +++ b/src/pages/POS/ModernPOS.vue @@ -334,7 +334,7 @@ import { POSItem, PosEmits, ItemQtyMap } from 'src/components/POS/types'; import { SalesInvoice } from 'models/baseModels/SalesInvoice/SalesInvoice'; import ModernPOSItemsGrid from 'src/components/POS/Modern/ModernPOSItemsGrid.vue'; import ModernPOSItemsTable from 'src/components/POS/Modern/ModernPOSItemsTable.vue'; -import WeightEnabledBarcode from 'src/components/Controls/weightEnabledBarcode.vue'; +import WeightEnabledBarcode from 'src/components/Controls/WeightEnabledBarcode.vue'; import FloatingLabelFloatInput from 'src/components/POS/FloatingLabelFloatInput.vue'; import { SalesInvoiceItem } from 'models/baseModels/SalesInvoiceItem/SalesInvoiceItem'; import FloatingLabelCurrencyInput from 'src/components/POS/FloatingLabelCurrencyInput.vue'; From 26a5e02c517e5c0775a836b2657f30334656b439 Mon Sep 17 00:00:00 2001 From: AbleKSaju <126228406+AbleKSaju@users.noreply.github.com> Date: Thu, 2 Jan 2025 13:06:22 +0530 Subject: [PATCH 12/12] fix: prevent adding items via barcode if not tracked in inventory --- src/components/Controls/WeightEnabledBarcode.vue | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) diff --git a/src/components/Controls/WeightEnabledBarcode.vue b/src/components/Controls/WeightEnabledBarcode.vue index 7ef3a69c..7bde8d46 100644 --- a/src/components/Controls/WeightEnabledBarcode.vue +++ b/src/components/Controls/WeightEnabledBarcode.vue @@ -92,11 +92,19 @@ export default defineComponent({ barcode: barcode.slice(checkDigits, checkDigits + itemCodeDigits), } : { barcode }; - const fields = isWeightEnabled ? ['name', 'unit'] : ['name']; + const fields = isWeightEnabled + ? ['name', 'unit', 'trackItem'] + : ['name', 'trackItem']; const items = (await this.fyo.db.getAll('Item', { filters, fields })) || []; - const { name, unit } = items[0] || {}; + const { name, unit, trackItem } = items[0] || {}; + + if (!trackItem) { + return this.error( + this.t`Item ${name as string} is not an Inventory Item.` + ); + } if (!name) { return this.error(this.t`Item with barcode ${barcode} not found.`);