payservedb 8.3.5 → 8.3.7

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 (177) hide show
  1. package/.env +2 -2
  2. package/.idea/material_theme_project_new.xml +12 -0
  3. package/.idea/modules.xml +8 -0
  4. package/.idea/psdb.iml +12 -0
  5. package/.idea/vcs.xml +6 -0
  6. package/index.js +306 -306
  7. package/package.json +17 -17
  8. package/src/models/account.js +52 -52
  9. package/src/models/agent_departments.js +59 -59
  10. package/src/models/agent_notifications.js +53 -53
  11. package/src/models/agent_performance.js +127 -127
  12. package/src/models/agent_roles.js +77 -77
  13. package/src/models/agents.js +154 -154
  14. package/src/models/apilog.js +18 -18
  15. package/src/models/approvalsWorkflows.js +49 -49
  16. package/src/models/archivedapilog.js +18 -18
  17. package/src/models/asset.js +92 -92
  18. package/src/models/assetsAssignment.js +64 -64
  19. package/src/models/auditTrail.js +346 -346
  20. package/src/models/bankdetails.js +47 -43
  21. package/src/models/billerAddress.js +124 -124
  22. package/src/models/booking_invoice.js +151 -151
  23. package/src/models/bookinganalytics.js +63 -63
  24. package/src/models/bookingconfig.js +45 -45
  25. package/src/models/bookingproperty.js +122 -122
  26. package/src/models/bookingreservation.js +192 -192
  27. package/src/models/bookingrevenuerecord.js +84 -84
  28. package/src/models/budget.js +95 -95
  29. package/src/models/budgetCategory.js +19 -19
  30. package/src/models/campaigns.js +108 -108
  31. package/src/models/cashpayment.js +264 -264
  32. package/src/models/combinedUnits.js +62 -62
  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/company.js +53 -53
  40. package/src/models/coreBaseSettings.js +16 -16
  41. package/src/models/coreInvoiceSettings.js +100 -100
  42. package/src/models/counter_schema.js +21 -21
  43. package/src/models/country_tax.js +42 -42
  44. package/src/models/currency_settings.js +39 -39
  45. package/src/models/customer.js +210 -210
  46. package/src/models/customer_satisfaction_survey.js +278 -278
  47. package/src/models/customer_surveys.js +139 -139
  48. package/src/models/customer_tickets.js +239 -239
  49. package/src/models/dailyChecklist.js +312 -312
  50. package/src/models/default_payment_details.js +17 -17
  51. package/src/models/deliveryTimeMarks.js +18 -18
  52. package/src/models/document_type.js +19 -19
  53. package/src/models/dutyRosterChecklist.js +250 -250
  54. package/src/models/dutyroster.js +136 -136
  55. package/src/models/email.js +37 -37
  56. package/src/models/email_sms_queue.js +61 -61
  57. package/src/models/entry_exit.js +53 -53
  58. package/src/models/expense.js +99 -99
  59. package/src/models/expense_category.js +45 -45
  60. package/src/models/facility.js +62 -62
  61. package/src/models/facilityBillingPrices.js +29 -29
  62. package/src/models/facilityInvoice.js +223 -240
  63. package/src/models/facilityInvoicePayment.js +47 -52
  64. package/src/models/facilityInvoiceRecipient.js +32 -32
  65. package/src/models/facilityWalletTransactionsMetadata.js +236 -236
  66. package/src/models/facility_departements.js +20 -20
  67. package/src/models/facility_payment_details.js +20 -20
  68. package/src/models/facilityasset.js +25 -25
  69. package/src/models/faq.js +14 -18
  70. package/src/models/gl_account_double_entries.js +25 -25
  71. package/src/models/gl_accounts.js +56 -56
  72. package/src/models/gl_entries.js +49 -49
  73. package/src/models/goodsReceivedNotes.js +115 -115
  74. package/src/models/guard.js +47 -47
  75. package/src/models/handover.js +247 -247
  76. package/src/models/inspection_category.js +38 -38
  77. package/src/models/invoice.js +387 -387
  78. package/src/models/invoicing_schedule.js +36 -36
  79. package/src/models/item_inspection.js +96 -96
  80. package/src/models/knowledge_base.js +109 -109
  81. package/src/models/knowledge_base_rating.js +44 -44
  82. package/src/models/leaseagreement.js +236 -243
  83. package/src/models/leasetemplate.js +17 -17
  84. package/src/models/levy.js +223 -223
  85. package/src/models/levy_invoice_settings.js +26 -26
  86. package/src/models/levycontract.js +177 -173
  87. package/src/models/levytype.js +23 -23
  88. package/src/models/maintenance_service_vendor.js +38 -38
  89. package/src/models/maintenance_services.js +17 -17
  90. package/src/models/maintenancerequisition.js +31 -31
  91. package/src/models/master_workplan.js +32 -32
  92. package/src/models/master_workplan_child.js +34 -34
  93. package/src/models/message.js +38 -38
  94. package/src/models/module.js +21 -21
  95. package/src/models/notification.js +44 -44
  96. package/src/models/paymentTermsMarks.js +19 -19
  97. package/src/models/penalty.js +76 -76
  98. package/src/models/pendingCredentials.js +32 -32
  99. package/src/models/powerMeterCommunicationProtocol.js +17 -17
  100. package/src/models/powerMeterCustomerAccount.js +78 -78
  101. package/src/models/powerMeterCustomerBand.js +14 -14
  102. package/src/models/powerMeterDailyReading.js +30 -30
  103. package/src/models/powerMeterGateways.js +40 -40
  104. package/src/models/powerMeterMonthlyReading.js +34 -34
  105. package/src/models/powerMeterPowerCharges.js +85 -85
  106. package/src/models/powerMeterSettings.js +159 -159
  107. package/src/models/powerMeterSingleDayReading.js +32 -32
  108. package/src/models/powerMeters.js +116 -116
  109. package/src/models/powerMetersManufacturer.js +14 -14
  110. package/src/models/power_meter_account.js +81 -81
  111. package/src/models/power_meter_command_logs.js +30 -30
  112. package/src/models/power_meter_command_queue.js +33 -33
  113. package/src/models/power_meter_negative_balance.js +44 -44
  114. package/src/models/power_prepaid_credits.js +47 -47
  115. package/src/models/power_prepaid_debits.js +53 -53
  116. package/src/models/power_prepaid_orders.js +78 -78
  117. package/src/models/power_sms_notification.js +26 -26
  118. package/src/models/propertyManagerContract.js +556 -556
  119. package/src/models/propertyManagerRevenue.js +195 -195
  120. package/src/models/purchaseOrderInvoice.js +74 -74
  121. package/src/models/purchase_order.js +213 -213
  122. package/src/models/purchase_request.js +110 -110
  123. package/src/models/refresh_token.js +23 -23
  124. package/src/models/reminder.js +197 -197
  125. package/src/models/report.js +13 -13
  126. package/src/models/resident.js +121 -121
  127. package/src/models/rfq_details.js +131 -131
  128. package/src/models/rfq_response.js +153 -153
  129. package/src/models/service_charge_invoice_upload.js +42 -42
  130. package/src/models/service_charge_payments.js +27 -27
  131. package/src/models/servicerequest.js +55 -55
  132. package/src/models/settings.js +62 -62
  133. package/src/models/short_urls.js +21 -21
  134. package/src/models/smart_meter_daily_consumption.js +44 -44
  135. package/src/models/sms_africastalking.js +20 -20
  136. package/src/models/sms_balance_notification.js +26 -26
  137. package/src/models/sms_meliora.js +20 -20
  138. package/src/models/staff.js +36 -36
  139. package/src/models/stocksandspare.js +161 -161
  140. package/src/models/suppliers.js +74 -74
  141. package/src/models/tickets.js +173 -173
  142. package/src/models/tickets_category.js +72 -72
  143. package/src/models/unitManagementTemplate.js +44 -44
  144. package/src/models/unitasset.js +25 -25
  145. package/src/models/units.js +118 -118
  146. package/src/models/user.js +186 -186
  147. package/src/models/valueaddedservices.js +79 -79
  148. package/src/models/vas_invoices_upload.js +50 -50
  149. package/src/models/vas_payments.js +24 -24
  150. package/src/models/vasinvoice.js +192 -192
  151. package/src/models/vasvendor.js +57 -57
  152. package/src/models/visitLog.js +95 -95
  153. package/src/models/visitor.js +67 -67
  154. package/src/models/waitlist.js +45 -45
  155. package/src/models/wallet.js +44 -44
  156. package/src/models/wallet_transactions.js +50 -50
  157. package/src/models/water_invoice.js +351 -351
  158. package/src/models/water_meter_Command_Queue.js +33 -33
  159. package/src/models/water_meter_account.js +82 -82
  160. package/src/models/water_meter_billing.js +58 -58
  161. package/src/models/water_meter_communication.js +17 -17
  162. package/src/models/water_meter_communication_logs.js +39 -39
  163. package/src/models/water_meter_concentrator.js +70 -70
  164. package/src/models/water_meter_daily_history.js +32 -32
  165. package/src/models/water_meter_high_risk.js +36 -36
  166. package/src/models/water_meter_iot_cards.js +34 -34
  167. package/src/models/water_meter_manufacturer.js +35 -35
  168. package/src/models/water_meter_monthly_history.js +36 -36
  169. package/src/models/water_meter_negative_amounts.js +44 -44
  170. package/src/models/water_meter_settings.js +283 -276
  171. package/src/models/water_meter_single_day_history.js +34 -34
  172. package/src/models/water_meter_size.js +15 -15
  173. package/src/models/water_meters.js +133 -133
  174. package/src/models/water_meters_delivery.js +76 -76
  175. package/src/models/water_prepaid_credit.js +47 -47
  176. package/src/models/water_prepaid_debit.js +50 -50
  177. package/src/models/workorder.js +49 -49
@@ -1,277 +1,284 @@
1
- const mongoose = require('mongoose');
2
-
3
- const waterMeterSettingsSchema = new mongoose.Schema({
4
- facilityId: {
5
- type: mongoose.Schema.Types.ObjectId,
6
- ref: 'Facility',
7
- required: true,
8
- unique: true
9
- },
10
- minAmount: {
11
- type: Number,
12
- required: true,
13
- default: 1
14
- },
15
- maxAmount: {
16
- type: Number,
17
- required: true,
18
- default: 10000
19
- },
20
- lowThreshold: {
21
- type: Number,
22
- default: 0
23
- },
24
- highThreshold: {
25
- type: Number,
26
- default: 0
27
- },
28
- gracePeriod: {
29
- type: Number,
30
- required: true,
31
- default: 10
32
- },
33
- invoiceDay: {
34
- type: Number,
35
- required: true,
36
- min: 0,
37
- max: 30,
38
- default: 3
39
- },
40
- enforcePayment: {
41
- type: String,
42
- enum: ['yes', 'no'],
43
- required: true,
44
- default: 'no'
45
- },
46
- minimumPaymentAmount: {
47
- type: Number,
48
- required: true,
49
- default: 0
50
- },
51
- tariff: {
52
- type: String,
53
- enum: ['yes', 'no'],
54
- required: true,
55
- default: 'no'
56
- },
57
- tariffAmount: {
58
- type: Number,
59
- required: true,
60
- default: 0
61
- },
62
- tariffAmountSmart: {
63
- type: Number,
64
- default: 0
65
- },
66
- fixedTariffAmount: {
67
- type: Number,
68
- required: true,
69
- default: 0
70
- },
71
- meterLoan: {
72
- type: Number,
73
- required: true,
74
- default: 0
75
- },
76
-
77
- // Updated notification structure - separated concerns
78
- notifications: {
79
- // Usage and billing notifications
80
- usageAlerts: {
81
- enabled: {
82
- type: Boolean,
83
- default: false
84
- },
85
- daily: {
86
- type: Boolean,
87
- default: false
88
- },
89
- weekly: {
90
- type: Boolean,
91
- default: false
92
- },
93
- monthly: {
94
- type: Boolean,
95
- default: false
96
- }
97
- },
98
- statements: {
99
- enabled: {
100
- type: Boolean,
101
- default: false
102
- }
103
- },
104
- // Payment reminder notifications
105
- paymentReminders: {
106
- enabled: {
107
- type: Boolean,
108
- default: false
109
- },
110
- daysBeforeDue: {
111
- type: Number,
112
- default: 3,
113
- min: 1,
114
- max: 30
115
- },
116
- frequency: {
117
- type: String,
118
- enum: ['daily', 'weekly', 'once'],
119
- default: 'once'
120
- }
121
- }
122
- },
123
-
124
- // Other charges section
125
- otherCharges: {
126
- type: String,
127
- enum: ['yes', 'no'],
128
- default: 'no'
129
- },
130
- sewerageCharge: {
131
- type: Number,
132
- default: 0
133
- },
134
- fixedCharge: {
135
- type: Number,
136
- default: 0
137
- },
138
- vatPercentage: {
139
- type: Number,
140
- min: 0,
141
- max: 100,
142
- default: 0
143
- },
144
-
145
- // Payment methods
146
- paymentMethods: {
147
- mobilePayment: {
148
- status: {
149
- type: Boolean,
150
- default: false
151
- },
152
- paymentId: {
153
- type: mongoose.Schema.Types.ObjectId,
154
- ref: 'FacilityPaymentDetails'
155
- }
156
- },
157
- bankPayment: {
158
- status: {
159
- type: Boolean,
160
- default: false
161
- },
162
- paymentId: {
163
- type: mongoose.Schema.Types.ObjectId,
164
- ref: 'BankDetails'
165
- }
166
- }
167
- },
168
-
169
- // Discounts
170
- discounts: [{
171
- name: {
172
- type: String,
173
- required: true,
174
- trim: true
175
- },
176
- type: {
177
- type: String,
178
- enum: ['percentage', 'fixed_amount'],
179
- required: true
180
- },
181
- value: {
182
- type: Number,
183
- required: true,
184
- min: 0
185
- },
186
- yearMonth: {
187
- type: String,
188
- required: true
189
- }
190
- }],
191
-
192
- // Biller address for invoices
193
- billerAddress: {
194
- name: {
195
- type: String,
196
- required: [true, "Biller name is required"],
197
- trim: true,
198
- minlength: [1, "Biller name must be at least 1 character long"],
199
- },
200
- email: {
201
- type: String,
202
- required: [true, "Biller email is required"],
203
- trim: true,
204
- lowercase: true,
205
- validate: {
206
- validator: function (v) {
207
- return /^\w+([\.-]?\w+)@\w+([\.-]?\w+)(\.\w{2,3})+$/.test(v);
208
- },
209
- message: "Please enter a valid email address"
210
- }
211
- },
212
- phone: {
213
- type: String,
214
- required: [true, "Biller phone is required"],
215
- trim: true,
216
- },
217
- address: {
218
- type: String,
219
- required: [true, "Biller address is required"],
220
- trim: true,
221
- },
222
- city: {
223
- type: String,
224
- required: [true, "Biller city is required"],
225
- trim: true,
226
- }
227
- },
228
-
229
- // GL accounts for accounting entries
230
- glAccounts: {
231
- invoice: {
232
- debit: {
233
- type: mongoose.Schema.Types.ObjectId,
234
- ref: "GLAccount",
235
- required: false,
236
- },
237
- credit: {
238
- type: mongoose.Schema.Types.ObjectId,
239
- ref: "GLAccount",
240
- required: false,
241
- }
242
- },
243
- payment: {
244
- debit: {
245
- type: mongoose.Schema.Types.ObjectId,
246
- ref: "GLAccount",
247
- required: false,
248
- },
249
- credit: {
250
- type: mongoose.Schema.Types.ObjectId,
251
- ref: "GLAccount",
252
- required: false,
253
- }
254
- }
255
- },
256
-
257
- //GL ACCOUNT DOUBLE ENTRIES
258
-
259
- invocieCreationDe: {
260
- type: mongoose.Schema.Types.ObjectId,
261
- ref: 'GLAccountDoubleEntries',
262
- unique: true
263
- },
264
-
265
- invoicePaymentDe: {
266
- type: mongoose.Schema.Types.ObjectId,
267
- ref: 'GLAccountDoubleEntries',
268
- unique: true
269
- },
270
-
271
- }, {
272
- timestamps: true
273
- });
274
-
275
- const WaterMeterSettings = mongoose.model('WaterMeterSettings', waterMeterSettingsSchema);
276
-
1
+ const mongoose = require('mongoose');
2
+
3
+ const waterMeterSettingsSchema = new mongoose.Schema({
4
+ facilityId: {
5
+ type: mongoose.Schema.Types.ObjectId,
6
+ ref: 'Facility',
7
+ required: true,
8
+ unique: true
9
+ },
10
+ minAmount: {
11
+ type: Number,
12
+ required: true,
13
+ default: 1
14
+ },
15
+ maxAmount: {
16
+ type: Number,
17
+ required: true,
18
+ default: 10000
19
+ },
20
+ lowThreshold: {
21
+ type: Number,
22
+ default: 0
23
+ },
24
+ highThreshold: {
25
+ type: Number,
26
+ default: 0
27
+ },
28
+ gracePeriod: {
29
+ type: Number,
30
+ required: true,
31
+ default: 10
32
+ },
33
+ invoiceDay: {
34
+ type: Number,
35
+ required: true,
36
+ min: 0,
37
+ max: 30,
38
+ default: 3
39
+ },
40
+ enforcePayment: {
41
+ type: String,
42
+ enum: ['yes', 'no'],
43
+ required: true,
44
+ default: 'no'
45
+ },
46
+ minimumPaymentAmount: {
47
+ type: Number,
48
+ required: true,
49
+ default: 0
50
+ },
51
+ tariff: {
52
+ type: String,
53
+ enum: ['yes', 'no'],
54
+ required: true,
55
+ default: 'no'
56
+ },
57
+ tariffAmount: {
58
+ type: Number,
59
+ required: true,
60
+ default: 0
61
+ },
62
+ tariffAmountSmart: {
63
+ type: Number,
64
+ default: 0
65
+ },
66
+ fixedTariffAmount: {
67
+ type: Number,
68
+ required: true,
69
+ default: 0
70
+ },
71
+ meterLoan: {
72
+ type: Number,
73
+ required: true,
74
+ default: 0
75
+ },
76
+
77
+ // Updated notification structure - separated concerns
78
+ notifications: {
79
+ // Usage and billing notifications
80
+ usageAlerts: {
81
+ enabled: {
82
+ type: Boolean,
83
+ default: false
84
+ },
85
+ daily: {
86
+ type: Boolean,
87
+ default: false
88
+ },
89
+ weekly: {
90
+ type: Boolean,
91
+ default: false
92
+ },
93
+ monthly: {
94
+ type: Boolean,
95
+ default: false
96
+ }
97
+ },
98
+ statements: {
99
+ enabled: {
100
+ type: Boolean,
101
+ default: false
102
+ }
103
+ },
104
+ // Payment reminder notifications
105
+ paymentReminders: {
106
+ enabled: {
107
+ type: Boolean,
108
+ default: false
109
+ },
110
+ daysBeforeDue: {
111
+ type: Number,
112
+ default: 3,
113
+ min: 1,
114
+ max: 30
115
+ },
116
+ frequency: {
117
+ type: String,
118
+ enum: ['daily', 'weekly', 'once'],
119
+ default: 'once'
120
+ }
121
+ }
122
+ },
123
+
124
+ // Other charges section
125
+ otherCharges: {
126
+ type: String,
127
+ enum: ['yes', 'no'],
128
+ default: 'no'
129
+ },
130
+ sewerageCharge: {
131
+ type: Number,
132
+ default: 0
133
+ },
134
+ fixedCharge: {
135
+ type: Number,
136
+ default: 0
137
+ },
138
+ vatPercentage: {
139
+ type: Number,
140
+ min: 0,
141
+ max: 100,
142
+ default: 0
143
+ },
144
+
145
+ // Payment methods
146
+ paymentMethods: {
147
+ mobilePayment: {
148
+ status: {
149
+ type: Boolean,
150
+ default: false
151
+ },
152
+ paymentId: {
153
+ type: mongoose.Schema.Types.ObjectId,
154
+ ref: 'FacilityPaymentDetails'
155
+ }
156
+ },
157
+ bankPayment: {
158
+ status: {
159
+ type: Boolean,
160
+ default: false
161
+ },
162
+ paymentId: {
163
+ type: mongoose.Schema.Types.ObjectId,
164
+ ref: 'BankDetails'
165
+ }
166
+ }
167
+ },
168
+
169
+ // Discounts
170
+ discounts: [{
171
+ name: {
172
+ type: String,
173
+ required: true,
174
+ trim: true
175
+ },
176
+ type: {
177
+ type: String,
178
+ enum: ['percentage', 'fixed_amount'],
179
+ required: true
180
+ },
181
+ value: {
182
+ type: Number,
183
+ required: true,
184
+ min: 0
185
+ },
186
+ yearMonth: {
187
+ type: String,
188
+ required: true
189
+ }
190
+ }],
191
+
192
+ // Biller address for invoices
193
+ billerAddress: {
194
+ name: {
195
+ type: String,
196
+ trim: true,
197
+ },
198
+ email: {
199
+ type: String,
200
+ trim: true,
201
+ lowercase: true,
202
+ validate: {
203
+ validator: function (v) {
204
+ if (!v) return true; // allow empty
205
+ return /^\w+([\.-]?\w+)@\w+([\.-]?\w+)(\.\w{2,3})+$/.test(v);
206
+ },
207
+ message: "Please enter a valid email address"
208
+ }
209
+ },
210
+ phone: {
211
+ type: String,
212
+ trim: true,
213
+ },
214
+ address: {
215
+ type: String,
216
+ trim: true,
217
+ },
218
+ city: {
219
+ type: String,
220
+ trim: true,
221
+ },
222
+ country: {
223
+ type: String,
224
+ trim: true,
225
+ default: "Kenya"
226
+ },
227
+ logo: {
228
+ type: String,
229
+ required: false,
230
+ },
231
+ digitalSignature: {
232
+ type: String,
233
+ required: false,
234
+ }
235
+ },
236
+ // GL accounts for accounting entries
237
+ glAccounts: {
238
+ invoice: {
239
+ debit: {
240
+ type: mongoose.Schema.Types.ObjectId,
241
+ ref: "GLAccount",
242
+ required: false,
243
+ },
244
+ credit: {
245
+ type: mongoose.Schema.Types.ObjectId,
246
+ ref: "GLAccount",
247
+ required: false,
248
+ }
249
+ },
250
+ payment: {
251
+ debit: {
252
+ type: mongoose.Schema.Types.ObjectId,
253
+ ref: "GLAccount",
254
+ required: false,
255
+ },
256
+ credit: {
257
+ type: mongoose.Schema.Types.ObjectId,
258
+ ref: "GLAccount",
259
+ required: false,
260
+ }
261
+ }
262
+ },
263
+
264
+ //GL ACCOUNT DOUBLE ENTRIES
265
+
266
+ invocieCreationDe: {
267
+ type: mongoose.Schema.Types.ObjectId,
268
+ ref: 'GLAccountDoubleEntries',
269
+ unique: true
270
+ },
271
+
272
+ invoicePaymentDe: {
273
+ type: mongoose.Schema.Types.ObjectId,
274
+ ref: 'GLAccountDoubleEntries',
275
+ unique: true
276
+ },
277
+
278
+ }, {
279
+ timestamps: true
280
+ });
281
+
282
+ const WaterMeterSettings = mongoose.model('WaterMeterSettings', waterMeterSettingsSchema);
283
+
277
284
  module.exports = WaterMeterSettings;
@@ -1,35 +1,35 @@
1
- const mongoose = require('mongoose');
2
-
3
- const singleDayWaterMeterHistorySchema = new mongoose.Schema({
4
- meterId: {
5
- type: mongoose.Schema.Types.ObjectId,
6
- ref: 'WaterMeter',
7
- required: true,
8
- index: true
9
- },
10
- date: {
11
- type: String,
12
- required: true
13
- },
14
- reading: {
15
- type: Number,
16
- required: true,
17
- min: 0
18
- },
19
- status: {
20
- type: String,
21
- enum: ['opened', 'closed', 'maintenance', 'faulty'],
22
- default: 'opened',
23
- },
24
- time: {
25
- type: String,
26
- required: true
27
- }
28
- }, {
29
- timestamps: true
30
- });
31
-
32
- singleDayWaterMeterHistorySchema.index({ meterId: 1, date: 1 });
33
- const SingleDayWaterMeterHistory = mongoose.model('SingleDayWaterMeterHistory', singleDayWaterMeterHistorySchema);
34
-
1
+ const mongoose = require('mongoose');
2
+
3
+ const singleDayWaterMeterHistorySchema = new mongoose.Schema({
4
+ meterId: {
5
+ type: mongoose.Schema.Types.ObjectId,
6
+ ref: 'WaterMeter',
7
+ required: true,
8
+ index: true
9
+ },
10
+ date: {
11
+ type: String,
12
+ required: true
13
+ },
14
+ reading: {
15
+ type: Number,
16
+ required: true,
17
+ min: 0
18
+ },
19
+ status: {
20
+ type: String,
21
+ enum: ['opened', 'closed', 'maintenance', 'faulty'],
22
+ default: 'opened',
23
+ },
24
+ time: {
25
+ type: String,
26
+ required: true
27
+ }
28
+ }, {
29
+ timestamps: true
30
+ });
31
+
32
+ singleDayWaterMeterHistorySchema.index({ meterId: 1, date: 1 });
33
+ const SingleDayWaterMeterHistory = mongoose.model('SingleDayWaterMeterHistory', singleDayWaterMeterHistorySchema);
34
+
35
35
  module.exports = SingleDayWaterMeterHistory;
@@ -1,16 +1,16 @@
1
- const mongoose = require('mongoose');
2
-
3
- const meterSizeSchema = new mongoose.Schema({
4
- code: {
5
- type: String,
6
- required: true,
7
- unique: true,
8
- trim: true, // Example: DN-15, DN-20, etc.
9
- }
10
- }, {
11
- timestamps: true
12
- });
13
-
14
- const MeterSize = mongoose.model('MeterSize', meterSizeSchema);
15
-
1
+ const mongoose = require('mongoose');
2
+
3
+ const meterSizeSchema = new mongoose.Schema({
4
+ code: {
5
+ type: String,
6
+ required: true,
7
+ unique: true,
8
+ trim: true, // Example: DN-15, DN-20, etc.
9
+ }
10
+ }, {
11
+ timestamps: true
12
+ });
13
+
14
+ const MeterSize = mongoose.model('MeterSize', meterSizeSchema);
15
+
16
16
  module.exports = MeterSize;