@renaissancerentals/renaissance-component 12.2.9 → 12.2.11
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/lib/data/Calendar.js +21 -0
- package/lib/data/SortField.d.ts +10 -0
- package/lib/data/SortField.js +62 -0
- package/lib/floorplan/card/FloorplanCard.js +3 -1
- package/lib/floorplan/data/Floorplan.d.ts +10 -2
- package/lib/floorplan/data/Floorplan.js +1 -1
- package/lib/floorplan/data/FloorplanFilters.d.ts +2 -11
- package/lib/floorplan/data/FloorplanFilters.js +1 -43
- package/lib/floorplan/section/FloorplansHeader.js +1 -1
- package/lib/floorplan/section/filter/Sort.d.ts +1 -1
- package/lib/floorplan/section/filter/Sort.js +5 -5
- package/lib/floorplan/service/FloorplanService.d.ts +6 -5
- package/lib/floorplan/service/FloorplanService.js +8 -20
- package/lib/index.d.ts +9 -5
- package/lib/index.js +89 -2
- package/lib/property/PropertyVideo.d.ts +5 -0
- package/lib/property/PropertyVideo.js +21 -0
- package/lib/property/data/Property.d.ts +1 -0
- package/lib/property/data/Property.js +1 -1
- package/lib/property/service/PropertyService.d.ts +3 -1
- package/lib/property/service/PropertyService.js +35 -4
- package/lib/short-term/data/ShortTermFilters.d.ts +1 -1
- package/lib/short-term/data/ShortTermFilters.js +1 -1
- package/lib/unit/card/UnitCard.d.ts +11 -0
- package/lib/unit/card/UnitCard.js +140 -0
- package/lib/unit/card/assets/360-icon.png +0 -0
- package/lib/unit/card/assets/UnitCard.scss +268 -0
- package/lib/unit/card/assets/camera-icon.png +0 -0
- package/lib/unit/card/assets/video-icon.png +0 -0
- package/lib/{floorplan → unit}/data/Unit.d.ts +18 -1
- package/lib/unit/data/Unit.js +26 -0
- package/lib/unit/data/UnitFilters.d.ts +16 -0
- package/lib/unit/data/UnitFilters.js +6 -0
- package/lib/unit/section/UnitsHeader.d.ts +14 -0
- package/lib/unit/section/UnitsHeader.js +214 -0
- package/lib/unit/section/UnitsSection.d.ts +11 -0
- package/lib/unit/section/UnitsSection.js +87 -0
- package/lib/unit/section/assets/UnitsHeader.scss +70 -0
- package/lib/unit/section/assets/UnitsSection.scss +18 -0
- package/lib/unit/service/UnitService.d.ts +12 -0
- package/lib/unit/service/UnitService.js +133 -0
- package/lib/utils/Utils.d.ts +1 -0
- package/lib/utils/Utils.js +10 -2
- package/lib/video/data/VideoAsset.d.ts +9 -0
- package/lib/video/data/VideoAsset.js +6 -0
- package/package.json +1 -1
- package/lib/floorplan/data/Calendar.js +0 -21
- package/lib/floorplan/data/Unit.js +0 -26
- /package/lib/{floorplan/data → data}/Calendar.d.ts +0 -0
|
@@ -1,2 +1,4 @@
|
|
|
1
|
-
import { PropertyDetails, PropertyId } from "../data/Property";
|
|
1
|
+
import { PropertyDetails, PropertyFilterData, PropertyId } from "../data/Property";
|
|
2
2
|
export declare const getProperty: (propertyId: PropertyId) => Promise<PropertyDetails>;
|
|
3
|
+
export declare const generatePropertyVideoUrl: (coverVideo: string) => string | null;
|
|
4
|
+
export declare const getAllPropertyFilterData: () => Promise<PropertyFilterData[]>;
|
|
@@ -3,10 +3,41 @@
|
|
|
3
3
|
Object.defineProperty(exports, "__esModule", {
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
|
-
exports.getProperty = void 0;
|
|
6
|
+
exports.getProperty = exports.getAllPropertyFilterData = exports.generatePropertyVideoUrl = void 0;
|
|
7
|
+
var _Property = require("../data/Property");
|
|
7
8
|
var _RoundRobin = require("../../service/RoundRobin");
|
|
8
|
-
const getProperty = propertyId => {
|
|
9
|
-
|
|
9
|
+
const getProperty = async propertyId => {
|
|
10
|
+
const response = await (0, _RoundRobin.get)("properties/" + propertyId + "?projection=details");
|
|
11
|
+
return response.data;
|
|
10
12
|
};
|
|
11
13
|
exports.getProperty = getProperty;
|
|
12
|
-
|
|
14
|
+
const videoIdFrom = coverVideo => {
|
|
15
|
+
const regex = /[?&]id=([^&]+)/; // Regular expression to match the id parameter
|
|
16
|
+
const match = coverVideo.match(regex); // Apply the regex on the URL
|
|
17
|
+
|
|
18
|
+
if (match) {
|
|
19
|
+
return match[1]; // Return the value of the id parameter
|
|
20
|
+
}
|
|
21
|
+
return null; // Return null if no id is found
|
|
22
|
+
};
|
|
23
|
+
const generatePropertyVideoUrl = coverVideo => {
|
|
24
|
+
const videoId = videoIdFrom(coverVideo);
|
|
25
|
+
if (!videoId) {
|
|
26
|
+
return null;
|
|
27
|
+
}
|
|
28
|
+
return "https://www.googleapis.com/drive/v3/files/".concat(videoId, "?alt=media&key=AIzaSyAdG4u5YD2CZvQTv_hRtaKrmSNWZkY30oU");
|
|
29
|
+
};
|
|
30
|
+
exports.generatePropertyVideoUrl = generatePropertyVideoUrl;
|
|
31
|
+
const getAllPropertyFilterData = async () => {
|
|
32
|
+
let response = await (0, _RoundRobin.get)("properties/filter");
|
|
33
|
+
const properties = response.data.filter(property => property.active).filter(property => property.leaseType === _Property.LeaseType.YEARLY).filter(property => !property.name.toLowerCase().includes("garage"));
|
|
34
|
+
properties.forEach(property => {
|
|
35
|
+
property.floorplans = property.floorplans.filter(floorplan => floorplan.active);
|
|
36
|
+
property.floorplans.forEach(floorplan => {
|
|
37
|
+
floorplan.units = floorplan.units.filter(unit => unit.active);
|
|
38
|
+
});
|
|
39
|
+
});
|
|
40
|
+
return properties;
|
|
41
|
+
};
|
|
42
|
+
exports.getAllPropertyFilterData = getAllPropertyFilterData;
|
|
43
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfUHJvcGVydHkiLCJyZXF1aXJlIiwiX1JvdW5kUm9iaW4iLCJnZXRQcm9wZXJ0eSIsInByb3BlcnR5SWQiLCJyZXNwb25zZSIsImdldCIsImRhdGEiLCJleHBvcnRzIiwidmlkZW9JZEZyb20iLCJjb3ZlclZpZGVvIiwicmVnZXgiLCJtYXRjaCIsImdlbmVyYXRlUHJvcGVydHlWaWRlb1VybCIsInZpZGVvSWQiLCJjb25jYXQiLCJnZXRBbGxQcm9wZXJ0eUZpbHRlckRhdGEiLCJwcm9wZXJ0aWVzIiwiZmlsdGVyIiwicHJvcGVydHkiLCJhY3RpdmUiLCJsZWFzZVR5cGUiLCJMZWFzZVR5cGUiLCJZRUFSTFkiLCJuYW1lIiwidG9Mb3dlckNhc2UiLCJpbmNsdWRlcyIsImZvckVhY2giLCJmbG9vcnBsYW5zIiwiZmxvb3JwbGFuIiwidW5pdHMiLCJ1bml0Il0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3Byb3BlcnR5L3NlcnZpY2UvUHJvcGVydHlTZXJ2aWNlLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7TGVhc2VUeXBlLCBQcm9wZXJ0eURldGFpbHMsIFByb3BlcnR5RmlsdGVyRGF0YSwgUHJvcGVydHlJZH0gZnJvbSBcIi4uL2RhdGEvUHJvcGVydHlcIjtcbmltcG9ydCB7Z2V0fSBmcm9tIFwiLi4vLi4vc2VydmljZS9Sb3VuZFJvYmluXCI7XG5cbmV4cG9ydCBjb25zdCBnZXRQcm9wZXJ0eSA9IGFzeW5jIChwcm9wZXJ0eUlkOiBQcm9wZXJ0eUlkKTogUHJvbWlzZTxQcm9wZXJ0eURldGFpbHM+ID0+IHtcblxuICAgIGNvbnN0IHJlc3BvbnNlID0gYXdhaXQgZ2V0KFwicHJvcGVydGllcy9cIiArIHByb3BlcnR5SWQgKyBcIj9wcm9qZWN0aW9uPWRldGFpbHNcIik7XG4gICAgcmV0dXJuIHJlc3BvbnNlLmRhdGE7XG5cbn07XG5cbmNvbnN0IHZpZGVvSWRGcm9tID0gKGNvdmVyVmlkZW86IHN0cmluZyk6IHN0cmluZyB8IG51bGwgPT4ge1xuICAgIGNvbnN0IHJlZ2V4ID0gL1s/Jl1pZD0oW14mXSspLzsgIC8vIFJlZ3VsYXIgZXhwcmVzc2lvbiB0byBtYXRjaCB0aGUgaWQgcGFyYW1ldGVyXG4gICAgY29uc3QgbWF0Y2ggPSBjb3ZlclZpZGVvLm1hdGNoKHJlZ2V4KTsgIC8vIEFwcGx5IHRoZSByZWdleCBvbiB0aGUgVVJMXG5cbiAgICBpZiAobWF0Y2gpIHtcbiAgICAgICAgcmV0dXJuIG1hdGNoWzFdOyAgLy8gUmV0dXJuIHRoZSB2YWx1ZSBvZiB0aGUgaWQgcGFyYW1ldGVyXG4gICAgfVxuXG4gICAgcmV0dXJuIG51bGw7ICAvLyBSZXR1cm4gbnVsbCBpZiBubyBpZCBpcyBmb3VuZFxufVxuXG5cbmV4cG9ydCBjb25zdCBnZW5lcmF0ZVByb3BlcnR5VmlkZW9VcmwgPSAoY292ZXJWaWRlbzogc3RyaW5nKTogc3RyaW5nIHwgbnVsbCA9PiB7XG5cbiAgICBjb25zdCB2aWRlb0lkID0gdmlkZW9JZEZyb20oY292ZXJWaWRlbyk7XG5cbiAgICBpZiAoIXZpZGVvSWQpIHtcbiAgICAgICAgcmV0dXJuIG51bGw7XG4gICAgfVxuXG4gICAgcmV0dXJuIGBodHRwczovL3d3dy5nb29nbGVhcGlzLmNvbS9kcml2ZS92My9maWxlcy8ke3ZpZGVvSWR9P2FsdD1tZWRpYSZrZXk9QUl6YVN5QWRHNHU1WUQyQ1p2UVR2X2hSdGFLcm1TTldaa1kzMG9VYFxuXG59O1xuZXhwb3J0IGNvbnN0IGdldEFsbFByb3BlcnR5RmlsdGVyRGF0YSA9IGFzeW5jICgpOiBQcm9taXNlPFByb3BlcnR5RmlsdGVyRGF0YVtdPiA9PiB7XG4gICAgbGV0IHJlc3BvbnNlID0gYXdhaXQgZ2V0KFwicHJvcGVydGllcy9maWx0ZXJcIik7XG5cbiAgICBjb25zdCBwcm9wZXJ0aWVzOiBQcm9wZXJ0eUZpbHRlckRhdGFbXSA9IHJlc3BvbnNlLmRhdGFcbiAgICAgICAgLmZpbHRlcigocHJvcGVydHk6IFByb3BlcnR5RmlsdGVyRGF0YSkgPT4gcHJvcGVydHkuYWN0aXZlKVxuICAgICAgICAuZmlsdGVyKChwcm9wZXJ0eTogUHJvcGVydHlGaWx0ZXJEYXRhKSA9PiBwcm9wZXJ0eS5sZWFzZVR5cGUgPT09IExlYXNlVHlwZS5ZRUFSTFkpXG4gICAgICAgIC5maWx0ZXIoKHByb3BlcnR5OiBQcm9wZXJ0eUZpbHRlckRhdGEpID0+ICFwcm9wZXJ0eS5uYW1lLnRvTG93ZXJDYXNlKCkuaW5jbHVkZXMoXCJnYXJhZ2VcIikpO1xuXG4gICAgcHJvcGVydGllcy5mb3JFYWNoKHByb3BlcnR5ID0+IHtcbiAgICAgICAgcHJvcGVydHkuZmxvb3JwbGFucyA9IHByb3BlcnR5LmZsb29ycGxhbnMuZmlsdGVyKGZsb29ycGxhbiA9PiBmbG9vcnBsYW4uYWN0aXZlKTtcbiAgICAgICAgcHJvcGVydHkuZmxvb3JwbGFucy5mb3JFYWNoKGZsb29ycGxhbiA9PiB7XG4gICAgICAgICAgICBmbG9vcnBsYW4udW5pdHMgPSBmbG9vcnBsYW4udW5pdHMuZmlsdGVyKHVuaXQgPT4gdW5pdC5hY3RpdmUpO1xuICAgICAgICB9KTtcbiAgICB9KTtcblxuICAgIHJldHVybiBwcm9wZXJ0aWVzO1xufVxuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQSxJQUFBQSxTQUFBLEdBQUFDLE9BQUE7QUFDQSxJQUFBQyxXQUFBLEdBQUFELE9BQUE7QUFFTyxNQUFNRSxXQUFXLEdBQUcsTUFBT0MsVUFBc0IsSUFBK0I7RUFFbkYsTUFBTUMsUUFBUSxHQUFHLE1BQU0sSUFBQUMsZUFBRyxFQUFDLGFBQWEsR0FBR0YsVUFBVSxHQUFHLHFCQUFxQixDQUFDO0VBQzlFLE9BQU9DLFFBQVEsQ0FBQ0UsSUFBSTtBQUV4QixDQUFDO0FBQUNDLE9BQUEsQ0FBQUwsV0FBQSxHQUFBQSxXQUFBO0FBRUYsTUFBTU0sV0FBVyxHQUFJQyxVQUFrQixJQUFvQjtFQUN2RCxNQUFNQyxLQUFLLEdBQUcsZ0JBQWdCLENBQUMsQ0FBRTtFQUNqQyxNQUFNQyxLQUFLLEdBQUdGLFVBQVUsQ0FBQ0UsS0FBSyxDQUFDRCxLQUFLLENBQUMsQ0FBQyxDQUFFOztFQUV4QyxJQUFJQyxLQUFLLEVBQUU7SUFDUCxPQUFPQSxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBRTtFQUN0QjtFQUVBLE9BQU8sSUFBSSxDQUFDLENBQUU7QUFDbEIsQ0FBQztBQUdNLE1BQU1DLHdCQUF3QixHQUFJSCxVQUFrQixJQUFvQjtFQUUzRSxNQUFNSSxPQUFPLEdBQUdMLFdBQVcsQ0FBQ0MsVUFBVSxDQUFDO0VBRXZDLElBQUksQ0FBQ0ksT0FBTyxFQUFFO0lBQ1YsT0FBTyxJQUFJO0VBQ2Y7RUFFQSxvREFBQUMsTUFBQSxDQUFvREQsT0FBTztBQUUvRCxDQUFDO0FBQUNOLE9BQUEsQ0FBQUssd0JBQUEsR0FBQUEsd0JBQUE7QUFDSyxNQUFNRyx3QkFBd0IsR0FBRyxNQUFBQSxDQUFBLEtBQTJDO0VBQy9FLElBQUlYLFFBQVEsR0FBRyxNQUFNLElBQUFDLGVBQUcsRUFBQyxtQkFBbUIsQ0FBQztFQUU3QyxNQUFNVyxVQUFnQyxHQUFHWixRQUFRLENBQUNFLElBQUksQ0FDakRXLE1BQU0sQ0FBRUMsUUFBNEIsSUFBS0EsUUFBUSxDQUFDQyxNQUFNLENBQUMsQ0FDekRGLE1BQU0sQ0FBRUMsUUFBNEIsSUFBS0EsUUFBUSxDQUFDRSxTQUFTLEtBQUtDLG1CQUFTLENBQUNDLE1BQU0sQ0FBQyxDQUNqRkwsTUFBTSxDQUFFQyxRQUE0QixJQUFLLENBQUNBLFFBQVEsQ0FBQ0ssSUFBSSxDQUFDQyxXQUFXLENBQUMsQ0FBQyxDQUFDQyxRQUFRLENBQUMsUUFBUSxDQUFDLENBQUM7RUFFOUZULFVBQVUsQ0FBQ1UsT0FBTyxDQUFDUixRQUFRLElBQUk7SUFDM0JBLFFBQVEsQ0FBQ1MsVUFBVSxHQUFHVCxRQUFRLENBQUNTLFVBQVUsQ0FBQ1YsTUFBTSxDQUFDVyxTQUFTLElBQUlBLFNBQVMsQ0FBQ1QsTUFBTSxDQUFDO0lBQy9FRCxRQUFRLENBQUNTLFVBQVUsQ0FBQ0QsT0FBTyxDQUFDRSxTQUFTLElBQUk7TUFDckNBLFNBQVMsQ0FBQ0MsS0FBSyxHQUFHRCxTQUFTLENBQUNDLEtBQUssQ0FBQ1osTUFBTSxDQUFDYSxJQUFJLElBQUlBLElBQUksQ0FBQ1gsTUFBTSxDQUFDO0lBQ2pFLENBQUMsQ0FBQztFQUNOLENBQUMsQ0FBQztFQUVGLE9BQU9ILFVBQVU7QUFDckIsQ0FBQztBQUFBVCxPQUFBLENBQUFRLHdCQUFBLEdBQUFBLHdCQUFBIn0=
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { SortField } from "../../floorplan/data/FloorplanFilters";
|
|
2
1
|
import { ShortTermStyle } from "./ShortTerm";
|
|
2
|
+
import { SortField } from "../../data/SortField";
|
|
3
3
|
export interface CurrentShortTermFilters {
|
|
4
4
|
bedroomFilters: number[];
|
|
5
5
|
styleFilters: ShortTermStyle[];
|
|
@@ -38,4 +38,4 @@ const ShortTermSortFields = exports.ShortTermSortFields = {
|
|
|
38
38
|
order: "desc"
|
|
39
39
|
}
|
|
40
40
|
};
|
|
41
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
41
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVXaWxkY2FyZCIsInJlcXVpcmUiLCJfbXVuY2hlclVpIiwiX2dldFJlcXVpcmVXaWxkY2FyZENhY2hlIiwiZSIsIldlYWtNYXAiLCJyIiwidCIsIl9fZXNNb2R1bGUiLCJkZWZhdWx0IiwiaGFzIiwiZ2V0IiwibiIsIl9fcHJvdG9fXyIsImEiLCJPYmplY3QiLCJkZWZpbmVQcm9wZXJ0eSIsImdldE93blByb3BlcnR5RGVzY3JpcHRvciIsInUiLCJwcm90b3R5cGUiLCJoYXNPd25Qcm9wZXJ0eSIsImNhbGwiLCJpIiwic2V0IiwiU2hvcnRUZXJtU29ydEZpZWxkcyIsImV4cG9ydHMiLCJwcmljZUFzYyIsImVsZW1lbnQiLCJjcmVhdGVFbGVtZW50IiwiRnJhZ21lbnQiLCJJY29uIiwibmFtZSIsInNvcnRGaWVsZCIsIm9yZGVyIiwicHJpY2VEZXNjIiwiYmVkcm9vbXNBc2MiLCJiZWRyb29tc0Rlc2MiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvc2hvcnQtdGVybS9kYXRhL1Nob3J0VGVybUZpbHRlcnMudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCwge0ZyYWdtZW50fSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCB7SWNvbn0gZnJvbSBcIkBjb250ZW50bXVuY2gvbXVuY2hlci11aVwiO1xuaW1wb3J0IHtTaG9ydFRlcm1TdHlsZX0gZnJvbSBcIi4vU2hvcnRUZXJtXCI7XG5pbXBvcnQge1NvcnRGaWVsZH0gZnJvbSBcIi4uLy4uL2RhdGEvU29ydEZpZWxkXCI7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ3VycmVudFNob3J0VGVybUZpbHRlcnMge1xuICAgIGJlZHJvb21GaWx0ZXJzOiBudW1iZXJbXTtcbiAgICBzdHlsZUZpbHRlcnM6IFNob3J0VGVybVN0eWxlW107XG4gICAgc29ydEJ5OiBTaG9ydFRlcm1Tb3J0Qnk7XG4gICAgZmxvb3JwbGFuSWRzOiBzdHJpbmdbXTtcbn1cblxuZXhwb3J0IHR5cGUgU2hvcnRUZXJtU29ydEJ5ID0ga2V5b2YgdHlwZW9mIFNob3J0VGVybVNvcnRGaWVsZHM7XG5cbmV4cG9ydCBjb25zdCBTaG9ydFRlcm1Tb3J0RmllbGRzOiB7IFtpZDogc3RyaW5nXTogU29ydEZpZWxkIH0gPSB7XG4gICAgcHJpY2VBc2M6IHtcbiAgICAgICAgZWxlbWVudDogPEZyYWdtZW50PjxJY29uIG5hbWU9XCJzb3J0LWFzY1wiLz4mbmJzcDtQcmljZTwvRnJhZ21lbnQ+LFxuICAgICAgICBzb3J0RmllbGQ6IFwic2hvcnRUZXJtLnByaWNlRm9yNVRvMTNEYXlzXCIsXG4gICAgICAgIG9yZGVyOiBcImFzY1wiXG4gICAgfSxcbiAgICBwcmljZURlc2M6IHtcbiAgICAgICAgZWxlbWVudDogPEZyYWdtZW50PjxJY29uIG5hbWU9XCJzb3J0LWRlc2NcIi8+Jm5ic3A7UHJpY2U8L0ZyYWdtZW50PixcbiAgICAgICAgc29ydEZpZWxkOiBcInNob3J0VGVybS5wcmljZUZvcjVUbzEzRGF5c1wiLFxuICAgICAgICBvcmRlcjogXCJkZXNjXCJcbiAgICB9LFxuICAgIGJlZHJvb21zQXNjOiB7XG4gICAgICAgIGVsZW1lbnQ6IDxGcmFnbWVudD48SWNvbiBuYW1lPVwic29ydC1hc2NcIi8+Jm5ic3A7QmVkcm9vbXM8L0ZyYWdtZW50PixcbiAgICAgICAgc29ydEZpZWxkOiBcImJlZHJvb21cIixcbiAgICAgICAgb3JkZXI6IFwiYXNjXCJcbiAgICB9LFxuICAgIGJlZHJvb21zRGVzYzoge1xuICAgICAgICBlbGVtZW50OiA8RnJhZ21lbnQ+PEljb24gbmFtZT1cInNvcnQtZGVzY1wiLz4mbmJzcDtCZWRyb29tczwvRnJhZ21lbnQ+LFxuICAgICAgICBzb3J0RmllbGQ6IFwiYmVkcm9vbVwiLFxuICAgICAgICBvcmRlcjogXCJkZXNjXCJcbiAgICB9LFxufVxuXG5leHBvcnQgaW50ZXJmYWNlIFNob3J0VGVybUZpbHRlcnMge1xuICAgIGJlZHJvb206IFNldDxudW1iZXI+O1xuICAgIHN0eWxl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
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import "./assets/UnitCard.scss";
|
|
3
|
+
import { Video } from "../../asset/data/Asset";
|
|
4
|
+
import { UnitCardData } from "../data/Unit";
|
|
5
|
+
export declare const UnitCard: React.FC<UnitCardProps>;
|
|
6
|
+
export interface UnitCardProps {
|
|
7
|
+
unit: UnitCardData;
|
|
8
|
+
size?: "small" | "large";
|
|
9
|
+
videoClickHandler: (video: Video) => void;
|
|
10
|
+
propertyId: string;
|
|
11
|
+
}
|
|
@@ -0,0 +1,140 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.UnitCard = void 0;
|
|
7
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
8
|
+
require("./assets/UnitCard.scss");
|
|
9
|
+
var _icon = _interopRequireDefault(require("./assets/360-icon.png"));
|
|
10
|
+
var _videoIcon = _interopRequireDefault(require("./assets/video-icon.png"));
|
|
11
|
+
var _muncherUi = require("@contentmunch/muncher-ui");
|
|
12
|
+
var _AssetService = require("../../asset/service/AssetService");
|
|
13
|
+
var _AssetApi = require("../../service/AssetApi");
|
|
14
|
+
var _Utils = require("../../utils/Utils");
|
|
15
|
+
var _SpecialOfferButton = require("../../specialOffer/SpecialOfferButton");
|
|
16
|
+
var _UnitService = require("../service/UnitService");
|
|
17
|
+
var _FloorplanPrice = require("../../floorplan/card/FloorplanPrice");
|
|
18
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
19
|
+
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
|
|
20
|
+
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
|
|
21
|
+
const UnitCard = _ref => {
|
|
22
|
+
let {
|
|
23
|
+
unit,
|
|
24
|
+
size,
|
|
25
|
+
videoClickHandler,
|
|
26
|
+
propertyId
|
|
27
|
+
} = _ref;
|
|
28
|
+
const [assets, setAssets] = (0, _react.useState)([]);
|
|
29
|
+
const [isAssetLoading, setIsAssetLoading] = (0, _react.useState)(false);
|
|
30
|
+
const [isAssetLoaded, setIsAssetLoaded] = (0, _react.useState)(false);
|
|
31
|
+
const [showSpecialOffer, setShowSpecialOffer] = (0, _react.useState)(false);
|
|
32
|
+
const loadAssets = () => {
|
|
33
|
+
if (unit.photosFolderId) {
|
|
34
|
+
(0, _AssetService.getAssetsFrom)(unit.photosFolderId).then(data => {
|
|
35
|
+
setAssets(data);
|
|
36
|
+
}).catch(() => {
|
|
37
|
+
console.log("invalid folderId");
|
|
38
|
+
}).finally(() => {
|
|
39
|
+
setIsAssetLoaded(true);
|
|
40
|
+
setIsAssetLoading(false);
|
|
41
|
+
});
|
|
42
|
+
} else {
|
|
43
|
+
setIsAssetLoaded(true);
|
|
44
|
+
setIsAssetLoading(false);
|
|
45
|
+
}
|
|
46
|
+
};
|
|
47
|
+
return /*#__PURE__*/_react.default.createElement("div", {
|
|
48
|
+
className: size === "small" ? "unit-card unit-card--small" : "unit-card"
|
|
49
|
+
}, isAssetLoaded && assets.length > 0 ? /*#__PURE__*/_react.default.createElement(_muncherUi.ItemSlider, {
|
|
50
|
+
navButtonSize: "medium",
|
|
51
|
+
sliderItems: assets.map(asset => /*#__PURE__*/_react.default.createElement("img", {
|
|
52
|
+
className: "card--image",
|
|
53
|
+
alt: "card",
|
|
54
|
+
src: (0, _AssetService.assetUrlFrom)(asset.id, propertyId)
|
|
55
|
+
}))
|
|
56
|
+
}) : /*#__PURE__*/_react.default.createElement("img", {
|
|
57
|
+
className: "card--image",
|
|
58
|
+
alt: "cover",
|
|
59
|
+
src: unit.coverImage ? (0, _AssetService.getAssetUrl)(unit.coverImage, propertyId) : _AssetApi.DEFAULT_IMAGE_URL
|
|
60
|
+
}), isAssetLoaded ? "" : /*#__PURE__*/_react.default.createElement(_muncherUi.NavigateButton, {
|
|
61
|
+
direction: "right",
|
|
62
|
+
onClick: loadAssets,
|
|
63
|
+
size: "medium"
|
|
64
|
+
}), isAssetLoading ? /*#__PURE__*/_react.default.createElement(_muncherUi.Spinner, {
|
|
65
|
+
size: "medium"
|
|
66
|
+
}) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null), /*#__PURE__*/_react.default.createElement("div", {
|
|
67
|
+
className: "badges--right"
|
|
68
|
+
}, unit.featured ? (0, _UnitService.isUnitAvailable)(unit) ? /*#__PURE__*/_react.default.createElement(_muncherUi.Badge, null, "Featured & Available Now") : /*#__PURE__*/_react.default.createElement(_muncherUi.Badge, null, "Featured") : (0, _UnitService.isUnitAvailable)(unit) ? /*#__PURE__*/_react.default.createElement(_muncherUi.Badge, null, "Available Now") : '', unit.webSpecials.length > 0 ? /*#__PURE__*/_react.default.createElement(_SpecialOfferButton.SpecialOfferButton, {
|
|
69
|
+
onMouseEnter: () => setShowSpecialOffer(true),
|
|
70
|
+
onMouseLeave: () => setShowSpecialOffer(false)
|
|
71
|
+
}) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null)), /*#__PURE__*/_react.default.createElement("div", {
|
|
72
|
+
className: "badges--left"
|
|
73
|
+
}, unit.virtualTourLink ? /*#__PURE__*/_react.default.createElement("div", {
|
|
74
|
+
className: "icon-tour"
|
|
75
|
+
}, /*#__PURE__*/_react.default.createElement(_muncherUi.Button, {
|
|
76
|
+
variant: "transparent",
|
|
77
|
+
size: "small",
|
|
78
|
+
title: "tour icon",
|
|
79
|
+
onClick: () => videoClickHandler({
|
|
80
|
+
url: unit.virtualTourLink,
|
|
81
|
+
type: "virtual"
|
|
82
|
+
})
|
|
83
|
+
}, /*#__PURE__*/_react.default.createElement("img", {
|
|
84
|
+
src: _icon.default,
|
|
85
|
+
alt: "tour icon",
|
|
86
|
+
height: 30
|
|
87
|
+
}))) : '', unit.videoTourLink ? /*#__PURE__*/_react.default.createElement("div", {
|
|
88
|
+
className: "icon-video"
|
|
89
|
+
}, /*#__PURE__*/_react.default.createElement(_muncherUi.Button, {
|
|
90
|
+
variant: "transparent",
|
|
91
|
+
size: "small",
|
|
92
|
+
title: "video icon",
|
|
93
|
+
onClick: () => videoClickHandler({
|
|
94
|
+
url: unit.videoTourLink,
|
|
95
|
+
type: "video"
|
|
96
|
+
})
|
|
97
|
+
}, /*#__PURE__*/_react.default.createElement("img", {
|
|
98
|
+
src: _videoIcon.default,
|
|
99
|
+
alt: "video icon",
|
|
100
|
+
height: 20
|
|
101
|
+
}))) : '', unit.address && unit.zipcode ? /*#__PURE__*/_react.default.createElement("div", {
|
|
102
|
+
className: "icon-map"
|
|
103
|
+
}, /*#__PURE__*/_react.default.createElement("a", {
|
|
104
|
+
target: "_blank",
|
|
105
|
+
rel: "noreferrer",
|
|
106
|
+
title: "address:" + (0, _Utils.renaissanceAddress)(unit.address, unit.zipcode),
|
|
107
|
+
href: (0, _Utils.addressToGoogleMapLink)(unit.address, unit.zipcode)
|
|
108
|
+
}, /*#__PURE__*/_react.default.createElement(_muncherUi.Icon, {
|
|
109
|
+
name: "map",
|
|
110
|
+
size: "small"
|
|
111
|
+
}))) : ''), /*#__PURE__*/_react.default.createElement("a", {
|
|
112
|
+
href: "/floorplans/" + unit.id,
|
|
113
|
+
title: unit.floorplanName + unit.id
|
|
114
|
+
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
115
|
+
className: "unit-card-content"
|
|
116
|
+
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
117
|
+
className: "unit-card-content--special"
|
|
118
|
+
}, showSpecialOffer && unit.webSpecials.length > 0 ? /*#__PURE__*/_react.default.createElement("div", {
|
|
119
|
+
className: "content--special"
|
|
120
|
+
}, /*#__PURE__*/_react.default.createElement("p", null, unit.webSpecials[0])) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null)), /*#__PURE__*/_react.default.createElement("div", {
|
|
121
|
+
className: "unit-card-footer"
|
|
122
|
+
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
123
|
+
className: "left"
|
|
124
|
+
}, /*#__PURE__*/_react.default.createElement("h3", null, /*#__PURE__*/_react.default.createElement("span", {
|
|
125
|
+
className: "truncate"
|
|
126
|
+
}, unit.floorplanName), " (", unit.id, ")"), /*#__PURE__*/_react.default.createElement("p", null, /*#__PURE__*/_react.default.createElement(_muncherUi.Icon, {
|
|
127
|
+
name: "calendar"
|
|
128
|
+
}, (0, _Utils.availabilityDate)(unit.moveInDate))), /*#__PURE__*/_react.default.createElement("p", null, /*#__PURE__*/_react.default.createElement(_FloorplanPrice.FloorplanPrice, {
|
|
129
|
+
unitRents: [{
|
|
130
|
+
rent: unit.rent
|
|
131
|
+
}],
|
|
132
|
+
specialRent: unit.specialRent,
|
|
133
|
+
specialRentEndDate: unit.specialRentEndDate,
|
|
134
|
+
specialRentStartDate: unit.specialRentStartDate
|
|
135
|
+
}))), /*#__PURE__*/_react.default.createElement("div", {
|
|
136
|
+
className: "right"
|
|
137
|
+
}, /*#__PURE__*/_react.default.createElement("p", null, unit.bedroom, " bed, ", unit.bathroom, " bath"), /*#__PURE__*/_react.default.createElement("p", null, unit.squareFoot, " sq."))))));
|
|
138
|
+
};
|
|
139
|
+
exports.UnitCard = UnitCard;
|
|
140
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_icon","_interopRequireDefault","_videoIcon","_muncherUi","_AssetService","_AssetApi","_Utils","_SpecialOfferButton","_UnitService","_FloorplanPrice","obj","__esModule","default","_getRequireWildcardCache","e","WeakMap","r","t","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","prototype","hasOwnProperty","call","i","set","UnitCard","_ref","unit","size","videoClickHandler","propertyId","assets","setAssets","useState","isAssetLoading","setIsAssetLoading","isAssetLoaded","setIsAssetLoaded","showSpecialOffer","setShowSpecialOffer","loadAssets","photosFolderId","getAssetsFrom","then","data","catch","console","log","finally","createElement","className","length","ItemSlider","navButtonSize","sliderItems","map","asset","alt","src","assetUrlFrom","id","coverImage","getAssetUrl","DEFAULT_IMAGE_URL","NavigateButton","direction","onClick","Spinner","Fragment","featured","isUnitAvailable","Badge","webSpecials","SpecialOfferButton","onMouseEnter","onMouseLeave","virtualTourLink","Button","variant","title","url","type","tourIcon","height","videoTourLink","videoIcon","address","zipcode","target","rel","renaissanceAddress","href","addressToGoogleMapLink","Icon","name","floorplanName","availabilityDate","moveInDate","FloorplanPrice","unitRents","rent","specialRent","specialRentEndDate","specialRentStartDate","bedroom","bathroom","squareFoot","exports"],"sources":["../../../src/unit/card/UnitCard.tsx"],"sourcesContent":["import React, {useState} from \"react\";\nimport \"./assets/UnitCard.scss\";\nimport tourIcon from \"./assets/360-icon.png\";\nimport videoIcon from \"./assets/video-icon.png\";\nimport {Badge, Button, Icon, ItemSlider, NavigateButton, Spinner} from \"@contentmunch/muncher-ui\";\nimport {assetUrlFrom, getAssetsFrom, getAssetUrl} from \"../../asset/service/AssetService\";\nimport {DEFAULT_IMAGE_URL} from \"../../service/AssetApi\";\nimport {addressToGoogleMapLink, availabilityDate, renaissanceAddress} from \"../../utils/Utils\";\nimport {Asset, Video} from \"../../asset/data/Asset\";\nimport {SpecialOfferButton} from \"../../specialOffer/SpecialOfferButton\";\nimport {UnitCardData} from \"../data/Unit\";\nimport {isUnitAvailable} from \"../service/UnitService\";\nimport {FloorplanPrice} from \"../../floorplan/card/FloorplanPrice\";\n\nexport const UnitCard: React.FC<UnitCardProps> = (\n    {\n        unit,\n        size,\n        videoClickHandler,\n        propertyId\n    }) => {\n    const [assets, setAssets] = useState<Asset[]>([]);\n    const [isAssetLoading, setIsAssetLoading] = useState(false);\n    const [isAssetLoaded, setIsAssetLoaded] = useState(false);\n    const [showSpecialOffer, setShowSpecialOffer] = useState(false);\n\n    const loadAssets = () => {\n\n        if (unit.photosFolderId) {\n            getAssetsFrom(unit.photosFolderId).then(data => {\n                setAssets(data);\n            }).catch(() => {\n                console.log(\"invalid folderId\");\n            }).finally(() => {\n                setIsAssetLoaded(true);\n                setIsAssetLoading(false);\n            });\n        } else {\n            setIsAssetLoaded(true);\n            setIsAssetLoading(false);\n        }\n    };\n\n\n    return (\n        <div className={size === \"small\" ? \"unit-card unit-card--small\" : \"unit-card\"}>\n\n            {isAssetLoaded && assets.length > 0 ?\n                <ItemSlider navButtonSize=\"medium\"\n                            sliderItems={assets.map(asset => <img\n                                className=\"card--image\"\n                                alt=\"card\"\n                                src={assetUrlFrom(asset.id, propertyId)}/>)}/> :\n                <img className=\"card--image\" alt=\"cover\"\n                     src={unit.coverImage ? getAssetUrl(unit.coverImage, propertyId) : DEFAULT_IMAGE_URL}/>}\n            {isAssetLoaded ? \"\" : <NavigateButton direction=\"right\" onClick={loadAssets} size=\"medium\"/>}\n\n            {isAssetLoading ? <Spinner size=\"medium\"/> : <></>}\n            <div className=\"badges--right\">\n                {\n                    unit.featured ? (isUnitAvailable(unit) ? <Badge>Featured & Available Now</Badge> :\n                        <Badge>Featured</Badge>) : isUnitAvailable(unit) ? <Badge>Available Now</Badge> : ''\n                }\n                {\n                    unit.webSpecials.length > 0 ?\n                        <SpecialOfferButton onMouseEnter={() => setShowSpecialOffer(true)}\n                                            onMouseLeave={() => setShowSpecialOffer(false)}/> : <></>\n                }\n            </div>\n            <div className=\"badges--left\">\n                {unit.virtualTourLink ?\n                    <div className=\"icon-tour\">\n                        <Button variant=\"transparent\" size=\"small\" title=\"tour icon\"\n                                onClick={() => videoClickHandler({\n                                    url: unit.virtualTourLink,\n                                    type: \"virtual\"\n                                })}>\n                            <img src={tourIcon} alt=\"tour icon\" height={30}/>\n                        </Button>\n\n                    </div>\n                    : ''}\n                {unit.videoTourLink ?\n                    <div className=\"icon-video\">\n                        <Button variant=\"transparent\" size=\"small\" title=\"video icon\"\n                                onClick={() => videoClickHandler({url: unit.videoTourLink, type: \"video\"})}>\n                            <img src={videoIcon} alt=\"video icon\" height={20}/>\n                        </Button>\n                    </div>\n                    : ''}\n                {unit.address && unit.zipcode ?\n                    <div className=\"icon-map\">\n\n                        <a target=\"_blank\" rel=\"noreferrer\"\n                           title={\"address:\" + renaissanceAddress(unit.address, unit.zipcode)}\n                           href={addressToGoogleMapLink(unit.address, unit.zipcode)}>\n                            <Icon name=\"map\"\n                                  size=\"small\"/></a>\n                    </div>\n                    : ''}\n            </div>\n            <a href={\"/floorplans/\" + unit.id}\n               title={unit.floorplanName + unit.id}>\n                <div className=\"unit-card-content\">\n                    <div className=\"unit-card-content--special\">\n                        {showSpecialOffer && unit.webSpecials.length > 0 ?\n                            <div className=\"content--special\">\n                                <p>{unit.webSpecials[0]}</p>\n                            </div> : <></>}\n                    </div>\n\n                    <div className=\"unit-card-footer\">\n                        <div className=\"left\">\n                            <h3>\n                                <span className=\"truncate\">{unit.floorplanName}</span> ({unit.id})\n\n                            </h3>\n                            <p>\n                                <Icon name=\"calendar\">{availabilityDate(unit.moveInDate)}</Icon>\n                            </p>\n\n                            <p>\n                                <FloorplanPrice unitRents={[{rent: unit.rent}]} specialRent={unit.specialRent}\n                                                specialRentEndDate={unit.specialRentEndDate}\n                                                specialRentStartDate={unit.specialRentStartDate}/>\n                            </p>\n\n                        </div>\n                        <div className=\"right\">\n                            <p>{unit.bedroom} bed, {unit.bathroom} bath</p>\n                            <p>{unit.squareFoot} sq.</p>\n                        </div>\n                    </div>\n\n                </div>\n\n            </a>\n        </div>\n    );\n}\n\nexport interface UnitCardProps {\n    unit: UnitCardData;\n    size?: \"small\" | \"large\"\n    videoClickHandler: (video: Video) => void;\n    propertyId: string;\n}\n\n"],"mappings":"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"}
|
|
Binary file
|
|
@@ -0,0 +1,268 @@
|
|
|
1
|
+
@import "src/assets/variables";
|
|
2
|
+
|
|
3
|
+
$unit-card-color: $primary-background-color !default;
|
|
4
|
+
$unit-card-secondary-color: $secondary-color !default;
|
|
5
|
+
.unit-card {
|
|
6
|
+
color: $unit-card-color;
|
|
7
|
+
|
|
8
|
+
a {
|
|
9
|
+
color: $unit-card-color;
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
a:hover {
|
|
13
|
+
color: inherit;
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
position: relative;
|
|
17
|
+
height: 16rem;
|
|
18
|
+
width: 100vw;
|
|
19
|
+
display: flex;
|
|
20
|
+
justify-content: center;
|
|
21
|
+
align-items: center;
|
|
22
|
+
|
|
23
|
+
|
|
24
|
+
.muncher-spinner {
|
|
25
|
+
position: absolute;
|
|
26
|
+
top: 40%;
|
|
27
|
+
left: 50%;
|
|
28
|
+
transform: translate(-50%, -50%);
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
.muncher-button--navigate {
|
|
32
|
+
position: absolute;
|
|
33
|
+
top: 40%;
|
|
34
|
+
right: 0;
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
//@media(min-width: $medium-size) {
|
|
38
|
+
// width: 20rem;
|
|
39
|
+
// height: 14rem;
|
|
40
|
+
//}
|
|
41
|
+
.card--image {
|
|
42
|
+
width: 100vw;
|
|
43
|
+
height: 16rem;
|
|
44
|
+
object-fit: cover;
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
@media(min-width: $large-size) {
|
|
48
|
+
width: 25rem;
|
|
49
|
+
height: 16rem;
|
|
50
|
+
.card--image {
|
|
51
|
+
width: 25rem;
|
|
52
|
+
height: 16rem;
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
@media(min-width: $extra-large-size) {
|
|
56
|
+
width: 33rem;
|
|
57
|
+
height: 18rem;
|
|
58
|
+
.card--image {
|
|
59
|
+
width: 33rem;
|
|
60
|
+
height: 18rem;
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
background-repeat: no-repeat;
|
|
65
|
+
background-position: center;
|
|
66
|
+
background-size: cover;
|
|
67
|
+
|
|
68
|
+
.badges--right {
|
|
69
|
+
position: absolute;
|
|
70
|
+
right: .5rem;
|
|
71
|
+
top: .5rem;
|
|
72
|
+
display: flex;
|
|
73
|
+
flex-direction: column;
|
|
74
|
+
align-items: flex-end;
|
|
75
|
+
|
|
76
|
+
.special-offer-button {
|
|
77
|
+
margin: .5rem 0;
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
.badges--left {
|
|
82
|
+
position: absolute;
|
|
83
|
+
top: 1rem;
|
|
84
|
+
left: 1rem;
|
|
85
|
+
display: flex;
|
|
86
|
+
flex-direction: column;
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
.muncher-badge {
|
|
90
|
+
font-size: .8rem;
|
|
91
|
+
}
|
|
92
|
+
.icon-tour {
|
|
93
|
+
position: absolute;
|
|
94
|
+
top: 1rem;
|
|
95
|
+
left: 1rem;
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
.icon-video {
|
|
99
|
+
position: absolute;
|
|
100
|
+
top: 3.5rem;
|
|
101
|
+
left: 1.1rem;
|
|
102
|
+
}
|
|
103
|
+
.icon-map {
|
|
104
|
+
position: absolute;
|
|
105
|
+
top: 5.7rem;
|
|
106
|
+
left: 1.5rem;
|
|
107
|
+
.muncher-icon--small{
|
|
108
|
+
width: 1.4rem;
|
|
109
|
+
height: 1.4rem;
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
.icon-left, .icon-right {
|
|
114
|
+
position: absolute;
|
|
115
|
+
top: 40%;
|
|
116
|
+
cursor: pointer;
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
.icon-left:hover, .icon-right:hover {
|
|
120
|
+
opacity: .6;
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
.icon-left {
|
|
124
|
+
left: .1rem;
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
.icon-right {
|
|
128
|
+
right: .1rem;
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
.unit-card-content {
|
|
132
|
+
position: absolute;
|
|
133
|
+
bottom: 0;
|
|
134
|
+
left: 0;
|
|
135
|
+
width: 100%;
|
|
136
|
+
}
|
|
137
|
+
|
|
138
|
+
.unit-card-content--special {
|
|
139
|
+
display: flex;
|
|
140
|
+
justify-content: flex-end;
|
|
141
|
+
}
|
|
142
|
+
|
|
143
|
+
.content--special {
|
|
144
|
+
text-align: center;
|
|
145
|
+
width: 45%;
|
|
146
|
+
background-color: $special-offer-color;
|
|
147
|
+
padding: 0 1rem;
|
|
148
|
+
}
|
|
149
|
+
|
|
150
|
+
.unit-card-footer {
|
|
151
|
+
background-color: rgba(0, 0, 0, .4);
|
|
152
|
+
width: 100%;
|
|
153
|
+
display: flex;
|
|
154
|
+
align-items: center;
|
|
155
|
+
justify-content: space-between;
|
|
156
|
+
.rent {
|
|
157
|
+
font-size: .8rem;
|
|
158
|
+
}
|
|
159
|
+
|
|
160
|
+
h3, p {
|
|
161
|
+
text-align: left;
|
|
162
|
+
margin: .5rem 0;
|
|
163
|
+
}
|
|
164
|
+
|
|
165
|
+
h3 {
|
|
166
|
+
font-size: .9rem;
|
|
167
|
+
}
|
|
168
|
+
p{
|
|
169
|
+
font-size: .8rem;
|
|
170
|
+
}
|
|
171
|
+
.truncate {
|
|
172
|
+
text-overflow: ellipsis;
|
|
173
|
+
//@media(min-width: $medium-size) {
|
|
174
|
+
// width: 10rem;
|
|
175
|
+
//}
|
|
176
|
+
@media(min-width: $large-size) {
|
|
177
|
+
width: 15rem;
|
|
178
|
+
}
|
|
179
|
+
@media(min-width: $extra-large-size) {
|
|
180
|
+
width: 22rem;
|
|
181
|
+
}
|
|
182
|
+
width: 55vw;
|
|
183
|
+
white-space: nowrap;
|
|
184
|
+
overflow: hidden;
|
|
185
|
+
}
|
|
186
|
+
|
|
187
|
+
.left, .right {
|
|
188
|
+
padding: 0 .5rem;
|
|
189
|
+
}
|
|
190
|
+
|
|
191
|
+
.address-link {
|
|
192
|
+
font-size: .7rem;
|
|
193
|
+
|
|
194
|
+
.muncher-icon--small {
|
|
195
|
+
width: .7rem;
|
|
196
|
+
height: .7rem;
|
|
197
|
+
}
|
|
198
|
+
|
|
199
|
+
margin: 0;
|
|
200
|
+
}
|
|
201
|
+
}
|
|
202
|
+
}
|
|
203
|
+
|
|
204
|
+
.unit-card--small {
|
|
205
|
+
//@media(min-width: $medium-size) {
|
|
206
|
+
// width: 15rem;
|
|
207
|
+
// height: 14rem;
|
|
208
|
+
//}
|
|
209
|
+
@media(min-width: $large-size) {
|
|
210
|
+
width: 20rem;
|
|
211
|
+
height: 16rem;
|
|
212
|
+
.card--image {
|
|
213
|
+
width: 20rem;
|
|
214
|
+
height: 16rem;
|
|
215
|
+
}
|
|
216
|
+
}
|
|
217
|
+
@media(min-width: $extra-large-size) {
|
|
218
|
+
width: 28rem;
|
|
219
|
+
height: 18rem;
|
|
220
|
+
.card--image {
|
|
221
|
+
width: 28rem;
|
|
222
|
+
height: 18rem;
|
|
223
|
+
}
|
|
224
|
+
}
|
|
225
|
+
|
|
226
|
+
.unit-card-footer {
|
|
227
|
+
.left {
|
|
228
|
+
//@media(min-width: $medium-size) {
|
|
229
|
+
// max-width: 8rem;
|
|
230
|
+
//}
|
|
231
|
+
@media(min-width: $large-size) {
|
|
232
|
+
max-width: 12rem;
|
|
233
|
+
}
|
|
234
|
+
@media(min-width: $extra-large-size) {
|
|
235
|
+
max-width: 16rem;
|
|
236
|
+
}
|
|
237
|
+
|
|
238
|
+
}
|
|
239
|
+
}
|
|
240
|
+
}
|
|
241
|
+
|
|
242
|
+
.unit-card--slider {
|
|
243
|
+
|
|
244
|
+
width: 100vw;
|
|
245
|
+
|
|
246
|
+
@media(min-width: $large-size) {
|
|
247
|
+
width: 25rem;
|
|
248
|
+
|
|
249
|
+
}
|
|
250
|
+
@media(min-width: $extra-large-size) {
|
|
251
|
+
width: 33rem;
|
|
252
|
+
|
|
253
|
+
}
|
|
254
|
+
|
|
255
|
+
.muncher-item-slider .muncher-button--navigate {
|
|
256
|
+
top: 38%;
|
|
257
|
+
}
|
|
258
|
+
}
|
|
259
|
+
|
|
260
|
+
.unit-card-slider--small {
|
|
261
|
+
|
|
262
|
+
@media(min-width: $large-size) {
|
|
263
|
+
width: 20rem;
|
|
264
|
+
}
|
|
265
|
+
@media(min-width: $extra-large-size) {
|
|
266
|
+
width: 28rem;
|
|
267
|
+
}
|
|
268
|
+
}
|
|
Binary file
|
|
Binary file
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { FloorplanStyle } from "../../floorplan/data/Floorplan";
|
|
1
2
|
export declare enum Pet {
|
|
2
3
|
NO_PET = "NO_PET",
|
|
3
4
|
CAT = "CAT",
|
|
@@ -46,11 +47,27 @@ export interface Unit {
|
|
|
46
47
|
active: boolean;
|
|
47
48
|
}
|
|
48
49
|
export interface UnitCardData {
|
|
50
|
+
id: string;
|
|
49
51
|
rent: number;
|
|
50
52
|
squareFoot: number;
|
|
51
|
-
active: boolean;
|
|
52
53
|
moveInDate: string;
|
|
53
54
|
availabilityExtensionMonths: number | null;
|
|
55
|
+
floorplanId: string;
|
|
56
|
+
floorplanName: string;
|
|
57
|
+
bedroom: number;
|
|
58
|
+
bathroom: number;
|
|
59
|
+
coverImage: string;
|
|
60
|
+
featured: boolean;
|
|
61
|
+
style: FloorplanStyle;
|
|
62
|
+
specialRent: number;
|
|
63
|
+
specialRentStartDate: string;
|
|
64
|
+
specialRentEndDate: string;
|
|
65
|
+
address: string;
|
|
66
|
+
zipcode: string;
|
|
67
|
+
virtualTourLink: string;
|
|
68
|
+
videoTourLink: string;
|
|
69
|
+
photosFolderId: string;
|
|
70
|
+
webSpecials: string[];
|
|
54
71
|
}
|
|
55
72
|
export declare enum Level {
|
|
56
73
|
GROUND = "GROUND",
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.UnitTurnoverRate = exports.Pet = exports.Level = void 0;
|
|
7
|
+
let Pet = exports.Pet = /*#__PURE__*/function (Pet) {
|
|
8
|
+
Pet["NO_PET"] = "NO_PET";
|
|
9
|
+
Pet["CAT"] = "CAT";
|
|
10
|
+
Pet["SMALL_DOG_CAT"] = "SMALL_DOG_CAT";
|
|
11
|
+
Pet["LARGE_DOG_SMALL_DOG_CAT"] = "LARGE_DOG_SMALL_DOG_CAT";
|
|
12
|
+
return Pet;
|
|
13
|
+
}({});
|
|
14
|
+
let Level = exports.Level = /*#__PURE__*/function (Level) {
|
|
15
|
+
Level["GROUND"] = "GROUND";
|
|
16
|
+
Level["MIDDLE"] = "MIDDLE";
|
|
17
|
+
Level["TOP"] = "TOP";
|
|
18
|
+
Level["MULTI"] = "MULTI";
|
|
19
|
+
return Level;
|
|
20
|
+
}({});
|
|
21
|
+
let UnitTurnoverRate = exports.UnitTurnoverRate = /*#__PURE__*/function (UnitTurnoverRate) {
|
|
22
|
+
UnitTurnoverRate["FOUR_DAYS"] = "FOUR_DAYS";
|
|
23
|
+
UnitTurnoverRate["FIVE_DAYS"] = "FIVE_DAYS";
|
|
24
|
+
return UnitTurnoverRate;
|
|
25
|
+
}({});
|
|
26
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJQZXQiLCJleHBvcnRzIiwiTGV2ZWwiLCJVbml0VHVybm92ZXJSYXRlIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3VuaXQvZGF0YS9Vbml0LnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Rmxvb3JwbGFuU3R5bGV9IGZyb20gXCIuLi8uLi9mbG9vcnBsYW4vZGF0YS9GbG9vcnBsYW5cIjtcblxuZXhwb3J0IGVudW0gUGV0IHtcbiAgICBOT19QRVQgPSBcIk5PX1BFVFwiLCBDQVQgPSBcIkNBVFwiLCBTTUFMTF9ET0dfQ0FUID0gXCJTTUFMTF9ET0dfQ0FUXCIsIExBUkdFX0RPR19TTUFMTF9ET0dfQ0FUID0gXCJMQVJHRV9ET0dfU01BTExfRE9HX0NBVFwiXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVW5pdERldGFpbHMge1xuICAgIGlkOiBzdHJpbmc7XG4gICAgc3F1YXJlRm9vdDogbnVtYmVyO1xuICAgIGFsbG93ZWRQZXQ6IFBldDtcbiAgICByZW50OiBudW1iZXI7XG4gICAgZGlzY291bnRlZFJlbnQ6IG51bWJlciB8IG51bGw7XG4gICAgZGVwb3NpdDogbnVtYmVyO1xuICAgIGdhcmFnZXM6IG51bWJlcjtcbiAgICBtb3ZlSW5EYXRlOiBzdHJpbmcgfCBudWxsO1xuICAgIGF2YWlsYWJpbGl0eUV4dGVuc2lvbk1vbnRoczogbnVtYmVyIHwgbnVsbDtcbiAgICBmdXJuaXNoZWQ6IGJvb2xlYW47XG4gICAgYWN0aXZlOiBib29sZWFuO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFVuaXQge1xuICAgIGlkOiBzdHJpbmc7XG4gICAgc3F1YXJlRm9vdDogbnVtYmVyO1xuICAgIGFsbG93ZWRQZXQ6IFBldDtcbiAgICBwZXRQb2xpY3k6IHN0cmluZztcbiAgICByZW50OiBudW1iZXI7XG4gICAgZGlzY291bnRlZFJlbnQ6IG51bWJlcjtcbiAgICBkZXBvc2l0OiBudW1iZXI7XG4gICAgZW5kVW5pdDogYm9vbGVhbjtcbiAgICBmdXJuaXNoZWQ6IGJvb2xlYW47XG4gICAgbXVycGh5QmVkUHJvdmlkZWQ6IGJvb2xlYW47XG4gICAgYWZmb3JkYWJsZUhvdXNpbmc6IGJvb2xlYW47XG4gICAgbGV2ZWw6IExldmVsO1xuICAgIGdhcmFnZXM6IG51bWJlcjtcbiAgICB0dXJub3ZlclJhdGU6IFVuaXRUdXJub3ZlclJhdGU7XG4gICAgYWRkcmVzczogc3RyaW5nO1xuICAgIHppcGNvZGU6IHN0cmluZztcbiAgICBiaWxsaW5nTGluazogc3RyaW5nO1xuICAgIG1vdmVJbkRhdGU6IHN0cmluZztcbiAgICBhdmFpbGFiaWxpdHlFeHRlbnNpb25Nb250aHM6IG51bWJlciB8IG51bGw7XG4gICAgcGhvdG9zTGluazogc3RyaW5nO1xuICAgIHZpZGVvVG91ckxpbms6IHN0cmluZztcbiAgICB0aHJlZVNpeHR5VmlkZW9Ub3VyTGluazogc3RyaW5nO1xuICAgIHZpcnR1YWxUb3VyTGluazogc3RyaW5nO1xuICAgIGxhc3RNb2RpZmllZEJ5OiBzdHJpbmc7XG4gICAgbGFzdE1vZGlmaWVkRGF0ZTogc3RyaW5nO1xuICAgIGFjdGl2ZTogYm9vbGVhbjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBVbml0Q2FyZERhdGEge1xuICAgIGlkOiBzdHJpbmc7XG4gICAgcmVudDogbnVtYmVyO1xuICAgIHNxdWFyZUZvb3Q6IG51bWJlcjtcbiAgICBtb3ZlSW5EYXRlOiBzdHJpbmc7XG4gICAgYXZhaWxhYmlsaXR5RXh0ZW5zaW9uTW9udGhzOiBudW1iZXIgfCBudWxsO1xuICAgIGZsb29ycGxhbklkOiBzdHJpbmc7XG4gICAgZmxvb3JwbGFuTmFtZTogc3RyaW5nO1xuICAgIGJlZHJvb206IG51bWJlcjtcbiAgICBiYXRocm9vbTogbnVtYmVyO1xuICAgIGNvdmVySW1hZ2U6IHN0cmluZztcbiAgICBmZWF0dXJlZDogYm9vbGVhbjtcbiAgICBzdHlsZTogRmxvb3JwbGFuU3R5bGU7XG4gICAgc3BlY2lhbFJlbnQ6IG51bWJlcixcbiAgICBzcGVjaWFsUmVudFN0YXJ0RGF0ZTogc3RyaW5nO1xuICAgIHNwZWNpYWxSZW50RW5kRGF0ZTogc3RyaW5nO1xuICAgIGFkZHJlc3M6IHN0cmluZztcbiAgICB6aXBjb2RlOiBzdHJpbmc7XG4gICAgdmlydHVhbFRvdXJMaW5rOiBzdHJpbmc7XG4gICAgdmlkZW9Ub3VyTGluazogc3RyaW5nO1xuICAgIHBob3Rvc0ZvbGRlcklkOiBzdHJpbmc7XG4gICAgd2ViU3BlY2lhbHM6IHN0cmluZyBbXTtcbn1cblxuXG5leHBvcnQgZW51bSBMZXZlbCB7XG4gICAgR1JPVU5EID0gXCJHUk9VTkRcIiwgTUlERExFID0gXCJNSURETEVcIiwgVE9QID0gXCJUT1BcIiwgTVVMVEkgPSBcIk1VTFRJXCJcbn1cblxuZXhwb3J0IGVudW0gVW5pdFR1cm5vdmVyUmF0ZSB7XG4gICAgRk9VUl9EQVlTID0gXCJGT1VSX0RBWVNcIiwgRklWRV9EQVlTID0gXCJGSVZFX0RBWVNcIlxufVxuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7SUFFWUEsR0FBRyxHQUFBQyxPQUFBLENBQUFELEdBQUEsMEJBQUhBLEdBQUc7RUFBSEEsR0FBRztFQUFIQSxHQUFHO0VBQUhBLEdBQUc7RUFBSEEsR0FBRztFQUFBLE9BQUhBLEdBQUc7QUFBQTtBQUFBLElBd0VIRSxLQUFLLEdBQUFELE9BQUEsQ0FBQUMsS0FBQSwwQkFBTEEsS0FBSztFQUFMQSxLQUFLO0VBQUxBLEtBQUs7RUFBTEEsS0FBSztFQUFMQSxLQUFLO0VBQUEsT0FBTEEsS0FBSztBQUFBO0FBQUEsSUFJTEMsZ0JBQWdCLEdBQUFGLE9BQUEsQ0FBQUUsZ0JBQUEsMEJBQWhCQSxnQkFBZ0I7RUFBaEJBLGdCQUFnQjtFQUFoQkEsZ0JBQWdCO0VBQUEsT0FBaEJBLGdCQUFnQjtBQUFBIn0=
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { SortBy } from "../../data/SortField";
|
|
2
|
+
import { FloorplanStyle } from "../../floorplan/data/Floorplan";
|
|
3
|
+
export interface CurrentFilters {
|
|
4
|
+
bedroomFilters: number[];
|
|
5
|
+
availabilityFilters: string[];
|
|
6
|
+
styleFilters: FloorplanStyle[];
|
|
7
|
+
minRent: number;
|
|
8
|
+
maxRent: number;
|
|
9
|
+
sortBy: SortBy;
|
|
10
|
+
floorplanIds: string[];
|
|
11
|
+
}
|
|
12
|
+
export interface UnitFilters {
|
|
13
|
+
bedroom: Set<number>;
|
|
14
|
+
availability: Set<string>;
|
|
15
|
+
style: Set<FloorplanStyle>;
|
|
16
|
+
}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3VuaXQvZGF0YS9Vbml0RmlsdGVycy50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtTb3J0Qnl9IGZyb20gXCIuLi8uLi9kYXRhL1NvcnRGaWVsZFwiO1xuaW1wb3J0IHtGbG9vcnBsYW5TdHlsZX0gZnJvbSBcIi4uLy4uL2Zsb29ycGxhbi9kYXRhL0Zsb29ycGxhblwiO1xuXG5leHBvcnQgaW50ZXJmYWNlIEN1cnJlbnRGaWx0ZXJzIHtcbiAgICBiZWRyb29tRmlsdGVyczogbnVtYmVyW107XG4gICAgYXZhaWxhYmlsaXR5RmlsdGVyczogc3RyaW5nW107XG4gICAgc3R5bGVGaWx0ZXJzOiBGbG9vcnBsYW5TdHlsZVtdO1xuICAgIG1pblJlbnQ6IG51bWJlcjtcbiAgICBtYXhSZW50OiBudW1iZXI7XG4gICAgc29ydEJ5OiBTb3J0Qnk7XG4gICAgZmxvb3JwbGFuSWRzOiBzdHJpbmdbXTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBVbml0RmlsdGVycyB7XG4gICAgYmVkcm9vbTogU2V0PG51bWJlcj47XG4gICAgYXZhaWxhYmlsaXR5OiBTZXQ8c3RyaW5nPjtcbiAgICBzdHlsZTogU2V0PEZsb29ycGxhblN0eWxlPjtcbn1cbiJdLCJtYXBwaW5ncyI6IiJ9
|