payservedb 9.1.0 → 9.1.2

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 (216) hide show
  1. package/.env +2 -2
  2. package/ZOHO_INTEGRATION_SCHEMA.md +644 -644
  3. package/index.js +401 -401
  4. package/package.json +17 -17
  5. package/src/models/InvoiceWithholdingTax.js +67 -67
  6. package/src/models/account.js +52 -52
  7. package/src/models/agent_departments.js +59 -59
  8. package/src/models/agent_notifications.js +53 -53
  9. package/src/models/agent_performance.js +127 -127
  10. package/src/models/agent_roles.js +77 -77
  11. package/src/models/agents.js +154 -154
  12. package/src/models/apilog.js +18 -18
  13. package/src/models/approvalsWorkflows.js +49 -49
  14. package/src/models/archivedapilog.js +18 -18
  15. package/src/models/asset.js +92 -92
  16. package/src/models/assetsAssignment.js +64 -64
  17. package/src/models/auditTrail.js +346 -346
  18. package/src/models/auto_reply_rule.js +68 -68
  19. package/src/models/bankdetails.js +47 -47
  20. package/src/models/billerAddress.js +124 -124
  21. package/src/models/booking_invoice.js +165 -165
  22. package/src/models/bookinganalytics.js +63 -63
  23. package/src/models/bookingconfig.js +45 -45
  24. package/src/models/bookingproperty.js +179 -179
  25. package/src/models/bookingreservation.js +239 -239
  26. package/src/models/bookingrevenuerecord.js +84 -84
  27. package/src/models/budget.js +95 -95
  28. package/src/models/budgetCategory.js +19 -19
  29. package/src/models/campaigns.js +108 -108
  30. package/src/models/cashpayment.js +290 -290
  31. package/src/models/combinedUnits.js +62 -62
  32. package/src/models/combined_invoice.js +424 -424
  33. package/src/models/common_area_electricity.js +38 -38
  34. package/src/models/common_area_generator.js +41 -41
  35. package/src/models/common_area_utility_alert.js +37 -37
  36. package/src/models/common_area_water.js +39 -39
  37. package/src/models/communication_status.js +33 -33
  38. package/src/models/communication_user_opt.js +32 -32
  39. package/src/models/community_guidelines.js +35 -35
  40. package/src/models/company.js +53 -53
  41. package/src/models/coreBaseSettings.js +16 -16
  42. package/src/models/coreInvoiceSettings.js +100 -100
  43. package/src/models/counter_schema.js +21 -21
  44. package/src/models/country_tax.js +42 -42
  45. package/src/models/currency_settings.js +39 -39
  46. package/src/models/customer.js +234 -234
  47. package/src/models/customer_preference.js +52 -52
  48. package/src/models/customer_satisfaction_survey.js +297 -297
  49. package/src/models/customer_surveys.js +139 -139
  50. package/src/models/customer_tickets.js +237 -237
  51. package/src/models/dailyChecklist.js +312 -312
  52. package/src/models/default_payment_details.js +17 -17
  53. package/src/models/deliveryTimeMarks.js +18 -18
  54. package/src/models/document_type.js +19 -19
  55. package/src/models/dutyRosterChecklist.js +250 -250
  56. package/src/models/dutyroster.js +136 -136
  57. package/src/models/email.js +37 -37
  58. package/src/models/email_cc_config.js +48 -48
  59. package/src/models/email_sms_queue.js +61 -61
  60. package/src/models/email_thread.js +35 -35
  61. package/src/models/entry_exit.js +53 -53
  62. package/src/models/expense.js +99 -99
  63. package/src/models/expense_category.js +45 -45
  64. package/src/models/facility.js +76 -76
  65. package/src/models/facilityBillingPrices.js +29 -29
  66. package/src/models/facilityInvoice.js +240 -240
  67. package/src/models/facilityInvoicePayment.js +52 -52
  68. package/src/models/facilityInvoiceRecipient.js +32 -32
  69. package/src/models/facilityWalletTransactionsMetadata.js +236 -236
  70. package/src/models/facility_departements.js +20 -20
  71. package/src/models/facility_etims_config.js +116 -116
  72. package/src/models/facility_payment_details.js +20 -20
  73. package/src/models/facility_rating.js +78 -78
  74. package/src/models/facilityasset.js +25 -25
  75. package/src/models/faq.js +15 -15
  76. package/src/models/gl_account_double_entries.js +25 -25
  77. package/src/models/gl_accounts.js +56 -56
  78. package/src/models/gl_entries.js +49 -49
  79. package/src/models/goodsReceivedNotes.js +115 -115
  80. package/src/models/guard.js +47 -47
  81. package/src/models/handover.js +258 -258
  82. package/src/models/inspection_category.js +38 -38
  83. package/src/models/invoice.js +528 -525
  84. package/src/models/invoiceCreditAdjustment.js +45 -45
  85. package/src/models/invoice_edit_log.js +81 -81
  86. package/src/models/invoice_generation_approval.js +86 -86
  87. package/src/models/invoicing_schedule.js +40 -40
  88. package/src/models/item_inspection.js +96 -96
  89. package/src/models/knowledge_base.js +109 -109
  90. package/src/models/knowledge_base_rating.js +44 -44
  91. package/src/models/leaseagreement.js +243 -243
  92. package/src/models/leasetemplate.js +17 -17
  93. package/src/models/levy.js +212 -212
  94. package/src/models/levy_invoice_settings.js +26 -26
  95. package/src/models/levycontract.js +215 -215
  96. package/src/models/levytype.js +23 -23
  97. package/src/models/maintenance_service_vendor.js +38 -38
  98. package/src/models/maintenance_services.js +17 -17
  99. package/src/models/maintenancerequisition.js +31 -31
  100. package/src/models/master_workplan.js +32 -32
  101. package/src/models/master_workplan_child.js +34 -34
  102. package/src/models/message.js +38 -38
  103. package/src/models/module.js +21 -21
  104. package/src/models/movein_application.js +29 -29
  105. package/src/models/movein_audit_log.js +21 -21
  106. package/src/models/movein_booking.js +33 -33
  107. package/src/models/movein_commission.js +46 -46
  108. package/src/models/movein_conversation.js +25 -25
  109. package/src/models/movein_deal.js +79 -79
  110. package/src/models/movein_handoff_token.js +16 -16
  111. package/src/models/movein_landlord.js +18 -18
  112. package/src/models/movein_landlord_user.js +20 -20
  113. package/src/models/movein_message.js +27 -27
  114. package/src/models/movein_notification.js +27 -27
  115. package/src/models/movein_otp.js +14 -14
  116. package/src/models/movein_payment.js +46 -46
  117. package/src/models/movein_reminder.js +77 -77
  118. package/src/models/movein_reservation.js +31 -31
  119. package/src/models/movein_unit.js +59 -59
  120. package/src/models/movein_user.js +15 -15
  121. package/src/models/movein_viewing_slot.js +21 -21
  122. package/src/models/notification.js +44 -44
  123. package/src/models/paymentTermsMarks.js +19 -19
  124. package/src/models/penalty.js +76 -76
  125. package/src/models/pendingCredentials.js +32 -32
  126. package/src/models/powerMeterCommunicationProtocol.js +17 -17
  127. package/src/models/powerMeterCustomerAccount.js +78 -78
  128. package/src/models/powerMeterCustomerBand.js +14 -14
  129. package/src/models/powerMeterDailyReading.js +30 -30
  130. package/src/models/powerMeterGateways.js +40 -40
  131. package/src/models/powerMeterMonthlyReading.js +34 -34
  132. package/src/models/powerMeterPowerCharges.js +85 -85
  133. package/src/models/powerMeterSettings.js +200 -200
  134. package/src/models/powerMeterSingleDayReading.js +32 -32
  135. package/src/models/powerMeters.js +149 -149
  136. package/src/models/powerMetersManufacturer.js +14 -14
  137. package/src/models/power_invoice.js +359 -359
  138. package/src/models/power_meter_account.js +81 -81
  139. package/src/models/power_meter_command_logs.js +30 -30
  140. package/src/models/power_meter_command_queue.js +33 -33
  141. package/src/models/power_meter_negative_balance.js +44 -44
  142. package/src/models/power_prepaid_credits.js +47 -47
  143. package/src/models/power_prepaid_debits.js +53 -53
  144. package/src/models/power_prepaid_orders.js +78 -78
  145. package/src/models/power_sms_notification.js +26 -26
  146. package/src/models/privacy_policy.js +19 -19
  147. package/src/models/propertyManagerContract.js +556 -556
  148. package/src/models/propertyManagerRevenue.js +195 -195
  149. package/src/models/purchaseOrderInvoice.js +74 -74
  150. package/src/models/purchase_order.js +213 -213
  151. package/src/models/purchase_request.js +110 -110
  152. package/src/models/quickbooks_config.js +52 -52
  153. package/src/models/recipient_group.js +61 -61
  154. package/src/models/recipient_group_member.js +62 -62
  155. package/src/models/refresh_token.js +23 -23
  156. package/src/models/reminder.js +197 -197
  157. package/src/models/report.js +13 -13
  158. package/src/models/resident.js +121 -121
  159. package/src/models/rfq_details.js +131 -131
  160. package/src/models/rfq_response.js +153 -153
  161. package/src/models/service_charge_invoice_upload.js +42 -42
  162. package/src/models/service_charge_payments.js +27 -27
  163. package/src/models/servicerequest.js +55 -55
  164. package/src/models/settings.js +62 -62
  165. package/src/models/short_urls.js +21 -21
  166. package/src/models/smart_meter_daily_consumption.js +44 -44
  167. package/src/models/sms_africastalking.js +20 -20
  168. package/src/models/sms_balance_notification.js +26 -26
  169. package/src/models/sms_meliora.js +20 -20
  170. package/src/models/staff.js +36 -36
  171. package/src/models/stocksandspare.js +161 -161
  172. package/src/models/suppliers.js +79 -79
  173. package/src/models/terms_and_conditions.js +19 -19
  174. package/src/models/tickets.js +186 -186
  175. package/src/models/tickets_category.js +72 -72
  176. package/src/models/unitManagementTemplate.js +44 -44
  177. package/src/models/unitasset.js +25 -25
  178. package/src/models/units.js +130 -130
  179. package/src/models/user.js +186 -186
  180. package/src/models/valueaddedservices.js +21 -21
  181. package/src/models/vas_invoices_upload.js +50 -50
  182. package/src/models/vas_payments.js +24 -24
  183. package/src/models/vasinvoice.js +196 -196
  184. package/src/models/vasvendor.js +52 -52
  185. package/src/models/visitLog.js +95 -95
  186. package/src/models/visitor.js +67 -67
  187. package/src/models/waitlist.js +45 -45
  188. package/src/models/wallet.js +44 -44
  189. package/src/models/wallet_transactions.js +50 -50
  190. package/src/models/water_invoice.js +351 -351
  191. package/src/models/water_meter_Command_Queue.js +33 -33
  192. package/src/models/water_meter_account.js +86 -86
  193. package/src/models/water_meter_billing.js +58 -58
  194. package/src/models/water_meter_combined_accounts.js +92 -92
  195. package/src/models/water_meter_communication.js +17 -17
  196. package/src/models/water_meter_communication_logs.js +39 -39
  197. package/src/models/water_meter_concentrator.js +70 -70
  198. package/src/models/water_meter_daily_history.js +32 -32
  199. package/src/models/water_meter_high_risk.js +36 -36
  200. package/src/models/water_meter_iot_cards.js +34 -34
  201. package/src/models/water_meter_loan_deduction.js +134 -134
  202. package/src/models/water_meter_manufacturer.js +35 -35
  203. package/src/models/water_meter_monthly_history.js +36 -36
  204. package/src/models/water_meter_negative_amounts.js +44 -44
  205. package/src/models/water_meter_settings.js +290 -290
  206. package/src/models/water_meter_single_day_history.js +34 -34
  207. package/src/models/water_meter_size.js +15 -15
  208. package/src/models/water_meters.js +176 -176
  209. package/src/models/water_meters_delivery.js +76 -76
  210. package/src/models/water_prepaid_credit.js +47 -47
  211. package/src/models/water_prepaid_debit.js +50 -50
  212. package/src/models/whatsapp_conversation.js +23 -23
  213. package/src/models/workorder.js +49 -49
  214. package/src/models/zohoAccount.js +453 -453
  215. package/src/models/zohoIntegration.js +262 -262
  216. package/src/models/zohoItem.js +504 -504
@@ -1,216 +1,216 @@
1
- const mongoose = require('mongoose');
2
- const Schema = mongoose.Schema;
3
-
4
- const LevyContractSchema = new Schema(
5
- {
6
- contractName: {
7
- type: String,
8
- required: [true, 'Contract name is required']
9
- },
10
- levyId: {
11
- type: mongoose.Schema.Types.ObjectId,
12
- ref: 'Levy',
13
- required: [true, 'Levy ID is required']
14
- },
15
- customerId: {
16
- type: mongoose.Schema.Types.ObjectId,
17
- ref: 'Customer',
18
- required: [true, 'Customer ID is required']
19
- },
20
- unitId: {
21
- type: mongoose.Schema.Types.ObjectId,
22
- ref: 'Unit',
23
- required: [true, 'Unit ID is required']
24
- },
25
- amount: {
26
- type: Number,
27
- required: [true, 'Amount is required'],
28
- min: [0, 'Amount cannot be negative']
29
- },
30
- startDate: {
31
- type: Date,
32
- required: [true, 'Start date is required']
33
- },
34
- endDate: {
35
- type: Date,
36
- required: [true, 'End date is required']
37
- },
38
- status: {
39
- type: String,
40
- enum: ['Active', 'Inactive', 'Completed', 'Suspended', 'Terminated'],
41
- default: 'Active',
42
- required: [true, 'Status is required']
43
- },
44
- balanceBroughtForward: {
45
- type: Number,
46
- default: 0
47
- },
48
- taxEnabled: {
49
- type: Boolean
50
- },
51
- enabledTaxes: [
52
- {
53
- type: mongoose.Schema.Types.ObjectId,
54
- ref: 'CountryTaxRate'
55
- }
56
- ],
57
- paymentFrequency: {
58
- type: String,
59
- enum: ['Daily', 'Weekly', 'Bi-Weekly', 'Monthly', 'Quarterly', 'Semi-Annually', 'Annually'],
60
- default: 'Monthly'
61
- },
62
- facilityId: {
63
- type: mongoose.Schema.Types.ObjectId,
64
- ref: 'Facility',
65
- required: [true, 'Facility ID is required']
66
- },
67
- lastInvoiceDate: {
68
- type: Date
69
- },
70
- createdBy: {
71
- type: mongoose.Schema.Types.ObjectId,
72
- ref: 'User'
73
- },
74
- updatedBy: {
75
- type: mongoose.Schema.Types.ObjectId,
76
- ref: 'User'
77
- },
78
- // New termination-specific fields
79
- terminationDate: {
80
- type: Date
81
- },
82
- terminationReason: {
83
- type: String
84
- },
85
- terminatedBy: {
86
- type: mongoose.Schema.Types.ObjectId,
87
- ref: 'User'
88
- },
89
- // Disable/reactivation tracking
90
- disabledDate: {
91
- type: Date
92
- },
93
- disabledBy: {
94
- type: mongoose.Schema.Types.ObjectId,
95
- ref: 'User'
96
- },
97
- disabledReason: {
98
- type: String
99
- },
100
- reactivatedDate: {
101
- type: Date
102
- },
103
- reactivatedBy: {
104
- type: mongoose.Schema.Types.ObjectId,
105
- ref: 'User'
106
- },
107
- lastInvoiceYearMonth: {
108
- type: String,
109
- default: null
110
- // Format: "2025-09", "2025-10", etc.
111
- },
112
- // Upfront payment fields
113
- upfrontPayment: {
114
- enabled: {
115
- type: Boolean,
116
- default: false
117
- },
118
- amount: {
119
- type: Number,
120
- default: 0,
121
- min: [0, 'Upfront amount cannot be negative']
122
- },
123
- billingPeriods: {
124
- type: [String],
125
- default: []
126
- },
127
- collectionFrequency: {
128
- type: String,
129
- enum: ['Monthly', 'Quarterly', 'Semi-Annually', 'Annually'],
130
- default: 'Monthly'
131
- },
132
- remainingAmount: {
133
- type: Number,
134
- default: 0
135
- },
136
- processedPeriods: {
137
- type: [String],
138
- default: []
139
- },
140
- createdAt: {
141
- type: Date,
142
- default: Date.now
143
- }
144
- }
145
- },
146
- {
147
- timestamps: true,
148
- toJSON: { virtuals: true },
149
- toObject: { virtuals: true }
150
- }
151
- );
152
-
153
- // Virtual populate for Levy details
154
- LevyContractSchema.virtual('levy', {
155
- ref: 'Levy',
156
- localField: 'levyId',
157
- foreignField: '_id',
158
- justOne: true
159
- });
160
-
161
- // Virtual populate for Customer details
162
- LevyContractSchema.virtual('customer', {
163
- ref: 'Customer',
164
- localField: 'customerId',
165
- foreignField: '_id',
166
- justOne: true
167
- });
168
-
169
- // Virtual populate for Unit details
170
- LevyContractSchema.virtual('unit', {
171
- ref: 'Unit',
172
- localField: 'unitId',
173
- foreignField: '_id',
174
- justOne: true
175
- });
176
-
177
- // Pre-save middleware to ensure endDate is after startDate
178
- LevyContractSchema.pre('save', function (next) {
179
- if (this.startDate && this.endDate && this.startDate >= this.endDate) {
180
- next(new Error('End date must be after start date'));
181
- } else {
182
- next();
183
- }
184
- });
185
-
186
- // Pre-save middleware to handle termination and disable date logic
187
- LevyContractSchema.pre('save', function (next) {
188
- // Set termination date when status changes to Terminated
189
- if (this.status === 'Terminated' && !this.terminationDate) {
190
- this.terminationDate = new Date();
191
- }
192
-
193
- // Set disabled date when status changes to Inactive
194
- if (this.status === 'Inactive' && !this.disabledDate && this.isModified('status')) {
195
- this.disabledDate = new Date();
196
- }
197
-
198
- // Set reactivated date when status changes from Inactive to Active
199
- if (this.status === 'Active' && this.isModified('status') && this.disabledDate) {
200
- this.reactivatedDate = new Date();
201
- }
202
-
203
- next();
204
- });
205
-
206
- // Index for efficient queries
207
- LevyContractSchema.index({ levyId: 1, unitId: 1, status: 1 });
208
- LevyContractSchema.index({ facilityId: 1 });
209
- LevyContractSchema.index({ customerId: 1 });
210
- LevyContractSchema.index({ status: 1 });
211
- LevyContractSchema.index({ terminationDate: 1 });
212
-
213
- module.exports = {
214
- schema: LevyContractSchema,
215
- name: 'LevyContract'
1
+ const mongoose = require('mongoose');
2
+ const Schema = mongoose.Schema;
3
+
4
+ const LevyContractSchema = new Schema(
5
+ {
6
+ contractName: {
7
+ type: String,
8
+ required: [true, 'Contract name is required']
9
+ },
10
+ levyId: {
11
+ type: mongoose.Schema.Types.ObjectId,
12
+ ref: 'Levy',
13
+ required: [true, 'Levy ID is required']
14
+ },
15
+ customerId: {
16
+ type: mongoose.Schema.Types.ObjectId,
17
+ ref: 'Customer',
18
+ required: [true, 'Customer ID is required']
19
+ },
20
+ unitId: {
21
+ type: mongoose.Schema.Types.ObjectId,
22
+ ref: 'Unit',
23
+ required: [true, 'Unit ID is required']
24
+ },
25
+ amount: {
26
+ type: Number,
27
+ required: [true, 'Amount is required'],
28
+ min: [0, 'Amount cannot be negative']
29
+ },
30
+ startDate: {
31
+ type: Date,
32
+ required: [true, 'Start date is required']
33
+ },
34
+ endDate: {
35
+ type: Date,
36
+ required: [true, 'End date is required']
37
+ },
38
+ status: {
39
+ type: String,
40
+ enum: ['Active', 'Inactive', 'Completed', 'Suspended', 'Terminated'],
41
+ default: 'Active',
42
+ required: [true, 'Status is required']
43
+ },
44
+ balanceBroughtForward: {
45
+ type: Number,
46
+ default: 0
47
+ },
48
+ taxEnabled: {
49
+ type: Boolean
50
+ },
51
+ enabledTaxes: [
52
+ {
53
+ type: mongoose.Schema.Types.ObjectId,
54
+ ref: 'CountryTaxRate'
55
+ }
56
+ ],
57
+ paymentFrequency: {
58
+ type: String,
59
+ enum: ['Daily', 'Weekly', 'Bi-Weekly', 'Monthly', 'Quarterly', 'Semi-Annually', 'Annually'],
60
+ default: 'Monthly'
61
+ },
62
+ facilityId: {
63
+ type: mongoose.Schema.Types.ObjectId,
64
+ ref: 'Facility',
65
+ required: [true, 'Facility ID is required']
66
+ },
67
+ lastInvoiceDate: {
68
+ type: Date
69
+ },
70
+ createdBy: {
71
+ type: mongoose.Schema.Types.ObjectId,
72
+ ref: 'User'
73
+ },
74
+ updatedBy: {
75
+ type: mongoose.Schema.Types.ObjectId,
76
+ ref: 'User'
77
+ },
78
+ // New termination-specific fields
79
+ terminationDate: {
80
+ type: Date
81
+ },
82
+ terminationReason: {
83
+ type: String
84
+ },
85
+ terminatedBy: {
86
+ type: mongoose.Schema.Types.ObjectId,
87
+ ref: 'User'
88
+ },
89
+ // Disable/reactivation tracking
90
+ disabledDate: {
91
+ type: Date
92
+ },
93
+ disabledBy: {
94
+ type: mongoose.Schema.Types.ObjectId,
95
+ ref: 'User'
96
+ },
97
+ disabledReason: {
98
+ type: String
99
+ },
100
+ reactivatedDate: {
101
+ type: Date
102
+ },
103
+ reactivatedBy: {
104
+ type: mongoose.Schema.Types.ObjectId,
105
+ ref: 'User'
106
+ },
107
+ lastInvoiceYearMonth: {
108
+ type: String,
109
+ default: null
110
+ // Format: "2025-09", "2025-10", etc.
111
+ },
112
+ // Upfront payment fields
113
+ upfrontPayment: {
114
+ enabled: {
115
+ type: Boolean,
116
+ default: false
117
+ },
118
+ amount: {
119
+ type: Number,
120
+ default: 0,
121
+ min: [0, 'Upfront amount cannot be negative']
122
+ },
123
+ billingPeriods: {
124
+ type: [String],
125
+ default: []
126
+ },
127
+ collectionFrequency: {
128
+ type: String,
129
+ enum: ['Monthly', 'Quarterly', 'Semi-Annually', 'Annually'],
130
+ default: 'Monthly'
131
+ },
132
+ remainingAmount: {
133
+ type: Number,
134
+ default: 0
135
+ },
136
+ processedPeriods: {
137
+ type: [String],
138
+ default: []
139
+ },
140
+ createdAt: {
141
+ type: Date,
142
+ default: Date.now
143
+ }
144
+ }
145
+ },
146
+ {
147
+ timestamps: true,
148
+ toJSON: { virtuals: true },
149
+ toObject: { virtuals: true }
150
+ }
151
+ );
152
+
153
+ // Virtual populate for Levy details
154
+ LevyContractSchema.virtual('levy', {
155
+ ref: 'Levy',
156
+ localField: 'levyId',
157
+ foreignField: '_id',
158
+ justOne: true
159
+ });
160
+
161
+ // Virtual populate for Customer details
162
+ LevyContractSchema.virtual('customer', {
163
+ ref: 'Customer',
164
+ localField: 'customerId',
165
+ foreignField: '_id',
166
+ justOne: true
167
+ });
168
+
169
+ // Virtual populate for Unit details
170
+ LevyContractSchema.virtual('unit', {
171
+ ref: 'Unit',
172
+ localField: 'unitId',
173
+ foreignField: '_id',
174
+ justOne: true
175
+ });
176
+
177
+ // Pre-save middleware to ensure endDate is after startDate
178
+ LevyContractSchema.pre('save', function (next) {
179
+ if (this.startDate && this.endDate && this.startDate >= this.endDate) {
180
+ next(new Error('End date must be after start date'));
181
+ } else {
182
+ next();
183
+ }
184
+ });
185
+
186
+ // Pre-save middleware to handle termination and disable date logic
187
+ LevyContractSchema.pre('save', function (next) {
188
+ // Set termination date when status changes to Terminated
189
+ if (this.status === 'Terminated' && !this.terminationDate) {
190
+ this.terminationDate = new Date();
191
+ }
192
+
193
+ // Set disabled date when status changes to Inactive
194
+ if (this.status === 'Inactive' && !this.disabledDate && this.isModified('status')) {
195
+ this.disabledDate = new Date();
196
+ }
197
+
198
+ // Set reactivated date when status changes from Inactive to Active
199
+ if (this.status === 'Active' && this.isModified('status') && this.disabledDate) {
200
+ this.reactivatedDate = new Date();
201
+ }
202
+
203
+ next();
204
+ });
205
+
206
+ // Index for efficient queries
207
+ LevyContractSchema.index({ levyId: 1, unitId: 1, status: 1 });
208
+ LevyContractSchema.index({ facilityId: 1 });
209
+ LevyContractSchema.index({ customerId: 1 });
210
+ LevyContractSchema.index({ status: 1 });
211
+ LevyContractSchema.index({ terminationDate: 1 });
212
+
213
+ module.exports = {
214
+ schema: LevyContractSchema,
215
+ name: 'LevyContract'
216
216
  };
@@ -1,23 +1,23 @@
1
- const mongoose = require('mongoose');
2
-
3
- // Define the schema for LevyType
4
- const levyTypeSchema = new mongoose.Schema({
5
- name: {
6
- type: String,
7
- required: true,
8
- trim: true,
9
- minlength: [1, 'Levy type name must be at least 1 character long']
10
- },
11
- facilityId: {
12
- type: mongoose.Schema.Types.ObjectId,
13
- ref: 'Facility',
14
- required: [true, 'Facility ID is required']
15
- }
16
- }, {
17
- timestamps: true // Automatically add createdAt and updatedAt fields
18
- });
19
-
20
- // Compile the model from the schema
21
- const LevyType = mongoose.model('LevyType', levyTypeSchema);
22
-
23
- module.exports = LevyType;
1
+ const mongoose = require('mongoose');
2
+
3
+ // Define the schema for LevyType
4
+ const levyTypeSchema = new mongoose.Schema({
5
+ name: {
6
+ type: String,
7
+ required: true,
8
+ trim: true,
9
+ minlength: [1, 'Levy type name must be at least 1 character long']
10
+ },
11
+ facilityId: {
12
+ type: mongoose.Schema.Types.ObjectId,
13
+ ref: 'Facility',
14
+ required: [true, 'Facility ID is required']
15
+ }
16
+ }, {
17
+ timestamps: true // Automatically add createdAt and updatedAt fields
18
+ });
19
+
20
+ // Compile the model from the schema
21
+ const LevyType = mongoose.model('LevyType', levyTypeSchema);
22
+
23
+ module.exports = LevyType;
@@ -1,38 +1,38 @@
1
- const mongoose = require('mongoose');
2
-
3
- const serviceVendorSchema = new mongoose.Schema({
4
- name: {
5
- type: String,
6
- required: true,
7
- },
8
- service: {
9
- type: String,
10
- required: true,
11
- },
12
- agreement: {
13
- type: String,
14
- },
15
- dates: {
16
- type: [Date],
17
- },
18
- assignedAssets: [{
19
- type: mongoose.Schema.Types.ObjectId,
20
- ref: 'Asset',
21
- }],
22
- facilityId: {
23
- type: mongoose.Schema.Types.ObjectId,
24
- ref: 'Facility',
25
- required: true,
26
- },
27
- phone: {
28
- type: String,
29
- required: true,
30
- },
31
- email: {
32
- type: String,
33
- },
34
- }, {
35
- timestamps: true,
36
- });
37
-
38
- module.exports = mongoose.model('ServiceVendor', serviceVendorSchema);
1
+ const mongoose = require('mongoose');
2
+
3
+ const serviceVendorSchema = new mongoose.Schema({
4
+ name: {
5
+ type: String,
6
+ required: true,
7
+ },
8
+ service: {
9
+ type: String,
10
+ required: true,
11
+ },
12
+ agreement: {
13
+ type: String,
14
+ },
15
+ dates: {
16
+ type: [Date],
17
+ },
18
+ assignedAssets: [{
19
+ type: mongoose.Schema.Types.ObjectId,
20
+ ref: 'Asset',
21
+ }],
22
+ facilityId: {
23
+ type: mongoose.Schema.Types.ObjectId,
24
+ ref: 'Facility',
25
+ required: true,
26
+ },
27
+ phone: {
28
+ type: String,
29
+ required: true,
30
+ },
31
+ email: {
32
+ type: String,
33
+ },
34
+ }, {
35
+ timestamps: true,
36
+ });
37
+
38
+ module.exports = mongoose.model('ServiceVendor', serviceVendorSchema);
@@ -1,17 +1,17 @@
1
- const mongoose = require('mongoose');
2
-
3
- const maintenanceServicesSchema = new mongoose.Schema({
4
- name: {
5
- type: String,
6
- required: true,
7
- },
8
- facilityId: {
9
- type: mongoose.Schema.Types.ObjectId,
10
- ref: 'Facility',
11
- required: true,
12
- },
13
- }, {
14
- timestamps: true,
15
- });
16
-
17
- module.exports = mongoose.model('MaintenanceServices', maintenanceServicesSchema);
1
+ const mongoose = require('mongoose');
2
+
3
+ const maintenanceServicesSchema = new mongoose.Schema({
4
+ name: {
5
+ type: String,
6
+ required: true,
7
+ },
8
+ facilityId: {
9
+ type: mongoose.Schema.Types.ObjectId,
10
+ ref: 'Facility',
11
+ required: true,
12
+ },
13
+ }, {
14
+ timestamps: true,
15
+ });
16
+
17
+ module.exports = mongoose.model('MaintenanceServices', maintenanceServicesSchema);
@@ -1,31 +1,31 @@
1
- const mongoose = require('mongoose');
2
-
3
- const requisitionSchema = new mongoose.Schema({
4
- facilityId: {
5
- type: mongoose.Schema.Types.ObjectId,
6
- ref: 'Facility',
7
- required: [true, 'Facility ID is required']
8
- },
9
- stockId: {
10
- type: mongoose.Schema.Types.ObjectId,
11
- ref: 'Stocksandspare',
12
- required: [true, 'stock ID is required']
13
- },
14
- workId: {
15
- type: mongoose.Schema.Types.ObjectId,
16
- ref: 'WorkOrder'
17
- },
18
- description: {
19
- type: String,
20
- required: true,
21
- },
22
- quantity: {
23
- type: Number,
24
- required: true,
25
- min: 1,
26
- }
27
- }, {
28
- timestamps: true,
29
- });
30
-
31
- module.exports = mongoose.model('StockRequisition', requisitionSchema);
1
+ const mongoose = require('mongoose');
2
+
3
+ const requisitionSchema = new mongoose.Schema({
4
+ facilityId: {
5
+ type: mongoose.Schema.Types.ObjectId,
6
+ ref: 'Facility',
7
+ required: [true, 'Facility ID is required']
8
+ },
9
+ stockId: {
10
+ type: mongoose.Schema.Types.ObjectId,
11
+ ref: 'Stocksandspare',
12
+ required: [true, 'stock ID is required']
13
+ },
14
+ workId: {
15
+ type: mongoose.Schema.Types.ObjectId,
16
+ ref: 'WorkOrder'
17
+ },
18
+ description: {
19
+ type: String,
20
+ required: true,
21
+ },
22
+ quantity: {
23
+ type: Number,
24
+ required: true,
25
+ min: 1,
26
+ }
27
+ }, {
28
+ timestamps: true,
29
+ });
30
+
31
+ module.exports = mongoose.model('StockRequisition', requisitionSchema);