2
0
mirror of https://github.com/frappe/books.git synced 2025-01-03 07:12:21 +00:00

incr: error handle lastSelectedFilepath load

This commit is contained in:
18alantom 2022-05-24 23:29:05 +05:30
parent 6ace4677e7
commit a8904a0854
3 changed files with 52 additions and 12 deletions

View File

@ -34,8 +34,10 @@
<script>
import { ConfigKeys } from 'fyo/core/types';
import { getSetupComplete, incrementOpenCount } from 'src/utils/misc';
import { ModelNameEnum } from 'models/types';
import { incrementOpenCount } from 'src/utils/misc';
import WindowsTitleBar from './components/WindowsTitleBar.vue';
import { handleErrorWithDialog } from './errorHandling';
import { fyo, initializeInstance } from './initFyo';
import DatabaseSelector from './pages/DatabaseSelector.vue';
import Desk from './pages/Desk.vue';
@ -66,12 +68,16 @@ export default {
null
);
if (lastSelectedFilePath) {
await this.fileSelected(lastSelectedFilePath, false);
return;
if (!lastSelectedFilePath) {
return (this.activeScreen = 'DatabaseSelector');
}
this.activeScreen = 'DatabaseSelector';
try {
await this.fileSelected(lastSelectedFilePath, false);
} catch (err) {
await handleErrorWithDialog(err, undefined, true, true);
this.activeScreen = 'DatabaseSelector';
}
},
methods: {
async setDesk(filePath) {
@ -96,7 +102,10 @@ export default {
},
async showSetupWizardOrDesk(filePath) {
const countryCode = await fyo.db.connectToDatabase(filePath);
const setupComplete = await getSetupComplete();
const setupComplete = await fyo.getValue(
ModelNameEnum.AccountingSettings,
'setupComplete'
);
if (!setupComplete) {
this.activeScreen = 'SetupWizard';

View File

@ -7,10 +7,12 @@ import {
ValidationError,
} from 'fyo/utils/errors';
import { ErrorLog } from 'fyo/utils/types';
import { truncate } from 'lodash';
import { IPC_ACTIONS, IPC_MESSAGES } from 'utils/messages';
import { fyo } from './initFyo';
import router from './router';
import { getErrorMessage } from './utils';
import { ToastOptions } from './utils/types';
import { MessageDialogOptions, ToastOptions } from './utils/types';
import { showMessageDialog, showToast } from './utils/ui';
function shouldNotStore(error: Error) {
@ -32,7 +34,6 @@ async function reportError(errorLogObj: ErrorLog, cb?: Function) {
};
if (fyo.store.isDevelopment) {
console.log('errorHandling');
console.log(body);
}
@ -85,12 +86,39 @@ export async function handleError(
await showToast(toastProps);
}
export async function handleErrorWithDialog(error: Error, doc?: Doc) {
export async function handleErrorWithDialog(
error: Error,
doc?: Doc,
reportError?: false,
dontThrow?: false
) {
const errorMessage = getErrorMessage(error, doc);
await handleError(false, error, { errorMessage, doc });
const name = error.name ?? t`Error`;
await showMessageDialog({ message: name, detail: errorMessage });
const options: MessageDialogOptions = { message: name, detail: errorMessage };
if (reportError) {
options.detail = truncate(options.detail, { length: 128 });
options.buttons = [
{
label: t`Report`,
action() {
reportIssue(getErrorLogObject(error, { errorMessage }));
},
},
{ label: t`OK`, action() {} },
];
}
await showMessageDialog(options);
if (dontThrow) {
if (fyo.store.isDevelopment) {
console.error(error);
}
return;
}
throw error;
}
@ -157,6 +185,9 @@ function getIssueUrlQuery(errorLogObj?: ErrorLog): string {
body.push(`**Path**: \`${fullPath}\``);
}
body.push(`**Version**: ${fyo.store.appVersion}`);
body.push(`**Route**: ${router.currentRoute.value.fullPath}`);
const url = [baseUrl, `body=${body.join('\n')}`].join('&');
return encodeURI(url);
}

View File

@ -167,7 +167,7 @@ import { setupDummyInstance } from 'dummy';
import { ipcRenderer } from 'electron';
import { t } from 'fyo';
import { ConfigKeys } from 'fyo/core/types';
import { addNewFile } from 'fyo/telemetry/helpers';
import { addNewConfigFile } from 'fyo/telemetry/helpers';
import { DateTime } from 'luxon';
import LanguageSelector from 'src/components/Controls/LanguageSelector.vue';
import FeatherIcon from 'src/components/FeatherIcon.vue';
@ -242,7 +242,7 @@ export default {
}
);
addNewFile(
addNewConfigFile(
companyName,
filePath,
instanceId,