payservedb 8.2.9 → 8.3.1

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/index.js +306 -306
  3. package/package.json +17 -17
  4. package/src/models/account.js +52 -52
  5. package/src/models/agent_departments.js +59 -59
  6. package/src/models/agent_notifications.js +53 -53
  7. package/src/models/agent_performance.js +127 -127
  8. package/src/models/agent_roles.js +77 -77
  9. package/src/models/agents.js +154 -154
  10. package/src/models/apilog.js +18 -18
  11. package/src/models/approvalsWorkflows.js +49 -49
  12. package/src/models/archivedapilog.js +18 -18
  13. package/src/models/asset.js +92 -92
  14. package/src/models/assetsAssignment.js +64 -64
  15. package/src/models/auditTrail.js +346 -346
  16. package/src/models/bankdetails.js +43 -43
  17. package/src/models/billerAddress.js +124 -124
  18. package/src/models/booking_invoice.js +151 -151
  19. package/src/models/bookinganalytics.js +63 -63
  20. package/src/models/bookingconfig.js +45 -45
  21. package/src/models/bookingproperty.js +122 -122
  22. package/src/models/bookingreservation.js +192 -192
  23. package/src/models/bookingrevenuerecord.js +84 -84
  24. package/src/models/budget.js +95 -95
  25. package/src/models/budgetCategory.js +19 -19
  26. package/src/models/campaigns.js +108 -108
  27. package/src/models/cashpayment.js +264 -264
  28. package/src/models/combinedUnits.js +62 -62
  29. package/src/models/common_area_electricity.js +38 -38
  30. package/src/models/common_area_generator.js +41 -41
  31. package/src/models/common_area_utility_alert.js +37 -37
  32. package/src/models/common_area_water.js +39 -39
  33. package/src/models/communication_status.js +33 -33
  34. package/src/models/communication_user_opt.js +32 -32
  35. package/src/models/company.js +53 -53
  36. package/src/models/coreBaseSettings.js +16 -16
  37. package/src/models/coreInvoiceSettings.js +100 -100
  38. package/src/models/counter_schema.js +21 -21
  39. package/src/models/country_tax.js +42 -42
  40. package/src/models/currency_settings.js +39 -39
  41. package/src/models/customer.js +210 -210
  42. package/src/models/customer_satisfaction_survey.js +278 -278
  43. package/src/models/customer_surveys.js +139 -139
  44. package/src/models/customer_tickets.js +239 -239
  45. package/src/models/dailyChecklist.js +312 -312
  46. package/src/models/default_payment_details.js +17 -17
  47. package/src/models/deliveryTimeMarks.js +18 -18
  48. package/src/models/document_type.js +19 -19
  49. package/src/models/dutyRosterChecklist.js +250 -250
  50. package/src/models/dutyroster.js +136 -136
  51. package/src/models/email.js +37 -37
  52. package/src/models/email_sms_queue.js +61 -61
  53. package/src/models/entry_exit.js +53 -53
  54. package/src/models/expense.js +99 -99
  55. package/src/models/expense_category.js +45 -45
  56. package/src/models/facility.js +62 -62
  57. package/src/models/facilityBillingPrices.js +29 -29
  58. package/src/models/facilityInvoice.js +224 -223
  59. package/src/models/facilityInvoicePayment.js +52 -47
  60. package/src/models/facilityInvoiceRecipient.js +32 -32
  61. package/src/models/facilityWalletTransactionsMetadata.js +236 -236
  62. package/src/models/facility_departements.js +20 -20
  63. package/src/models/facility_payment_details.js +20 -20
  64. package/src/models/facilityasset.js +25 -25
  65. package/src/models/faq.js +18 -18
  66. package/src/models/gl_account_double_entries.js +25 -25
  67. package/src/models/gl_accounts.js +56 -56
  68. package/src/models/gl_entries.js +49 -49
  69. package/src/models/goodsReceivedNotes.js +115 -115
  70. package/src/models/guard.js +47 -47
  71. package/src/models/handover.js +247 -247
  72. package/src/models/inspection_category.js +38 -38
  73. package/src/models/invoice.js +387 -387
  74. package/src/models/invoicing_schedule.js +36 -36
  75. package/src/models/item_inspection.js +96 -96
  76. package/src/models/knowledge_base.js +109 -109
  77. package/src/models/knowledge_base_rating.js +44 -44
  78. package/src/models/leaseagreement.js +243 -243
  79. package/src/models/leasetemplate.js +17 -17
  80. package/src/models/levy.js +223 -223
  81. package/src/models/levy_invoice_settings.js +26 -26
  82. package/src/models/levycontract.js +173 -173
  83. package/src/models/levytype.js +23 -23
  84. package/src/models/maintenance_service_vendor.js +38 -38
  85. package/src/models/maintenance_services.js +17 -17
  86. package/src/models/maintenancerequisition.js +31 -31
  87. package/src/models/master_workplan.js +32 -32
  88. package/src/models/master_workplan_child.js +34 -34
  89. package/src/models/message.js +38 -38
  90. package/src/models/module.js +21 -21
  91. package/src/models/notification.js +44 -44
  92. package/src/models/paymentTermsMarks.js +19 -19
  93. package/src/models/penalty.js +76 -76
  94. package/src/models/pendingCredentials.js +32 -32
  95. package/src/models/powerMeterCommunicationProtocol.js +17 -17
  96. package/src/models/powerMeterCustomerAccount.js +78 -78
  97. package/src/models/powerMeterCustomerBand.js +14 -14
  98. package/src/models/powerMeterDailyReading.js +30 -30
  99. package/src/models/powerMeterGateways.js +40 -40
  100. package/src/models/powerMeterMonthlyReading.js +34 -34
  101. package/src/models/powerMeterPowerCharges.js +85 -85
  102. package/src/models/powerMeterSettings.js +159 -159
  103. package/src/models/powerMeterSingleDayReading.js +32 -32
  104. package/src/models/powerMeters.js +116 -116
  105. package/src/models/powerMetersManufacturer.js +14 -14
  106. package/src/models/power_meter_account.js +81 -81
  107. package/src/models/power_meter_command_logs.js +30 -30
  108. package/src/models/power_meter_command_queue.js +33 -33
  109. package/src/models/power_meter_negative_balance.js +44 -44
  110. package/src/models/power_prepaid_credits.js +47 -47
  111. package/src/models/power_prepaid_debits.js +53 -53
  112. package/src/models/power_prepaid_orders.js +78 -78
  113. package/src/models/power_sms_notification.js +26 -26
  114. package/src/models/propertyManagerContract.js +556 -556
  115. package/src/models/propertyManagerRevenue.js +195 -195
  116. package/src/models/purchaseOrderInvoice.js +74 -74
  117. package/src/models/purchase_order.js +213 -213
  118. package/src/models/purchase_request.js +110 -110
  119. package/src/models/refresh_token.js +23 -23
  120. package/src/models/reminder.js +197 -197
  121. package/src/models/report.js +13 -13
  122. package/src/models/resident.js +121 -121
  123. package/src/models/rfq_details.js +131 -131
  124. package/src/models/rfq_response.js +153 -153
  125. package/src/models/service_charge_invoice_upload.js +42 -42
  126. package/src/models/service_charge_payments.js +27 -27
  127. package/src/models/servicerequest.js +55 -55
  128. package/src/models/settings.js +62 -62
  129. package/src/models/short_urls.js +21 -21
  130. package/src/models/smart_meter_daily_consumption.js +44 -44
  131. package/src/models/sms_africastalking.js +20 -20
  132. package/src/models/sms_balance_notification.js +26 -26
  133. package/src/models/sms_meliora.js +20 -20
  134. package/src/models/staff.js +36 -36
  135. package/src/models/stocksandspare.js +161 -161
  136. package/src/models/suppliers.js +74 -74
  137. package/src/models/tickets.js +173 -173
  138. package/src/models/tickets_category.js +72 -72
  139. package/src/models/unitManagementTemplate.js +44 -44
  140. package/src/models/unitasset.js +25 -25
  141. package/src/models/units.js +118 -118
  142. package/src/models/user.js +186 -186
  143. package/src/models/valueaddedservices.js +79 -79
  144. package/src/models/vas_invoices_upload.js +50 -50
  145. package/src/models/vas_payments.js +24 -24
  146. package/src/models/vasinvoice.js +192 -192
  147. package/src/models/vasvendor.js +57 -57
  148. package/src/models/visitLog.js +95 -95
  149. package/src/models/visitor.js +67 -67
  150. package/src/models/waitlist.js +45 -45
  151. package/src/models/wallet.js +44 -44
  152. package/src/models/wallet_transactions.js +50 -50
  153. package/src/models/water_invoice.js +351 -351
  154. package/src/models/water_meter_Command_Queue.js +33 -33
  155. package/src/models/water_meter_account.js +82 -82
  156. package/src/models/water_meter_billing.js +58 -58
  157. package/src/models/water_meter_communication.js +17 -17
  158. package/src/models/water_meter_communication_logs.js +39 -39
  159. package/src/models/water_meter_concentrator.js +70 -70
  160. package/src/models/water_meter_daily_history.js +32 -32
  161. package/src/models/water_meter_high_risk.js +36 -36
  162. package/src/models/water_meter_iot_cards.js +34 -34
  163. package/src/models/water_meter_manufacturer.js +35 -35
  164. package/src/models/water_meter_monthly_history.js +36 -36
  165. package/src/models/water_meter_negative_amounts.js +44 -44
  166. package/src/models/water_meter_settings.js +276 -276
  167. package/src/models/water_meter_single_day_history.js +34 -34
  168. package/src/models/water_meter_size.js +15 -15
  169. package/src/models/water_meters.js +133 -133
  170. package/src/models/water_meters_delivery.js +76 -76
  171. package/src/models/water_prepaid_credit.js +47 -47
  172. package/src/models/water_prepaid_debit.js +50 -50
  173. package/src/models/workorder.js +49 -49
  174. package/.idea/material_theme_project_new.xml +0 -12
  175. package/.idea/modules.xml +0 -8
  176. package/.idea/psdb.iml +0 -12
  177. package/.idea/vcs.xml +0 -6
@@ -1,44 +1,44 @@
1
- const mongoose = require('mongoose');
2
-
3
- const BankDetailsSchema = new mongoose.Schema({
4
- accountName: {
5
- type: String,
6
- required: true
7
- },
8
- accountNumber: {
9
- type: String,
10
- required: true,
11
- },
12
- bankName: {
13
- type: String,
14
- required: true,
15
- },
16
- branchName: {
17
- type: String,
18
- required: true,
19
- },
20
- branchCode: {
21
- type: String,
22
- required: false,
23
- },
24
- bankCode: {
25
- type: String,
26
- required: false,
27
- },
28
- bankPaybill: {
29
- type: String,
30
- required: false,
31
- },
32
- isDefault: {
33
- type: Boolean,
34
- default: false
35
- },
36
- facilityId: {
37
- type: mongoose.Schema.Types.ObjectId,
38
- ref: 'Facility'
39
- },
40
- });
41
-
42
- const BankDetails = mongoose.model('BankDetails', BankDetailsSchema);
43
-
1
+ const mongoose = require('mongoose');
2
+
3
+ const BankDetailsSchema = new mongoose.Schema({
4
+ accountName: {
5
+ type: String,
6
+ required: true
7
+ },
8
+ accountNumber: {
9
+ type: String,
10
+ required: true,
11
+ },
12
+ bankName: {
13
+ type: String,
14
+ required: true,
15
+ },
16
+ branchName: {
17
+ type: String,
18
+ required: true,
19
+ },
20
+ branchCode: {
21
+ type: String,
22
+ required: false,
23
+ },
24
+ bankCode: {
25
+ type: String,
26
+ required: false,
27
+ },
28
+ bankPaybill: {
29
+ type: String,
30
+ required: false,
31
+ },
32
+ isDefault: {
33
+ type: Boolean,
34
+ default: false
35
+ },
36
+ facilityId: {
37
+ type: mongoose.Schema.Types.ObjectId,
38
+ ref: 'Facility'
39
+ },
40
+ });
41
+
42
+ const BankDetails = mongoose.model('BankDetails', BankDetailsSchema);
43
+
44
44
  module.exports = BankDetails;
@@ -1,124 +1,124 @@
1
- const mongoose = require("mongoose");
2
-
3
- // Define the schema for Biller Address
4
- const billerAddressSchema = new mongoose.Schema(
5
- {
6
- name: {
7
- type: String,
8
- required: [true, "Address name is required"],
9
- trim: true,
10
- minlength: [1, "Address name must be at least 1 character long"],
11
- },
12
- companyName: {
13
- type: String,
14
- required: [true, "Company name is required"],
15
- trim: true,
16
- },
17
- website: {
18
- type: String,
19
- trim: true,
20
- validate: {
21
- validator: function (v) {
22
- // If website is empty or null, it's valid (optional field)
23
- if (!v || v.trim() === '') return true;
24
-
25
- // Updated regex pattern that's more flexible for various URL formats
26
- return /^(https?:\/\/)?(www\.)?[-a-zA-Z0-9@:%.\+~#=]{1,256}\.[a-zA-Z0-9()]{1,6}\b([-a-zA-Z0-9()@:%\+.~#?&//=]*)$/.test(v);
27
- },
28
- message: "Please enter a valid website URL (e.g., https://example.com, www.example.com, or example.com)"
29
- }
30
- },
31
- email: {
32
- type: String,
33
- required: [true, "Email is required"],
34
- trim: true,
35
- lowercase: true,
36
- validate: {
37
- validator: function (v) {
38
- return /^\w+([\.-]?\w+)@\w+([\.-]?\w+)(\.\w{2,3})+$/.test(v);
39
- },
40
- message: "Please enter a valid email address"
41
- }
42
- },
43
- phone: {
44
- type: String,
45
- trim: true,
46
- },
47
- address: {
48
- type: String,
49
- required: [true, "Address is required"],
50
- trim: true,
51
- },
52
- city: {
53
- type: String,
54
- required: [true, "City is required"],
55
- trim: true,
56
- },
57
- state: {
58
- type: String,
59
- trim: true,
60
- },
61
- country: {
62
- type: String,
63
- required: [true, "Country is required"],
64
- trim: true,
65
- default: "Kenya"
66
- },
67
- postalCode: {
68
- type: String,
69
- trim: true,
70
- },
71
- logo: {
72
- type: String, // Will store the file path/URL of the uploaded logo
73
- required: false,
74
- },
75
- digitalSignature: {
76
- type: String, // Will store the file path/URL of the uploaded digital signature
77
- required: false,
78
- },
79
- isDefault: {
80
- type: Boolean,
81
- default: false,
82
- },
83
- facilityId: {
84
- type: mongoose.Schema.Types.ObjectId,
85
- ref: "Facility",
86
- required: true,
87
- },
88
- createdBy: {
89
- type: mongoose.Schema.Types.ObjectId,
90
- ref: "User",
91
- },
92
- updatedBy: {
93
- type: mongoose.Schema.Types.ObjectId,
94
- ref: "User",
95
- }
96
- },
97
- {
98
- timestamps: true,
99
- }
100
- );
101
-
102
- // Index for efficient queries
103
- billerAddressSchema.index({ facilityId: 1 });
104
- billerAddressSchema.index({ facilityId: 1, isDefault: 1 });
105
-
106
- // Pre-save middleware to ensure only one default address per facility
107
- billerAddressSchema.pre('save', async function (next) {
108
- if (this.isDefault && this.isModified('isDefault')) {
109
- // If this address is being set as default, unset all other defaults for this facility
110
- await this.constructor.updateMany(
111
- {
112
- facilityId: this.facilityId,
113
- _id: { $ne: this._id }
114
- },
115
- { $set: { isDefault: false } }
116
- );
117
- }
118
- next();
119
- });
120
-
121
- // Compile the model from the schema
122
- const BillerAddress = mongoose.model("BillerAddress", billerAddressSchema);
123
-
124
- module.exports = BillerAddress;
1
+ const mongoose = require("mongoose");
2
+
3
+ // Define the schema for Biller Address
4
+ const billerAddressSchema = new mongoose.Schema(
5
+ {
6
+ name: {
7
+ type: String,
8
+ required: [true, "Address name is required"],
9
+ trim: true,
10
+ minlength: [1, "Address name must be at least 1 character long"],
11
+ },
12
+ companyName: {
13
+ type: String,
14
+ required: [true, "Company name is required"],
15
+ trim: true,
16
+ },
17
+ website: {
18
+ type: String,
19
+ trim: true,
20
+ validate: {
21
+ validator: function (v) {
22
+ // If website is empty or null, it's valid (optional field)
23
+ if (!v || v.trim() === '') return true;
24
+
25
+ // Updated regex pattern that's more flexible for various URL formats
26
+ return /^(https?:\/\/)?(www\.)?[-a-zA-Z0-9@:%.\+~#=]{1,256}\.[a-zA-Z0-9()]{1,6}\b([-a-zA-Z0-9()@:%\+.~#?&//=]*)$/.test(v);
27
+ },
28
+ message: "Please enter a valid website URL (e.g., https://example.com, www.example.com, or example.com)"
29
+ }
30
+ },
31
+ email: {
32
+ type: String,
33
+ required: [true, "Email is required"],
34
+ trim: true,
35
+ lowercase: true,
36
+ validate: {
37
+ validator: function (v) {
38
+ return /^\w+([\.-]?\w+)@\w+([\.-]?\w+)(\.\w{2,3})+$/.test(v);
39
+ },
40
+ message: "Please enter a valid email address"
41
+ }
42
+ },
43
+ phone: {
44
+ type: String,
45
+ trim: true,
46
+ },
47
+ address: {
48
+ type: String,
49
+ required: [true, "Address is required"],
50
+ trim: true,
51
+ },
52
+ city: {
53
+ type: String,
54
+ required: [true, "City is required"],
55
+ trim: true,
56
+ },
57
+ state: {
58
+ type: String,
59
+ trim: true,
60
+ },
61
+ country: {
62
+ type: String,
63
+ required: [true, "Country is required"],
64
+ trim: true,
65
+ default: "Kenya"
66
+ },
67
+ postalCode: {
68
+ type: String,
69
+ trim: true,
70
+ },
71
+ logo: {
72
+ type: String, // Will store the file path/URL of the uploaded logo
73
+ required: false,
74
+ },
75
+ digitalSignature: {
76
+ type: String, // Will store the file path/URL of the uploaded digital signature
77
+ required: false,
78
+ },
79
+ isDefault: {
80
+ type: Boolean,
81
+ default: false,
82
+ },
83
+ facilityId: {
84
+ type: mongoose.Schema.Types.ObjectId,
85
+ ref: "Facility",
86
+ required: true,
87
+ },
88
+ createdBy: {
89
+ type: mongoose.Schema.Types.ObjectId,
90
+ ref: "User",
91
+ },
92
+ updatedBy: {
93
+ type: mongoose.Schema.Types.ObjectId,
94
+ ref: "User",
95
+ }
96
+ },
97
+ {
98
+ timestamps: true,
99
+ }
100
+ );
101
+
102
+ // Index for efficient queries
103
+ billerAddressSchema.index({ facilityId: 1 });
104
+ billerAddressSchema.index({ facilityId: 1, isDefault: 1 });
105
+
106
+ // Pre-save middleware to ensure only one default address per facility
107
+ billerAddressSchema.pre('save', async function (next) {
108
+ if (this.isDefault && this.isModified('isDefault')) {
109
+ // If this address is being set as default, unset all other defaults for this facility
110
+ await this.constructor.updateMany(
111
+ {
112
+ facilityId: this.facilityId,
113
+ _id: { $ne: this._id }
114
+ },
115
+ { $set: { isDefault: false } }
116
+ );
117
+ }
118
+ next();
119
+ });
120
+
121
+ // Compile the model from the schema
122
+ const BillerAddress = mongoose.model("BillerAddress", billerAddressSchema);
123
+
124
+ module.exports = BillerAddress;
@@ -1,152 +1,152 @@
1
- const mongoose = require('mongoose');
2
-
3
- // Define the schema for Booking Invoices
4
- const bookingInvoiceSchema = new mongoose.Schema({
5
- invoiceNumber: {
6
- type: String,
7
- required: true,
8
- unique: true,
9
- },
10
- facilityId: {
11
- type: mongoose.Schema.Types.ObjectId,
12
- ref: 'Facility',
13
- required: true
14
- },
15
- invoiceId: {
16
- type: String,
17
- required: true,
18
- unique: true
19
- },
20
- bookingReservationId: {
21
- type: mongoose.Schema.Types.ObjectId,
22
- ref: 'BookingReservation',
23
- required: true
24
- },
25
- unitId: {
26
- type: mongoose.Schema.Types.ObjectId,
27
- ref: 'Unit',
28
- required: true
29
- },
30
- guestInfo: {
31
- name: {
32
- type: String,
33
- required: true
34
- },
35
- email: {
36
- type: String,
37
- required: true
38
- },
39
- phone: {
40
- type: String,
41
- required: true
42
- },
43
- idNumber: {
44
- type: String
45
- }
46
- },
47
- issueDate: {
48
- type: Date,
49
- default: Date.now,
50
- required: true
51
- },
52
- dueDate: {
53
- type: Date,
54
- required: true
55
- },
56
- checkIn: {
57
- type: Date,
58
- required: true
59
- },
60
- checkOut: {
61
- type: Date,
62
- required: true
63
- },
64
- basePrice: {
65
- type: Number,
66
- required: true
67
- },
68
- totalAmount: {
69
- type: Number,
70
- required: true
71
- },
72
- additionalServices: [{
73
- serviceId: {
74
- type: mongoose.Schema.Types.ObjectId,
75
- ref: 'ValueAddedService'
76
- },
77
- serviceName: {
78
- type: String,
79
- required: true
80
- },
81
- quantity: {
82
- type: Number,
83
- default: 1
84
- },
85
- price: {
86
- type: Number,
87
- required: true
88
- }
89
- }],
90
- discountAmount: {
91
- type: Number,
92
- default: 0
93
- },
94
- taxAmount: {
95
- type: Number,
96
- default: 0
97
- },
98
- paymentMethod: {
99
- type: String,
100
- enum: ['Cash', 'Card', 'Bank Transfer', 'Mobile Money', 'Other'],
101
- required: true
102
- },
103
- paymentStatus: {
104
- type: String,
105
- enum: ['Pending', 'Paid', 'Partially Paid', 'Refunded', 'Cancelled'],
106
- default: 'Pending'
107
- },
108
- paymentHistory: [{
109
- amount: {
110
- type: Number,
111
- required: true
112
- },
113
- paymentMethod: {
114
- type: String,
115
- enum: ['Cash', 'Card', 'Bank Transfer', 'Mobile Money', 'Other'],
116
- required: true
117
- },
118
- transactionId: String,
119
- date: {
120
- type: Date,
121
- default: Date.now
122
- },
123
- notes: String
124
- }],
125
- currencyId: {
126
- type: mongoose.Schema.Types.ObjectId,
127
- ref: 'Currency',
128
- required: true
129
- },
130
- status: {
131
- type: String,
132
- enum: ['active', 'cancelled', 'void'],
133
- default: 'active'
134
- },
135
- notes: {
136
- type: String
137
- },
138
- createdBy: {
139
- type: mongoose.Schema.Types.ObjectId,
140
- ref: 'User'
141
- },
142
- updatedBy: {
143
- type: mongoose.Schema.Types.ObjectId,
144
- ref: 'User'
145
- }
146
- }, {
147
- timestamps: true
148
- });
149
-
150
- const BookingInvoice = mongoose.model('BookingInvoice', bookingInvoiceSchema);
151
-
1
+ const mongoose = require('mongoose');
2
+
3
+ // Define the schema for Booking Invoices
4
+ const bookingInvoiceSchema = new mongoose.Schema({
5
+ invoiceNumber: {
6
+ type: String,
7
+ required: true,
8
+ unique: true,
9
+ },
10
+ facilityId: {
11
+ type: mongoose.Schema.Types.ObjectId,
12
+ ref: 'Facility',
13
+ required: true
14
+ },
15
+ invoiceId: {
16
+ type: String,
17
+ required: true,
18
+ unique: true
19
+ },
20
+ bookingReservationId: {
21
+ type: mongoose.Schema.Types.ObjectId,
22
+ ref: 'BookingReservation',
23
+ required: true
24
+ },
25
+ unitId: {
26
+ type: mongoose.Schema.Types.ObjectId,
27
+ ref: 'Unit',
28
+ required: true
29
+ },
30
+ guestInfo: {
31
+ name: {
32
+ type: String,
33
+ required: true
34
+ },
35
+ email: {
36
+ type: String,
37
+ required: true
38
+ },
39
+ phone: {
40
+ type: String,
41
+ required: true
42
+ },
43
+ idNumber: {
44
+ type: String
45
+ }
46
+ },
47
+ issueDate: {
48
+ type: Date,
49
+ default: Date.now,
50
+ required: true
51
+ },
52
+ dueDate: {
53
+ type: Date,
54
+ required: true
55
+ },
56
+ checkIn: {
57
+ type: Date,
58
+ required: true
59
+ },
60
+ checkOut: {
61
+ type: Date,
62
+ required: true
63
+ },
64
+ basePrice: {
65
+ type: Number,
66
+ required: true
67
+ },
68
+ totalAmount: {
69
+ type: Number,
70
+ required: true
71
+ },
72
+ additionalServices: [{
73
+ serviceId: {
74
+ type: mongoose.Schema.Types.ObjectId,
75
+ ref: 'ValueAddedService'
76
+ },
77
+ serviceName: {
78
+ type: String,
79
+ required: true
80
+ },
81
+ quantity: {
82
+ type: Number,
83
+ default: 1
84
+ },
85
+ price: {
86
+ type: Number,
87
+ required: true
88
+ }
89
+ }],
90
+ discountAmount: {
91
+ type: Number,
92
+ default: 0
93
+ },
94
+ taxAmount: {
95
+ type: Number,
96
+ default: 0
97
+ },
98
+ paymentMethod: {
99
+ type: String,
100
+ enum: ['Cash', 'Card', 'Bank Transfer', 'Mobile Money', 'Other'],
101
+ required: true
102
+ },
103
+ paymentStatus: {
104
+ type: String,
105
+ enum: ['Pending', 'Paid', 'Partially Paid', 'Refunded', 'Cancelled'],
106
+ default: 'Pending'
107
+ },
108
+ paymentHistory: [{
109
+ amount: {
110
+ type: Number,
111
+ required: true
112
+ },
113
+ paymentMethod: {
114
+ type: String,
115
+ enum: ['Cash', 'Card', 'Bank Transfer', 'Mobile Money', 'Other'],
116
+ required: true
117
+ },
118
+ transactionId: String,
119
+ date: {
120
+ type: Date,
121
+ default: Date.now
122
+ },
123
+ notes: String
124
+ }],
125
+ currencyId: {
126
+ type: mongoose.Schema.Types.ObjectId,
127
+ ref: 'Currency',
128
+ required: true
129
+ },
130
+ status: {
131
+ type: String,
132
+ enum: ['active', 'cancelled', 'void'],
133
+ default: 'active'
134
+ },
135
+ notes: {
136
+ type: String
137
+ },
138
+ createdBy: {
139
+ type: mongoose.Schema.Types.ObjectId,
140
+ ref: 'User'
141
+ },
142
+ updatedBy: {
143
+ type: mongoose.Schema.Types.ObjectId,
144
+ ref: 'User'
145
+ }
146
+ }, {
147
+ timestamps: true
148
+ });
149
+
150
+ const BookingInvoice = mongoose.model('BookingInvoice', bookingInvoiceSchema);
151
+
152
152
  module.exports = BookingInvoice;