payservedb 8.1.4 → 8.1.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 (163) hide show
  1. package/.env +2 -2
  2. package/.idea/material_theme_project_new.xml +11 -11
  3. package/.idea/modules.xml +7 -7
  4. package/.idea/psdb.iml +11 -11
  5. package/.idea/vcs.xml +5 -5
  6. package/index.js +292 -291
  7. package/package.json +17 -17
  8. package/src/models/account.js +47 -47
  9. package/src/models/apilog.js +18 -18
  10. package/src/models/approvalsWorkflows.js +49 -49
  11. package/src/models/archivedapilog.js +18 -18
  12. package/src/models/asset.js +92 -92
  13. package/src/models/assetsAssignment.js +64 -64
  14. package/src/models/auditTrail.js +346 -346
  15. package/src/models/bankdetails.js +43 -43
  16. package/src/models/billerAddress.js +124 -124
  17. package/src/models/booking_invoice.js +151 -151
  18. package/src/models/bookinganalytics.js +63 -63
  19. package/src/models/bookingconfig.js +45 -45
  20. package/src/models/bookingproperty.js +122 -122
  21. package/src/models/bookingreservation.js +192 -192
  22. package/src/models/bookingrevenuerecord.js +84 -84
  23. package/src/models/budget.js +95 -95
  24. package/src/models/budgetCategory.js +19 -19
  25. package/src/models/campaigns.js +108 -108
  26. package/src/models/cashpayment.js +264 -264
  27. package/src/models/combinedUnits.js +62 -62
  28. package/src/models/common_area_electricity.js +38 -38
  29. package/src/models/common_area_generator.js +41 -41
  30. package/src/models/common_area_utility_alert.js +37 -37
  31. package/src/models/common_area_water.js +39 -39
  32. package/src/models/communication_status.js +33 -33
  33. package/src/models/communication_user_opt.js +24 -32
  34. package/src/models/company.js +53 -53
  35. package/src/models/coreBaseSettings.js +16 -16
  36. package/src/models/coreInvoiceSettings.js +100 -100
  37. package/src/models/country_tax.js +42 -42
  38. package/src/models/currency_settings.js +39 -39
  39. package/src/models/customer.js +208 -208
  40. package/src/models/dailyChecklist.js +312 -312
  41. package/src/models/default_payment_details.js +17 -17
  42. package/src/models/deliveryTimeMarks.js +18 -18
  43. package/src/models/dutyRosterChecklist.js +250 -250
  44. package/src/models/dutyroster.js +136 -136
  45. package/src/models/email.js +37 -37
  46. package/src/models/email_sms_queue.js +61 -61
  47. package/src/models/entry_exit.js +53 -53
  48. package/src/models/expense.js +99 -99
  49. package/src/models/expense_category.js +45 -45
  50. package/src/models/facility.js +62 -62
  51. package/src/models/facilityBillingPrices.js +29 -29
  52. package/src/models/facilityInvoice.js +223 -223
  53. package/src/models/facilityInvoicePayment.js +47 -47
  54. package/src/models/facilityInvoiceRecipient.js +32 -32
  55. package/src/models/facilityWalletTransactionsMetadata.js +236 -236
  56. package/src/models/facility_departements.js +20 -20
  57. package/src/models/facility_payment_details.js +20 -20
  58. package/src/models/facilityasset.js +25 -25
  59. package/src/models/faq.js +18 -18
  60. package/src/models/gl_account_double_entries.js +25 -25
  61. package/src/models/gl_accounts.js +56 -56
  62. package/src/models/gl_entries.js +49 -49
  63. package/src/models/goodsReceivedNotes.js +115 -115
  64. package/src/models/guard.js +47 -47
  65. package/src/models/handover.js +246 -246
  66. package/src/models/invoice.js +387 -387
  67. package/src/models/invoicing_schedule.js +36 -36
  68. package/src/models/item_inspection.js +96 -96
  69. package/src/models/leaseagreement.js +243 -243
  70. package/src/models/leasetemplate.js +17 -17
  71. package/src/models/levy.js +206 -206
  72. package/src/models/levy_invoice_settings.js +26 -26
  73. package/src/models/levycontract.js +173 -173
  74. package/src/models/levytype.js +23 -23
  75. package/src/models/maintenance_service_vendor.js +38 -38
  76. package/src/models/maintenance_services.js +17 -17
  77. package/src/models/maintenancerequisition.js +31 -31
  78. package/src/models/master_workplan.js +32 -32
  79. package/src/models/master_workplan_child.js +34 -34
  80. package/src/models/message.js +38 -38
  81. package/src/models/module.js +21 -21
  82. package/src/models/notification.js +44 -44
  83. package/src/models/paymentTermsMarks.js +19 -19
  84. package/src/models/penalty.js +76 -76
  85. package/src/models/pendingCredentials.js +32 -32
  86. package/src/models/powerMeterCommunicationProtocol.js +17 -17
  87. package/src/models/powerMeterCustomerAccount.js +78 -78
  88. package/src/models/powerMeterCustomerBand.js +14 -14
  89. package/src/models/powerMeterDailyReading.js +30 -30
  90. package/src/models/powerMeterGateways.js +40 -40
  91. package/src/models/powerMeterMonthlyReading.js +34 -34
  92. package/src/models/powerMeterPowerCharges.js +85 -85
  93. package/src/models/powerMeterSettings.js +159 -159
  94. package/src/models/powerMeterSingleDayReading.js +32 -32
  95. package/src/models/powerMeters.js +116 -116
  96. package/src/models/powerMetersManufacturer.js +14 -14
  97. package/src/models/power_meter_account.js +81 -81
  98. package/src/models/power_meter_command_logs.js +30 -30
  99. package/src/models/power_meter_command_queue.js +33 -33
  100. package/src/models/power_meter_negative_balance.js +44 -44
  101. package/src/models/power_prepaid_credits.js +47 -47
  102. package/src/models/power_prepaid_debits.js +53 -53
  103. package/src/models/power_prepaid_orders.js +78 -78
  104. package/src/models/power_sms_notification.js +26 -26
  105. package/src/models/propertyManagerContract.js +556 -556
  106. package/src/models/propertyManagerRevenue.js +195 -195
  107. package/src/models/purchaseOrderInvoice.js +74 -74
  108. package/src/models/purchase_order.js +213 -213
  109. package/src/models/purchase_request.js +110 -110
  110. package/src/models/refresh_token.js +23 -23
  111. package/src/models/reminder.js +197 -197
  112. package/src/models/report.js +13 -13
  113. package/src/models/resident.js +121 -121
  114. package/src/models/rfq_details.js +131 -131
  115. package/src/models/rfq_response.js +153 -153
  116. package/src/models/service_charge_invoice_upload.js +42 -42
  117. package/src/models/service_charge_payments.js +27 -27
  118. package/src/models/servicerequest.js +55 -55
  119. package/src/models/settings.js +62 -62
  120. package/src/models/short_urls.js +21 -0
  121. package/src/models/smart_meter_daily_consumption.js +44 -44
  122. package/src/models/sms_africastalking.js +20 -20
  123. package/src/models/sms_balance_notification.js +26 -26
  124. package/src/models/sms_meliora.js +20 -20
  125. package/src/models/staff.js +36 -36
  126. package/src/models/stocksandspare.js +161 -161
  127. package/src/models/suppliers.js +74 -74
  128. package/src/models/tickets.js +121 -121
  129. package/src/models/unitManagementTemplate.js +44 -44
  130. package/src/models/unitasset.js +25 -25
  131. package/src/models/units.js +117 -117
  132. package/src/models/user.js +186 -186
  133. package/src/models/valueaddedservices.js +79 -79
  134. package/src/models/vas_invoices_upload.js +50 -50
  135. package/src/models/vas_payments.js +24 -24
  136. package/src/models/vasinvoice.js +192 -192
  137. package/src/models/vasvendor.js +57 -57
  138. package/src/models/visitLog.js +95 -95
  139. package/src/models/visitor.js +67 -67
  140. package/src/models/waitlist.js +45 -45
  141. package/src/models/wallet.js +44 -44
  142. package/src/models/wallet_transactions.js +50 -50
  143. package/src/models/water_invoice.js +351 -351
  144. package/src/models/water_meter_Command_Queue.js +33 -33
  145. package/src/models/water_meter_account.js +82 -82
  146. package/src/models/water_meter_billing.js +58 -58
  147. package/src/models/water_meter_communication.js +17 -17
  148. package/src/models/water_meter_communication_logs.js +39 -39
  149. package/src/models/water_meter_concentrator.js +70 -70
  150. package/src/models/water_meter_daily_history.js +32 -32
  151. package/src/models/water_meter_high_risk.js +36 -36
  152. package/src/models/water_meter_iot_cards.js +34 -34
  153. package/src/models/water_meter_manufacturer.js +35 -35
  154. package/src/models/water_meter_monthly_history.js +36 -36
  155. package/src/models/water_meter_negative_amounts.js +44 -44
  156. package/src/models/water_meter_settings.js +276 -276
  157. package/src/models/water_meter_single_day_history.js +34 -34
  158. package/src/models/water_meter_size.js +15 -15
  159. package/src/models/water_meters.js +133 -133
  160. package/src/models/water_meters_delivery.js +76 -76
  161. package/src/models/water_prepaid_credit.js +47 -47
  162. package/src/models/water_prepaid_debit.js +50 -50
  163. package/src/models/workorder.js +49 -49
@@ -1,193 +1,193 @@
1
- const mongoose = require('mongoose');
2
-
3
- // Define the schema for VasInvoices
4
- const vasInvoiceSchema = new mongoose.Schema({
5
- invoiceNumber: {
6
- type: String,
7
- required: true,
8
- unique: true,
9
- },
10
- accountNumber: {
11
- type: String,
12
- required: true,
13
- unique: true
14
- },
15
- facilityId: {
16
- type: mongoose.Schema.Types.ObjectId,
17
- required: true
18
- },
19
- serviceId: {
20
- type: mongoose.Schema.Types.ObjectId,
21
- required: true
22
- },
23
- customerId: {
24
- type: mongoose.Schema.Types.ObjectId,
25
- required: true
26
- },
27
- dueDate: {
28
- type: Date,
29
- required: true,
30
- },
31
- invoiceNote: {
32
- type: String,
33
- default: "Payment is due within 30 days",
34
- },
35
- status: {
36
- type: String,
37
- required: true,
38
- enum: ['Pending', 'Paid', 'Partially Paid', 'Cancelled', 'Overdue', 'Unpaid', 'Void'],
39
- default: 'Pending'
40
- },
41
- unit: {
42
- type: String,
43
- required: true
44
- },
45
- serviceName: {
46
- type: String,
47
- default: 'Service Fee'
48
- },
49
- amountPaid: {
50
- type: Number,
51
- default: 0
52
- },
53
- subTotal: {
54
- type: Number,
55
- required: true,
56
- },
57
- tax: {
58
- type: Number,
59
- default: 0
60
- },
61
- amount: {
62
- type: Number,
63
- required: true
64
- },
65
- currency: {
66
- id: {
67
- type: mongoose.Schema.Types.ObjectId
68
- },
69
- name: {
70
- type: String,
71
- default: 'Kenyan Shilling'
72
- },
73
- code: {
74
- type: String,
75
- default: 'KES'
76
- },
77
- symbol: {
78
- type: String,
79
- default: 'KSh'
80
- }
81
- },
82
- items: [{
83
- description: {
84
- type: String,
85
- required: true
86
- },
87
- quantity: {
88
- type: Number,
89
- default: 1
90
- },
91
- unitPrice: {
92
- type: Number,
93
- required: true
94
- }
95
- }],
96
- reconciliationHistory: [{
97
- date: {
98
- type: Date,
99
- default: Date.now
100
- },
101
- amount: {
102
- type: Number,
103
- required: true
104
- },
105
- type: {
106
- type: String,
107
- default: 'Manual'
108
- },
109
- paymentReference: String,
110
- paymentCompletion: {
111
- type: String,
112
- default: 'Completed'
113
- },
114
- sourceInvoice: String,
115
- destinationInvoice: String,
116
- notes: String,
117
- remainingBalance: Number
118
- }],
119
- customerInfo: {
120
- fullName: {
121
- type: String,
122
- default: 'Customer'
123
- }
124
- },
125
- paymentDetails: {
126
- paymentStatus: {
127
- type: String,
128
- enum: ['Pending', 'Completed', 'Failed', 'Partial'],
129
- default: 'Pending'
130
- },
131
- paymentMethod: String,
132
- paymentDate: Date,
133
- transactionId: String,
134
- mobilePayment: {
135
- type: Boolean,
136
- default: false
137
- }
138
- },
139
- overpay: {
140
- type: Number,
141
- default: 0
142
- },
143
- // GL Integration Fields
144
- invoiceGLEntryId: {
145
- type: mongoose.Schema.Types.ObjectId,
146
- ref: 'GLEntry'
147
- },
148
- taxGLEntryId: {
149
- type: mongoose.Schema.Types.ObjectId,
150
- ref: 'GLEntry'
151
- },
152
- glDoubleEntryId: {
153
- type: mongoose.Schema.Types.ObjectId,
154
- ref: 'GLAccountDoubleEntries'
155
- },
156
- // Tax GL details
157
- taxDetails: [{
158
- taxId: {
159
- type: mongoose.Schema.Types.ObjectId,
160
- ref: 'CountryTaxRate'
161
- },
162
- taxName: {
163
- type: String
164
- },
165
- taxRate: {
166
- type: Number
167
- },
168
- taxAmount: {
169
- type: Number
170
- },
171
- glEntryId: {
172
- type: mongoose.Schema.Types.ObjectId,
173
- ref: 'GLEntry'
174
- }
175
- }]
176
- }, {
177
- timestamps: true
178
- });
179
-
180
- // Add pre-save middleware to check if invoice is overdue
181
- vasInvoiceSchema.pre('save', function (next) {
182
- if (this.isModified('dueDate') || this.isNew) {
183
- const today = new Date();
184
- if (this.dueDate < today && this.status === 'Pending') {
185
- this.status = 'Overdue';
186
- }
187
- }
188
- next();
189
- });
190
-
191
- const VasInvoice = mongoose.model('VasInvoice', vasInvoiceSchema);
192
-
1
+ const mongoose = require('mongoose');
2
+
3
+ // Define the schema for VasInvoices
4
+ const vasInvoiceSchema = new mongoose.Schema({
5
+ invoiceNumber: {
6
+ type: String,
7
+ required: true,
8
+ unique: true,
9
+ },
10
+ accountNumber: {
11
+ type: String,
12
+ required: true,
13
+ unique: true
14
+ },
15
+ facilityId: {
16
+ type: mongoose.Schema.Types.ObjectId,
17
+ required: true
18
+ },
19
+ serviceId: {
20
+ type: mongoose.Schema.Types.ObjectId,
21
+ required: true
22
+ },
23
+ customerId: {
24
+ type: mongoose.Schema.Types.ObjectId,
25
+ required: true
26
+ },
27
+ dueDate: {
28
+ type: Date,
29
+ required: true,
30
+ },
31
+ invoiceNote: {
32
+ type: String,
33
+ default: "Payment is due within 30 days",
34
+ },
35
+ status: {
36
+ type: String,
37
+ required: true,
38
+ enum: ['Pending', 'Paid', 'Partially Paid', 'Cancelled', 'Overdue', 'Unpaid', 'Void'],
39
+ default: 'Pending'
40
+ },
41
+ unit: {
42
+ type: String,
43
+ required: true
44
+ },
45
+ serviceName: {
46
+ type: String,
47
+ default: 'Service Fee'
48
+ },
49
+ amountPaid: {
50
+ type: Number,
51
+ default: 0
52
+ },
53
+ subTotal: {
54
+ type: Number,
55
+ required: true,
56
+ },
57
+ tax: {
58
+ type: Number,
59
+ default: 0
60
+ },
61
+ amount: {
62
+ type: Number,
63
+ required: true
64
+ },
65
+ currency: {
66
+ id: {
67
+ type: mongoose.Schema.Types.ObjectId
68
+ },
69
+ name: {
70
+ type: String,
71
+ default: 'Kenyan Shilling'
72
+ },
73
+ code: {
74
+ type: String,
75
+ default: 'KES'
76
+ },
77
+ symbol: {
78
+ type: String,
79
+ default: 'KSh'
80
+ }
81
+ },
82
+ items: [{
83
+ description: {
84
+ type: String,
85
+ required: true
86
+ },
87
+ quantity: {
88
+ type: Number,
89
+ default: 1
90
+ },
91
+ unitPrice: {
92
+ type: Number,
93
+ required: true
94
+ }
95
+ }],
96
+ reconciliationHistory: [{
97
+ date: {
98
+ type: Date,
99
+ default: Date.now
100
+ },
101
+ amount: {
102
+ type: Number,
103
+ required: true
104
+ },
105
+ type: {
106
+ type: String,
107
+ default: 'Manual'
108
+ },
109
+ paymentReference: String,
110
+ paymentCompletion: {
111
+ type: String,
112
+ default: 'Completed'
113
+ },
114
+ sourceInvoice: String,
115
+ destinationInvoice: String,
116
+ notes: String,
117
+ remainingBalance: Number
118
+ }],
119
+ customerInfo: {
120
+ fullName: {
121
+ type: String,
122
+ default: 'Customer'
123
+ }
124
+ },
125
+ paymentDetails: {
126
+ paymentStatus: {
127
+ type: String,
128
+ enum: ['Pending', 'Completed', 'Failed', 'Partial'],
129
+ default: 'Pending'
130
+ },
131
+ paymentMethod: String,
132
+ paymentDate: Date,
133
+ transactionId: String,
134
+ mobilePayment: {
135
+ type: Boolean,
136
+ default: false
137
+ }
138
+ },
139
+ overpay: {
140
+ type: Number,
141
+ default: 0
142
+ },
143
+ // GL Integration Fields
144
+ invoiceGLEntryId: {
145
+ type: mongoose.Schema.Types.ObjectId,
146
+ ref: 'GLEntry'
147
+ },
148
+ taxGLEntryId: {
149
+ type: mongoose.Schema.Types.ObjectId,
150
+ ref: 'GLEntry'
151
+ },
152
+ glDoubleEntryId: {
153
+ type: mongoose.Schema.Types.ObjectId,
154
+ ref: 'GLAccountDoubleEntries'
155
+ },
156
+ // Tax GL details
157
+ taxDetails: [{
158
+ taxId: {
159
+ type: mongoose.Schema.Types.ObjectId,
160
+ ref: 'CountryTaxRate'
161
+ },
162
+ taxName: {
163
+ type: String
164
+ },
165
+ taxRate: {
166
+ type: Number
167
+ },
168
+ taxAmount: {
169
+ type: Number
170
+ },
171
+ glEntryId: {
172
+ type: mongoose.Schema.Types.ObjectId,
173
+ ref: 'GLEntry'
174
+ }
175
+ }]
176
+ }, {
177
+ timestamps: true
178
+ });
179
+
180
+ // Add pre-save middleware to check if invoice is overdue
181
+ vasInvoiceSchema.pre('save', function (next) {
182
+ if (this.isModified('dueDate') || this.isNew) {
183
+ const today = new Date();
184
+ if (this.dueDate < today && this.status === 'Pending') {
185
+ this.status = 'Overdue';
186
+ }
187
+ }
188
+ next();
189
+ });
190
+
191
+ const VasInvoice = mongoose.model('VasInvoice', vasInvoiceSchema);
192
+
193
193
  module.exports = VasInvoice;
@@ -1,58 +1,58 @@
1
- const mongoose = require('mongoose');
2
-
3
- // Define the schema for VasVendor
4
- const vasVendorSchema = new mongoose.Schema({
5
- facilityId: {
6
- type: mongoose.Schema.Types.ObjectId,
7
- ref: 'Facility',
8
- required: true,
9
- },
10
- name: {
11
- type: String,
12
- required: true,
13
- trim: true
14
- },
15
- location: {
16
- type: String,
17
- required: true,
18
- trim: true
19
- },
20
- jobDescription: {
21
- type: String,
22
- required: true,
23
- trim: true
24
- },
25
- offers: [{
26
- serviceId: {
27
- type: mongoose.Schema.Types.ObjectId,
28
- ref: 'Service', // Reference to the Service model
29
- required: true
30
- },
31
- amount: {
32
- type: Number,
33
- required: true,
34
- min: [0, 'Amount must be a positive number']
35
- }
36
- }],
37
- contactDetails: {
38
- name: {
39
- type: String,
40
- required: true
41
- },
42
- phone: {
43
- type: String,
44
- required: true
45
- },
46
- email: {
47
- type: String,
48
- required: true,
49
- match: [/.+\@.+\..+/, 'Please provide a valid email address']
50
- }
51
- }
52
- }, {
53
- timestamps: true // This will automatically add createdAt and updatedAt fields
54
- });
55
-
56
- const VasVendor = mongoose.model('VasVendor', vasVendorSchema);
57
-
1
+ const mongoose = require('mongoose');
2
+
3
+ // Define the schema for VasVendor
4
+ const vasVendorSchema = new mongoose.Schema({
5
+ facilityId: {
6
+ type: mongoose.Schema.Types.ObjectId,
7
+ ref: 'Facility',
8
+ required: true,
9
+ },
10
+ name: {
11
+ type: String,
12
+ required: true,
13
+ trim: true
14
+ },
15
+ location: {
16
+ type: String,
17
+ required: true,
18
+ trim: true
19
+ },
20
+ jobDescription: {
21
+ type: String,
22
+ required: true,
23
+ trim: true
24
+ },
25
+ offers: [{
26
+ serviceId: {
27
+ type: mongoose.Schema.Types.ObjectId,
28
+ ref: 'Service', // Reference to the Service model
29
+ required: true
30
+ },
31
+ amount: {
32
+ type: Number,
33
+ required: true,
34
+ min: [0, 'Amount must be a positive number']
35
+ }
36
+ }],
37
+ contactDetails: {
38
+ name: {
39
+ type: String,
40
+ required: true
41
+ },
42
+ phone: {
43
+ type: String,
44
+ required: true
45
+ },
46
+ email: {
47
+ type: String,
48
+ required: true,
49
+ match: [/.+\@.+\..+/, 'Please provide a valid email address']
50
+ }
51
+ }
52
+ }, {
53
+ timestamps: true // This will automatically add createdAt and updatedAt fields
54
+ });
55
+
56
+ const VasVendor = mongoose.model('VasVendor', vasVendorSchema);
57
+
58
58
  module.exports = VasVendor;
@@ -1,95 +1,95 @@
1
- const mongoose = require('mongoose');
2
-
3
- // Define the schema for visit logs
4
- const visitLogSchema = new mongoose.Schema({
5
- visitorName: {
6
- type: String,
7
- required: true
8
- },
9
- visitorId: {
10
- type: mongoose.Schema.Types.ObjectId,
11
- ref: 'Visitor',
12
- required: true
13
- },
14
- residentName: {
15
- type: String,
16
- required: false
17
- },
18
- phoneNumber: {
19
- type: String,
20
- trim: true
21
- },
22
- residentId: {
23
- type: mongoose.Schema.Types.ObjectId,
24
- },
25
- qrCode: {
26
- type: Boolean,
27
- required: false
28
- },
29
- houseNumber: {
30
- type: String,
31
- required: false
32
- },
33
- startTime: {
34
- type: String, // Changed to Date for better handling of time
35
- required: true
36
- },
37
- endTime: {
38
- type: Date, // Changed to Date for better handling of time
39
- required: false
40
- },
41
- days: {
42
- type: Number,
43
- required: false
44
- },
45
- division: {
46
- type: String,
47
- required: false
48
- },
49
- entryPoint: {
50
- type: String,
51
- required: false
52
- },
53
- exitPoint: {
54
- type: String,
55
- required: false
56
- },
57
- guardId: {
58
- type: mongoose.Schema.Types.ObjectId,
59
- ref: 'User',
60
- required: false
61
- },
62
- status: {
63
- type: String,
64
- required: true,
65
- enum: ['Visit Confirmation', 'Scheduled', 'Checked In', 'Checked Out', 'Cancelled'] // Define valid statuses
66
- // Define valid statuses
67
- },
68
- vehicle: {
69
- registration: String,
70
- make: String,
71
- color: String,
72
- occupants: String,
73
- },
74
- visitationCode: {
75
- type: Number,
76
- required: false
77
- },
78
- requestedBy: {
79
- type: mongoose.Schema.Types.ObjectId,
80
- ref: "User",
81
- required: false
82
- },
83
- facilityId: {
84
- type: mongoose.Schema.Types.ObjectId,
85
- ref: 'Facility',
86
- required: true // Ensures a facilityId is always provided
87
- }
88
- }, {
89
- timestamps: true // Automatically add createdAt and updatedAt fields
90
- });
91
-
92
- // Compile the model from the schema
93
- const VisitLog = mongoose.model('VisitLog', visitLogSchema);
94
-
95
- module.exports = VisitLog;
1
+ const mongoose = require('mongoose');
2
+
3
+ // Define the schema for visit logs
4
+ const visitLogSchema = new mongoose.Schema({
5
+ visitorName: {
6
+ type: String,
7
+ required: true
8
+ },
9
+ visitorId: {
10
+ type: mongoose.Schema.Types.ObjectId,
11
+ ref: 'Visitor',
12
+ required: true
13
+ },
14
+ residentName: {
15
+ type: String,
16
+ required: false
17
+ },
18
+ phoneNumber: {
19
+ type: String,
20
+ trim: true
21
+ },
22
+ residentId: {
23
+ type: mongoose.Schema.Types.ObjectId,
24
+ },
25
+ qrCode: {
26
+ type: Boolean,
27
+ required: false
28
+ },
29
+ houseNumber: {
30
+ type: String,
31
+ required: false
32
+ },
33
+ startTime: {
34
+ type: String, // Changed to Date for better handling of time
35
+ required: true
36
+ },
37
+ endTime: {
38
+ type: Date, // Changed to Date for better handling of time
39
+ required: false
40
+ },
41
+ days: {
42
+ type: Number,
43
+ required: false
44
+ },
45
+ division: {
46
+ type: String,
47
+ required: false
48
+ },
49
+ entryPoint: {
50
+ type: String,
51
+ required: false
52
+ },
53
+ exitPoint: {
54
+ type: String,
55
+ required: false
56
+ },
57
+ guardId: {
58
+ type: mongoose.Schema.Types.ObjectId,
59
+ ref: 'User',
60
+ required: false
61
+ },
62
+ status: {
63
+ type: String,
64
+ required: true,
65
+ enum: ['Visit Confirmation', 'Scheduled', 'Checked In', 'Checked Out', 'Cancelled'] // Define valid statuses
66
+ // Define valid statuses
67
+ },
68
+ vehicle: {
69
+ registration: String,
70
+ make: String,
71
+ color: String,
72
+ occupants: String,
73
+ },
74
+ visitationCode: {
75
+ type: Number,
76
+ required: false
77
+ },
78
+ requestedBy: {
79
+ type: mongoose.Schema.Types.ObjectId,
80
+ ref: "User",
81
+ required: false
82
+ },
83
+ facilityId: {
84
+ type: mongoose.Schema.Types.ObjectId,
85
+ ref: 'Facility',
86
+ required: true // Ensures a facilityId is always provided
87
+ }
88
+ }, {
89
+ timestamps: true // Automatically add createdAt and updatedAt fields
90
+ });
91
+
92
+ // Compile the model from the schema
93
+ const VisitLog = mongoose.model('VisitLog', visitLogSchema);
94
+
95
+ module.exports = VisitLog;