@tomei/rental 0.17.4-dev.9 → 0.17.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.
Files changed (298) hide show
  1. package/.commitlintrc.json +23 -23
  2. package/.gitlab-ci.yml +16 -16
  3. package/.husky/commit-msg +9 -9
  4. package/.husky/pre-commit +7 -7
  5. package/.prettierrc +4 -4
  6. package/Jenkinsfile +51 -51
  7. package/README.md +8 -8
  8. package/dist/ClassMappings/ItemClassMap.d.ts +4 -0
  9. package/dist/ClassMappings/ItemClassMap.js +8 -0
  10. package/dist/ClassMappings/ItemClassMap.js.map +1 -0
  11. package/dist/ClassMappings/index.d.ts +2 -0
  12. package/dist/ClassMappings/index.js +6 -0
  13. package/dist/ClassMappings/index.js.map +1 -0
  14. package/dist/components/agreement/agreement.d.ts +27 -0
  15. package/dist/components/agreement/agreement.js +120 -0
  16. package/dist/components/agreement/agreement.js.map +1 -0
  17. package/dist/components/agreement/agreement.repository.d.ts +8 -0
  18. package/dist/components/agreement/agreement.repository.js +52 -0
  19. package/dist/components/agreement/agreement.repository.js.map +1 -0
  20. package/dist/components/agreement-history/agreement-history.d.ts +17 -0
  21. package/dist/components/agreement-history/agreement-history.js +40 -0
  22. package/dist/components/agreement-history/agreement-history.js.map +1 -0
  23. package/dist/components/agreement-history/agreement-history.repository.d.ts +8 -0
  24. package/dist/components/agreement-history/agreement-history.repository.js +52 -0
  25. package/dist/components/agreement-history/agreement-history.repository.js.map +1 -0
  26. package/dist/components/agreement-signature/agreement-signature.d.ts +27 -0
  27. package/dist/components/agreement-signature/agreement-signature.js +99 -0
  28. package/dist/components/agreement-signature/agreement-signature.js.map +1 -0
  29. package/dist/components/agreement-signature/agreement-signature.repository.d.ts +8 -0
  30. package/dist/components/agreement-signature/agreement-signature.repository.js +53 -0
  31. package/dist/components/agreement-signature/agreement-signature.repository.js.map +1 -0
  32. package/dist/components/booking/booking.d.ts +46 -0
  33. package/dist/components/booking/booking.js +289 -0
  34. package/dist/components/booking/booking.js.map +1 -0
  35. package/dist/components/booking/booking.repository.d.ts +8 -0
  36. package/dist/components/booking/booking.repository.js +52 -0
  37. package/dist/components/booking/booking.repository.js.map +1 -0
  38. package/dist/components/hirer-change-request-new-hirer/hirer-change-request-new-hirer.d.ts +32 -0
  39. package/dist/components/hirer-change-request-new-hirer/hirer-change-request-new-hirer.js +106 -0
  40. package/dist/components/hirer-change-request-new-hirer/hirer-change-request-new-hirer.js.map +1 -0
  41. package/dist/components/hirer-change-request-new-hirer/hirer-change-request-new-hirer.repository.d.ts +9 -0
  42. package/dist/components/hirer-change-request-new-hirer/hirer-change-request-new-hirer.repository.js +62 -0
  43. package/dist/components/hirer-change-request-new-hirer/hirer-change-request-new-hirer.repository.js.map +1 -0
  44. package/dist/components/hirer-change-request-remove-hirer/hirer-change-request-remove-hirer.d.ts +22 -0
  45. package/dist/components/hirer-change-request-remove-hirer/hirer-change-request-remove-hirer.js +89 -0
  46. package/dist/components/hirer-change-request-remove-hirer/hirer-change-request-remove-hirer.js.map +1 -0
  47. package/dist/components/hirer-change-request-remove-hirer/hirer-change-request-remove-hirer.repository.d.ts +9 -0
  48. package/dist/components/hirer-change-request-remove-hirer/hirer-change-request-remove-hirer.repository.js +63 -0
  49. package/dist/components/hirer-change-request-remove-hirer/hirer-change-request-remove-hirer.repository.js.map +1 -0
  50. package/dist/components/hirer-change-request-signature/hirer-change-request-signature.d.ts +30 -0
  51. package/dist/components/hirer-change-request-signature/hirer-change-request-signature.js +208 -0
  52. package/dist/components/hirer-change-request-signature/hirer-change-request-signature.js.map +1 -0
  53. package/dist/components/hirer-change-request-signature/hirer-change-request-signature.repository.d.ts +9 -0
  54. package/dist/components/hirer-change-request-signature/hirer-change-request-signature.repository.js +63 -0
  55. package/dist/components/hirer-change-request-signature/hirer-change-request-signature.repository.js.map +1 -0
  56. package/dist/components/joint-hirer/joint-hirer.d.ts +26 -0
  57. package/dist/components/joint-hirer/joint-hirer.js +137 -0
  58. package/dist/components/joint-hirer/joint-hirer.js.map +1 -0
  59. package/dist/components/joint-hirer/joint-hirer.repository.d.ts +8 -0
  60. package/dist/components/joint-hirer/joint-hirer.repository.js +52 -0
  61. package/dist/components/joint-hirer/joint-hirer.repository.js.map +1 -0
  62. package/dist/components/rental/rental.d.ts +72 -0
  63. package/dist/components/rental/rental.js +844 -0
  64. package/dist/components/rental/rental.js.map +1 -0
  65. package/dist/components/rental/rental.repository.d.ts +8 -0
  66. package/dist/components/rental/rental.repository.js +52 -0
  67. package/dist/components/rental/rental.repository.js.map +1 -0
  68. package/dist/components/rental-hirer-change-request/rental-hirer-change-request.d.ts +71 -0
  69. package/dist/components/rental-hirer-change-request/rental-hirer-change-request.js +531 -0
  70. package/dist/components/rental-hirer-change-request/rental-hirer-change-request.js.map +1 -0
  71. package/dist/components/rental-hirer-change-request/rental-hirer-change-request.repository.d.ts +9 -0
  72. package/dist/components/rental-hirer-change-request/rental-hirer-change-request.repository.js +62 -0
  73. package/dist/components/rental-hirer-change-request/rental-hirer-change-request.repository.js.map +1 -0
  74. package/dist/components/rental-price/rental-price.d.ts +18 -0
  75. package/dist/components/rental-price/rental-price.js +66 -0
  76. package/dist/components/rental-price/rental-price.js.map +1 -0
  77. package/dist/components/rental-price/rental-price.repository.d.ts +8 -0
  78. package/dist/components/rental-price/rental-price.repository.js +52 -0
  79. package/dist/components/rental-price/rental-price.repository.js.map +1 -0
  80. package/dist/database.d.ts +4 -0
  81. package/dist/database.js +37 -0
  82. package/dist/database.js.map +1 -0
  83. package/dist/enum/account-type.enum.d.ts +4 -0
  84. package/dist/enum/account-type.enum.js +9 -0
  85. package/dist/enum/account-type.enum.js.map +1 -0
  86. package/dist/enum/aggrement-status.enum.d.ts +5 -0
  87. package/dist/enum/aggrement-status.enum.js +10 -0
  88. package/dist/enum/aggrement-status.enum.js.map +1 -0
  89. package/dist/enum/agreement-signature-status.enum.d.ts +4 -0
  90. package/dist/enum/agreement-signature-status.enum.js +9 -0
  91. package/dist/enum/agreement-signature-status.enum.js.map +1 -0
  92. package/dist/enum/agreement-signature-verification-method.enum.d.ts +4 -0
  93. package/dist/enum/agreement-signature-verification-method.enum.js +9 -0
  94. package/dist/enum/agreement-signature-verification-method.enum.js.map +1 -0
  95. package/dist/enum/booking.enum.d.ts +5 -0
  96. package/dist/enum/booking.enum.js +10 -0
  97. package/dist/enum/booking.enum.js.map +1 -0
  98. package/dist/enum/hirer-type.enum.d.ts +4 -0
  99. package/dist/enum/hirer-type.enum.js +9 -0
  100. package/dist/enum/hirer-type.enum.js.map +1 -0
  101. package/dist/enum/index.d.ts +11 -0
  102. package/dist/enum/index.js +24 -0
  103. package/dist/enum/index.js.map +1 -0
  104. package/dist/enum/rental-hirer-change-request-hirer-role.d.ts +4 -0
  105. package/dist/enum/rental-hirer-change-request-hirer-role.js +9 -0
  106. package/dist/enum/rental-hirer-change-request-hirer-role.js.map +1 -0
  107. package/dist/enum/rental-hirer-change-request-status.d.ts +7 -0
  108. package/dist/enum/rental-hirer-change-request-status.js +12 -0
  109. package/dist/enum/rental-hirer-change-request-status.js.map +1 -0
  110. package/dist/enum/rental-hirer-change-request-type.d.ts +4 -0
  111. package/dist/enum/rental-hirer-change-request-type.js +9 -0
  112. package/dist/enum/rental-hirer-change-request-type.js.map +1 -0
  113. package/dist/enum/rental-status.enum.d.ts +9 -0
  114. package/dist/enum/rental-status.enum.js +14 -0
  115. package/dist/enum/rental-status.enum.js.map +1 -0
  116. package/dist/interfaces/agreemeent-signature-attr.interface.d.ts +14 -0
  117. package/dist/interfaces/agreemeent-signature-attr.interface.js +3 -0
  118. package/dist/interfaces/agreemeent-signature-attr.interface.js.map +1 -0
  119. package/dist/interfaces/agreement-attr.interface.d.ts +7 -0
  120. package/dist/interfaces/agreement-attr.interface.js +3 -0
  121. package/dist/interfaces/agreement-attr.interface.js.map +1 -0
  122. package/dist/interfaces/agreement-history-attr.interface.d.ts +7 -0
  123. package/dist/interfaces/agreement-history-attr.interface.js +3 -0
  124. package/dist/interfaces/agreement-history-attr.interface.js.map +1 -0
  125. package/dist/interfaces/booking-attr.interface.d.ts +18 -0
  126. package/dist/interfaces/booking-attr.interface.js +3 -0
  127. package/dist/interfaces/booking-attr.interface.js.map +1 -0
  128. package/dist/interfaces/booking-find-all-search-attr.interface.d.ts +12 -0
  129. package/dist/interfaces/booking-find-all-search-attr.interface.js +3 -0
  130. package/dist/interfaces/booking-find-all-search-attr.interface.js.map +1 -0
  131. package/dist/interfaces/hirer-change-request-new-hirer-attr.interface.d.ts +15 -0
  132. package/dist/interfaces/hirer-change-request-new-hirer-attr.interface.js +3 -0
  133. package/dist/interfaces/hirer-change-request-new-hirer-attr.interface.js.map +1 -0
  134. package/dist/interfaces/hirer-change-request-remove-hirer-attr.interface.d.ts +5 -0
  135. package/dist/interfaces/hirer-change-request-remove-hirer-attr.interface.js +3 -0
  136. package/dist/interfaces/hirer-change-request-remove-hirer-attr.interface.js.map +1 -0
  137. package/dist/interfaces/hirer-change-request-signature-attr.interface.d.ts +14 -0
  138. package/dist/interfaces/hirer-change-request-signature-attr.interface.js +3 -0
  139. package/dist/interfaces/hirer-change-request-signature-attr.interface.js.map +1 -0
  140. package/dist/interfaces/index.d.ts +14 -0
  141. package/dist/interfaces/index.js +3 -0
  142. package/dist/interfaces/index.js.map +1 -0
  143. package/dist/interfaces/joint-hirer-attr.interface.d.ts +11 -0
  144. package/dist/interfaces/joint-hirer-attr.interface.js +3 -0
  145. package/dist/interfaces/joint-hirer-attr.interface.js.map +1 -0
  146. package/dist/interfaces/rental-attr.interface.d.ts +24 -0
  147. package/dist/interfaces/rental-attr.interface.js +3 -0
  148. package/dist/interfaces/rental-attr.interface.js.map +1 -0
  149. package/dist/interfaces/rental-find-all-search-attr.interface.d.ts +10 -0
  150. package/dist/interfaces/rental-find-all-search-attr.interface.js +3 -0
  151. package/dist/interfaces/rental-find-all-search-attr.interface.js.map +1 -0
  152. package/dist/interfaces/rental-hirer-change-request.attr.interface.d.ts +16 -0
  153. package/dist/interfaces/rental-hirer-change-request.attr.interface.js +3 -0
  154. package/dist/interfaces/rental-hirer-change-request.attr.interface.js.map +1 -0
  155. package/dist/interfaces/rental-hirer-change-request.update.interface.d.ts +4 -0
  156. package/dist/interfaces/rental-hirer-change-request.update.interface.js +3 -0
  157. package/dist/interfaces/rental-hirer-change-request.update.interface.js.map +1 -0
  158. package/dist/interfaces/rental-price-attr.interface.d.ts +7 -0
  159. package/dist/interfaces/rental-price-attr.interface.js +3 -0
  160. package/dist/interfaces/rental-price-attr.interface.js.map +1 -0
  161. package/dist/interfaces/response-hirer-signature-attr.interface.d.ts +14 -0
  162. package/dist/interfaces/response-hirer-signature-attr.interface.js +3 -0
  163. package/dist/interfaces/response-hirer-signature-attr.interface.js.map +1 -0
  164. package/dist/models/agreement-history.entity.d.ts +10 -0
  165. package/dist/models/agreement-history.entity.js +65 -0
  166. package/dist/models/agreement-history.entity.js.map +1 -0
  167. package/dist/models/agreement-signature.entity.d.ts +22 -0
  168. package/dist/models/agreement-signature.entity.js +123 -0
  169. package/dist/models/agreement-signature.entity.js.map +1 -0
  170. package/dist/models/agreement.entity.d.ts +14 -0
  171. package/dist/models/agreement.entity.js +70 -0
  172. package/dist/models/agreement.entity.js.map +1 -0
  173. package/dist/models/booking.entity.d.ts +21 -0
  174. package/dist/models/booking.entity.js +128 -0
  175. package/dist/models/booking.entity.js.map +1 -0
  176. package/dist/models/hirer-change-request-new-hirer.entity.d.ts +19 -0
  177. package/dist/models/hirer-change-request-new-hirer.entity.js +121 -0
  178. package/dist/models/hirer-change-request-new-hirer.entity.js.map +1 -0
  179. package/dist/models/hirer-change-request-remove-hirer.entity.d.ts +11 -0
  180. package/dist/models/hirer-change-request-remove-hirer.entity.js +57 -0
  181. package/dist/models/hirer-change-request-remove-hirer.entity.js.map +1 -0
  182. package/dist/models/hirer-change-request-signature.entity.d.ts +18 -0
  183. package/dist/models/hirer-change-request-signature.entity.js +101 -0
  184. package/dist/models/hirer-change-request-signature.entity.js.map +1 -0
  185. package/dist/models/index.d.ts +12 -0
  186. package/dist/models/index.js +26 -0
  187. package/dist/models/index.js.map +1 -0
  188. package/dist/models/joint-hirer.entity.d.ts +14 -0
  189. package/dist/models/joint-hirer.entity.js +91 -0
  190. package/dist/models/joint-hirer.entity.js.map +1 -0
  191. package/dist/models/rental-hirer-change-request.entity.d.ts +22 -0
  192. package/dist/models/rental-hirer-change-request.entity.js +108 -0
  193. package/dist/models/rental-hirer-change-request.entity.js.map +1 -0
  194. package/dist/models/rental-price.entity.d.ts +8 -0
  195. package/dist/models/rental-price.entity.js +59 -0
  196. package/dist/models/rental-price.entity.js.map +1 -0
  197. package/dist/models/rental.entity.d.ts +29 -0
  198. package/dist/models/rental.entity.js +160 -0
  199. package/dist/models/rental.entity.js.map +1 -0
  200. package/dist/src/components/agreement/agreement.js +9 -9
  201. package/dist/src/components/joint-hirer/joint-hirer.js +1 -1
  202. package/dist/src/components/joint-hirer/joint-hirer.js.map +1 -1
  203. package/dist/src/components/rental/rental.d.ts +2 -1
  204. package/dist/src/components/rental/rental.js +19 -17
  205. package/dist/src/components/rental/rental.js.map +1 -1
  206. package/dist/src/components/rental-hirer-change-request/rental-hirer-change-request.js.map +1 -1
  207. package/dist/src/enum/agreement-signature-verification-method.enum.d.ts +4 -0
  208. package/dist/src/enum/agreement-signature-verification-method.enum.js +9 -0
  209. package/dist/src/enum/agreement-signature-verification-method.enum.js.map +1 -0
  210. package/dist/src/enum/index.d.ts +2 -1
  211. package/dist/src/enum/index.js +3 -1
  212. package/dist/src/enum/index.js.map +1 -1
  213. package/dist/src/models/agreement-signature.entity.d.ts +4 -0
  214. package/dist/src/models/agreement-signature.entity.js +22 -0
  215. package/dist/src/models/agreement-signature.entity.js.map +1 -1
  216. package/dist/tsconfig.build.tsbuildinfo +1 -0
  217. package/dist/tsconfig.tsbuildinfo +1 -1
  218. package/eslint.config.mjs +58 -58
  219. package/jest.config.js +10 -10
  220. package/migrations/20250529092130-add-status-to-joint-hirer.js +19 -19
  221. package/migrations/agreement-signature-table-migration.js +76 -64
  222. package/migrations/booking-table-migration.js +79 -79
  223. package/migrations/hirer-change-request-new-hirer-migration.js +72 -72
  224. package/migrations/hirer-change-request-remove-hirer-migration.js +39 -39
  225. package/migrations/hirer-change-request-signature-migration.js +65 -65
  226. package/migrations/joint-hirer-table-migration.js +52 -52
  227. package/migrations/rental-aggreement-history-migration.js +41 -41
  228. package/migrations/rental-aggrement-table-migration.js +30 -30
  229. package/migrations/rental-hirer-change-request-migrations.js +64 -64
  230. package/migrations/rental-price-table-migration.js +32 -32
  231. package/migrations/rental-table-migrations.js +96 -96
  232. package/package.json +80 -80
  233. package/sonar-project.properties +12 -12
  234. package/src/ClassMappings/ItemClassMap.ts +7 -7
  235. package/src/ClassMappings/index.ts +3 -3
  236. package/src/components/agreement/agreement.repository.ts +54 -54
  237. package/src/components/agreement/agreement.ts +187 -187
  238. package/src/components/agreement-history/agreement-history.repository.ts +54 -54
  239. package/src/components/agreement-history/agreement-history.ts +57 -57
  240. package/src/components/agreement-signature/agreement-signature.repository.ts +55 -55
  241. package/src/components/agreement-signature/agreement-signature.ts +143 -143
  242. package/src/components/booking/booking.repository.ts +51 -51
  243. package/src/components/booking/booking.ts +492 -492
  244. package/src/components/hirer-change-request-new-hirer/hirer-change-request-new-hirer.repository.ts +64 -64
  245. package/src/components/hirer-change-request-new-hirer/hirer-change-request-new-hirer.ts +153 -153
  246. package/src/components/hirer-change-request-remove-hirer/hirer-change-request-remove-hirer.repository.ts +65 -65
  247. package/src/components/hirer-change-request-remove-hirer/hirer-change-request-remove-hirer.ts +134 -134
  248. package/src/components/hirer-change-request-signature/hirer-change-request-signature.repository.ts +65 -65
  249. package/src/components/hirer-change-request-signature/hirer-change-request-signature.ts +272 -272
  250. package/src/components/joint-hirer/joint-hirer.repository.ts +54 -54
  251. package/src/components/joint-hirer/joint-hirer.ts +252 -252
  252. package/src/components/rental/rental.repository.ts +51 -51
  253. package/src/components/rental/rental.ts +1466 -1461
  254. package/src/components/rental-hirer-change-request/rental-hirer-change-request.repository.ts +64 -64
  255. package/src/components/rental-hirer-change-request/rental-hirer-change-request.ts +907 -930
  256. package/src/components/rental-price/rental-price.repository.ts +54 -54
  257. package/src/components/rental-price/rental-price.ts +100 -100
  258. package/src/database.ts +39 -39
  259. package/src/enum/account-type.enum.ts +4 -4
  260. package/src/enum/agreement-signature-status.enum.ts +4 -4
  261. package/src/enum/agreement-signature-verification-method.enum.ts +4 -0
  262. package/src/enum/booking.enum.ts +5 -5
  263. package/src/enum/hirer-type.enum.ts +4 -4
  264. package/src/enum/index.ts +23 -21
  265. package/src/enum/rental-hirer-change-request-hirer-role.ts +4 -4
  266. package/src/enum/rental-hirer-change-request-status.ts +7 -7
  267. package/src/enum/rental-hirer-change-request-type.ts +4 -4
  268. package/src/enum/rental-status.enum.ts +39 -39
  269. package/src/index.ts +54 -54
  270. package/src/interfaces/agreemeent-signature-attr.interface.ts +15 -15
  271. package/src/interfaces/agreement-attr.interface.ts +7 -7
  272. package/src/interfaces/agreement-history-attr.interface.ts +7 -7
  273. package/src/interfaces/booking-attr.interface.ts +19 -19
  274. package/src/interfaces/booking-find-all-search-attr.interface.ts +12 -12
  275. package/src/interfaces/hirer-change-request-new-hirer-attr.interface.ts +15 -15
  276. package/src/interfaces/hirer-change-request-remove-hirer-attr.interface.ts +5 -5
  277. package/src/interfaces/hirer-change-request-signature-attr.interface.ts +15 -15
  278. package/src/interfaces/index.ts +29 -29
  279. package/src/interfaces/joint-hirer-attr.interface.ts +11 -11
  280. package/src/interfaces/rental-attr.interface.ts +25 -25
  281. package/src/interfaces/rental-find-all-search-attr.interface.ts +11 -11
  282. package/src/interfaces/rental-hirer-change-request.attr.interface.ts +17 -17
  283. package/src/interfaces/rental-hirer-change-request.update.interface.ts +4 -4
  284. package/src/interfaces/rental-price-attr.interface.ts +7 -7
  285. package/src/interfaces/response-hirer-signature-attr.interface.ts +15 -15
  286. package/src/models/agreement-history.entity.ts +51 -51
  287. package/src/models/agreement-signature.entity.ts +105 -86
  288. package/src/models/agreement.entity.ts +47 -47
  289. package/src/models/booking.entity.ts +105 -105
  290. package/src/models/hirer-change-request-new-hirer.entity.ts +102 -102
  291. package/src/models/hirer-change-request-remove-hirer.entity.ts +47 -47
  292. package/src/models/hirer-change-request-signature.entity.ts +86 -86
  293. package/src/models/index.ts +25 -25
  294. package/src/models/joint-hirer.entity.ts +70 -70
  295. package/src/models/rental-price.entity.ts +38 -38
  296. package/src/models/rental.entity.ts +133 -133
  297. package/tsconfig.build.json +5 -5
  298. package/tsconfig.json +24 -24
@@ -1,187 +1,187 @@
1
- import { ClassError, ObjectBase } from '@tomei/general';
2
- import { AggrementStatusEnum } from '../../enum/aggrement-status.enum';
3
- import { IAgreementAttr } from '../../interfaces/agreement-attr.interface';
4
- import { AgreementRepository } from './agreement.repository';
5
- import { ApplicationConfig } from '@tomei/config';
6
- import { LoginUser } from '@tomei/sso';
7
- import { AgreementSignatureRepository } from '../agreement-signature/agreement-signature.repository';
8
- import * as rentalDb from '../../database';
9
- import { QueryTypes, where } from 'sequelize';
10
- import { IResponseAgreementSignature } from '../../interfaces/response-hirer-signature-attr.interface';
11
- import { AgreementHistoryRepository } from '../agreement-history/agreement-history.repository';
12
- import { IAgreementHistoryAttr } from '../../interfaces/agreement-history-attr.interface';
13
- import { ActionEnum, Activity } from '@tomei/activity-history';
14
-
15
- export class Agreement extends ObjectBase {
16
- ObjectId: string;
17
- ObjectName: string;
18
- ObjectType: string = 'Agreement';
19
- TableName = 'rental_Agreement';
20
- Status: AggrementStatusEnum;
21
- DateSigned: Date;
22
- MediaId: string;
23
-
24
- private static _Repo = new AgreementRepository();
25
- protected static _AgreementSignatureRepo = new AgreementSignatureRepository();
26
- protected static _AgreementHistoryRepo = new AgreementHistoryRepository();
27
-
28
- get AgreementNo(): string {
29
- return this.ObjectId;
30
- }
31
-
32
- set AgreementNo(value: string) {
33
- this.ObjectId = value;
34
- }
35
-
36
- protected constructor(agreementAttr?: IAgreementAttr) {
37
- super();
38
- if (agreementAttr) {
39
- this.ObjectId = agreementAttr.AgreementNo;
40
- this.Status = agreementAttr.Status;
41
- this.DateSigned = agreementAttr.DateSigned;
42
- this.MediaId = agreementAttr.MediaId;
43
- }
44
- }
45
-
46
- public static async init(
47
- agreementNo?: string,
48
- dbTransaction?: any,
49
- ): Promise<Agreement> {
50
- try {
51
- if (agreementNo) {
52
- const agreement = await this._Repo.findByPk(agreementNo, dbTransaction);
53
- return new Agreement(agreement?.get({ plain: true }));
54
- }
55
- return new Agreement();
56
- } catch (error) {
57
- throw error;
58
- }
59
- }
60
-
61
- public static async getSignatureList(
62
- loginUser: LoginUser,
63
- agreementNo: string,
64
- dbTransaction: any,
65
- ) {
66
- try {
67
- // Part 1: Privilege Checking
68
- // Call loginUser.checkPrivileges() by passing:
69
- // SystemCode: "<get_from_app_config>"
70
- // PrivilegeCode: "AGREEMENT_SIGNATURE_LIST"
71
- const systemCode =
72
- ApplicationConfig.getComponentConfigValue('system-code');
73
- const isPrivileged = loginUser.checkPrivileges(
74
- systemCode,
75
- 'AGREEMENT_SIGNATURE_LIST',
76
- );
77
-
78
- if (!isPrivileged) {
79
- throw new ClassError(
80
- 'Agreement',
81
- 'AgreementErrMsg01',
82
- "You do not have 'AGREEMENT_SIGNATURE_LIST' privilege.",
83
- );
84
- }
85
-
86
- // Part 2: Validation
87
- // Make sure agreementNo exists, if not throw new ClassError by passing:
88
- if (!agreementNo) {
89
- throw new ClassError(
90
- 'AgreementNo',
91
- 'AgreementNoErrMsg01',
92
- 'AgreementNo is missing',
93
- );
94
- }
95
-
96
- // Part 3: Retrieve Listing
97
- const query = `
98
- SELECT
99
- hs.*
100
- FROM
101
- rental_AgreementSignature hs
102
- WHERE
103
- hs.AgreementNo = '${agreementNo}'
104
- ORDER BY
105
- hs.CreatedAt ASC
106
- `;
107
-
108
- const db = rentalDb.getConnection();
109
-
110
- const signatures: IResponseAgreementSignature[] = await db.query(query, {
111
- type: QueryTypes.SELECT,
112
- transaction: dbTransaction,
113
- });
114
-
115
- return signatures;
116
- } catch (error) {
117
- throw error;
118
- }
119
- }
120
-
121
- async getAllActivities(
122
- loginUser: LoginUser,
123
- dbTransaction?: any,
124
- ): Promise<IAgreementHistoryAttr[]> {
125
- try {
126
- const systemCode =
127
- ApplicationConfig.getComponentConfigValue('system-code');
128
- const isPrivileged = loginUser.checkPrivileges(
129
- systemCode,
130
- 'RENTAL_AGREEMENT_VIEW',
131
- );
132
-
133
- if (!isPrivileged) {
134
- throw new ClassError(
135
- 'Agreement',
136
- 'AgreementErrMsg02',
137
- "You do not have 'RENTAL_AGREEMENT_VIEW' privilege.",
138
- );
139
- }
140
-
141
- const activities = await Agreement._AgreementHistoryRepo.findAll({
142
- where: { AgreementNo: this.ObjectId },
143
- order: [['CreatedAt', 'DESC']],
144
- transaction: dbTransaction,
145
- });
146
- return activities;
147
- } catch (error) {
148
- throw error;
149
- }
150
- }
151
-
152
- async createActivity(
153
- activityCompleted: string,
154
- MediaId: string,
155
- dbTransaction: any,
156
- loginUser: LoginUser,
157
- ): Promise<IAgreementHistoryAttr> {
158
- try {
159
- const activity = await Agreement._AgreementHistoryRepo.create(
160
- {
161
- AgreementNo: this.ObjectId,
162
- MediaId: MediaId,
163
- ActivityCompleted: activityCompleted,
164
- CreatedAt: new Date(),
165
- },
166
- {
167
- transaction: dbTransaction,
168
- },
169
- );
170
-
171
- const entityValueAfter = activity.get({ plain: true });
172
- const activityHistory = new Activity();
173
- activityHistory.ActivityId = entityValueAfter.HistoryId;
174
- activityHistory.Action = ActionEnum.CREATE;
175
- activityHistory.Description = activityCompleted;
176
- activityHistory.EntityId = activity.HistoryId.toString();
177
- activityHistory.EntityType = 'RentalAgreementHistory';
178
- activityHistory.EntityValueBefore = JSON.stringify({});
179
- activityHistory.EntityValueAfter = JSON.stringify(entityValueAfter);
180
- await activityHistory.create(loginUser.ObjectId, dbTransaction);
181
-
182
- return activity;
183
- } catch (error) {
184
- throw error;
185
- }
186
- }
187
- }
1
+ import { ClassError, ObjectBase } from '@tomei/general';
2
+ import { AggrementStatusEnum } from '../../enum/aggrement-status.enum';
3
+ import { IAgreementAttr } from '../../interfaces/agreement-attr.interface';
4
+ import { AgreementRepository } from './agreement.repository';
5
+ import { ApplicationConfig } from '@tomei/config';
6
+ import { LoginUser } from '@tomei/sso';
7
+ import { AgreementSignatureRepository } from '../agreement-signature/agreement-signature.repository';
8
+ import * as rentalDb from '../../database';
9
+ import { QueryTypes, where } from 'sequelize';
10
+ import { IResponseAgreementSignature } from '../../interfaces/response-hirer-signature-attr.interface';
11
+ import { AgreementHistoryRepository } from '../agreement-history/agreement-history.repository';
12
+ import { IAgreementHistoryAttr } from '../../interfaces/agreement-history-attr.interface';
13
+ import { ActionEnum, Activity } from '@tomei/activity-history';
14
+
15
+ export class Agreement extends ObjectBase {
16
+ ObjectId: string;
17
+ ObjectName: string;
18
+ ObjectType: string = 'Agreement';
19
+ TableName = 'rental_Agreement';
20
+ Status: AggrementStatusEnum;
21
+ DateSigned: Date;
22
+ MediaId: string;
23
+
24
+ private static _Repo = new AgreementRepository();
25
+ protected static _AgreementSignatureRepo = new AgreementSignatureRepository();
26
+ protected static _AgreementHistoryRepo = new AgreementHistoryRepository();
27
+
28
+ get AgreementNo(): string {
29
+ return this.ObjectId;
30
+ }
31
+
32
+ set AgreementNo(value: string) {
33
+ this.ObjectId = value;
34
+ }
35
+
36
+ protected constructor(agreementAttr?: IAgreementAttr) {
37
+ super();
38
+ if (agreementAttr) {
39
+ this.ObjectId = agreementAttr.AgreementNo;
40
+ this.Status = agreementAttr.Status;
41
+ this.DateSigned = agreementAttr.DateSigned;
42
+ this.MediaId = agreementAttr.MediaId;
43
+ }
44
+ }
45
+
46
+ public static async init(
47
+ agreementNo?: string,
48
+ dbTransaction?: any,
49
+ ): Promise<Agreement> {
50
+ try {
51
+ if (agreementNo) {
52
+ const agreement = await this._Repo.findByPk(agreementNo, dbTransaction);
53
+ return new Agreement(agreement?.get({ plain: true }));
54
+ }
55
+ return new Agreement();
56
+ } catch (error) {
57
+ throw error;
58
+ }
59
+ }
60
+
61
+ public static async getSignatureList(
62
+ loginUser: LoginUser,
63
+ agreementNo: string,
64
+ dbTransaction: any,
65
+ ) {
66
+ try {
67
+ // Part 1: Privilege Checking
68
+ // Call loginUser.checkPrivileges() by passing:
69
+ // SystemCode: "<get_from_app_config>"
70
+ // PrivilegeCode: "AGREEMENT_SIGNATURE_LIST"
71
+ const systemCode =
72
+ ApplicationConfig.getComponentConfigValue('system-code');
73
+ const isPrivileged = loginUser.checkPrivileges(
74
+ systemCode,
75
+ 'AGREEMENT_SIGNATURE_LIST',
76
+ );
77
+
78
+ if (!isPrivileged) {
79
+ throw new ClassError(
80
+ 'Agreement',
81
+ 'AgreementErrMsg01',
82
+ "You do not have 'AGREEMENT_SIGNATURE_LIST' privilege.",
83
+ );
84
+ }
85
+
86
+ // Part 2: Validation
87
+ // Make sure agreementNo exists, if not throw new ClassError by passing:
88
+ if (!agreementNo) {
89
+ throw new ClassError(
90
+ 'AgreementNo',
91
+ 'AgreementNoErrMsg01',
92
+ 'AgreementNo is missing',
93
+ );
94
+ }
95
+
96
+ // Part 3: Retrieve Listing
97
+ const query = `
98
+ SELECT
99
+ hs.*
100
+ FROM
101
+ rental_AgreementSignature hs
102
+ WHERE
103
+ hs.AgreementNo = '${agreementNo}'
104
+ ORDER BY
105
+ hs.CreatedAt ASC
106
+ `;
107
+
108
+ const db = rentalDb.getConnection();
109
+
110
+ const signatures: IResponseAgreementSignature[] = await db.query(query, {
111
+ type: QueryTypes.SELECT,
112
+ transaction: dbTransaction,
113
+ });
114
+
115
+ return signatures;
116
+ } catch (error) {
117
+ throw error;
118
+ }
119
+ }
120
+
121
+ async getAllActivities(
122
+ loginUser: LoginUser,
123
+ dbTransaction?: any,
124
+ ): Promise<IAgreementHistoryAttr[]> {
125
+ try {
126
+ const systemCode =
127
+ ApplicationConfig.getComponentConfigValue('system-code');
128
+ const isPrivileged = loginUser.checkPrivileges(
129
+ systemCode,
130
+ 'RENTAL_AGREEMENT_VIEW',
131
+ );
132
+
133
+ if (!isPrivileged) {
134
+ throw new ClassError(
135
+ 'Agreement',
136
+ 'AgreementErrMsg02',
137
+ "You do not have 'RENTAL_AGREEMENT_VIEW' privilege.",
138
+ );
139
+ }
140
+
141
+ const activities = await Agreement._AgreementHistoryRepo.findAll({
142
+ where: { AgreementNo: this.ObjectId },
143
+ order: [['CreatedAt', 'DESC']],
144
+ transaction: dbTransaction,
145
+ });
146
+ return activities;
147
+ } catch (error) {
148
+ throw error;
149
+ }
150
+ }
151
+
152
+ async createActivity(
153
+ activityCompleted: string,
154
+ MediaId: string,
155
+ dbTransaction: any,
156
+ loginUser: LoginUser,
157
+ ): Promise<IAgreementHistoryAttr> {
158
+ try {
159
+ const activity = await Agreement._AgreementHistoryRepo.create(
160
+ {
161
+ AgreementNo: this.ObjectId,
162
+ MediaId: MediaId,
163
+ ActivityCompleted: activityCompleted,
164
+ CreatedAt: new Date(),
165
+ },
166
+ {
167
+ transaction: dbTransaction,
168
+ },
169
+ );
170
+
171
+ const entityValueAfter = activity.get({ plain: true });
172
+ const activityHistory = new Activity();
173
+ activityHistory.ActivityId = entityValueAfter.HistoryId;
174
+ activityHistory.Action = ActionEnum.CREATE;
175
+ activityHistory.Description = activityCompleted;
176
+ activityHistory.EntityId = activity.HistoryId.toString();
177
+ activityHistory.EntityType = 'RentalAgreementHistory';
178
+ activityHistory.EntityValueBefore = JSON.stringify({});
179
+ activityHistory.EntityValueAfter = JSON.stringify(entityValueAfter);
180
+ await activityHistory.create(loginUser.ObjectId, dbTransaction);
181
+
182
+ return activity;
183
+ } catch (error) {
184
+ throw error;
185
+ }
186
+ }
187
+ }
@@ -1,54 +1,54 @@
1
- import { RepositoryBase, IRepositoryBase } from '@tomei/general';
2
- import { AgreementHistoryModel } from '../../models/agreement-history.entity';
3
-
4
- export class AgreementHistoryRepository
5
- extends RepositoryBase<AgreementHistoryModel>
6
- implements IRepositoryBase<AgreementHistoryModel>
7
- {
8
- constructor() {
9
- super(AgreementHistoryModel);
10
- }
11
-
12
- async findByPk(
13
- id: string,
14
- transaction?: any,
15
- ): Promise<AgreementHistoryModel | null> {
16
- try {
17
- const result = await AgreementHistoryModel.findByPk(parseInt(id), {
18
- transaction: transaction,
19
- });
20
-
21
- return result;
22
- } catch (error) {
23
- throw new Error(`An Error occured when fetching : ${error.message}`);
24
- }
25
- }
26
-
27
- async delete(AgreementNo: string, dbTransaction?: any) {
28
- try {
29
- const options = {
30
- where: {
31
- AgreementNo,
32
- },
33
- transaction: dbTransaction,
34
- };
35
- await AgreementHistoryModel.destroy(options);
36
- } catch (error) {
37
- throw new Error(`An Error occured when delete : ${error.message}`);
38
- }
39
- }
40
-
41
- async findAndCountAll(options?: any) {
42
- try {
43
- let Agreements: any;
44
- if (options) {
45
- Agreements = await AgreementHistoryModel.findAndCountAll(options);
46
- } else {
47
- Agreements = await AgreementHistoryModel.findAndCountAll();
48
- }
49
- return Agreements;
50
- } catch (error) {
51
- throw new Error(`An Error occured when retriving : ${error.message}`);
52
- }
53
- }
54
- }
1
+ import { RepositoryBase, IRepositoryBase } from '@tomei/general';
2
+ import { AgreementHistoryModel } from '../../models/agreement-history.entity';
3
+
4
+ export class AgreementHistoryRepository
5
+ extends RepositoryBase<AgreementHistoryModel>
6
+ implements IRepositoryBase<AgreementHistoryModel>
7
+ {
8
+ constructor() {
9
+ super(AgreementHistoryModel);
10
+ }
11
+
12
+ async findByPk(
13
+ id: string,
14
+ transaction?: any,
15
+ ): Promise<AgreementHistoryModel | null> {
16
+ try {
17
+ const result = await AgreementHistoryModel.findByPk(parseInt(id), {
18
+ transaction: transaction,
19
+ });
20
+
21
+ return result;
22
+ } catch (error) {
23
+ throw new Error(`An Error occured when fetching : ${error.message}`);
24
+ }
25
+ }
26
+
27
+ async delete(AgreementNo: string, dbTransaction?: any) {
28
+ try {
29
+ const options = {
30
+ where: {
31
+ AgreementNo,
32
+ },
33
+ transaction: dbTransaction,
34
+ };
35
+ await AgreementHistoryModel.destroy(options);
36
+ } catch (error) {
37
+ throw new Error(`An Error occured when delete : ${error.message}`);
38
+ }
39
+ }
40
+
41
+ async findAndCountAll(options?: any) {
42
+ try {
43
+ let Agreements: any;
44
+ if (options) {
45
+ Agreements = await AgreementHistoryModel.findAndCountAll(options);
46
+ } else {
47
+ Agreements = await AgreementHistoryModel.findAndCountAll();
48
+ }
49
+ return Agreements;
50
+ } catch (error) {
51
+ throw new Error(`An Error occured when retriving : ${error.message}`);
52
+ }
53
+ }
54
+ }
@@ -1,57 +1,57 @@
1
- import { ObjectBase } from '@tomei/general';
2
- import { AgreementHistoryRepository } from './agreement-history.repository';
3
- import { AggrementStatusEnum } from '../../enum/aggrement-status.enum';
4
- import { IAgreementHistoryAttr } from '../../interfaces/agreement-history-attr.interface';
5
-
6
- export class AgreementHistory
7
- extends ObjectBase
8
- implements IAgreementHistoryAttr
9
- {
10
- ObjectId: string;
11
- ObjectName: string;
12
- ObjectType: string = 'AgreementHistory';
13
- TableName = 'rental_AgreementHistory';
14
- AgreementNo: string;
15
- ActivityCompleted: string;
16
- MediaId: string;
17
- CreatedAt: Date;
18
-
19
- private static _Repo = new AgreementHistoryRepository();
20
-
21
- get HistoryId(): number {
22
- return parseInt(this.ObjectId);
23
- }
24
-
25
- set HistoryId(value: number) {
26
- this.ObjectId = value.toString();
27
- }
28
-
29
- protected constructor(agreementAttr?: IAgreementHistoryAttr) {
30
- super();
31
- if (agreementAttr) {
32
- this.HistoryId = agreementAttr.HistoryId;
33
- this.AgreementNo = agreementAttr.AgreementNo;
34
- this.ActivityCompleted = agreementAttr.ActivityCompleted;
35
- this.MediaId = agreementAttr.MediaId;
36
- this.CreatedAt = agreementAttr.CreatedAt;
37
- }
38
- }
39
-
40
- public static async init(
41
- historyId: number,
42
- dbTransaction?: any,
43
- ): Promise<AgreementHistory> {
44
- try {
45
- if (historyId) {
46
- const ah = await this._Repo.findByPk(
47
- historyId.toString(),
48
- dbTransaction,
49
- );
50
- return new AgreementHistory(ah?.get({ plain: true }));
51
- }
52
- return new AgreementHistory();
53
- } catch (error) {
54
- throw error;
55
- }
56
- }
57
- }
1
+ import { ObjectBase } from '@tomei/general';
2
+ import { AgreementHistoryRepository } from './agreement-history.repository';
3
+ import { AggrementStatusEnum } from '../../enum/aggrement-status.enum';
4
+ import { IAgreementHistoryAttr } from '../../interfaces/agreement-history-attr.interface';
5
+
6
+ export class AgreementHistory
7
+ extends ObjectBase
8
+ implements IAgreementHistoryAttr
9
+ {
10
+ ObjectId: string;
11
+ ObjectName: string;
12
+ ObjectType: string = 'AgreementHistory';
13
+ TableName = 'rental_AgreementHistory';
14
+ AgreementNo: string;
15
+ ActivityCompleted: string;
16
+ MediaId: string;
17
+ CreatedAt: Date;
18
+
19
+ private static _Repo = new AgreementHistoryRepository();
20
+
21
+ get HistoryId(): number {
22
+ return parseInt(this.ObjectId);
23
+ }
24
+
25
+ set HistoryId(value: number) {
26
+ this.ObjectId = value.toString();
27
+ }
28
+
29
+ protected constructor(agreementAttr?: IAgreementHistoryAttr) {
30
+ super();
31
+ if (agreementAttr) {
32
+ this.HistoryId = agreementAttr.HistoryId;
33
+ this.AgreementNo = agreementAttr.AgreementNo;
34
+ this.ActivityCompleted = agreementAttr.ActivityCompleted;
35
+ this.MediaId = agreementAttr.MediaId;
36
+ this.CreatedAt = agreementAttr.CreatedAt;
37
+ }
38
+ }
39
+
40
+ public static async init(
41
+ historyId: number,
42
+ dbTransaction?: any,
43
+ ): Promise<AgreementHistory> {
44
+ try {
45
+ if (historyId) {
46
+ const ah = await this._Repo.findByPk(
47
+ historyId.toString(),
48
+ dbTransaction,
49
+ );
50
+ return new AgreementHistory(ah?.get({ plain: true }));
51
+ }
52
+ return new AgreementHistory();
53
+ } catch (error) {
54
+ throw error;
55
+ }
56
+ }
57
+ }