payservedb 8.4.6 → 8.4.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.
- package/.env +2 -2
- package/ZOHO_INTEGRATION_SCHEMA.md +644 -644
- package/index.js +312 -312
- package/package.json +17 -17
- package/src/models/account.js +52 -52
- package/src/models/agent_departments.js +59 -59
- package/src/models/agent_notifications.js +53 -53
- package/src/models/agent_performance.js +127 -127
- package/src/models/agent_roles.js +77 -77
- package/src/models/agents.js +154 -154
- package/src/models/apilog.js +18 -18
- package/src/models/approvalsWorkflows.js +49 -49
- package/src/models/archivedapilog.js +18 -18
- package/src/models/asset.js +92 -92
- package/src/models/assetsAssignment.js +64 -64
- package/src/models/auditTrail.js +346 -346
- package/src/models/bankdetails.js +47 -47
- package/src/models/billerAddress.js +124 -124
- package/src/models/booking_invoice.js +165 -165
- package/src/models/bookinganalytics.js +63 -63
- package/src/models/bookingconfig.js +45 -45
- package/src/models/bookingproperty.js +173 -173
- package/src/models/bookingreservation.js +209 -209
- package/src/models/bookingrevenuerecord.js +84 -84
- package/src/models/budget.js +95 -95
- package/src/models/budgetCategory.js +19 -19
- package/src/models/campaigns.js +108 -108
- package/src/models/cashpayment.js +264 -264
- package/src/models/combinedUnits.js +62 -62
- package/src/models/common_area_electricity.js +38 -38
- package/src/models/common_area_generator.js +41 -41
- package/src/models/common_area_utility_alert.js +37 -37
- package/src/models/common_area_water.js +39 -39
- package/src/models/communication_status.js +33 -33
- package/src/models/communication_user_opt.js +32 -32
- package/src/models/community_guidelines.js +24 -24
- package/src/models/company.js +53 -53
- package/src/models/coreBaseSettings.js +16 -16
- package/src/models/coreInvoiceSettings.js +100 -100
- package/src/models/counter_schema.js +21 -21
- package/src/models/country_tax.js +42 -42
- package/src/models/currency_settings.js +39 -39
- package/src/models/customer.js +210 -210
- package/src/models/customer_satisfaction_survey.js +278 -278
- package/src/models/customer_surveys.js +139 -139
- package/src/models/customer_tickets.js +239 -239
- package/src/models/dailyChecklist.js +312 -312
- package/src/models/default_payment_details.js +17 -17
- package/src/models/deliveryTimeMarks.js +18 -18
- package/src/models/document_type.js +19 -19
- package/src/models/dutyRosterChecklist.js +250 -250
- package/src/models/dutyroster.js +136 -136
- package/src/models/email.js +37 -37
- package/src/models/email_sms_queue.js +61 -61
- package/src/models/entry_exit.js +53 -53
- package/src/models/expense.js +99 -99
- package/src/models/expense_category.js +45 -45
- package/src/models/facility.js +71 -71
- package/src/models/facilityBillingPrices.js +29 -29
- package/src/models/facilityInvoice.js +240 -240
- package/src/models/facilityInvoicePayment.js +52 -52
- package/src/models/facilityInvoiceRecipient.js +32 -32
- package/src/models/facilityWalletTransactionsMetadata.js +236 -236
- package/src/models/facility_departements.js +20 -20
- package/src/models/facility_payment_details.js +20 -20
- package/src/models/facilityasset.js +25 -25
- package/src/models/faq.js +14 -14
- package/src/models/gl_account_double_entries.js +25 -25
- package/src/models/gl_accounts.js +56 -56
- package/src/models/gl_entries.js +49 -49
- package/src/models/goodsReceivedNotes.js +115 -115
- package/src/models/guard.js +47 -47
- package/src/models/handover.js +247 -247
- package/src/models/inspection_category.js +38 -38
- package/src/models/invoice.js +480 -480
- package/src/models/invoicing_schedule.js +41 -36
- package/src/models/item_inspection.js +96 -96
- package/src/models/knowledge_base.js +109 -109
- package/src/models/knowledge_base_rating.js +44 -44
- package/src/models/leaseagreement.js +236 -236
- package/src/models/leasetemplate.js +17 -17
- package/src/models/levy.js +223 -223
- package/src/models/levy_invoice_settings.js +26 -26
- package/src/models/levycontract.js +177 -177
- package/src/models/levytype.js +23 -23
- package/src/models/maintenance_service_vendor.js +38 -38
- package/src/models/maintenance_services.js +17 -17
- package/src/models/maintenancerequisition.js +31 -31
- package/src/models/master_workplan.js +32 -32
- package/src/models/master_workplan_child.js +34 -34
- package/src/models/message.js +38 -38
- package/src/models/module.js +21 -21
- package/src/models/notification.js +44 -44
- package/src/models/paymentTermsMarks.js +19 -19
- package/src/models/penalty.js +76 -76
- package/src/models/pendingCredentials.js +32 -32
- package/src/models/powerMeterCommunicationProtocol.js +17 -17
- package/src/models/powerMeterCustomerAccount.js +78 -78
- package/src/models/powerMeterCustomerBand.js +14 -14
- package/src/models/powerMeterDailyReading.js +30 -30
- package/src/models/powerMeterGateways.js +40 -40
- package/src/models/powerMeterMonthlyReading.js +34 -34
- package/src/models/powerMeterPowerCharges.js +85 -85
- package/src/models/powerMeterSettings.js +159 -159
- package/src/models/powerMeterSingleDayReading.js +32 -32
- package/src/models/powerMeters.js +116 -116
- package/src/models/powerMetersManufacturer.js +14 -14
- package/src/models/power_meter_account.js +81 -81
- package/src/models/power_meter_command_logs.js +30 -30
- package/src/models/power_meter_command_queue.js +33 -33
- package/src/models/power_meter_negative_balance.js +44 -44
- package/src/models/power_prepaid_credits.js +47 -47
- package/src/models/power_prepaid_debits.js +53 -53
- package/src/models/power_prepaid_orders.js +78 -78
- package/src/models/power_sms_notification.js +26 -26
- package/src/models/privacy_policy.js +19 -19
- package/src/models/propertyManagerContract.js +556 -556
- package/src/models/propertyManagerRevenue.js +195 -195
- package/src/models/purchaseOrderInvoice.js +74 -74
- package/src/models/purchase_order.js +213 -213
- package/src/models/purchase_request.js +110 -110
- package/src/models/refresh_token.js +23 -23
- package/src/models/reminder.js +197 -197
- package/src/models/report.js +13 -13
- package/src/models/resident.js +121 -121
- package/src/models/rfq_details.js +131 -131
- package/src/models/rfq_response.js +153 -153
- package/src/models/service_charge_invoice_upload.js +42 -42
- package/src/models/service_charge_payments.js +27 -27
- package/src/models/servicerequest.js +55 -55
- package/src/models/settings.js +62 -62
- package/src/models/short_urls.js +21 -21
- package/src/models/smart_meter_daily_consumption.js +44 -44
- package/src/models/sms_africastalking.js +20 -20
- package/src/models/sms_balance_notification.js +26 -26
- package/src/models/sms_meliora.js +20 -20
- package/src/models/staff.js +36 -36
- package/src/models/stocksandspare.js +161 -161
- package/src/models/suppliers.js +74 -74
- package/src/models/terms_and_conditions.js +19 -19
- package/src/models/tickets.js +186 -186
- package/src/models/tickets_category.js +72 -72
- package/src/models/unitManagementTemplate.js +44 -44
- package/src/models/unitasset.js +25 -25
- package/src/models/units.js +118 -118
- package/src/models/user.js +186 -186
- package/src/models/valueaddedservices.js +79 -79
- package/src/models/vas_invoices_upload.js +50 -50
- package/src/models/vas_payments.js +24 -24
- package/src/models/vasinvoice.js +192 -192
- package/src/models/vasvendor.js +57 -57
- package/src/models/visitLog.js +95 -95
- package/src/models/visitor.js +67 -67
- package/src/models/waitlist.js +45 -45
- package/src/models/wallet.js +44 -44
- package/src/models/wallet_transactions.js +50 -50
- package/src/models/water_invoice.js +351 -351
- package/src/models/water_meter_Command_Queue.js +33 -33
- package/src/models/water_meter_account.js +87 -87
- package/src/models/water_meter_billing.js +58 -58
- package/src/models/water_meter_communication.js +17 -17
- package/src/models/water_meter_communication_logs.js +39 -39
- package/src/models/water_meter_concentrator.js +70 -70
- package/src/models/water_meter_daily_history.js +32 -32
- package/src/models/water_meter_high_risk.js +36 -36
- package/src/models/water_meter_iot_cards.js +34 -34
- package/src/models/water_meter_manufacturer.js +35 -35
- package/src/models/water_meter_monthly_history.js +36 -36
- package/src/models/water_meter_negative_amounts.js +44 -44
- package/src/models/water_meter_settings.js +287 -287
- package/src/models/water_meter_single_day_history.js +34 -34
- package/src/models/water_meter_size.js +15 -15
- package/src/models/water_meters.js +133 -133
- package/src/models/water_meters_delivery.js +76 -76
- package/src/models/water_prepaid_credit.js +47 -47
- package/src/models/water_prepaid_debit.js +50 -50
- package/src/models/workorder.js +49 -49
- package/src/models/zohoAccount.js +453 -453
- package/src/models/zohoIntegration.js +262 -262
- package/src/models/zohoItem.js +504 -504
|
@@ -1,178 +1,178 @@
|
|
|
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
|
-
default: true
|
|
51
|
-
},
|
|
52
|
-
paymentFrequency: {
|
|
53
|
-
type: String,
|
|
54
|
-
enum: ['Daily', 'Weekly', 'Bi-Weekly', 'Monthly', 'Quarterly', 'Semi-Annually', 'Annually'],
|
|
55
|
-
default: 'Monthly'
|
|
56
|
-
},
|
|
57
|
-
facilityId: {
|
|
58
|
-
type: mongoose.Schema.Types.ObjectId,
|
|
59
|
-
ref: 'Facility',
|
|
60
|
-
required: [true, 'Facility ID is required']
|
|
61
|
-
},
|
|
62
|
-
lastInvoiceDate: {
|
|
63
|
-
type: Date
|
|
64
|
-
},
|
|
65
|
-
createdBy: {
|
|
66
|
-
type: mongoose.Schema.Types.ObjectId,
|
|
67
|
-
ref: 'User'
|
|
68
|
-
},
|
|
69
|
-
updatedBy: {
|
|
70
|
-
type: mongoose.Schema.Types.ObjectId,
|
|
71
|
-
ref: 'User'
|
|
72
|
-
},
|
|
73
|
-
// New termination-specific fields
|
|
74
|
-
terminationDate: {
|
|
75
|
-
type: Date
|
|
76
|
-
},
|
|
77
|
-
terminationReason: {
|
|
78
|
-
type: String
|
|
79
|
-
},
|
|
80
|
-
terminatedBy: {
|
|
81
|
-
type: mongoose.Schema.Types.ObjectId,
|
|
82
|
-
ref: 'User'
|
|
83
|
-
},
|
|
84
|
-
// Disable/reactivation tracking
|
|
85
|
-
disabledDate: {
|
|
86
|
-
type: Date
|
|
87
|
-
},
|
|
88
|
-
disabledBy: {
|
|
89
|
-
type: mongoose.Schema.Types.ObjectId,
|
|
90
|
-
ref: 'User'
|
|
91
|
-
},
|
|
92
|
-
disabledReason: {
|
|
93
|
-
type: String
|
|
94
|
-
},
|
|
95
|
-
reactivatedDate: {
|
|
96
|
-
type: Date
|
|
97
|
-
},
|
|
98
|
-
reactivatedBy: {
|
|
99
|
-
type: mongoose.Schema.Types.ObjectId,
|
|
100
|
-
ref: 'User'
|
|
101
|
-
},
|
|
102
|
-
lastInvoiceYearMonth: {
|
|
103
|
-
type: String,
|
|
104
|
-
default: null
|
|
105
|
-
// Format: "2025-09", "2025-10", etc.
|
|
106
|
-
}
|
|
107
|
-
},
|
|
108
|
-
{
|
|
109
|
-
timestamps: true,
|
|
110
|
-
toJSON: { virtuals: true },
|
|
111
|
-
toObject: { virtuals: true }
|
|
112
|
-
}
|
|
113
|
-
);
|
|
114
|
-
|
|
115
|
-
// Virtual populate for Levy details
|
|
116
|
-
LevyContractSchema.virtual('levy', {
|
|
117
|
-
ref: 'Levy',
|
|
118
|
-
localField: 'levyId',
|
|
119
|
-
foreignField: '_id',
|
|
120
|
-
justOne: true
|
|
121
|
-
});
|
|
122
|
-
|
|
123
|
-
// Virtual populate for Customer details
|
|
124
|
-
LevyContractSchema.virtual('customer', {
|
|
125
|
-
ref: 'Customer',
|
|
126
|
-
localField: 'customerId',
|
|
127
|
-
foreignField: '_id',
|
|
128
|
-
justOne: true
|
|
129
|
-
});
|
|
130
|
-
|
|
131
|
-
// Virtual populate for Unit details
|
|
132
|
-
LevyContractSchema.virtual('unit', {
|
|
133
|
-
ref: 'Unit',
|
|
134
|
-
localField: 'unitId',
|
|
135
|
-
foreignField: '_id',
|
|
136
|
-
justOne: true
|
|
137
|
-
});
|
|
138
|
-
|
|
139
|
-
// Pre-save middleware to ensure endDate is after startDate
|
|
140
|
-
LevyContractSchema.pre('save', function (next) {
|
|
141
|
-
if (this.startDate && this.endDate && this.startDate >= this.endDate) {
|
|
142
|
-
next(new Error('End date must be after start date'));
|
|
143
|
-
} else {
|
|
144
|
-
next();
|
|
145
|
-
}
|
|
146
|
-
});
|
|
147
|
-
|
|
148
|
-
// Pre-save middleware to handle termination and disable date logic
|
|
149
|
-
LevyContractSchema.pre('save', function (next) {
|
|
150
|
-
// Set termination date when status changes to Terminated
|
|
151
|
-
if (this.status === 'Terminated' && !this.terminationDate) {
|
|
152
|
-
this.terminationDate = new Date();
|
|
153
|
-
}
|
|
154
|
-
|
|
155
|
-
// Set disabled date when status changes to Inactive
|
|
156
|
-
if (this.status === 'Inactive' && !this.disabledDate && this.isModified('status')) {
|
|
157
|
-
this.disabledDate = new Date();
|
|
158
|
-
}
|
|
159
|
-
|
|
160
|
-
// Set reactivated date when status changes from Inactive to Active
|
|
161
|
-
if (this.status === 'Active' && this.isModified('status') && this.disabledDate) {
|
|
162
|
-
this.reactivatedDate = new Date();
|
|
163
|
-
}
|
|
164
|
-
|
|
165
|
-
next();
|
|
166
|
-
});
|
|
167
|
-
|
|
168
|
-
// Index for efficient queries
|
|
169
|
-
LevyContractSchema.index({ levyId: 1, unitId: 1, status: 1 });
|
|
170
|
-
LevyContractSchema.index({ facilityId: 1 });
|
|
171
|
-
LevyContractSchema.index({ customerId: 1 });
|
|
172
|
-
LevyContractSchema.index({ status: 1 });
|
|
173
|
-
LevyContractSchema.index({ terminationDate: 1 });
|
|
174
|
-
|
|
175
|
-
module.exports = {
|
|
176
|
-
schema: LevyContractSchema,
|
|
177
|
-
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
|
+
default: true
|
|
51
|
+
},
|
|
52
|
+
paymentFrequency: {
|
|
53
|
+
type: String,
|
|
54
|
+
enum: ['Daily', 'Weekly', 'Bi-Weekly', 'Monthly', 'Quarterly', 'Semi-Annually', 'Annually'],
|
|
55
|
+
default: 'Monthly'
|
|
56
|
+
},
|
|
57
|
+
facilityId: {
|
|
58
|
+
type: mongoose.Schema.Types.ObjectId,
|
|
59
|
+
ref: 'Facility',
|
|
60
|
+
required: [true, 'Facility ID is required']
|
|
61
|
+
},
|
|
62
|
+
lastInvoiceDate: {
|
|
63
|
+
type: Date
|
|
64
|
+
},
|
|
65
|
+
createdBy: {
|
|
66
|
+
type: mongoose.Schema.Types.ObjectId,
|
|
67
|
+
ref: 'User'
|
|
68
|
+
},
|
|
69
|
+
updatedBy: {
|
|
70
|
+
type: mongoose.Schema.Types.ObjectId,
|
|
71
|
+
ref: 'User'
|
|
72
|
+
},
|
|
73
|
+
// New termination-specific fields
|
|
74
|
+
terminationDate: {
|
|
75
|
+
type: Date
|
|
76
|
+
},
|
|
77
|
+
terminationReason: {
|
|
78
|
+
type: String
|
|
79
|
+
},
|
|
80
|
+
terminatedBy: {
|
|
81
|
+
type: mongoose.Schema.Types.ObjectId,
|
|
82
|
+
ref: 'User'
|
|
83
|
+
},
|
|
84
|
+
// Disable/reactivation tracking
|
|
85
|
+
disabledDate: {
|
|
86
|
+
type: Date
|
|
87
|
+
},
|
|
88
|
+
disabledBy: {
|
|
89
|
+
type: mongoose.Schema.Types.ObjectId,
|
|
90
|
+
ref: 'User'
|
|
91
|
+
},
|
|
92
|
+
disabledReason: {
|
|
93
|
+
type: String
|
|
94
|
+
},
|
|
95
|
+
reactivatedDate: {
|
|
96
|
+
type: Date
|
|
97
|
+
},
|
|
98
|
+
reactivatedBy: {
|
|
99
|
+
type: mongoose.Schema.Types.ObjectId,
|
|
100
|
+
ref: 'User'
|
|
101
|
+
},
|
|
102
|
+
lastInvoiceYearMonth: {
|
|
103
|
+
type: String,
|
|
104
|
+
default: null
|
|
105
|
+
// Format: "2025-09", "2025-10", etc.
|
|
106
|
+
}
|
|
107
|
+
},
|
|
108
|
+
{
|
|
109
|
+
timestamps: true,
|
|
110
|
+
toJSON: { virtuals: true },
|
|
111
|
+
toObject: { virtuals: true }
|
|
112
|
+
}
|
|
113
|
+
);
|
|
114
|
+
|
|
115
|
+
// Virtual populate for Levy details
|
|
116
|
+
LevyContractSchema.virtual('levy', {
|
|
117
|
+
ref: 'Levy',
|
|
118
|
+
localField: 'levyId',
|
|
119
|
+
foreignField: '_id',
|
|
120
|
+
justOne: true
|
|
121
|
+
});
|
|
122
|
+
|
|
123
|
+
// Virtual populate for Customer details
|
|
124
|
+
LevyContractSchema.virtual('customer', {
|
|
125
|
+
ref: 'Customer',
|
|
126
|
+
localField: 'customerId',
|
|
127
|
+
foreignField: '_id',
|
|
128
|
+
justOne: true
|
|
129
|
+
});
|
|
130
|
+
|
|
131
|
+
// Virtual populate for Unit details
|
|
132
|
+
LevyContractSchema.virtual('unit', {
|
|
133
|
+
ref: 'Unit',
|
|
134
|
+
localField: 'unitId',
|
|
135
|
+
foreignField: '_id',
|
|
136
|
+
justOne: true
|
|
137
|
+
});
|
|
138
|
+
|
|
139
|
+
// Pre-save middleware to ensure endDate is after startDate
|
|
140
|
+
LevyContractSchema.pre('save', function (next) {
|
|
141
|
+
if (this.startDate && this.endDate && this.startDate >= this.endDate) {
|
|
142
|
+
next(new Error('End date must be after start date'));
|
|
143
|
+
} else {
|
|
144
|
+
next();
|
|
145
|
+
}
|
|
146
|
+
});
|
|
147
|
+
|
|
148
|
+
// Pre-save middleware to handle termination and disable date logic
|
|
149
|
+
LevyContractSchema.pre('save', function (next) {
|
|
150
|
+
// Set termination date when status changes to Terminated
|
|
151
|
+
if (this.status === 'Terminated' && !this.terminationDate) {
|
|
152
|
+
this.terminationDate = new Date();
|
|
153
|
+
}
|
|
154
|
+
|
|
155
|
+
// Set disabled date when status changes to Inactive
|
|
156
|
+
if (this.status === 'Inactive' && !this.disabledDate && this.isModified('status')) {
|
|
157
|
+
this.disabledDate = new Date();
|
|
158
|
+
}
|
|
159
|
+
|
|
160
|
+
// Set reactivated date when status changes from Inactive to Active
|
|
161
|
+
if (this.status === 'Active' && this.isModified('status') && this.disabledDate) {
|
|
162
|
+
this.reactivatedDate = new Date();
|
|
163
|
+
}
|
|
164
|
+
|
|
165
|
+
next();
|
|
166
|
+
});
|
|
167
|
+
|
|
168
|
+
// Index for efficient queries
|
|
169
|
+
LevyContractSchema.index({ levyId: 1, unitId: 1, status: 1 });
|
|
170
|
+
LevyContractSchema.index({ facilityId: 1 });
|
|
171
|
+
LevyContractSchema.index({ customerId: 1 });
|
|
172
|
+
LevyContractSchema.index({ status: 1 });
|
|
173
|
+
LevyContractSchema.index({ terminationDate: 1 });
|
|
174
|
+
|
|
175
|
+
module.exports = {
|
|
176
|
+
schema: LevyContractSchema,
|
|
177
|
+
name: 'LevyContract'
|
|
178
178
|
};
|
package/src/models/levytype.js
CHANGED
|
@@ -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);
|
|
@@ -1,32 +1,32 @@
|
|
|
1
|
-
const mongoose = require("mongoose");
|
|
2
|
-
|
|
3
|
-
const masterWorkplanSchema = new mongoose.Schema({
|
|
4
|
-
facility: {
|
|
5
|
-
type: mongoose.Schema.Types.ObjectId,
|
|
6
|
-
ref: "Facility",
|
|
7
|
-
required: true,
|
|
8
|
-
},
|
|
9
|
-
title: {
|
|
10
|
-
type: String,
|
|
11
|
-
required: true,
|
|
12
|
-
unique: true,
|
|
13
|
-
},
|
|
14
|
-
description: {
|
|
15
|
-
type: String,
|
|
16
|
-
required: true,
|
|
17
|
-
},
|
|
18
|
-
life: {
|
|
19
|
-
type: String,
|
|
20
|
-
enum: ["Active", "Inactive"],
|
|
21
|
-
default: "Active",
|
|
22
|
-
},
|
|
23
|
-
status: {
|
|
24
|
-
type: String,
|
|
25
|
-
enum: ["Approved", "Rejected", "Pending"],
|
|
26
|
-
default: "Approved",
|
|
27
|
-
},
|
|
28
|
-
});
|
|
29
|
-
|
|
30
|
-
const MasterWorkplan = mongoose.model("MasterWorkplan", masterWorkplanSchema);
|
|
31
|
-
|
|
32
|
-
module.exports = MasterWorkplan;
|
|
1
|
+
const mongoose = require("mongoose");
|
|
2
|
+
|
|
3
|
+
const masterWorkplanSchema = new mongoose.Schema({
|
|
4
|
+
facility: {
|
|
5
|
+
type: mongoose.Schema.Types.ObjectId,
|
|
6
|
+
ref: "Facility",
|
|
7
|
+
required: true,
|
|
8
|
+
},
|
|
9
|
+
title: {
|
|
10
|
+
type: String,
|
|
11
|
+
required: true,
|
|
12
|
+
unique: true,
|
|
13
|
+
},
|
|
14
|
+
description: {
|
|
15
|
+
type: String,
|
|
16
|
+
required: true,
|
|
17
|
+
},
|
|
18
|
+
life: {
|
|
19
|
+
type: String,
|
|
20
|
+
enum: ["Active", "Inactive"],
|
|
21
|
+
default: "Active",
|
|
22
|
+
},
|
|
23
|
+
status: {
|
|
24
|
+
type: String,
|
|
25
|
+
enum: ["Approved", "Rejected", "Pending"],
|
|
26
|
+
default: "Approved",
|
|
27
|
+
},
|
|
28
|
+
});
|
|
29
|
+
|
|
30
|
+
const MasterWorkplan = mongoose.model("MasterWorkplan", masterWorkplanSchema);
|
|
31
|
+
|
|
32
|
+
module.exports = MasterWorkplan;
|