2
0
mirror of https://github.com/frappe/books.git synced 2025-01-10 18:24:40 +00:00

fix: doc shortcuts in non keep alive contexts

- remove readonly on ImportWizard entries
- indicate if Grand Total is 0 on an Invoice.
This commit is contained in:
18alantom 2023-04-24 13:34:02 +05:30 committed by Alan
parent eb2b6f4727
commit 7b85277fb1
3 changed files with 59 additions and 16 deletions

View File

@ -191,6 +191,7 @@
:rows="1" :rows="1"
:border="true" :border="true"
:value="val.error ? null : val.value" :value="val.error ? null : val.value"
:read-only="false"
@change="(value: DocValue)=> { @change="(value: DocValue)=> {
importer.valueMatrix[ridx][cidx]!.error = false importer.valueMatrix[ridx][cidx]!.error = false
importer.valueMatrix[ridx][cidx]!.value = value importer.valueMatrix[ridx][cidx]!.value = value

View File

@ -31,6 +31,7 @@ import {
ToastOptions, ToastOptions,
UIGroupedFields, UIGroupedFields,
} from './types'; } from './types';
import { Invoice } from 'models/baseModels/Invoice/Invoice';
export const toastDurationMap = { short: 2_500, long: 5_000 } as const; export const toastDurationMap = { short: 2_500, long: 5_000 } as const;
@ -81,7 +82,7 @@ export async function deleteDocWithPrompt(doc: Doc) {
} }
return await showDialog({ return await showDialog({
title: t`Delete ${getActionLabel(doc)}?`, title: t`Delete ${getDocReferenceLabel(doc)}?`,
detail, detail,
type: 'warning', type: 'warning',
buttons: [ buttons: [
@ -152,7 +153,7 @@ export async function cancelDocWithPrompt(doc: Doc) {
} }
return await showDialog({ return await showDialog({
title: t`Cancel ${getActionLabel(doc)}?`, title: t`Cancel ${getDocReferenceLabel(doc)}?`,
detail, detail,
type: 'warning', type: 'warning',
buttons: [ buttons: [
@ -544,19 +545,17 @@ export async function commonDocSubmit(doc: Doc): Promise<boolean> {
} }
async function showSubmitOrSyncDialog(doc: Doc, type: 'submit' | 'sync') { async function showSubmitOrSyncDialog(doc: Doc, type: 'submit' | 'sync') {
const label = getActionLabel(doc); const label = getDocReferenceLabel(doc);
let title = t`Submit ${label}?`; let title = t`Save ${label}?`;
if (type === 'sync') { if (type === 'submit') {
title = t`Save ${label}?`; title = t`Submit ${label}?`;
}
let detail = t`Create new ${doc.schema.label} entry.`;
if (type === 'sync' && doc.inserted) {
detail = t`Save changes made to ${label}.`;
} }
let detail: string;
if (type === 'submit') { if (type === 'submit') {
detail = getDocSubmitMessage(doc); detail = getDocSubmitMessage(doc);
} else {
detail = getDocSyncMessage(doc);
} }
const yesAction = async () => { const yesAction = async () => {
@ -590,6 +589,24 @@ async function showSubmitOrSyncDialog(doc: Doc, type: 'submit' | 'sync') {
}); });
} }
function getDocSyncMessage(doc: Doc): string {
const label = getDocReferenceLabel(doc);
const detail = t`Create new ${doc.schema.label} entry?`;
if (doc.inserted) {
return t`Save changes made to ${label}?`;
}
if (doc instanceof Invoice && doc.grandTotal?.isZero()) {
const gt = doc.fyo.format(doc.grandTotal ?? doc.fyo.pesa(0), 'Currency');
return [
detail,
t`Entry has Grand Total ${gt}. Please verify amounts.`,
].join(' ');
}
return detail;
}
function getDocSubmitMessage(doc: Doc): string { function getDocSubmitMessage(doc: Doc): string {
const details = [t`Mark ${doc.schema.label} as submitted?`]; const details = [t`Mark ${doc.schema.label} as submitted?`];
@ -615,7 +632,7 @@ function getDocSubmitMessage(doc: Doc): string {
} }
function showActionToast(doc: Doc, type: 'sync' | 'cancel' | 'delete') { function showActionToast(doc: Doc, type: 'sync' | 'cancel' | 'delete') {
const label = getActionLabel(doc); const label = getDocReferenceLabel(doc);
const message = { const message = {
sync: t`${label} saved`, sync: t`${label} saved`,
cancel: t`${label} cancelled`, cancel: t`${label} cancelled`,
@ -626,7 +643,7 @@ function showActionToast(doc: Doc, type: 'sync' | 'cancel' | 'delete') {
} }
function showSubmitToast(doc: Doc) { function showSubmitToast(doc: Doc) {
const label = getActionLabel(doc); const label = getDocReferenceLabel(doc);
const message = t`${label} submitted`; const message = t`${label} submitted`;
const toastOption: ToastOptions = { const toastOption: ToastOptions = {
type: 'success', type: 'success',
@ -665,7 +682,7 @@ function getSubmitSuccessToastAction(doc: Doc) {
} }
export function showCannotSaveOrSubmitToast(doc: Doc) { export function showCannotSaveOrSubmitToast(doc: Doc) {
const label = getActionLabel(doc); const label = getDocReferenceLabel(doc);
let message = t`${label} already saved`; let message = t`${label} already saved`;
if (doc.schema.isSubmittable && doc.isSubmitted) { if (doc.schema.isSubmittable && doc.isSubmitted) {
@ -676,7 +693,7 @@ export function showCannotSaveOrSubmitToast(doc: Doc) {
} }
export function showCannotCancelOrDeleteToast(doc: Doc) { export function showCannotCancelOrDeleteToast(doc: Doc) {
const label = getActionLabel(doc); const label = getDocReferenceLabel(doc);
let message = t`${label} cannot be deleted`; let message = t`${label} cannot be deleted`;
if (doc.schema.isSubmittable && !doc.isCancelled) { if (doc.schema.isSubmittable && !doc.isCancelled) {
message = t`${label} cannot be cancelled`; message = t`${label} cannot be cancelled`;
@ -685,7 +702,7 @@ export function showCannotCancelOrDeleteToast(doc: Doc) {
showToast({ type: 'warning', message, duration: 'short' }); showToast({ type: 'warning', message, duration: 'short' });
} }
function getActionLabel(doc: Doc) { function getDocReferenceLabel(doc: Doc) {
const label = doc.schema.label || doc.schemaName; const label = doc.schema.label || doc.schemaName;
if (doc.schema.naming === 'random') { if (doc.schema.naming === 'random') {
return label; return label;

View File

@ -141,12 +141,37 @@ export function useDocShortcuts(
showCannotCancelOrDeleteToast(doc); showCannotCancelOrDeleteToast(doc);
}; };
onMounted(() => {
if (isMultiple && shortcuts.has(context)) {
return;
}
shortcuts.pmod.set(context, ['KeyS'], syncOrSubmitCallback, false);
shortcuts.pmod.set(context, ['Backspace'], cancelOrDeleteCallback, false);
});
onActivated(() => { onActivated(() => {
if (isMultiple && shortcuts.has(context)) {
return;
}
shortcuts.pmod.set(context, ['KeyS'], syncOrSubmitCallback, false); shortcuts.pmod.set(context, ['KeyS'], syncOrSubmitCallback, false);
shortcuts.pmod.set(context, ['Backspace'], cancelOrDeleteCallback, false); shortcuts.pmod.set(context, ['Backspace'], cancelOrDeleteCallback, false);
}); });
onDeactivated(() => { onDeactivated(() => {
if (!shortcuts.has(context)) {
return;
}
shortcuts.delete(context);
});
onUnmounted(() => {
if (!shortcuts.has(context)) {
return;
}
shortcuts.delete(context); shortcuts.delete(context);
}); });