payservedb 9.1.0 → 9.1.2
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 +401 -401
- package/package.json +17 -17
- package/src/models/InvoiceWithholdingTax.js +67 -67
- 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/auto_reply_rule.js +68 -68
- 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 +179 -179
- package/src/models/bookingreservation.js +239 -239
- 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 +290 -290
- package/src/models/combinedUnits.js +62 -62
- package/src/models/combined_invoice.js +424 -424
- 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 +35 -35
- 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 +234 -234
- package/src/models/customer_preference.js +52 -52
- package/src/models/customer_satisfaction_survey.js +297 -297
- package/src/models/customer_surveys.js +139 -139
- package/src/models/customer_tickets.js +237 -237
- 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_cc_config.js +48 -48
- package/src/models/email_sms_queue.js +61 -61
- package/src/models/email_thread.js +35 -35
- 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 +76 -76
- 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_etims_config.js +116 -116
- package/src/models/facility_payment_details.js +20 -20
- package/src/models/facility_rating.js +78 -78
- package/src/models/facilityasset.js +25 -25
- package/src/models/faq.js +15 -15
- 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 +258 -258
- package/src/models/inspection_category.js +38 -38
- package/src/models/invoice.js +528 -525
- package/src/models/invoiceCreditAdjustment.js +45 -45
- package/src/models/invoice_edit_log.js +81 -81
- package/src/models/invoice_generation_approval.js +86 -86
- package/src/models/invoicing_schedule.js +40 -40
- 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 +243 -243
- package/src/models/leasetemplate.js +17 -17
- package/src/models/levy.js +212 -212
- package/src/models/levy_invoice_settings.js +26 -26
- package/src/models/levycontract.js +215 -215
- 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/movein_application.js +29 -29
- package/src/models/movein_audit_log.js +21 -21
- package/src/models/movein_booking.js +33 -33
- package/src/models/movein_commission.js +46 -46
- package/src/models/movein_conversation.js +25 -25
- package/src/models/movein_deal.js +79 -79
- package/src/models/movein_handoff_token.js +16 -16
- package/src/models/movein_landlord.js +18 -18
- package/src/models/movein_landlord_user.js +20 -20
- package/src/models/movein_message.js +27 -27
- package/src/models/movein_notification.js +27 -27
- package/src/models/movein_otp.js +14 -14
- package/src/models/movein_payment.js +46 -46
- package/src/models/movein_reminder.js +77 -77
- package/src/models/movein_reservation.js +31 -31
- package/src/models/movein_unit.js +59 -59
- package/src/models/movein_user.js +15 -15
- package/src/models/movein_viewing_slot.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 +200 -200
- package/src/models/powerMeterSingleDayReading.js +32 -32
- package/src/models/powerMeters.js +149 -149
- package/src/models/powerMetersManufacturer.js +14 -14
- package/src/models/power_invoice.js +359 -359
- 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/quickbooks_config.js +52 -52
- package/src/models/recipient_group.js +61 -61
- package/src/models/recipient_group_member.js +62 -62
- 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 +79 -79
- 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 +130 -130
- package/src/models/user.js +186 -186
- package/src/models/valueaddedservices.js +21 -21
- package/src/models/vas_invoices_upload.js +50 -50
- package/src/models/vas_payments.js +24 -24
- package/src/models/vasinvoice.js +196 -196
- package/src/models/vasvendor.js +52 -52
- 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 +86 -86
- package/src/models/water_meter_billing.js +58 -58
- package/src/models/water_meter_combined_accounts.js +92 -92
- 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_loan_deduction.js +134 -134
- 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 +290 -290
- 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 +176 -176
- 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/whatsapp_conversation.js +23 -23
- 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,46 +1,46 @@
|
|
|
1
|
-
const mongoose = require("mongoose");
|
|
2
|
-
|
|
3
|
-
const invoiceCreditAdjustmentSchema = new mongoose.Schema(
|
|
4
|
-
{
|
|
5
|
-
invoice: {
|
|
6
|
-
id: { type: mongoose.Schema.Types.ObjectId, ref: "Invoice", required: true },
|
|
7
|
-
invoiceNumber: { type: String, required: true },
|
|
8
|
-
},
|
|
9
|
-
facility: {
|
|
10
|
-
id: { type: mongoose.Schema.Types.ObjectId, ref: "Facility", required: true },
|
|
11
|
-
name: { type: String, required: true },
|
|
12
|
-
},
|
|
13
|
-
client: {
|
|
14
|
-
clientId: { type: mongoose.Schema.Types.ObjectId, ref: "Customer", required: true },
|
|
15
|
-
firstName: { type: String, required: true },
|
|
16
|
-
lastName: { type: String, required: true },
|
|
17
|
-
},
|
|
18
|
-
adjustmentType: {
|
|
19
|
-
type: String,
|
|
20
|
-
enum: ["credit", "debit", "opening-balance"],
|
|
21
|
-
required: true,
|
|
22
|
-
},
|
|
23
|
-
previousBalance: { type: Number, required: true }, // balanceBroughtForward before change
|
|
24
|
-
adjustmentAmount: { type: Number, required: true }, // the actual change (can be negative)
|
|
25
|
-
newBalance: { type: Number, required: true }, // balanceBroughtForward after change
|
|
26
|
-
reason: { type: String, required: true },
|
|
27
|
-
madeBy: {
|
|
28
|
-
userId: { type: mongoose.Schema.Types.ObjectId, ref: "User", required: true },
|
|
29
|
-
name: { type: String, required: true },
|
|
30
|
-
role: { type: String, required: true },
|
|
31
|
-
},
|
|
32
|
-
},
|
|
33
|
-
{ timestamps: true }
|
|
34
|
-
);
|
|
35
|
-
|
|
36
|
-
invoiceCreditAdjustmentSchema.index({ "invoice.id": 1 });
|
|
37
|
-
invoiceCreditAdjustmentSchema.index({ "client.clientId": 1 });
|
|
38
|
-
invoiceCreditAdjustmentSchema.index({ "facility.id": 1 });
|
|
39
|
-
invoiceCreditAdjustmentSchema.index({ adjustmentType: 1 });
|
|
40
|
-
|
|
41
|
-
const InvoiceCreditAdjustment = mongoose.model(
|
|
42
|
-
"InvoiceCreditAdjustment",
|
|
43
|
-
invoiceCreditAdjustmentSchema
|
|
44
|
-
);
|
|
45
|
-
|
|
1
|
+
const mongoose = require("mongoose");
|
|
2
|
+
|
|
3
|
+
const invoiceCreditAdjustmentSchema = new mongoose.Schema(
|
|
4
|
+
{
|
|
5
|
+
invoice: {
|
|
6
|
+
id: { type: mongoose.Schema.Types.ObjectId, ref: "Invoice", required: true },
|
|
7
|
+
invoiceNumber: { type: String, required: true },
|
|
8
|
+
},
|
|
9
|
+
facility: {
|
|
10
|
+
id: { type: mongoose.Schema.Types.ObjectId, ref: "Facility", required: true },
|
|
11
|
+
name: { type: String, required: true },
|
|
12
|
+
},
|
|
13
|
+
client: {
|
|
14
|
+
clientId: { type: mongoose.Schema.Types.ObjectId, ref: "Customer", required: true },
|
|
15
|
+
firstName: { type: String, required: true },
|
|
16
|
+
lastName: { type: String, required: true },
|
|
17
|
+
},
|
|
18
|
+
adjustmentType: {
|
|
19
|
+
type: String,
|
|
20
|
+
enum: ["credit", "debit", "opening-balance"],
|
|
21
|
+
required: true,
|
|
22
|
+
},
|
|
23
|
+
previousBalance: { type: Number, required: true }, // balanceBroughtForward before change
|
|
24
|
+
adjustmentAmount: { type: Number, required: true }, // the actual change (can be negative)
|
|
25
|
+
newBalance: { type: Number, required: true }, // balanceBroughtForward after change
|
|
26
|
+
reason: { type: String, required: true },
|
|
27
|
+
madeBy: {
|
|
28
|
+
userId: { type: mongoose.Schema.Types.ObjectId, ref: "User", required: true },
|
|
29
|
+
name: { type: String, required: true },
|
|
30
|
+
role: { type: String, required: true },
|
|
31
|
+
},
|
|
32
|
+
},
|
|
33
|
+
{ timestamps: true }
|
|
34
|
+
);
|
|
35
|
+
|
|
36
|
+
invoiceCreditAdjustmentSchema.index({ "invoice.id": 1 });
|
|
37
|
+
invoiceCreditAdjustmentSchema.index({ "client.clientId": 1 });
|
|
38
|
+
invoiceCreditAdjustmentSchema.index({ "facility.id": 1 });
|
|
39
|
+
invoiceCreditAdjustmentSchema.index({ adjustmentType: 1 });
|
|
40
|
+
|
|
41
|
+
const InvoiceCreditAdjustment = mongoose.model(
|
|
42
|
+
"InvoiceCreditAdjustment",
|
|
43
|
+
invoiceCreditAdjustmentSchema
|
|
44
|
+
);
|
|
45
|
+
|
|
46
46
|
module.exports = InvoiceCreditAdjustment;
|
|
@@ -1,82 +1,82 @@
|
|
|
1
|
-
const mongoose = require("mongoose");
|
|
2
|
-
|
|
3
|
-
const invoiceEditLogSchema = new mongoose.Schema(
|
|
4
|
-
{
|
|
5
|
-
// Invoice reference
|
|
6
|
-
invoiceId: {
|
|
7
|
-
type: mongoose.Schema.Types.ObjectId,
|
|
8
|
-
required: true,
|
|
9
|
-
},
|
|
10
|
-
invoiceNumber: {
|
|
11
|
-
type: String,
|
|
12
|
-
required: true,
|
|
13
|
-
},
|
|
14
|
-
invoiceType: {
|
|
15
|
-
type: String,
|
|
16
|
-
required: true,
|
|
17
|
-
},
|
|
18
|
-
|
|
19
|
-
// Unit & Customer context
|
|
20
|
-
unit: {
|
|
21
|
-
type: String,
|
|
22
|
-
required: true,
|
|
23
|
-
},
|
|
24
|
-
customerName: {
|
|
25
|
-
type: String,
|
|
26
|
-
required: true,
|
|
27
|
-
},
|
|
28
|
-
|
|
29
|
-
// Who edited
|
|
30
|
-
editedBy: {
|
|
31
|
-
userId: {
|
|
32
|
-
type: mongoose.Schema.Types.ObjectId,
|
|
33
|
-
ref: "User",
|
|
34
|
-
required: true,
|
|
35
|
-
},
|
|
36
|
-
name: {
|
|
37
|
-
type: String,
|
|
38
|
-
required: true,
|
|
39
|
-
},
|
|
40
|
-
},
|
|
41
|
-
|
|
42
|
-
// What was changed
|
|
43
|
-
changes: [
|
|
44
|
-
{
|
|
45
|
-
field: {
|
|
46
|
-
type: String,
|
|
47
|
-
required: true,
|
|
48
|
-
enum: [
|
|
49
|
-
"amount",
|
|
50
|
-
"balanceBroughtForward",
|
|
51
|
-
"totalBalance",
|
|
52
|
-
"customer",
|
|
53
|
-
],
|
|
54
|
-
},
|
|
55
|
-
previousValue: {
|
|
56
|
-
type: mongoose.Schema.Types.Mixed,
|
|
57
|
-
required: true,
|
|
58
|
-
},
|
|
59
|
-
newValue: {
|
|
60
|
-
type: mongoose.Schema.Types.Mixed,
|
|
61
|
-
required: true,
|
|
62
|
-
},
|
|
63
|
-
description: {
|
|
64
|
-
type: String,
|
|
65
|
-
required: true,
|
|
66
|
-
// e.g. "Amount updated from KES 5,000 to KES 6,000"
|
|
67
|
-
},
|
|
68
|
-
},
|
|
69
|
-
],
|
|
70
|
-
},
|
|
71
|
-
{
|
|
72
|
-
timestamps: true, // gives you createdAt as your date & time
|
|
73
|
-
}
|
|
74
|
-
);
|
|
75
|
-
|
|
76
|
-
invoiceEditLogSchema.index({ invoiceId: 1 });
|
|
77
|
-
invoiceEditLogSchema.index({ invoiceNumber: 1 });
|
|
78
|
-
invoiceEditLogSchema.index({ "editedBy.userId": 1 });
|
|
79
|
-
|
|
80
|
-
const InvoiceEditLog = mongoose.model("InvoiceEditLog", invoiceEditLogSchema);
|
|
81
|
-
|
|
1
|
+
const mongoose = require("mongoose");
|
|
2
|
+
|
|
3
|
+
const invoiceEditLogSchema = new mongoose.Schema(
|
|
4
|
+
{
|
|
5
|
+
// Invoice reference
|
|
6
|
+
invoiceId: {
|
|
7
|
+
type: mongoose.Schema.Types.ObjectId,
|
|
8
|
+
required: true,
|
|
9
|
+
},
|
|
10
|
+
invoiceNumber: {
|
|
11
|
+
type: String,
|
|
12
|
+
required: true,
|
|
13
|
+
},
|
|
14
|
+
invoiceType: {
|
|
15
|
+
type: String,
|
|
16
|
+
required: true,
|
|
17
|
+
},
|
|
18
|
+
|
|
19
|
+
// Unit & Customer context
|
|
20
|
+
unit: {
|
|
21
|
+
type: String,
|
|
22
|
+
required: true,
|
|
23
|
+
},
|
|
24
|
+
customerName: {
|
|
25
|
+
type: String,
|
|
26
|
+
required: true,
|
|
27
|
+
},
|
|
28
|
+
|
|
29
|
+
// Who edited
|
|
30
|
+
editedBy: {
|
|
31
|
+
userId: {
|
|
32
|
+
type: mongoose.Schema.Types.ObjectId,
|
|
33
|
+
ref: "User",
|
|
34
|
+
required: true,
|
|
35
|
+
},
|
|
36
|
+
name: {
|
|
37
|
+
type: String,
|
|
38
|
+
required: true,
|
|
39
|
+
},
|
|
40
|
+
},
|
|
41
|
+
|
|
42
|
+
// What was changed
|
|
43
|
+
changes: [
|
|
44
|
+
{
|
|
45
|
+
field: {
|
|
46
|
+
type: String,
|
|
47
|
+
required: true,
|
|
48
|
+
enum: [
|
|
49
|
+
"amount",
|
|
50
|
+
"balanceBroughtForward",
|
|
51
|
+
"totalBalance",
|
|
52
|
+
"customer",
|
|
53
|
+
],
|
|
54
|
+
},
|
|
55
|
+
previousValue: {
|
|
56
|
+
type: mongoose.Schema.Types.Mixed,
|
|
57
|
+
required: true,
|
|
58
|
+
},
|
|
59
|
+
newValue: {
|
|
60
|
+
type: mongoose.Schema.Types.Mixed,
|
|
61
|
+
required: true,
|
|
62
|
+
},
|
|
63
|
+
description: {
|
|
64
|
+
type: String,
|
|
65
|
+
required: true,
|
|
66
|
+
// e.g. "Amount updated from KES 5,000 to KES 6,000"
|
|
67
|
+
},
|
|
68
|
+
},
|
|
69
|
+
],
|
|
70
|
+
},
|
|
71
|
+
{
|
|
72
|
+
timestamps: true, // gives you createdAt as your date & time
|
|
73
|
+
}
|
|
74
|
+
);
|
|
75
|
+
|
|
76
|
+
invoiceEditLogSchema.index({ invoiceId: 1 });
|
|
77
|
+
invoiceEditLogSchema.index({ invoiceNumber: 1 });
|
|
78
|
+
invoiceEditLogSchema.index({ "editedBy.userId": 1 });
|
|
79
|
+
|
|
80
|
+
const InvoiceEditLog = mongoose.model("InvoiceEditLog", invoiceEditLogSchema);
|
|
81
|
+
|
|
82
82
|
module.exports = InvoiceEditLog;
|
|
@@ -1,87 +1,87 @@
|
|
|
1
|
-
const mongoose = require('mongoose');
|
|
2
|
-
|
|
3
|
-
const invoiceGenerationSchema = new mongoose.Schema(
|
|
4
|
-
{
|
|
5
|
-
invoiceType: {
|
|
6
|
-
type: String,
|
|
7
|
-
enum: ['levy', 'lease'],
|
|
8
|
-
required: true
|
|
9
|
-
},
|
|
10
|
-
facility: {
|
|
11
|
-
id: {
|
|
12
|
-
type: mongoose.Schema.Types.ObjectId,
|
|
13
|
-
ref: "Facility",
|
|
14
|
-
required: true
|
|
15
|
-
},
|
|
16
|
-
name: {
|
|
17
|
-
type: String,
|
|
18
|
-
required: true,
|
|
19
|
-
trim: true
|
|
20
|
-
}
|
|
21
|
-
},
|
|
22
|
-
yearMonth: {
|
|
23
|
-
type: String,
|
|
24
|
-
required: true,
|
|
25
|
-
trim: true
|
|
26
|
-
},
|
|
27
|
-
generationDate: {
|
|
28
|
-
type: Date,
|
|
29
|
-
required: true,
|
|
30
|
-
default: Date.now
|
|
31
|
-
},
|
|
32
|
-
approvalStatus: {
|
|
33
|
-
type: String,
|
|
34
|
-
enum: ['Pending', 'Approved', 'Rejected'],
|
|
35
|
-
default: 'Pending'
|
|
36
|
-
},
|
|
37
|
-
approvedBy: {
|
|
38
|
-
userId: mongoose.Schema.Types.ObjectId,
|
|
39
|
-
name: String,
|
|
40
|
-
approvalDate: Date,
|
|
41
|
-
comments: String
|
|
42
|
-
},
|
|
43
|
-
rejectedBy: {
|
|
44
|
-
userId: mongoose.Schema.Types.ObjectId,
|
|
45
|
-
name: String,
|
|
46
|
-
rejectionDate: Date,
|
|
47
|
-
reason: String
|
|
48
|
-
},
|
|
49
|
-
metadata: {
|
|
50
|
-
createdBy: {
|
|
51
|
-
type: mongoose.Schema.Types.ObjectId
|
|
52
|
-
},
|
|
53
|
-
source: {
|
|
54
|
-
type: String,
|
|
55
|
-
enum: ['manual', 'api', 'import', 'mobile'],
|
|
56
|
-
default: 'manual'
|
|
57
|
-
},
|
|
58
|
-
deviceInfo: {
|
|
59
|
-
deviceId: String,
|
|
60
|
-
deviceType: String,
|
|
61
|
-
ipAddress: String
|
|
62
|
-
}
|
|
63
|
-
}
|
|
64
|
-
},
|
|
65
|
-
{
|
|
66
|
-
timestamps: true
|
|
67
|
-
}
|
|
68
|
-
);
|
|
69
|
-
|
|
70
|
-
// Static methods
|
|
71
|
-
invoiceGenerationSchema.statics.findPendingGenerations = function (facilityId) {
|
|
72
|
-
return this.find({
|
|
73
|
-
'facility.id': facilityId,
|
|
74
|
-
'approvalStatus': 'Pending'
|
|
75
|
-
}).sort({ generationDate: -1 });
|
|
76
|
-
};
|
|
77
|
-
|
|
78
|
-
invoiceGenerationSchema.statics.findByType = function (invoiceType, facilityId) {
|
|
79
|
-
return this.find({
|
|
80
|
-
'facility.id': facilityId,
|
|
81
|
-
'invoiceType': invoiceType
|
|
82
|
-
}).sort({ generationDate: -1 });
|
|
83
|
-
};
|
|
84
|
-
|
|
85
|
-
const InvoiceGeneration = mongoose.model('InvoiceGeneration', invoiceGenerationSchema);
|
|
86
|
-
|
|
1
|
+
const mongoose = require('mongoose');
|
|
2
|
+
|
|
3
|
+
const invoiceGenerationSchema = new mongoose.Schema(
|
|
4
|
+
{
|
|
5
|
+
invoiceType: {
|
|
6
|
+
type: String,
|
|
7
|
+
enum: ['levy', 'lease'],
|
|
8
|
+
required: true
|
|
9
|
+
},
|
|
10
|
+
facility: {
|
|
11
|
+
id: {
|
|
12
|
+
type: mongoose.Schema.Types.ObjectId,
|
|
13
|
+
ref: "Facility",
|
|
14
|
+
required: true
|
|
15
|
+
},
|
|
16
|
+
name: {
|
|
17
|
+
type: String,
|
|
18
|
+
required: true,
|
|
19
|
+
trim: true
|
|
20
|
+
}
|
|
21
|
+
},
|
|
22
|
+
yearMonth: {
|
|
23
|
+
type: String,
|
|
24
|
+
required: true,
|
|
25
|
+
trim: true
|
|
26
|
+
},
|
|
27
|
+
generationDate: {
|
|
28
|
+
type: Date,
|
|
29
|
+
required: true,
|
|
30
|
+
default: Date.now
|
|
31
|
+
},
|
|
32
|
+
approvalStatus: {
|
|
33
|
+
type: String,
|
|
34
|
+
enum: ['Pending', 'Approved', 'Rejected'],
|
|
35
|
+
default: 'Pending'
|
|
36
|
+
},
|
|
37
|
+
approvedBy: {
|
|
38
|
+
userId: mongoose.Schema.Types.ObjectId,
|
|
39
|
+
name: String,
|
|
40
|
+
approvalDate: Date,
|
|
41
|
+
comments: String
|
|
42
|
+
},
|
|
43
|
+
rejectedBy: {
|
|
44
|
+
userId: mongoose.Schema.Types.ObjectId,
|
|
45
|
+
name: String,
|
|
46
|
+
rejectionDate: Date,
|
|
47
|
+
reason: String
|
|
48
|
+
},
|
|
49
|
+
metadata: {
|
|
50
|
+
createdBy: {
|
|
51
|
+
type: mongoose.Schema.Types.ObjectId
|
|
52
|
+
},
|
|
53
|
+
source: {
|
|
54
|
+
type: String,
|
|
55
|
+
enum: ['manual', 'api', 'import', 'mobile'],
|
|
56
|
+
default: 'manual'
|
|
57
|
+
},
|
|
58
|
+
deviceInfo: {
|
|
59
|
+
deviceId: String,
|
|
60
|
+
deviceType: String,
|
|
61
|
+
ipAddress: String
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
},
|
|
65
|
+
{
|
|
66
|
+
timestamps: true
|
|
67
|
+
}
|
|
68
|
+
);
|
|
69
|
+
|
|
70
|
+
// Static methods
|
|
71
|
+
invoiceGenerationSchema.statics.findPendingGenerations = function (facilityId) {
|
|
72
|
+
return this.find({
|
|
73
|
+
'facility.id': facilityId,
|
|
74
|
+
'approvalStatus': 'Pending'
|
|
75
|
+
}).sort({ generationDate: -1 });
|
|
76
|
+
};
|
|
77
|
+
|
|
78
|
+
invoiceGenerationSchema.statics.findByType = function (invoiceType, facilityId) {
|
|
79
|
+
return this.find({
|
|
80
|
+
'facility.id': facilityId,
|
|
81
|
+
'invoiceType': invoiceType
|
|
82
|
+
}).sort({ generationDate: -1 });
|
|
83
|
+
};
|
|
84
|
+
|
|
85
|
+
const InvoiceGeneration = mongoose.model('InvoiceGeneration', invoiceGenerationSchema);
|
|
86
|
+
|
|
87
87
|
module.exports = InvoiceGeneration;
|
|
@@ -1,41 +1,41 @@
|
|
|
1
|
-
const mongoose = require('mongoose');
|
|
2
|
-
|
|
3
|
-
const InvoicingScheduleSchema = new mongoose.Schema({
|
|
4
|
-
facilityId: {
|
|
5
|
-
type: mongoose.Schema.Types.ObjectId,
|
|
6
|
-
ref: 'Facility',
|
|
7
|
-
},
|
|
8
|
-
nextInvoiceDate: {
|
|
9
|
-
type: Date,
|
|
10
|
-
required: true
|
|
11
|
-
},
|
|
12
|
-
invoiceType: {
|
|
13
|
-
type: String,
|
|
14
|
-
required: true,
|
|
15
|
-
unique: true,
|
|
16
|
-
trim: true,
|
|
17
|
-
index: true
|
|
18
|
-
},
|
|
19
|
-
isAutomatic: {
|
|
20
|
-
type: Boolean,
|
|
21
|
-
required: true,
|
|
22
|
-
default: true
|
|
23
|
-
},
|
|
24
|
-
createdAt: {
|
|
25
|
-
type: Date,
|
|
26
|
-
default: Date.now
|
|
27
|
-
},
|
|
28
|
-
updatedAt: {
|
|
29
|
-
type: Date,
|
|
30
|
-
default: Date.now
|
|
31
|
-
}
|
|
32
|
-
});
|
|
33
|
-
|
|
34
|
-
InvoicingScheduleSchema.pre('save', function(next) {
|
|
35
|
-
this.updatedAt = Date.now();
|
|
36
|
-
next();
|
|
37
|
-
});
|
|
38
|
-
|
|
39
|
-
const InvoicingSchedule = mongoose.model('InvoicingSchedule', InvoicingScheduleSchema);
|
|
40
|
-
|
|
1
|
+
const mongoose = require('mongoose');
|
|
2
|
+
|
|
3
|
+
const InvoicingScheduleSchema = new mongoose.Schema({
|
|
4
|
+
facilityId: {
|
|
5
|
+
type: mongoose.Schema.Types.ObjectId,
|
|
6
|
+
ref: 'Facility',
|
|
7
|
+
},
|
|
8
|
+
nextInvoiceDate: {
|
|
9
|
+
type: Date,
|
|
10
|
+
required: true
|
|
11
|
+
},
|
|
12
|
+
invoiceType: {
|
|
13
|
+
type: String,
|
|
14
|
+
required: true,
|
|
15
|
+
unique: true,
|
|
16
|
+
trim: true,
|
|
17
|
+
index: true
|
|
18
|
+
},
|
|
19
|
+
isAutomatic: {
|
|
20
|
+
type: Boolean,
|
|
21
|
+
required: true,
|
|
22
|
+
default: true
|
|
23
|
+
},
|
|
24
|
+
createdAt: {
|
|
25
|
+
type: Date,
|
|
26
|
+
default: Date.now
|
|
27
|
+
},
|
|
28
|
+
updatedAt: {
|
|
29
|
+
type: Date,
|
|
30
|
+
default: Date.now
|
|
31
|
+
}
|
|
32
|
+
});
|
|
33
|
+
|
|
34
|
+
InvoicingScheduleSchema.pre('save', function(next) {
|
|
35
|
+
this.updatedAt = Date.now();
|
|
36
|
+
next();
|
|
37
|
+
});
|
|
38
|
+
|
|
39
|
+
const InvoicingSchedule = mongoose.model('InvoicingSchedule', InvoicingScheduleSchema);
|
|
40
|
+
|
|
41
41
|
module.exports = InvoicingSchedule;
|