taxtank-core 0.33.44 → 0.33.45

Sign up to get free protection for your applications and to get access to all the features.
@@ -1,4 +1,4 @@
1
- import { Dictionary } from '../../models';
1
+ import { CHART_ACCOUNTS_CATEGORIES, Dictionary } from '../../models';
2
2
  import { ChartAccountsListEnum } from '../../db/Enums';
3
3
  import { TankTypeEnum } from '../../db/Enums/tank-type.enum';
4
4
  import { plainToClass } from 'class-transformer';
@@ -16,6 +16,9 @@ export class TransactionCollection extends TransactionBaseCollection {
16
16
  * we use depreciations as expense transactions a lot
17
17
  */
18
18
  constructor(transactions = [], depreciations = []) {
19
+ if (depreciations.length) {
20
+ transactions = transactions.filter(transaction => !CHART_ACCOUNTS_CATEGORIES.depreciation.includes(transaction.chartAccounts.category));
21
+ }
19
22
  super([...transactions, ...depreciations.map((depreciation) => depreciation.toTransaction())]);
20
23
  }
21
24
  getSoleTransactions() {
@@ -228,4 +231,4 @@ export class TransactionCollection extends TransactionBaseCollection {
228
231
  return this.filter(transaction => transaction.claimPercent > 0);
229
232
  }
230
233
  }
231
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction.collection.js","sourceRoot":"","sources":["../../../../../../../projects/tt-core/src/lib/collections/transaction/transaction.collection.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Dictionary,\n  Transaction,\n  TransactionMetaField,\n  VehicleClaim\n} from '../../models';\nimport { TransactionAllocationCollection } from './transaction-allocation.collection';\nimport { ChartAccountsCategoryEnum, ChartAccountsListEnum } from '../../db/Enums';\nimport { TankTypeEnum } from '../../db/Enums/tank-type.enum';\nimport { plainToClass } from 'class-transformer';\nimport { ExportCell } from '../../models/export/export-cell';\nimport { ExportCellTypeEnum } from '../../models/export/export-cell-type.enum';\nimport { Collection } from '../collection';\nimport { ChartData } from '../../models/chart/chart-data';\nimport { Depreciation, FinancialYear, MONTHS } from '../../models';\nimport { SoleInvoiceCollection } from '../sole';\nimport { TransactionBaseCollection } from './transaction-base.collection';\n\n/**\n * Collection of transactions\n */\nexport class TransactionCollection extends TransactionBaseCollection<Transaction> {\n  /**\n   * we use depreciations as expense transactions a lot\n   */\n  constructor(transactions: Transaction[] = [], depreciations: Depreciation[] = []) {\n    super([...transactions, ...depreciations.map((depreciation) => depreciation.toTransaction())]);\n  }\n\n  getSoleTransactions(): this {\n    return this.filter((transaction: Transaction) => transaction.isSoleTank());\n  }\n\n  getFindAndMatch(allocations: TransactionAllocationCollection): this {\n    return this.filter((transaction) => transaction.canFindAndMatch(allocations));\n  }\n\n  getUnallocated(allocations: TransactionAllocationCollection): TransactionCollection {\n    return new TransactionCollection(\n      this.items.filter((transaction: Transaction): boolean => !transaction.isAllocated(allocations))\n    );\n  }\n\n  getUnallocatedAmount(allocations: TransactionAllocationCollection): number {\n    return this.items.reduce((sum: number, transaction: Transaction): number =>\n      sum + transaction.getUnallocatedAmount(allocations.filterBy('transaction.id', transaction.id)), 0);\n  }\n\n  /**\n   * get date of the last transaction\n   */\n  getLastTransactionDate(): Date {\n    return new Date(Math.max.apply(Math, this.items.map((transaction: Transaction) => transaction.date)));\n  }\n\n  get amount(): number {\n    return this.sumBy('amount');\n  }\n\n  get claimAmount(): number {\n    return this.items.reduce((sum: number, transaction: Transaction) => sum + transaction.claimAmount, 0);\n  }\n\n  get grossAmount(): number {\n    return this.items.reduce((sum: number, transaction: Transaction) => sum + transaction.grossAmount, 0);\n  }\n\n  get grossClaimAmount(): number {\n    return this.items.reduce((sum: number, transaction: Transaction) => sum + transaction.grossClaimAmount, 0);\n  }\n\n  getByChartAccountsCategories(categories: ChartAccountsCategoryEnum[]): TransactionCollection {\n    return new TransactionCollection(\n      this.items.filter((transaction: Transaction): boolean => categories.includes(transaction.chartAccounts.category))\n    );\n  }\n\n  /**\n   * Get transactions by month\n   * @param monthIndex by which desired month should be taken\n   */\n  getByMonth(monthIndex: number): TransactionCollection {\n    return new TransactionCollection(this.items.filter((transaction: Transaction): boolean =>\n      transaction.date.getMonth() === monthIndex\n    ));\n  }\n\n  /**\n   * Get collection of transactions meta fields\n   */\n  getTransactionsMetaFields(): Collection<TransactionMetaField> {\n    const metaFieldsArray: TransactionMetaField[] = [];\n\n    this.items.forEach((transaction: Transaction) => {\n      metaFieldsArray.push(...transaction.metaFields);\n    });\n\n    return new Collection<TransactionMetaField>(metaFieldsArray);\n  }\n\n  getIncomeTransactions(): TransactionCollection {\n    return new TransactionCollection(\n      this.items.filter((transaction: Transaction): boolean => transaction.isIncome())\n    );\n  }\n\n  getExpenseTransactions(): TransactionCollection {\n    return new TransactionCollection(\n      this.items.filter((transaction: Transaction): boolean => transaction.isExpense() && !transaction.isInterest())\n    );\n  }\n\n  get claimIncome(): number {\n    return this.getIncomeTransactions().claimAmount;\n  }\n\n  get claimExpense(): number {\n    return this.getExpenseTransactions().claimAmount;\n  }\n\n  getInterestTransactions(): TransactionCollection {\n    return new TransactionCollection(\n      this.items.filter((transaction: Transaction): boolean => transaction.isInterest())\n    );\n  }\n\n  get claimInterest(): number {\n    return this.getInterestTransactions().claimAmount;\n  }\n\n  /**\n   * Get collection of transactions and properties filtered by properties ids\n   * @param ids Ids of properties for filter\n   */\n  getByPropertiesIds(ids: number[]): TransactionCollection {\n    return new TransactionCollection(\n      this.items.filter((transaction: Transaction): boolean => ids.includes(transaction.property?.id))\n    );\n  }\n\n  /**\n   * Get new collection filtered by income source id\n   * @param id id of income source for filter\n   */\n  getByIncomeSourceId(id: number): TransactionCollection {\n    return new TransactionCollection(\n      this.items.filter((transaction: Transaction): boolean => transaction.incomeSource?.id === id)\n    );\n  }\n\n  /**\n   * Get new collection filtered by chart accounts category\n   * @param category Chart accounts category value\n   */\n  getByChartAccountsCategory(category: ChartAccountsCategoryEnum): TransactionCollection {\n    return new TransactionCollection(\n      this.items.filter((transaction: Transaction): boolean => transaction.chartAccounts.category === category)\n    );\n  }\n\n  /**\n   * Get new collection of property transactions\n   */\n  getPropertyTransactions(): TransactionCollection {\n    return this.filterBy('tankType', TankTypeEnum.PROPERTY);\n  }\n\n  getDebitTransactions(): TransactionCollection {\n    return new TransactionCollection(\n      this.items.filter((transaction: Transaction): boolean => transaction.isDebit())\n    );\n  }\n\n  getCreditTransactions(): TransactionCollection {\n    return new TransactionCollection(\n      this.items.filter((transaction: Transaction): boolean => transaction.isCredit())\n    );\n  }\n\n  getByAllocations(allocations: TransactionAllocationCollection): TransactionCollection {\n    return new TransactionCollection(\n      this.items.filter((transaction: Transaction): boolean => allocations.hasTransaction(transaction))\n    );\n  }\n\n  getByInvoices(invoices: SoleInvoiceCollection): this {\n    return this.filterBy('invoiceItem.id', invoices.getInvoiceItemsIds());\n  }\n\n  getAmountPerInvoice(): Dictionary<number> {\n    // @TODO invoiceItem.invoice will be removed on backend\n    const transactionsByInvoice = this.groupBy('invoiceItem.invoice.id');\n    const dictionary: Dictionary<number> = new Dictionary([]);\n\n    transactionsByInvoice.keys.forEach((key) => {\n      dictionary.add(key, transactionsByInvoice.get(key).grossAmount);\n    });\n\n    return dictionary;\n  }\n\n  /**\n   * Get transactions related to Vehicle category\n   */\n  getVehicleTransactions(): this {\n    return this.create(\n      this.items.filter((transaction: Transaction): boolean => transaction.isVehicleTransaction())\n    );\n  }\n\n  /**\n   * Get new transaction collection filtered by tank type\n   */\n  getByTankType(tankType: TankTypeEnum): this {\n    return this.filterBy('tankType', tankType);\n  }\n\n  getExportHeader(): string[] {\n    return ['Date', 'Description', 'Debit', 'Credit'];\n  }\n\n  getExportFooter(): ExportCell[] {\n    return [\n      plainToClass(ExportCell, { value: 'Total', type: ExportCellTypeEnum.STRING }),\n      plainToClass(ExportCell, { value: '', type: ExportCellTypeEnum.STRING }),\n      plainToClass(ExportCell, { value: this.sumBy('debit'), type: ExportCellTypeEnum.CURRENCY }),\n      plainToClass(ExportCell, { value: this.sumBy('credit'), type: ExportCellTypeEnum.CURRENCY })\n    ];\n  }\n\n  getExportBody(): ExportCell[][] {\n    /**\n     * Description is not a required field for transactions.\n     * if there is no description, then add an empty line so that there are no errors when translated into a string.\n     */\n    return this.items.map((transaction: Transaction) => [\n      plainToClass(ExportCell, { value: transaction.date, type: ExportCellTypeEnum.DATE }),\n      plainToClass(ExportCell, { value: transaction.description ?? '-', type: ExportCellTypeEnum.STRING }),\n      plainToClass(ExportCell, { value: transaction.debit, type: ExportCellTypeEnum.CURRENCY }),\n      plainToClass(ExportCell, { value: transaction.credit, type: ExportCellTypeEnum.CURRENCY })\n    ]);\n  }\n\n  /**\n   * Get list of vehicle transactions filtered by vehicle claim\n   */\n  getByVehicleClaim(vehicleClaim?: VehicleClaim): this {\n    if (!vehicleClaim) {\n      return this.create([]);\n    }\n\n    return vehicleClaim.isSoleTank()\n      // sole tank may have multiple vehicle claims, so we need to filter by business.id\n      ? this.getVehicleTransactions().filterBy('business.id', vehicleClaim.business.id)\n      // work tank may have only one vehicle claim, so we need to filter by tank type\n      : this.getVehicleTransactions().filterBy('tankType', TankTypeEnum.WORK);\n  }\n\n  /**\n   * Get list of vehicle transactions except KMS transactions\n   */\n  getLogbookTransactions(): this {\n    return this\n      .getVehicleTransactions()\n      .removeBy('chartAccounts.id', [ChartAccountsListEnum.KLMS_TRAVELLED_FOR_WORK, ChartAccountsListEnum.KLMS_TRAVELLED]);\n  }\n\n  /**\n   * Build chart data with transactions cash position.\n   * Cash position = Income - Expenses (include depreciations)\n   * Chart data for each month from fin year start till current month\n   */\n  getCashPositionChartData(): ChartData[] {\n    const chartData: ChartData[] = [\n      plainToClass(ChartData, { name: 'Income', data: [] }),\n      plainToClass(ChartData, { name: 'Expense', data: [] })\n    ];\n\n    new FinancialYear().getPastMonths().forEach(month => {\n      chartData[0].data.push({\n        label: MONTHS[month],\n        value: this.getIncomeTransactions().getByMonth(month).claimAmount\n      });\n      chartData[1].data.push({\n        label: MONTHS[month],\n        value: Math.abs(this.getExpenseTransactions().getByMonth(month).claimAmount)\n      });\n    });\n\n    return chartData;\n  }\n\n  getAllocatedAmount(allocations: TransactionAllocationCollection): number {\n    return allocations.getByTransactionsIds(this.getIds()).sumBy('amount')\n  }\n\n  /**\n   * @TODO vik business transactions calculated differently, separated collection?\n   */\n  getBusinessClaimAmount(businessId: number = null): number {\n    const transactions = businessId ? this.filterBy('business.id', businessId) : this;\n    const expenses = transactions.getExpenseTransactions();\n    const incomes = transactions.getIncomeTransactions();\n\n    return incomes.sumBy('claimAmount') + expenses.sumBy('claimAmount');\n  }\n\n  getTaxable(): this {\n    return this.filter(transaction => transaction.claimPercent > 0);\n  }\n}\n"]}
234
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction.collection.js","sourceRoot":"","sources":["../../../../../../../projects/tt-core/src/lib/collections/transaction/transaction.collection.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  CHART_ACCOUNTS_CATEGORIES,\n  Dictionary,\n  Transaction,\n  TransactionMetaField,\n  VehicleClaim\n} from '../../models';\nimport { TransactionAllocationCollection } from './transaction-allocation.collection';\nimport { ChartAccountsCategoryEnum, ChartAccountsListEnum } from '../../db/Enums';\nimport { TankTypeEnum } from '../../db/Enums/tank-type.enum';\nimport { plainToClass } from 'class-transformer';\nimport { ExportCell } from '../../models/export/export-cell';\nimport { ExportCellTypeEnum } from '../../models/export/export-cell-type.enum';\nimport { Collection } from '../collection';\nimport { ChartData } from '../../models/chart/chart-data';\nimport { Depreciation, FinancialYear, MONTHS } from '../../models';\nimport { SoleInvoiceCollection } from '../sole';\nimport { TransactionBaseCollection } from './transaction-base.collection';\n\n/**\n * Collection of transactions\n */\nexport class TransactionCollection extends TransactionBaseCollection<Transaction> {\n  /**\n   * we use depreciations as expense transactions a lot\n   */\n  constructor(transactions: Transaction[] = [], depreciations: Depreciation[] = []) {\n    if (depreciations.length) {\n      transactions = transactions.filter(\n        transaction => !CHART_ACCOUNTS_CATEGORIES.depreciation.includes(transaction.chartAccounts.category)\n      );\n    }\n    super([...transactions, ...depreciations.map((depreciation) => depreciation.toTransaction())]);\n  }\n\n  getSoleTransactions(): this {\n    return this.filter((transaction: Transaction) => transaction.isSoleTank());\n  }\n\n  getFindAndMatch(allocations: TransactionAllocationCollection): this {\n    return this.filter((transaction) => transaction.canFindAndMatch(allocations));\n  }\n\n  getUnallocated(allocations: TransactionAllocationCollection): TransactionCollection {\n    return new TransactionCollection(\n      this.items.filter((transaction: Transaction): boolean => !transaction.isAllocated(allocations))\n    );\n  }\n\n  getUnallocatedAmount(allocations: TransactionAllocationCollection): number {\n    return this.items.reduce((sum: number, transaction: Transaction): number =>\n      sum + transaction.getUnallocatedAmount(allocations.filterBy('transaction.id', transaction.id)), 0);\n  }\n\n  /**\n   * get date of the last transaction\n   */\n  getLastTransactionDate(): Date {\n    return new Date(Math.max.apply(Math, this.items.map((transaction: Transaction) => transaction.date)));\n  }\n\n  get amount(): number {\n    return this.sumBy('amount');\n  }\n\n  get claimAmount(): number {\n    return this.items.reduce((sum: number, transaction: Transaction) => sum + transaction.claimAmount, 0);\n  }\n\n  get grossAmount(): number {\n    return this.items.reduce((sum: number, transaction: Transaction) => sum + transaction.grossAmount, 0);\n  }\n\n  get grossClaimAmount(): number {\n    return this.items.reduce((sum: number, transaction: Transaction) => sum + transaction.grossClaimAmount, 0);\n  }\n\n  getByChartAccountsCategories(categories: ChartAccountsCategoryEnum[]): TransactionCollection {\n    return new TransactionCollection(\n      this.items.filter((transaction: Transaction): boolean => categories.includes(transaction.chartAccounts.category))\n    );\n  }\n\n  /**\n   * Get transactions by month\n   * @param monthIndex by which desired month should be taken\n   */\n  getByMonth(monthIndex: number): TransactionCollection {\n    return new TransactionCollection(this.items.filter((transaction: Transaction): boolean =>\n      transaction.date.getMonth() === monthIndex\n    ));\n  }\n\n  /**\n   * Get collection of transactions meta fields\n   */\n  getTransactionsMetaFields(): Collection<TransactionMetaField> {\n    const metaFieldsArray: TransactionMetaField[] = [];\n\n    this.items.forEach((transaction: Transaction) => {\n      metaFieldsArray.push(...transaction.metaFields);\n    });\n\n    return new Collection<TransactionMetaField>(metaFieldsArray);\n  }\n\n  getIncomeTransactions(): TransactionCollection {\n    return new TransactionCollection(\n      this.items.filter((transaction: Transaction): boolean => transaction.isIncome())\n    );\n  }\n\n  getExpenseTransactions(): TransactionCollection {\n    return new TransactionCollection(\n      this.items.filter((transaction: Transaction): boolean => transaction.isExpense() && !transaction.isInterest())\n    );\n  }\n\n  get claimIncome(): number {\n    return this.getIncomeTransactions().claimAmount;\n  }\n\n  get claimExpense(): number {\n    return this.getExpenseTransactions().claimAmount;\n  }\n\n  getInterestTransactions(): TransactionCollection {\n    return new TransactionCollection(\n      this.items.filter((transaction: Transaction): boolean => transaction.isInterest())\n    );\n  }\n\n  get claimInterest(): number {\n    return this.getInterestTransactions().claimAmount;\n  }\n\n  /**\n   * Get collection of transactions and properties filtered by properties ids\n   * @param ids Ids of properties for filter\n   */\n  getByPropertiesIds(ids: number[]): TransactionCollection {\n    return new TransactionCollection(\n      this.items.filter((transaction: Transaction): boolean => ids.includes(transaction.property?.id))\n    );\n  }\n\n  /**\n   * Get new collection filtered by income source id\n   * @param id id of income source for filter\n   */\n  getByIncomeSourceId(id: number): TransactionCollection {\n    return new TransactionCollection(\n      this.items.filter((transaction: Transaction): boolean => transaction.incomeSource?.id === id)\n    );\n  }\n\n  /**\n   * Get new collection filtered by chart accounts category\n   * @param category Chart accounts category value\n   */\n  getByChartAccountsCategory(category: ChartAccountsCategoryEnum): TransactionCollection {\n    return new TransactionCollection(\n      this.items.filter((transaction: Transaction): boolean => transaction.chartAccounts.category === category)\n    );\n  }\n\n  /**\n   * Get new collection of property transactions\n   */\n  getPropertyTransactions(): TransactionCollection {\n    return this.filterBy('tankType', TankTypeEnum.PROPERTY);\n  }\n\n  getDebitTransactions(): TransactionCollection {\n    return new TransactionCollection(\n      this.items.filter((transaction: Transaction): boolean => transaction.isDebit())\n    );\n  }\n\n  getCreditTransactions(): TransactionCollection {\n    return new TransactionCollection(\n      this.items.filter((transaction: Transaction): boolean => transaction.isCredit())\n    );\n  }\n\n  getByAllocations(allocations: TransactionAllocationCollection): TransactionCollection {\n    return new TransactionCollection(\n      this.items.filter((transaction: Transaction): boolean => allocations.hasTransaction(transaction))\n    );\n  }\n\n  getByInvoices(invoices: SoleInvoiceCollection): this {\n    return this.filterBy('invoiceItem.id', invoices.getInvoiceItemsIds());\n  }\n\n  getAmountPerInvoice(): Dictionary<number> {\n    // @TODO invoiceItem.invoice will be removed on backend\n    const transactionsByInvoice = this.groupBy('invoiceItem.invoice.id');\n    const dictionary: Dictionary<number> = new Dictionary([]);\n\n    transactionsByInvoice.keys.forEach((key) => {\n      dictionary.add(key, transactionsByInvoice.get(key).grossAmount);\n    });\n\n    return dictionary;\n  }\n\n  /**\n   * Get transactions related to Vehicle category\n   */\n  getVehicleTransactions(): this {\n    return this.create(\n      this.items.filter((transaction: Transaction): boolean => transaction.isVehicleTransaction())\n    );\n  }\n\n  /**\n   * Get new transaction collection filtered by tank type\n   */\n  getByTankType(tankType: TankTypeEnum): this {\n    return this.filterBy('tankType', tankType);\n  }\n\n  getExportHeader(): string[] {\n    return ['Date', 'Description', 'Debit', 'Credit'];\n  }\n\n  getExportFooter(): ExportCell[] {\n    return [\n      plainToClass(ExportCell, { value: 'Total', type: ExportCellTypeEnum.STRING }),\n      plainToClass(ExportCell, { value: '', type: ExportCellTypeEnum.STRING }),\n      plainToClass(ExportCell, { value: this.sumBy('debit'), type: ExportCellTypeEnum.CURRENCY }),\n      plainToClass(ExportCell, { value: this.sumBy('credit'), type: ExportCellTypeEnum.CURRENCY })\n    ];\n  }\n\n  getExportBody(): ExportCell[][] {\n    /**\n     * Description is not a required field for transactions.\n     * if there is no description, then add an empty line so that there are no errors when translated into a string.\n     */\n    return this.items.map((transaction: Transaction) => [\n      plainToClass(ExportCell, { value: transaction.date, type: ExportCellTypeEnum.DATE }),\n      plainToClass(ExportCell, { value: transaction.description ?? '-', type: ExportCellTypeEnum.STRING }),\n      plainToClass(ExportCell, { value: transaction.debit, type: ExportCellTypeEnum.CURRENCY }),\n      plainToClass(ExportCell, { value: transaction.credit, type: ExportCellTypeEnum.CURRENCY })\n    ]);\n  }\n\n  /**\n   * Get list of vehicle transactions filtered by vehicle claim\n   */\n  getByVehicleClaim(vehicleClaim?: VehicleClaim): this {\n    if (!vehicleClaim) {\n      return this.create([]);\n    }\n\n    return vehicleClaim.isSoleTank()\n      // sole tank may have multiple vehicle claims, so we need to filter by business.id\n      ? this.getVehicleTransactions().filterBy('business.id', vehicleClaim.business.id)\n      // work tank may have only one vehicle claim, so we need to filter by tank type\n      : this.getVehicleTransactions().filterBy('tankType', TankTypeEnum.WORK);\n  }\n\n  /**\n   * Get list of vehicle transactions except KMS transactions\n   */\n  getLogbookTransactions(): this {\n    return this\n      .getVehicleTransactions()\n      .removeBy('chartAccounts.id', [ChartAccountsListEnum.KLMS_TRAVELLED_FOR_WORK, ChartAccountsListEnum.KLMS_TRAVELLED]);\n  }\n\n  /**\n   * Build chart data with transactions cash position.\n   * Cash position = Income - Expenses (include depreciations)\n   * Chart data for each month from fin year start till current month\n   */\n  getCashPositionChartData(): ChartData[] {\n    const chartData: ChartData[] = [\n      plainToClass(ChartData, { name: 'Income', data: [] }),\n      plainToClass(ChartData, { name: 'Expense', data: [] })\n    ];\n\n    new FinancialYear().getPastMonths().forEach(month => {\n      chartData[0].data.push({\n        label: MONTHS[month],\n        value: this.getIncomeTransactions().getByMonth(month).claimAmount\n      });\n      chartData[1].data.push({\n        label: MONTHS[month],\n        value: Math.abs(this.getExpenseTransactions().getByMonth(month).claimAmount)\n      });\n    });\n\n    return chartData;\n  }\n\n  getAllocatedAmount(allocations: TransactionAllocationCollection): number {\n    return allocations.getByTransactionsIds(this.getIds()).sumBy('amount')\n  }\n\n  /**\n   * @TODO vik business transactions calculated differently, separated collection?\n   */\n  getBusinessClaimAmount(businessId: number = null): number {\n    const transactions = businessId ? this.filterBy('business.id', businessId) : this;\n    const expenses = transactions.getExpenseTransactions();\n    const incomes = transactions.getIncomeTransactions();\n\n    return incomes.sumBy('claimAmount') + expenses.sumBy('claimAmount');\n  }\n\n  getTaxable(): this {\n    return this.filter(transaction => transaction.claimPercent > 0);\n  }\n}\n"]}
@@ -1,5 +1,5 @@
1
- import { TAX_RETURN_CATEGORIES, TransactionCollection } from '../../../../../collections';
2
- import { ChartAccountsCategoryEnum, ChartAccountsHeadingListEnum, ChartAccountsListEnum } from '../../../../../db/Enums';
1
+ import { TAX_RETURN_CATEGORIES } from '../../../../../collections';
2
+ import { ChartAccountsCategoryEnum, ChartAccountsHeadingListEnum, ChartAccountsListEnum, TaxReturnCategoryListEnum, TaxReturnItemEnum } from '../../../../../db/Enums';
3
3
  import { TaxSummarySectionEnum } from '../../../../../db/Enums/tax-summary-section.enum';
4
4
  /**
5
5
  * Sole business information related to expense transactions (losses)
@@ -41,7 +41,7 @@ export class MyTaxBusinessLosses {
41
41
  this.logbookExpensesAmount = Math.abs(transactions.getVehicleTransactions().sumBy('claimAmount')) +
42
42
  depreciations.getVehicleDepreciations().sumBy('claimAmount');
43
43
  this.otherExpensesAmount = Math.abs(transactions
44
- .filterBy('chartAccounts.heading.id', ChartAccountsHeadingListEnum.OTHER_EXPENSES)
44
+ .filterBy('chartAccounts.taxReturnItem.id', TaxReturnItemEnum.ALL_OTHER_EXPENSES)
45
45
  .sumBy('claimAmount'));
46
46
  this.totalNonPrimaryProductionExpensesAmount = Math.abs(transactions
47
47
  .filterBy('chartAccounts.category', [ChartAccountsCategoryEnum.SOLE_EXPENSE])
@@ -59,12 +59,11 @@ export class MyTaxBusinessLosses {
59
59
  this.deductionsForGeneralSmallBusinessPoolAmount = depreciations
60
60
  .getSBPDepreciations()
61
61
  .sumBy('claimAmount');
62
- this.currentYearNetNonPrimaryIncomeOrLossesAmount = new TransactionCollection(transactions.toArray(), depreciations.toArray())
63
- .getBusinessClaimAmount();
62
+ this.currentYearNetNonPrimaryIncomeOrLossesAmount = taxSummary.sole.items.sumByCategoriesAndSection([TaxReturnCategoryListEnum.BUSINESS_INCOME_OR_LOSS], TaxSummarySectionEnum.SOLE_TANK);
64
63
  this.priorYearsNonPrimaryLossesAmount = businessLosses.sumBy('openBalance');
65
64
  this.netNonPrimaryIncomeOrLossesAmount = this.currentYearNetNonPrimaryIncomeOrLossesAmount -
66
65
  this.priorYearsNonPrimaryLossesAmount;
67
66
  this.deferredLossesAmount = taxSummary.sole.items.sumByCategoriesAndSection(TAX_RETURN_CATEGORIES.sole.lossCurrent, TaxSummarySectionEnum.SOLE_TANK);
68
67
  }
69
68
  }
70
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"my-tax-business-losses.js","sourceRoot":"","sources":["../../../../../../../../../../projects/tt-core/src/lib/models/report/my-tax/my-tax-business-income-or-losses/my-tax-business-losses/my-tax-business-losses.ts"],"names":[],"mappings":"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","sourcesContent":["import { DepreciationCollection, TAX_RETURN_CATEGORIES, TransactionCollection } from '../../../../../collections';\nimport { ChartAccountsCategoryEnum, ChartAccountsHeadingListEnum, ChartAccountsListEnum } from '../../../../../db/Enums';\nimport { SoleBusinessLoss } from '../../../../sole';\nimport { SoleBusinessLossCollection } from '../../../../../collections';\nimport { TaxSummary } from '../../../../tax-summary/tax-summary';\nimport { TaxSummarySectionEnum } from '../../../../../db/Enums/tax-summary-section.enum';\n\n/**\n * Sole business information related to expense transactions (losses)\n * https://taxtank.atlassian.net/wiki/spaces/TAXTANK/pages/4644110466/Tax+Return+MyTax+-+Online+Form (section \"Business income or losses\")\n */\nexport class MyTaxBusinessLosses {\n  currentLoss: SoleBusinessLoss;\n  purchasesAndOtherCostsAmount: number;\n  contractorsAndCommissionAmount: number;\n  superannuationAmount: number;\n  badDebtAmount: number;\n  leaseExpensesCommercialAmount: number;\n  rentExpensesCommercialPremisesAmount: number;\n  interestExpensesAustraliaAmount: number;\n  interestExpensesOverseasAmount: number;\n  kmsTravelledExpensesAmount: number;\n  logbookExpensesAmount: number;\n  otherExpensesAmount: number;\n  totalNonPrimaryProductionExpensesAmount: number;\n  depreciationExpensesAmount: number;\n  deductionsForCertainAssetsAmount: number;\n  deductionsForGeneralSmallBusinessPoolAmount: number;\n  priorYearsNonPrimaryLossesAmount: number;\n  netNonPrimaryIncomeOrLossesAmount: number;\n  currentYearNetNonPrimaryIncomeOrLossesAmount: number;\n  deferredLossesAmount: number;\n\n  constructor(\n    transactions: TransactionCollection,\n    depreciations: DepreciationCollection,\n    businessLosses: SoleBusinessLossCollection,\n    currentLoss: SoleBusinessLoss,\n    taxSummary: TaxSummary\n  ) {\n    this.currentLoss = currentLoss;\n    this.purchasesAndOtherCostsAmount = Math.abs(transactions.getExpenseTransactions()\n      .filterBy('chartAccounts.id', ChartAccountsListEnum.PURCHASES_STOCK_INVENTORY)\n      .sumBy('claimAmount'));\n    this.contractorsAndCommissionAmount = Math.abs(transactions.getExpenseTransactions()\n      .filterBy('chartAccounts.id', ChartAccountsListEnum.CONTRACTORS_AND_COMMISSION)\n      .sumBy('claimAmount'));\n    this.superannuationAmount = Math.abs(transactions.getExpenseTransactions()\n      .filterBy('chartAccounts.id', ChartAccountsListEnum.SUPERANNUATION)\n      .sumBy('claimAmount'));\n    this.badDebtAmount = Math.abs(transactions.getExpenseTransactions()\n      .filterBy('chartAccounts.id', ChartAccountsListEnum.BAD_DEBT)\n      .sumBy('claimAmount'));\n    this.leaseExpensesCommercialAmount = Math.abs(transactions.getExpenseTransactions()\n      .filterBy('chartAccounts.id', ChartAccountsListEnum.LEASE_EXPENSES_COMMERCIAL)\n      .sumBy('claimAmount'));\n    this.rentExpensesCommercialPremisesAmount = Math.abs(transactions.getExpenseTransactions()\n      .filterBy('chartAccounts.id', ChartAccountsListEnum.RENT_EXPENSES_COMMERCIAL_PREMISES)\n      .sumBy('claimAmount'));\n    this.interestExpensesAustraliaAmount = Math.abs(transactions.getExpenseTransactions()\n      .filterBy('chartAccounts.id', ChartAccountsListEnum.INTEREST_EXPENSES_AUSTRALIA)\n      .sumBy('claimAmount'));\n    this.interestExpensesOverseasAmount = Math.abs(transactions.getExpenseTransactions()\n      .filterBy('chartAccounts.id', ChartAccountsListEnum.INTEREST_EXPENSES_OVERSEAS)\n      .sumBy('claimAmount'));\n    this.kmsTravelledExpensesAmount = Math.abs(\n      transactions\n        .filterBy('chartAccounts.category', [ChartAccountsListEnum.KLMS_TRAVELLED])\n        .sumBy('claimAmount') +\n      depreciations\n        .filterBy('chartAccounts.category', [ChartAccountsListEnum.KLMS_TRAVELLED])\n        .sumBy('claimAmount')\n    );\n    this.logbookExpensesAmount = Math.abs(transactions.getVehicleTransactions().sumBy('claimAmount')) +\n      depreciations.getVehicleDepreciations().sumBy('claimAmount');\n    this.otherExpensesAmount = Math.abs(transactions\n      .filterBy('chartAccounts.heading.id', ChartAccountsHeadingListEnum.OTHER_EXPENSES)\n      .sumBy('claimAmount'));\n    this.totalNonPrimaryProductionExpensesAmount = Math.abs(transactions\n      .filterBy('chartAccounts.category', [ChartAccountsCategoryEnum.SOLE_EXPENSE])\n      .sumBy('claimAmount')) +\n      depreciations\n        .filterBy('chartAccounts.category', [ChartAccountsCategoryEnum.SOLE_DEPRECIATION])\n        .sumBy('claimAmount');\n    // depreciations\n    this.depreciationExpensesAmount = depreciations\n      .filterBy('chartAccounts.heading.id', ChartAccountsHeadingListEnum.DEPRECIATION_EXPENSES)\n      .sumBy('claimAmount');\n    this.deductionsForCertainAssetsAmount = depreciations\n      .getWrittenOffDepreciations()\n      .sumBy('claimAmount');\n    this.deductionsForGeneralSmallBusinessPoolAmount = depreciations\n      .getSBPDepreciations()\n      .sumBy('claimAmount');\n    this.currentYearNetNonPrimaryIncomeOrLossesAmount = new TransactionCollection(transactions.toArray(), depreciations.toArray())\n      .getBusinessClaimAmount();\n    this.priorYearsNonPrimaryLossesAmount = businessLosses.sumBy('openBalance');\n    this.netNonPrimaryIncomeOrLossesAmount = this.currentYearNetNonPrimaryIncomeOrLossesAmount -\n      this.priorYearsNonPrimaryLossesAmount;\n    this.deferredLossesAmount = taxSummary.sole.items.sumByCategoriesAndSection(\n      TAX_RETURN_CATEGORIES.sole.lossCurrent,\n      TaxSummarySectionEnum.SOLE_TANK\n    )\n  }\n}\n"]}
69
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"my-tax-business-losses.js","sourceRoot":"","sources":["../../../../../../../../../../projects/tt-core/src/lib/models/report/my-tax/my-tax-business-income-or-losses/my-tax-business-losses/my-tax-business-losses.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  DepreciationCollection,\n  SoleBusinessLossCollection,\n  TAX_RETURN_CATEGORIES,\n  TransactionCollection\n} from '../../../../../collections';\nimport {\n  ChartAccountsCategoryEnum,\n  ChartAccountsHeadingListEnum,\n  ChartAccountsListEnum,\n  TaxReturnCategoryListEnum,\n  TaxReturnItemEnum\n} from '../../../../../db/Enums';\nimport { SoleBusinessLoss } from '../../../../sole';\nimport { TaxSummary } from '../../../../tax-summary/tax-summary';\nimport { TaxSummarySectionEnum } from '../../../../../db/Enums/tax-summary-section.enum';\n\n/**\n * Sole business information related to expense transactions (losses)\n * https://taxtank.atlassian.net/wiki/spaces/TAXTANK/pages/4644110466/Tax+Return+MyTax+-+Online+Form (section \"Business income or losses\")\n */\nexport class MyTaxBusinessLosses {\n  currentLoss: SoleBusinessLoss;\n  purchasesAndOtherCostsAmount: number;\n  contractorsAndCommissionAmount: number;\n  superannuationAmount: number;\n  badDebtAmount: number;\n  leaseExpensesCommercialAmount: number;\n  rentExpensesCommercialPremisesAmount: number;\n  interestExpensesAustraliaAmount: number;\n  interestExpensesOverseasAmount: number;\n  kmsTravelledExpensesAmount: number;\n  logbookExpensesAmount: number;\n  otherExpensesAmount: number;\n  totalNonPrimaryProductionExpensesAmount: number;\n  depreciationExpensesAmount: number;\n  deductionsForCertainAssetsAmount: number;\n  deductionsForGeneralSmallBusinessPoolAmount: number;\n  priorYearsNonPrimaryLossesAmount: number;\n  netNonPrimaryIncomeOrLossesAmount: number;\n  currentYearNetNonPrimaryIncomeOrLossesAmount: number;\n  deferredLossesAmount: number;\n\n  constructor(\n    transactions: TransactionCollection,\n    depreciations: DepreciationCollection,\n    businessLosses: SoleBusinessLossCollection,\n    currentLoss: SoleBusinessLoss,\n    taxSummary: TaxSummary\n  ) {\n    this.currentLoss = currentLoss;\n    this.purchasesAndOtherCostsAmount = Math.abs(transactions.getExpenseTransactions()\n      .filterBy('chartAccounts.id', ChartAccountsListEnum.PURCHASES_STOCK_INVENTORY)\n      .sumBy('claimAmount'));\n    this.contractorsAndCommissionAmount = Math.abs(transactions.getExpenseTransactions()\n      .filterBy('chartAccounts.id', ChartAccountsListEnum.CONTRACTORS_AND_COMMISSION)\n      .sumBy('claimAmount'));\n    this.superannuationAmount = Math.abs(transactions.getExpenseTransactions()\n      .filterBy('chartAccounts.id', ChartAccountsListEnum.SUPERANNUATION)\n      .sumBy('claimAmount'));\n    this.badDebtAmount = Math.abs(transactions.getExpenseTransactions()\n      .filterBy('chartAccounts.id', ChartAccountsListEnum.BAD_DEBT)\n      .sumBy('claimAmount'));\n    this.leaseExpensesCommercialAmount = Math.abs(transactions.getExpenseTransactions()\n      .filterBy('chartAccounts.id', ChartAccountsListEnum.LEASE_EXPENSES_COMMERCIAL)\n      .sumBy('claimAmount'));\n    this.rentExpensesCommercialPremisesAmount = Math.abs(transactions.getExpenseTransactions()\n      .filterBy('chartAccounts.id', ChartAccountsListEnum.RENT_EXPENSES_COMMERCIAL_PREMISES)\n      .sumBy('claimAmount'));\n    this.interestExpensesAustraliaAmount = Math.abs(transactions.getExpenseTransactions()\n      .filterBy('chartAccounts.id', ChartAccountsListEnum.INTEREST_EXPENSES_AUSTRALIA)\n      .sumBy('claimAmount'));\n    this.interestExpensesOverseasAmount = Math.abs(transactions.getExpenseTransactions()\n      .filterBy('chartAccounts.id', ChartAccountsListEnum.INTEREST_EXPENSES_OVERSEAS)\n      .sumBy('claimAmount'));\n    this.kmsTravelledExpensesAmount = Math.abs(\n      transactions\n        .filterBy('chartAccounts.category', [ChartAccountsListEnum.KLMS_TRAVELLED])\n        .sumBy('claimAmount') +\n      depreciations\n        .filterBy('chartAccounts.category', [ChartAccountsListEnum.KLMS_TRAVELLED])\n        .sumBy('claimAmount')\n    );\n    this.logbookExpensesAmount = Math.abs(transactions.getVehicleTransactions().sumBy('claimAmount')) +\n      depreciations.getVehicleDepreciations().sumBy('claimAmount');\n    this.otherExpensesAmount = Math.abs(transactions\n      .filterBy('chartAccounts.taxReturnItem.id', TaxReturnItemEnum.ALL_OTHER_EXPENSES)\n      .sumBy('claimAmount'));\n    this.totalNonPrimaryProductionExpensesAmount = Math.abs(transactions\n      .filterBy('chartAccounts.category', [ChartAccountsCategoryEnum.SOLE_EXPENSE])\n      .sumBy('claimAmount')) +\n      depreciations\n        .filterBy('chartAccounts.category', [ChartAccountsCategoryEnum.SOLE_DEPRECIATION])\n        .sumBy('claimAmount');\n    // depreciations\n    this.depreciationExpensesAmount = depreciations\n      .filterBy('chartAccounts.heading.id', ChartAccountsHeadingListEnum.DEPRECIATION_EXPENSES)\n      .sumBy('claimAmount');\n    this.deductionsForCertainAssetsAmount = depreciations\n      .getWrittenOffDepreciations()\n      .sumBy('claimAmount');\n    this.deductionsForGeneralSmallBusinessPoolAmount = depreciations\n      .getSBPDepreciations()\n      .sumBy('claimAmount');\n    this.currentYearNetNonPrimaryIncomeOrLossesAmount = taxSummary.sole.items.sumByCategoriesAndSection(\n      [TaxReturnCategoryListEnum.BUSINESS_INCOME_OR_LOSS],\n      TaxSummarySectionEnum.SOLE_TANK\n    )\n    this.priorYearsNonPrimaryLossesAmount = businessLosses.sumBy('openBalance');\n    this.netNonPrimaryIncomeOrLossesAmount = this.currentYearNetNonPrimaryIncomeOrLossesAmount -\n      this.priorYearsNonPrimaryLossesAmount;\n    this.deferredLossesAmount = taxSummary.sole.items.sumByCategoriesAndSection(\n      TAX_RETURN_CATEGORIES.sole.lossCurrent,\n      TaxSummarySectionEnum.SOLE_TANK\n    )\n  }\n}\n"]}
@@ -9,8 +9,8 @@ const EXCEL_TYPE = 'application/vnd.openxmlformats-officedocument.spreadsheetml.
9
9
  export class XlsxService {
10
10
  constructor() {
11
11
  this.getFileName = (name) => {
12
- let sheetName = name || "ExportResult";
13
- let fileName = `${sheetName}`;
12
+ const sheetName = name || 'ExportResult';
13
+ const fileName = `${sheetName}`;
14
14
  return {
15
15
  sheetName,
16
16
  fileName
@@ -39,16 +39,15 @@ export class XlsxService {
39
39
  // add caption for the current table
40
40
  xlsx.utils.sheet_add_aoa(worksheet, [[data.caption?.innerText]], { origin: -1 });
41
41
  // Prepare to add table data to the worksheet, processing each cell
42
- const rows = Array.from(data.rows).map((row) => {
43
- return Array.from(row.cells).map((cell) => {
44
- let cellValue = cell.innerText;
45
- // Convert currency strings like "$0.00" to numbers
46
- if (/^-?\$/.test(cellValue)) {
47
- cellValue = parseFloat(cellValue.replace('$', ''));
48
- }
49
- return cellValue;
50
- });
51
- });
42
+ const rows = Array.from(data.rows).map((row) => Array.from(row.cells).map((cell) => {
43
+ const cellValue = cell.innerText;
44
+ // Convert currency strings like "$0.00" to numbers
45
+ if (/^-?\$/.test(cellValue)) {
46
+ // @TODO vik fix
47
+ // cellValue = parseFloat(cellValue.replace('$', ''));
48
+ }
49
+ return cellValue;
50
+ }));
52
51
  // Add the processed table data to the worksheet
53
52
  xlsx.utils.sheet_add_aoa(worksheet, rows, { origin: -1 });
54
53
  // set empty row after current table
@@ -70,7 +69,7 @@ export class XlsxService {
70
69
  };
71
70
  const exportData = exportableCollection.export(params);
72
71
  const exportAoa = exportableCollection.getBodyAoa(exportData);
73
- let { sheetName, fileName } = this.getFileName(name);
72
+ const { sheetName, fileName } = this.getFileName(name);
74
73
  xlsx.utils.sheet_add_aoa(worksheet, [exportData.header], { origin: -1 });
75
74
  // add table table data to the worksheet
76
75
  xlsx.utils.sheet_add_aoa(worksheet, exportAoa, { origin: -1 });
@@ -92,4 +91,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
92
91
  providedIn: 'root'
93
92
  }]
94
93
  }] });
95
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"xlsx.service.js","sourceRoot":"","sources":["../../../../../../../projects/tt-core/src/lib/services/xlsx/xlsx.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport * as xlsx from 'xlsx';\nimport * as FileSaver from 'file-saver';\nimport { ExportableCollection } from \"../../collections\";\nimport { ExportDataTable } from \"../../models/export/export-data-table\";\n\nconst EXCEL_TYPE: string = 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=UTF-8'\n\n@Injectable({\n  providedIn: 'root'\n})\n\n/**\n * Service to work with XLSX (generate, download, e.t.c.)\n */\nexport class XlsxService {\n  /**\n   * Export file form provided HTML tables\n   */\n  exportTables(tables: NodeListOf<HTMLTableElement>, title: string, fileName: string): void {\n    const excelFile: BlobPart = this.generateFromTables(tables, title);\n    const data: Blob = new Blob([excelFile], {\n      type: EXCEL_TYPE\n    });\n\n    FileSaver.saveAs(data, `${fileName}.xlsx`);\n  }\n\n  private generateFromTables(tables: NodeListOf<HTMLTableElement>, title?: string): BlobPart {\n    // create new workbook\n    const workbook: xlsx.WorkBook = xlsx.utils.book_new();\n    // create empty worksheet\n    const worksheet: xlsx.WorkSheet = {\n      SheetNames: [],\n      Sheets: {}\n    };\n\n    tables.forEach((data: HTMLTableElement) => {\n      // add caption for the current table\n      xlsx.utils.sheet_add_aoa(worksheet, [[data.caption?.innerText]], {origin: -1});\n      // Prepare to add table data to the worksheet, processing each cell\n      const rows = Array.from(data.rows).map((row: HTMLTableRowElement) => {\n        return Array.from(row.cells).map((cell: HTMLTableCellElement) => {\n          let cellValue: string | number = cell.innerText;\n          // Convert currency strings like \"$0.00\" to numbers\n          if (/^-?\\$/.test(cellValue)) {\n            cellValue = parseFloat(cellValue.replace('$', ''));\n          }\n\n          return cellValue;\n        });\n      });\n      // Add the processed table data to the worksheet\n      xlsx.utils.sheet_add_aoa(worksheet, rows, {origin: -1});\n      // set empty row after current table\n      xlsx.utils.sheet_add_aoa(worksheet, [], {origin: -1});\n    });\n\n    xlsx.utils.book_append_sheet(workbook, worksheet);\n    return xlsx.write(workbook, { bookType: 'xlsx', type: 'array' });\n  }\n\n  getFileName = (name: string) => {\n    let sheetName = name || \"ExportResult\";\n    let fileName = `${sheetName}`;\n    return {\n      sheetName,\n      fileName\n    };\n  };\n\n  /**\n   * @TODO vik/artem work with ExportDataTable instead of ExportableCollection\n   * @TODO vik/artem why so much code? here is 6 rows solution https://stackoverflow.com/questions/64939994/how-to-export-array-of-objects-to-an-excel-in-angular-8\n   */\n  exportArrayToExcel(exportableCollection: ExportableCollection<any>, name?: string, params? : any) {\n    const workbook: xlsx.WorkBook = xlsx.utils.book_new();\n    // create empty worksheet\n    const worksheet: xlsx.WorkSheet = {\n      SheetNames: [],\n      Sheets: {}\n    };\n\n    const exportData: ExportDataTable = exportableCollection.export(params)\n    const exportAoa = exportableCollection.getBodyAoa(exportData);\n    let { sheetName, fileName } = this.getFileName(name);\n\n    xlsx.utils.sheet_add_aoa(worksheet, [exportData.header], {origin: -1});\n    // add table table data to the worksheet\n    xlsx.utils.sheet_add_aoa(worksheet, exportAoa, {origin: -1});\n    // set empty row after current table\n    xlsx.utils.sheet_add_aoa(worksheet, [], {origin: -1});\n\n    xlsx.utils.book_append_sheet(workbook, worksheet);\n    const excelFile: BlobPart = xlsx.write(workbook, { bookType: 'xlsx', type: 'array' });\n\n    const data: Blob = new Blob([excelFile], {\n      type: EXCEL_TYPE\n    });\n    FileSaver.saveAs(data, `${fileName}.xlsx`);\n  }\n}\n"]}
94
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"xlsx.service.js","sourceRoot":"","sources":["../../../../../../../projects/tt-core/src/lib/services/xlsx/xlsx.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport * as xlsx from 'xlsx';\nimport * as FileSaver from 'file-saver';\nimport { ExportableCollection } from '../../collections';\nimport { ExportDataTable } from '../../models/export/export-data-table';\n\nconst EXCEL_TYPE: string = 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=UTF-8'\n\n@Injectable({\n  providedIn: 'root'\n})\n\n/**\n * Service to work with XLSX (generate, download, e.t.c.)\n */\nexport class XlsxService {\n  /**\n   * Export file form provided HTML tables\n   */\n  exportTables(tables: NodeListOf<HTMLTableElement>, title: string, fileName: string): void {\n    const excelFile: BlobPart = this.generateFromTables(tables, title);\n    const data: Blob = new Blob([excelFile], {\n      type: EXCEL_TYPE\n    });\n\n    FileSaver.saveAs(data, `${fileName}.xlsx`);\n  }\n\n  private generateFromTables(tables: NodeListOf<HTMLTableElement>, title?: string): BlobPart {\n    // create new workbook\n    const workbook: xlsx.WorkBook = xlsx.utils.book_new();\n    // create empty worksheet\n    const worksheet: xlsx.WorkSheet = {\n      SheetNames: [],\n      Sheets: {}\n    };\n\n    tables.forEach((data: HTMLTableElement) => {\n      // add caption for the current table\n      xlsx.utils.sheet_add_aoa(worksheet, [[data.caption?.innerText]], { origin: -1 });\n      // Prepare to add table data to the worksheet, processing each cell\n      const rows = Array.from(data.rows).map((row: HTMLTableRowElement) => Array.from(row.cells).map((cell: HTMLTableCellElement) => {\n        const cellValue: string | number = cell.innerText;\n        // Convert currency strings like \"$0.00\" to numbers\n        if (/^-?\\$/.test(cellValue)) {\n          // @TODO vik fix\n          // cellValue = parseFloat(cellValue.replace('$', ''));\n        }\n\n        return cellValue;\n      }));\n      // Add the processed table data to the worksheet\n      xlsx.utils.sheet_add_aoa(worksheet, rows, { origin: -1 });\n      // set empty row after current table\n      xlsx.utils.sheet_add_aoa(worksheet, [], { origin: -1 });\n    });\n\n    xlsx.utils.book_append_sheet(workbook, worksheet);\n    return xlsx.write(workbook, { bookType: 'xlsx', type: 'array' });\n  }\n\n  getFileName = (name: string) => {\n    const sheetName = name || 'ExportResult';\n    const fileName = `${sheetName}`;\n    return {\n      sheetName,\n      fileName\n    };\n  };\n\n  /**\n   * @TODO vik/artem work with ExportDataTable instead of ExportableCollection\n   * @TODO vik/artem why so much code? here is 6 rows solution https://stackoverflow.com/questions/64939994/how-to-export-array-of-objects-to-an-excel-in-angular-8\n   */\n  exportArrayToExcel(exportableCollection: ExportableCollection<any>, name?: string, params? : any) {\n    const workbook: xlsx.WorkBook = xlsx.utils.book_new();\n    // create empty worksheet\n    const worksheet: xlsx.WorkSheet = {\n      SheetNames: [],\n      Sheets: {}\n    };\n\n    const exportData: ExportDataTable = exportableCollection.export(params)\n    const exportAoa = exportableCollection.getBodyAoa(exportData);\n    const { sheetName, fileName } = this.getFileName(name);\n\n    xlsx.utils.sheet_add_aoa(worksheet, [exportData.header], { origin: -1 });\n    // add table table data to the worksheet\n    xlsx.utils.sheet_add_aoa(worksheet, exportAoa, { origin: -1 });\n    // set empty row after current table\n    xlsx.utils.sheet_add_aoa(worksheet, [], { origin: -1 });\n\n    xlsx.utils.book_append_sheet(workbook, worksheet);\n    const excelFile: BlobPart = xlsx.write(workbook, { bookType: 'xlsx', type: 'array' });\n\n    const data: Blob = new Blob([excelFile], {\n      type: EXCEL_TYPE\n    });\n    FileSaver.saveAs(data, `${fileName}.xlsx`);\n  }\n}\n"]}
@@ -6800,6 +6800,9 @@ class TransactionCollection extends TransactionBaseCollection {
6800
6800
  * we use depreciations as expense transactions a lot
6801
6801
  */
6802
6802
  constructor(transactions = [], depreciations = []) {
6803
+ if (depreciations.length) {
6804
+ transactions = transactions.filter(transaction => !CHART_ACCOUNTS_CATEGORIES.depreciation.includes(transaction.chartAccounts.category));
6805
+ }
6803
6806
  super([...transactions, ...depreciations.map((depreciation) => depreciation.toTransaction())]);
6804
6807
  }
6805
6808
  getSoleTransactions() {
@@ -7384,7 +7387,7 @@ class MyTaxBusinessLosses {
7384
7387
  this.logbookExpensesAmount = Math.abs(transactions.getVehicleTransactions().sumBy('claimAmount')) +
7385
7388
  depreciations.getVehicleDepreciations().sumBy('claimAmount');
7386
7389
  this.otherExpensesAmount = Math.abs(transactions
7387
- .filterBy('chartAccounts.heading.id', ChartAccountsHeadingListEnum.OTHER_EXPENSES)
7390
+ .filterBy('chartAccounts.taxReturnItem.id', TaxReturnItemEnum.ALL_OTHER_EXPENSES)
7388
7391
  .sumBy('claimAmount'));
7389
7392
  this.totalNonPrimaryProductionExpensesAmount = Math.abs(transactions
7390
7393
  .filterBy('chartAccounts.category', [ChartAccountsCategoryEnum.SOLE_EXPENSE])
@@ -7402,8 +7405,7 @@ class MyTaxBusinessLosses {
7402
7405
  this.deductionsForGeneralSmallBusinessPoolAmount = depreciations
7403
7406
  .getSBPDepreciations()
7404
7407
  .sumBy('claimAmount');
7405
- this.currentYearNetNonPrimaryIncomeOrLossesAmount = new TransactionCollection(transactions.toArray(), depreciations.toArray())
7406
- .getBusinessClaimAmount();
7408
+ this.currentYearNetNonPrimaryIncomeOrLossesAmount = taxSummary.sole.items.sumByCategoriesAndSection([TaxReturnCategoryListEnum.BUSINESS_INCOME_OR_LOSS], TaxSummarySectionEnum.SOLE_TANK);
7407
7409
  this.priorYearsNonPrimaryLossesAmount = businessLosses.sumBy('openBalance');
7408
7410
  this.netNonPrimaryIncomeOrLossesAmount = this.currentYearNetNonPrimaryIncomeOrLossesAmount -
7409
7411
  this.priorYearsNonPrimaryLossesAmount;
@@ -19431,8 +19433,8 @@ const EXCEL_TYPE = 'application/vnd.openxmlformats-officedocument.spreadsheetml.
19431
19433
  class XlsxService {
19432
19434
  constructor() {
19433
19435
  this.getFileName = (name) => {
19434
- let sheetName = name || "ExportResult";
19435
- let fileName = `${sheetName}`;
19436
+ const sheetName = name || 'ExportResult';
19437
+ const fileName = `${sheetName}`;
19436
19438
  return {
19437
19439
  sheetName,
19438
19440
  fileName
@@ -19461,16 +19463,15 @@ class XlsxService {
19461
19463
  // add caption for the current table
19462
19464
  xlsx.utils.sheet_add_aoa(worksheet, [[data.caption?.innerText]], { origin: -1 });
19463
19465
  // Prepare to add table data to the worksheet, processing each cell
19464
- const rows = Array.from(data.rows).map((row) => {
19465
- return Array.from(row.cells).map((cell) => {
19466
- let cellValue = cell.innerText;
19467
- // Convert currency strings like "$0.00" to numbers
19468
- if (/^-?\$/.test(cellValue)) {
19469
- cellValue = parseFloat(cellValue.replace('$', ''));
19470
- }
19471
- return cellValue;
19472
- });
19473
- });
19466
+ const rows = Array.from(data.rows).map((row) => Array.from(row.cells).map((cell) => {
19467
+ const cellValue = cell.innerText;
19468
+ // Convert currency strings like "$0.00" to numbers
19469
+ if (/^-?\$/.test(cellValue)) {
19470
+ // @TODO vik fix
19471
+ // cellValue = parseFloat(cellValue.replace('$', ''));
19472
+ }
19473
+ return cellValue;
19474
+ }));
19474
19475
  // Add the processed table data to the worksheet
19475
19476
  xlsx.utils.sheet_add_aoa(worksheet, rows, { origin: -1 });
19476
19477
  // set empty row after current table
@@ -19492,7 +19493,7 @@ class XlsxService {
19492
19493
  };
19493
19494
  const exportData = exportableCollection.export(params);
19494
19495
  const exportAoa = exportableCollection.getBodyAoa(exportData);
19495
- let { sheetName, fileName } = this.getFileName(name);
19496
+ const { sheetName, fileName } = this.getFileName(name);
19496
19497
  xlsx.utils.sheet_add_aoa(worksheet, [exportData.header], { origin: -1 });
19497
19498
  // add table table data to the worksheet
19498
19499
  xlsx.utils.sheet_add_aoa(worksheet, exportAoa, { origin: -1 });