2
0
mirror of https://github.com/frappe/books.git synced 2025-01-05 08:02:15 +00:00

feat: added keyboard shortcuts in POS

This commit is contained in:
AbleKSaju 2024-12-03 14:46:26 +05:30
parent ce1831502c
commit 7b019f294c

View File

@ -104,14 +104,15 @@ import ModernPOS from './ModernPOS.vue';
import ClassicPOS from './ClassicPOS.vue'; import ClassicPOS from './ClassicPOS.vue';
import { ModelNameEnum } from 'models/types'; import { ModelNameEnum } from 'models/types';
import Button from 'src/components/Button.vue'; import Button from 'src/components/Button.vue';
import { computed, defineComponent } from 'vue';
import { showToast } from 'src/utils/interactive'; import { showToast } from 'src/utils/interactive';
import { Item } from 'models/baseModels/Item/Item'; import { Item } from 'models/baseModels/Item/Item';
import { ModalName } from 'src/components/POS/types';
import { Shipment } from 'models/inventory/Shipment'; import { Shipment } from 'models/inventory/Shipment';
import { routeTo, toggleSidebar } from 'src/utils/ui'; import { routeTo, toggleSidebar } from 'src/utils/ui';
import { shortcutsKey } from 'src/utils/injectionKeys';
import PageHeader from 'src/components/PageHeader.vue'; import PageHeader from 'src/components/PageHeader.vue';
import { computed, defineComponent, inject } from 'vue';
import { Payment } from 'models/baseModels/Payment/Payment'; import { Payment } from 'models/baseModels/Payment/Payment';
import { ModalName, modalNames } from 'src/components/POS/types';
import { InvoiceItem } from 'models/baseModels/InvoiceItem/InvoiceItem'; import { InvoiceItem } from 'models/baseModels/InvoiceItem/InvoiceItem';
import { SalesInvoice } from 'models/baseModels/SalesInvoice/SalesInvoice'; import { SalesInvoice } from 'models/baseModels/SalesInvoice/SalesInvoice';
import { SalesInvoiceItem } from 'models/baseModels/SalesInvoiceItem/SalesInvoiceItem'; import { SalesInvoiceItem } from 'models/baseModels/SalesInvoiceItem/SalesInvoiceItem';
@ -138,6 +139,8 @@ import {
ItemSerialNumbers, ItemSerialNumbers,
} from 'src/components/POS/types'; } from 'src/components/POS/types';
const COMPONENT_NAME = 'POS';
export default defineComponent({ export default defineComponent({
name: 'POS', name: 'POS',
components: { components: {
@ -163,6 +166,11 @@ export default defineComponent({
transferClearanceDate: computed(() => this.transferClearanceDate), transferClearanceDate: computed(() => this.transferClearanceDate),
}; };
}, },
setup() {
return {
shortcuts: inject(shortcutsKey),
};
},
data() { data() {
return { return {
tableView: true, tableView: true,
@ -242,10 +250,13 @@ export default defineComponent({
this.setCouponCodeDoc(); this.setCouponCodeDoc();
this.setSinvDoc(); this.setSinvDoc();
this.setDefaultCustomer(); this.setDefaultCustomer();
this.setShortcuts();
await this.setItemQtyMap(); await this.setItemQtyMap();
await this.setItems(); await this.setItems();
}, },
deactivated() { deactivated() {
this.shortcuts?.delete(COMPONENT_NAME);
toggleSidebar(true); toggleSidebar(true);
}, },
methods: { methods: {
@ -265,6 +276,71 @@ export default defineComponent({
this.loyaltyProgram = party[0]?.loyaltyProgram as string; this.loyaltyProgram = party[0]?.loyaltyProgram as string;
this.loyaltyPoints = party[0]?.loyaltyPoints as number; this.loyaltyPoints = party[0]?.loyaltyPoints as number;
}, },
setShortcuts() {
this.shortcuts?.shift.set(COMPONENT_NAME, ['KeyS'], async () => {
this.routeToSinvList();
});
this.shortcuts?.shift.set(COMPONENT_NAME, ['KeyV'], async () => {
this.toggleView();
});
this.shortcuts?.shift.set(COMPONENT_NAME, ['KeyP'], async () => {
this.toggleModal('PriceList');
});
this.shortcuts?.pmodShift.set(COMPONENT_NAME, ['KeyH'], async () => {
this.toggleModal('SavedInvoice');
});
this.shortcuts?.pmodShift.set(COMPONENT_NAME, ['Backspace'], async () => {
let anyModalClosed = false;
modalNames.forEach((modal: ModalName) => {
if (modal && this[`open${modal}Modal`]) {
this[`open${modal}Modal`] = false;
anyModalClosed = true;
}
});
if (!anyModalClosed) {
this.clearValues();
}
});
this.shortcuts?.pmodShift.set(COMPONENT_NAME, ['KeyP'], async () => {
if (!this.disablePayButton) {
this.toggleModal('Payment');
}
});
this.shortcuts?.pmodShift.set(COMPONENT_NAME, ['KeyS'], async () => {
if (this.sinvDoc.party && this.sinvDoc.items?.length) {
this.saveOrder();
}
});
this.shortcuts?.shift.set(COMPONENT_NAME, ['KeyL'], async () => {
if (
this.fyo.singles.AccountingSettings?.enablePriceList &&
this.loyaltyPoints &&
this.sinvDoc.party &&
this.sinvDoc.items?.length
) {
this.toggleModal('LoyaltyProgram', true);
}
});
this.shortcuts?.shift.set(COMPONENT_NAME, ['KeyC'], async () => {
if (
this.fyo.singles.AccountingSettings?.enableCouponCode &&
this.sinvDoc?.party &&
this.sinvDoc?.items?.length
) {
this.toggleModal('CouponCode');
}
});
},
async saveOrder() { async saveOrder() {
try { try {
await this.validate(); await this.validate();
@ -482,6 +558,7 @@ export default defineComponent({
await this.applyPricingRule(); await this.applyPricingRule();
await this.sinvDoc.runFormulas(); await this.sinvDoc.runFormulas();
}, },
async createTransaction(shouldPrint = false) { async createTransaction(shouldPrint = false) {
try { try {
await this.validate(); await this.validate();
@ -640,9 +717,10 @@ export default defineComponent({
if (!hasPricingRules || !hasPricingRules.length) { if (!hasPricingRules || !hasPricingRules.length) {
this.sinvDoc.pricingRuleDetail = undefined; this.sinvDoc.pricingRuleDetail = undefined;
this.sinvDoc.isPricingRuleApplied = false; this.sinvDoc.isPricingRuleApplied = false;
removeFreeItems(this.sinvDoc as SalesInvoice);
removeFreeItems(this.sinvDoc as SalesInvoice);
await this.sinvDoc.applyProductDiscount(); await this.sinvDoc.applyProductDiscount();
return; return;
} }