@tomei/finance 0.6.13 → 0.6.20

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.
Files changed (287) hide show
  1. package/.commitlintrc.json +22 -22
  2. package/.eslintrc.js +72 -72
  3. package/.husky/commit-msg +4 -4
  4. package/.husky/pre-commit +4 -4
  5. package/.prettierrc +4 -4
  6. package/CONTRIBUTING.md +30 -30
  7. package/LICENSE +21 -21
  8. package/README.md +13 -13
  9. package/configs/config.js +336 -336
  10. package/dist/document/document.js +4 -1
  11. package/dist/document/document.js.map +1 -1
  12. package/dist/payment-item/payment-item.js +6 -5
  13. package/dist/payment-item/payment-item.js.map +1 -1
  14. package/dist/tsconfig.tsbuildinfo +1 -1
  15. package/invoice-template/assets/css/style.css.map +12 -12
  16. package/invoice-template/assets/css/style.min.css +1 -1
  17. package/invoice-template/assets/img/arrow_bg.svg +11 -11
  18. package/invoice-template/assets/img/coffy_shop_img.svg +18 -18
  19. package/invoice-template/assets/img/logo_accent.svg +3 -3
  20. package/invoice-template/assets/img/logo_white.svg +4 -4
  21. package/invoice-template/assets/img/sign.svg +12 -12
  22. package/invoice-template/assets/img/tomei-logo.svg +9 -9
  23. package/invoice-template/assets/js/html2canvas.min.js +10379 -10379
  24. package/invoice-template/assets/js/jquery.min.js +1 -1
  25. package/invoice-template/assets/sass/common/_color_variable.scss +12 -12
  26. package/invoice-template/assets/sass/common/_typography.scss +178 -178
  27. package/invoice-template/assets/sass/style.scss +12 -12
  28. package/migrations/finance-account-migration.js +97 -97
  29. package/migrations/finance-company-migration.js +29 -29
  30. package/migrations/finance-customer-migration.js +51 -51
  31. package/migrations/finance-document-item-migration.js +111 -111
  32. package/migrations/finance-document-migration.js +116 -116
  33. package/migrations/finance-payment-item-migration.js +52 -52
  34. package/migrations/finance-payment-method-migration.js +31 -31
  35. package/migrations/finance-payment-method-type-migration.js +55 -55
  36. package/migrations/finance-payment-migration.js +96 -96
  37. package/migrations/finance-post-history-migration.js +45 -45
  38. package/nest-cli.json +19 -19
  39. package/package.json +82 -82
  40. package/src/account/account.repository.ts +11 -11
  41. package/src/account/account.ts +271 -271
  42. package/src/account/interfaces/account-attr.interface.ts +31 -31
  43. package/src/account-system-entity/account-system-entity.ts +65 -65
  44. package/src/account-system-entity/post-history.repository.ts +11 -11
  45. package/src/config.ts +382 -382
  46. package/src/customer/customer.ts +299 -299
  47. package/src/customer/finance-customer.repository.ts +13 -13
  48. package/src/customer/interfaces/customer.repository.interface.ts +3 -3
  49. package/src/customer/interfaces/finance-customer-attr.interface.ts +10 -10
  50. package/src/customer/interfaces/finance-customer.repository.interface.ts +4 -4
  51. package/src/database.ts +15 -15
  52. package/src/document/document-item.repository.ts +11 -11
  53. package/src/document/document.repository.ts +11 -11
  54. package/src/document/document.ts +4 -1
  55. package/src/document/interfaces/document-attr.interface.ts +28 -28
  56. package/src/document/interfaces/document-item-attr.interface.ts +22 -22
  57. package/src/document/interfaces/document-item.repository.interface.ts +4 -4
  58. package/src/enum/doc-type.enum.ts +8 -8
  59. package/src/enum/index.ts +17 -17
  60. package/src/enum/payment-method.enum.ts +3 -3
  61. package/src/enum/payment-type.enum.ts +4 -4
  62. package/src/finance-company/finance-company.repository.ts +11 -11
  63. package/src/finance-company/finance-company.ts +1778 -1778
  64. package/src/helpers/typeof.ts +29 -29
  65. package/src/index.ts +32 -32
  66. package/src/interfaces/account-system.interface.ts +20 -20
  67. package/src/interfaces/index.ts +3 -3
  68. package/src/models/account.entity.ts +206 -206
  69. package/src/models/customer.entity.ts +93 -93
  70. package/src/models/document-item.entity.ts +143 -143
  71. package/src/models/document.entity.ts +211 -211
  72. package/src/models/finance-company.entity.ts +25 -25
  73. package/src/models/journal-entry.entity.ts +110 -110
  74. package/src/models/ledger-transaction.entity.ts +148 -148
  75. package/src/models/payment-item.entity.ts +60 -60
  76. package/src/models/payment-method-type.entity.ts +70 -70
  77. package/src/models/payment-method.entity.ts +51 -51
  78. package/src/models/payment.entity.ts +161 -161
  79. package/src/models/post-history.entity.ts +41 -41
  80. package/src/payment/interfaces/payment-attr.interface.ts +23 -23
  81. package/src/payment/interfaces/payment-params.interface.ts +8 -8
  82. package/src/payment/payment.repository.ts +11 -11
  83. package/src/payment/payment.ts +217 -217
  84. package/src/payment-item/interfaces/payment-item-attr.interface.ts +10 -10
  85. package/src/payment-item/payment-item.repository.ts +11 -11
  86. package/src/payment-item/payment-item.ts +128 -125
  87. package/src/payment-method/payment-method.repository.ts +11 -11
  88. package/src/payment-method-type/payment-method-type.repository.ts +11 -11
  89. package/src/test-document.ts +25 -25
  90. package/tsconfig.build.json +4 -4
  91. package/tsconfig.json +22 -22
  92. package/tslint.json +18 -18
  93. package/dist/account/entities/account.entity.d.ts +0 -26
  94. package/dist/account/entities/account.entity.js +0 -199
  95. package/dist/account/entities/account.entity.js.map +0 -1
  96. package/dist/account/entities/fee-associated-object.entity.d.ts +0 -6
  97. package/dist/account/entities/fee-associated-object.entity.js +0 -52
  98. package/dist/account/entities/fee-associated-object.entity.js.map +0 -1
  99. package/dist/account/index.d.ts +0 -6
  100. package/dist/account/index.js +0 -10
  101. package/dist/account/index.js.map +0 -1
  102. package/dist/account/interfaces/account.repository.interface.d.ts +0 -3
  103. package/dist/account/interfaces/account.repository.interface.js +0 -3
  104. package/dist/account/interfaces/account.repository.interface.js.map +0 -1
  105. package/dist/account-system-entity/index.d.ts +0 -2
  106. package/dist/account-system-entity/index.js +0 -6
  107. package/dist/account-system-entity/index.js.map +0 -1
  108. package/dist/account-system-entity/post-history.entity.d.ts +0 -11
  109. package/dist/account-system-entity/post-history.entity.js +0 -65
  110. package/dist/account-system-entity/post-history.entity.js.map +0 -1
  111. package/dist/base/account-system.interface.d.ts +0 -7
  112. package/dist/base/account-system.interface.js +0 -3
  113. package/dist/base/account-system.interface.js.map +0 -1
  114. package/dist/base/address.base.abstract.d.ts +0 -4
  115. package/dist/base/address.base.abstract.js +0 -10
  116. package/dist/base/address.base.abstract.js.map +0 -1
  117. package/dist/base/base.address.d.ts +0 -8
  118. package/dist/base/base.address.js +0 -15
  119. package/dist/base/base.address.js.map +0 -1
  120. package/dist/base/base.object.d.ts +0 -7
  121. package/dist/base/base.object.js +0 -14
  122. package/dist/base/base.object.js.map +0 -1
  123. package/dist/base/base.owner.d.ts +0 -23
  124. package/dist/base/base.owner.js +0 -34
  125. package/dist/base/base.owner.js.map +0 -1
  126. package/dist/base/base.repository.abstract.d.ts +0 -12
  127. package/dist/base/base.repository.abstract.js +0 -22
  128. package/dist/base/base.repository.abstract.js.map +0 -1
  129. package/dist/base/base.repository.interface.d.ts +0 -9
  130. package/dist/base/base.repository.interface.js +0 -3
  131. package/dist/base/base.repository.interface.js.map +0 -1
  132. package/dist/base/index.d.ts +0 -4
  133. package/dist/base/index.js +0 -10
  134. package/dist/base/index.js.map +0 -1
  135. package/dist/base/object/base.object.abstract.d.ts +0 -5
  136. package/dist/base/object/base.object.abstract.js +0 -7
  137. package/dist/base/object/base.object.abstract.js.map +0 -1
  138. package/dist/base/object/base.object.d.ts +0 -7
  139. package/dist/base/object/base.object.js +0 -14
  140. package/dist/base/object/base.object.js.map +0 -1
  141. package/dist/base/object/object.interface.d.ts +0 -4
  142. package/dist/base/object/object.interface.js +0 -3
  143. package/dist/base/object/object.interface.js.map +0 -1
  144. package/dist/base/object.base.abstract.d.ts +0 -5
  145. package/dist/base/object.base.abstract.js +0 -11
  146. package/dist/base/object.base.abstract.js.map +0 -1
  147. package/dist/base/owner/base.owner.abstract.d.ts +0 -20
  148. package/dist/base/owner/base.owner.abstract.js +0 -8
  149. package/dist/base/owner/base.owner.abstract.js.map +0 -1
  150. package/dist/base/owner/base.owner.d.ts +0 -22
  151. package/dist/base/owner/base.owner.js +0 -31
  152. package/dist/base/owner/base.owner.js.map +0 -1
  153. package/dist/base/owner/owner.interface.d.ts +0 -19
  154. package/dist/base/owner/owner.interface.js +0 -3
  155. package/dist/base/owner/owner.interface.js.map +0 -1
  156. package/dist/base/person.base.abstract.d.ts +0 -21
  157. package/dist/base/person.base.abstract.js +0 -17
  158. package/dist/base/person.base.abstract.js.map +0 -1
  159. package/dist/base/repository/base.repository.abstract.d.ts +0 -12
  160. package/dist/base/repository/base.repository.abstract.js +0 -22
  161. package/dist/base/repository/base.repository.abstract.js.map +0 -1
  162. package/dist/base/repository/base.repository.interface.d.ts +0 -9
  163. package/dist/base/repository/base.repository.interface.js +0 -3
  164. package/dist/base/repository/base.repository.interface.js.map +0 -1
  165. package/dist/customer/customer.repository.d.ts +0 -0
  166. package/dist/customer/customer.repository.js +0 -1
  167. package/dist/customer/customer.repository.js.map +0 -1
  168. package/dist/customer/entities/customer.entity.d.ts +0 -13
  169. package/dist/customer/entities/customer.entity.js +0 -111
  170. package/dist/customer/entities/customer.entity.js.map +0 -1
  171. package/dist/customer/index.d.ts +0 -7
  172. package/dist/customer/index.js +0 -10
  173. package/dist/customer/index.js.map +0 -1
  174. package/dist/document/entities/document-item.entity.d.ts +0 -27
  175. package/dist/document/entities/document-item.entity.js +0 -174
  176. package/dist/document/entities/document-item.entity.js.map +0 -1
  177. package/dist/document/entities/document.entity.d.ts +0 -22
  178. package/dist/document/entities/document.entity.js +0 -139
  179. package/dist/document/entities/document.entity.js.map +0 -1
  180. package/dist/document/index.d.ts +0 -11
  181. package/dist/document/index.js +0 -20
  182. package/dist/document/index.js.map +0 -1
  183. package/dist/document/interfaces/document.repository.interface.d.ts +0 -3
  184. package/dist/document/interfaces/document.repository.interface.js +0 -3
  185. package/dist/document/interfaces/document.repository.interface.js.map +0 -1
  186. package/dist/enum/document-type.enum.d.ts +0 -7
  187. package/dist/enum/document-type.enum.js +0 -12
  188. package/dist/enum/document-type.enum.js.map +0 -1
  189. package/dist/enum/intuit-client.enum.d.ts +0 -13
  190. package/dist/enum/intuit-client.enum.js +0 -19
  191. package/dist/enum/intuit-client.enum.js.map +0 -1
  192. package/dist/finance-company/entities/finance-company.entity.d.ts +0 -13
  193. package/dist/finance-company/entities/finance-company.entity.js +0 -113
  194. package/dist/finance-company/entities/finance-company.entity.js.map +0 -1
  195. package/dist/finance-company/finance-company.entity.d.ts +0 -13
  196. package/dist/finance-company/finance-company.entity.js +0 -66
  197. package/dist/finance-company/finance-company.entity.js.map +0 -1
  198. package/dist/finance-company/index.d.ts +0 -3
  199. package/dist/finance-company/index.js +0 -8
  200. package/dist/finance-company/index.js.map +0 -1
  201. package/dist/finance-company/interfaces/finance-company-attr.interface.d.ts +0 -10
  202. package/dist/finance-company/interfaces/finance-company-attr.interface.js +0 -3
  203. package/dist/finance-company/interfaces/finance-company-attr.interface.js.map +0 -1
  204. package/dist/finance-company/interfaces/finance-company.repository.interface.d.ts +0 -3
  205. package/dist/finance-company/interfaces/finance-company.repository.interface.js +0 -3
  206. package/dist/finance-company/interfaces/finance-company.repository.interface.js.map +0 -1
  207. package/dist/interfaces/account-system-entity.interface.d.ts +0 -7
  208. package/dist/interfaces/account-system-entity.interface.js +0 -3
  209. package/dist/interfaces/account-system-entity.interface.js.map +0 -1
  210. package/dist/interfaces/customer.repository.interface.d.ts +0 -3
  211. package/dist/interfaces/customer.repository.interface.js +0 -3
  212. package/dist/interfaces/customer.repository.interface.js.map +0 -1
  213. package/dist/interfaces/finance-customer.repository.interface.d.ts +0 -3
  214. package/dist/interfaces/finance-customer.repository.interface.js +0 -3
  215. package/dist/interfaces/finance-customer.repository.interface.js.map +0 -1
  216. package/dist/interfaces/systemConfig.interface.d.ts +0 -0
  217. package/dist/interfaces/systemConfig.interface.js +0 -1
  218. package/dist/interfaces/systemConfig.interface.js.map +0 -1
  219. package/dist/intuit-client/client.d.ts +0 -14
  220. package/dist/intuit-client/client.js +0 -44
  221. package/dist/intuit-client/client.js.map +0 -1
  222. package/dist/journal-entry/entities/journal-entry.entity.d.ts +0 -16
  223. package/dist/journal-entry/entities/journal-entry.entity.js +0 -129
  224. package/dist/journal-entry/entities/journal-entry.entity.js.map +0 -1
  225. package/dist/journal-entry/index.d.ts +0 -6
  226. package/dist/journal-entry/index.js +0 -10
  227. package/dist/journal-entry/index.js.map +0 -1
  228. package/dist/journal-entry/interfaces/journal-entry.repository.interface.d.ts +0 -10
  229. package/dist/journal-entry/interfaces/journal-entry.repository.interface.js +0 -3
  230. package/dist/journal-entry/interfaces/journal-entry.repository.interface.js.map +0 -1
  231. package/dist/ledger-transaction/entities/ledger-transaction.entity.d.ts +0 -19
  232. package/dist/ledger-transaction/entities/ledger-transaction.entity.js +0 -157
  233. package/dist/ledger-transaction/entities/ledger-transaction.entity.js.map +0 -1
  234. package/dist/ledger-transaction/index.d.ts +0 -6
  235. package/dist/ledger-transaction/index.js +0 -10
  236. package/dist/ledger-transaction/index.js.map +0 -1
  237. package/dist/payment/entities/payment-item.entity.d.ts +0 -10
  238. package/dist/payment/entities/payment-item.entity.js +0 -62
  239. package/dist/payment/entities/payment-item.entity.js.map +0 -1
  240. package/dist/payment/entities/payment.entity.d.ts +0 -25
  241. package/dist/payment/entities/payment.entity.js +0 -152
  242. package/dist/payment/entities/payment.entity.js.map +0 -1
  243. package/dist/payment/index.d.ts +0 -10
  244. package/dist/payment/index.js +0 -18
  245. package/dist/payment/index.js.map +0 -1
  246. package/dist/payment/interfaces/payment-item-attr.interface.d.ts +0 -8
  247. package/dist/payment/interfaces/payment-item-attr.interface.js +0 -7
  248. package/dist/payment/interfaces/payment-item-attr.interface.js.map +0 -1
  249. package/dist/payment/interfaces/payment-item.repository.interface.d.ts +0 -3
  250. package/dist/payment/interfaces/payment-item.repository.interface.js +0 -3
  251. package/dist/payment/interfaces/payment-item.repository.interface.js.map +0 -1
  252. package/dist/payment/interfaces/payment.repository.interface.d.ts +0 -3
  253. package/dist/payment/interfaces/payment.repository.interface.js +0 -3
  254. package/dist/payment/interfaces/payment.repository.interface.js.map +0 -1
  255. package/dist/payment/payment-item.repository.d.ts +0 -5
  256. package/dist/payment/payment-item.repository.js +0 -12
  257. package/dist/payment/payment-item.repository.js.map +0 -1
  258. package/dist/payment-item/interfaces/payment-item.repository.interface.d.ts +0 -3
  259. package/dist/payment-item/interfaces/payment-item.repository.interface.js +0 -3
  260. package/dist/payment-item/interfaces/payment-item.repository.interface.js.map +0 -1
  261. package/dist/quickbook-client/client.d.ts +0 -39
  262. package/dist/quickbook-client/client.js +0 -205
  263. package/dist/quickbook-client/client.js.map +0 -1
  264. package/dist/quickbook-client/constant.d.ts +0 -1
  265. package/dist/quickbook-client/constant.js +0 -5
  266. package/dist/quickbook-client/constant.js.map +0 -1
  267. package/dist/quickbook-client/index.d.ts +0 -5
  268. package/dist/quickbook-client/index.js +0 -6
  269. package/dist/quickbook-client/index.js.map +0 -1
  270. package/dist/quickbook-client/interfaces/quickbook-client-call-options.interface.d.ts +0 -6
  271. package/dist/quickbook-client/interfaces/quickbook-client-call-options.interface.js +0 -3
  272. package/dist/quickbook-client/interfaces/quickbook-client-call-options.interface.js.map +0 -1
  273. package/dist/quickbook-client/interfaces/quickbook-client-create-account-options.interface.d.ts +0 -9
  274. package/dist/quickbook-client/interfaces/quickbook-client-create-account-options.interface.js +0 -3
  275. package/dist/quickbook-client/interfaces/quickbook-client-create-account-options.interface.js.map +0 -1
  276. package/dist/quickbook-client/interfaces/quickbook-client-create-customer-options.interface.d.ts +0 -7
  277. package/dist/quickbook-client/interfaces/quickbook-client-create-customer-options.interface.js +0 -3
  278. package/dist/quickbook-client/interfaces/quickbook-client-create-customer-options.interface.js.map +0 -1
  279. package/dist/quickbook-client/interfaces/quickbook-client-options.interface.d.ts +0 -8
  280. package/dist/quickbook-client/interfaces/quickbook-client-options.interface.js +0 -3
  281. package/dist/quickbook-client/interfaces/quickbook-client-options.interface.js.map +0 -1
  282. package/dist/quickbook-client/quickbook-client.module-definition.d.ts +0 -2
  283. package/dist/quickbook-client/quickbook-client.module-definition.js +0 -9
  284. package/dist/quickbook-client/quickbook-client.module-definition.js.map +0 -1
  285. package/dist/quickbook-client/quickbook-client.module.d.ts +0 -6
  286. package/dist/quickbook-client/quickbook-client.module.js +0 -34
  287. package/dist/quickbook-client/quickbook-client.module.js.map +0 -1
@@ -1,125 +1,128 @@
1
- import { ObjectBase } from '@tomei/general';
2
- import Payment from '../payment/payment';
3
- import { type } from '../helpers/typeof';
4
- import { QueryTypes } from 'sequelize';
5
- import { FinanceDb } from '../';
6
- import { Next } from '@nestjs/common/decorators';
7
-
8
- export default class PaymentItem extends ObjectBase {
9
- private _PaymentId = '';
10
- private _PayForObjectId = '';
11
- private _PayForObjectType = '';
12
- Currency = 'MYR';
13
- Amount = 0;
14
- Name = '';
15
- Description = '';
16
- Remarks = '';
17
-
18
- get PaymentId() {
19
- return this._PaymentId;
20
- }
21
-
22
- private set PaymentId(id: string) {
23
- this._PaymentId = id;
24
- }
25
-
26
- get PayForObjectId() {
27
- return this._PayForObjectId;
28
- }
29
-
30
- set PayForObjectId(id: string) {
31
- this._PayForObjectId = id;
32
- }
33
-
34
- get PayForObjectType(): string {
35
- return this._PayForObjectType;
36
- }
37
-
38
- set PayForObjectType(type: string) {
39
- this._PayForObjectType = type;
40
- }
41
-
42
- /* ObjectBase Implementation */
43
- get ObjectId() {
44
- return '';
45
- }
46
-
47
- get ObjectName() {
48
- return '';
49
- }
50
-
51
- get TableName() {
52
- return 'finance_PaymentItem';
53
- }
54
-
55
- constructor(payment: Payment, objectBeingPaidFor: ObjectBase) {
56
- super();
57
- this.PaymentId = payment.PaymentId;
58
- this.PayForObjectId = objectBeingPaidFor.ObjectId;
59
- this.PayForObjectType = type(objectBeingPaidFor);
60
- }
61
-
62
- async paid(dbTransaction: any) {
63
- const sequelize = FinanceDb.getConnection();
64
- if (this.PayForObjectType === 'Document') {
65
- const selectQuery = `SELECT Amount FROM finance_Document WHERE DocNo = '${this.PayForObjectId}'`;
66
- const invoice: any[] = await sequelize.query(selectQuery, {
67
- type: QueryTypes.SELECT,
68
- raw: true,
69
- transaction: dbTransaction,
70
- });
71
-
72
- let paidStatus = '';
73
- if (invoice[0].Amount > this.Amount) {
74
- const selectPaymentItem = `SELECT * FROM finance_PaymentItem WHERE PayForObjectId = '${this.PayForObjectId}' AND PayForObjectType = 'Document'`;
75
- const documentPaymentItems: any[] = await sequelize.query(
76
- selectPaymentItem,
77
- {
78
- type: QueryTypes.SELECT,
79
- raw: true,
80
- transaction: dbTransaction,
81
- },
82
- );
83
- let amountPreviouslyPaid = 0;
84
- documentPaymentItems.forEach((paymentItem) => {
85
- const amount =
86
- typeof paymentItem.Amount === 'string'
87
- ? parseFloat(paymentItem.Amount).toFixed(2)
88
- : paymentItem.Amount;
89
- amountPreviouslyPaid += amount;
90
- });
91
- if (invoice[0].Amount === amountPreviouslyPaid) {
92
- paidStatus = 'Paid';
93
- } else {
94
- paidStatus = 'Partial Paid';
95
- }
96
- } else if (invoice[0].Amount === this.Amount) {
97
- paidStatus = 'Paid';
98
- } else {
99
- throw new Error(
100
- 'Payment Item amount cannot be greater than its PayForObject amount.',
101
- );
102
- }
103
-
104
- const updateQuery = `
105
- UPDATE finance_Document
106
- SET Status = '${paidStatus}'
107
- WHERE DocNo = '${this.PayForObjectId}'
108
- `;
109
- // const replacements = { docNo: this.PayForObjectId };
110
- await sequelize.query(updateQuery, {
111
- type: QueryTypes.UPDATE,
112
- raw: true,
113
- transaction: dbTransaction,
114
- });
115
- } else if (
116
- this.PayForObjectType === 'LoanSchedule' ||
117
- this.PayForObjectType === 'SimpleLoans' ||
118
- this.PayForObjectType === 'Loans'
119
- ) {
120
- Next();
121
- } else {
122
- throw new Error('Unknown type');
123
- }
124
- }
125
- }
1
+ import { ObjectBase } from '@tomei/general';
2
+ import Payment from '../payment/payment';
3
+ import { type } from '../helpers/typeof';
4
+ import { QueryTypes } from 'sequelize';
5
+ import { FinanceDb } from '../';
6
+ import { Next } from '@nestjs/common/decorators';
7
+
8
+ export default class PaymentItem extends ObjectBase {
9
+ private _PaymentId = '';
10
+ private _PayForObjectId = '';
11
+ private _PayForObjectType = '';
12
+ Currency = 'MYR';
13
+ Amount = 0;
14
+ Name = '';
15
+ Description = '';
16
+ Remarks = '';
17
+
18
+ get PaymentId() {
19
+ return this._PaymentId;
20
+ }
21
+
22
+ private set PaymentId(id: string) {
23
+ this._PaymentId = id;
24
+ }
25
+
26
+ get PayForObjectId() {
27
+ return this._PayForObjectId;
28
+ }
29
+
30
+ set PayForObjectId(id: string) {
31
+ this._PayForObjectId = id;
32
+ }
33
+
34
+ get PayForObjectType(): string {
35
+ return this._PayForObjectType;
36
+ }
37
+
38
+ set PayForObjectType(type: string) {
39
+ this._PayForObjectType = type;
40
+ }
41
+
42
+ /* ObjectBase Implementation */
43
+ get ObjectId() {
44
+ return '';
45
+ }
46
+
47
+ get ObjectName() {
48
+ return '';
49
+ }
50
+
51
+ get TableName() {
52
+ return 'finance_PaymentItem';
53
+ }
54
+
55
+ constructor(payment: Payment, objectBeingPaidFor: ObjectBase) {
56
+ super();
57
+ this.PaymentId = payment.PaymentId;
58
+ this.PayForObjectId = objectBeingPaidFor.ObjectId;
59
+ this.PayForObjectType = type(objectBeingPaidFor);
60
+ }
61
+
62
+ async paid(dbTransaction: any) {
63
+ const sequelize = FinanceDb.getConnection();
64
+ if (
65
+ this.PayForObjectType === 'Document' ||
66
+ this.PayForObjectType === 'FinanceDocument'
67
+ ) {
68
+ const selectQuery = `SELECT Amount FROM finance_Document WHERE DocNo = '${this.PayForObjectId}'`;
69
+ const invoice: any[] = await sequelize.query(selectQuery, {
70
+ type: QueryTypes.SELECT,
71
+ raw: true,
72
+ transaction: dbTransaction,
73
+ });
74
+
75
+ let paidStatus = '';
76
+ if (invoice[0].Amount > this.Amount) {
77
+ const selectPaymentItem = `SELECT * FROM finance_PaymentItem WHERE PayForObjectId = '${this.PayForObjectId}' AND PayForObjectType = 'Document'`;
78
+ const documentPaymentItems: any[] = await sequelize.query(
79
+ selectPaymentItem,
80
+ {
81
+ type: QueryTypes.SELECT,
82
+ raw: true,
83
+ transaction: dbTransaction,
84
+ },
85
+ );
86
+ let amountPreviouslyPaid = 0;
87
+ documentPaymentItems.forEach((paymentItem) => {
88
+ const amount =
89
+ typeof paymentItem.Amount === 'string'
90
+ ? parseFloat(paymentItem.Amount).toFixed(2)
91
+ : paymentItem.Amount;
92
+ amountPreviouslyPaid += amount;
93
+ });
94
+ if (invoice[0].Amount === amountPreviouslyPaid) {
95
+ paidStatus = 'Paid';
96
+ } else {
97
+ paidStatus = 'Partial Paid';
98
+ }
99
+ } else if (invoice[0].Amount === this.Amount) {
100
+ paidStatus = 'Paid';
101
+ } else {
102
+ throw new Error(
103
+ 'Payment Item amount cannot be greater than its PayForObject amount.',
104
+ );
105
+ }
106
+
107
+ const updateQuery = `
108
+ UPDATE finance_Document
109
+ SET Status = '${paidStatus}'
110
+ WHERE DocNo = '${this.PayForObjectId}'
111
+ `;
112
+ // const replacements = { docNo: this.PayForObjectId };
113
+ await sequelize.query(updateQuery, {
114
+ type: QueryTypes.UPDATE,
115
+ raw: true,
116
+ transaction: dbTransaction,
117
+ });
118
+ } else if (
119
+ this.PayForObjectType === 'LoanSchedule' ||
120
+ this.PayForObjectType === 'SimpleLoans' ||
121
+ this.PayForObjectType === 'Loans'
122
+ ) {
123
+ Next();
124
+ } else {
125
+ throw new Error('Unknown type');
126
+ }
127
+ }
128
+ }
@@ -1,11 +1,11 @@
1
- import { RepositoryBase, IRepositoryBase } from '@tomei/general';
2
- import PaymentMethodModel from '../models/payment-method.entity';
3
-
4
- export class PaymentMethodRepository
5
- extends RepositoryBase<PaymentMethodModel>
6
- implements IRepositoryBase<PaymentMethodModel>
7
- {
8
- constructor() {
9
- super(PaymentMethodModel);
10
- }
11
- }
1
+ import { RepositoryBase, IRepositoryBase } from '@tomei/general';
2
+ import PaymentMethodModel from '../models/payment-method.entity';
3
+
4
+ export class PaymentMethodRepository
5
+ extends RepositoryBase<PaymentMethodModel>
6
+ implements IRepositoryBase<PaymentMethodModel>
7
+ {
8
+ constructor() {
9
+ super(PaymentMethodModel);
10
+ }
11
+ }
@@ -1,11 +1,11 @@
1
- import { RepositoryBase, IRepositoryBase } from '@tomei/general';
2
- import PaymentMethodType from '../models/payment-method-type.entity';
3
-
4
- export class PaymentMethodTypeRepository
5
- extends RepositoryBase<PaymentMethodType>
6
- implements IRepositoryBase<PaymentMethodType>
7
- {
8
- constructor() {
9
- super(PaymentMethodType);
10
- }
11
- }
1
+ import { RepositoryBase, IRepositoryBase } from '@tomei/general';
2
+ import PaymentMethodType from '../models/payment-method-type.entity';
3
+
4
+ export class PaymentMethodTypeRepository
5
+ extends RepositoryBase<PaymentMethodType>
6
+ implements IRepositoryBase<PaymentMethodType>
7
+ {
8
+ constructor() {
9
+ super(PaymentMethodType);
10
+ }
11
+ }
@@ -1,25 +1,25 @@
1
- export class TestDocument {
2
- static test(classPath, className) {
3
- // tslint:disable-next-line:no-console
4
- console.log('inside test() #1');
5
- // eslint-disable-next-line @typescript-eslint/ban-ts-comment
6
- // @ts-ignore
7
- // eslint-disable-next-line @typescript-eslint/no-var-requires,@typescript-eslint/no-unused-vars,
8
- const module = require(classPath);
9
- // tslint:disable-next-line:no-console
10
- console.log('inside test() #1: %o', module);
11
- console.log(`module.${className}`);
12
- // tslint:disable-next-line:no-eval
13
- const classConstructor = eval(`module.${className}`);
14
- // tslint:disable-next-line:no-console
15
- console.log('inside test() #2: %o', classConstructor);
16
-
17
- const docGen = new classConstructor('RECEIPT001');
18
- // tslint:disable-next-line:no-console
19
- console.log('inside test() #3');
20
-
21
- docGen.generateReceipt();
22
- // tslint:disable-next-line:no-console
23
- console.log('inside test() #4');
24
- }
25
- }
1
+ export class TestDocument {
2
+ static test(classPath, className) {
3
+ // tslint:disable-next-line:no-console
4
+ console.log('inside test() #1');
5
+ // eslint-disable-next-line @typescript-eslint/ban-ts-comment
6
+ // @ts-ignore
7
+ // eslint-disable-next-line @typescript-eslint/no-var-requires,@typescript-eslint/no-unused-vars,
8
+ const module = require(classPath);
9
+ // tslint:disable-next-line:no-console
10
+ console.log('inside test() #1: %o', module);
11
+ console.log(`module.${className}`);
12
+ // tslint:disable-next-line:no-eval
13
+ const classConstructor = eval(`module.${className}`);
14
+ // tslint:disable-next-line:no-console
15
+ console.log('inside test() #2: %o', classConstructor);
16
+
17
+ const docGen = new classConstructor('RECEIPT001');
18
+ // tslint:disable-next-line:no-console
19
+ console.log('inside test() #3');
20
+
21
+ docGen.generateReceipt();
22
+ // tslint:disable-next-line:no-console
23
+ console.log('inside test() #4');
24
+ }
25
+ }
@@ -1,4 +1,4 @@
1
- {
2
- "extends": "./tsconfig.json",
3
- "exclude": ["node_modules", "test", "dist", "**/*spec.ts"]
4
- }
1
+ {
2
+ "extends": "./tsconfig.json",
3
+ "exclude": ["node_modules", "test", "dist", "**/*spec.ts"]
4
+ }
package/tsconfig.json CHANGED
@@ -1,22 +1,22 @@
1
- {
2
- "compilerOptions": {
3
- "module": "commonjs",
4
- "declaration": true,
5
- "removeComments": true,
6
- "emitDecoratorMetadata": true,
7
- "experimentalDecorators": true,
8
- "allowSyntheticDefaultImports": true,
9
- "moduleResolution": "node",
10
- "target": "es6",
11
- "sourceMap": true,
12
- "outDir": "./dist",
13
- "baseUrl": "./",
14
- "incremental": true,
15
- "skipLibCheck": true,
16
- "strictNullChecks": false,
17
- "noImplicitAny": false,
18
- "strictBindCallApply": false,
19
- "forceConsistentCasingInFileNames": false,
20
- "noFallthroughCasesInSwitch": false,
21
- }
22
- }
1
+ {
2
+ "compilerOptions": {
3
+ "module": "commonjs",
4
+ "declaration": true,
5
+ "removeComments": true,
6
+ "emitDecoratorMetadata": true,
7
+ "experimentalDecorators": true,
8
+ "allowSyntheticDefaultImports": true,
9
+ "moduleResolution": "node",
10
+ "target": "es6",
11
+ "sourceMap": true,
12
+ "outDir": "./dist",
13
+ "baseUrl": "./",
14
+ "incremental": true,
15
+ "skipLibCheck": true,
16
+ "strictNullChecks": false,
17
+ "noImplicitAny": false,
18
+ "strictBindCallApply": false,
19
+ "forceConsistentCasingInFileNames": false,
20
+ "noFallthroughCasesInSwitch": false,
21
+ }
22
+ }
package/tslint.json CHANGED
@@ -1,18 +1,18 @@
1
- {
2
- "defaultSeverity": "error",
3
- "extends": ["tslint:recommended"],
4
- "jsRules": {
5
- "no-unused-expression": true
6
- },
7
- "rules": {
8
- "quotemark": [true, "single"],
9
- "member-access": [false],
10
- "ordered-imports": [false],
11
- "max-line-length": [true, 150],
12
- "member-ordering": [false],
13
- "interface-name": [false],
14
- "arrow-parens": false,
15
- "object-literal-sort-keys": false
16
- },
17
- "rulesDirectory": []
18
- }
1
+ {
2
+ "defaultSeverity": "error",
3
+ "extends": ["tslint:recommended"],
4
+ "jsRules": {
5
+ "no-unused-expression": true
6
+ },
7
+ "rules": {
8
+ "quotemark": [true, "single"],
9
+ "member-access": [false],
10
+ "ordered-imports": [false],
11
+ "max-line-length": [true, 150],
12
+ "member-ordering": [false],
13
+ "interface-name": [false],
14
+ "arrow-parens": false,
15
+ "object-literal-sort-keys": false
16
+ },
17
+ "rulesDirectory": []
18
+ }
@@ -1,26 +0,0 @@
1
- import { Model } from 'sequelize-typescript';
2
- import { LedgerTransactionModel } from '../../ledger-transaction/entities/ledger-transaction.entity';
3
- import { PaymentModel } from '../../payment/entities/payment.entity';
4
- import { DocumentItemModel } from '../../document/entities/document-item.entity';
5
- export declare class AccountModel extends Model {
6
- AccountNo: string;
7
- ParentAccountNo: string;
8
- SystemCode: string;
9
- AccSystemCode: string;
10
- AccSystemRefId: string;
11
- Name: string;
12
- Description: string;
13
- AccountType: string;
14
- AccountSubType: string;
15
- OwnerId: string;
16
- OwnerType: string;
17
- RelatedObjectId: string;
18
- RelatedObjectType: string;
19
- CreatedAt: Date;
20
- CreatedById: string;
21
- UpdatedAt: Date;
22
- UpdatedById: string;
23
- Payments: PaymentModel[];
24
- DocumentItems: DocumentItemModel[];
25
- LedgerTransactions: LedgerTransactionModel[];
26
- }