mirror of
https://github.com/bigcapitalhq/bigcapital.git
synced 2026-02-19 14:20:31 +00:00
Compare commits
2 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
80e545072d | ||
|
|
de3d4698ea |
@@ -9,5 +9,10 @@
|
|||||||
"net_cash_financing": "Net cash provided by financing activities",
|
"net_cash_financing": "Net cash provided by financing activities",
|
||||||
"cash_beginning_period": "Cash at beginning of period",
|
"cash_beginning_period": "Cash at beginning of period",
|
||||||
"net_cash_increase": "NET CASH INCREASE FOR PERIOD",
|
"net_cash_increase": "NET CASH INCREASE FOR PERIOD",
|
||||||
"cash_end_period": "CASH AT END OF PERIOD"
|
"cash_end_period": "CASH AT END OF PERIOD",
|
||||||
|
"account_name": "Account name",
|
||||||
|
"total": "Total",
|
||||||
|
"sheet_name": "Statement of Cash Flow",
|
||||||
|
"from_date": "From",
|
||||||
|
"to_date": "To"
|
||||||
}
|
}
|
||||||
|
|||||||
5
packages/server/src/i18n/en/contact_summary_balance.json
Normal file
5
packages/server/src/i18n/en/contact_summary_balance.json
Normal file
@@ -0,0 +1,5 @@
|
|||||||
|
{
|
||||||
|
"account_name": "Account name",
|
||||||
|
"total": "Total",
|
||||||
|
"percentage_column": "% of Column"
|
||||||
|
}
|
||||||
14
packages/server/src/i18n/en/inventory_item_details.json
Normal file
14
packages/server/src/i18n/en/inventory_item_details.json
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
{
|
||||||
|
"opening_balance": "Opening balance",
|
||||||
|
"closing_balance": "Closing balance",
|
||||||
|
"date": "Date",
|
||||||
|
"transaction_type": "Transaction type",
|
||||||
|
"transaction_number": "Transaction #",
|
||||||
|
"quantity": "Quantity",
|
||||||
|
"rate": "Rate",
|
||||||
|
"total": "Total",
|
||||||
|
"value": "Value",
|
||||||
|
"profit_margin": "Profit Margin",
|
||||||
|
"running_quantity": "Running quantity",
|
||||||
|
"running_value": "Running Value"
|
||||||
|
}
|
||||||
4
packages/server/src/i18n/en/transactions_by_contact.json
Normal file
4
packages/server/src/i18n/en/transactions_by_contact.json
Normal file
@@ -0,0 +1,4 @@
|
|||||||
|
{
|
||||||
|
"opening_balance": "Opening balance",
|
||||||
|
"closing_balance": "Closing balance"
|
||||||
|
}
|
||||||
6
packages/server/src/i18n/en/trial_balance_sheet.json
Normal file
6
packages/server/src/i18n/en/trial_balance_sheet.json
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
{
|
||||||
|
"account": "Account",
|
||||||
|
"debit": "Debit",
|
||||||
|
"credit": "Credit",
|
||||||
|
"total": "Total"
|
||||||
|
}
|
||||||
@@ -239,7 +239,7 @@ export class CashFlowTable {
|
|||||||
section: ICashFlowStatementSection,
|
section: ICashFlowStatementSection,
|
||||||
): ICashFlowStatementSection => {
|
): ICashFlowStatementSection => {
|
||||||
const label = section.footerLabel
|
const label = section.footerLabel
|
||||||
? section.footerLabel
|
? this.i18n.t(section.footerLabel)
|
||||||
: this.i18n.t('financial_sheet.total_row', {
|
: this.i18n.t('financial_sheet.total_row', {
|
||||||
args: { value: section.label },
|
args: { value: section.label },
|
||||||
});
|
});
|
||||||
@@ -302,7 +302,7 @@ export class CashFlowTable {
|
|||||||
* @returns {ITableColumn}
|
* @returns {ITableColumn}
|
||||||
*/
|
*/
|
||||||
private totalColumns = (): ITableColumn[] => {
|
private totalColumns = (): ITableColumn[] => {
|
||||||
return [{ key: 'total', label: this.i18n.t('Total') }];
|
return [{ key: 'total', label: this.i18n.t('cash_flow_statement.total') }];
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -366,7 +366,7 @@ export class CashFlowTable {
|
|||||||
*/
|
*/
|
||||||
public tableColumns = (): ITableColumn[] => {
|
public tableColumns = (): ITableColumn[] => {
|
||||||
return R.compose(
|
return R.compose(
|
||||||
R.concat([{ key: 'name', label: this.i18n.t('Account name') }]),
|
R.concat([{ key: 'name', label: this.i18n.t('cash_flow_statement.account_name') }]),
|
||||||
R.when(
|
R.when(
|
||||||
R.always(this.isDisplayColumnsBy(DISPLAY_COLUMNS_BY.DATE_PERIODS)),
|
R.always(this.isDisplayColumnsBy(DISPLAY_COLUMNS_BY.DATE_PERIODS)),
|
||||||
R.concat(this.datePeriodsColumns()),
|
R.concat(this.datePeriodsColumns()),
|
||||||
|
|||||||
@@ -1,5 +1,6 @@
|
|||||||
import * as moment from 'moment';
|
import * as moment from 'moment';
|
||||||
import { Injectable } from '@nestjs/common';
|
import { Injectable } from '@nestjs/common';
|
||||||
|
import { I18nService } from 'nestjs-i18n';
|
||||||
import { FinancialSheetMeta } from '../../common/FinancialSheetMeta';
|
import { FinancialSheetMeta } from '../../common/FinancialSheetMeta';
|
||||||
import {
|
import {
|
||||||
ICashFlowStatementMeta,
|
ICashFlowStatementMeta,
|
||||||
@@ -8,7 +9,10 @@ import {
|
|||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class CashflowSheetMeta {
|
export class CashflowSheetMeta {
|
||||||
constructor(private readonly financialSheetMeta: FinancialSheetMeta) {}
|
constructor(
|
||||||
|
private readonly financialSheetMeta: FinancialSheetMeta,
|
||||||
|
private readonly i18n: I18nService,
|
||||||
|
) {}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Cashflow sheet meta.
|
* Cashflow sheet meta.
|
||||||
@@ -21,9 +25,11 @@ export class CashflowSheetMeta {
|
|||||||
const meta = await this.financialSheetMeta.meta();
|
const meta = await this.financialSheetMeta.meta();
|
||||||
const formattedToDate = moment(query.toDate).format('YYYY/MM/DD');
|
const formattedToDate = moment(query.toDate).format('YYYY/MM/DD');
|
||||||
const formattedFromDate = moment(query.fromDate).format('YYYY/MM/DD');
|
const formattedFromDate = moment(query.fromDate).format('YYYY/MM/DD');
|
||||||
const formattedDateRange = `From ${formattedFromDate} | To ${formattedToDate}`;
|
const fromLabel = this.i18n.t('cash_flow_statement.from_date');
|
||||||
|
const toLabel = this.i18n.t('cash_flow_statement.to_date');
|
||||||
|
const formattedDateRange = `${fromLabel} ${formattedFromDate} | ${toLabel} ${formattedToDate}`;
|
||||||
|
|
||||||
const sheetName = 'Statement of Cash Flow';
|
const sheetName = this.i18n.t('cash_flow_statement.sheet_name');
|
||||||
|
|
||||||
return {
|
return {
|
||||||
...meta,
|
...meta,
|
||||||
|
|||||||
@@ -91,7 +91,7 @@ export class CustomerBalanceSummaryTable {
|
|||||||
*/
|
*/
|
||||||
private getTotalColumnsAccessor = (): IColumnMapperMeta[] => {
|
private getTotalColumnsAccessor = (): IColumnMapperMeta[] => {
|
||||||
const columns = [
|
const columns = [
|
||||||
{ key: 'name', value: this.i18n.t('Total') },
|
{ key: 'name', value: this.i18n.t('contact_summary_balance.total') },
|
||||||
{ key: 'total', accessor: 'total.formattedAmount' },
|
{ key: 'total', accessor: 'total.formattedAmount' },
|
||||||
];
|
];
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
|
|||||||
@@ -93,7 +93,7 @@ export class InventoryItemDetailsTable {
|
|||||||
): ITableRow => {
|
): ITableRow => {
|
||||||
const columns: Array<IColumnMapperMeta> = [
|
const columns: Array<IColumnMapperMeta> = [
|
||||||
{ key: 'date', accessor: 'date.formattedDate' },
|
{ key: 'date', accessor: 'date.formattedDate' },
|
||||||
{ key: 'closing', value: this.i18n.t('Opening balance') },
|
{ key: 'closing', value: this.i18n.t('inventory_item_details.opening_balance') },
|
||||||
{ key: 'empty', value: '' },
|
{ key: 'empty', value: '' },
|
||||||
{ key: 'quantity', accessor: 'quantity.formattedNumber' },
|
{ key: 'quantity', accessor: 'quantity.formattedNumber' },
|
||||||
{ key: 'empty', value: '' },
|
{ key: 'empty', value: '' },
|
||||||
@@ -115,7 +115,7 @@ export class InventoryItemDetailsTable {
|
|||||||
): ITableRow => {
|
): ITableRow => {
|
||||||
const columns: Array<IColumnMapperMeta> = [
|
const columns: Array<IColumnMapperMeta> = [
|
||||||
{ key: 'date', accessor: 'date.formattedDate' },
|
{ key: 'date', accessor: 'date.formattedDate' },
|
||||||
{ key: 'closing', value: this.i18n.t('Closing balance') },
|
{ key: 'closing', value: this.i18n.t('inventory_item_details.closing_balance') },
|
||||||
{ key: 'empty', value: '' },
|
{ key: 'empty', value: '' },
|
||||||
{ key: 'quantity', accessor: 'quantity.formattedNumber' },
|
{ key: 'quantity', accessor: 'quantity.formattedNumber' },
|
||||||
{ key: 'empty', value: '' },
|
{ key: 'empty', value: '' },
|
||||||
@@ -193,16 +193,16 @@ export class InventoryItemDetailsTable {
|
|||||||
*/
|
*/
|
||||||
public tableColumns = (): ITableColumn[] => {
|
public tableColumns = (): ITableColumn[] => {
|
||||||
return [
|
return [
|
||||||
{ key: 'date', label: this.i18n.t('Date') },
|
{ key: 'date', label: this.i18n.t('inventory_item_details.date') },
|
||||||
{ key: 'transaction_type', label: this.i18n.t('Transaction type') },
|
{ key: 'transaction_type', label: this.i18n.t('inventory_item_details.transaction_type') },
|
||||||
{ key: 'transaction_id', label: this.i18n.t('Transaction #') },
|
{ key: 'transaction_id', label: this.i18n.t('inventory_item_details.transaction_number') },
|
||||||
{ key: 'quantity', label: this.i18n.t('Quantity') },
|
{ key: 'quantity', label: this.i18n.t('inventory_item_details.quantity') },
|
||||||
{ key: 'rate', label: this.i18n.t('Rate') },
|
{ key: 'rate', label: this.i18n.t('inventory_item_details.rate') },
|
||||||
{ key: 'total', label: this.i18n.t('Total') },
|
{ key: 'total', label: this.i18n.t('inventory_item_details.total') },
|
||||||
{ key: 'value', label: this.i18n.t('Value') },
|
{ key: 'value', label: this.i18n.t('inventory_item_details.value') },
|
||||||
{ key: 'profit_margin', label: this.i18n.t('Profit Margin') },
|
{ key: 'profit_margin', label: this.i18n.t('inventory_item_details.profit_margin') },
|
||||||
{ key: 'running_quantity', label: this.i18n.t('Running quantity') },
|
{ key: 'running_quantity', label: this.i18n.t('inventory_item_details.running_quantity') },
|
||||||
{ key: 'running_value', label: this.i18n.t('Running Value') },
|
{ key: 'running_value', label: this.i18n.t('inventory_item_details.running_value') },
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -52,7 +52,7 @@ export class TransactionsByContactsTableRows {
|
|||||||
const columns = [
|
const columns = [
|
||||||
{
|
{
|
||||||
key: 'openingBalanceLabel',
|
key: 'openingBalanceLabel',
|
||||||
value: this.i18n.t('Opening balance') as string,
|
value: this.i18n.t('transactions_by_contact.opening_balance') as string,
|
||||||
},
|
},
|
||||||
...R.repeat({ key: 'empty', value: '' }, 5),
|
...R.repeat({ key: 'empty', value: '' }, 5),
|
||||||
{
|
{
|
||||||
@@ -76,7 +76,7 @@ export class TransactionsByContactsTableRows {
|
|||||||
const columns = [
|
const columns = [
|
||||||
{
|
{
|
||||||
key: 'closingBalanceLabel',
|
key: 'closingBalanceLabel',
|
||||||
value: this.i18n.t('Closing balance') as string,
|
value: this.i18n.t('transactions_by_contact.closing_balance') as string,
|
||||||
},
|
},
|
||||||
...R.repeat({ key: 'empty', value: '' }, 5),
|
...R.repeat({ key: 'empty', value: '' }, 5),
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -141,10 +141,10 @@ export class TrialBalanceSheetTable extends R.compose(
|
|||||||
return R.compose(
|
return R.compose(
|
||||||
this.tableColumnsCellIndexing,
|
this.tableColumnsCellIndexing,
|
||||||
R.concat([
|
R.concat([
|
||||||
{ key: 'account', label: 'Account' },
|
{ key: 'account', label: this.i18n.t('trial_balance_sheet.account') },
|
||||||
{ key: 'debit', label: 'Debit' },
|
{ key: 'debit', label: this.i18n.t('trial_balance_sheet.debit') },
|
||||||
{ key: 'credit', label: 'Credit' },
|
{ key: 'credit', label: this.i18n.t('trial_balance_sheet.credit') },
|
||||||
{ key: 'total', label: 'Total' },
|
{ key: 'total', label: this.i18n.t('trial_balance_sheet.total') },
|
||||||
]),
|
]),
|
||||||
)([]);
|
)([]);
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -91,7 +91,7 @@ export class VendorBalanceSummaryTable {
|
|||||||
*/
|
*/
|
||||||
private getTotalColumnsAccessor = (): IColumnMapperMeta[] => {
|
private getTotalColumnsAccessor = (): IColumnMapperMeta[] => {
|
||||||
const columns = [
|
const columns = [
|
||||||
{ key: 'name', value: this.i18n.t('Total') },
|
{ key: 'name', value: this.i18n.t('contact_summary_balance.total') },
|
||||||
{ key: 'total', accessor: 'total.formattedAmount' },
|
{ key: 'total', accessor: 'total.formattedAmount' },
|
||||||
];
|
];
|
||||||
return R.compose(
|
return R.compose(
|
||||||
|
|||||||
Reference in New Issue
Block a user