@renaissancerentals/renaissance-component 10.0.12 → 10.0.15
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/asset/AssetModal.d.ts +10 -0
- package/lib/asset/AssetModal.js +84 -0
- package/lib/asset/assets/AssetModal.scss +37 -0
- package/lib/assets/_variables.scss +1 -0
- package/lib/floorplan/card/FloorplanCard.js +2 -2
- package/lib/floorplan/card/SimilarFloorplanCard.d.ts +7 -0
- package/lib/floorplan/card/SimilarFloorplanCard.js +117 -0
- package/lib/floorplan/card/TestimonialsCard.d.ts +7 -0
- package/lib/floorplan/card/TestimonialsCard.js +68 -0
- package/lib/floorplan/card/assets/SimilarFloorplanCard.scss +53 -0
- package/lib/floorplan/card/assets/TestimonialsCard.scss +65 -0
- package/lib/floorplan/data/Floorplan.d.ts +39 -1
- package/lib/floorplan/data/Floorplan.js +1 -1
- package/lib/floorplan/section/FloorplanHero.d.ts +9 -0
- package/lib/floorplan/section/FloorplanHero.js +126 -0
- package/lib/floorplan/section/FloorplanSection.d.ts +13 -0
- package/lib/floorplan/section/FloorplanSection.js +187 -0
- package/lib/floorplan/section/assets/FloorplanHero.scss +75 -0
- package/lib/floorplan/section/assets/FloorplanSection.scss +89 -0
- package/lib/floorplan/service/FloorplanService.d.ts +11 -1
- package/lib/floorplan/service/FloorplanService.js +127 -2
- package/lib/gallery/GalleryHero.d.ts +2 -2
- package/lib/gallery/GalleryHero.js +53 -8
- package/lib/gallery/GalleryModal.js +5 -5
- package/lib/gallery/VideoTours.d.ts +5 -0
- package/lib/gallery/VideoTours.js +56 -0
- package/lib/gallery/VirtualTour.d.ts +5 -0
- package/lib/gallery/VirtualTour.js +28 -0
- package/lib/gallery/assets/GalleryHero.scss +64 -3
- package/lib/index.d.ts +4 -3
- package/lib/index.js +77 -1
- package/lib/utils/Utils.d.ts +3 -0
- package/lib/utils/Utils.js +16 -2
- package/package.json +2 -1
- package/lib/card/data/ImageCardData.d.ts +0 -6
- package/lib/card/data/ImageCardData.js +0 -6
|
@@ -0,0 +1,126 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
|
|
4
|
+
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports.FloorplanHero = void 0;
|
|
9
|
+
|
|
10
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
11
|
+
|
|
12
|
+
require("./assets/FloorplanHero.scss");
|
|
13
|
+
|
|
14
|
+
var _muncherUi = require("@contentmunch/muncher-ui");
|
|
15
|
+
|
|
16
|
+
var _AssetService = require("../../asset/service/AssetService");
|
|
17
|
+
|
|
18
|
+
var _GalleryHeroSkeleton = require("../../gallery/GalleryHeroSkeleton");
|
|
19
|
+
|
|
20
|
+
var _GalleryHero = require("../../gallery/GalleryHero");
|
|
21
|
+
|
|
22
|
+
var _FloorplanService = require("../service/FloorplanService");
|
|
23
|
+
|
|
24
|
+
var _Utils = require("../../utils/Utils");
|
|
25
|
+
|
|
26
|
+
var _AssetModal = require("../../asset/AssetModal");
|
|
27
|
+
|
|
28
|
+
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
29
|
+
|
|
30
|
+
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
31
|
+
|
|
32
|
+
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
|
|
33
|
+
|
|
34
|
+
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
35
|
+
|
|
36
|
+
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
|
37
|
+
|
|
38
|
+
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
|
|
39
|
+
|
|
40
|
+
function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
|
|
41
|
+
|
|
42
|
+
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
|
|
43
|
+
|
|
44
|
+
var FloorplanHero = function FloorplanHero(_ref) {
|
|
45
|
+
var _floorplan$units$, _floorplan$units$2, _floorplan$units$3, _floorplan$units$4;
|
|
46
|
+
|
|
47
|
+
var floorplan = _ref.floorplan,
|
|
48
|
+
contactClickHandler = _ref.contactClickHandler,
|
|
49
|
+
applyClickHandler = _ref.applyClickHandler;
|
|
50
|
+
|
|
51
|
+
var _useState = (0, _react.useState)([]),
|
|
52
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
53
|
+
assets = _useState2[0],
|
|
54
|
+
setAssets = _useState2[1];
|
|
55
|
+
|
|
56
|
+
var _useState3 = (0, _react.useState)(true),
|
|
57
|
+
_useState4 = _slicedToArray(_useState3, 2),
|
|
58
|
+
isLoading = _useState4[0],
|
|
59
|
+
setIsLoading = _useState4[1];
|
|
60
|
+
|
|
61
|
+
var _useState5 = (0, _react.useState)([]),
|
|
62
|
+
_useState6 = _slicedToArray(_useState5, 2),
|
|
63
|
+
videoTours = _useState6[0],
|
|
64
|
+
setVideoTours = _useState6[1];
|
|
65
|
+
|
|
66
|
+
var _useState7 = (0, _react.useState)(undefined),
|
|
67
|
+
_useState8 = _slicedToArray(_useState7, 2),
|
|
68
|
+
virtualTour = _useState8[0],
|
|
69
|
+
setVirtualTour = _useState8[1];
|
|
70
|
+
|
|
71
|
+
(0, _react.useEffect)(function () {
|
|
72
|
+
if (floorplan.virtualTourLink) setVirtualTour(floorplan.virtualTourLink);
|
|
73
|
+
var tourLinks = [];
|
|
74
|
+
if (floorplan.videoTourLink) tourLinks.push(floorplan.videoTourLink);
|
|
75
|
+
if (floorplan.threeSixtyVideoTourLink) tourLinks.push(floorplan.threeSixtyVideoTourLink);
|
|
76
|
+
setVideoTours(tourLinks);
|
|
77
|
+
(0, _AssetService.getAssetsFrom)(floorplan.photosFolderId).then(function (galleryAssets) {
|
|
78
|
+
setAssets(galleryAssets);
|
|
79
|
+
}).finally(function () {
|
|
80
|
+
setIsLoading(false);
|
|
81
|
+
});
|
|
82
|
+
}, [floorplan]);
|
|
83
|
+
return /*#__PURE__*/_react.default.createElement("section", {
|
|
84
|
+
className: "section-floorplan--hero"
|
|
85
|
+
}, isLoading ? /*#__PURE__*/_react.default.createElement(_GalleryHeroSkeleton.GalleryHeroSkeleton, null) : /*#__PURE__*/_react.default.createElement(_GalleryHero.GalleryHero, {
|
|
86
|
+
assets: assets,
|
|
87
|
+
isAvailableNow: (0, _FloorplanService.isFloorplanAvailable)(floorplan),
|
|
88
|
+
virtualTour: virtualTour,
|
|
89
|
+
videoTours: videoTours
|
|
90
|
+
}), /*#__PURE__*/_react.default.createElement("div", {
|
|
91
|
+
className: "container"
|
|
92
|
+
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
93
|
+
className: "floorplan--two-columns"
|
|
94
|
+
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
95
|
+
className: "floorplan-column-left"
|
|
96
|
+
}, /*#__PURE__*/_react.default.createElement("h3", null, floorplan.name), /*#__PURE__*/_react.default.createElement("h4", null, "$", (0, _Utils.rangeFrom)(floorplan.units, "rent"), "/mo"), /*#__PURE__*/_react.default.createElement("p", {
|
|
97
|
+
className: "floorplan--description"
|
|
98
|
+
}, floorplan === null || floorplan === void 0 ? void 0 : (_floorplan$units$ = floorplan.units[0]) === null || _floorplan$units$ === void 0 ? void 0 : _floorplan$units$.address, ", ", floorplan === null || floorplan === void 0 ? void 0 : (_floorplan$units$2 = floorplan.units[0]) === null || _floorplan$units$2 === void 0 ? void 0 : _floorplan$units$2.zipcode), /*#__PURE__*/_react.default.createElement("p", {
|
|
99
|
+
className: "floorplan--featured"
|
|
100
|
+
}, /*#__PURE__*/_react.default.createElement(_AssetModal.AssetModal, {
|
|
101
|
+
assetUrl: floorplan.photo,
|
|
102
|
+
assetTitle: "Floorplan image",
|
|
103
|
+
size: "small"
|
|
104
|
+
}, "View Floorplan"), "|\xA0\xA0", /*#__PURE__*/_react.default.createElement("a", {
|
|
105
|
+
target: "_blank",
|
|
106
|
+
href: (0, _Utils.addressToGoogleMapLink)(floorplan === null || floorplan === void 0 ? void 0 : (_floorplan$units$3 = floorplan.units[0]) === null || _floorplan$units$3 === void 0 ? void 0 : _floorplan$units$3.address, floorplan === null || floorplan === void 0 ? void 0 : (_floorplan$units$4 = floorplan.units[0]) === null || _floorplan$units$4 === void 0 ? void 0 : _floorplan$units$4.zipcode)
|
|
107
|
+
}, "View on Map"))), /*#__PURE__*/_react.default.createElement("div", {
|
|
108
|
+
className: "main"
|
|
109
|
+
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
110
|
+
className: " floorplan-column-right"
|
|
111
|
+
}, /*#__PURE__*/_react.default.createElement(_muncherUi.Button, {
|
|
112
|
+
variant: "primary",
|
|
113
|
+
size: "medium",
|
|
114
|
+
onClick: contactClickHandler
|
|
115
|
+
}, "contact us"), /*#__PURE__*/_react.default.createElement(_muncherUi.Button, {
|
|
116
|
+
variant: "tertiary",
|
|
117
|
+
size: "medium",
|
|
118
|
+
onClick: applyClickHandler
|
|
119
|
+
}, "apply"), /*#__PURE__*/_react.default.createElement(_muncherUi.ShareButton, {
|
|
120
|
+
title: "Check out this apartment",
|
|
121
|
+
size: "large"
|
|
122
|
+
}))))));
|
|
123
|
+
};
|
|
124
|
+
|
|
125
|
+
exports.FloorplanHero = FloorplanHero;
|
|
126
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["FloorplanHero","floorplan","contactClickHandler","applyClickHandler","useState","assets","setAssets","isLoading","setIsLoading","videoTours","setVideoTours","undefined","virtualTour","setVirtualTour","useEffect","virtualTourLink","tourLinks","videoTourLink","push","threeSixtyVideoTourLink","getAssetsFrom","photosFolderId","then","galleryAssets","finally","isFloorplanAvailable","name","rangeFrom","units","address","zipcode","photo","addressToGoogleMapLink"],"sources":["../../../src/floorplan/section/FloorplanHero.tsx"],"sourcesContent":["import React, {useEffect, useState} from \"react\";\nimport \"./assets/FloorplanHero.scss\";\nimport {Button, ShareButton} from \"@contentmunch/muncher-ui\";\nimport {Asset} from \"../../asset/data/Asset\";\nimport {getAssetsFrom} from \"../../asset/service/AssetService\";\nimport {GalleryHeroSkeleton} from \"../../gallery/GalleryHeroSkeleton\";\nimport {GalleryHero} from \"../../gallery/GalleryHero\";\nimport {isFloorplanAvailable} from \"../service/FloorplanService\";\nimport {addressToGoogleMapLink, rangeFrom} from \"../../utils/Utils\";\nimport {Floorplan} from \"../data/Floorplan\";\nimport {AssetModal} from \"../../asset/AssetModal\";\n\nexport const FloorplanHero: React.FC<FloorplanProps> = ({floorplan, contactClickHandler, applyClickHandler}) => {\n    const [assets, setAssets] = useState<Asset[]>([]);\n    const [isLoading, setIsLoading] = useState(true);\n    const [videoTours, setVideoTours] = useState<string[]>([]);\n    const [virtualTour, setVirtualTour] = useState<string | undefined>(undefined);\n    useEffect(() => {\n        if (floorplan.virtualTourLink)\n            setVirtualTour(floorplan.virtualTourLink);\n        const tourLinks = [];\n        if (floorplan.videoTourLink)\n            tourLinks.push(floorplan.videoTourLink);\n        if (floorplan.threeSixtyVideoTourLink)\n            tourLinks.push(floorplan.threeSixtyVideoTourLink);\n        setVideoTours(tourLinks);\n\n        getAssetsFrom(floorplan.photosFolderId).then(galleryAssets => {\n            setAssets(galleryAssets);\n        }).finally(() => {\n            setIsLoading(false);\n        });\n    }, [floorplan])\n    return (\n        <section className=\"section-floorplan--hero\">\n            {isLoading ? <GalleryHeroSkeleton/> :\n                <GalleryHero assets={assets} isAvailableNow={isFloorplanAvailable(floorplan)}\n                             virtualTour={virtualTour} videoTours={videoTours}/>}\n\n            <div className=\"container\">\n                <div className=\"floorplan--two-columns\">\n                    <div className=\"floorplan-column-left\">\n                        <h3>{floorplan.name}</h3>\n                        <h4>${rangeFrom(floorplan.units, \"rent\")}/mo</h4>\n                        <p className=\"floorplan--description\">{floorplan?.units[0]?.address}, {floorplan?.units[0]?.zipcode}</p>\n                        <p className=\"floorplan--featured\">\n                            <AssetModal assetUrl={floorplan.photo} assetTitle=\"Floorplan image\" size=\"small\">View\n                                Floorplan</AssetModal>|&nbsp;&nbsp;<a target=\"_blank\"\n                                                                      href={addressToGoogleMapLink(floorplan?.units[0]?.address, floorplan?.units[0]?.zipcode)}>View\n                            on Map</a>\n                        </p>\n                    </div>\n                    <div className=\"main\">\n                        <div className=\" floorplan-column-right\">\n                            <Button variant=\"primary\" size=\"medium\" onClick={contactClickHandler}>contact us</Button>\n                            <Button variant=\"tertiary\" size=\"medium\" onClick={applyClickHandler}>apply</Button>\n                            <ShareButton title=\"Check out this apartment\" size=\"large\"/>\n                        </div>\n                    </div>\n\n                </div>\n\n\n            </div>\n        </section>\n    );\n};\n\nexport interface FloorplanProps {\n    floorplan: Floorplan;\n    contactClickHandler: () => void;\n    applyClickHandler: () => void;\n}"],"mappings":"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"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import "./assets/FloorplanSection.scss";
|
|
3
|
+
export declare const FloorplanSection: React.FC<FloorplanSectionProps>;
|
|
4
|
+
export interface FloorplanSectionProps {
|
|
5
|
+
contactClickHandler: () => void;
|
|
6
|
+
applyClickHandler: () => void;
|
|
7
|
+
floorplanId: string;
|
|
8
|
+
contact: ContactNumber;
|
|
9
|
+
}
|
|
10
|
+
export interface ContactNumber {
|
|
11
|
+
number: number;
|
|
12
|
+
display: string;
|
|
13
|
+
}
|
|
@@ -0,0 +1,187 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
|
|
4
|
+
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports.FloorplanSection = void 0;
|
|
9
|
+
|
|
10
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
11
|
+
|
|
12
|
+
var _Floorplan = require("../data/Floorplan");
|
|
13
|
+
|
|
14
|
+
require("./assets/FloorplanSection.scss");
|
|
15
|
+
|
|
16
|
+
var _FloorplanService = require("../service/FloorplanService");
|
|
17
|
+
|
|
18
|
+
var _GalleryHeroSkeleton = require("../../gallery/GalleryHeroSkeleton");
|
|
19
|
+
|
|
20
|
+
var _FloorplanHero = require("./FloorplanHero");
|
|
21
|
+
|
|
22
|
+
var _Card = require("../../card/Card");
|
|
23
|
+
|
|
24
|
+
var _Utils = require("../../utils/Utils");
|
|
25
|
+
|
|
26
|
+
var _TestimonialsCard = require("../card/TestimonialsCard");
|
|
27
|
+
|
|
28
|
+
var _MapSection = require("../../map/MapSection");
|
|
29
|
+
|
|
30
|
+
var _SimilarFloorplanCard = require("../card/SimilarFloorplanCard");
|
|
31
|
+
|
|
32
|
+
var _muncherUi = require("@contentmunch/muncher-ui");
|
|
33
|
+
|
|
34
|
+
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
35
|
+
|
|
36
|
+
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
37
|
+
|
|
38
|
+
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
|
|
39
|
+
|
|
40
|
+
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
41
|
+
|
|
42
|
+
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
|
43
|
+
|
|
44
|
+
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
|
|
45
|
+
|
|
46
|
+
function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
|
|
47
|
+
|
|
48
|
+
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
|
|
49
|
+
|
|
50
|
+
var FloorplanSection = function FloorplanSection(_ref) {
|
|
51
|
+
var _floorplan$units$, _floorplan$units$2;
|
|
52
|
+
|
|
53
|
+
var contactClickHandler = _ref.contactClickHandler,
|
|
54
|
+
applyClickHandler = _ref.applyClickHandler,
|
|
55
|
+
floorplanId = _ref.floorplanId,
|
|
56
|
+
contact = _ref.contact;
|
|
57
|
+
|
|
58
|
+
var _useState = (0, _react.useState)({}),
|
|
59
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
60
|
+
floorplan = _useState2[0],
|
|
61
|
+
setFloorplan = _useState2[1];
|
|
62
|
+
|
|
63
|
+
var _useState3 = (0, _react.useState)([]),
|
|
64
|
+
_useState4 = _slicedToArray(_useState3, 2),
|
|
65
|
+
similarFloorplans = _useState4[0],
|
|
66
|
+
setSimilarFloorplans = _useState4[1];
|
|
67
|
+
|
|
68
|
+
var _useState5 = (0, _react.useState)([]),
|
|
69
|
+
_useState6 = _slicedToArray(_useState5, 2),
|
|
70
|
+
floorplanVariations = _useState6[0],
|
|
71
|
+
setFloorplanVariations = _useState6[1];
|
|
72
|
+
|
|
73
|
+
var _useState7 = (0, _react.useState)([]),
|
|
74
|
+
_useState8 = _slicedToArray(_useState7, 2),
|
|
75
|
+
testimonials = _useState8[0],
|
|
76
|
+
setTestimonials = _useState8[1];
|
|
77
|
+
|
|
78
|
+
var _useState9 = (0, _react.useState)(true),
|
|
79
|
+
_useState10 = _slicedToArray(_useState9, 2),
|
|
80
|
+
isLoading = _useState10[0],
|
|
81
|
+
setIsLoading = _useState10[1];
|
|
82
|
+
|
|
83
|
+
var _useState11 = (0, _react.useState)(false),
|
|
84
|
+
_useState12 = _slicedToArray(_useState11, 2),
|
|
85
|
+
errorLoading = _useState12[0],
|
|
86
|
+
setErrorLoading = _useState12[1];
|
|
87
|
+
|
|
88
|
+
(0, _react.useEffect)(function () {
|
|
89
|
+
Promise.all([(0, _FloorplanService.getFloorplan)(floorplanId), (0, _FloorplanService.getFloorplanVariations)(floorplanId), (0, _FloorplanService.getSimilarFloorplans)(floorplanId), (0, _FloorplanService.getTestimonials)(floorplanId)]).then(function (data) {
|
|
90
|
+
setFloorplan(data[0]);
|
|
91
|
+
setFloorplanVariations(data[1]);
|
|
92
|
+
setSimilarFloorplans(data[2]);
|
|
93
|
+
setTestimonials(data[3]);
|
|
94
|
+
}).catch(function () {
|
|
95
|
+
setErrorLoading(true);
|
|
96
|
+
}).finally(function () {
|
|
97
|
+
setIsLoading(false);
|
|
98
|
+
});
|
|
99
|
+
}, [floorplanId]);
|
|
100
|
+
return /*#__PURE__*/_react.default.createElement("section", {
|
|
101
|
+
className: "section-floorplan"
|
|
102
|
+
}, isLoading ? /*#__PURE__*/_react.default.createElement("section", {
|
|
103
|
+
className: "section-floorplan--hero"
|
|
104
|
+
}, /*#__PURE__*/_react.default.createElement(_GalleryHeroSkeleton.GalleryHeroSkeleton, null)) : errorLoading ? /*#__PURE__*/_react.default.createElement("section", {
|
|
105
|
+
className: "div-full--center"
|
|
106
|
+
}, /*#__PURE__*/_react.default.createElement("h2", null, "Uh-oh, this is a 404")) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_FloorplanHero.FloorplanHero, {
|
|
107
|
+
floorplan: floorplan,
|
|
108
|
+
contactClickHandler: contactClickHandler,
|
|
109
|
+
applyClickHandler: applyClickHandler
|
|
110
|
+
}), /*#__PURE__*/_react.default.createElement("div", {
|
|
111
|
+
className: "container"
|
|
112
|
+
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
113
|
+
className: "floorplan--cards"
|
|
114
|
+
}, /*#__PURE__*/_react.default.createElement(_Card.Card, {
|
|
115
|
+
title: "Details"
|
|
116
|
+
}, /*#__PURE__*/_react.default.createElement("p", {
|
|
117
|
+
className: "floorplan-card--featured"
|
|
118
|
+
}, floorplan.bedroom, " Bedroom | ", floorplan.bathroom, " Bathroom ", (0, _Utils.enumToString)(floorplan.style)), /*#__PURE__*/_react.default.createElement("p", {
|
|
119
|
+
className: "floorplan-card--featured"
|
|
120
|
+
}, "$", (0, _Utils.rangeFrom)(floorplan.units, "squareFoot"), " Square Feet"), /*#__PURE__*/_react.default.createElement("p", {
|
|
121
|
+
className: "floorplan-card--featured"
|
|
122
|
+
}, "$", (0, _Utils.rangeFrom)(floorplan.units, "rent"), "/mo"), /*#__PURE__*/_react.default.createElement("p", {
|
|
123
|
+
className: "floorplan-card--featured"
|
|
124
|
+
}, "$", (0, _Utils.rangeFrom)(floorplan.units, "deposit"), " Security Deposit"), /*#__PURE__*/_react.default.createElement("p", null, floorplan.description)), floorplan.amenities.length > 0 ? /*#__PURE__*/_react.default.createElement(_Card.Card, {
|
|
125
|
+
title: "Amenities"
|
|
126
|
+
}, floorplan.amenities.filter(function (amenity) {
|
|
127
|
+
return amenity.featured;
|
|
128
|
+
}).map(function (amenity) {
|
|
129
|
+
return /*#__PURE__*/_react.default.createElement("p", {
|
|
130
|
+
className: "floorplan-card--featured",
|
|
131
|
+
key: "floorplan-amenity-featured-" + amenity.id
|
|
132
|
+
}, amenity.name);
|
|
133
|
+
}), /*#__PURE__*/_react.default.createElement("ul", null, floorplan.amenities.filter(function (amenity) {
|
|
134
|
+
return !amenity.featured;
|
|
135
|
+
}).map(function (amenity) {
|
|
136
|
+
return /*#__PURE__*/_react.default.createElement("li", {
|
|
137
|
+
key: "floorplan-amenity-" + amenity.id
|
|
138
|
+
}, amenity.name);
|
|
139
|
+
})), floorplanVariations.length > 0 ? /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("h5", null, "Variations"), /*#__PURE__*/_react.default.createElement("ul", null, floorplanVariations.map(function (variation, i) {
|
|
140
|
+
return /*#__PURE__*/_react.default.createElement("li", {
|
|
141
|
+
key: "floorplan-variation-" + i
|
|
142
|
+
}, variation.variation);
|
|
143
|
+
}))) : "") : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null), testimonials.length > 0 ? /*#__PURE__*/_react.default.createElement(_TestimonialsCard.TestimonialsCard, {
|
|
144
|
+
testimonials: testimonials
|
|
145
|
+
}) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null), /*#__PURE__*/_react.default.createElement(_Card.Card, null, /*#__PURE__*/_react.default.createElement(_MapSection.MapSection, {
|
|
146
|
+
src: (0, _Utils.addressToGoogleMap)(floorplan === null || floorplan === void 0 ? void 0 : (_floorplan$units$ = floorplan.units[0]) === null || _floorplan$units$ === void 0 ? void 0 : _floorplan$units$.address, floorplan === null || floorplan === void 0 ? void 0 : (_floorplan$units$2 = floorplan.units[0]) === null || _floorplan$units$2 === void 0 ? void 0 : _floorplan$units$2.zipcode)
|
|
147
|
+
})), /*#__PURE__*/_react.default.createElement(_Card.Card, {
|
|
148
|
+
title: "Pets"
|
|
149
|
+
}, /*#__PURE__*/_react.default.createElement("h5", null, "Permitted"), /*#__PURE__*/_react.default.createElement("ul", null, (0, _FloorplanService.permittedPets)(floorplan).map(function (pet, i) {
|
|
150
|
+
return /*#__PURE__*/_react.default.createElement("li", {
|
|
151
|
+
key: "floorplan-permitted-pet-" + i
|
|
152
|
+
}, pet);
|
|
153
|
+
})), (0, _FloorplanService.notPermittedPets)(floorplan).length > 0 ? /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("h5", null, "Not Permitted"), /*#__PURE__*/_react.default.createElement("ul", null, (0, _FloorplanService.notPermittedPets)(floorplan).map(function (pet, i) {
|
|
154
|
+
return /*#__PURE__*/_react.default.createElement("li", {
|
|
155
|
+
key: "floorplan-not-permitted-pet-" + i
|
|
156
|
+
}, pet);
|
|
157
|
+
}))) : "", (0, _FloorplanService.petPolicy)(floorplan) ? /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("h5", null, "Additional Information"), /*#__PURE__*/_react.default.createElement("p", null, "petPolicy(floorplan)")) : ""), /*#__PURE__*/_react.default.createElement(_Card.Card, {
|
|
158
|
+
title: "Utilities"
|
|
159
|
+
}, /*#__PURE__*/_react.default.createElement("h5", null, "Paid By Landlord"), /*#__PURE__*/_react.default.createElement("ul", null, floorplan.utilities.filter(function (utility) {
|
|
160
|
+
return utility.type === _Floorplan.UtilityType.INCLUDED_UTILITY;
|
|
161
|
+
}).map(function (utility) {
|
|
162
|
+
return /*#__PURE__*/_react.default.createElement("li", {
|
|
163
|
+
key: "floorplan-included-utility-" + utility.id
|
|
164
|
+
}, (0, _Utils.capitalizeFirstLetter)(utility.name));
|
|
165
|
+
})), /*#__PURE__*/_react.default.createElement("h5", null, "Paid By Tenant"), /*#__PURE__*/_react.default.createElement("ul", null, floorplan.utilities.filter(function (utility) {
|
|
166
|
+
return utility.type === _Floorplan.UtilityType.RESIDENT_UTILITY;
|
|
167
|
+
}).map(function (utility) {
|
|
168
|
+
return /*#__PURE__*/_react.default.createElement("li", {
|
|
169
|
+
key: "floorplan-resident-utility-" + utility.id
|
|
170
|
+
}, (0, _Utils.capitalizeFirstLetter)(utility.name));
|
|
171
|
+
}))), similarFloorplans.length > 0 ? /*#__PURE__*/_react.default.createElement(_SimilarFloorplanCard.SimilarFloorplanCard, {
|
|
172
|
+
similarFloorplans: similarFloorplans
|
|
173
|
+
}) : "", /*#__PURE__*/_react.default.createElement("div", {
|
|
174
|
+
className: "contact-card"
|
|
175
|
+
}, /*#__PURE__*/_react.default.createElement(_Card.Card, {
|
|
176
|
+
featured: true
|
|
177
|
+
}, /*#__PURE__*/_react.default.createElement("p", null, /*#__PURE__*/_react.default.createElement("i", null, "Questions?")), /*#__PURE__*/_react.default.createElement("p", null, /*#__PURE__*/_react.default.createElement("i", null, "Call or text us anytime:")), /*#__PURE__*/_react.default.createElement("p", null, /*#__PURE__*/_react.default.createElement("a", {
|
|
178
|
+
href: "tel:" + contact.number
|
|
179
|
+
}, contact.display)), /*#__PURE__*/_react.default.createElement(_muncherUi.Button, {
|
|
180
|
+
variant: "tertiary",
|
|
181
|
+
onClick: contactClickHandler,
|
|
182
|
+
size: "large"
|
|
183
|
+
}, "Contact Us \xBB")))))));
|
|
184
|
+
};
|
|
185
|
+
|
|
186
|
+
exports.FloorplanSection = FloorplanSection;
|
|
187
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["FloorplanSection","contactClickHandler","applyClickHandler","floorplanId","contact","useState","floorplan","setFloorplan","similarFloorplans","setSimilarFloorplans","floorplanVariations","setFloorplanVariations","testimonials","setTestimonials","isLoading","setIsLoading","errorLoading","setErrorLoading","useEffect","Promise","all","getFloorplan","getFloorplanVariations","getSimilarFloorplans","getTestimonials","then","data","catch","finally","bedroom","bathroom","enumToString","style","rangeFrom","units","description","amenities","length","filter","amenity","featured","map","id","name","variation","i","addressToGoogleMap","address","zipcode","permittedPets","pet","notPermittedPets","petPolicy","utilities","utility","type","UtilityType","INCLUDED_UTILITY","capitalizeFirstLetter","RESIDENT_UTILITY","number","display"],"sources":["../../../src/floorplan/section/FloorplanSection.tsx"],"sourcesContent":["import React, {useEffect, useState} from \"react\";\nimport {Floorplan, FloorplanVariation, SimilarFloorplan, Testimonial, UtilityType} from \"../data/Floorplan\";\nimport \"./assets/FloorplanSection.scss\";\nimport {\n    getFloorplan,\n    getFloorplanVariations,\n    getSimilarFloorplans,\n    getTestimonials,\n    notPermittedPets,\n    permittedPets,\n    petPolicy\n} from \"../service/FloorplanService\";\nimport {GalleryHeroSkeleton} from \"../../gallery/GalleryHeroSkeleton\";\nimport {FloorplanHero} from \"./FloorplanHero\";\nimport {Card} from \"../../card/Card\";\nimport {addressToGoogleMap, capitalizeFirstLetter, enumToString, rangeFrom} from \"../../utils/Utils\";\nimport {TestimonialsCard} from \"../card/TestimonialsCard\";\nimport {MapSection} from \"../../map/MapSection\";\nimport {SimilarFloorplanCard} from \"../card/SimilarFloorplanCard\";\nimport {Button} from \"@contentmunch/muncher-ui\";\n\nexport const FloorplanSection: React.FC<FloorplanSectionProps> = ({contactClickHandler, applyClickHandler, floorplanId, contact}) => {\n    const [floorplan, setFloorplan] = useState<Floorplan>({} as Floorplan);\n    const [similarFloorplans, setSimilarFloorplans] = useState<SimilarFloorplan[]>([]);\n    const [floorplanVariations, setFloorplanVariations] = useState<FloorplanVariation[]>([]);\n    const [testimonials, setTestimonials] = useState<Testimonial[]>([]);\n    const [isLoading, setIsLoading] = useState(true);\n    const [errorLoading, setErrorLoading] = useState(false);\n    useEffect(() => {\n        Promise.all([\n            getFloorplan(floorplanId),\n            getFloorplanVariations(floorplanId),\n            getSimilarFloorplans(floorplanId),\n            getTestimonials(floorplanId)\n        ])\n            .then((data) => {\n                setFloorplan(data[0]);\n                setFloorplanVariations(data[1]);\n                setSimilarFloorplans(data[2]);\n                setTestimonials(data[3]);\n            })\n            .catch(() => {\n                setErrorLoading(true);\n            })\n            .finally(() => {\n                setIsLoading(false);\n            });\n\n    }, [floorplanId]);\n\n    return (\n        <section className=\"section-floorplan\">\n            {\n                isLoading ? <section className=\"section-floorplan--hero\"><GalleryHeroSkeleton/></section> :\n                    errorLoading ?\n                        <section className=\"div-full--center\">\n                            <h2>Uh-oh, this is a 404</h2>\n                        </section> :\n                        <>\n                            <FloorplanHero floorplan={floorplan} contactClickHandler={contactClickHandler} applyClickHandler={applyClickHandler}/>\n                            <div className=\"container\">\n                                <div className=\"floorplan--cards\">\n                                    <Card title=\"Details\">\n                                        <p className=\"floorplan-card--featured\">\n                                            {floorplan.bedroom} Bedroom\n                                            | {floorplan.bathroom} Bathroom {enumToString(floorplan.style)}\n                                        </p>\n                                        <p className=\"floorplan-card--featured\">\n                                            ${rangeFrom(floorplan.units, \"squareFoot\")} Square Feet\n                                        </p>\n                                        <p className=\"floorplan-card--featured\">\n                                            ${rangeFrom(floorplan.units, \"rent\")}/mo\n                                        </p>\n                                        <p className=\"floorplan-card--featured\">\n                                            ${rangeFrom(floorplan.units, \"deposit\")} Security Deposit</p>\n                                        <p>\n                                            {floorplan.description}\n                                        </p>\n                                    </Card>\n\n                                    {\n                                        floorplan.amenities.length > 0 ?\n                                            <Card title=\"Amenities\">\n                                                {\n                                                    floorplan.amenities.filter(amenity => amenity.featured).map(amenity =>\n                                                        <p className=\"floorplan-card--featured\"\n                                                           key={\"floorplan-amenity-featured-\" + amenity.id}>\n                                                            {amenity.name}\n                                                        </p>\n                                                    )}\n                                                <ul>\n                                                    {\n                                                        floorplan.amenities.filter(amenity => !amenity.featured).map(amenity =>\n                                                            <li key={\"floorplan-amenity-\" + amenity.id}>\n                                                                {amenity.name}\n                                                            </li>\n                                                        )\n                                                    }\n                                                </ul>\n                                                {\n                                                    floorplanVariations.length > 0 ?\n                                                        <>\n                                                            <h5>Variations</h5>\n                                                            <ul>\n                                                                {\n                                                                    floorplanVariations.map((variation, i) =>\n                                                                        <li key={\"floorplan-variation-\" + i}>\n                                                                            {variation.variation}\n                                                                        </li>\n                                                                    )\n                                                                }\n                                                            </ul>\n\n                                                        </> : \"\"}\n\n                                            </Card> : <></>\n                                    }\n\n                                    {\n                                        testimonials.length > 0 ?\n                                            <TestimonialsCard testimonials={testimonials}/> : <></>\n                                    }\n                                    <Card>\n                                        <MapSection\n                                            src={addressToGoogleMap(floorplan?.units[0]?.address, floorplan?.units[0]?.zipcode)}/>\n                                    </Card>\n\n                                    <Card title=\"Pets\">\n                                        <h5>Permitted</h5>\n                                        <ul>\n                                            {\n                                                permittedPets(floorplan).map((pet, i) =>\n                                                    <li key={\"floorplan-permitted-pet-\" + i}>\n                                                        {pet}\n                                                    </li>\n                                                )\n                                            }\n                                        </ul>\n                                        {notPermittedPets(floorplan).length > 0 ?\n                                            <><h5>Not Permitted</h5>\n                                                <ul>\n                                                    {\n                                                        notPermittedPets(floorplan).map((pet, i) =>\n                                                            <li key={\"floorplan-not-permitted-pet-\" + i}>\n                                                                {pet}\n                                                            </li>\n                                                        )\n                                                    }\n                                                </ul>\n                                            </> : \"\"}\n\n                                        {\n                                            petPolicy(floorplan) ?\n                                                <>\n                                                    <h5>Additional Information</h5>\n                                                    <p>petPolicy(floorplan)</p>\n                                                </> : \"\"\n\n                                        }\n\n                                    </Card>\n                                    <Card title=\"Utilities\">\n                                        <h5>Paid By Landlord</h5>\n                                        <ul>\n                                            {\n                                                floorplan.utilities.filter(utility => utility.type === UtilityType.INCLUDED_UTILITY).map(utility =>\n                                                    <li key={\"floorplan-included-utility-\" + utility.id}>\n                                                        {capitalizeFirstLetter(utility.name)}\n                                                    </li>\n                                                )\n                                            }\n                                        </ul>\n                                        <h5>Paid By Tenant</h5>\n                                        <ul>\n                                            {\n                                                floorplan.utilities.filter(utility => utility.type === UtilityType.RESIDENT_UTILITY).map(utility =>\n                                                    <li key={\"floorplan-resident-utility-\" + utility.id}>\n                                                        {capitalizeFirstLetter(utility.name)}\n                                                    </li>\n                                                )\n                                            }\n                                        </ul>\n\n                                    </Card>\n                                    {similarFloorplans.length > 0 ?\n                                        <SimilarFloorplanCard similarFloorplans={similarFloorplans}/> : \"\"}\n\n                                    <div className=\"contact-card\">\n                                        <Card featured={true}>\n                                            <p><i>Questions?</i></p>\n                                            <p><i>Call or text us anytime:</i></p>\n                                            <p><a\n                                                href={\"tel:\" + contact.number}>{contact.display}</a>\n                                            </p>\n                                            <Button variant=\"tertiary\" onClick={contactClickHandler} size=\"large\">Contact\n                                                Us\n                                                »</Button>\n                                        </Card>\n                                    </div>\n                                </div>\n                            </div>\n                        </>\n            }\n\n        </section>\n    );\n};\n\nexport interface FloorplanSectionProps {\n    contactClickHandler: () => void;\n    applyClickHandler: () => void;\n    floorplanId: string;\n    contact: ContactNumber;\n\n}\n\nexport interface ContactNumber {\n    number: number;\n    display: string;\n}\n"],"mappings":"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"}
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
@import 'src/assets/variables';
|
|
2
|
+
|
|
3
|
+
.section-floorplan--hero {
|
|
4
|
+
padding: 0;
|
|
5
|
+
background: $primary-background-color;
|
|
6
|
+
|
|
7
|
+
a {
|
|
8
|
+
text-decoration: underline;
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
.floorplan--two-columns {
|
|
12
|
+
padding: 2rem;
|
|
13
|
+
@media (min-width: $medium-size) {
|
|
14
|
+
display: flex;
|
|
15
|
+
justify-content: space-between;
|
|
16
|
+
align-items: flex-start;
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
.floorplan-column-left {
|
|
20
|
+
h3, h4 {
|
|
21
|
+
text-align: left;
|
|
22
|
+
font-family: $serif-font;
|
|
23
|
+
margin: .5rem 0;
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
h3 {
|
|
27
|
+
font-weight: 400;
|
|
28
|
+
font-size: 2rem;
|
|
29
|
+
text-transform: capitalize;
|
|
30
|
+
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
h4 {
|
|
34
|
+
color: $secondary-color;
|
|
35
|
+
text-transform: none;
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
.floorplan--description {
|
|
39
|
+
font-family: $sans-serif-font;
|
|
40
|
+
//color: $tertiary-background-color;
|
|
41
|
+
font-weight: 300;
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
.floorplan--featured {
|
|
45
|
+
font-family: $sans-serif-font;
|
|
46
|
+
letter-spacing: .05rem;
|
|
47
|
+
font-size: 1.1rem;
|
|
48
|
+
.muncher-button{
|
|
49
|
+
font-family: $sans-serif-font;
|
|
50
|
+
letter-spacing: .05rem;
|
|
51
|
+
font-size: 1.1rem;
|
|
52
|
+
text-transform: capitalize;
|
|
53
|
+
text-decoration: underline;
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
.floorplan-column-right {
|
|
59
|
+
display: flex;
|
|
60
|
+
justify-content: space-evenly;
|
|
61
|
+
align-content: space-evenly;
|
|
62
|
+
align-items: center;
|
|
63
|
+
flex-direction: column;
|
|
64
|
+
|
|
65
|
+
> .muncher-button, .muncher-dropdown > .muncher-button {
|
|
66
|
+
margin: .5rem;
|
|
67
|
+
min-width: 10rem;
|
|
68
|
+
height: 3rem;
|
|
69
|
+
text-transform: capitalize;
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
}
|
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
@import 'src/assets/variables';
|
|
2
|
+
|
|
3
|
+
$floorplan-background-color: $tertiary-color !default;
|
|
4
|
+
.section-floorplan {
|
|
5
|
+
padding: 0 0 .5rem;
|
|
6
|
+
background: $floorplan-background-color;
|
|
7
|
+
|
|
8
|
+
.floorplan--cards {
|
|
9
|
+
padding: 0;
|
|
10
|
+
margin: 1rem 0;
|
|
11
|
+
@media (min-width: $large-size) {
|
|
12
|
+
-webkit-column-count: 2;
|
|
13
|
+
column-count: 2;
|
|
14
|
+
column-gap: 1rem;
|
|
15
|
+
> .section-card {
|
|
16
|
+
margin-top: 0;
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
.section-card {
|
|
22
|
+
padding: 0;
|
|
23
|
+
margin: 3vw;
|
|
24
|
+
width: 94vw;
|
|
25
|
+
|
|
26
|
+
@media (min-width: $large-size) {
|
|
27
|
+
margin: 1rem 0;
|
|
28
|
+
width: 100%;
|
|
29
|
+
break-inside: avoid-column;
|
|
30
|
+
-webkit-column-break-inside: avoid;
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
p {
|
|
34
|
+
font-size: 1rem;
|
|
35
|
+
letter-spacing: .03rem;
|
|
36
|
+
line-height: 1.5rem;
|
|
37
|
+
font-weight: 300;
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
ul {
|
|
41
|
+
column-count: 1;
|
|
42
|
+
padding-top: 0;
|
|
43
|
+
|
|
44
|
+
li {
|
|
45
|
+
font-size: 1rem;
|
|
46
|
+
letter-spacing: .03rem;
|
|
47
|
+
line-height: 1.5rem;
|
|
48
|
+
font-weight: 300;
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
.muncher-paper {
|
|
53
|
+
margin: 0;
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
.floorplan-card--featured, h5 {
|
|
57
|
+
color: $primary-color;
|
|
58
|
+
margin: .3rem 0;
|
|
59
|
+
text-transform: capitalize;
|
|
60
|
+
font-weight: 400;
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
h5 {
|
|
64
|
+
padding: 0;
|
|
65
|
+
text-align: left;
|
|
66
|
+
font-size: 1.1rem;
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
.contact-card {
|
|
71
|
+
text-align: center;
|
|
72
|
+
|
|
73
|
+
p {
|
|
74
|
+
font-size: 1.6rem;
|
|
75
|
+
font-family: $serif-font;
|
|
76
|
+
letter-spacing: .04rem;
|
|
77
|
+
line-height: 2rem;
|
|
78
|
+
font-weight: 400;
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
a {
|
|
82
|
+
color: $primary-background-color;
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
.muncher-button--tertiary {
|
|
87
|
+
color: $primary-background-color;
|
|
88
|
+
}
|
|
89
|
+
}
|
|
@@ -1,8 +1,18 @@
|
|
|
1
1
|
import { CurrentFilters, FloorplanFilters, SortBy } from "../data/FloorplanFilters";
|
|
2
|
-
import { FloorplanDetails } from "../data/Floorplan";
|
|
2
|
+
import { Floorplan, FloorplanDetails, FloorplanSpotlight, FloorplanVariation, SimilarFloorplan, Testimonial } from "../data/Floorplan";
|
|
3
3
|
import { PropertyId } from "../../property/data/Property";
|
|
4
4
|
export declare const convertToHttps: (url: string) => string;
|
|
5
5
|
export declare const getFloorplans: (propertyId: PropertyId) => Promise<FloorplanDetails[]>;
|
|
6
6
|
export declare const sortAndFilter: (floorplans: FloorplanDetails[], currentFilters: CurrentFilters) => FloorplanDetails[];
|
|
7
7
|
export declare const sortFloorplans: (floorplans: FloorplanDetails[], sortBy: SortBy) => FloorplanDetails[];
|
|
8
8
|
export declare const filtersFrom: (floorplans: FloorplanDetails[]) => FloorplanFilters;
|
|
9
|
+
export declare const getFeaturedFloorplans: () => Promise<FloorplanSpotlight[]>;
|
|
10
|
+
export declare const getAllActiveFloorplans: () => Promise<FloorplanDetails[]>;
|
|
11
|
+
export declare const getFloorplan: (floorplanId: string) => Promise<Floorplan>;
|
|
12
|
+
export declare const getSimilarFloorplans: (floorplanId: string) => Promise<SimilarFloorplan[]>;
|
|
13
|
+
export declare const getFloorplanVariations: (floorplanId: string) => Promise<FloorplanVariation[]>;
|
|
14
|
+
export declare const isFloorplanAvailable: (floorplan: Floorplan) => boolean;
|
|
15
|
+
export declare const getTestimonials: (floorplanId: string) => Promise<Testimonial[]>;
|
|
16
|
+
export declare const permittedPets: (floorplan: Floorplan) => string[];
|
|
17
|
+
export declare const notPermittedPets: (floorplan: Floorplan) => string[];
|
|
18
|
+
export declare const petPolicy: (floorplan: Floorplan) => string | undefined;
|