2
0
mirror of https://github.com/frappe/books.git synced 2025-01-03 15:17:30 +00:00

fix: mark missed strings as translate

This commit is contained in:
18alantom 2022-03-30 16:27:45 +05:30
parent 5a66e4aba6
commit 0d78df598c
45 changed files with 219 additions and 175 deletions

View File

@ -20,7 +20,7 @@ module.exports = {
{
fieldname: 'subject',
label: t`Subject`,
placeholder: 'Subject',
placeholder: t`Subject`,
fieldtype: 'Data',
required: 1,
},

View File

@ -20,7 +20,7 @@ export default {
fieldname: 'rootType',
label: t`Root Type`,
fieldtype: 'Select',
placeholder: 'Root Type',
placeholder: t`Root Type`,
options: ['Asset', 'Liability', 'Equity', 'Income', 'Expense'],
required: 1,
},
@ -40,7 +40,7 @@ export default {
{
fieldname: 'accountType',
label: t`Account Type`,
placeholder: 'Account Type',
placeholder: t`Account Type`,
fieldtype: 'Select',
options: [
'Accumulated Depreciation',

View File

@ -51,7 +51,7 @@ export default {
fieldname: 'country',
label: t`Country`,
fieldtype: 'AutoComplete',
placeholder: 'Select Country',
placeholder: t`Select Country`,
readOnly: 1,
required: 1,
getList: () => countryList,
@ -113,7 +113,7 @@ export default {
fieldname: 'gstin',
label: t`GSTIN`,
fieldtype: 'Data',
placeholder: '27AAAAA0000A1Z5',
placeholder: t`27AAAAA0000A1Z5`,
},
],
quickEditFields: [

View File

@ -29,27 +29,27 @@ export default {
{
fieldname: 'addressLine1',
label: t`Address Line 1`,
placeholder: 'Address Line 1',
placeholder: t`Address Line 1`,
fieldtype: 'Data',
required: 1,
},
{
fieldname: 'addressLine2',
label: t`Address Line 2`,
placeholder: 'Address Line 2',
placeholder: t`Address Line 2`,
fieldtype: 'Data',
},
{
fieldname: 'city',
label: t`City / Town`,
placeholder: 'City / Town',
placeholder: t`City / Town`,
fieldtype: 'Data',
required: 1,
},
{
fieldname: 'state',
label: t`State`,
placeholder: 'State',
placeholder: t`State`,
fieldtype: 'AutoComplete',
emptyMessage: (doc) => {
if (doc.country) {
@ -62,7 +62,7 @@ export default {
{
fieldname: 'country',
label: t`Country`,
placeholder: 'Country',
placeholder: t`Country`,
fieldtype: 'AutoComplete',
getList: () => Object.keys(countryList).sort(),
required: 1,
@ -70,19 +70,19 @@ export default {
{
fieldname: 'postalCode',
label: t`Postal Code`,
placeholder: 'Postal Code',
placeholder: t`Postal Code`,
fieldtype: 'Data',
},
{
fieldname: 'emailAddress',
label: t`Email Address`,
placeholder: 'Email Address',
placeholder: t`Email Address`,
fieldtype: 'Data',
},
{
fieldname: 'phone',
label: t`Phone`,
placeholder: 'Phone',
placeholder: t`Phone`,
fieldtype: 'Data',
},
{

View File

@ -18,7 +18,7 @@ export default function getAugmentedAddress({ country }) {
fieldname: 'pos',
label: t`Place of Supply`,
fieldtype: 'AutoComplete',
placeholder: 'Place of Supply',
placeholder: t`Place of Supply`,
formula: (doc) => (stateList.includes(doc.state) ? doc.state : ''),
getList: () => stateList,
},

View File

@ -20,7 +20,7 @@ export default {
{
fieldname: 'month',
label: t`Month`,
placeholder: 'Month',
placeholder: t`Month`,
fieldtype: 'Select',
options: [
'January',

View File

@ -18,7 +18,7 @@ export default {
fieldname: 'name',
label: t`Item Name`,
fieldtype: 'Data',
placeholder: 'Item Name',
placeholder: t`Item Name`,
required: 1,
},
{
@ -29,21 +29,21 @@ export default {
{
fieldname: 'description',
label: t`Description`,
placeholder: 'Item Description',
placeholder: t`Item Description`,
fieldtype: 'Text',
},
{
fieldname: 'unit',
label: t`Unit Type`,
fieldtype: 'Select',
placeholder: 'Unit Type',
placeholder: t`Unit Type`,
default: 'Unit',
options: ['Unit', 'Kg', 'Gram', 'Hour', 'Day'],
},
{
fieldname: 'itemType',
label: t`Type`,
placeholder: 'Type',
placeholder: t`Type`,
fieldtype: 'Select',
default: 'Product',
options: ['Product', 'Service'],
@ -61,7 +61,7 @@ export default {
label: t`Income`,
fieldtype: 'Link',
target: 'Account',
placeholder: 'Income',
placeholder: t`Income`,
required: 1,
disableCreation: true,
getFilters: () => {
@ -86,7 +86,7 @@ export default {
label: t`Expense`,
fieldtype: 'Link',
target: 'Account',
placeholder: 'Expense',
placeholder: t`Expense`,
required: 1,
disableCreation: true,
getFilters: () => {
@ -112,7 +112,7 @@ export default {
label: t`Tax`,
fieldtype: 'Link',
target: 'Tax',
placeholder: 'Tax',
placeholder: t`Tax`,
},
{
fieldname: 'rate',

View File

@ -17,7 +17,7 @@ export default function getAugmentedItem({ country }) {
fieldname: 'hsnCode',
label: t`HSN/SAC`,
fieldtype: 'Int',
placeholder: 'HSN/SAC Code',
placeholder: t`HSN/SAC Code`,
},
...Item.fields.slice(nameFieldIndex + 1, Item.fields.length),
];

View File

@ -28,7 +28,7 @@ export default {
fieldname: 'entryType',
label: t`Entry Type`,
fieldtype: 'Select',
placeholder: 'Entry Type',
placeholder: t`Entry Type`,
options: Object.keys(journalEntryTypeMap),
map: journalEntryTypeMap,
required: 1,
@ -67,7 +67,7 @@ export default {
fieldname: 'userRemark',
label: t`User Remark`,
fieldtype: 'Text',
placeholder: 'User Remark',
placeholder: t`User Remark`,
},
{
fieldname: 'cancelled',

View File

@ -6,7 +6,7 @@ export default {
{
fieldname: 'account',
label: t`Account`,
placeholder: 'Account',
placeholder: t`Account`,
fieldtype: 'Link',
target: 'Account',
required: 1,

View File

@ -11,7 +11,7 @@ export default {
label: t`Name`,
fieldtype: 'Data',
required: 1,
placeholder: 'Full Name',
placeholder: t`Full Name`,
},
{
fieldname: 'image',
@ -59,14 +59,14 @@ export default {
label: t`Currency`,
fieldtype: 'Link',
target: 'Currency',
placeholder: 'INR',
placeholder: t`INR`,
formula: () => frappe.AccountingSettings.currency,
},
{
fieldname: 'email',
label: t`Email`,
fieldtype: 'Data',
placeholder: 'john@doe.com',
placeholder: t`john@doe.com`,
validate: {
type: 'email',
},
@ -75,7 +75,7 @@ export default {
fieldname: 'phone',
label: t`Phone`,
fieldtype: 'Data',
placeholder: 'Phone',
placeholder: t`Phone`,
validate: {
type: 'phone',
},

View File

@ -23,7 +23,7 @@ export default function getAugmentedParty({ country }) {
{
fieldname: 'gstType',
label: t`GST Registration`,
placeholder: 'GST Registration',
placeholder: t`GST Registration`,
fieldtype: 'Select',
default: gstTypes[0],
options: gstTypes,

View File

@ -7,6 +7,12 @@ const paymentTypeMap = {
Pay: t`Pay`,
};
const paymentMethodMap = {
Cash: t`Cash`,
Cheque: t`Cheque`,
Transfer: t`Transfer`,
};
export default {
name: 'Payment',
label: t`Payment`,
@ -61,7 +67,7 @@ export default {
fieldname: 'paymentType',
label: t`Payment Type`,
fieldtype: 'Select',
placeholder: 'Payment Type',
placeholder: t`Payment Type`,
options: Object.keys(paymentTypeMap),
map: paymentTypeMap,
required: 1,
@ -69,7 +75,7 @@ export default {
{
fieldname: 'paymentAccount',
label: t`To Account`,
placeholder: 'To Account',
placeholder: t`To Account`,
fieldtype: 'Link',
target: 'Account',
required: 1,
@ -102,16 +108,17 @@ export default {
{
fieldname: 'paymentMethod',
label: t`Payment Method`,
placeholder: 'Payment Method',
placeholder: t`Payment Method`,
fieldtype: 'Select',
options: ['Cash', 'Cheque', 'Transfer'],
options: Object.keys(paymentMethodMap),
map: paymentMethodMap,
default: 'Cash',
required: 1,
},
{
fieldname: 'referenceId',
label: t`Ref. / Cheque No.`,
placeholder: 'Ref. / Cheque No.',
placeholder: t`Ref. / Cheque No.`,
fieldtype: 'Data',
required: (doc) => doc.paymentMethod !== 'Cash', // TODO: UNIQUE
hidden: (doc) => doc.paymentMethod === 'Cash',
@ -119,13 +126,13 @@ export default {
{
fieldname: 'referenceDate',
label: t`Ref. Date`,
placeholder: 'Ref. Date',
placeholder: t`Ref. Date`,
fieldtype: 'Date',
},
{
fieldname: 'clearanceDate',
label: t`Clearance Date`,
placeholder: 'Clearance Date',
placeholder: t`Clearance Date`,
fieldtype: 'Date',
hidden: (doc) => doc.paymentMethod === 'Cash',
},

View File

@ -16,7 +16,7 @@ export default {
{
fieldname: 'referenceType',
label: t`Reference Type`,
placeholder: 'Type',
placeholder: t`Type`,
fieldtype: 'Select',
options: Object.keys(referenceTypeMap),
map: referenceTypeMap,
@ -27,7 +27,7 @@ export default {
label: t`Reference Name`,
fieldtype: 'DynamicLink',
references: 'referenceType',
placeholder: 'Name',
placeholder: t`Name`,
getFilters() {
return {
outstandingAmount: ['>', 0],

View File

@ -20,7 +20,7 @@ export default {
fieldname: 'email',
label: t`Email`,
fieldtype: 'Data',
placeholder: 'john@doe.com',
placeholder: t`john@doe.com`,
validate: {
type: 'email',
},
@ -34,7 +34,7 @@ export default {
fieldname: 'phone',
label: t`Phone`,
fieldtype: 'Data',
placeholder: '9888900000',
placeholder: t`9888900000`,
validate: {
type: 'phone',
},
@ -44,13 +44,13 @@ export default {
label: t`Address`,
fieldtype: 'Link',
target: 'Address',
placeholder: 'Click to create',
placeholder: t`Click to create`,
inline: true,
},
{
fieldname: 'template',
label: t`Template`,
placeholder: 'Template',
placeholder: t`Template`,
fieldtype: 'Select',
options: ['Basic', 'Minimal', 'Business'],
default: 'Basic',
@ -58,7 +58,7 @@ export default {
{
fieldname: 'color',
label: t`Color`,
placeholder: 'Select Color',
placeholder: t`Select Color`,
fieldtype: 'Color',
colors: [
'red',
@ -86,7 +86,7 @@ export default {
{
fieldname: 'font',
label: t`Font`,
placeholder: 'Font',
placeholder: t`Font`,
fieldtype: 'Select',
options: ['Inter', 'Times New Roman', 'Arial', 'Courier'],
default: 'Inter',

View File

@ -10,7 +10,7 @@ export default {
{
fieldname: 'template',
label: t`Template`,
placeholder: 'Template',
placeholder: t`Template`,
fieldtype: 'Select',
options: ['Basic I', 'Basic II', 'Modern'],
required: 1,
@ -19,7 +19,7 @@ export default {
{
fieldname: 'font',
label: t`Font`,
placeholder: 'Font',
placeholder: t`Font`,
fieldtype: 'Select',
options: ['Montserrat', 'Open Sans', 'Oxygen', 'Merriweather'],
required: 1,

View File

@ -22,7 +22,7 @@ export default {
fieldname: 'country',
label: t`Country`,
fieldtype: 'AutoComplete',
placeholder: 'Select Country',
placeholder: t`Select Country`,
required: 1,
getList: () => Object.keys(countryList).sort(),
},
@ -31,7 +31,7 @@ export default {
fieldname: 'fullname',
label: t`Your Name`,
fieldtype: 'Data',
placeholder: 'John Doe',
placeholder: t`John Doe`,
required: 1,
},
@ -39,7 +39,7 @@ export default {
fieldname: 'email',
label: t`Email`,
fieldtype: 'Data',
placeholder: 'john@doe.com',
placeholder: t`john@doe.com`,
required: 1,
validate: {
type: 'email',
@ -49,7 +49,7 @@ export default {
{
fieldname: 'companyName',
label: t`Company Name`,
placeholder: 'Company Name',
placeholder: t`Company Name`,
fieldtype: 'Data',
required: 1,
},
@ -58,14 +58,14 @@ export default {
fieldname: 'bankName',
label: t`Bank Name`,
fieldtype: 'Data',
placeholder: 'Prime Bank',
placeholder: t`Prime Bank`,
required: 1,
},
{
fieldname: 'fiscalYearStart',
label: t`Fiscal Year Start Date`,
placeholder: 'Fiscal Year Start Date',
placeholder: t`Fiscal Year Start Date`,
fieldtype: 'Date',
formulaDependsOn: ['country'],
formula: (doc) => {
@ -84,7 +84,7 @@ export default {
{
fieldname: 'fiscalYearEnd',
label: t`Fiscal Year End Date`,
placeholder: 'Fiscal Year End Date',
placeholder: t`Fiscal Year End Date`,
fieldtype: 'Date',
formulaDependsOn: ['country'],
formula: (doc) => {
@ -103,7 +103,7 @@ export default {
fieldname: 'currency',
label: t`Currency`,
fieldtype: 'Data',
placeholder: 'Currency',
placeholder: t`Currency`,
formulaDependsOn: ['country'],
formula: (doc) => {
if (!doc.country) return;

View File

@ -19,7 +19,7 @@ export default {
label: t`Rate`,
fieldtype: 'Float',
required: 1,
placeholder: '0%',
placeholder: t`0%`,
},
],
tableFields: ['account', 'rate'],

View File

@ -5,6 +5,12 @@ import utils from '../../../accounting/utils';
import { statusColor } from '../../../src/colors';
export function getStatusColumn() {
const statusMap = {
Unpaid: t`Unpaid`,
Paid: t`Paid`,
Draft: t`Draft`,
Cancelled: t`Cancelled`,
};
return {
label: t`Status`,
fieldname: 'status',
@ -12,8 +18,9 @@ export function getStatusColumn() {
render(doc) {
const status = getInvoiceStatus(doc);
const color = statusColor[status];
const label = statusMap[status];
return {
template: `<Badge class="text-xs" color="${color}">${status}</Badge>`,
template: `<Badge class="text-xs" color="${color}">${label}</Badge>`,
components: { Badge },
};
},

View File

@ -1,15 +1,21 @@
import frappe, { t } from 'frappe';
import getCommonExportActions from '../commonExporter';
const periodicityMap = {
Monthly: t`Monthly`,
Quarterly: t`Quarterly`,
'Half Yearly': t`Half Yearly`,
Yearly: t`Yearly`,
};
export default {
title: 'Balance Sheet',
title: t`Balance Sheet`,
method: 'balance-sheet',
filterFields: [
{
fieldtype: 'Date',
fieldname: 'toDate',
size: 'small',
placeholder: 'ToDate',
placeholder: t`To Date`,
label: t`To Date`,
required: 1,
default: async () => {
@ -18,9 +24,10 @@ export default {
},
{
fieldtype: 'Select',
placeholder: 'Select Period',
placeholder: t`Select Period`,
size: 'small',
options: ['Monthly', 'Quarterly', 'Half Yearly', 'Yearly'],
options: Object.keys(periodicityMap),
map: periodicityMap,
label: t`Periodicity`,
fieldname: 'periodicity',
default: 'Monthly',

View File

@ -11,7 +11,7 @@ export default {
fieldtype: 'Link',
target: 'Account',
size: 'small',
placeholder: 'Payment Account',
placeholder: t`Payment Account`,
label: t`Payment Account`,
fieldname: 'paymentAccount',
getFilters: () => {
@ -26,20 +26,20 @@ export default {
target: 'Party',
size: 'small',
label: t`Party`,
placeholder: 'Party',
placeholder: t`Party`,
fieldname: 'party',
},
{
fieldtype: 'Date',
size: 'small',
placeholder: 'From Date',
placeholder: t`From Date`,
label: t`From Date`,
fieldname: 'fromDate',
},
{
fieldtype: 'Date',
size: 'small',
placeholder: 'To Date',
placeholder: t`To Date`,
label: t`To Date`,
fieldname: 'toDate',
},

View File

@ -2,7 +2,7 @@ import { partyWithAvatar } from '@/utils';
import { t } from 'frappe';
import getCommonExportActions from '../commonExporter';
let title = 'General Ledger';
let title = t`General Ledger`;
const viewConfig = {
title,
@ -19,13 +19,13 @@ const viewConfig = {
size: 'small',
label: t`Reference Type`,
fieldname: 'referenceType',
placeholder: 'Reference Type',
placeholder: t`Reference Type`,
default: 'All',
},
{
fieldtype: 'DynamicLink',
size: 'small',
placeholder: 'Reference Name',
placeholder: t`Reference Name`,
references: 'referenceType',
label: t`Reference Name`,
fieldname: 'referenceName',
@ -34,7 +34,7 @@ const viewConfig = {
fieldtype: 'Link',
target: 'Account',
size: 'small',
placeholder: 'Account',
placeholder: t`Account`,
label: t`Account`,
fieldname: 'account',
},
@ -43,20 +43,20 @@ const viewConfig = {
target: 'Party',
label: t`Party`,
size: 'small',
placeholder: 'Party',
placeholder: t`Party`,
fieldname: 'party',
},
{
fieldtype: 'Date',
size: 'small',
placeholder: 'From Date',
placeholder: t`From Date`,
label: t`From Date`,
fieldname: 'fromDate',
},
{
fieldtype: 'Date',
size: 'small',
placeholder: 'To Date',
placeholder: t`To Date`,
label: t`To Date`,
fieldname: 'toDate',
},

View File

@ -11,7 +11,7 @@ export default {
fieldtype: 'AutoComplete',
label: t`Place`,
size: 'small',
placeholder: 'Place',
placeholder: t`Place`,
fieldname: 'place',
getList: () => stateList,
},
@ -19,7 +19,7 @@ export default {
fieldtype: 'Date',
label: t`From Date`,
size: 'small',
placeholder: 'From Date',
placeholder: t`From Date`,
fieldname: 'fromDate',
default: () => DateTime.local().minus({ months: 3 }).toISODate(),
},
@ -27,7 +27,7 @@ export default {
fieldtype: 'Date',
label: t`To Date`,
size: 'small',
placeholder: 'To Date',
placeholder: t`To Date`,
fieldname: 'toDate',
default: () => DateTime.local().toISODate(),
},

View File

@ -13,7 +13,7 @@ const transferTypeMap = {
const transferType = {
fieldtype: 'Select',
label: t`Transfer Type`,
placeholder: 'Transfer Type',
placeholder: t`Transfer Type`,
fieldname: 'transferType',
options: Object.keys(transferTypeMap),
map: transferTypeMap,
@ -23,7 +23,7 @@ const transferType = {
const actions = [
{
group: 'Export',
group: t`Export`,
label: t`JSON`,
type: 'primary',
action: async (report, filters) => {
@ -31,7 +31,7 @@ const actions = [
},
},
{
group: 'Export',
group: t`Export`,
label: t`CSV`,
type: 'primary',
action: async (report, filters) => {

View File

@ -10,7 +10,7 @@ const transferTypeMap = {
const transferType = {
fieldtype: 'Select',
label: t`Transfer Type`,
placeholder: 'Transfer Type',
placeholder: t`Transfer Type`,
fieldname: 'transferType',
options: Object.keys(transferTypeMap),
map: transferTypeMap,
@ -20,7 +20,7 @@ const transferType = {
const actions = [
{
group: 'Export',
group: t`Export`,
label: t`CSV`,
type: 'primary',
action: async (report, filters) => {

View File

@ -1,8 +1,14 @@
import frappe, { t } from 'frappe';
import getCommonExportActions from '../commonExporter';
const title = 'Profit and Loss';
const title = t`Profit and Loss`;
const periodicityMap = {
Monthly: t`Monthly`,
Quarterly: t`Quarterly`,
'Half Yearly': t`Half Yearly`,
Yearly: t`Yearly`,
};
export default {
title: title,
method: 'profit-and-loss',
@ -12,7 +18,7 @@ export default {
fieldtype: 'Date',
fieldname: 'fromDate',
size: 'small',
placeholder: 'From Date',
placeholder: t`From Date`,
label: t`From Date`,
required: 1,
default: async () => {
@ -23,7 +29,7 @@ export default {
fieldtype: 'Date',
fieldname: 'toDate',
size: 'small',
placeholder: 'To Date',
placeholder: t`To Date`,
label: t`To Date`,
required: 1,
default: async () => {
@ -33,10 +39,11 @@ export default {
{
fieldtype: 'Select',
size: 'small',
options: ['Monthly', 'Quarterly', 'Half Yearly', 'Yearly'],
options: Object.keys(periodicityMap),
map: periodicityMap,
default: 'Monthly',
label: t`Periodicity`,
placeholder: 'Select Period...',
placeholder: t`Select Period...`,
fieldname: 'periodicity',
},
],

View File

@ -11,7 +11,7 @@ export default {
label: t`Supplier Name`,
fieldname: 'supplier',
size: 'small',
placeholder: 'Supplier Name',
placeholder: t`Supplier Name`,
getFilters: (query) => {
if (query)
return {
@ -28,14 +28,14 @@ export default {
fieldtype: 'Date',
fieldname: 'fromDate',
size: 'small',
placeholder: 'From Date',
placeholder: t`From Date`,
label: t`From Date`,
required: 1,
},
{
fieldtype: 'Date',
size: 'small',
placeholder: 'To Date',
placeholder: t`To Date`,
fieldname: 'toDate',
label: t`To Date`,
required: 1,

View File

@ -10,7 +10,7 @@ export default {
target: 'Party',
label: t`Customer Name`,
size: 'small',
placeholder: 'Customer Name',
placeholder: t`Customer Name`,
fieldname: 'customer',
getFilters: (query) => {
if (query)
@ -28,14 +28,14 @@ export default {
fieldtype: 'Date',
fieldname: 'fromDate',
size: 'small',
placeholder: 'From Date',
placeholder: t`From Date`,
label: t`From Date`,
required: 1,
},
{
fieldtype: 'Date',
size: 'small',
placeholder: 'To Date',
placeholder: t`To Date`,
fieldname: 'toDate',
label: t`To Date`,
required: 1,

View File

@ -1,7 +1,7 @@
import frappe, { t } from 'frappe';
import getCommonExportActions from '../commonExporter';
const title = 'Trial Balance';
const title = t`Trial Balance`;
export default {
title: title,
@ -13,7 +13,7 @@ export default {
fieldname: 'fromDate',
label: t`From Date`,
size: 'small',
placeholder: 'From Date',
placeholder: t`From Date`,
required: 1,
default: async () => {
return (await frappe.getSingle('AccountingSettings')).fiscalYearStart;
@ -22,7 +22,7 @@ export default {
{
fieldtype: 'Date',
size: 'small',
placeholder: 'To Date',
placeholder: t`To Date`,
fieldname: 'toDate',
label: t`To Date`,
required: 1,

View File

@ -95,7 +95,7 @@ async function exportReport(extention, reportName, getReportData) {
export default function getCommonExportActions(reportName) {
return ['csv', 'json'].map((ext) => ({
group: 'Export',
group: frappe.t`Export`,
label: ext.toUpperCase(),
type: 'primary',
action: async (getReportData) =>

View File

@ -31,7 +31,7 @@
size="small"
input-class="bg-gray-100"
:df="{
placeholder: 'Field',
placeholder: t`Field`,
fieldname: 'fieldname',
fieldtype: 'Select',
options: fieldOptions,
@ -45,7 +45,7 @@
size="small"
input-class="bg-gray-100"
:df="{
placeholder: 'Condition',
placeholder: t`Condition`,
fieldname: 'condition',
fieldtype: 'Select',
options: conditions,
@ -59,7 +59,7 @@
size="small"
input-class="bg-gray-100"
:df="{
placeholder: 'Value',
placeholder: t`Value`,
fieldname: 'value',
fieldtype: 'Data',
}"
@ -116,11 +116,11 @@
</template>
<script>
import Popover from './Popover';
import Button from './Button';
import Icon from './Icon';
import FormControl from './Controls/FormControl';
import { t } from 'frappe';
import Button from './Button';
import FormControl from './Controls/FormControl';
import Icon from './Icon';
import Popover from './Popover';
let conditions = [
{ label: t`Is`, value: '=' },

View File

@ -18,7 +18,7 @@
<input
type="search"
class="bg-gray-200 text-sm pl-8 focus:outline-none h-full w-56"
placeholder="Search..."
:placeholder="t`Search...`"
autocomplete="off"
spellcheck="false"
v-model="inputValue"
@ -41,11 +41,10 @@
</div>
</template>
<script>
import frappe from 'frappe';
import reports from '../../reports/view';
import Dropdown from '@/components/Dropdown';
import { routeTo } from '@/utils';
import { t } from 'frappe';
import frappe, { t } from 'frappe';
import reports from '../../reports/view';
export default {
data() {

View File

@ -89,21 +89,21 @@
class="pb-1 text-sm text-gray-600 hover:text-gray-800 w-full text-left"
@click="() => reportIssue()"
>
Report Issue
{{ t`Report Issue` }}
</button>
<p class="pb-3 text-sm text-gray-600">v{{ appVersion }}</p>
</div>
</div>
</template>
<script>
import { reportIssue } from '@/errorHandling';
import sidebarConfig from '../sidebarConfig';
import Button from '@/components/Button';
import WindowControls from './WindowControls';
import { reportIssue } from '@/errorHandling';
import { routeTo } from '@/utils';
import path from 'path';
import router from '../router';
import sidebarConfig from '../sidebarConfig';
import Icon from './Icon.vue';
import WindowControls from './WindowControls';
export default {
components: [Button],

View File

@ -49,11 +49,8 @@
</template>
<script>
import config, {
ConfigKeys,
telemetryOptions,
TelemetrySetting
} from '@/config';
import config, { ConfigKeys, TelemetrySetting } from '@/config';
import { getTelemetryOptions } from '@/telemetry/helpers';
import telemetry from '@/telemetry/telemetry';
import { NounEnum, Verb } from '@/telemetry/types';
import Button from '../Button.vue';
@ -72,6 +69,7 @@ export default {
},
computed: {
df() {
const telemetryOptions = getTelemetryOptions();
return {
fieldname: 'anonymizedTelemetry',
label: this.t`Anonymized Telemetry`,
@ -106,7 +104,7 @@ export default {
if (this.value === TelemetrySetting.dontLogUsage) {
telemetry.finalLogAndStop();
} else {
telemetry.log(Verb.Started, NounEnum.Telemetry)
telemetry.log(Verb.Started, NounEnum.Telemetry);
}
config.set(ConfigKeys.Telemetry, this.value);

View File

@ -19,12 +19,6 @@ export enum TelemetrySetting {
dontLogAnything = 'dontLogAnything',
}
export const telemetryOptions = {
[TelemetrySetting.allow]: frappe.t`Allow Telemetry`,
[TelemetrySetting.dontLogUsage]: frappe.t`Don't Log Usage`,
[TelemetrySetting.dontLogAnything]: frappe.t`Don't Log Anything`,
};
export interface ConfigFile {
id: string;
companyName: string;

View File

@ -1,3 +1,11 @@
<script setup>
const periodSelectorMap = {
'This Year': t`This Year`,
'This Quarter': t`This Quarter`,
'This Month': t`This Month`,
};
</script>
<template>
<Dropdown ref="dropdown" class="text-sm" :items="periodOptions" right>
<template
@ -28,7 +36,7 @@
@keydown.up="highlightItemUp"
@keydown.enter="selectHighlightedItem"
>
{{ value }}
{{ periodSelectorMap[value] }}
<feather-icon name="chevron-down" class="ml-1 w-3 h-3" />
</div>
</template>
@ -37,6 +45,8 @@
<script>
import Dropdown from '@/components/Dropdown';
import { t } from 'frappe';
export default {
name: 'PeriodSelector',
props: {
@ -54,7 +64,7 @@ export default {
return {
periodOptions: this.options.map((option) => {
return {
label: option,
label: this.periodSelectorMap[option],
action: () => this.selectOption(option),
};
}),

View File

@ -68,13 +68,12 @@
</div>
</template>
<script>
import frappe from 'frappe';
import Button from '@/components/Button';
import { routeTo } from '@/utils';
import frappe, { t } from 'frappe';
import { getDatesAndPeriodicity } from './getDatesAndPeriodicity';
import PeriodSelector from './PeriodSelector';
import SectionHeader from './SectionHeader';
import { getDatesAndPeriodicity } from './getDatesAndPeriodicity';
import { routeTo } from '@/utils';
export default {
name: 'UnpaidInvoices',
components: {
@ -85,7 +84,7 @@ export default {
data: () => ({
invoices: [
{
title: 'Invoices',
title: t`Invoices`,
doctype: 'SalesInvoice',
total: 0,
unpaid: 0,
@ -96,7 +95,7 @@ export default {
barWidth: 40,
},
{
title: 'Bills',
title: t`Bills`,
doctype: 'PurchaseInvoice',
total: 0,
unpaid: 0,

View File

@ -449,7 +449,7 @@ export default {
fieldname: 'importType',
label: this.t`Import Type`,
fieldtype: 'AutoComplete',
placeholder: 'Import Type',
placeholder: this.t`Import Type`,
getList: () => importable.map((i) => frappe.models[i].label),
};
},

View File

@ -101,7 +101,7 @@
class="text-brand text-sm mt-4 inline-block cursor-pointer"
@click="showFiles = true"
>
Select from existing files
{{ t`Select from existing files` }}
</a>
</div>
@ -144,7 +144,7 @@
class="text-brand text-sm cursor-pointer"
@click="showFiles = false"
>
Select file manually
{{ t`Select file manually` }}
</a>
</div>
</div>
@ -158,15 +158,14 @@
</div>
</template>
<script>
import fs from 'fs';
import config from '@/config';
import { DateTime } from 'luxon';
import { ipcRenderer } from 'electron';
import { DB_CONN_FAILURE, IPC_ACTIONS } from '../messages';
import { createNewDatabase, connectToLocalDatabase } from '@/initialization';
import { showErrorDialog } from '../errorHandling';
import LanguageSelector from '@/components/Controls/LanguageSelector.vue';
import config from '@/config';
import { connectToLocalDatabase, createNewDatabase } from '@/initialization';
import { ipcRenderer } from 'electron';
import fs from 'fs';
import { DateTime } from 'luxon';
import { showErrorDialog } from '../errorHandling';
import { DB_CONN_FAILURE, IPC_ACTIONS } from '../messages';
export default {
name: 'DatabaseSelector',

View File

@ -84,15 +84,13 @@
</template>
<script>
import frappe from 'frappe';
import { t } from 'frappe';
import PageHeader from '@/components/PageHeader';
import Icon from '@/components/Icon';
import Button from '@/components/Button';
import { openSettings } from '@/utils';
import { ipcRenderer } from 'electron';
import Icon from '@/components/Icon';
import PageHeader from '@/components/PageHeader';
import { IPC_MESSAGES } from '@/messages';
import { routeTo } from '@/utils';
import { openSettings, routeTo } from '@/utils';
import { ipcRenderer } from 'electron';
import frappe, { t } from 'frappe';
import { h } from 'vue';
export default {
@ -115,7 +113,7 @@ export default {
label: t`Invoice`,
icon: 'invoice',
description:
'Customize your invoices by adding a logo and address details',
t`Customize your invoices by adding a logo and address details`,
fieldname: 'invoiceSetup',
action() {
openSettings('Invoice');
@ -126,7 +124,7 @@ export default {
label: t`General`,
icon: 'general',
description:
'Setup your company information, email, country and fiscal year',
t`Setup your company information, email, country and fiscal year`,
fieldname: 'companySetup',
action() {
openSettings('General');
@ -137,7 +135,7 @@ export default {
label: t`System`,
icon: 'system',
description:
'Setup system defaults like date format and display precision',
t`Setup system defaults like date format and display precision`,
fieldname: 'systemSetup',
action() {
openSettings('System');
@ -154,7 +152,7 @@ export default {
label: t`Review Accounts`,
icon: 'review-ac',
description:
'Review your chart of accounts, add any account or tax heads as needed',
t`Review your chart of accounts, add any account or tax heads as needed`,
action: () => {
routeTo('/chart-of-accounts');
},
@ -168,7 +166,7 @@ export default {
icon: 'opening-ac',
fieldname: 'openingBalanceChecked',
description:
'Setup your opening balances before performing any accounting entries',
t`Setup your opening balances before performing any accounting entries`,
documentation:
'https://frappebooks.com/docs/setting-up#5-setup-opening-balances',
},
@ -178,7 +176,7 @@ export default {
icon: 'percentage',
fieldname: 'taxesAdded',
description:
'Setup your tax templates for your sales or purchase transactions',
t`Setup your tax templates for your sales or purchase transactions`,
action: () => routeTo('/list/Tax'),
documentation:
'https://frappebooks.com/docs/setting-up#2-add-taxes',
@ -194,7 +192,7 @@ export default {
label: t`Add Items`,
icon: 'item',
description:
'Add products or services that you sell to your customers',
t`Add products or services that you sell to your customers`,
action: () => routeTo('/list/Item'),
fieldname: 'itemCreated',
documentation:
@ -204,7 +202,7 @@ export default {
key: 'Add Customers',
label: t`Add Customers`,
icon: 'customer',
description: 'Add a few customers to create your first invoice',
description: t`Add a few customers to create your first invoice`,
action: () => routeTo('/list/Customer'),
fieldname: 'customerCreated',
documentation:
@ -215,7 +213,7 @@ export default {
label: t`Create Invoice`,
icon: 'sales-invoice',
description:
'Create your first invoice and mail it to your customer',
t`Create your first invoice and mail it to your customer`,
action: () => routeTo('/list/SalesInvoice'),
fieldname: 'invoiceCreated',
documentation: 'https://frappebooks.com/docs/invoices',
@ -231,7 +229,7 @@ export default {
label: t`Add Items`,
icon: 'item',
description:
'Add products or services that you buy from your suppliers',
t`Add products or services that you buy from your suppliers`,
action: () => routeTo('/list/Item'),
fieldname: 'itemCreated',
},
@ -239,7 +237,7 @@ export default {
key: 'Add Suppliers',
label: t`Add Suppliers`,
icon: 'supplier',
description: 'Add a few suppliers to create your first bill',
description: t`Add a few suppliers to create your first bill`,
action: () => routeTo('/list/Supplier'),
fieldname: 'supplierCreated',
},
@ -248,7 +246,7 @@ export default {
label: t`Create Bill`,
icon: 'purchase-invoice',
description:
'Create your first bill and mail it to your supplier',
t`Create your first bill and mail it to your supplier`,
action: () => routeTo('/list/PurchaseInvoice'),
fieldname: 'billCreated',
documentation: 'https://frappebooks.com/docs/bills',

View File

@ -48,20 +48,20 @@
</div>
<div v-else class="flex flex-col items-center justify-center my-auto">
<img src="@/assets/img/list-empty-state.svg" alt="" class="w-24" />
<p class="my-3 text-gray-800">No {{ meta.label || meta.name }} found</p>
<p class="my-3 text-gray-800">{{ t`No entries found` }}</p>
<Button type="primary" class="text-white" @click="$emit('makeNewDoc')">
Create a new {{ meta.label || meta.name }}
{{ t`Make Entry` }}
</Button>
</div>
</div>
</template>
<script>
import frappe from 'frappe';
import Row from '@/components/Row';
import ListCell from './ListCell';
import Avatar from '@/components/Avatar';
import { openQuickEdit, routeTo } from '@/utils';
import Button from '@/components/Button';
import Row from '@/components/Row';
import { openQuickEdit, routeTo } from '@/utils';
import frappe from 'frappe';
import ListCell from './ListCell';
export default {
name: 'List',

View File

@ -37,7 +37,6 @@ import SearchBar from '@/components/SearchBar';
import { routeTo } from '@/utils';
import frappe from 'frappe';
import List from './List';
import listConfigs from './listConfig';
export default {
name: 'ListView',
@ -49,10 +48,17 @@ export default {
SearchBar,
FilterDropdown,
},
activated() {
data() {
return { listConfigs: undefined };
},
async activated() {
if (typeof this.filters === 'object') {
this.$refs.filterDropdown.setFilter(this.filters);
}
if (this.listConfigs === undefined) {
this.listConfigs = (await import('./listConfig')).default;
}
},
methods: {
async makeNewDoc() {
@ -102,8 +108,8 @@ export default {
return frappe.getMeta(this.doctype);
},
listConfig() {
if (listConfigs[this.doctype]) {
return listConfigs[this.doctype];
if (this?.listConfigs?.[this?.doctype]) {
return this.listConfigs[this.doctype];
} else {
return {
title: this.doctype,

View File

@ -31,7 +31,7 @@
"
@click="checkForUpdates(true)"
>
Check for Updates
{{ t`Check for Updates` }}
</button>
</div>
</div>
@ -43,9 +43,9 @@ import LanguageSelector from '@/components/Controls/LanguageSelector.vue';
import TwoColumnForm from '@/components/TwoColumnForm';
import config, {
ConfigKeys,
telemetryOptions,
TelemetrySetting
} from '@/config';
import { getTelemetryOptions } from '@/telemetry/helpers';
import telemetry from '@/telemetry/telemetry';
import { checkForUpdates } from '@/utils';
import frappe from 'frappe';
@ -71,6 +71,7 @@ export default {
},
computed: {
df() {
const telemetryOptions = getTelemetryOptions();
return {
fieldname: 'anonymizedTelemetry',
label: this.t`Anonymized Telemetry`,

View File

@ -1,6 +1,7 @@
import config, { ConfigFile, ConfigKeys } from '@/config';
import config, { ConfigFile, ConfigKeys, TelemetrySetting } from '@/config';
import { IPC_ACTIONS } from '@/messages';
import { ipcRenderer } from 'electron';
import frappe, { t } from 'frappe';
import { DoctypeName } from '../../models/types';
import { Count, UniqueId } from './types';
@ -38,6 +39,10 @@ export async function getCounts(): Promise<Count> {
];
const countMap: Count = {};
// @ts-ignore
if (frappe.db === undefined) {
return countMap;
}
type CountResponse = { 'count(*)': number }[];
for (const name of interestingDocs) {
@ -132,3 +137,9 @@ export async function getCreds() {
const token: string = creds?.tokenString ?? '';
return { url, token };
}
export const getTelemetryOptions = () => ({
[TelemetrySetting.allow]: t`Allow Telemetry`,
[TelemetrySetting.dontLogUsage]: t`Don't Log Usage`,
[TelemetrySetting.dontLogAnything]: t`Don't Log Anything`,
});

View File

@ -309,7 +309,7 @@ export async function runWindowAction(name) {
}
export function getInvoiceStatus(doc) {
let status = 'Unpaid';
let status = `Unpaid`;
if (!doc.submitted) {
status = 'Draft';
}
@ -526,6 +526,7 @@ async function fetchAndSetLanguageMap(code) {
if (!success) {
showToast({ type: 'error', message });
} else {
window.lm = languageMap;
setLanguageMapOnTranslationString(languageMap);
}