From 09f194badc9a61636afdab0e4ab45bb1c6771711 Mon Sep 17 00:00:00 2001 From: 18alantom <2.alan.tom@gmail.com> Date: Wed, 1 Mar 2023 13:24:49 +0530 Subject: [PATCH] incr: add sections to settings --- schemas/app/AccountingSettings.json | 97 +++++++++++--------- schemas/app/Defaults.json | 29 +++--- schemas/app/PrintSettings.json | 57 +++++++----- schemas/app/inventory/InventorySettings.json | 24 +++-- schemas/core/SystemSettings.json | 69 ++++++++------ schemas/regional/in/AccountingSettings.json | 3 +- src/pages/Settings/Settings.vue | 30 +++--- 7 files changed, 181 insertions(+), 128 deletions(-) diff --git a/schemas/app/AccountingSettings.json b/schemas/app/AccountingSettings.json index 69738a59..7bf9cddc 100644 --- a/schemas/app/AccountingSettings.json +++ b/schemas/app/AccountingSettings.json @@ -5,87 +5,100 @@ "isChild": false, "isSubmittable": false, "fields": [ + { + "label": "Full Name", + "fieldname": "fullname", + "fieldtype": "Data", + "required": true, + "section": "Default" + }, { "label": "Company Name", "fieldname": "companyName", "fieldtype": "Data", "readOnly": true, - "required": true + "required": true, + "section": "Default" }, { - "label": "Write Off Account", - "fieldname": "writeOffAccount", - "fieldtype": "Link", - "target": "Account" + "label": "Bank Name", + "fieldname": "bankName", + "fieldtype": "Data", + "readOnly": true, + "required": true, + "section": "Default" }, { - "label": "Round Off Account", - "fieldname": "roundOffAccount", - "fieldtype": "Link", - "target": "Account" - }, - { - "fieldname": "country", "label": "Country", + "fieldname": "country", "fieldtype": "AutoComplete", "placeholder": "Select Country", "readOnly": true, - "required": true - }, - { - "fieldname": "fullname", - "label": "Full Name", - "fieldtype": "Data", - "required": true + "required": true, + "section": "Default" }, { "fieldname": "email", "label": "Email", "fieldtype": "Data", - "required": true + "required": true, + "section": "Default" }, { - "fieldname": "bankName", - "label": "Bank Name", - "fieldtype": "Data", - "readOnly": true, - "required": true + "label": "Write Off Account", + "fieldname": "writeOffAccount", + "fieldtype": "Link", + "target": "Account", + "section": "Accounts" }, { - "fieldname": "fiscalYearStart", - "label": "Fiscal Year Start Date", - "fieldtype": "Date", - "required": true + "label": "Round Off Account", + "fieldname": "roundOffAccount", + "fieldtype": "Link", + "target": "Account", + "section": "Accounts" }, { - "fieldname": "fiscalYearEnd", - "label": "Fiscal Year End Date", - "fieldtype": "Date", - "required": true + "label": "Discount Account", + "fieldname": "discountAccount", + "fieldtype": "Link", + "target": "Account", + "section": "Accounts" }, { "fieldname": "enableDiscounting", "label": "Enable Discount Accounting", "fieldtype": "Check", - "default": false - }, - { - "fieldname": "discountAccount", - "label": "Discount Account", - "fieldtype": "Link", - "target": "Account" + "default": false, + "section": "Feature Flags" }, { "fieldname": "enableInventory", "label": "Enable Inventory", "fieldtype": "Check", - "default": false + "default": false, + "section": "Feature Flags" + }, + { + "fieldname": "fiscalYearStart", + "label": "Fiscal Year Start Date", + "fieldtype": "Date", + "required": true, + "section": "Fiscal Year" + }, + { + "fieldname": "fiscalYearEnd", + "label": "Fiscal Year End Date", + "fieldtype": "Date", + "required": true, + "section": "Fiscal Year" }, { "fieldname": "setupComplete", "label": "Setup Complete", "fieldtype": "Check", - "default": false + "default": false, + "hidden": true } ], "quickEditFields": [ diff --git a/schemas/app/Defaults.json b/schemas/app/Defaults.json index aa91be4e..d68c6c79 100644 --- a/schemas/app/Defaults.json +++ b/schemas/app/Defaults.json @@ -9,73 +9,80 @@ "label": "Sales Invoice Number Series", "fieldtype": "Link", "target": "NumberSeries", - "create": true + "create": true, + "section": "Number Series" }, { "fieldname": "purchaseInvoiceNumberSeries", "label": "Purchase Invoice Number Series", "fieldtype": "Link", "target": "NumberSeries", - "create": true + "create": true, + "section": "Number Series" }, { "fieldname": "journalEntryNumberSeries", "label": "Journal Entry Number Series", "fieldtype": "Link", "target": "NumberSeries", - "create": true + "create": true, + "section": "Number Series" }, { "fieldname": "paymentNumberSeries", "label": "Payment Number Series", "fieldtype": "Link", "target": "NumberSeries", - "create": true + "create": true, + "section": "Number Series" }, { "fieldname": "stockMovementNumberSeries", "label": "Stock Movement Number Series", "fieldtype": "Link", "target": "NumberSeries", - "create": true + "create": true, + "section": "Number Series" }, { "fieldname": "shipmentNumberSeries", "label": "Shipment Number Series", "fieldtype": "Link", "target": "NumberSeries", - "create": true + "create": true, + "section": "Number Series" }, { "fieldname": "purchaseReceiptNumberSeries", "label": "Purchase Receipt Number Series", "fieldtype": "Link", "target": "NumberSeries", - "create": true + "create": true, + "section": "Number Series" }, { "fieldname": "salesInvoiceTerms", "label": "Sales Invoice Terms", "fieldtype": "Text", - "target": "NumberSeries" + "section": "Terms" }, { "fieldname": "purchaseInvoiceTerms", "label": "Purchase Invoice Terms", "fieldtype": "Text", - "target": "NumberSeries" + "section": "Terms" }, { "fieldname": "shipmentTerms", "label": "Shipment Terms", "fieldtype": "Text", - "target": "NumberSeries" + "section": "Terms" }, { "fieldname": "purchaseReceiptTerms", "label": "Purchase Receipt Terms", "fieldtype": "Text", - "target": "NumberSeries" + "section": "Terms" } ] } diff --git a/schemas/app/PrintSettings.json b/schemas/app/PrintSettings.json index 08f8f16c..cd671c4f 100644 --- a/schemas/app/PrintSettings.json +++ b/schemas/app/PrintSettings.json @@ -6,46 +6,36 @@ { "fieldname": "logo", "label": "Logo", - "fieldtype": "AttachImage" + "fieldtype": "AttachImage", + "section": "Default" }, { "fieldname": "companyName", "label": "Company Name", - "fieldtype": "Data" + "fieldtype": "Data", + "section": "Default" }, { "fieldname": "email", "label": "Email", "fieldtype": "Data", - "placeholder": "john@doe.com" - }, - { - "fieldname": "displayLogo", - "label": "Display Logo in Invoice", - "fieldtype": "Check" - }, - { - "fieldname": "displayTaxInvoice", - "label": "Display Tax Invoice", - "fieldtype": "Check" - }, - { - "fieldname": "displayBatch", - "label": "Display Batch", - "fieldtype": "Check" + "placeholder": "john@doe.com", + "section": "Contacts" }, { "fieldname": "phone", "label": "Phone", "fieldtype": "Data", - "placeholder": "9888900000" + "placeholder": "9888900000", + "section": "Contacts" }, { "fieldname": "address", "label": "Address", "fieldtype": "Link", "target": "Address", - "inline": true + "inline": true, + "section": "Contacts" }, { "fieldname": "template", @@ -66,7 +56,8 @@ "label": "Business" } ], - "default": "Basic" + "default": "Basic", + "section": "Customizations" }, { "fieldname": "color", @@ -115,7 +106,8 @@ "label": "Black", "value": "#112B42" } - ] + ], + "section": "Customizations" }, { "fieldname": "font", @@ -136,7 +128,26 @@ "label": "Courier" } ], - "default": "Arial" + "default": "Arial", + "section": "Customizations" + }, + { + "fieldname": "displayLogo", + "label": "Display Logo in Invoice", + "fieldtype": "Check", + "section": "Customizations" + }, + { + "fieldname": "displayTaxInvoice", + "label": "Display Tax Invoice", + "fieldtype": "Check", + "section": "Customizations" + }, + { + "fieldname": "displayBatch", + "label": "Display Batch", + "fieldtype": "Check", + "section": "Customizations" } ], "quickEditFields": [ diff --git a/schemas/app/inventory/InventorySettings.json b/schemas/app/inventory/InventorySettings.json index 0df7e6b4..811db4a4 100644 --- a/schemas/app/inventory/InventorySettings.json +++ b/schemas/app/inventory/InventorySettings.json @@ -19,47 +19,55 @@ } ], "default": "FIFO", - "required": true + "required": true, + "section": "Default" }, { "fieldname": "defaultLocation", "label": "Default Location", "fieldtype": "Link", "target": "Location", - "create": true + "create": true, + "section": "Default" }, { "fieldname": "stockInHand", "label": "Stock In Hand Acc.", "fieldtype": "Link", - "target": "Account" + "target": "Account", + "section": "Accounts" }, { "fieldname": "stockReceivedButNotBilled", "label": "Stock Received But Not Billed Acc.", "fieldtype": "Link", - "target": "Account" + "target": "Account", + "section": "Accounts" }, { "fieldname": "costOfGoodsSold", "label": "Cost Of Goods Sold Acc.", "fieldtype": "Link", - "target": "Account" + "target": "Account", + "section": "Accounts" }, { "fieldname": "enableBarcodes", "label": "Enable Barcodes", - "fieldtype": "Check" + "fieldtype": "Check", + "section": "Feature Flags" }, { "fieldname": "enableBatches", "label": "Enable Batches", - "fieldtype": "Check" + "fieldtype": "Check", + "section": "Feature Flags" }, { "fieldname": "enableUomConversions", "label": "Enable UOM Conversion", - "fieldtype": "Check" + "fieldtype": "Check", + "section": "Feature Flags" } ] } diff --git a/schemas/core/SystemSettings.json b/schemas/core/SystemSettings.json index 65bb5759..e597c40f 100644 --- a/schemas/core/SystemSettings.json +++ b/schemas/core/SystemSettings.json @@ -45,7 +45,23 @@ "default": "MMM d, y", "required": true, "allowCustom": true, - "description": "Sets the app-wide date display format." + "description": "Sets the app-wide date display format.", + "section": "Default" + }, + { + "fieldname": "hideGetStarted", + "label": "Hide Get Started", + "fieldtype": "Check", + "default": false, + "description": "Hides the Get Started section from the sidebar. Change will be visible on restart or refreshing the app.", + "section": "Default" + }, + { + "fieldname": "version", + "label": "Version", + "fieldtype": "Data", + "readOnly": true, + "section": "Default" }, { "fieldname": "locale", @@ -54,7 +70,8 @@ "default": "en-IN", "required": true, "allowCustom": true, - "description": "Set the local code. This is used for number formatting." + "description": "Set the local code. This is used for number formatting.", + "section": "Number Display" }, { "fieldname": "displayPrecision", @@ -64,29 +81,8 @@ "required": true, "minvalue": 0, "maxvalue": 9, - "description": "Sets how many digits are shown after the decimal point." - }, - { - "fieldname": "internalPrecision", - "label": "Internal Precision", - "fieldtype": "Int", - "minvalue": 0, - "default": 11, - "description": "Sets the internal precision used for monetary calculations. Above 6 should be sufficient for most currencies." - }, - { - "fieldname": "hideGetStarted", - "label": "Hide Get Started", - "fieldtype": "Check", - "default": false, - "description": "Hides the Get Started section from the sidebar. Change will be visible on restart or refreshing the app." - }, - { - "fieldname": "countryCode", - "label": "Country Code", - "fieldtype": "Data", - "default": "in", - "description": "Country code used to initialize regional settings." + "description": "Sets how many digits are shown after the decimal point.", + "section": "Number Display" }, { "fieldname": "currency", @@ -94,19 +90,32 @@ "fieldtype": "AutoComplete", "default": "INR", "readOnly": true, - "required": true + "required": true, + "section": "Number Display" }, { - "fieldname": "version", - "label": "Version", + "fieldname": "internalPrecision", + "label": "Internal Precision", + "fieldtype": "Int", + "minvalue": 0, + "default": 11, + "description": "Sets the internal precision used for monetary calculations. Above 6 should be sufficient for most currencies.", + "hidden": true + }, + { + "fieldname": "countryCode", + "label": "Country Code", "fieldtype": "Data", - "readOnly": true + "default": "in", + "description": "Country code used to initialize regional settings.", + "hidden": true }, { "fieldname": "instanceId", "label": "Instance Id", "fieldtype": "Data", - "readOnly": true + "readOnly": true, + "hidden": true } ], "quickEditFields": [ diff --git a/schemas/regional/in/AccountingSettings.json b/schemas/regional/in/AccountingSettings.json index 66de67ac..e1be3e8e 100644 --- a/schemas/regional/in/AccountingSettings.json +++ b/schemas/regional/in/AccountingSettings.json @@ -5,7 +5,8 @@ "fieldname": "gstin", "label": "GSTIN", "fieldtype": "Data", - "placeholder": "27AAAAA0000A1Z5" + "placeholder": "27AAAAA0000A1Z5", + "section": "Default" } ], "quickEditFields": [ diff --git a/src/pages/Settings/Settings.vue b/src/pages/Settings/Settings.vue index 1ee9c74b..edc3ca4b 100644 --- a/src/pages/Settings/Settings.vue +++ b/src/pages/Settings/Settings.vue @@ -82,7 +82,7 @@ import { evaluateHidden } from 'src/utils/doc'; import { reloadWindow } from 'src/utils/ipcCalls'; import { UIGroupedFields } from 'src/utils/types'; import { showToast } from 'src/utils/ui'; -import { defineComponent, nextTick } from 'vue'; +import { computed, defineComponent, nextTick } from 'vue'; import CommonFormSection from '../CommonForm/CommonFormSection.vue'; export default defineComponent({ @@ -102,15 +102,19 @@ export default defineComponent({ quickEditDoc: null | Doc; }; }, + provide() { + return { doc: computed(() => this.doc) }; + }, mounted() { - this.updateGroupedFields(); if (this.fyo.store.isDevelopment) { // @ts-ignore window.settings = this; } + + this.update(); }, methods: { - async sync() { + async sync(): Promise<void> { const syncableDocs = this.schemas .map(({ name }) => this.fyo.singles[name]) .filter((doc) => doc?.canSave) as Doc[]; @@ -127,7 +131,7 @@ export default defineComponent({ action: reloadWindow, }); }, - async syncDoc(doc: Doc) { + async syncDoc(doc: Doc): Promise<void> { try { await doc.sync(); this.updateGroupedFields(); @@ -139,7 +143,7 @@ export default defineComponent({ await handleErrorWithDialog(err, doc); } }, - async toggleQuickEditDoc(doc: Doc | null) { + async toggleQuickEditDoc(doc: Doc | null): Promise<void> { if (this.quickEditDoc && doc) { this.quickEditDoc = null; await nextTick(); @@ -147,7 +151,7 @@ export default defineComponent({ this.quickEditDoc = doc; }, - async onValueChange(field: Field, value: DocValue) { + async onValueChange(field: Field, value: DocValue): Promise<void> { const { fieldname } = field; delete this.errors[fieldname]; @@ -163,16 +167,16 @@ export default defineComponent({ this.update(); }, - update() { + update(): void { this.updateCanSave(); this.updateGroupedFields(); }, - updateCanSave() { + updateCanSave(): void { this.canSave = this.schemas .map(({ name }) => this.fyo.singles[name]?.canSave) .some(Boolean); }, - updateGroupedFields() { + updateGroupedFields(): void { const grouped: UIGroupedFields = new Map(); const fields: Field[] = this.schemas.map((s) => s.fields).flat(); @@ -183,7 +187,7 @@ export default defineComponent({ } const tabbed = grouped.get(schemaName)!; - const section = field.section ?? this.t`Misc`; + const section = field.section ?? this.t`Miscellaneous`; if (!tabbed.has(section)) { tabbed.set(section, []); } @@ -214,7 +218,7 @@ export default defineComponent({ }, tabLabels(): Record<string, string> { return { - [ModelNameEnum.AccountingSettings]: this.t`Accounting`, + [ModelNameEnum.AccountingSettings]: this.t`General`, [ModelNameEnum.PrintSettings]: this.t`Print`, [ModelNameEnum.InventorySettings]: this.t`Inventory`, [ModelNameEnum.Defaults]: this.t`Defaults`, @@ -227,9 +231,9 @@ export default defineComponent({ return [ ModelNameEnum.AccountingSettings, - ModelNameEnum.PrintSettings, ModelNameEnum.InventorySettings, ModelNameEnum.Defaults, + ModelNameEnum.PrintSettings, ModelNameEnum.SystemSettings, ] .filter((s) => @@ -237,7 +241,7 @@ export default defineComponent({ ) .map((s) => this.fyo.schemaMap[s]!); }, - activeGroup() { + activeGroup(): Map<string, Field[]> { if (!this.groupedFields) { return new Map(); }