2018-06-01 18:05:51 +05:30
|
|
|
<template>
|
2020-01-28 13:50:42 +05:30
|
|
|
<div
|
|
|
|
id="app"
|
|
|
|
class="h-screen flex flex-col font-sans overflow-hidden antialiased"
|
2023-01-13 12:13:28 +05:30
|
|
|
:dir="languageDirection"
|
2023-01-07 13:25:08 +03:00
|
|
|
:language="language"
|
2020-01-28 13:50:42 +05:30
|
|
|
>
|
2022-05-28 09:07:14 +05:30
|
|
|
<WindowsTitleBar
|
|
|
|
v-if="platform === 'Windows'"
|
|
|
|
:db-path="dbPath"
|
|
|
|
:company-name="companyName"
|
|
|
|
/>
|
2022-04-29 00:27:10 +05:30
|
|
|
<!-- Main Contents -->
|
2021-11-24 14:38:13 +05:30
|
|
|
<Desk
|
|
|
|
v-if="activeScreen === 'Desk'"
|
2023-06-23 12:35:44 +05:30
|
|
|
class="flex-1"
|
2022-05-23 11:51:06 +05:30
|
|
|
@change-db-file="showDbSelector"
|
2022-04-25 15:56:01 +05:30
|
|
|
/>
|
2020-01-01 13:41:57 +05:30
|
|
|
<DatabaseSelector
|
|
|
|
v-if="activeScreen === 'DatabaseSelector'"
|
2023-06-23 12:35:44 +05:30
|
|
|
ref="databaseSelector"
|
2023-07-11 13:43:32 +05:30
|
|
|
@new-database="newDatabase"
|
2022-04-22 16:32:03 +05:30
|
|
|
@file-selected="fileSelected"
|
2020-01-01 13:41:57 +05:30
|
|
|
/>
|
2022-04-22 16:32:03 +05:30
|
|
|
<SetupWizard
|
2020-01-01 13:41:57 +05:30
|
|
|
v-if="activeScreen === 'SetupWizard'"
|
2022-02-02 13:53:04 +05:30
|
|
|
@setup-complete="setupComplete"
|
2022-05-23 11:51:06 +05:30
|
|
|
@setup-canceled="showDbSelector"
|
2020-01-01 13:41:57 +05:30
|
|
|
/>
|
2022-05-23 11:51:06 +05:30
|
|
|
|
2022-04-29 00:27:10 +05:30
|
|
|
<!-- Render target for toasts -->
|
2022-02-16 16:07:09 +05:30
|
|
|
<div
|
|
|
|
id="toast-container"
|
2023-01-07 15:40:16 +03:00
|
|
|
class="absolute bottom-0 flex flex-col items-end mb-3 pe-6"
|
2023-03-24 13:42:03 +05:30
|
|
|
style="width: 100%; pointer-events: none"
|
|
|
|
></div>
|
2018-06-01 18:05:51 +05:30
|
|
|
</div>
|
|
|
|
</template>
|
2023-03-21 15:03:13 +05:30
|
|
|
<script lang="ts">
|
2023-01-13 12:13:28 +05:30
|
|
|
import { RTL_LANGUAGES } from 'fyo/utils/consts';
|
2022-05-24 23:29:05 +05:30
|
|
|
import { ModelNameEnum } from 'models/types';
|
2023-01-30 16:20:40 +05:30
|
|
|
import { systemLanguageRef } from 'src/utils/refs';
|
2023-03-21 15:03:13 +05:30
|
|
|
import { defineComponent, provide, ref, Ref } from 'vue';
|
2022-05-28 16:44:38 +05:30
|
|
|
import WindowsTitleBar from './components/WindowsTitleBar.vue';
|
2022-05-24 23:29:05 +05:30
|
|
|
import { handleErrorWithDialog } from './errorHandling';
|
2022-11-01 13:47:55 +05:30
|
|
|
import { fyo } from './initFyo';
|
2022-04-22 16:32:03 +05:30
|
|
|
import DatabaseSelector from './pages/DatabaseSelector.vue';
|
2022-04-25 15:56:01 +05:30
|
|
|
import Desk from './pages/Desk.vue';
|
2022-04-22 16:32:03 +05:30
|
|
|
import SetupWizard from './pages/SetupWizard/SetupWizard.vue';
|
2022-04-23 14:53:44 +05:30
|
|
|
import setupInstance from './setup/setupInstance';
|
2023-03-21 15:03:13 +05:30
|
|
|
import { SetupWizardOptions } from './setup/types';
|
2022-03-11 15:15:43 +05:30
|
|
|
import './styles/index.css';
|
2023-04-04 11:51:00 +05:30
|
|
|
import { connectToDatabase, dbErrorActionSymbols } from './utils/db';
|
2022-11-01 13:47:55 +05:30
|
|
|
import { initializeInstance } from './utils/initialization';
|
2023-03-21 15:03:13 +05:30
|
|
|
import * as injectionKeys from './utils/injectionKeys';
|
2023-06-29 11:02:09 +05:30
|
|
|
import { showDialog } from './utils/interactive';
|
2023-07-10 12:27:13 +05:30
|
|
|
import { setLanguageMap } from './utils/language';
|
2022-07-20 14:14:36 +05:30
|
|
|
import { updateConfigFiles } from './utils/misc';
|
2023-03-13 21:14:10 +05:30
|
|
|
import { updatePrintTemplates } from './utils/printTemplates';
|
2022-05-30 14:20:54 +05:30
|
|
|
import { Search } from './utils/search';
|
2023-03-22 22:58:36 +05:30
|
|
|
import { Shortcuts } from './utils/shortcuts';
|
2023-01-30 16:20:40 +05:30
|
|
|
import { routeTo } from './utils/ui';
|
2023-03-22 22:58:36 +05:30
|
|
|
import { useKeys } from './utils/vueUtils';
|
2018-06-01 18:05:51 +05:30
|
|
|
|
2023-03-21 15:03:13 +05:30
|
|
|
enum Screen {
|
|
|
|
Desk = 'Desk',
|
|
|
|
DatabaseSelector = 'DatabaseSelector',
|
|
|
|
SetupWizard = 'SetupWizard',
|
|
|
|
}
|
|
|
|
|
|
|
|
export default defineComponent({
|
2018-06-01 18:05:51 +05:30
|
|
|
name: 'App',
|
2023-06-23 12:35:44 +05:30
|
|
|
components: {
|
|
|
|
Desk,
|
|
|
|
SetupWizard,
|
|
|
|
DatabaseSelector,
|
|
|
|
WindowsTitleBar,
|
|
|
|
},
|
2022-12-08 15:19:22 +05:30
|
|
|
setup() {
|
2023-03-21 15:03:13 +05:30
|
|
|
const keys = useKeys();
|
|
|
|
const searcher: Ref<null | Search> = ref(null);
|
|
|
|
const shortcuts = new Shortcuts(keys);
|
|
|
|
const languageDirection = ref(
|
|
|
|
getLanguageDirection(systemLanguageRef.value)
|
|
|
|
);
|
|
|
|
|
|
|
|
provide(injectionKeys.keysKey, keys);
|
|
|
|
provide(injectionKeys.searcherKey, searcher);
|
|
|
|
provide(injectionKeys.shortcutsKey, shortcuts);
|
|
|
|
provide(injectionKeys.languageDirectionKey, languageDirection);
|
|
|
|
|
2023-04-03 13:51:46 +05:30
|
|
|
const databaseSelector = ref<InstanceType<typeof DatabaseSelector> | null>(
|
|
|
|
null
|
|
|
|
);
|
|
|
|
|
|
|
|
return {
|
|
|
|
keys,
|
|
|
|
searcher,
|
|
|
|
shortcuts,
|
|
|
|
languageDirection,
|
|
|
|
databaseSelector,
|
|
|
|
};
|
2022-12-08 15:19:22 +05:30
|
|
|
},
|
2018-06-11 15:16:25 +05:30
|
|
|
data() {
|
|
|
|
return {
|
2021-11-04 15:03:51 +05:30
|
|
|
activeScreen: null,
|
2022-05-28 09:07:14 +05:30
|
|
|
dbPath: '',
|
|
|
|
companyName: '',
|
2023-03-21 15:03:13 +05:30
|
|
|
} as {
|
|
|
|
activeScreen: null | Screen;
|
|
|
|
dbPath: string;
|
|
|
|
companyName: string;
|
2019-08-20 14:27:27 +05:30
|
|
|
};
|
2018-06-11 15:16:25 +05:30
|
|
|
},
|
2023-06-23 12:35:44 +05:30
|
|
|
computed: {
|
|
|
|
language(): string {
|
|
|
|
return systemLanguageRef.value;
|
|
|
|
},
|
2023-03-21 15:03:13 +05:30
|
|
|
},
|
|
|
|
watch: {
|
2023-06-26 13:40:23 +05:30
|
|
|
language(value: string) {
|
2023-03-21 15:03:13 +05:30
|
|
|
this.languageDirection = getLanguageDirection(value);
|
|
|
|
},
|
2020-01-01 13:41:57 +05:30
|
|
|
},
|
2023-06-23 12:35:44 +05:30
|
|
|
async mounted() {
|
2023-06-26 13:40:23 +05:30
|
|
|
await this.setInitialScreen();
|
2023-01-27 14:13:36 +05:30
|
|
|
},
|
2020-01-01 13:41:57 +05:30
|
|
|
methods: {
|
2023-03-21 15:03:13 +05:30
|
|
|
async setInitialScreen(): Promise<void> {
|
2023-06-21 16:08:39 +05:30
|
|
|
const lastSelectedFilePath = fyo.config.get('lastSelectedFilePath', null);
|
2023-03-21 15:03:13 +05:30
|
|
|
|
|
|
|
if (
|
|
|
|
typeof lastSelectedFilePath !== 'string' ||
|
|
|
|
!lastSelectedFilePath.length
|
|
|
|
) {
|
|
|
|
this.activeScreen = Screen.DatabaseSelector;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2023-07-11 13:43:32 +05:30
|
|
|
await this.fileSelected(lastSelectedFilePath);
|
2023-03-21 15:03:13 +05:30
|
|
|
},
|
|
|
|
async setSearcher(): Promise<void> {
|
|
|
|
this.searcher = new Search(fyo);
|
|
|
|
await this.searcher.initializeKeywords();
|
|
|
|
},
|
|
|
|
async setDesk(filePath: string): Promise<void> {
|
|
|
|
this.activeScreen = Screen.Desk;
|
2022-05-23 11:51:06 +05:30
|
|
|
await this.setDeskRoute();
|
2022-07-18 16:43:56 +05:30
|
|
|
await fyo.telemetry.start(true);
|
2023-07-10 13:33:52 +05:30
|
|
|
await ipc.checkForUpdates();
|
2023-07-10 12:27:13 +05:30
|
|
|
await setLanguageMap();
|
2022-05-28 09:07:14 +05:30
|
|
|
this.dbPath = filePath;
|
2023-03-21 15:03:13 +05:30
|
|
|
this.companyName = (await fyo.getValue(
|
2022-05-28 09:07:14 +05:30
|
|
|
ModelNameEnum.AccountingSettings,
|
|
|
|
'companyName'
|
2023-03-21 15:03:13 +05:30
|
|
|
)) as string;
|
2022-05-30 14:20:54 +05:30
|
|
|
await this.setSearcher();
|
2023-03-06 14:18:04 +05:30
|
|
|
updateConfigFiles(fyo);
|
2022-05-30 14:20:54 +05:30
|
|
|
},
|
2023-07-11 13:43:32 +05:30
|
|
|
newDatabase() {
|
|
|
|
this.activeScreen = Screen.SetupWizard;
|
|
|
|
},
|
|
|
|
async fileSelected(filePath: string): Promise<void> {
|
2023-06-21 16:08:39 +05:30
|
|
|
fyo.config.set('lastSelectedFilePath', filePath);
|
2023-07-10 13:33:52 +05:30
|
|
|
if (filePath !== ':memory:' && !(await ipc.checkDbAccess(filePath))) {
|
2023-06-29 11:02:09 +05:30
|
|
|
await showDialog({
|
|
|
|
title: this.t`Cannot open file`,
|
|
|
|
type: 'error',
|
|
|
|
detail: this
|
|
|
|
.t`Frappe Books does not have access to the selected file: ${filePath}`,
|
|
|
|
});
|
|
|
|
|
|
|
|
fyo.config.set('lastSelectedFilePath', null);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2023-03-21 15:03:13 +05:30
|
|
|
try {
|
|
|
|
await this.showSetupWizardOrDesk(filePath);
|
|
|
|
} catch (error) {
|
|
|
|
await handleErrorWithDialog(error, undefined, true, true);
|
|
|
|
await this.showDbSelector();
|
|
|
|
}
|
2022-04-22 16:32:03 +05:30
|
|
|
},
|
2023-03-21 15:03:13 +05:30
|
|
|
async setupComplete(setupWizardOptions: SetupWizardOptions): Promise<void> {
|
2023-07-11 13:43:32 +05:30
|
|
|
const companyName = setupWizardOptions.companyName;
|
|
|
|
const filePath = await ipc.getDbDefaultPath(companyName);
|
2022-04-24 12:18:44 +05:30
|
|
|
await setupInstance(filePath, setupWizardOptions, fyo);
|
2023-07-11 13:43:32 +05:30
|
|
|
fyo.config.set('lastSelectedFilePath', filePath);
|
2022-05-23 11:51:06 +05:30
|
|
|
await this.setDesk(filePath);
|
2022-04-23 14:53:44 +05:30
|
|
|
},
|
2023-03-21 15:03:13 +05:30
|
|
|
async showSetupWizardOrDesk(filePath: string): Promise<void> {
|
2023-04-03 13:51:46 +05:30
|
|
|
const { countryCode, error, actionSymbol } = await connectToDatabase(
|
|
|
|
this.fyo,
|
|
|
|
filePath
|
|
|
|
);
|
|
|
|
|
|
|
|
if (!countryCode && error && actionSymbol) {
|
|
|
|
return await this.handleConnectionFailed(error, actionSymbol);
|
|
|
|
}
|
|
|
|
|
2023-04-04 11:51:00 +05:30
|
|
|
const setupComplete = await fyo.getValue(
|
|
|
|
ModelNameEnum.AccountingSettings,
|
|
|
|
'setupComplete'
|
|
|
|
);
|
2022-04-22 16:32:03 +05:30
|
|
|
|
2020-01-01 13:41:57 +05:30
|
|
|
if (!setupComplete) {
|
2023-03-21 15:03:13 +05:30
|
|
|
this.activeScreen = Screen.SetupWizard;
|
2022-04-22 16:32:03 +05:30
|
|
|
return;
|
2019-10-24 16:09:57 +05:30
|
|
|
}
|
2021-12-02 18:50:51 +05:30
|
|
|
|
2023-04-04 11:51:00 +05:30
|
|
|
await initializeInstance(filePath, false, countryCode, fyo);
|
2023-03-13 21:14:10 +05:30
|
|
|
await updatePrintTemplates(fyo);
|
2022-05-23 11:51:06 +05:30
|
|
|
await this.setDesk(filePath);
|
2022-04-22 16:32:03 +05:30
|
|
|
},
|
2023-04-03 13:51:46 +05:30
|
|
|
async handleConnectionFailed(error: Error, actionSymbol: symbol) {
|
|
|
|
await this.showDbSelector();
|
|
|
|
|
|
|
|
if (actionSymbol === dbErrorActionSymbols.CancelSelection) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (actionSymbol === dbErrorActionSymbols.SelectFile) {
|
2023-06-26 13:40:23 +05:30
|
|
|
await this.databaseSelector?.existingDatabase();
|
|
|
|
return;
|
2023-04-03 13:51:46 +05:30
|
|
|
}
|
|
|
|
|
|
|
|
throw error;
|
|
|
|
},
|
2023-03-21 15:03:13 +05:30
|
|
|
async setDeskRoute(): Promise<void> {
|
2022-05-26 15:41:15 +05:30
|
|
|
const { onboardingComplete } = await fyo.doc.getDoc('GetStarted');
|
|
|
|
const { hideGetStarted } = await fyo.doc.getDoc('SystemSettings');
|
2021-12-02 18:50:51 +05:30
|
|
|
|
2023-06-30 11:57:43 +05:30
|
|
|
let route = '/get-started';
|
2021-12-02 18:50:51 +05:30
|
|
|
if (hideGetStarted || onboardingComplete) {
|
2023-06-30 11:57:43 +05:30
|
|
|
route = '/';
|
2019-12-16 17:04:22 +05:30
|
|
|
}
|
2023-06-30 11:57:43 +05:30
|
|
|
|
|
|
|
await routeTo(localStorage.getItem('lastRoute') || route);
|
2019-12-27 12:07:39 +05:30
|
|
|
},
|
2023-03-21 15:03:13 +05:30
|
|
|
async showDbSelector(): Promise<void> {
|
2023-06-30 11:57:43 +05:30
|
|
|
localStorage.clear();
|
2022-04-21 18:38:36 +05:30
|
|
|
fyo.config.set('lastSelectedFilePath', null);
|
2022-04-22 16:32:03 +05:30
|
|
|
fyo.telemetry.stop();
|
2022-07-30 16:33:09 +05:30
|
|
|
await fyo.purgeCache();
|
2023-03-21 15:03:13 +05:30
|
|
|
this.activeScreen = Screen.DatabaseSelector;
|
2022-05-28 09:07:14 +05:30
|
|
|
this.dbPath = '';
|
2022-05-30 14:20:54 +05:30
|
|
|
this.searcher = null;
|
2022-05-28 09:07:14 +05:30
|
|
|
this.companyName = '';
|
2021-11-24 14:38:13 +05:30
|
|
|
},
|
2021-11-04 15:03:51 +05:30
|
|
|
},
|
2023-03-21 15:03:13 +05:30
|
|
|
});
|
|
|
|
|
|
|
|
function getLanguageDirection(language: string): 'rtl' | 'ltr' {
|
|
|
|
return RTL_LANGUAGES.includes(language) ? 'rtl' : 'ltr';
|
|
|
|
}
|
2018-06-01 18:05:51 +05:30
|
|
|
</script>
|