@vibe-flats/booking-engine-common-server 1.0.101 → 1.0.105
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/build/src/models/units-distances.d.ts +15 -0
- package/build/src/models/units-distances.js +47 -0
- package/build/src/units-models.d.ts +3 -0
- package/build/src/units-models.js +2 -0
- package/build/src/utils/guesty-price.d.ts +16 -7
- package/build/src/utils/guesty-price.js +22 -9
- package/package.json +1 -1
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import mongoose from 'mongoose';
|
|
2
|
+
import { UnitDocument } from './units';
|
|
3
|
+
export interface UnitDistanceDocument extends mongoose.Document {
|
|
4
|
+
unitA: UnitDocument;
|
|
5
|
+
unitB: UnitDocument;
|
|
6
|
+
distance: {
|
|
7
|
+
miles: number;
|
|
8
|
+
kilometers: number;
|
|
9
|
+
};
|
|
10
|
+
createdAt: Date;
|
|
11
|
+
updatedAt: Date;
|
|
12
|
+
}
|
|
13
|
+
export declare const UnitDistanceModel: (connection: mongoose.Connection) => mongoose.Model<UnitDistanceDocument, {}, {}, {}, mongoose.Document<unknown, {}, UnitDistanceDocument> & UnitDistanceDocument & Required<{
|
|
14
|
+
_id: unknown;
|
|
15
|
+
}>, any>;
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
25
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
+
exports.UnitDistanceModel = void 0;
|
|
27
|
+
const mongoose_1 = __importStar(require("mongoose"));
|
|
28
|
+
const schema = new mongoose_1.default.Schema({
|
|
29
|
+
unitA: { type: mongoose_1.Schema.Types.ObjectId, ref: 'Unit', required: true },
|
|
30
|
+
unitB: { type: mongoose_1.Schema.Types.ObjectId, ref: 'Unit', required: true },
|
|
31
|
+
distance: {
|
|
32
|
+
miles: { type: Number, required: true },
|
|
33
|
+
kilometers: { type: Number, required: true }
|
|
34
|
+
}
|
|
35
|
+
}, {
|
|
36
|
+
timestamps: true,
|
|
37
|
+
versionKey: false
|
|
38
|
+
});
|
|
39
|
+
// Create a compound index for efficient lookups
|
|
40
|
+
schema.index({ unitA: 1, unitB: 1 }, { unique: true });
|
|
41
|
+
// Create single indexes for when you want to find all distances from a specific unit
|
|
42
|
+
schema.index({ unitA: 1 });
|
|
43
|
+
schema.index({ unitB: 1 });
|
|
44
|
+
const UnitDistanceModel = (connection) => {
|
|
45
|
+
return connection.model('UnitDistance', schema);
|
|
46
|
+
};
|
|
47
|
+
exports.UnitDistanceModel = UnitDistanceModel;
|
|
@@ -9,6 +9,9 @@ export declare const unitsModels: (connection: mongoose.Connection) => {
|
|
|
9
9
|
UnitModel: mongoose.Model<import("./models/units").UnitDocument, {}, {}, {}, mongoose.Document<unknown, {}, import("./models/units").UnitDocument> & import("./models/units").UnitDocument & Required<{
|
|
10
10
|
_id: unknown;
|
|
11
11
|
}>, any>;
|
|
12
|
+
UnitDistanceModel: mongoose.Model<import("./models/units-distances").UnitDistanceDocument, {}, {}, {}, mongoose.Document<unknown, {}, import("./models/units-distances").UnitDistanceDocument> & import("./models/units-distances").UnitDistanceDocument & Required<{
|
|
13
|
+
_id: unknown;
|
|
14
|
+
}>, any>;
|
|
12
15
|
AvailabilityModel: mongoose.Model<import("./models/availability").AvailabilityDocument, {}, {}, {}, mongoose.Document<unknown, {}, import("./models/availability").AvailabilityDocument> & import("./models/availability").AvailabilityDocument & Required<{
|
|
13
16
|
_id: unknown;
|
|
14
17
|
}>, any>;
|
|
@@ -8,10 +8,12 @@ const building_1 = require("./models/building");
|
|
|
8
8
|
const areas_1 = require("./models/areas");
|
|
9
9
|
const markets_1 = require("./models/markets");
|
|
10
10
|
const guests_1 = require("./models/guests");
|
|
11
|
+
const units_distances_1 = require("./models/units-distances");
|
|
11
12
|
const unitsModels = (connection) => ({
|
|
12
13
|
MarketModel: (0, markets_1.MarketModel)(connection),
|
|
13
14
|
CityModel: (0, cities_1.CityModel)(connection),
|
|
14
15
|
UnitModel: (0, units_1.UnitModel)(connection),
|
|
16
|
+
UnitDistanceModel: (0, units_distances_1.UnitDistanceModel)(connection),
|
|
15
17
|
AvailabilityModel: (0, availability_1.AvailabilityModel)(connection),
|
|
16
18
|
BuildingModel: (0, building_1.BuildingModel)(connection),
|
|
17
19
|
AreaModel: (0, areas_1.AreaModel)(connection),
|
|
@@ -1,14 +1,23 @@
|
|
|
1
|
-
import { AvailabilityDocument } from '../models/availability';
|
|
2
1
|
import { UnitDocument } from '../models/units';
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
stay: AvailabilityDocument[];
|
|
6
|
-
excludeCleaning?: boolean;
|
|
7
|
-
}) => {
|
|
2
|
+
import { AvailabilityDocument } from '../models/availability';
|
|
3
|
+
export interface VibePrice {
|
|
8
4
|
nights: number;
|
|
9
5
|
rent: number;
|
|
10
6
|
cleaning: number;
|
|
11
7
|
utilities: number;
|
|
8
|
+
subTotal: number;
|
|
12
9
|
total: number;
|
|
13
10
|
discount: number;
|
|
14
|
-
|
|
11
|
+
monthly: {
|
|
12
|
+
discount: number;
|
|
13
|
+
rent: number;
|
|
14
|
+
subTotal: number;
|
|
15
|
+
total: number;
|
|
16
|
+
};
|
|
17
|
+
}
|
|
18
|
+
export declare const vibePrice: (obj: {
|
|
19
|
+
unit: UnitDocument;
|
|
20
|
+
stay: AvailabilityDocument[];
|
|
21
|
+
excludeCleaning?: boolean;
|
|
22
|
+
excludeUtilities?: boolean;
|
|
23
|
+
}) => VibePrice;
|
|
@@ -1,20 +1,33 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
3
|
+
exports.vibePrice = void 0;
|
|
4
4
|
const app_1 = require("../config/app");
|
|
5
|
-
const
|
|
6
|
-
|
|
7
|
-
const { unit, stay, excludeCleaning } = obj;
|
|
5
|
+
const monthly_diff_1 = require("./monthly-diff");
|
|
6
|
+
const vibePrice = (obj) => {
|
|
7
|
+
const { unit, stay, excludeCleaning, excludeUtilities } = obj;
|
|
8
8
|
const nights = stay.length;
|
|
9
9
|
const multiplier = nights >= app_1.COMMON_SERVER.priceFactor.monthly ? unit.prices.monthlyPriceFactor : 1;
|
|
10
10
|
// Apply multiplier: Guesty's approach to monthly pricing
|
|
11
11
|
const rent = +(stay.reduce((acc, stay) => acc + stay.price, 0) * multiplier).toFixed(0);
|
|
12
12
|
const cleaning = excludeCleaning ? 0 : unit.prices.cleaningFee;
|
|
13
|
-
const utilities = unit.prices.utilities * nights;
|
|
14
|
-
const
|
|
13
|
+
const utilities = excludeUtilities ? 0 : unit.prices.utilities * nights;
|
|
14
|
+
const subTotal = rent + utilities + cleaning;
|
|
15
15
|
const discount = nights >= app_1.COMMON_SERVER.priceFactor.monthly && unit.prices.monthlyPriceFactor !== 1
|
|
16
|
-
?
|
|
16
|
+
? subTotal * (1 - unit.prices.monthlyPriceFactor)
|
|
17
17
|
: 0;
|
|
18
|
-
|
|
18
|
+
const total = subTotal - discount;
|
|
19
|
+
// Get min and max dates from stay array
|
|
20
|
+
const sortedStay = [...stay].sort((a, b) => a.date.getTime() - b.date.getTime());
|
|
21
|
+
const dateFrom = sortedStay[0].date;
|
|
22
|
+
const dateTo = sortedStay[sortedStay.length - 1].date;
|
|
23
|
+
// Calculate exact months difference using dayjs
|
|
24
|
+
const monthsDiff = (0, monthly_diff_1.calculatePreciseMonthDifference)(dateFrom, dateTo);
|
|
25
|
+
const monthly = {
|
|
26
|
+
rent: Math.round(rent / monthsDiff),
|
|
27
|
+
discount: Math.round(discount / monthsDiff),
|
|
28
|
+
subTotal: Math.round(subTotal / monthsDiff),
|
|
29
|
+
total: Math.round(total / monthsDiff)
|
|
30
|
+
};
|
|
31
|
+
return { nights, rent, cleaning, utilities, subTotal, discount, total, monthly };
|
|
19
32
|
};
|
|
20
|
-
exports.
|
|
33
|
+
exports.vibePrice = vibePrice;
|