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

feat: handle change in main settings component

- show toast if display precision has changed
This commit is contained in:
18alantom 2022-01-18 14:02:40 +05:30 committed by Alan
parent 975e083084
commit 526eaf9e2c
2 changed files with 35 additions and 4 deletions

View File

@ -40,7 +40,7 @@
</Row>
</div>
<div class="flex-1 p-6 overflow-y-auto">
<component :is="activeTabComponent" />
<component :is="activeTabComponent" @change="handleChange" />
</div>
</div>
</div>
@ -48,6 +48,7 @@
</template>
<script>
import { _ } from 'frappejs/utils';
import frappe from 'frappejs';
import WindowControls from '@/components/WindowControls';
import TabGeneral from './TabGeneral.vue';
import TabSystem from './TabSystem.vue';
@ -57,6 +58,8 @@ import Row from '@/components/Row';
import Icon from '@/components/Icon';
import PageHeader from '@/components/PageHeader';
import StatusBadge from '@/components/StatusBadge';
import { callInitializeMoneyMaker } from '../../utils';
import { showToast } from '../../utils';
export default {
name: 'Settings',
@ -71,6 +74,7 @@ export default {
return {
activeTab: 0,
updated: false,
fieldsChanged: [],
tabs: [
{
label: _('Invoice'),
@ -93,7 +97,34 @@ export default {
activated() {
this.setActiveTab();
},
deactivated() {
if (this.fieldsChanged.length === 0) {
return;
}
const fieldnames = this.fieldsChanged.map(({ fieldname }) => fieldname);
if (fieldnames.includes('displayPrecision')) {
callInitializeMoneyMaker(undefined, true);
const { label } =
this.fieldsChanged[fieldnames.indexOf('displayPrecision')];
showToast({
message: _(`${label} change will be visible on reload.`),
actionText: frappe._('Reload'),
action: async () => {
frappe.events.trigger('reload-main-window');
},
});
}
},
methods: {
handleChange(df, newValue, oldValue) {
if (!df) {
return;
}
this.fieldsChanged.push(df);
},
setActiveTab() {
const { tab } = this.$route.query;
const index = this.tabs.findIndex((t) => t.label === _(tab));

View File

@ -380,13 +380,13 @@ export async function getCurrency() {
return currency;
}
export async function callInitializeMoneyMaker(currency) {
export async function callInitializeMoneyMaker(currency, force = false) {
currency ??= await getCurrency();
if (!currency && frappe.pesa) {
if (!force && !currency && frappe.pesa) {
return;
}
if (currency && frappe.pesa().options.currency === currency) {
if (!force && currency && frappe.pesa().options.currency === currency) {
return;
}
await frappe.initializeMoneyMaker(currency);