taxtank-core 0.27.2 → 0.27.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/taxtank-core.umd.js +441 -199
- package/bundles/taxtank-core.umd.js.map +1 -1
- package/esm2015/lib/collections/chart-accounts.collection.js +3 -3
- package/esm2015/lib/collections/depreciation.collection.js +10 -9
- package/esm2015/lib/collections/transaction/transaction.collection.js +5 -2
- package/esm2015/lib/collections/vehicle/vehicle-claim.collection.js +2 -4
- package/esm2015/lib/collections/vehicle/vehicle-logbook.collection.js +15 -30
- package/esm2015/lib/db/Enums/depreciation-calculation.enum.js +2 -1
- package/esm2015/lib/db/Enums/sole-depreciation-method.enum.js +6 -0
- package/esm2015/lib/db/Models/sole/sole-business-activity.js +4 -0
- package/esm2015/lib/db/Models/sole/sole-business.js +1 -1
- package/esm2015/lib/db/Models/sole/sole-depreciation-method.js +4 -0
- package/esm2015/lib/db/Models/sole/sole-details.js +1 -1
- package/esm2015/lib/db/Models/user/user.js +1 -1
- package/esm2015/lib/forms/abstract.form.js +11 -5
- package/esm2015/lib/forms/bank/bank-account/bank-account-allocation.form.js +6 -3
- package/esm2015/lib/forms/sole/index.js +2 -1
- package/esm2015/lib/forms/sole/sole-business-allocations.form.js +2 -1
- package/esm2015/lib/forms/sole/sole-business.form.js +3 -3
- package/esm2015/lib/forms/sole/sole-depreciation-method.form.js +10 -0
- package/esm2015/lib/forms/sole/sole-invoice-template.form.js +2 -2
- package/esm2015/lib/forms/vehicle/vehicle-claim-details.form.js +3 -7
- package/esm2015/lib/forms/vehicle/vehicle-claim.form.js +8 -2
- package/esm2015/lib/forms/vehicle/vehicle-logbook.form.js +22 -15
- package/esm2015/lib/models/account-setup/account-setup-items.const.js +2 -2
- package/esm2015/lib/models/bank/bank-account.js +4 -1
- package/esm2015/lib/models/chart-accounts/chart-accounts.js +9 -9
- package/esm2015/lib/models/depreciation/depreciation-group.enum.js +2 -1
- package/esm2015/lib/models/depreciation/depreciation-groups.const.js +7 -2
- package/esm2015/lib/models/depreciation/depreciation.js +32 -25
- package/esm2015/lib/models/endpoint/endpoints.const.js +6 -4
- package/esm2015/lib/models/event/app-event-type.enum.js +33 -31
- package/esm2015/lib/models/financial-year/financial-year.js +2 -1
- package/esm2015/lib/models/report/depreciation/depreciation-report-item.js +2 -2
- package/esm2015/lib/models/report/my-tax/my-tax-deductions/my-tax-deductions.js +3 -3
- package/esm2015/lib/models/sole/index.js +3 -1
- package/esm2015/lib/models/sole/sole-business-activity.js +4 -0
- package/esm2015/lib/models/sole/sole-business.js +5 -1
- package/esm2015/lib/models/sole/sole-depreciation-method.js +8 -0
- package/esm2015/lib/models/sole/sole-invoice-template.js +5 -4
- package/esm2015/lib/models/transaction/transaction.js +3 -3
- package/esm2015/lib/models/vehicle/logbook-period.js +2 -1
- package/esm2015/lib/models/vehicle/vehicle-claim-details.js +12 -11
- package/esm2015/lib/models/vehicle/vehicle-claim.js +14 -13
- package/esm2015/lib/models/vehicle/vehicle-logbook.js +18 -5
- package/esm2015/lib/services/account-setup/account-setup.service.js +2 -2
- package/esm2015/lib/services/affiliate/rewardful/rewardful.service.js +34 -0
- package/esm2015/lib/services/http/depreciation/depreciation.service.js +19 -2
- package/esm2015/lib/services/http/property/property.service.js +8 -1
- package/esm2015/lib/services/http/sole/index.js +3 -1
- package/esm2015/lib/services/http/sole/sole-business-activity/sole-business-activity.service.js +21 -0
- package/esm2015/lib/services/http/sole/sole-depreciation-method/sole-depreciation-method.service.js +62 -0
- package/esm2015/lib/services/http/transaction/transaction.service.js +1 -2
- package/esm2015/lib/services/http/vehicle/vehicle-claim-details.service.js +7 -6
- package/esm2015/lib/services/http/vehicle/vehicle-claim.service.js +10 -10
- package/esm2015/lib/services/index.js +2 -1
- package/esm2015/public-api.js +2 -1
- package/fesm2015/taxtank-core.js +381 -189
- package/fesm2015/taxtank-core.js.map +1 -1
- package/lib/collections/chart-accounts.collection.d.ts +2 -2
- package/lib/collections/depreciation.collection.d.ts +2 -1
- package/lib/collections/transaction/transaction.collection.d.ts +2 -2
- package/lib/collections/vehicle/vehicle-claim.collection.d.ts +1 -3
- package/lib/collections/vehicle/vehicle-logbook.collection.d.ts +4 -9
- package/lib/db/Enums/depreciation-calculation.enum.d.ts +2 -1
- package/lib/db/Enums/sole-depreciation-method.enum.d.ts +4 -0
- package/lib/db/Models/sole/sole-business-activity.d.ts +6 -0
- package/lib/db/Models/sole/sole-business.d.ts +2 -1
- package/lib/db/Models/sole/sole-depreciation-method.d.ts +10 -0
- package/lib/db/Models/user/user.d.ts +1 -0
- package/lib/forms/abstract.form.d.ts +3 -1
- package/lib/forms/bank/bank-account/bank-account-allocation.form.d.ts +4 -2
- package/lib/forms/sole/index.d.ts +1 -0
- package/lib/forms/sole/sole-business-allocations.form.d.ts +1 -0
- package/lib/forms/sole/sole-business.form.d.ts +1 -1
- package/lib/forms/sole/sole-depreciation-method.form.d.ts +5 -0
- package/lib/forms/vehicle/vehicle-claim-details.form.d.ts +1 -6
- package/lib/forms/vehicle/vehicle-claim.form.d.ts +3 -0
- package/lib/forms/vehicle/vehicle-logbook.form.d.ts +4 -0
- package/lib/models/bank/bank-account.d.ts +2 -0
- package/lib/models/chart-accounts/chart-accounts.d.ts +6 -6
- package/lib/models/depreciation/depreciation-group.enum.d.ts +2 -1
- package/lib/models/depreciation/depreciation.d.ts +9 -16
- package/lib/models/event/app-event-type.enum.d.ts +32 -30
- package/lib/models/financial-year/financial-year.d.ts +1 -0
- package/lib/models/sole/index.d.ts +2 -0
- package/lib/models/sole/sole-business-activity.d.ts +3 -0
- package/lib/models/sole/sole-business.d.ts +2 -0
- package/lib/models/sole/sole-depreciation-method.d.ts +4 -0
- package/lib/models/sole/sole-invoice-template.d.ts +1 -1
- package/lib/models/transaction/transaction.d.ts +2 -2
- package/lib/models/vehicle/logbook-period.d.ts +1 -0
- package/lib/models/vehicle/vehicle-claim-details.d.ts +8 -2
- package/lib/models/vehicle/vehicle-claim.d.ts +6 -4
- package/lib/models/vehicle/vehicle-logbook.d.ts +8 -4
- package/lib/services/affiliate/rewardful/rewardful.service.d.ts +13 -0
- package/lib/services/http/depreciation/depreciation.service.d.ts +8 -0
- package/lib/services/http/property/property.service.d.ts +1 -0
- package/lib/services/http/sole/index.d.ts +2 -0
- package/lib/services/http/sole/sole-business-activity/sole-business-activity.service.d.ts +11 -0
- package/lib/services/http/sole/sole-depreciation-method/sole-depreciation-method.service.d.ts +23 -0
- package/lib/services/index.d.ts +1 -0
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
|
@@ -3,10 +3,10 @@ import { ChartAccountsListEnum } from '../db/Enums/chart-accounts-list.enum';
|
|
|
3
3
|
import { FinancialYear } from '../models/financial-year/financial-year';
|
|
4
4
|
export class ChartAccountsCollection extends Collection {
|
|
5
5
|
/**
|
|
6
|
-
* Get '
|
|
6
|
+
* Get 'Kms travelled for work' related chart account value
|
|
7
7
|
*/
|
|
8
|
-
|
|
8
|
+
getVehicleKmsRate(year = new FinancialYear().year) {
|
|
9
9
|
return this.findBy('id', ChartAccountsListEnum.KLMS_TRAVELLED_FOR_WORK).getValueByYear(year).value;
|
|
10
10
|
}
|
|
11
11
|
}
|
|
12
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
12
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhcnQtYWNjb3VudHMuY29sbGVjdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3R0LWNvcmUvc3JjL2xpYi9jb2xsZWN0aW9ucy9jaGFydC1hY2NvdW50cy5jb2xsZWN0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFFMUMsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sc0NBQXNDLENBQUM7QUFDN0UsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHlDQUF5QyxDQUFDO0FBR3hFLE1BQU0sT0FBTyx1QkFBd0IsU0FBUSxVQUF5QjtJQUNwRTs7T0FFRztJQUNILGlCQUFpQixDQUFDLE9BQWUsSUFBSSxhQUFhLEVBQUUsQ0FBQyxJQUFJO1FBQ3ZELE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLEVBQUUscUJBQXFCLENBQUMsdUJBQXVCLENBQUMsQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLENBQUMsS0FBSyxDQUFBO0lBQ3BHLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbGxlY3Rpb24gfSBmcm9tICcuL2NvbGxlY3Rpb24nO1xuaW1wb3J0IHsgQ2hhcnRBY2NvdW50cyB9IGZyb20gJy4uL21vZGVscy9jaGFydC1hY2NvdW50cy9jaGFydC1hY2NvdW50cyc7XG5pbXBvcnQgeyBDaGFydEFjY291bnRzTGlzdEVudW0gfSBmcm9tICcuLi9kYi9FbnVtcy9jaGFydC1hY2NvdW50cy1saXN0LmVudW0nO1xuaW1wb3J0IHsgRmluYW5jaWFsWWVhciB9IGZyb20gJy4uL21vZGVscy9maW5hbmNpYWwteWVhci9maW5hbmNpYWwteWVhcic7XG5cblxuZXhwb3J0IGNsYXNzIENoYXJ0QWNjb3VudHNDb2xsZWN0aW9uIGV4dGVuZHMgQ29sbGVjdGlvbjxDaGFydEFjY291bnRzPiB7XG4gIC8qKlxuICAgKiBHZXQgJ0ttcyB0cmF2ZWxsZWQgZm9yIHdvcmsnIHJlbGF0ZWQgY2hhcnQgYWNjb3VudCB2YWx1ZVxuICAgKi9cbiAgZ2V0VmVoaWNsZUttc1JhdGUoeWVhcjogbnVtYmVyID0gbmV3IEZpbmFuY2lhbFllYXIoKS55ZWFyKTogbnVtYmVyIHtcbiAgICByZXR1cm4gdGhpcy5maW5kQnkoJ2lkJywgQ2hhcnRBY2NvdW50c0xpc3RFbnVtLktMTVNfVFJBVkVMTEVEX0ZPUl9XT1JLKS5nZXRWYWx1ZUJ5WWVhcih5ZWFyKS52YWx1ZVxuICB9XG59XG4iXX0=
|
|
@@ -57,19 +57,22 @@ export class DepreciationCollection extends Collection {
|
|
|
57
57
|
return this.filter((depreciation) => depreciation.isAsset());
|
|
58
58
|
}
|
|
59
59
|
getPlantEquipment() {
|
|
60
|
-
return this.filter((depreciation) => depreciation.
|
|
60
|
+
return this.filter((depreciation) => depreciation.isPlantEquipmentPool());
|
|
61
61
|
}
|
|
62
62
|
getCapitalDepreciations() {
|
|
63
63
|
return this.filter((depreciation) => depreciation.isCapital());
|
|
64
64
|
}
|
|
65
65
|
getBorrowingExpenseDepreciations() {
|
|
66
|
-
return
|
|
66
|
+
return this.filter((depreciation) => depreciation.isBorrowingExpense());
|
|
67
67
|
}
|
|
68
68
|
getWrittenOffDepreciations() {
|
|
69
|
-
return
|
|
69
|
+
return this.filter((depreciation) => depreciation.isWrittenOff());
|
|
70
70
|
}
|
|
71
|
-
|
|
72
|
-
return
|
|
71
|
+
getLVPDepreciations() {
|
|
72
|
+
return this.filter((depreciation) => depreciation.isLVP());
|
|
73
|
+
}
|
|
74
|
+
getSBPDepreciations() {
|
|
75
|
+
return this.filter((depreciation) => depreciation.isSBP());
|
|
73
76
|
}
|
|
74
77
|
getCapitalProjects() {
|
|
75
78
|
return uniqBy(compact(this.items.map((depreciation) => {
|
|
@@ -80,9 +83,7 @@ export class DepreciationCollection extends Collection {
|
|
|
80
83
|
* Get a new collection of depreciations related to vehicles
|
|
81
84
|
*/
|
|
82
85
|
getVehicleDepreciations() {
|
|
83
|
-
return this.
|
|
84
|
-
return depreciation.isVehicleDepreciation();
|
|
85
|
-
}));
|
|
86
|
+
return this.filter((depreciation) => depreciation.isVehicleDepreciation());
|
|
86
87
|
}
|
|
87
88
|
getByTankType(tankType) {
|
|
88
89
|
return this.create(this.items.filter((depreciation) => {
|
|
@@ -116,4 +117,4 @@ export class DepreciationCollection extends Collection {
|
|
|
116
117
|
: this.getVehicleDepreciations().filterBy('tankType', TankTypeEnum.WORK);
|
|
117
118
|
}
|
|
118
119
|
}
|
|
119
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"depreciation.collection.js","sourceRoot":"","sources":["../../../../../projects/tt-core/src/lib/collections/depreciation.collection.ts"],"names":[],"mappings":"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","sourcesContent":["import { TankTypeEnum } from '../db/Enums/tank-type.enum';\nimport { Collection } from './collection';\nimport { Depreciation } from '../models/depreciation/depreciation';\nimport uniqBy from 'lodash/uniqBy';\nimport compact from 'lodash/compact';\nimport { DepreciationCapitalProject } from '../models/depreciation/depreciation-capital-project';\nimport { TransactionCollection } from './transaction/transaction.collection';\nimport { ChartAccountsCategoryEnum } from '../db/Enums/chart-accounts-category.enum';\nimport { VehicleClaim } from '../models';\n\nexport class DepreciationCollection extends Collection<Depreciation> {\n\n  /**\n   * Get total amount of all depreciations in the collection\n   */\n  get amount(): number {\n    return this.items.reduce((sum: number, depreciation: Depreciation): number => sum + depreciation.amount, 0);\n  }\n\n  get claimAmount(): number {\n    return this.items.reduce((sum: number, depreciation: Depreciation) => {\n      return sum + depreciation.currentYearForecast.claimAmount;\n    }, 0);\n  }\n\n  getClaimedAmountByYear(year: number = +localStorage.getItem('financialYear')): number {\n    return +Math.round(this.amount - this.items.reduce((sum: number, depreciation: Depreciation): number => {\n      return sum + depreciation.getCloseBalanceByYear(year);\n    }, 0)).toFixed(2);\n  }\n\n  getClaimAmountByYear(year: number = +localStorage.getItem('financialYear')): number {\n    return this.items.reduce((sum: number, depreciation: Depreciation): number => {\n      return sum + depreciation.getClaimAmountByYear(year);\n    }, 0);\n  }\n\n  getCloseBalanceByYear(year: number = +localStorage.getItem('financialYear')): number {\n    return this.items.reduce((sum: number, depreciation: Depreciation): number => {\n      return sum + depreciation.getCloseBalanceByYear(year);\n    }, 0);\n  }\n\n  getCurrentYearForecastAmount(): number {\n    return this.items.reduce((sum: number, depreciation: Depreciation): number => {\n      return sum + depreciation.currentYearForecast.amount;\n    }, 0);\n  }\n\n  get closeBalance(): number {\n    return this.sumBy('currentYearForecast.closeBalance');\n  }\n\n  getByPropertiesIds(ids: number[]): DepreciationCollection {\n    return new DepreciationCollection(\n      this.items.filter((depreciation: Depreciation): boolean => ids.includes(depreciation.property?.id))\n    );\n  }\n\n  getWithCapitalProject(): DepreciationCollection {\n    return new DepreciationCollection(\n      this.items.filter((depreciation: Depreciation): boolean => !!depreciation.depreciationCapitalProject)\n    );\n  }\n\n  getWithoutCapitalProject(): DepreciationCollection {\n    return new DepreciationCollection(\n      this.items.filter((depreciation: Depreciation): boolean => !depreciation.depreciationCapitalProject)\n    );\n  }\n\n  getWithoutBorrowingExpenses(): DepreciationCollection {\n    return new DepreciationCollection(\n      this.items.filter((depreciation: Depreciation): boolean => !depreciation.isBorrowingExpense())\n    );\n  }\n\n  getByChartAccountsCategories(categories: ChartAccountsCategoryEnum[]): this {\n    return this.create(\n      this.items.filter((depreciation: Depreciation): boolean => categories.includes(depreciation.chartAccounts.category))\n    );\n  }\n\n  getAssets(): this {\n    return this.filter((depreciation) => depreciation.isAsset());\n  }\n\n  getPlantEquipment(): this {\n    return this.filter((depreciation) => depreciation.isPlantEquipment());\n  }\n\n  getCapitalDepreciations(): this {\n    return this.filter((depreciation) => depreciation.isCapital());\n  }\n\n  getBorrowingExpenseDepreciations(): DepreciationCollection {\n    return new DepreciationCollection(\n      this.items.filter((depreciation: Depreciation): boolean => depreciation.isBorrowingExpense())\n    );\n  }\n\n  getWrittenOffDepreciations(): DepreciationCollection {\n    return new DepreciationCollection(\n      this.items.filter((depreciation: Depreciation): boolean => depreciation.isWrittenOff())\n    );\n  }\n\n  getLowValuePoolDepreciations(): DepreciationCollection {\n    return new DepreciationCollection(\n      this.items.filter((depreciation: Depreciation): boolean => depreciation.isLowValuePool())\n    );\n  }\n\n  getCapitalProjects(): DepreciationCapitalProject[] {\n    return uniqBy(\n      compact(\n        this.items.map((depreciation: Depreciation): DepreciationCapitalProject => {\n          return depreciation.depreciationCapitalProject;\n        })\n      ),\n      'id'\n    );\n  }\n\n  /**\n   * Get a new collection of depreciations related to vehicles\n   */\n  getVehicleDepreciations(): this {\n    return this.create(\n      this.items.filter((depreciation: Depreciation): boolean => {\n        return depreciation.isVehicleDepreciation();\n      })\n    );\n  }\n\n  getByTankType(tankType: TankTypeEnum): this {\n    return this.create(\n      this.items.filter((depreciation: Depreciation): boolean => {\n        switch (tankType) {\n          case TankTypeEnum.PROPERTY:\n            return depreciation.isPropertyTank();\n          case TankTypeEnum.WORK:\n            return depreciation.isWorkTank();\n          case TankTypeEnum.SOLE:\n            return depreciation.isSoleTank();\n          // case for other tank or some extra\n          default:\n            return false;\n        }\n      })\n    );\n  }\n\n  /**\n   * Create TransactionCollection from depreciation items\n   */\n  toTransactions(): TransactionCollection {\n    return new TransactionCollection(\n      this.items.map((item: Depreciation) => item.toTransaction())\n    );\n  }\n\n  /**\n   * Get depreciations by vehicle claim. Only vehicle depreciations may be related to vehicle claim\n   */\n  getByVehicleClaim(vehicleClaim: VehicleClaim): this {\n    return vehicleClaim.isSoleTank()\n      // sole tank may have multiple vehicle claims, so we need to filter by business.id\n      ? this.getVehicleDepreciations().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.getVehicleDepreciations().filterBy('tankType', TankTypeEnum.WORK);\n  }\n}\n"]}
|
|
120
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"depreciation.collection.js","sourceRoot":"","sources":["../../../../../projects/tt-core/src/lib/collections/depreciation.collection.ts"],"names":[],"mappings":"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","sourcesContent":["import { TankTypeEnum } from '../db/Enums/tank-type.enum';\nimport { Collection } from './collection';\nimport { Depreciation } from '../models/depreciation/depreciation';\nimport uniqBy from 'lodash/uniqBy';\nimport compact from 'lodash/compact';\nimport { DepreciationCapitalProject } from '../models/depreciation/depreciation-capital-project';\nimport { TransactionCollection } from './transaction/transaction.collection';\nimport { ChartAccountsCategoryEnum } from '../db/Enums/chart-accounts-category.enum';\nimport { VehicleClaim } from '../models';\n\nexport class DepreciationCollection extends Collection<Depreciation> {\n\n  /**\n   * Get total amount of all depreciations in the collection\n   */\n  get amount(): number {\n    return this.items.reduce((sum: number, depreciation: Depreciation): number => sum + depreciation.amount, 0);\n  }\n\n  get claimAmount(): number {\n    return this.items.reduce((sum: number, depreciation: Depreciation) => {\n      return sum + depreciation.currentYearForecast.claimAmount;\n    }, 0);\n  }\n\n  getClaimedAmountByYear(year: number = +localStorage.getItem('financialYear')): number {\n    return +Math.round(this.amount - this.items.reduce((sum: number, depreciation: Depreciation): number => {\n      return sum + depreciation.getCloseBalanceByYear(year);\n    }, 0)).toFixed(2);\n  }\n\n  getClaimAmountByYear(year: number = +localStorage.getItem('financialYear')): number {\n    return this.items.reduce((sum: number, depreciation: Depreciation): number => {\n      return sum + depreciation.getClaimAmountByYear(year);\n    }, 0);\n  }\n\n  getCloseBalanceByYear(year: number = +localStorage.getItem('financialYear')): number {\n    return this.items.reduce((sum: number, depreciation: Depreciation): number => {\n      return sum + depreciation.getCloseBalanceByYear(year);\n    }, 0);\n  }\n\n  getCurrentYearForecastAmount(): number {\n    return this.items.reduce((sum: number, depreciation: Depreciation): number => {\n      return sum + depreciation.currentYearForecast.amount;\n    }, 0);\n  }\n\n  get closeBalance(): number {\n    return this.sumBy('currentYearForecast.closeBalance');\n  }\n\n  getByPropertiesIds(ids: number[]): DepreciationCollection {\n    return new DepreciationCollection(\n      this.items.filter((depreciation: Depreciation): boolean => ids.includes(depreciation.property?.id))\n    );\n  }\n\n  getWithCapitalProject(): DepreciationCollection {\n    return new DepreciationCollection(\n      this.items.filter((depreciation: Depreciation): boolean => !!depreciation.depreciationCapitalProject)\n    );\n  }\n\n  getWithoutCapitalProject(): DepreciationCollection {\n    return new DepreciationCollection(\n      this.items.filter((depreciation: Depreciation): boolean => !depreciation.depreciationCapitalProject)\n    );\n  }\n\n  getWithoutBorrowingExpenses(): DepreciationCollection {\n    return new DepreciationCollection(\n      this.items.filter((depreciation: Depreciation): boolean => !depreciation.isBorrowingExpense())\n    );\n  }\n\n  getByChartAccountsCategories(categories: ChartAccountsCategoryEnum[]): this {\n    return this.create(\n      this.items.filter((depreciation: Depreciation): boolean => categories.includes(depreciation.chartAccounts.category))\n    );\n  }\n\n  getAssets(): this {\n    return this.filter((depreciation) => depreciation.isAsset());\n  }\n\n  getPlantEquipment(): this {\n    return this.filter((depreciation) => depreciation.isPlantEquipmentPool());\n  }\n\n  getCapitalDepreciations(): this {\n    return this.filter((depreciation) => depreciation.isCapital());\n  }\n\n  getBorrowingExpenseDepreciations(): DepreciationCollection {\n    return this.filter((depreciation: Depreciation) => depreciation.isBorrowingExpense());\n  }\n\n  getWrittenOffDepreciations(): DepreciationCollection {\n    return this.filter((depreciation: Depreciation) => depreciation.isWrittenOff());\n  }\n\n  getLVPDepreciations(): this {\n    return this.filter((depreciation: Depreciation) => depreciation.isLVP());\n  }\n\n  getSBPDepreciations(): this {\n    return this.filter((depreciation: Depreciation) => depreciation.isSBP());\n  }\n\n  getCapitalProjects(): DepreciationCapitalProject[] {\n    return uniqBy(\n      compact(\n        this.items.map((depreciation: Depreciation): DepreciationCapitalProject => {\n          return depreciation.depreciationCapitalProject;\n        })\n      ),\n      'id'\n    );\n  }\n\n  /**\n   * Get a new collection of depreciations related to vehicles\n   */\n  getVehicleDepreciations(): this {\n    return this.filter((depreciation: Depreciation) => depreciation.isVehicleDepreciation());\n  }\n\n  getByTankType(tankType: TankTypeEnum): this {\n    return this.create(\n      this.items.filter((depreciation: Depreciation): boolean => {\n        switch (tankType) {\n          case TankTypeEnum.PROPERTY:\n            return depreciation.isPropertyTank();\n          case TankTypeEnum.WORK:\n            return depreciation.isWorkTank();\n          case TankTypeEnum.SOLE:\n            return depreciation.isSoleTank();\n          // case for other tank or some extra\n          default:\n            return false;\n        }\n      })\n    );\n  }\n\n  /**\n   * Create TransactionCollection from depreciation items\n   */\n  toTransactions(): TransactionCollection {\n    return new TransactionCollection(\n      this.items.map((item: Depreciation) => item.toTransaction())\n    );\n  }\n\n  /**\n   * Get depreciations by vehicle claim. Only vehicle depreciations may be related to vehicle claim\n   */\n  getByVehicleClaim(vehicleClaim: VehicleClaim): this {\n    return vehicleClaim.isSoleTank()\n      // sole tank may have multiple vehicle claims, so we need to filter by business.id\n      ? this.getVehicleDepreciations().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.getVehicleDepreciations().filterBy('tankType', TankTypeEnum.WORK);\n  }\n}\n"]}
|
|
@@ -172,6 +172,9 @@ export class TransactionCollection extends ExportableCollection {
|
|
|
172
172
|
* Get list of vehicle transactions filtered by vehicle claim
|
|
173
173
|
*/
|
|
174
174
|
getByVehicleClaim(vehicleClaim) {
|
|
175
|
+
if (!vehicleClaim) {
|
|
176
|
+
return this.create([]);
|
|
177
|
+
}
|
|
175
178
|
return vehicleClaim.isSoleTank()
|
|
176
179
|
// sole tank may have multiple vehicle claims, so we need to filter by business.id
|
|
177
180
|
? this.getVehicleTransactions().filterBy('business.id', vehicleClaim.business.id)
|
|
@@ -179,7 +182,7 @@ export class TransactionCollection extends ExportableCollection {
|
|
|
179
182
|
: this.getVehicleTransactions().filterBy('tankType', TankTypeEnum.WORK);
|
|
180
183
|
}
|
|
181
184
|
/**
|
|
182
|
-
* Get list of vehicle transactions except
|
|
185
|
+
* Get list of vehicle transactions except KMS transactions
|
|
183
186
|
*/
|
|
184
187
|
getLogbookTransactions() {
|
|
185
188
|
return this
|
|
@@ -187,4 +190,4 @@ export class TransactionCollection extends ExportableCollection {
|
|
|
187
190
|
.removeBy('chartAccounts.id', [ChartAccountsListEnum.KLMS_TRAVELLED_FOR_WORK, ChartAccountsListEnum.KLMS_TRAVELLED]);
|
|
188
191
|
}
|
|
189
192
|
}
|
|
190
|
-
//# 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 { Transaction } from '../../models/transaction/transaction';\nimport { TransactionAllocationCollection } from './transaction-allocation.collection';\nimport { ChartAccountsCategoryEnum } from '../../db/Enums/chart-accounts-category.enum';\nimport { TankTypeEnum } from '../../db/Enums/tank-type.enum';\nimport { ExportableCollection } from '../exportable.collection';\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 { TransactionMetadata } from '../../models/transaction/transaction-metadata';\nimport { VehicleClaim } from '../../models';\nimport { ChartAccountsListEnum } from '../../db/Enums/chart-accounts-list.enum';\n\n/**\n * Collection of transactions\n */\nexport class TransactionCollection extends ExportableCollection<Transaction> {\n  /**\n   * Get total amount of all transactions in the collection\n   */\n  get amount(): number {\n    return +this.items.reduce((sum: number, transaction: Transaction) => sum + transaction.getNetAmount(), 0).toFixed(2);\n  }\n\n  /**\n   * Difference between allocated amount and total amount\n   */\n  getUnallocatedAmount(allocations: TransactionAllocationCollection): number {\n    return +(this.amount - allocations.getByTransactionsIds(this.getIds()).amount).toFixed(2);\n  }\n\n  /**\n   * Get cash position\n   * Cash Position = Income - Expenses\n   * Cash position is equal to Total Amount because income is positive and expense is negative,\n   */\n  get cashPosition(): number {\n    return this.claimAmount;\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  /**\n   * Get summary of claim amounts\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.amount, 0).toFixed(2);\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 metadata\n   */\n  getTransactionsMetadata(): Collection<TransactionMetadata> {\n    const metadataArray: TransactionMetadata[] = [];\n\n    this.items.forEach((transaction: Transaction) => {\n      metadataArray.push(...transaction.metadata);\n    });\n\n    return new Collection<TransactionMetadata>(metadataArray);\n  }\n\n  getIncomeTransactions(): TransactionCollection {\n    return new TransactionCollection(\n      this.items.filter((transaction: Transaction): boolean => transaction.isIncome())\n    );\n  }\n\n  get claimIncome(): number {\n    return this.getIncomeTransactions().claimAmount;\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 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 => {\n        return ids.includes(transaction.property?.id);\n      })\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 new TransactionCollection(\n      this.items.filter((transaction: Transaction): boolean => transaction.isPropertyTank())\n    );\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  /**\n   * Get transactions related to Vehicle category\n   */\n  getVehicleTransactions(): this {\n    return this.create(\n      this.items.filter((transaction: Transaction): boolean => {\n        return transaction.isVehicleTransaction();\n      })\n    );\n  }\n\n  /**\n   * Get new transaction collection filtered by tank type\n   */\n  getByTankType(tankType: TankTypeEnum): this {\n    return this.create(\n      this.items.filter((transaction: Transaction): boolean => {\n        switch (tankType) {\n          case TankTypeEnum.PROPERTY:\n            return transaction.isPropertyTank();\n          case TankTypeEnum.WORK:\n            return transaction.isWorkTank();\n          case TankTypeEnum.SOLE:\n            return transaction.isSoleTank();\n          // Transaction may be not related to any tank type (personal)\n          default:\n            return false;\n        }\n      })\n    );\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    return this.items.map((transaction: Transaction) => {\n      return [\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  /**\n   * Get list of vehicle transactions filtered by vehicle claim\n   */\n  getByVehicleClaim(vehicleClaim: VehicleClaim): this {\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 KLMS 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"]}
|
|
193
|
+
//# 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 { Transaction } from '../../models/transaction/transaction';\nimport { TransactionAllocationCollection } from './transaction-allocation.collection';\nimport { ChartAccountsCategoryEnum } from '../../db/Enums/chart-accounts-category.enum';\nimport { TankTypeEnum } from '../../db/Enums/tank-type.enum';\nimport { ExportableCollection } from '../exportable.collection';\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 { TransactionMetadata } from '../../models/transaction/transaction-metadata';\nimport { VehicleClaim } from '../../models';\nimport { ChartAccountsListEnum } from '../../db/Enums/chart-accounts-list.enum';\n\n/**\n * Collection of transactions\n */\nexport class TransactionCollection extends ExportableCollection<Transaction> {\n  /**\n   * Get total amount of all transactions in the collection\n   */\n  get amount(): number {\n    return +this.items.reduce((sum: number, transaction: Transaction) => sum + transaction.getNetAmount(), 0).toFixed(2);\n  }\n\n  /**\n   * Difference between allocated amount and total amount\n   */\n  getUnallocatedAmount(allocations: TransactionAllocationCollection): number {\n    return +(this.amount - allocations.getByTransactionsIds(this.getIds()).amount).toFixed(2);\n  }\n\n  /**\n   * Get cash position\n   * Cash Position = Income - Expenses\n   * Cash position is equal to Total Amount because income is positive and expense is negative,\n   */\n  get cashPosition(): number {\n    return this.claimAmount;\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  /**\n   * Get summary of claim amounts\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.amount, 0).toFixed(2);\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 metadata\n   */\n  getTransactionsMetadata(): Collection<TransactionMetadata> {\n    const metadataArray: TransactionMetadata[] = [];\n\n    this.items.forEach((transaction: Transaction) => {\n      metadataArray.push(...transaction.metadata);\n    });\n\n    return new Collection<TransactionMetadata>(metadataArray);\n  }\n\n  getIncomeTransactions(): TransactionCollection {\n    return new TransactionCollection(\n      this.items.filter((transaction: Transaction): boolean => transaction.isIncome())\n    );\n  }\n\n  get claimIncome(): number {\n    return this.getIncomeTransactions().claimAmount;\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 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 => {\n        return ids.includes(transaction.property?.id);\n      })\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 new TransactionCollection(\n      this.items.filter((transaction: Transaction): boolean => transaction.isPropertyTank())\n    );\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  /**\n   * Get transactions related to Vehicle category\n   */\n  getVehicleTransactions(): this {\n    return this.create(\n      this.items.filter((transaction: Transaction): boolean => {\n        return transaction.isVehicleTransaction();\n      })\n    );\n  }\n\n  /**\n   * Get new transaction collection filtered by tank type\n   */\n  getByTankType(tankType: TankTypeEnum): this {\n    return this.create(\n      this.items.filter((transaction: Transaction): boolean => {\n        switch (tankType) {\n          case TankTypeEnum.PROPERTY:\n            return transaction.isPropertyTank();\n          case TankTypeEnum.WORK:\n            return transaction.isWorkTank();\n          case TankTypeEnum.SOLE:\n            return transaction.isSoleTank();\n          // Transaction may be not related to any tank type (personal)\n          default:\n            return false;\n        }\n      })\n    );\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    return this.items.map((transaction: Transaction) => {\n      return [\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  /**\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"]}
|
|
@@ -3,9 +3,8 @@ import { VehicleClaim } from '../../models';
|
|
|
3
3
|
export class VehicleClaimCollection extends Collection {
|
|
4
4
|
/**
|
|
5
5
|
* Get remaining kilometers limit. Total limit ({@link VehicleClaim.totalKmsLimit}) - claimed kilometers from other vehicle claims
|
|
6
|
-
* @param claim may not exist when user come to vehicle claim page 1st time and not created claim yet
|
|
7
6
|
*/
|
|
8
|
-
|
|
7
|
+
getKmsLimitForClaim(claim) {
|
|
9
8
|
let collection = this;
|
|
10
9
|
if (claim) {
|
|
11
10
|
collection = collection.removeBy('id', claim.id);
|
|
@@ -14,7 +13,6 @@ export class VehicleClaimCollection extends Collection {
|
|
|
14
13
|
}
|
|
15
14
|
/**
|
|
16
15
|
* Get remaining work usage limit. Total limit ({@link VehicleClaim.totalWorkUsagePercent}) - claimed percent from other vehicle claims
|
|
17
|
-
* @param claim may not exist when user come to vehicle claim page 1st time and not created claim yet
|
|
18
16
|
*/
|
|
19
17
|
getWorkUsageLimitForClaim(claim) {
|
|
20
18
|
let collection = this;
|
|
@@ -24,4 +22,4 @@ export class VehicleClaimCollection extends Collection {
|
|
|
24
22
|
return VehicleClaim.totalWorkUsagePercent - collection.sumBy('workUsage');
|
|
25
23
|
}
|
|
26
24
|
}
|
|
27
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
25
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVoaWNsZS1jbGFpbS5jb2xsZWN0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdHQtY29yZS9zcmMvbGliL2NvbGxlY3Rpb25zL3ZlaGljbGUvdmVoaWNsZS1jbGFpbS5jb2xsZWN0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDM0MsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUU1QyxNQUFNLE9BQU8sc0JBQXVCLFNBQVEsVUFBd0I7SUFDbEU7O09BRUc7SUFDSCxtQkFBbUIsQ0FBQyxLQUFvQjtRQUN0QyxJQUFJLFVBQVUsR0FBMkIsSUFBSSxDQUFDO1FBRTlDLElBQUksS0FBSyxFQUFFO1lBQ1QsVUFBVSxHQUFHLFVBQVUsQ0FBQyxRQUFRLENBQUMsSUFBSSxFQUFFLEtBQUssQ0FBQyxFQUFFLENBQUMsQ0FBQztTQUNsRDtRQUVELE9BQU8sWUFBWSxDQUFDLGFBQWEsR0FBRyxVQUFVLENBQUMsS0FBSyxDQUFDLFlBQVksQ0FBQyxDQUFDO0lBQ3JFLENBQUM7SUFFRDs7T0FFRztJQUNILHlCQUF5QixDQUFDLEtBQW9CO1FBQzVDLElBQUksVUFBVSxHQUEyQixJQUFJLENBQUM7UUFFOUMsSUFBSSxLQUFLLEVBQUU7WUFDVCxVQUFVLEdBQUcsVUFBVSxDQUFDLFFBQVEsQ0FBQyxJQUFJLEVBQUUsS0FBSyxDQUFDLEVBQUUsQ0FBQyxDQUFDO1NBQ2xEO1FBRUQsT0FBTyxZQUFZLENBQUMscUJBQXFCLEdBQUcsVUFBVSxDQUFDLEtBQUssQ0FBQyxXQUFXLENBQUMsQ0FBQztJQUM1RSxDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb2xsZWN0aW9uIH0gZnJvbSAnLi4vY29sbGVjdGlvbic7XG5pbXBvcnQgeyBWZWhpY2xlQ2xhaW0gfSBmcm9tICcuLi8uLi9tb2RlbHMnO1xuXG5leHBvcnQgY2xhc3MgVmVoaWNsZUNsYWltQ29sbGVjdGlvbiBleHRlbmRzIENvbGxlY3Rpb248VmVoaWNsZUNsYWltPiB7XG4gIC8qKlxuICAgKiBHZXQgcmVtYWluaW5nIGtpbG9tZXRlcnMgbGltaXQuIFRvdGFsIGxpbWl0ICh7QGxpbmsgVmVoaWNsZUNsYWltLnRvdGFsS21zTGltaXR9KSAtIGNsYWltZWQga2lsb21ldGVycyBmcm9tIG90aGVyIHZlaGljbGUgY2xhaW1zXG4gICAqL1xuICBnZXRLbXNMaW1pdEZvckNsYWltKGNsYWltPzogVmVoaWNsZUNsYWltKTogbnVtYmVyIHtcbiAgICBsZXQgY29sbGVjdGlvbjogVmVoaWNsZUNsYWltQ29sbGVjdGlvbiA9IHRoaXM7XG5cbiAgICBpZiAoY2xhaW0pIHtcbiAgICAgIGNvbGxlY3Rpb24gPSBjb2xsZWN0aW9uLnJlbW92ZUJ5KCdpZCcsIGNsYWltLmlkKTtcbiAgICB9XG5cbiAgICByZXR1cm4gVmVoaWNsZUNsYWltLnRvdGFsS21zTGltaXQgLSBjb2xsZWN0aW9uLnN1bUJ5KCdraWxvbWV0ZXJzJyk7XG4gIH1cblxuICAvKipcbiAgICogR2V0IHJlbWFpbmluZyB3b3JrIHVzYWdlIGxpbWl0LiBUb3RhbCBsaW1pdCAoe0BsaW5rIFZlaGljbGVDbGFpbS50b3RhbFdvcmtVc2FnZVBlcmNlbnR9KSAtIGNsYWltZWQgcGVyY2VudCBmcm9tIG90aGVyIHZlaGljbGUgY2xhaW1zXG4gICAqL1xuICBnZXRXb3JrVXNhZ2VMaW1pdEZvckNsYWltKGNsYWltPzogVmVoaWNsZUNsYWltKTogbnVtYmVyIHtcbiAgICBsZXQgY29sbGVjdGlvbjogVmVoaWNsZUNsYWltQ29sbGVjdGlvbiA9IHRoaXM7XG5cbiAgICBpZiAoY2xhaW0pIHtcbiAgICAgIGNvbGxlY3Rpb24gPSBjb2xsZWN0aW9uLnJlbW92ZUJ5KCdpZCcsIGNsYWltLmlkKTtcbiAgICB9XG5cbiAgICByZXR1cm4gVmVoaWNsZUNsYWltLnRvdGFsV29ya1VzYWdlUGVyY2VudCAtIGNvbGxlY3Rpb24uc3VtQnkoJ3dvcmtVc2FnZScpO1xuICB9XG59XG4iXX0=
|
|
@@ -1,18 +1,17 @@
|
|
|
1
|
-
import { FinancialYear } from '../../models/financial-year/financial-year';
|
|
2
1
|
import { plainToClass } from 'class-transformer';
|
|
3
2
|
import { Collection } from '../collection';
|
|
4
3
|
import { LogbookPeriod, VehicleLogbook } from '../../models';
|
|
5
4
|
import { TankTypeEnum } from '../../db/Enums/tank-type.enum';
|
|
6
5
|
export class VehicleLogbookCollection extends Collection {
|
|
7
6
|
/**
|
|
8
|
-
* Best period may be calculated only when user has logbooks minimum for
|
|
7
|
+
* Best period may be calculated only when user has logbooks minimum for VehicleLogbook.bestPeriodWeeks
|
|
9
8
|
* @TODO Vik: Best period: move this and related logic to backend
|
|
10
9
|
*/
|
|
11
10
|
isBestPeriodExist() {
|
|
12
11
|
if (this.items.length < 2) {
|
|
13
12
|
return false;
|
|
14
13
|
}
|
|
15
|
-
return VehicleLogbook.
|
|
14
|
+
return VehicleLogbook.bestPeriodWeeks < (this.last.date.getTime() - this.first.date.getTime());
|
|
16
15
|
}
|
|
17
16
|
/**
|
|
18
17
|
* Get collection of non-personal logbooks (work-related, sole-related).
|
|
@@ -22,15 +21,14 @@ export class VehicleLogbookCollection extends Collection {
|
|
|
22
21
|
return this.filterBy('isPersonal', false);
|
|
23
22
|
}
|
|
24
23
|
/**
|
|
25
|
-
* Logbook Period
|
|
26
|
-
* Best period duration is defined as
|
|
24
|
+
* Get Logbook Period with the biggest work usage percent
|
|
25
|
+
* Best period duration is defined as VehicleLogbook.bestPeriodWeeks by the ATO
|
|
27
26
|
* @TODO Vik: Best period: move this and related logic to backend
|
|
28
27
|
*/
|
|
29
28
|
getBestPeriod() {
|
|
30
29
|
if (!this.isBestPeriodExist()) {
|
|
31
30
|
return null;
|
|
32
31
|
}
|
|
33
|
-
// declare best period variable
|
|
34
32
|
let bestPeriod;
|
|
35
33
|
// get list of all logbooks available for best period calculation
|
|
36
34
|
const claimableLogbooks = this.getClaimableLogbooks().toArray();
|
|
@@ -40,12 +38,12 @@ export class VehicleLogbookCollection extends Collection {
|
|
|
40
38
|
break;
|
|
41
39
|
}
|
|
42
40
|
// get date range started from current handling logbook date
|
|
43
|
-
const dateRange =
|
|
41
|
+
const dateRange = claimableLogbooks[i].getPeriod();
|
|
44
42
|
// get all logbooks included in current logbook period
|
|
45
|
-
const logbooksInRange = this.filterByRange('date', dateRange.
|
|
43
|
+
const logbooksInRange = this.filterByRange('date', dateRange.start, dateRange.end);
|
|
46
44
|
const currentPeriod = plainToClass(LogbookPeriod, {
|
|
47
|
-
from: dateRange.
|
|
48
|
-
to: dateRange.
|
|
45
|
+
from: dateRange.start,
|
|
46
|
+
to: dateRange.end,
|
|
49
47
|
kilometers: logbooksInRange.getClaimableLogbooks().kilometers,
|
|
50
48
|
workUsage: logbooksInRange.getWorkUsage(),
|
|
51
49
|
logbooks: logbooksInRange
|
|
@@ -79,28 +77,15 @@ export class VehicleLogbookCollection extends Collection {
|
|
|
79
77
|
const workKilometers = this.getClaimableLogbooks().kilometers;
|
|
80
78
|
return Math.round(workKilometers / this.kilometers * 100);
|
|
81
79
|
}
|
|
82
|
-
/**
|
|
83
|
-
* Get LOGBOOK_PERIOD_DURATION date range from passed start date
|
|
84
|
-
* @TODO Vik: Best period: move this and related logic to backend
|
|
85
|
-
*/
|
|
86
|
-
getPeriodRange(from) {
|
|
87
|
-
// set end date as VehicleLogbook.periodDuration after start date
|
|
88
|
-
let to = new Date(from.getTime() + VehicleLogbook.periodDuration);
|
|
89
|
-
const financialYear = new FinancialYear();
|
|
90
|
-
// set as period last VehicleLogbook.periodDuration of current year if period end date after end of current year
|
|
91
|
-
if (to > financialYear.endDate) {
|
|
92
|
-
to = financialYear.endDate;
|
|
93
|
-
from = new Date(to.getTime() - VehicleLogbook.periodDuration);
|
|
94
|
-
}
|
|
95
|
-
return { from, to };
|
|
96
|
-
}
|
|
97
80
|
/**
|
|
98
81
|
* Get list of logbooks related to passed vehicle claim
|
|
99
82
|
*/
|
|
100
|
-
getByVehicleClaim(
|
|
101
|
-
return
|
|
102
|
-
|
|
103
|
-
|
|
83
|
+
getByVehicleClaim(vehicleClaim) {
|
|
84
|
+
return vehicleClaim.isSoleTank()
|
|
85
|
+
// sole tank may have multiple vehicle claims, so we need to filter by business.id
|
|
86
|
+
? this.filterBy('business.id', vehicleClaim.business.id)
|
|
87
|
+
// work tank may have only one vehicle claim, so we need to filter by tank type
|
|
88
|
+
: this.filterBy('tankType', TankTypeEnum.WORK);
|
|
104
89
|
}
|
|
105
90
|
}
|
|
106
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"vehicle-logbook.collection.js","sourceRoot":"","sources":["../../../../../../projects/tt-core/src/lib/collections/vehicle/vehicle-logbook.collection.ts"],"names":[],"mappings":"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","sourcesContent":["import { FinancialYear } from '../../models/financial-year/financial-year';\nimport { plainToClass } from 'class-transformer';\nimport { Collection } from '../collection';\nimport { LogbookPeriod, VehicleClaim, VehicleLogbook } from '../../models';\nimport { TankTypeEnum } from '../../db/Enums/tank-type.enum';\n\nexport class VehicleLogbookCollection extends Collection<VehicleLogbook> {\n  /**\n   * Best period may be calculated only when user has logbooks minimum for {@link VehicleLogbook.periodDuration}\n   * @TODO Vik: Best period: move this and related logic to backend\n   */\n  isBestPeriodExist(): boolean {\n    if (this.items.length < 2) {\n      return false;\n    }\n\n    return VehicleLogbook.periodDuration < (this.last.date.getTime() - this.first.date.getTime());\n  }\n\n  /**\n   * Get collection of non-personal logbooks (work-related, sole-related).\n   * @TODO Vik: Best period: move this and related logic to backend\n   */\n  getClaimableLogbooks(): this {\n    return this.filterBy('isPersonal', false);\n  }\n\n  /**\n   * Logbook Period is the best when it has the biggest work usage percent\n   * Best period duration is defined as {@link VehicleLogbook.periodDuration} by the ATO\n   * @TODO Vik: Best period: move this and related logic to backend\n   */\n  getBestPeriod(): LogbookPeriod {\n    if (!this.isBestPeriodExist()) {\n      return null;\n    }\n\n    // declare best period variable\n    let bestPeriod: LogbookPeriod;\n\n    // get list of all logbooks available for best period calculation\n    const claimableLogbooks: VehicleLogbook[] = this.getClaimableLogbooks().toArray();\n\n    for (let i = 0; i < claimableLogbooks.length; i ++) {\n      // no sense to check next logbooks because we already get the end of the year\n      if (bestPeriod && bestPeriod.isEndOfYear()) {\n        break;\n      }\n\n      // get date range started from current handling logbook date\n      const dateRange: {from: Date, to: Date} = this.getPeriodRange(claimableLogbooks[i].date);\n\n      // get all logbooks included in current logbook period\n      const logbooksInRange: VehicleLogbookCollection = this.filterByRange('date', dateRange.from, dateRange.to);\n\n      const currentPeriod: LogbookPeriod = plainToClass(LogbookPeriod, {\n        from: dateRange.from,\n        to: dateRange.to,\n        kilometers: logbooksInRange.getClaimableLogbooks().kilometers,\n        workUsage: logbooksInRange.getWorkUsage(),\n        logbooks: logbooksInRange\n      });\n\n      // compare with previous best period and overwrite if needs\n      if (!bestPeriod || currentPeriod.workUsage > bestPeriod.workUsage) {\n        bestPeriod = currentPeriod;\n      } else if (currentPeriod.workUsage === bestPeriod.workUsage) {\n        // if work usage is the same then get period with the biggest work usage for work tank\n        const oldWorkUsage: number = bestPeriod.logbooks.filterBy('tankType', TankTypeEnum.WORK).getWorkUsage();\n        const currentWorkUsage: number = currentPeriod.logbooks.filterBy('tankType', TankTypeEnum.WORK).getWorkUsage();\n\n        if (oldWorkUsage < currentWorkUsage) {\n          bestPeriod = currentPeriod;\n        }\n      }\n    }\n\n    return bestPeriod;\n  }\n\n  /**\n   * Calculate total kilometers traveled\n   */\n  get kilometers(): number {\n    return this.sumBy('kilometers');\n  }\n\n  /**\n   * Calculate work usage (percent of business-related kilometers from total kilometers)\n   * @TODO Alex: TT-2089 replace with getter\n   */\n  getWorkUsage(): number {\n    const workKilometers: number = this.getClaimableLogbooks().kilometers;\n\n    return Math.round(workKilometers / this.kilometers * 100);\n  }\n\n  /**\n   * Get LOGBOOK_PERIOD_DURATION date range from passed start date\n   * @TODO Vik: Best period: move this and related logic to backend\n   */\n  private getPeriodRange(from: Date): {from: Date, to: Date} {\n    // set end date as VehicleLogbook.periodDuration after start date\n    let to: Date = new Date(from.getTime() + VehicleLogbook.periodDuration);\n\n    const financialYear = new FinancialYear();\n\n    // set as period last VehicleLogbook.periodDuration of current year if period end date after end of current year\n    if (to > financialYear.endDate) {\n      to = financialYear.endDate;\n      from = new Date(to.getTime() - VehicleLogbook.periodDuration);\n    }\n\n    return {from, to};\n  }\n\n  /**\n   * Get list of logbooks related to passed vehicle claim\n   */\n  getByVehicleClaim(claim: VehicleClaim): this {\n    return claim.isWorkTank()\n      ? this.filterBy('tankType', TankTypeEnum.WORK)\n      : this.filterBy('business.id', claim.business.id);\n  }\n}\n"]}
|
|
91
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"vehicle-logbook.collection.js","sourceRoot":"","sources":["../../../../../../projects/tt-core/src/lib/collections/vehicle/vehicle-logbook.collection.ts"],"names":[],"mappings":"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","sourcesContent":["import { plainToClass } from 'class-transformer';\nimport { Collection } from '../collection';\nimport { LogbookPeriod, VehicleClaim, VehicleLogbook } from '../../models';\nimport { TankTypeEnum } from '../../db/Enums/tank-type.enum';\nimport { DateRange } from 'moment-range';\n\n\nexport class VehicleLogbookCollection extends Collection<VehicleLogbook> {\n  /**\n   * Best period may be calculated only when user has logbooks minimum for VehicleLogbook.bestPeriodWeeks\n   * @TODO Vik: Best period: move this and related logic to backend\n   */\n  isBestPeriodExist(): boolean {\n    if (this.items.length < 2) {\n      return false;\n    }\n\n    return VehicleLogbook.bestPeriodWeeks < (this.last.date.getTime() - this.first.date.getTime());\n  }\n\n  /**\n   * Get collection of non-personal logbooks (work-related, sole-related).\n   * @TODO Vik: Best period: move this and related logic to backend\n   */\n  getClaimableLogbooks(): this {\n    return this.filterBy('isPersonal', false);\n  }\n\n  /**\n   * Get Logbook Period with the biggest work usage percent\n   * Best period duration is defined as VehicleLogbook.bestPeriodWeeks by the ATO\n   * @TODO Vik: Best period: move this and related logic to backend\n   */\n  getBestPeriod(): LogbookPeriod {\n    if (!this.isBestPeriodExist()) {\n      return null;\n    }\n\n    let bestPeriod: LogbookPeriod;\n\n    // get list of all logbooks available for best period calculation\n    const claimableLogbooks: VehicleLogbook[] = this.getClaimableLogbooks().toArray();\n\n    for (let i = 0; i < claimableLogbooks.length; i ++) {\n      // no sense to check next logbooks because we already get the end of the year\n      if (bestPeriod && bestPeriod.isEndOfYear()) {\n        break;\n      }\n\n      // get date range started from current handling logbook date\n      const dateRange: DateRange = claimableLogbooks[i].getPeriod();\n\n      // get all logbooks included in current logbook period\n      const logbooksInRange: VehicleLogbookCollection = this.filterByRange('date', dateRange.start, dateRange.end);\n\n      const currentPeriod: LogbookPeriod = plainToClass(LogbookPeriod, {\n        from: dateRange.start,\n        to: dateRange.end,\n        kilometers: logbooksInRange.getClaimableLogbooks().kilometers,\n        workUsage: logbooksInRange.getWorkUsage(),\n        logbooks: logbooksInRange\n      });\n\n      // compare with previous best period and overwrite if needs\n      if (!bestPeriod || currentPeriod.workUsage > bestPeriod.workUsage) {\n        bestPeriod = currentPeriod;\n      } else if (currentPeriod.workUsage === bestPeriod.workUsage) {\n        // if work usage is the same then get period with the biggest work usage for work tank\n        const oldWorkUsage: number = bestPeriod.logbooks.filterBy('tankType', TankTypeEnum.WORK).getWorkUsage();\n        const currentWorkUsage: number = currentPeriod.logbooks.filterBy('tankType', TankTypeEnum.WORK).getWorkUsage();\n\n        if (oldWorkUsage < currentWorkUsage) {\n          bestPeriod = currentPeriod;\n        }\n      }\n    }\n\n    return bestPeriod;\n  }\n\n  /**\n   * Calculate total kilometers traveled\n   */\n  get kilometers(): number {\n    return this.sumBy('kilometers');\n  }\n\n  /**\n   * Calculate work usage (percent of business-related kilometers from total kilometers)\n   * @TODO Alex: TT-2089 replace with getter\n   */\n  getWorkUsage(): number {\n    const workKilometers: number = this.getClaimableLogbooks().kilometers;\n\n    return Math.round(workKilometers / this.kilometers * 100);\n  }\n\n  /**\n   * Get list of logbooks related to passed vehicle claim\n   */\n  getByVehicleClaim(vehicleClaim: VehicleClaim): this {\n    return vehicleClaim.isSoleTank()\n      // sole tank may have multiple vehicle claims, so we need to filter by business.id\n      ? this.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.filterBy('tankType', TankTypeEnum.WORK);\n  }\n}\n"]}
|
|
@@ -5,5 +5,6 @@ export var DepreciationCalculationEnum;
|
|
|
5
5
|
DepreciationCalculationEnum[DepreciationCalculationEnum["CAPITAL"] = 3] = "CAPITAL";
|
|
6
6
|
DepreciationCalculationEnum[DepreciationCalculationEnum["LVP"] = 4] = "LVP";
|
|
7
7
|
DepreciationCalculationEnum[DepreciationCalculationEnum["AMORTISATION"] = 5] = "AMORTISATION";
|
|
8
|
+
DepreciationCalculationEnum[DepreciationCalculationEnum["SBP"] = 6] = "SBP";
|
|
8
9
|
})(DepreciationCalculationEnum || (DepreciationCalculationEnum = {}));
|
|
9
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVwcmVjaWF0aW9uLWNhbGN1bGF0aW9uLmVudW0uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90dC1jb3JlL3NyYy9saWIvZGIvRW51bXMvZGVwcmVjaWF0aW9uLWNhbGN1bGF0aW9uLmVudW0udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFOLElBQVksMkJBT1g7QUFQRCxXQUFZLDJCQUEyQjtJQUN0Qyx5RkFBYyxDQUFBO0lBQ2QsMkZBQWUsQ0FBQTtJQUNmLG1GQUFXLENBQUE7SUFDWCwyRUFBTyxDQUFBO0lBQ1AsNkZBQWdCLENBQUE7SUFDZiwyRUFBTyxDQUFBO0FBQ1QsQ0FBQyxFQVBXLDJCQUEyQixLQUEzQiwyQkFBMkIsUUFPdEMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZW51bSBEZXByZWNpYXRpb25DYWxjdWxhdGlvbkVudW0ge1xuXHRQUklNRV9DT1NUID0gMSxcblx0RElNSU5JU0hJTkcgPSAyLFxuXHRDQVBJVEFMID0gMyxcblx0TFZQID0gNCxcblx0QU1PUlRJU0FUSU9OID0gNSxcbiAgU0JQID0gNlxufVxuIl19
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export var SoleDepreciationMethodEnum;
|
|
2
|
+
(function (SoleDepreciationMethodEnum) {
|
|
3
|
+
SoleDepreciationMethodEnum[SoleDepreciationMethodEnum["SBP"] = 1] = "SBP";
|
|
4
|
+
SoleDepreciationMethodEnum[SoleDepreciationMethodEnum["DEPRECIATION"] = 2] = "DEPRECIATION";
|
|
5
|
+
})(SoleDepreciationMethodEnum || (SoleDepreciationMethodEnum = {}));
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic29sZS1kZXByZWNpYXRpb24tbWV0aG9kLmVudW0uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90dC1jb3JlL3NyYy9saWIvZGIvRW51bXMvc29sZS1kZXByZWNpYXRpb24tbWV0aG9kLmVudW0udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFOLElBQVksMEJBR1g7QUFIRCxXQUFZLDBCQUEwQjtJQUNwQyx5RUFBTyxDQUFBO0lBQ1AsMkZBQWdCLENBQUE7QUFDbEIsQ0FBQyxFQUhXLDBCQUEwQixLQUExQiwwQkFBMEIsUUFHckMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZW51bSBTb2xlRGVwcmVjaWF0aW9uTWV0aG9kRW51bSB7XG4gIFNCUCA9IDEsXG4gIERFUFJFQ0lBVElPTiA9IDIsXG59XG4iXX0=
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { AbstractModel } from '../abstract-model';
|
|
2
|
+
export class SoleBusinessActivity extends AbstractModel {
|
|
3
|
+
}
|
|
4
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic29sZS1idXNpbmVzcy1hY3Rpdml0eS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3R0LWNvcmUvc3JjL2xpYi9kYi9Nb2RlbHMvc29sZS9zb2xlLWJ1c2luZXNzLWFjdGl2aXR5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUVsRCxNQUFNLE9BQU8sb0JBQXFCLFNBQVEsYUFBYTtDQUl0RCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFic3RyYWN0TW9kZWwgfSBmcm9tICcuLi9hYnN0cmFjdC1tb2RlbCc7XG5cbmV4cG9ydCBjbGFzcyBTb2xlQnVzaW5lc3NBY3Rpdml0eSBleHRlbmRzIEFic3RyYWN0TW9kZWwge1xuXHRuYW1lPzogc3RyaW5nO1xuXHRjb2RlPzogbnVtYmVyO1xuXHRpZD86IG51bWJlcjtcbn1cbiJdfQ==
|
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
import { AbstractModel } from '../abstract-model';
|
|
2
2
|
export class SoleBusiness extends AbstractModel {
|
|
3
3
|
}
|
|
4
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
4
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic29sZS1idXNpbmVzcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3R0LWNvcmUvc3JjL2xpYi9kYi9Nb2RlbHMvc29sZS9zb2xlLWJ1c2luZXNzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVFBLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUlsRCxNQUFNLE9BQU8sWUFBYSxTQUFRLGFBQWE7Q0FpQjlDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVXNlciB9IGZyb20gJy4uL3VzZXIvdXNlcic7XG5pbXBvcnQgeyBTb2xlQnVzaW5lc3NBbGxvY2F0aW9uIH0gZnJvbSAnLi9zb2xlLWJ1c2luZXNzLWFsbG9jYXRpb24nO1xuaW1wb3J0IHsgU29sZUJ1c2luZXNzTG9zcyB9IGZyb20gJy4vc29sZS1idXNpbmVzcy1sb3NzJztcbmltcG9ydCB7IFNvbGVJbnZvaWNlIH0gZnJvbSAnLi9zb2xlLWludm9pY2UnO1xuaW1wb3J0IHsgU29sZUludm9pY2VUZW1wbGF0ZSB9IGZyb20gJy4vc29sZS1pbnZvaWNlLXRlbXBsYXRlJztcbmltcG9ydCB7IFZlaGljbGVDbGFpbSB9IGZyb20gJy4uL3ZlaGljbGUvdmVoaWNsZS1jbGFpbSc7XG5pbXBvcnQgeyBUcmFuc2FjdGlvbiB9IGZyb20gJy4uL3RyYW5zYWN0aW9uL3RyYW5zYWN0aW9uJztcbmltcG9ydCB7IERlcHJlY2lhdGlvbiB9IGZyb20gJy4uL2RlcHJlY2lhdGlvbi9kZXByZWNpYXRpb24nO1xuaW1wb3J0IHsgQWJzdHJhY3RNb2RlbCB9IGZyb20gJy4uL2Fic3RyYWN0LW1vZGVsJztcbmltcG9ydCB7IFZlaGljbGVMb2dib29rIH0gZnJvbSAnLi4vdmVoaWNsZS92ZWhpY2xlLWxvZ2Jvb2snO1xuaW1wb3J0IHsgU29sZUJ1c2luZXNzQWN0aXZpdHkgfSBmcm9tICcuL3NvbGUtYnVzaW5lc3MtYWN0aXZpdHknO1xuXG5leHBvcnQgY2xhc3MgU29sZUJ1c2luZXNzIGV4dGVuZHMgQWJzdHJhY3RNb2RlbCB7XG4gIG5hbWU/OiBzdHJpbmc7XG4gIGRlc2NyaXB0aW9uPzogc3RyaW5nO1xuICB3ZWJzaXRlPzogc3RyaW5nO1xuICBsb2dvPzogc3RyaW5nO1xuICBpZD86IG51bWJlcjtcbiAgZGVsZXRlZEF0PzogRGF0ZTtcbiAgdXNlcj86IFVzZXI7XG4gIGFjdGl2aXR5PzogU29sZUJ1c2luZXNzQWN0aXZpdHk7XG4gIGFsbG9jYXRpb25zPzogU29sZUJ1c2luZXNzQWxsb2NhdGlvbltdO1xuICBsb3NzZXM/OiBTb2xlQnVzaW5lc3NMb3NzW107XG4gIGludm9pY2VzPzogU29sZUludm9pY2VbXTtcbiAgaW52b2ljZVRlbXBsYXRlcz86IFNvbGVJbnZvaWNlVGVtcGxhdGVbXTtcbiAgdmVoaWNsZUNsYWltcz86IFZlaGljbGVDbGFpbVtdO1xuICB2ZWhpY2xlTG9nYm9va3M/OiBWZWhpY2xlTG9nYm9va1tdO1xuICB0cmFuc2FjdGlvbnM/OiBUcmFuc2FjdGlvbltdO1xuICBkZXByZWNpYXRpb25zPzogRGVwcmVjaWF0aW9uW107XG59XG4iXX0=
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { AbstractModel } from '../abstract-model';
|
|
2
|
+
export class SoleDepreciationMethod extends AbstractModel {
|
|
3
|
+
}
|
|
4
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic29sZS1kZXByZWNpYXRpb24tbWV0aG9kLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdHQtY29yZS9zcmMvbGliL2RiL01vZGVscy9zb2xlL3NvbGUtZGVwcmVjaWF0aW9uLW1ldGhvZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFFbEQsTUFBTSxPQUFPLHNCQUF1QixTQUFRLGFBQWE7Q0FNeEQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBVc2VyIH0gZnJvbSAnLi4vdXNlci91c2VyJztcbmltcG9ydCB7IFNvbGVEZXByZWNpYXRpb25NZXRob2RFbnVtIH0gZnJvbSAnLi4vLi4vRW51bXMvc29sZS1kZXByZWNpYXRpb24tbWV0aG9kLmVudW0nO1xuaW1wb3J0IHsgQWJzdHJhY3RNb2RlbCB9IGZyb20gJy4uL2Fic3RyYWN0LW1vZGVsJztcblxuZXhwb3J0IGNsYXNzIFNvbGVEZXByZWNpYXRpb25NZXRob2QgZXh0ZW5kcyBBYnN0cmFjdE1vZGVsIHtcbiAgbWV0aG9kPzogU29sZURlcHJlY2lhdGlvbk1ldGhvZEVudW07XG4gIGNsb3NlQmFsYW5jZT86IG51bWJlcjtcbiAgaWQ/OiBudW1iZXI7XG4gIGZpbmFuY2lhbFllYXI/OiBudW1iZXI7XG4gIHVzZXI/OiBVc2VyO1xufVxuIl19
|
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
import { AbstractModel } from '../abstract-model';
|
|
2
2
|
export class SoleDetails extends AbstractModel {
|
|
3
3
|
}
|
|
4
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
4
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic29sZS1kZXRhaWxzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdHQtY29yZS9zcmMvbGliL2RiL01vZGVscy9zb2xlL3NvbGUtZGV0YWlscy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUMsYUFBYSxFQUFDLE1BQU0sbUJBQW1CLENBQUM7QUFFaEQsTUFBTSxPQUFPLFdBQVksU0FBUSxhQUFhO0NBUTdDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtVc2VyfSBmcm9tICcuLi91c2VyL3VzZXInO1xuaW1wb3J0IHtBYnN0cmFjdE1vZGVsfSBmcm9tICcuLi9hYnN0cmFjdC1tb2RlbCc7XG5cbmV4cG9ydCBjbGFzcyBTb2xlRGV0YWlscyBleHRlbmRzIEFic3RyYWN0TW9kZWwge1xuICBhYm4/OiBzdHJpbmc7XG4gIGlkPzogbnVtYmVyO1xuICBpc0dTVD86IGJvb2xlYW47XG4gIGNyZWF0ZWRBdD86IERhdGU7XG4gIHVwZGF0ZWRBdD86IERhdGU7XG4gIGRlbGV0ZWRBdD86IERhdGU7XG4gIHVzZXI/OiBVc2VyO1xufVxuIl19
|
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
import { AbstractModel } from '../abstract-model';
|
|
2
2
|
export class User extends AbstractModel {
|
|
3
3
|
}
|
|
4
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
4
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXNlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3R0LWNvcmUvc3JjL2xpYi9kYi9Nb2RlbHMvdXNlci91c2VyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWVBLE9BQU8sRUFBQyxhQUFhLEVBQUMsTUFBTSxtQkFBbUIsQ0FBQztBQUdoRCxNQUFNLE9BQU8sSUFBSyxTQUFRLGFBQWE7Q0FxQ3RDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVXNlclRpdGxlRW51bSB9IGZyb20gJy4uLy4uL0VudW1zL3VzZXItdGl0bGUuZW51bSc7XG5pbXBvcnQgeyBVc2VyU3RhdHVzRW51bSB9IGZyb20gJy4uLy4uL0VudW1zL3VzZXItc3RhdHVzLmVudW0nO1xuaW1wb3J0IHsgVXNlclJvbGVzRW51bSB9IGZyb20gJy4uLy4uL0VudW1zL3VzZXItcm9sZXMuZW51bSc7XG5pbXBvcnQgeyBQcm9wZXJ0eSB9IGZyb20gJy4uL3Byb3BlcnR5L3Byb3BlcnR5JztcbmltcG9ydCB7IFByb3BlcnR5U3Vic2NyaXB0aW9uIH0gZnJvbSAnLi4vcHJvcGVydHkvcHJvcGVydHktc3Vic2NyaXB0aW9uJztcbmltcG9ydCB7IFNlcnZpY2VTdWJzY3JpcHRpb24gfSBmcm9tICcuLi9zdWJzY3JpcHRpb24vc2VydmljZS1zdWJzY3JpcHRpb24nO1xuaW1wb3J0IHsgVXNlckV2ZW50U2V0dGluZyB9IGZyb20gJy4vdXNlci1ldmVudC1zZXR0aW5nJztcbmltcG9ydCB7IEJhbmtDb25uZWN0aW9uIH0gZnJvbSAnLi4vYmFuay9iYW5rLWNvbm5lY3Rpb24nO1xuaW1wb3J0IHsgVGF4UmV2aWV3IH0gZnJvbSAnLi4vZmlybS9hY2NvdW50YW50L3RheC1yZXZpZXcnO1xuaW1wb3J0IHsgUHJvcGVydHlTaGFyZSB9IGZyb20gJy4uL3Byb3BlcnR5L3Byb3BlcnR5LXNoYXJlJztcbmltcG9ydCB7IEFkZHJlc3MgfSBmcm9tICcuLi9hZGRyZXNzJztcbmltcG9ydCB7IFBob25lIH0gZnJvbSAnLi4vcGhvbmUnO1xuaW1wb3J0IHsgQ2xpZW50TW92ZW1lbnQgfSBmcm9tICcuLi9maXJtL2NsaWVudC1tb3ZlbWVudCc7XG5pbXBvcnQgeyBDbGllbnREZXRhaWxzIH0gZnJvbSAnLi9jbGllbnQtZGV0YWlscyc7XG5pbXBvcnQgeyBFbXBsb3llZURldGFpbHMgfSBmcm9tICcuL2VtcGxveWVlLWRldGFpbHMnO1xuaW1wb3J0IHtBYnN0cmFjdE1vZGVsfSBmcm9tICcuLi9hYnN0cmFjdC1tb2RlbCc7XG5pbXBvcnQgeyBTb2xlRGV0YWlscyB9IGZyb20gJy4uL3NvbGUvc29sZS1kZXRhaWxzJztcblxuZXhwb3J0IGNsYXNzIFVzZXIgZXh0ZW5kcyBBYnN0cmFjdE1vZGVsIHtcbiAgaWQ/OiBudW1iZXI7XG4gIGludGVyY29tSWQ/OiBudW1iZXI7XG4gIGNyZWF0ZWRBdD86IERhdGU7XG4gIHVwZGF0ZWRBdD86IERhdGU7XG4gIGVtYWlsPzogc3RyaW5nO1xuICBoYXNoZWRFbWFpbD86IHN0cmluZztcbiAgcGFzc3dvcmQ/OiBzdHJpbmc7XG4gIGZpcnN0TmFtZT86IHN0cmluZztcbiAgbGFzdE5hbWU/OiBzdHJpbmc7XG4gIHRpdGxlPzogVXNlclRpdGxlRW51bTtcbiAgcGhvdG8/OiBzdHJpbmc7XG4gIHN0YXR1cz86IFVzZXJTdGF0dXNFbnVtO1xuICBpc0NvbmZpcm1lZD86IGJvb2xlYW47XG4gIHZlcmlmaWNhdGlvbkNvZGU/OiBzdHJpbmc7XG4gIHJlZmVyZXI/OiBVc2VyO1xuICByZWZlcmVuY2VDb2RlPzogc3RyaW5nO1xuICByZXdhcmRmdWxSZWZlcnJhbEtleT86IHN0cmluZztcbiAgc3RyaXBlSWQ/OiBzdHJpbmc7XG4gIGJhc2lxSWQ/OiBzdHJpbmc7XG4gIHJvbGVzPzogVXNlclJvbGVzRW51bTtcbiAgZmluYW5jaWFsWWVhcj86IG51bWJlcjtcbiAgZGF0ZU9mQmlydGg/OiBEYXRlO1xuICBkZWxldGVkQXQ/OiBEYXRlO1xuICBwcm9wZXJ0aWVzPzogUHJvcGVydHlbXTtcbiAgcHJvcGVydHlTdWJzY3JpcHRpb25zPzogUHJvcGVydHlTdWJzY3JpcHRpb25bXTtcbiAgc3Vic2NyaXB0aW9ucz86IFNlcnZpY2VTdWJzY3JpcHRpb25bXTtcbiAgZXZlbnRTZXR0aW5ncz86IFVzZXJFdmVudFNldHRpbmdbXTtcbiAgYmFua0Nvbm5lY3Rpb25zPzogQmFua0Nvbm5lY3Rpb25bXTtcbiAgdGF4UmV2aWV3cz86IFRheFJldmlld1tdO1xuICBwcm9wZXJ0eVNoYXJlcz86IFByb3BlcnR5U2hhcmVbXTtcbiAgYWRkcmVzcz86IEFkZHJlc3M7XG4gIHBob25lPzogUGhvbmU7XG4gIGNsaWVudE1vdmVtZW50cz86IENsaWVudE1vdmVtZW50W107XG4gIGNsaWVudERldGFpbHM/OiBDbGllbnREZXRhaWxzO1xuICBlbXBsb3llZURldGFpbHM/OiBFbXBsb3llZURldGFpbHM7XG4gIHNvbGVEZXRhaWxzPzogU29sZURldGFpbHM7XG59XG4iXX0=
|
|
@@ -5,7 +5,7 @@ import isEqual from 'lodash/isEqual';
|
|
|
5
5
|
/**
|
|
6
6
|
* Abstract form class
|
|
7
7
|
* @TODO rename to AbstractFormGroup
|
|
8
|
-
* @TODO Alex: refactor: check and improve logic
|
|
8
|
+
* @TODO Alex TT-2190: refactor: check and improve logic
|
|
9
9
|
*/
|
|
10
10
|
export class AbstractForm extends FormGroup {
|
|
11
11
|
constructor(controls, model, validatorOrOpts, asyncValidator) {
|
|
@@ -21,13 +21,14 @@ export class AbstractForm extends FormGroup {
|
|
|
21
21
|
if (model && !model['id']) {
|
|
22
22
|
this.markAsUnsaved();
|
|
23
23
|
}
|
|
24
|
-
this.
|
|
25
|
-
!!model && !!model['id'] && isEqual(this.value, this.initialValue) ? this.markAsSaved() : this.markAsUnsaved();
|
|
26
|
-
});
|
|
24
|
+
this.listenValueChanges();
|
|
27
25
|
}
|
|
28
26
|
get saved() {
|
|
29
27
|
return !this.unsaved;
|
|
30
28
|
}
|
|
29
|
+
get currentValue() {
|
|
30
|
+
return this.createModelInstance(Object.assign({}, this.model, this.getRawValue()));
|
|
31
|
+
}
|
|
31
32
|
/**
|
|
32
33
|
* Check validation and return a new instance of generic model.
|
|
33
34
|
* Merge form value to initial object
|
|
@@ -56,5 +57,10 @@ export class AbstractForm extends FormGroup {
|
|
|
56
57
|
createModelInstance(data = {}) {
|
|
57
58
|
return plainToClass(this.modelClass, data);
|
|
58
59
|
}
|
|
60
|
+
listenValueChanges() {
|
|
61
|
+
this.valueChanges.subscribe(() => {
|
|
62
|
+
!!this.model && !!this.model['id'] && isEqual(this.value, this.initialValue) ? this.markAsSaved() : this.markAsUnsaved();
|
|
63
|
+
});
|
|
64
|
+
}
|
|
59
65
|
}
|
|
60
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
66
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWJzdHJhY3QuZm9ybS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3R0LWNvcmUvc3JjL2xpYi9mb3Jtcy9hYnN0cmFjdC5mb3JtLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBNkQsU0FBUyxFQUFlLE1BQU0sZ0JBQWdCLENBQUM7QUFDbkgsT0FBTyxFQUFFLFlBQVksRUFBUSxNQUFNLGVBQWUsQ0FBQztBQUNuRCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDakQsT0FBTyxPQUFPLE1BQU0sZ0JBQWdCLENBQUM7QUFFckM7Ozs7R0FJRztBQUNILE1BQU0sT0FBZ0IsWUFBb0IsU0FBUSxTQUFTO0lBaUJ6RCxZQUNFLFFBQTBDLEVBQzFDLEtBQWEsRUFDYixlQUE2RSxFQUM3RSxjQUE2RDtRQUU3RCxLQUFLLENBQUMsUUFBUSxFQUFFLGVBQWUsRUFBRSxjQUFjLENBQUMsQ0FBQztRQWJuRDs7V0FFRztRQUNILFlBQU8sR0FBWSxLQUFLLENBQUM7UUFFekIsYUFBUSxHQUF3QixJQUFJLFlBQVksRUFBRSxDQUFDO1FBU2pELElBQUksQ0FBQyxLQUFLLEdBQUcsS0FBSyxJQUFJLElBQUksQ0FBQyxtQkFBbUIsRUFBRSxDQUFDO1FBQ2pELElBQUksQ0FBQyxVQUFVLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxXQUE4QixDQUFDO1FBQzVELElBQUksQ0FBQyxZQUFZLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQztRQUUvQixJQUFJLEtBQUssSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsRUFBRTtZQUN6QixJQUFJLENBQUMsYUFBYSxFQUFFLENBQUM7U0FDdEI7UUFFRCxJQUFJLENBQUMsa0JBQWtCLEVBQUUsQ0FBQztJQUM1QixDQUFDO0lBRUQsSUFBSSxLQUFLO1FBQ1AsT0FBTyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUM7SUFDdkIsQ0FBQztJQUVELElBQUksWUFBWTtRQUNkLE9BQU8sSUFBSSxDQUFDLG1CQUFtQixDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsRUFBRSxFQUFFLElBQUksQ0FBQyxLQUFLLEVBQUUsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDLENBQUMsQ0FBQztJQUNyRixDQUFDO0lBRUQ7Ozs7T0FJRztJQUNILE1BQU0sQ0FBQyxPQUFlLEVBQUU7UUFDdEIsSUFBSSxDQUFDLFNBQVMsR0FBRyxJQUFJLENBQUM7UUFDdEIsSUFBSSxDQUFDLGdCQUFnQixFQUFFLENBQUM7UUFFeEIsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFO1lBQ2pDLE9BQU8sSUFBSSxDQUFDO1NBQ2I7UUFFRCxNQUFNLEtBQUssR0FBVSxJQUFJLENBQUMsbUJBQW1CLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxFQUFFLEVBQUUsSUFBSSxDQUFDLEtBQUssRUFBRSxJQUFJLENBQUMsS0FBSyxFQUFFLElBQUksQ0FBQyxDQUFDLENBQUM7UUFFL0YsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDMUIsT0FBTyxLQUFLLENBQUM7SUFDZixDQUFDO0lBRUQsVUFBVSxDQUFDLElBQVksRUFBRSxPQUF3QixFQUFFLE9BQWlDO1FBQ2xGLEtBQUssQ0FBQyxVQUFVLENBQUMsSUFBSSxFQUFFLE9BQU8sRUFBRSxPQUFPLENBQUMsQ0FBQztRQUV6QyxPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7SUFFRCxhQUFhO1FBQ1gsSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUM7SUFDdEIsQ0FBQztJQUVELFdBQVc7UUFDVCxJQUFJLENBQUMsT0FBTyxHQUFHLEtBQUssQ0FBQztJQUN2QixDQUFDO0lBRU8sbUJBQW1CLENBQUMsT0FBZSxFQUFFO1FBQzNDLE9BQU8sWUFBWSxDQUFDLElBQUksQ0FBQyxVQUFVLEVBQUUsSUFBSSxDQUFDLENBQUM7SUFDN0MsQ0FBQztJQUVPLGtCQUFrQjtRQUN4QixJQUFJLENBQUMsWUFBWSxDQUFDLFNBQVMsQ0FBQyxHQUFHLEVBQUU7WUFDL0IsQ0FBQyxDQUFDLElBQUksQ0FBQyxLQUFLLElBQUksQ0FBQyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLElBQUksT0FBTyxDQUFDLElBQUksQ0FBQyxLQUFLLEVBQUUsSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxhQUFhLEVBQUUsQ0FBQztRQUMzSCxDQUFDLENBQUMsQ0FBQTtJQUNKLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFic3RyYWN0Q29udHJvbCwgQWJzdHJhY3RDb250cm9sT3B0aW9ucywgQXN5bmNWYWxpZGF0b3JGbiwgRm9ybUdyb3VwLCBWYWxpZGF0b3JGbiB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IEV2ZW50RW1pdHRlciwgVHlwZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgcGxhaW5Ub0NsYXNzIH0gZnJvbSAnY2xhc3MtdHJhbnNmb3JtZXInO1xuaW1wb3J0IGlzRXF1YWwgZnJvbSAnbG9kYXNoL2lzRXF1YWwnO1xuXG4vKipcbiAqIEFic3RyYWN0IGZvcm0gY2xhc3NcbiAqIEBUT0RPIHJlbmFtZSB0byBBYnN0cmFjdEZvcm1Hcm91cFxuICogQFRPRE8gQWxleCBUVC0yMTkwOiByZWZhY3RvcjogY2hlY2sgYW5kIGltcHJvdmUgbG9naWNcbiAqL1xuZXhwb3J0IGFic3RyYWN0IGNsYXNzIEFic3RyYWN0Rm9ybTxNb2RlbD4gZXh0ZW5kcyBGb3JtR3JvdXAge1xuICAvKipcbiAgICogSW5pdGlhbCBmb3JtIHZhbHVlIGZvciBjb21wYXJpc29uIHdpdGggY2hhbmdlcyB0byBjaGVjayBzYXZlZC91bnNhdmVkIHN0YXRlXG4gICAqL1xuICBwcml2YXRlIGluaXRpYWxWYWx1ZTogb2JqZWN0O1xuXG4gIHByb3RlY3RlZCBtb2RlbENsYXNzOiBUeXBlPE1vZGVsPjtcbiAgbW9kZWw6IE1vZGVsO1xuICBzdWJtaXR0ZWQ6IGJvb2xlYW47XG5cbiAgLyoqXG4gICAqIEZsYWcgZGlzcGxheSBpZiBzb21lIGZvcm0gdmFsdWVzIGNoYW5nZWRcbiAgICovXG4gIHVuc2F2ZWQ6IGJvb2xlYW4gPSBmYWxzZTtcblxuICBvblN1Ym1pdDogRXZlbnRFbWl0dGVyPE1vZGVsPiA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcblxuICBwcm90ZWN0ZWQgY29uc3RydWN0b3IoXG4gICAgY29udHJvbHM6IHtba2V5OiBzdHJpbmddOiBBYnN0cmFjdENvbnRyb2x9LFxuICAgIG1vZGVsPzogTW9kZWwsXG4gICAgdmFsaWRhdG9yT3JPcHRzPzogVmFsaWRhdG9yRm4gfCBWYWxpZGF0b3JGbltdIHwgQWJzdHJhY3RDb250cm9sT3B0aW9ucyB8IG51bGwsXG4gICAgYXN5bmNWYWxpZGF0b3I/OiBBc3luY1ZhbGlkYXRvckZuIHwgQXN5bmNWYWxpZGF0b3JGbltdIHwgbnVsbFxuICApIHtcbiAgICBzdXBlcihjb250cm9scywgdmFsaWRhdG9yT3JPcHRzLCBhc3luY1ZhbGlkYXRvcik7XG4gICAgdGhpcy5tb2RlbCA9IG1vZGVsIHx8IHRoaXMuY3JlYXRlTW9kZWxJbnN0YW5jZSgpO1xuICAgIHRoaXMubW9kZWxDbGFzcyA9IHRoaXMubW9kZWwuY29uc3RydWN0b3IgYXMgbmV3ICgpID0+IE1vZGVsO1xuICAgIHRoaXMuaW5pdGlhbFZhbHVlID0gdGhpcy52YWx1ZTtcblxuICAgIGlmIChtb2RlbCAmJiAhbW9kZWxbJ2lkJ10pIHtcbiAgICAgIHRoaXMubWFya0FzVW5zYXZlZCgpO1xuICAgIH1cblxuICAgIHRoaXMubGlzdGVuVmFsdWVDaGFuZ2VzKCk7XG4gIH1cblxuICBnZXQgc2F2ZWQoKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuICF0aGlzLnVuc2F2ZWQ7XG4gIH1cblxuICBnZXQgY3VycmVudFZhbHVlKCk6IE1vZGVsIHtcbiAgICByZXR1cm4gdGhpcy5jcmVhdGVNb2RlbEluc3RhbmNlKE9iamVjdC5hc3NpZ24oe30sIHRoaXMubW9kZWwsIHRoaXMuZ2V0UmF3VmFsdWUoKSkpO1xuICB9XG5cbiAgLyoqXG4gICAqIENoZWNrIHZhbGlkYXRpb24gYW5kIHJldHVybiBhIG5ldyBpbnN0YW5jZSBvZiBnZW5lcmljIG1vZGVsLlxuICAgKiBNZXJnZSBmb3JtIHZhbHVlIHRvIGluaXRpYWwgb2JqZWN0XG4gICAqIEBwYXJhbSBkYXRhIEFkZGl0aW9uYWwgZGF0YSBvYmplY3Qgd2hpY2ggYmUgbWVyZ2VkIHRvIGZvcm0gdmFsdWVcbiAgICovXG4gIHN1Ym1pdChkYXRhOiBvYmplY3QgPSB7fSk6IE1vZGVsIHtcbiAgICB0aGlzLnN1Ym1pdHRlZCA9IHRydWU7XG4gICAgdGhpcy5tYXJrQWxsQXNUb3VjaGVkKCk7XG5cbiAgICBpZiAoIXRoaXMuZGlzYWJsZWQgJiYgIXRoaXMudmFsaWQpIHtcbiAgICAgIHJldHVybiBudWxsO1xuICAgIH1cblxuICAgIGNvbnN0IG1vZGVsOiBNb2RlbCA9IHRoaXMuY3JlYXRlTW9kZWxJbnN0YW5jZShPYmplY3QuYXNzaWduKHt9LCB0aGlzLm1vZGVsLCB0aGlzLnZhbHVlLCBkYXRhKSk7XG5cbiAgICB0aGlzLm9uU3VibWl0LmVtaXQobW9kZWwpO1xuICAgIHJldHVybiBtb2RlbDtcbiAgfVxuXG4gIGFkZENvbnRyb2wobmFtZTogc3RyaW5nLCBjb250cm9sOiBBYnN0cmFjdENvbnRyb2wsIG9wdGlvbnM/OiB7IGVtaXRFdmVudD86IGJvb2xlYW4gfSk6IHRoaXMge1xuICAgIHN1cGVyLmFkZENvbnRyb2wobmFtZSwgY29udHJvbCwgb3B0aW9ucyk7XG5cbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIG1hcmtBc1Vuc2F2ZWQoKTogdm9pZCB7XG4gICAgdGhpcy51bnNhdmVkID0gdHJ1ZTtcbiAgfVxuXG4gIG1hcmtBc1NhdmVkKCk6IHZvaWQge1xuICAgIHRoaXMudW5zYXZlZCA9IGZhbHNlO1xuICB9XG5cbiAgcHJpdmF0ZSBjcmVhdGVNb2RlbEluc3RhbmNlKGRhdGE6IG9iamVjdCA9IHt9KTogTW9kZWwge1xuICAgIHJldHVybiBwbGFpblRvQ2xhc3ModGhpcy5tb2RlbENsYXNzLCBkYXRhKTtcbiAgfVxuXG4gIHByaXZhdGUgbGlzdGVuVmFsdWVDaGFuZ2VzKCk6IHZvaWQge1xuICAgIHRoaXMudmFsdWVDaGFuZ2VzLnN1YnNjcmliZSgoKSA9PiB7XG4gICAgICAhIXRoaXMubW9kZWwgJiYgISF0aGlzLm1vZGVsWydpZCddICYmIGlzRXF1YWwodGhpcy52YWx1ZSwgdGhpcy5pbml0aWFsVmFsdWUpID8gdGhpcy5tYXJrQXNTYXZlZCgpIDogdGhpcy5tYXJrQXNVbnNhdmVkKCk7XG4gICAgfSlcbiAgfVxufVxuIl19
|
|
@@ -17,9 +17,12 @@ export class BankAccountAllocationForm extends AbstractForm {
|
|
|
17
17
|
if (bankAccount === null || bankAccount === void 0 ? void 0 : bankAccount.isSoleTank()) {
|
|
18
18
|
this.addControl('businessAllocations', new SoleBusinessAllocationsForm(bankAccount.businessAllocations));
|
|
19
19
|
}
|
|
20
|
-
this.
|
|
20
|
+
this.listenEvents();
|
|
21
21
|
}
|
|
22
|
-
|
|
22
|
+
listenEvents() {
|
|
23
|
+
this.listenTankTypeChanges();
|
|
24
|
+
}
|
|
25
|
+
listenTankTypeChanges() {
|
|
23
26
|
this.get('tankType').valueChanges.subscribe((tankType) => {
|
|
24
27
|
var _a, _b;
|
|
25
28
|
this.removeControl('bankAccountProperties');
|
|
@@ -35,4 +38,4 @@ export class BankAccountAllocationForm extends AbstractForm {
|
|
|
35
38
|
});
|
|
36
39
|
}
|
|
37
40
|
}
|
|
38
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
41
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFuay1hY2NvdW50LWFsbG9jYXRpb24uZm9ybS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3R0LWNvcmUvc3JjL2xpYi9mb3Jtcy9iYW5rL2JhbmstYWNjb3VudC9iYW5rLWFjY291bnQtYWxsb2NhdGlvbi5mb3JtLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUNuRCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sbUNBQW1DLENBQUM7QUFDaEUsT0FBTyxFQUFFLFdBQVcsRUFBRSxVQUFVLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUN6RCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDakQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGtDQUFrQyxDQUFDO0FBQ2hFLE9BQU8sRUFBRSx5QkFBeUIsRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBQzNFLE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxNQUFNLFlBQVksQ0FBQztBQUd6RCxNQUFNLE9BQU8seUJBQTBCLFNBQVEsWUFBeUI7SUFDdEUsWUFBb0IsV0FBeUI7UUFDM0MsS0FBSyxDQUFDO1lBQ0osUUFBUSxFQUFFLElBQUksV0FBVyxDQUFDLFdBQVcsQ0FBQyxDQUFDLENBQUMsV0FBVyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsSUFBSSxFQUFFLFVBQVUsQ0FBQyxRQUFRLENBQUM7U0FDMUYsRUFBRSxZQUFZLENBQUMsV0FBVyxFQUFFLFdBQVcsSUFBSSxFQUFFLENBQUMsQ0FBQyxDQUFDO1FBSC9CLGdCQUFXLEdBQVgsV0FBVyxDQUFjO1FBSzNDLElBQUksV0FBVyxhQUFYLFdBQVcsdUJBQVgsV0FBVyxDQUFFLGNBQWMsRUFBRSxFQUFFO1lBQ2pDLElBQUksQ0FBQyxVQUFVLENBQUMsdUJBQXVCLEVBQUUsSUFBSSx5QkFBeUIsQ0FBQyxXQUFXLENBQUMscUJBQXFCLENBQUMsQ0FBQyxDQUFDO1NBQzVHO1FBRUQsSUFBSSxXQUFXLGFBQVgsV0FBVyx1QkFBWCxXQUFXLENBQUUsVUFBVSxFQUFFLEVBQUU7WUFDN0IsSUFBSSxDQUFDLFVBQVUsQ0FBQyxxQkFBcUIsRUFBRSxJQUFJLDJCQUEyQixDQUFDLFdBQVcsQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDLENBQUE7U0FDekc7UUFFRCxJQUFJLENBQUMsWUFBWSxFQUFFLENBQUM7SUFDdEIsQ0FBQztJQUVELFlBQVk7UUFDVixJQUFJLENBQUMscUJBQXFCLEVBQUUsQ0FBQztJQUMvQixDQUFDO0lBRUQscUJBQXFCO1FBQ25CLElBQUksQ0FBQyxHQUFHLENBQUMsVUFBVSxDQUFDLENBQUMsWUFBWSxDQUFDLFNBQVMsQ0FBQyxDQUFDLFFBQXNCLEVBQUUsRUFBRTs7WUFDckUsSUFBSSxDQUFDLGFBQWEsQ0FBQyx1QkFBdUIsQ0FBQyxDQUFDO1lBQzVDLElBQUksQ0FBQyxhQUFhLENBQUMscUJBQXFCLENBQUMsQ0FBQztZQUUxQyxRQUFRLFFBQVEsRUFBRTtnQkFDaEIsS0FBSyxZQUFZLENBQUMsUUFBUTtvQkFDeEIsSUFBSSxDQUFDLFVBQVUsQ0FBQyx1QkFBdUIsRUFBRSxJQUFJLHlCQUF5QixDQUFDLE1BQUEsSUFBSSxDQUFDLFdBQVcsMENBQUUscUJBQXFCLENBQUMsQ0FBQyxDQUFDO29CQUNqSCxNQUFNO2dCQUNSLEtBQUssWUFBWSxDQUFDLElBQUk7b0JBQ3BCLElBQUksQ0FBQyxVQUFVLENBQUMscUJBQXFCLEVBQUUsSUFBSSwyQkFBMkIsQ0FBQyxNQUFBLElBQUksQ0FBQyxXQUFXLDBDQUFFLG1CQUFtQixDQUFDLENBQUMsQ0FBQTtvQkFDOUcsTUFBTTthQUNUO1FBQ0gsQ0FBQyxDQUFDLENBQUE7SUFDSixDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBYnN0cmFjdEZvcm0gfSBmcm9tICcuLi8uLi9hYnN0cmFjdC5mb3JtJztcbmltcG9ydCB7IEJhbmtBY2NvdW50IH0gZnJvbSAnLi4vLi4vLi4vbW9kZWxzL2JhbmsvYmFuay1hY2NvdW50JztcbmltcG9ydCB7IEZvcm1Db250cm9sLCBWYWxpZGF0b3JzIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgcGxhaW5Ub0NsYXNzIH0gZnJvbSAnY2xhc3MtdHJhbnNmb3JtZXInO1xuaW1wb3J0IHsgVGFua1R5cGVFbnVtIH0gZnJvbSAnLi4vLi4vLi4vZGIvRW51bXMvdGFuay10eXBlLmVudW0nO1xuaW1wb3J0IHsgQmFua0FjY291bnRQcm9wZXJ0aWVzRm9ybSB9IGZyb20gJy4vYmFuay1hY2NvdW50LXByb3BlcnRpZXMuZm9ybSc7XG5pbXBvcnQgeyBTb2xlQnVzaW5lc3NBbGxvY2F0aW9uc0Zvcm0gfSBmcm9tICcuLi8uLi9zb2xlJztcbmltcG9ydCB7IElFdmVudExpc3RlbmVyIH0gZnJvbSAnLi4vLi4vLi4vaW50ZXJmYWNlcy9ldmVudC1saXN0ZW5lci5pbnRlcmZhY2UnO1xuXG5leHBvcnQgY2xhc3MgQmFua0FjY291bnRBbGxvY2F0aW9uRm9ybSBleHRlbmRzIEFic3RyYWN0Rm9ybTxCYW5rQWNjb3VudD4gaW1wbGVtZW50cyBJRXZlbnRMaXN0ZW5lciB7XG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgYmFua0FjY291bnQ/OiBCYW5rQWNjb3VudCkge1xuICAgIHN1cGVyKHtcbiAgICAgIHRhbmtUeXBlOiBuZXcgRm9ybUNvbnRyb2woYmFua0FjY291bnQgPyBiYW5rQWNjb3VudC50YW5rVHlwZSA6IG51bGwsIFZhbGlkYXRvcnMucmVxdWlyZWQpXG4gICAgfSwgcGxhaW5Ub0NsYXNzKEJhbmtBY2NvdW50LCBiYW5rQWNjb3VudCB8fCB7fSkpO1xuXG4gICAgaWYgKGJhbmtBY2NvdW50Py5pc1Byb3BlcnR5VGFuaygpKSB7XG4gICAgICB0aGlzLmFkZENvbnRyb2woJ2JhbmtBY2NvdW50UHJvcGVydGllcycsIG5ldyBCYW5rQWNjb3VudFByb3BlcnRpZXNGb3JtKGJhbmtBY2NvdW50LmJhbmtBY2NvdW50UHJvcGVydGllcykpO1xuICAgIH1cblxuICAgIGlmIChiYW5rQWNjb3VudD8uaXNTb2xlVGFuaygpKSB7XG4gICAgICB0aGlzLmFkZENvbnRyb2woJ2J1c2luZXNzQWxsb2NhdGlvbnMnLCBuZXcgU29sZUJ1c2luZXNzQWxsb2NhdGlvbnNGb3JtKGJhbmtBY2NvdW50LmJ1c2luZXNzQWxsb2NhdGlvbnMpKVxuICAgIH1cblxuICAgIHRoaXMubGlzdGVuRXZlbnRzKCk7XG4gIH1cblxuICBsaXN0ZW5FdmVudHMoKTogdm9pZCB7XG4gICAgdGhpcy5saXN0ZW5UYW5rVHlwZUNoYW5nZXMoKTtcbiAgfVxuXG4gIGxpc3RlblRhbmtUeXBlQ2hhbmdlcygpOiB2b2lkIHtcbiAgICB0aGlzLmdldCgndGFua1R5cGUnKS52YWx1ZUNoYW5nZXMuc3Vic2NyaWJlKCh0YW5rVHlwZTogVGFua1R5cGVFbnVtKSA9PiB7XG4gICAgICB0aGlzLnJlbW92ZUNvbnRyb2woJ2JhbmtBY2NvdW50UHJvcGVydGllcycpO1xuICAgICAgdGhpcy5yZW1vdmVDb250cm9sKCdidXNpbmVzc0FsbG9jYXRpb25zJyk7XG5cbiAgICAgIHN3aXRjaCAodGFua1R5cGUpIHtcbiAgICAgICAgY2FzZSBUYW5rVHlwZUVudW0uUFJPUEVSVFk6XG4gICAgICAgICAgdGhpcy5hZGRDb250cm9sKCdiYW5rQWNjb3VudFByb3BlcnRpZXMnLCBuZXcgQmFua0FjY291bnRQcm9wZXJ0aWVzRm9ybSh0aGlzLmJhbmtBY2NvdW50Py5iYW5rQWNjb3VudFByb3BlcnRpZXMpKTtcbiAgICAgICAgICBicmVhaztcbiAgICAgICAgY2FzZSBUYW5rVHlwZUVudW0uU09MRTpcbiAgICAgICAgICB0aGlzLmFkZENvbnRyb2woJ2J1c2luZXNzQWxsb2NhdGlvbnMnLCBuZXcgU29sZUJ1c2luZXNzQWxsb2NhdGlvbnNGb3JtKHRoaXMuYmFua0FjY291bnQ/LmJ1c2luZXNzQWxsb2NhdGlvbnMpKVxuICAgICAgICAgIGJyZWFrO1xuICAgICAgfVxuICAgIH0pXG4gIH1cbn1cbiJdfQ==
|