@kipicore/dbcore 1.1.32 → 1.1.34

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 (220) hide show
  1. package/dist/models/psql/SubCategoriesModel.d.ts +1 -0
  2. package/dist/models/psql/SubCategoriesModel.js +60 -63
  3. package/dist/models/psql/academicCalendarModel.d.ts +2 -3
  4. package/dist/models/psql/academicCalendarModel.js +45 -42
  5. package/dist/models/psql/accountHasReceiptDetailsModel.d.ts +6 -5
  6. package/dist/models/psql/accountHasReceiptDetailsModel.js +47 -68
  7. package/dist/models/psql/announcementModel.d.ts +10 -8
  8. package/dist/models/psql/announcementModel.js +90 -109
  9. package/dist/models/psql/areaModel.d.ts +5 -1
  10. package/dist/models/psql/areaModel.js +13 -12
  11. package/dist/models/psql/bankAccountDetailsModel.d.ts +6 -5
  12. package/dist/models/psql/bankAccountDetailsModel.js +25 -37
  13. package/dist/models/psql/bannerModel.d.ts +18 -18
  14. package/dist/models/psql/bannerModel.js +53 -81
  15. package/dist/models/psql/batchModel.d.ts +3 -1
  16. package/dist/models/psql/batchModel.js +77 -135
  17. package/dist/models/psql/batchSubjectBookAssessmentModel.d.ts +2 -1
  18. package/dist/models/psql/batchSubjectBookAssessmentModel.js +57 -104
  19. package/dist/models/psql/batchSubjectProjectAssessmentModel.d.ts +2 -1
  20. package/dist/models/psql/batchSubjectProjectAssessmentModel.js +59 -92
  21. package/dist/models/psql/bookAssessmentDateModel.d.ts +2 -1
  22. package/dist/models/psql/bookAssessmentDateModel.js +26 -46
  23. package/dist/models/psql/categoriesModel.d.ts +2 -1
  24. package/dist/models/psql/categoriesModel.js +25 -45
  25. package/dist/models/psql/cityModel.d.ts +2 -1
  26. package/dist/models/psql/cityModel.js +21 -33
  27. package/dist/models/psql/classRoomModel.d.ts +2 -1
  28. package/dist/models/psql/classRoomModel.js +41 -67
  29. package/dist/models/psql/cloudStorageModel.d.ts +2 -1
  30. package/dist/models/psql/cloudStorageModel.js +18 -29
  31. package/dist/models/psql/coinPurchaseOfferModel.d.ts +5 -4
  32. package/dist/models/psql/coinPurchaseOfferModel.js +18 -29
  33. package/dist/models/psql/contactFeedBackModel.d.ts +2 -1
  34. package/dist/models/psql/contactFeedBackModel.js +49 -62
  35. package/dist/models/psql/countryModel.d.ts +1 -1
  36. package/dist/models/psql/countryModel.js +2 -0
  37. package/dist/models/psql/courseHasVisitorsModel.d.ts +2 -1
  38. package/dist/models/psql/courseHasVisitorsModel.js +25 -38
  39. package/dist/models/psql/courseModel.d.ts +2 -1
  40. package/dist/models/psql/courseModel.js +41 -56
  41. package/dist/models/psql/driverModel.d.ts +3 -1
  42. package/dist/models/psql/driverModel.js +61 -65
  43. package/dist/models/psql/entityGroupModel.d.ts +2 -1
  44. package/dist/models/psql/entityGroupModel.js +25 -45
  45. package/dist/models/psql/facilityModel.d.ts +3 -1
  46. package/dist/models/psql/facilityModel.js +63 -73
  47. package/dist/models/psql/featureActionModel.d.ts +3 -2
  48. package/dist/models/psql/featureActionModel.js +21 -36
  49. package/dist/models/psql/feeHistoryDetailsModel.d.ts +2 -1
  50. package/dist/models/psql/feeHistoryDetailsModel.js +65 -106
  51. package/dist/models/psql/feeHistoryModel.d.ts +4 -2
  52. package/dist/models/psql/feeHistoryModel.js +154 -309
  53. package/dist/models/psql/feeReminderModel.d.ts +2 -0
  54. package/dist/models/psql/feeReminderModel.js +147 -179
  55. package/dist/models/psql/feeReminderSettingModel.d.ts +1 -0
  56. package/dist/models/psql/feeReminderSettingModel.js +23 -47
  57. package/dist/models/psql/feeTypeHasTermsModel.d.ts +1 -0
  58. package/dist/models/psql/feeTypeHasTermsModel.js +48 -51
  59. package/dist/models/psql/feeTypeModel.d.ts +1 -0
  60. package/dist/models/psql/feeTypeModel.js +44 -72
  61. package/dist/models/psql/feesCollectionModel.d.ts +2 -0
  62. package/dist/models/psql/feesCollectionModel.js +112 -144
  63. package/dist/models/psql/fileStorageModel.d.ts +1 -0
  64. package/dist/models/psql/fileStorageModel.js +27 -29
  65. package/dist/models/psql/floorManagementModel.d.ts +1 -0
  66. package/dist/models/psql/floorManagementModel.js +23 -42
  67. package/dist/models/psql/greetingsModel.d.ts +3 -2
  68. package/dist/models/psql/greetingsModel.js +64 -66
  69. package/dist/models/psql/homeWorkModel.d.ts +1 -0
  70. package/dist/models/psql/homeWorkModel.js +40 -70
  71. package/dist/models/psql/index.js +7 -6
  72. package/dist/models/psql/instituteEntityModel.d.ts +1 -0
  73. package/dist/models/psql/instituteEntityModel.js +59 -62
  74. package/dist/models/psql/instituteEntityTypeModel.d.ts +1 -0
  75. package/dist/models/psql/instituteEntityTypeModel.js +15 -28
  76. package/dist/models/psql/instituteModel.d.ts +1 -0
  77. package/dist/models/psql/instituteModel.js +66 -185
  78. package/dist/models/psql/instituteSubscriptionPlanModel.d.ts +1 -0
  79. package/dist/models/psql/instituteSubscriptionPlanModel.js +40 -81
  80. package/dist/models/psql/inventoryHistoryModel.d.ts +1 -0
  81. package/dist/models/psql/inventoryHistoryModel.js +39 -79
  82. package/dist/models/psql/inventoryModel.d.ts +1 -0
  83. package/dist/models/psql/inventoryModel.js +31 -62
  84. package/dist/models/psql/lectureHistoryModel.d.ts +1 -0
  85. package/dist/models/psql/lectureHistoryModel.js +65 -196
  86. package/dist/models/psql/lectureModel.d.ts +2 -0
  87. package/dist/models/psql/lectureModel.js +191 -454
  88. package/dist/models/psql/masterLeaveModel.d.ts +2 -0
  89. package/dist/models/psql/masterLeaveModel.js +71 -71
  90. package/dist/models/psql/moduleFeatureModel.d.ts +1 -0
  91. package/dist/models/psql/moduleFeatureModel.js +41 -44
  92. package/dist/models/psql/moduleModel.d.ts +1 -0
  93. package/dist/models/psql/moduleModel.js +48 -52
  94. package/dist/models/psql/offerModel.d.ts +1 -0
  95. package/dist/models/psql/offerModel.js +43 -64
  96. package/dist/models/psql/paymentTermsModel.d.ts +1 -0
  97. package/dist/models/psql/paymentTermsModel.js +43 -45
  98. package/dist/models/psql/pdcChequeModel.d.ts +1 -0
  99. package/dist/models/psql/pdcChequeModel.js +59 -64
  100. package/dist/models/psql/pdcHistoryModel.d.ts +1 -0
  101. package/dist/models/psql/pdcHistoryModel.js +55 -73
  102. package/dist/models/psql/pincodeModel.d.ts +1 -0
  103. package/dist/models/psql/pincodeModel.js +6 -9
  104. package/dist/models/psql/productModel.d.ts +1 -0
  105. package/dist/models/psql/productModel.js +40 -80
  106. package/dist/models/psql/projectAssessmentOptionModel.d.ts +1 -0
  107. package/dist/models/psql/projectAssessmentOptionModel.js +23 -45
  108. package/dist/models/psql/roleModel.d.ts +1 -0
  109. package/dist/models/psql/roleModel.js +15 -38
  110. package/dist/models/psql/rulesRegulationModel.d.ts +3 -2
  111. package/dist/models/psql/rulesRegulationModel.js +20 -33
  112. package/dist/models/psql/schoolFeeCollectionModel.d.ts +1 -0
  113. package/dist/models/psql/schoolFeeCollectionModel.js +47 -94
  114. package/dist/models/psql/schoolOfferModel.d.ts +1 -0
  115. package/dist/models/psql/schoolOfferModel.js +39 -78
  116. package/dist/models/psql/sendNotificationModel.d.ts +1 -0
  117. package/dist/models/psql/sendNotificationModel.js +37 -61
  118. package/dist/models/psql/slotModel.d.ts +2 -0
  119. package/dist/models/psql/slotModel.js +46 -58
  120. package/dist/models/psql/stateModel.d.ts +1 -0
  121. package/dist/models/psql/stateModel.js +17 -18
  122. package/dist/models/psql/subjectHasFeeModel.d.ts +1 -0
  123. package/dist/models/psql/subjectHasFeeModel.js +49 -46
  124. package/dist/models/psql/subjectHasPayFeeHistoryModel.d.ts +1 -0
  125. package/dist/models/psql/subjectHasPayFeeHistoryModel.js +74 -69
  126. package/dist/models/psql/syllabusModel.d.ts +1 -0
  127. package/dist/models/psql/syllabusModel.js +72 -85
  128. package/dist/models/psql/testimonialModel.d.ts +2 -0
  129. package/dist/models/psql/testimonialModel.js +97 -100
  130. package/dist/models/psql/toDoModel.d.ts +2 -0
  131. package/dist/models/psql/toDoModel.js +64 -64
  132. package/dist/models/psql/tripModel.d.ts +1 -0
  133. package/dist/models/psql/tripModel.js +51 -55
  134. package/dist/models/psql/typeManagementModel.d.ts +2 -0
  135. package/dist/models/psql/typeManagementModel.js +69 -69
  136. package/dist/models/psql/userBookAssessmentModel.d.ts +1 -0
  137. package/dist/models/psql/userBookAssessmentModel.js +83 -89
  138. package/dist/models/psql/userFeeTypeByAccountModel.d.ts +1 -0
  139. package/dist/models/psql/userFeeTypeByAccountModel.js +117 -122
  140. package/dist/models/psql/userFeeTypeModel.d.ts +1 -0
  141. package/dist/models/psql/userFeeTypeModel.js +97 -102
  142. package/dist/models/psql/userHasAnnouncementModel.d.ts +1 -0
  143. package/dist/models/psql/userHasAnnouncementModel.js +63 -66
  144. package/dist/models/psql/userHasBatchModel.d.ts +1 -0
  145. package/dist/models/psql/userHasBatchModel.js +55 -57
  146. package/dist/models/psql/userHasCourseModel.d.ts +1 -0
  147. package/dist/models/psql/userHasCourseModel.js +51 -55
  148. package/dist/models/psql/userHasDeviceModel.d.ts +1 -0
  149. package/dist/models/psql/userHasDeviceModel.js +35 -38
  150. package/dist/models/psql/userHasFeeTermsModel.d.ts +1 -0
  151. package/dist/models/psql/userHasFeeTermsModel.js +51 -117
  152. package/dist/models/psql/userHasFileModel.d.ts +1 -0
  153. package/dist/models/psql/userHasFileModel.js +33 -61
  154. package/dist/models/psql/userHasHomeWorkModel.d.ts +9 -6
  155. package/dist/models/psql/userHasHomeWorkModel.js +50 -72
  156. package/dist/models/psql/userHasInventoryHistoryModel.d.ts +5 -4
  157. package/dist/models/psql/userHasInventoryHistoryModel.js +42 -59
  158. package/dist/models/psql/userHasInventoryModel.d.ts +5 -4
  159. package/dist/models/psql/userHasInventoryModel.js +30 -54
  160. package/dist/models/psql/userHasLeaveHistoryModel.d.ts +5 -4
  161. package/dist/models/psql/userHasLeaveHistoryModel.js +21 -36
  162. package/dist/models/psql/userHasLeaveModel.d.ts +6 -5
  163. package/dist/models/psql/userHasLeaveModel.js +47 -68
  164. package/dist/models/psql/userHasOfferModel.d.ts +8 -7
  165. package/dist/models/psql/userHasOfferModel.js +54 -109
  166. package/dist/models/psql/userHasParentModel.d.ts +7 -5
  167. package/dist/models/psql/userHasParentModel.js +38 -65
  168. package/dist/models/psql/userHasRoleModel.d.ts +6 -5
  169. package/dist/models/psql/userHasRoleModel.js +27 -56
  170. package/dist/models/psql/userHasRollNumberModel.d.ts +5 -4
  171. package/dist/models/psql/userHasRollNumberModel.js +39 -54
  172. package/dist/models/psql/userHasStorageModel.d.ts +5 -4
  173. package/dist/models/psql/userHasStorageModel.js +31 -35
  174. package/dist/models/psql/userHasSubjectFeeModel.d.ts +5 -4
  175. package/dist/models/psql/userHasSubjectFeeModel.js +32 -47
  176. package/dist/models/psql/userLeaveRequestModel.d.ts +6 -5
  177. package/dist/models/psql/userLeaveRequestModel.js +24 -40
  178. package/dist/models/psql/userModel.d.ts +2 -2
  179. package/dist/models/psql/userModel.js +174 -370
  180. package/dist/models/psql/userPayoutDetailsModel.d.ts +1 -0
  181. package/dist/models/psql/userPayoutDetailsModel.js +65 -146
  182. package/dist/models/psql/userPayoutHistoryModel.d.ts +1 -0
  183. package/dist/models/psql/userPayoutHistoryModel.js +39 -66
  184. package/dist/models/psql/userPayoutModel.d.ts +2 -0
  185. package/dist/models/psql/userPayoutModel.js +205 -240
  186. package/dist/models/psql/userProjectAssessmentOptionModel.d.ts +1 -0
  187. package/dist/models/psql/userProjectAssessmentOptionModel.js +39 -74
  188. package/dist/models/psql/userRequiredStepsModel.d.ts +1 -0
  189. package/dist/models/psql/userRequiredStepsModel.js +23 -36
  190. package/dist/models/psql/vehicleModel.d.ts +1 -0
  191. package/dist/models/psql/vehicleModel.js +27 -53
  192. package/dist/models/psql/vendorManagementModel.d.ts +6 -5
  193. package/dist/models/psql/vendorManagementModel.js +48 -97
  194. package/dist/models/psql/walletHistoryModel.d.ts +2 -1
  195. package/dist/models/psql/walletHistoryModel.js +31 -33
  196. package/dist/models/psql/walletModel.d.ts +2 -1
  197. package/dist/models/psql/walletModel.js +28 -46
  198. package/dist/models/psql/workingDayModel.d.ts +3 -2
  199. package/dist/models/psql/workingDayModel.js +18 -31
  200. package/dist/models/psql/workingShiftModel.d.ts +3 -2
  201. package/dist/models/psql/workingShiftModel.js +43 -40
  202. package/dist/types/accountHasReceiptDetailsType.d.ts +1 -1
  203. package/dist/types/bannerType.d.ts +1 -1
  204. package/dist/types/batchSubjectBookAssessmentType.d.ts +1 -1
  205. package/dist/types/batchSubjectProjectAssessmentType.d.ts +1 -1
  206. package/dist/types/batchType.d.ts +1 -1
  207. package/dist/types/bookAssessmentDateType.d.ts +1 -1
  208. package/dist/types/examType.d.ts +1 -1
  209. package/dist/types/feeHistoryType.d.ts +1 -1
  210. package/dist/types/greetingsType.d.ts +1 -1
  211. package/dist/types/holidayType.js +1 -1
  212. package/dist/types/paymentTermsType.js +1 -1
  213. package/dist/types/projectAssessmentOptionType.d.ts +1 -1
  214. package/dist/types/subjectIndexType.d.ts +1 -1
  215. package/dist/types/syllabusType.d.ts +1 -1
  216. package/dist/types/testimonialType.d.ts +1 -1
  217. package/dist/types/userBookAssessmentType.d.ts +1 -1
  218. package/dist/types/userHasBatchType.d.ts +1 -1
  219. package/dist/types/userProjectAssessmentOptionType.d.ts +1 -1
  220. package/package.json +1 -1
@@ -18,5 +18,7 @@ declare class MasterLeaveModel extends Model<IMasterLeaveModelAttributes, TMaste
18
18
  readonly createdAt: Date;
19
19
  readonly deletedAt: string;
20
20
  readonly updatedAt: Date;
21
+ static addHooks(models: any): void;
22
+ static associate(models: any): void;
21
23
  }
22
24
  export default MasterLeaveModel;
@@ -1,16 +1,81 @@
1
1
  "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
2
  Object.defineProperty(exports, "__esModule", { value: true });
6
3
  const sequelize_1 = require("sequelize");
7
4
  const index_1 = require("./index");
8
5
  const app_1 = require("../../constants/app");
9
- const instituteModel_1 = __importDefault(require("./instituteModel"));
10
- const userModel_1 = __importDefault(require("./userModel"));
11
- const typeManagementModel_1 = __importDefault(require("./typeManagementModel"));
12
6
  const errorMessages_1 = require("../../constants/errorMessages");
13
7
  class MasterLeaveModel extends sequelize_1.Model {
8
+ static addHooks(models) {
9
+ const { TypeManagementModel } = models;
10
+ const validateAndCalculate = async (instance) => {
11
+ try {
12
+ if (instance.typeManagementId) {
13
+ const typeManagement = await TypeManagementModel.findByPk(instance.typeManagementId);
14
+ if (!typeManagement || typeManagement.type !== app_1.TYPE_MANAGEMENT_TYPE.LEAVE) {
15
+ throw new Error(errorMessages_1.MASTER_LEAVE_ERROR_MESSAGES.INVALID_TYPE_MANAGEMENT_ID);
16
+ }
17
+ }
18
+ }
19
+ catch (err) {
20
+ throw err;
21
+ }
22
+ };
23
+ MasterLeaveModel.beforeCreate(async (instance) => {
24
+ await validateAndCalculate(instance);
25
+ });
26
+ MasterLeaveModel.beforeBulkUpdate(async (instance) => {
27
+ await validateAndCalculate(instance.attributes);
28
+ });
29
+ }
30
+ static associate(models) {
31
+ const { InstituteModel, TypeManagementModel, UserModel } = models;
32
+ MasterLeaveModel.belongsTo(InstituteModel, {
33
+ foreignKey: {
34
+ name: 'instituteId',
35
+ field: 'institute_id',
36
+ },
37
+ as: 'leaveInstitute',
38
+ });
39
+ InstituteModel.hasMany(MasterLeaveModel, {
40
+ foreignKey: 'instituteId',
41
+ as: 'instituteHasLeaves',
42
+ });
43
+ MasterLeaveModel.belongsTo(TypeManagementModel, {
44
+ foreignKey: {
45
+ name: 'typeManagementId',
46
+ field: 'type_management_id',
47
+ },
48
+ as: 'leaveTypeManagement',
49
+ });
50
+ TypeManagementModel.hasMany(MasterLeaveModel, {
51
+ foreignKey: 'typeManagementId',
52
+ as: 'typeManagementHasLeaves',
53
+ });
54
+ MasterLeaveModel.belongsTo(UserModel, {
55
+ foreignKey: {
56
+ name: 'createdBy',
57
+ allowNull: true,
58
+ field: 'created_by',
59
+ },
60
+ as: 'createdByUser',
61
+ });
62
+ MasterLeaveModel.belongsTo(UserModel, {
63
+ foreignKey: {
64
+ name: 'updatedBy',
65
+ allowNull: true,
66
+ field: 'updated_by',
67
+ },
68
+ as: 'updatedByUser',
69
+ });
70
+ MasterLeaveModel.belongsTo(UserModel, {
71
+ foreignKey: {
72
+ name: 'deletedBy',
73
+ allowNull: true,
74
+ field: 'deleted_by',
75
+ },
76
+ as: 'deletedByUser',
77
+ });
78
+ }
14
79
  }
15
80
  MasterLeaveModel.init({
16
81
  id: {
@@ -63,69 +128,4 @@ MasterLeaveModel.init({
63
128
  timestamps: true,
64
129
  sequelize: index_1.sequelize,
65
130
  });
66
- const validateAndCalculate = async (instance) => {
67
- try {
68
- if (instance.typeManagementId) {
69
- const typeManagement = await typeManagementModel_1.default.findByPk(instance.typeManagementId);
70
- if (!typeManagement || typeManagement.type !== app_1.TYPE_MANAGEMENT_TYPE.LEAVE) {
71
- throw new Error(errorMessages_1.MASTER_LEAVE_ERROR_MESSAGES.INVALID_TYPE_MANAGEMENT_ID);
72
- }
73
- }
74
- }
75
- catch (err) {
76
- throw err;
77
- }
78
- };
79
- MasterLeaveModel.beforeCreate(async (instance) => {
80
- await validateAndCalculate(instance);
81
- });
82
- MasterLeaveModel.beforeBulkUpdate(async (instance) => {
83
- await validateAndCalculate(instance.attributes);
84
- });
85
- MasterLeaveModel.belongsTo(instituteModel_1.default, {
86
- foreignKey: {
87
- name: 'instituteId',
88
- field: 'institute_id',
89
- },
90
- as: 'leaveInstitute',
91
- });
92
- instituteModel_1.default.hasMany(MasterLeaveModel, {
93
- foreignKey: 'instituteId',
94
- as: 'instituteHasLeaves',
95
- });
96
- MasterLeaveModel.belongsTo(typeManagementModel_1.default, {
97
- foreignKey: {
98
- name: 'typeManagementId',
99
- field: 'type_management_id',
100
- },
101
- as: 'leaveTypeManagement',
102
- });
103
- typeManagementModel_1.default.hasMany(MasterLeaveModel, {
104
- foreignKey: 'typeManagementId',
105
- as: 'typeManagementHasLeaves',
106
- });
107
- MasterLeaveModel.belongsTo(userModel_1.default, {
108
- foreignKey: {
109
- name: 'createdBy',
110
- allowNull: true,
111
- field: 'created_by',
112
- },
113
- as: 'createdByUser',
114
- });
115
- MasterLeaveModel.belongsTo(userModel_1.default, {
116
- foreignKey: {
117
- name: 'updatedBy',
118
- allowNull: true,
119
- field: 'updated_by',
120
- },
121
- as: 'updatedByUser',
122
- });
123
- MasterLeaveModel.belongsTo(userModel_1.default, {
124
- foreignKey: {
125
- name: 'deletedBy',
126
- allowNull: true,
127
- field: 'deleted_by',
128
- },
129
- as: 'deletedByUser',
130
- });
131
131
  exports.default = MasterLeaveModel;
@@ -17,5 +17,6 @@ declare class ModuleFeatureModel extends Model<IModuleFeatureAttributes, TModule
17
17
  readonly createdAt: Date;
18
18
  readonly deletedAt: string;
19
19
  readonly updatedAt: Date;
20
+ static associate(models: any): void;
20
21
  }
21
22
  export default ModuleFeatureModel;
@@ -1,15 +1,50 @@
1
1
  "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
2
  Object.defineProperty(exports, "__esModule", { value: true });
6
3
  const sequelize_1 = require("sequelize");
7
4
  const index_1 = require("./index");
8
5
  const app_1 = require("../../constants/app");
9
- const userModel_1 = __importDefault(require("./userModel"));
10
- const featureActionModel_1 = __importDefault(require("./featureActionModel"));
11
- const roleModel_1 = __importDefault(require("./roleModel"));
12
6
  class ModuleFeatureModel extends sequelize_1.Model {
7
+ static associate(models) {
8
+ const { UserModel, FeatureActionModel, RoleModel } = models;
9
+ ModuleFeatureModel.belongsTo(UserModel, {
10
+ foreignKey: {
11
+ name: 'createdBy',
12
+ allowNull: true,
13
+ field: 'created_by',
14
+ },
15
+ as: 'createdByUser',
16
+ });
17
+ ModuleFeatureModel.belongsTo(UserModel, {
18
+ foreignKey: {
19
+ name: 'updatedBy',
20
+ allowNull: true,
21
+ field: 'updated_by',
22
+ },
23
+ as: 'updatedByUser',
24
+ });
25
+ ModuleFeatureModel.belongsTo(UserModel, {
26
+ foreignKey: {
27
+ name: 'deletedBy',
28
+ allowNull: true,
29
+ field: 'deleted_by',
30
+ },
31
+ as: 'deletedByUser',
32
+ });
33
+ ModuleFeatureModel.hasMany(FeatureActionModel, {
34
+ foreignKey: {
35
+ name: 'featureId',
36
+ field: 'feature_id',
37
+ },
38
+ as: 'actions',
39
+ });
40
+ ModuleFeatureModel.belongsTo(RoleModel, {
41
+ foreignKey: {
42
+ name: 'roleId',
43
+ field: 'roleId',
44
+ },
45
+ as: 'role',
46
+ });
47
+ }
13
48
  }
14
49
  ModuleFeatureModel.init({
15
50
  id: {
@@ -57,42 +92,4 @@ ModuleFeatureModel.init({
57
92
  timestamps: true,
58
93
  sequelize: index_1.sequelize,
59
94
  });
60
- ModuleFeatureModel.belongsTo(userModel_1.default, {
61
- foreignKey: {
62
- name: 'createdBy',
63
- allowNull: true,
64
- field: 'created_by',
65
- },
66
- as: 'createdByUser',
67
- });
68
- ModuleFeatureModel.belongsTo(userModel_1.default, {
69
- foreignKey: {
70
- name: 'updatedBy',
71
- allowNull: true,
72
- field: 'updated_by',
73
- },
74
- as: 'updatedByUser',
75
- });
76
- ModuleFeatureModel.belongsTo(userModel_1.default, {
77
- foreignKey: {
78
- name: 'deletedBy',
79
- allowNull: true,
80
- field: 'deleted_by',
81
- },
82
- as: 'deletedByUser',
83
- });
84
- ModuleFeatureModel.hasMany(featureActionModel_1.default, {
85
- foreignKey: {
86
- name: 'featureId',
87
- field: 'feature_id',
88
- },
89
- as: 'actions',
90
- });
91
- ModuleFeatureModel.belongsTo(roleModel_1.default, {
92
- foreignKey: {
93
- name: 'roleId',
94
- field: 'roleId',
95
- },
96
- as: 'role',
97
- });
98
95
  exports.default = ModuleFeatureModel;
@@ -16,5 +16,6 @@ declare class ModuleModel extends Model<IModuleAttributes, TModuleCreationAttrib
16
16
  readonly createdAt: Date;
17
17
  readonly deletedAt: string;
18
18
  readonly updatedAt: Date;
19
+ static associate(models: any): void;
19
20
  }
20
21
  export default ModuleModel;
@@ -1,16 +1,57 @@
1
1
  "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
2
  Object.defineProperty(exports, "__esModule", { value: true });
6
3
  const sequelize_1 = require("sequelize");
7
4
  const index_1 = require("./index");
8
5
  const app_1 = require("../../constants/app");
9
- const userModel_1 = __importDefault(require("./userModel"));
10
- const moduleFeatureModel_1 = __importDefault(require("./moduleFeatureModel"));
11
- const featureActionModel_1 = __importDefault(require("./featureActionModel"));
12
- const roleModel_1 = __importDefault(require("./roleModel"));
13
6
  class ModuleModel extends sequelize_1.Model {
7
+ static associate(models) {
8
+ const { UserModel, ModuleFeatureModel, FeatureActionModel, RoleModel } = models;
9
+ ModuleModel.belongsTo(UserModel, {
10
+ foreignKey: {
11
+ name: 'createdBy',
12
+ allowNull: true,
13
+ field: 'created_by',
14
+ },
15
+ as: 'createdByUser',
16
+ });
17
+ ModuleModel.belongsTo(UserModel, {
18
+ foreignKey: {
19
+ name: 'updatedBy',
20
+ allowNull: true,
21
+ field: 'updated_by',
22
+ },
23
+ as: 'updatedByUser',
24
+ });
25
+ ModuleModel.belongsTo(UserModel, {
26
+ foreignKey: {
27
+ name: 'deletedBy',
28
+ allowNull: true,
29
+ field: 'deleted_by',
30
+ },
31
+ as: 'deletedByUser',
32
+ });
33
+ ModuleModel.hasMany(ModuleFeatureModel, {
34
+ foreignKey: {
35
+ name: 'moduleId',
36
+ field: 'module_id',
37
+ },
38
+ as: 'features',
39
+ });
40
+ ModuleModel.hasMany(FeatureActionModel, {
41
+ foreignKey: {
42
+ name: 'moduleId',
43
+ field: 'module_id',
44
+ },
45
+ as: 'actions',
46
+ });
47
+ ModuleModel.belongsTo(RoleModel, {
48
+ foreignKey: {
49
+ name: 'roleId',
50
+ field: 'roleId',
51
+ },
52
+ as: 'role',
53
+ });
54
+ }
14
55
  }
15
56
  ModuleModel.init({
16
57
  id: {
@@ -53,49 +94,4 @@ ModuleModel.init({
53
94
  timestamps: true,
54
95
  sequelize: index_1.sequelize,
55
96
  });
56
- ModuleModel.belongsTo(userModel_1.default, {
57
- foreignKey: {
58
- name: 'createdBy',
59
- allowNull: true,
60
- field: 'created_by',
61
- },
62
- as: 'createdByUser',
63
- });
64
- ModuleModel.belongsTo(userModel_1.default, {
65
- foreignKey: {
66
- name: 'updatedBy',
67
- allowNull: true,
68
- field: 'updated_by',
69
- },
70
- as: 'updatedByUser',
71
- });
72
- ModuleModel.belongsTo(userModel_1.default, {
73
- foreignKey: {
74
- name: 'deletedBy',
75
- allowNull: true,
76
- field: 'deleted_by',
77
- },
78
- as: 'deletedByUser',
79
- });
80
- ModuleModel.hasMany(moduleFeatureModel_1.default, {
81
- foreignKey: {
82
- name: 'moduleId',
83
- field: 'module_id',
84
- },
85
- as: 'features',
86
- });
87
- ModuleModel.hasMany(featureActionModel_1.default, {
88
- foreignKey: {
89
- name: 'moduleId',
90
- field: 'module_id',
91
- },
92
- as: 'actions',
93
- });
94
- ModuleModel.belongsTo(roleModel_1.default, {
95
- foreignKey: {
96
- name: 'roleId',
97
- field: 'roleId',
98
- },
99
- as: 'role',
100
- });
101
97
  exports.default = ModuleModel;
@@ -23,5 +23,6 @@ declare class OfferModel extends Model<IOffersModelAttributes, TOfferModelCreati
23
23
  readonly createdAt: Date;
24
24
  readonly deletedAt: string;
25
25
  readonly updatedAt: Date;
26
+ static associate(models: any): void;
26
27
  }
27
28
  export default OfferModel;
@@ -1,16 +1,52 @@
1
1
  "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
2
  Object.defineProperty(exports, "__esModule", { value: true });
6
3
  const sequelize_1 = require("sequelize");
7
4
  const index_1 = require("./index");
8
5
  const app_1 = require("../../constants/app");
9
- const instituteModel_1 = __importDefault(require("./instituteModel"));
10
- const userModel_1 = __importDefault(require("./userModel"));
11
- // const instituteService = container.resolve<IInstituteService>(InstituteService);
12
- // const userService = container.resolve<IUserService>(UserService);
13
6
  class OfferModel extends sequelize_1.Model {
7
+ static associate(models) {
8
+ const { UserModel, InstituteModel } = models;
9
+ OfferModel.belongsTo(UserModel, {
10
+ foreignKey: {
11
+ name: 'userId',
12
+ field: 'user_id',
13
+ },
14
+ as: 'offerUser',
15
+ });
16
+ UserModel.hasMany(OfferModel, { foreignKey: 'userId', as: 'userHasOffers' });
17
+ OfferModel.belongsTo(InstituteModel, {
18
+ foreignKey: {
19
+ name: 'instituteId',
20
+ field: 'institute_id',
21
+ },
22
+ as: 'offerInstitute',
23
+ });
24
+ InstituteModel.hasMany(OfferModel, { foreignKey: 'instituteId', as: 'instituteHasOffers' });
25
+ OfferModel.belongsTo(UserModel, {
26
+ foreignKey: {
27
+ name: 'createdBy',
28
+ allowNull: true,
29
+ field: 'created_by',
30
+ },
31
+ as: 'createdByUser',
32
+ });
33
+ OfferModel.belongsTo(UserModel, {
34
+ foreignKey: {
35
+ name: 'updatedBy',
36
+ allowNull: true,
37
+ field: 'updated_by',
38
+ },
39
+ as: 'updatedByUser',
40
+ });
41
+ OfferModel.belongsTo(UserModel, {
42
+ foreignKey: {
43
+ name: 'deletedBy',
44
+ allowNull: true,
45
+ field: 'deleted_by',
46
+ },
47
+ as: 'deletedByUser',
48
+ });
49
+ }
14
50
  }
15
51
  OfferModel.init({
16
52
  id: {
@@ -77,7 +113,6 @@ OfferModel.init({
77
113
  userLimit: {
78
114
  type: sequelize_1.DataTypes.INTEGER,
79
115
  allowNull: true,
80
- // defaultValue: 1,
81
116
  },
82
117
  }, {
83
118
  modelName: 'OfferModel',
@@ -85,60 +120,4 @@ OfferModel.init({
85
120
  timestamps: true,
86
121
  sequelize: index_1.sequelize,
87
122
  });
88
- OfferModel.belongsTo(userModel_1.default, {
89
- foreignKey: {
90
- name: 'userId',
91
- field: 'user_id',
92
- },
93
- as: 'offerUser',
94
- });
95
- userModel_1.default.hasMany(OfferModel, { foreignKey: 'userId', as: 'userHasOffers' });
96
- OfferModel.belongsTo(instituteModel_1.default, {
97
- foreignKey: {
98
- name: 'instituteId',
99
- field: 'institute_id',
100
- },
101
- as: 'offerInstitute',
102
- });
103
- instituteModel_1.default.hasMany(OfferModel, { foreignKey: 'instituteId', as: 'instituteHasOffers' });
104
- OfferModel.belongsTo(userModel_1.default, {
105
- foreignKey: {
106
- name: 'createdBy',
107
- allowNull: true,
108
- field: 'created_by',
109
- },
110
- as: 'createdByUser',
111
- });
112
- OfferModel.belongsTo(userModel_1.default, {
113
- foreignKey: {
114
- name: 'updatedBy',
115
- allowNull: true,
116
- field: 'updated_by',
117
- },
118
- as: 'updatedByUser',
119
- });
120
- OfferModel.belongsTo(userModel_1.default, {
121
- foreignKey: {
122
- name: 'deletedBy',
123
- allowNull: true,
124
- field: 'deleted_by',
125
- },
126
- as: 'deletedByUser',
127
- });
128
- // const beforeCreateOrUpdateHook = async (offer: OfferModel) => {
129
- // if (offer.instituteId) {
130
- // const institute = await instituteService.findByPk(offer.instituteId);
131
- // if (!institute) {
132
- // throw new Error(INSTITUTE_ERROR_MESSAGES.NOT_FOUND);
133
- // }
134
- // }
135
- // if (offer.userId) {
136
- // const user = await userService.findByPk(offer.userId);
137
- // if (!user) {
138
- // throw new Error(USER_ERROR_MESSAGES.NOT_FOUND);
139
- // }
140
- // }
141
- // };
142
- // OfferModel.beforeCreate(beforeCreateOrUpdateHook);
143
- // OfferModel.beforeUpdate(beforeCreateOrUpdateHook);
144
123
  exports.default = OfferModel;
@@ -13,5 +13,6 @@ declare class PaymentTermsModel extends Model<IPaymentTermsModelAttributes> {
13
13
  feeCollectionId: string;
14
14
  startDate: Date;
15
15
  endDate: Date;
16
+ static associate(models: any): void;
16
17
  }
17
18
  export default PaymentTermsModel;
@@ -1,14 +1,52 @@
1
1
  "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
2
  Object.defineProperty(exports, "__esModule", { value: true });
6
3
  const sequelize_1 = require("sequelize");
7
4
  const index_1 = require("./index");
8
5
  const app_1 = require("../../constants/app");
9
- const instituteModel_1 = __importDefault(require("./instituteModel"));
10
- const userModel_1 = __importDefault(require("./userModel"));
11
6
  class PaymentTermsModel extends sequelize_1.Model {
7
+ static associate(models) {
8
+ const { UserModel, InstituteModel } = models;
9
+ PaymentTermsModel.belongsTo(InstituteModel, {
10
+ foreignKey: {
11
+ name: 'instituteId',
12
+ field: 'institute_id',
13
+ },
14
+ as: 'institute',
15
+ });
16
+ PaymentTermsModel.belongsTo(UserModel, {
17
+ foreignKey: {
18
+ name: 'userId',
19
+ field: 'user_id',
20
+ },
21
+ as: 'user',
22
+ });
23
+ UserModel.hasMany(PaymentTermsModel, { foreignKey: 'userId', as: 'userHasPaymentTerms' });
24
+ InstituteModel.hasMany(PaymentTermsModel, { foreignKey: 'instituteId', as: 'instituteHasPaymentTerms' });
25
+ PaymentTermsModel.belongsTo(UserModel, {
26
+ foreignKey: {
27
+ name: 'createdBy',
28
+ allowNull: true,
29
+ field: 'created_by',
30
+ },
31
+ as: 'createdByUser',
32
+ });
33
+ PaymentTermsModel.belongsTo(UserModel, {
34
+ foreignKey: {
35
+ name: 'updatedBy',
36
+ allowNull: true,
37
+ field: 'updated_by',
38
+ },
39
+ as: 'updatedByUser',
40
+ });
41
+ PaymentTermsModel.belongsTo(UserModel, {
42
+ foreignKey: {
43
+ name: 'deletedBy',
44
+ allowNull: true,
45
+ field: 'deleted_by',
46
+ },
47
+ as: 'deletedByUser',
48
+ });
49
+ }
12
50
  }
13
51
  PaymentTermsModel.init({
14
52
  id: {
@@ -71,44 +109,4 @@ PaymentTermsModel.init({
71
109
  timestamps: true,
72
110
  sequelize: index_1.sequelize,
73
111
  });
74
- PaymentTermsModel.belongsTo(instituteModel_1.default, {
75
- foreignKey: {
76
- name: 'instituteId',
77
- field: 'institute_id',
78
- },
79
- as: 'institute',
80
- });
81
- PaymentTermsModel.belongsTo(userModel_1.default, {
82
- foreignKey: {
83
- name: 'userId',
84
- field: 'user_id',
85
- },
86
- as: 'user',
87
- });
88
- userModel_1.default.hasMany(PaymentTermsModel, { foreignKey: 'userId', as: 'userHasPaymentTerms' });
89
- instituteModel_1.default.hasMany(PaymentTermsModel, { foreignKey: 'instituteId', as: 'instituteHasPaymentTerms' });
90
- PaymentTermsModel.belongsTo(userModel_1.default, {
91
- foreignKey: {
92
- name: 'createdBy',
93
- allowNull: true,
94
- field: 'created_by',
95
- },
96
- as: 'createdByUser',
97
- });
98
- PaymentTermsModel.belongsTo(userModel_1.default, {
99
- foreignKey: {
100
- name: 'updatedBy',
101
- allowNull: true,
102
- field: 'updated_by',
103
- },
104
- as: 'updatedByUser',
105
- });
106
- PaymentTermsModel.belongsTo(userModel_1.default, {
107
- foreignKey: {
108
- name: 'deletedBy',
109
- allowNull: true,
110
- field: 'deleted_by',
111
- },
112
- as: 'deletedByUser',
113
- });
114
112
  exports.default = PaymentTermsModel;
@@ -21,5 +21,6 @@ declare class PdcChequeModel extends Model<IPdcChequeModelAttributes, TPdcCheque
21
21
  readonly createdAt: Date;
22
22
  readonly updatedAt: Date;
23
23
  readonly deletedAt?: Date;
24
+ static associate(models: any): void;
24
25
  }
25
26
  export default PdcChequeModel;