payservedb 5.7.6 → 5.7.8

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 (116) hide show
  1. package/.env +2 -2
  2. package/index.js +198 -196
  3. package/package.json +17 -17
  4. package/src/models/account.js +35 -35
  5. package/src/models/apilog.js +18 -18
  6. package/src/models/approvalsWorkflows.js +49 -49
  7. package/src/models/archivedapilog.js +18 -18
  8. package/src/models/archivedauditlog.js +83 -83
  9. package/src/models/asset.js +34 -34
  10. package/src/models/assetsAssignment.js +64 -64
  11. package/src/models/auditlog.js +83 -83
  12. package/src/models/bankdetails.js +40 -40
  13. package/src/models/billerAddress.js +119 -119
  14. package/src/models/booking_invoice.js +151 -151
  15. package/src/models/bookinganalytics.js +63 -63
  16. package/src/models/bookingconfig.js +45 -45
  17. package/src/models/bookingproperty.js +112 -112
  18. package/src/models/bookingreservation.js +192 -192
  19. package/src/models/bookingrevenuerecord.js +84 -84
  20. package/src/models/budget.js +91 -91
  21. package/src/models/budgetCategory.js +19 -19
  22. package/src/models/campaigns.js +72 -72
  23. package/src/models/cashpayment.js +262 -262
  24. package/src/models/combinedUnits.js +62 -62
  25. package/src/models/common_area_electricity.js +38 -38
  26. package/src/models/common_area_generator.js +41 -41
  27. package/src/models/common_area_utility_alert.js +37 -37
  28. package/src/models/common_area_water.js +39 -39
  29. package/src/models/company.js +53 -53
  30. package/src/models/country_tax.js +42 -42
  31. package/src/models/currency_settings.js +39 -39
  32. package/src/models/customer.js +200 -200
  33. package/src/models/default_payment_details.js +17 -17
  34. package/src/models/dutyroster.js +107 -107
  35. package/src/models/email.js +37 -37
  36. package/src/models/entry_exit.js +53 -53
  37. package/src/models/expense.js +99 -99
  38. package/src/models/expense_category.js +45 -45
  39. package/src/models/facility.js +61 -61
  40. package/src/models/facility_payment_details.js +20 -20
  41. package/src/models/facilityasset.js +25 -25
  42. package/src/models/faq.js +18 -18
  43. package/src/models/gl_account_double_entries.js +25 -25
  44. package/src/models/gl_accounts.js +56 -56
  45. package/src/models/gl_entries.js +49 -49
  46. package/src/models/guard.js +47 -47
  47. package/src/models/handover.js +246 -246
  48. package/src/models/invoice.js +336 -336
  49. package/src/models/item_inspection.js +67 -67
  50. package/src/models/leaseagreement.js +221 -221
  51. package/src/models/leasetemplate.js +17 -17
  52. package/src/models/levy.js +206 -206
  53. package/src/models/levy_invoice_settings.js +26 -26
  54. package/src/models/levycontract.js +117 -117
  55. package/src/models/levytype.js +23 -23
  56. package/src/models/maintenance_service_vendor.js +38 -38
  57. package/src/models/maintenance_services.js +17 -17
  58. package/src/models/maintenancerequisition.js +31 -31
  59. package/src/models/message.js +38 -38
  60. package/src/models/module.js +21 -21
  61. package/src/models/notification.js +44 -44
  62. package/src/models/penalty.js +76 -76
  63. package/src/models/pendingCredentials.js +32 -32
  64. package/src/models/propertyManagerContract.js +171 -171
  65. package/src/models/propertyManagerRevenue.js +100 -100
  66. package/src/models/purchase_order.js +202 -202
  67. package/src/models/purchase_request.js +110 -110
  68. package/src/models/refresh_token.js +23 -23
  69. package/src/models/reminder.js +197 -197
  70. package/src/models/report.js +13 -13
  71. package/src/models/resident.js +121 -121
  72. package/src/models/rfq_details.js +131 -131
  73. package/src/models/rfq_response.js +110 -110
  74. package/src/models/service_charge_invoice_upload.js +42 -42
  75. package/src/models/service_charge_payments.js +27 -27
  76. package/src/models/servicerequest.js +55 -55
  77. package/src/models/settings.js +62 -62
  78. package/src/models/smart_meter_daily_consumption.js +44 -44
  79. package/src/models/sms_africastalking.js +20 -20
  80. package/src/models/sms_meliora.js +20 -20
  81. package/src/models/staff.js +36 -36
  82. package/src/models/stocksandspare.js +34 -34
  83. package/src/models/suppliers.js +74 -74
  84. package/src/models/tickets.js +121 -121
  85. package/src/models/unitManagementTemplate.js +44 -44
  86. package/src/models/unitasset.js +25 -25
  87. package/src/models/units.js +112 -112
  88. package/src/models/user.js +187 -187
  89. package/src/models/valueaddedservices.js +79 -79
  90. package/src/models/vas_invoices_upload.js +50 -50
  91. package/src/models/vas_payments.js +24 -24
  92. package/src/models/vasinvoice.js +192 -192
  93. package/src/models/vasvendor.js +57 -57
  94. package/src/models/visitLog.js +86 -86
  95. package/src/models/visitor.js +67 -67
  96. package/src/models/waitlist.js +45 -45
  97. package/src/models/wallet.js +35 -0
  98. package/src/models/wallet_transactions.js +50 -0
  99. package/src/models/water_invoice.js +193 -193
  100. package/src/models/water_meter_account.js +78 -78
  101. package/src/models/water_meter_billing.js +58 -58
  102. package/src/models/water_meter_communication.js +17 -17
  103. package/src/models/water_meter_communication_logs.js +30 -30
  104. package/src/models/water_meter_concentrator.js +63 -63
  105. package/src/models/water_meter_daily_history.js +32 -32
  106. package/src/models/water_meter_iot_cards.js +34 -34
  107. package/src/models/water_meter_manufacturer.js +35 -35
  108. package/src/models/water_meter_monthly_history.js +36 -36
  109. package/src/models/water_meter_settings.js +114 -114
  110. package/src/models/water_meter_single_day_history.js +34 -34
  111. package/src/models/water_meter_size.js +15 -15
  112. package/src/models/water_meters.js +117 -117
  113. package/src/models/water_meters_delivery.js +76 -76
  114. package/src/models/water_prepaid_credit.js +43 -43
  115. package/src/models/water_prepaid_debit.js +50 -50
  116. package/src/models/workorder.js +49 -49
@@ -1,67 +1,67 @@
1
- const mongoose = require('mongoose');
2
-
3
- // Define the schema for companies
4
- const visitorSchema = new mongoose.Schema({
5
- firstName: {
6
- type: String,
7
- required: true
8
- },
9
- lastName: {
10
- type: String,
11
- required: true
12
- },
13
- phoneNumber: {
14
- type: String,
15
- required: true
16
- },
17
- email: {
18
- type: String,
19
- required: false
20
- },
21
- idNumber: {
22
- type: String,
23
- required: false
24
- },
25
- houseNumber: {
26
- type: String,
27
- required: false
28
- },
29
- status: {
30
- type: String,
31
- required: false
32
- },
33
- type: {
34
- type: String,
35
- required: false,
36
- enum: ["Staff", "Other", "Service Providers", "Government Officials/Agents", "Student", ""]
37
- },
38
- residentId: {
39
- type: mongoose.Schema.Types.ObjectId,
40
- ref: 'Customer',
41
- },
42
- invited: {
43
- type: Boolean,
44
- required: false,
45
- default: false
46
- },
47
- invitationDate: {
48
- type: String,
49
- required: false
50
- },
51
- visitingEndDate: {
52
- type: String,
53
- required: false
54
- },
55
- facilityId: {
56
- type: mongoose.Schema.Types.ObjectId,
57
- ref: 'Facility',
58
- },
59
- }, {
60
- timestamps: true // Automatically add createdAt and updatedAt fields
61
- });
62
-
63
- // Indexes for improved performance
64
- // Compile the model from the schema
65
- const Visitor = mongoose.model('Visitor', visitorSchema);
66
-
67
- module.exports = Visitor;
1
+ const mongoose = require('mongoose');
2
+
3
+ // Define the schema for companies
4
+ const visitorSchema = new mongoose.Schema({
5
+ firstName: {
6
+ type: String,
7
+ required: true
8
+ },
9
+ lastName: {
10
+ type: String,
11
+ required: true
12
+ },
13
+ phoneNumber: {
14
+ type: String,
15
+ required: true
16
+ },
17
+ email: {
18
+ type: String,
19
+ required: false
20
+ },
21
+ idNumber: {
22
+ type: String,
23
+ required: false
24
+ },
25
+ houseNumber: {
26
+ type: String,
27
+ required: false
28
+ },
29
+ status: {
30
+ type: String,
31
+ required: false
32
+ },
33
+ type: {
34
+ type: String,
35
+ required: false,
36
+ enum: ["Staff", "Other", "Service Providers", "Government Officials/Agents", "Student", ""]
37
+ },
38
+ residentId: {
39
+ type: mongoose.Schema.Types.ObjectId,
40
+ ref: 'Customer',
41
+ },
42
+ invited: {
43
+ type: Boolean,
44
+ required: false,
45
+ default: false
46
+ },
47
+ invitationDate: {
48
+ type: String,
49
+ required: false
50
+ },
51
+ visitingEndDate: {
52
+ type: String,
53
+ required: false
54
+ },
55
+ facilityId: {
56
+ type: mongoose.Schema.Types.ObjectId,
57
+ ref: 'Facility',
58
+ },
59
+ }, {
60
+ timestamps: true // Automatically add createdAt and updatedAt fields
61
+ });
62
+
63
+ // Indexes for improved performance
64
+ // Compile the model from the schema
65
+ const Visitor = mongoose.model('Visitor', visitorSchema);
66
+
67
+ module.exports = Visitor;
@@ -1,45 +1,45 @@
1
- const mongoose = require('mongoose');
2
-
3
- // Define the schema for companies
4
- const waitListSchema = new mongoose.Schema({
5
- firstName: {
6
- type: String,
7
- required: true
8
- },
9
- lastName: {
10
- type: String,
11
- required: true
12
- },
13
- phoneNumber: {
14
- type: String,
15
- required: true
16
- },
17
- division: {
18
- type: mongoose.Schema.Types.ObjectId,
19
- ref: 'Facility',
20
- required: true
21
- },
22
- unit: {
23
- type: mongoose.Schema.Types.ObjectId,
24
- ref: 'Unit',
25
- required: true
26
- },
27
- status: {
28
- type: String,
29
- required: true,
30
- enum: ['Waiting confirmation', 'Approved', 'Denied']
31
- },
32
- facilityId: {
33
- type: mongoose.Schema.Types.ObjectId,
34
- ref: 'Facility',
35
- required: true // Ensures a facilityId is always provided
36
- },
37
-
38
- }, {
39
- timestamps: true // Automatically add createdAt and updatedAt fields
40
- });
41
-
42
-
43
- const WaitList = mongoose.model('WaitList', waitListSchema);
44
-
45
- module.exports = WaitList;
1
+ const mongoose = require('mongoose');
2
+
3
+ // Define the schema for companies
4
+ const waitListSchema = new mongoose.Schema({
5
+ firstName: {
6
+ type: String,
7
+ required: true
8
+ },
9
+ lastName: {
10
+ type: String,
11
+ required: true
12
+ },
13
+ phoneNumber: {
14
+ type: String,
15
+ required: true
16
+ },
17
+ division: {
18
+ type: mongoose.Schema.Types.ObjectId,
19
+ ref: 'Facility',
20
+ required: true
21
+ },
22
+ unit: {
23
+ type: mongoose.Schema.Types.ObjectId,
24
+ ref: 'Unit',
25
+ required: true
26
+ },
27
+ status: {
28
+ type: String,
29
+ required: true,
30
+ enum: ['Waiting confirmation', 'Approved', 'Denied']
31
+ },
32
+ facilityId: {
33
+ type: mongoose.Schema.Types.ObjectId,
34
+ ref: 'Facility',
35
+ required: true // Ensures a facilityId is always provided
36
+ },
37
+
38
+ }, {
39
+ timestamps: true // Automatically add createdAt and updatedAt fields
40
+ });
41
+
42
+
43
+ const WaitList = mongoose.model('WaitList', waitListSchema);
44
+
45
+ module.exports = WaitList;
@@ -0,0 +1,35 @@
1
+ const mongoose = require("mongoose");
2
+
3
+ // Define the schema for Wallet
4
+ const walletSchema = new mongoose.Schema(
5
+ {
6
+ owner: {
7
+ type: mongoose.Schema.Types.ObjectId,
8
+ required: true,
9
+ },
10
+ ownerType: {
11
+ type: String,
12
+ required: true,
13
+ enum: ["User", "Customer"],
14
+ },
15
+ amount: {
16
+ type: Number,
17
+ default: 0,
18
+ min: 0,
19
+ },
20
+ facilityId: {
21
+ type: mongoose.Schema.Types.ObjectId,
22
+ ref: "Facility",
23
+ required: true,
24
+ },
25
+ },
26
+ {
27
+ timestamps: true,
28
+ },
29
+ );
30
+
31
+ // Index for efficient queries
32
+ walletSchema.index({ owner: 1, ownerType: 1, facilityId: 1 });
33
+
34
+ const Wallet = mongoose.model("Wallet", walletSchema);
35
+ module.exports = Wallet;
@@ -0,0 +1,50 @@
1
+ const mongoose = require("mongoose");
2
+
3
+ // Define the schema for Wallet Transactions
4
+ const walletTransactionSchema = new mongoose.Schema(
5
+ {
6
+ walletId: {
7
+ type: mongoose.Schema.Types.ObjectId,
8
+ ref: "Wallet",
9
+ required: true,
10
+ },
11
+ date: {
12
+ type: Date,
13
+ required: true,
14
+ default: Date.now,
15
+ },
16
+ amount: {
17
+ type: Number,
18
+ required: true,
19
+ min: 0.01,
20
+ },
21
+ transactionType: {
22
+ type: String,
23
+ required: true,
24
+ enum: ["topup", "deductable"],
25
+ },
26
+ description: {
27
+ type: String,
28
+ required: true,
29
+ },
30
+ facilityId: {
31
+ type: mongoose.Schema.Types.ObjectId,
32
+ ref: "Facility",
33
+ required: true,
34
+ },
35
+ },
36
+ {
37
+ timestamps: true,
38
+ },
39
+ );
40
+
41
+ // Index for efficient queries
42
+ walletTransactionSchema.index({ walletId: 1, facilityId: 1 });
43
+ walletTransactionSchema.index({ facilityId: 1, transactionType: 1 });
44
+ walletTransactionSchema.index({ date: -1 });
45
+
46
+ const WalletTransaction = mongoose.model(
47
+ "WalletTransaction",
48
+ walletTransactionSchema,
49
+ );
50
+ module.exports = WalletTransaction;
@@ -1,193 +1,193 @@
1
- const mongoose = require('mongoose');
2
-
3
- const waterInvoiceSchema = new mongoose.Schema(
4
- {
5
- // Basic identifiers
6
- invoiceNumber: {
7
- type: String,
8
- required: true,
9
- unique: true
10
- },
11
- accountNumber: {
12
- type: String,
13
- required: true
14
- },
15
- unitName: {
16
- type: String,
17
- required: true,
18
- },
19
- yearMonth: {
20
- type: String,
21
- required: true,
22
- },
23
- facilityId: {
24
- type: mongoose.Schema.Types.ObjectId,
25
- required: true
26
- },
27
- customerId: {
28
- type: mongoose.Schema.Types.ObjectId,
29
- required: true
30
- },
31
- billingType: {
32
- type: String,
33
- enum: ['postpaid'],
34
- },
35
- balanceBroughtForward: {
36
- type: Number,
37
- default: 0
38
- },
39
- // Dates
40
- dateIssued: {
41
- type: Date,
42
- default: Date.now
43
- },
44
- dueDate: {
45
- type: Date,
46
- required: true
47
- },
48
-
49
- // Meter & Consumption Details
50
- meterNumber: {
51
- type: String,
52
- required: true
53
- },
54
- meterReadings: {
55
- previousReading: {
56
- type: Number,
57
- required: true
58
- },
59
- currentReading: {
60
- type: Number,
61
- required: true
62
- },
63
- usage: {
64
- type: Number,
65
- required: true,
66
- }
67
- },
68
- consumptionPeriod: {
69
- startDate: {
70
- type: Date,
71
- required: true
72
- },
73
- endDate: {
74
- type: Date,
75
- required: true
76
- }
77
- },
78
-
79
- // Charges
80
- charges: {
81
- waterCharge: {
82
- type: Number,
83
- required: true
84
- },
85
- sewerCharge: {
86
- type: Number,
87
- default: 0
88
- },
89
- tax: {
90
- type: Number,
91
- default: 0
92
- },
93
- fixedCharge: {
94
- type: Number,
95
- default: 0
96
- },
97
- totalMonthlyBill: {
98
- type: Number,
99
- required: true
100
- }
101
- },
102
- amountPaid: {
103
- type: Number,
104
- default: 0
105
- },
106
- imageUrl: { type: String, trim: true },
107
-
108
- // Invoice Note & Status
109
- invoiceNote: {
110
- type: String,
111
- default: 'Payment is due within 10 days'
112
- },
113
- status: {
114
- type: String,
115
- required: true,
116
- enum: ['Pending', 'Paid', 'Partially Paid', 'Cancelled', 'Overdue', 'Unpaid'],
117
- default: 'Pending'
118
- },
119
-
120
- // Currency Info
121
- currency: {
122
- id: {
123
- type: mongoose.Schema.Types.ObjectId
124
- },
125
- name: {
126
- type: String,
127
- default: 'Kenyan Shilling'
128
- },
129
- code: {
130
- type: String,
131
- default: 'KES'
132
- },
133
- symbol: {
134
- type: String,
135
- default: 'KSh'
136
- }
137
- },
138
-
139
- // Payment & Reconciliation
140
- reconciliationHistory: [
141
- {
142
- date: {
143
- type: Date,
144
- default: Date.now
145
- },
146
- amount: {
147
- type: Number,
148
- required: true
149
- },
150
- type: {
151
- type: String,
152
- default: 'Manual'
153
- },
154
- paymentReference: {
155
- type: String
156
- },
157
- paymentCompletion: {
158
- type: String,
159
- default: 'Completed'
160
- },
161
- sourceInvoice: {
162
- type: String
163
- },
164
- destinationInvoice: {
165
- type: String
166
- },
167
- notes: {
168
- type: String
169
- },
170
- remainingBalance: {
171
- type: Number
172
- }
173
- }
174
- ],
175
- },
176
- {
177
- timestamps: true
178
- }
179
- );
180
-
181
- waterInvoiceSchema.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 WaterInvoice = mongoose.model('WaterInvoice', waterInvoiceSchema);
192
-
193
- module.exports = WaterInvoice;
1
+ const mongoose = require('mongoose');
2
+
3
+ const waterInvoiceSchema = new mongoose.Schema(
4
+ {
5
+ // Basic identifiers
6
+ invoiceNumber: {
7
+ type: String,
8
+ required: true,
9
+ unique: true
10
+ },
11
+ accountNumber: {
12
+ type: String,
13
+ required: true
14
+ },
15
+ unitName: {
16
+ type: String,
17
+ required: true,
18
+ },
19
+ yearMonth: {
20
+ type: String,
21
+ required: true,
22
+ },
23
+ facilityId: {
24
+ type: mongoose.Schema.Types.ObjectId,
25
+ required: true
26
+ },
27
+ customerId: {
28
+ type: mongoose.Schema.Types.ObjectId,
29
+ required: true
30
+ },
31
+ billingType: {
32
+ type: String,
33
+ enum: ['postpaid'],
34
+ },
35
+ balanceBroughtForward: {
36
+ type: Number,
37
+ default: 0
38
+ },
39
+ // Dates
40
+ dateIssued: {
41
+ type: Date,
42
+ default: Date.now
43
+ },
44
+ dueDate: {
45
+ type: Date,
46
+ required: true
47
+ },
48
+
49
+ // Meter & Consumption Details
50
+ meterNumber: {
51
+ type: String,
52
+ required: true
53
+ },
54
+ meterReadings: {
55
+ previousReading: {
56
+ type: Number,
57
+ required: true
58
+ },
59
+ currentReading: {
60
+ type: Number,
61
+ required: true
62
+ },
63
+ usage: {
64
+ type: Number,
65
+ required: true,
66
+ }
67
+ },
68
+ consumptionPeriod: {
69
+ startDate: {
70
+ type: Date,
71
+ required: true
72
+ },
73
+ endDate: {
74
+ type: Date,
75
+ required: true
76
+ }
77
+ },
78
+
79
+ // Charges
80
+ charges: {
81
+ waterCharge: {
82
+ type: Number,
83
+ required: true
84
+ },
85
+ sewerCharge: {
86
+ type: Number,
87
+ default: 0
88
+ },
89
+ tax: {
90
+ type: Number,
91
+ default: 0
92
+ },
93
+ fixedCharge: {
94
+ type: Number,
95
+ default: 0
96
+ },
97
+ totalMonthlyBill: {
98
+ type: Number,
99
+ required: true
100
+ }
101
+ },
102
+ amountPaid: {
103
+ type: Number,
104
+ default: 0
105
+ },
106
+ imageUrl: { type: String, trim: true },
107
+
108
+ // Invoice Note & Status
109
+ invoiceNote: {
110
+ type: String,
111
+ default: 'Payment is due within 10 days'
112
+ },
113
+ status: {
114
+ type: String,
115
+ required: true,
116
+ enum: ['Pending', 'Paid', 'Partially Paid', 'Cancelled', 'Overdue', 'Unpaid'],
117
+ default: 'Pending'
118
+ },
119
+
120
+ // Currency Info
121
+ currency: {
122
+ id: {
123
+ type: mongoose.Schema.Types.ObjectId
124
+ },
125
+ name: {
126
+ type: String,
127
+ default: 'Kenyan Shilling'
128
+ },
129
+ code: {
130
+ type: String,
131
+ default: 'KES'
132
+ },
133
+ symbol: {
134
+ type: String,
135
+ default: 'KSh'
136
+ }
137
+ },
138
+
139
+ // Payment & Reconciliation
140
+ reconciliationHistory: [
141
+ {
142
+ date: {
143
+ type: Date,
144
+ default: Date.now
145
+ },
146
+ amount: {
147
+ type: Number,
148
+ required: true
149
+ },
150
+ type: {
151
+ type: String,
152
+ default: 'Manual'
153
+ },
154
+ paymentReference: {
155
+ type: String
156
+ },
157
+ paymentCompletion: {
158
+ type: String,
159
+ default: 'Completed'
160
+ },
161
+ sourceInvoice: {
162
+ type: String
163
+ },
164
+ destinationInvoice: {
165
+ type: String
166
+ },
167
+ notes: {
168
+ type: String
169
+ },
170
+ remainingBalance: {
171
+ type: Number
172
+ }
173
+ }
174
+ ],
175
+ },
176
+ {
177
+ timestamps: true
178
+ }
179
+ );
180
+
181
+ waterInvoiceSchema.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 WaterInvoice = mongoose.model('WaterInvoice', waterInvoiceSchema);
192
+
193
+ module.exports = WaterInvoice;