@renaissancerentals/renaissance-component 12.1.15 → 12.1.17
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/RenaissanceData.d.ts +2 -0
- package/lib/data/RenaissanceData.js +4 -2
- package/lib/floorplan/data/Floorplan.d.ts +2 -1
- package/lib/floorplan/data/Floorplan.js +1 -1
- package/lib/floorplan/section/FloorplanSection.js +33 -22
- package/lib/floorplan/service/FloorplanService.js +4 -3
- package/lib/property/data/Property.d.ts +5 -0
- package/lib/property/data/Property.js +7 -2
- package/lib/short-term/ShortTermFloorplanHero.d.ts +12 -0
- package/lib/short-term/ShortTermFloorplanHero.js +198 -0
- package/lib/short-term/ShortTermFloorplanSection.d.ts +10 -0
- package/lib/short-term/ShortTermFloorplanSection.js +134 -0
- package/lib/short-term/assets/ShortTermFloorplanHero.scss +165 -0
- package/lib/short-term/assets/ShortTermFloorplanSection.scss +124 -0
- package/lib/short-term/data/ShortTerm.d.ts +6 -1
- package/lib/short-term/data/ShortTerm.js +1 -1
- package/lib/short-term/service/ShortTermService.js +1 -1
- package/package.json +1 -1
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import "./assets/ShortTermFloorplanHero.scss";
|
|
3
|
+
import { FloorplanShortTerm } from "./data/ShortTerm";
|
|
4
|
+
import { WebSpecial } from "../floorplan/data/Floorplan";
|
|
5
|
+
export declare const ShortTermFloorplanHero: React.FC<ShortTermFloorplanHeroProps>;
|
|
6
|
+
export interface ShortTermFloorplanHeroProps {
|
|
7
|
+
floorplan: FloorplanShortTerm;
|
|
8
|
+
webSpecials: WebSpecial[];
|
|
9
|
+
contactClickHandler: () => void;
|
|
10
|
+
applyClickHandler: () => void;
|
|
11
|
+
handleRefToMap: () => void;
|
|
12
|
+
}
|
|
@@ -0,0 +1,198 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.ShortTermFloorplanHero = void 0;
|
|
7
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
8
|
+
require("./assets/ShortTermFloorplanHero.scss");
|
|
9
|
+
var _muncherUi = require("@contentmunch/muncher-ui");
|
|
10
|
+
var _Utils = require("../utils/Utils");
|
|
11
|
+
var _AssetService = require("../asset/service/AssetService");
|
|
12
|
+
var _RenaissanceData = require("../data/RenaissanceData");
|
|
13
|
+
var _GalleryHeroSkeleton = require("../gallery/GalleryHeroSkeleton");
|
|
14
|
+
var _GalleryModal = require("../gallery/GalleryModal");
|
|
15
|
+
var _GalleryHeroMain = require("../gallery/GalleryHeroMain");
|
|
16
|
+
var _GalleryHeroMobile = require("../gallery/GalleryHeroMobile");
|
|
17
|
+
var _VideoTours = require("../gallery/VideoTours");
|
|
18
|
+
var _VirtualTour = require("../gallery/VirtualTour");
|
|
19
|
+
var _HeroBadgeStats = require("../floorplan/section/HeroBadgeStats");
|
|
20
|
+
var _AssetModal = require("../asset/AssetModal");
|
|
21
|
+
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); }
|
|
22
|
+
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; }
|
|
23
|
+
const ShortTermFloorplanHero = _ref => {
|
|
24
|
+
let {
|
|
25
|
+
floorplan,
|
|
26
|
+
contactClickHandler,
|
|
27
|
+
applyClickHandler,
|
|
28
|
+
handleRefToMap,
|
|
29
|
+
webSpecials
|
|
30
|
+
} = _ref;
|
|
31
|
+
const [assets, setAssets] = (0, _react.useState)([]);
|
|
32
|
+
const [isAssetsLoading, setIsAssetsLoading] = (0, _react.useState)(true);
|
|
33
|
+
const [videoTours, setVideoTours] = (0, _react.useState)([]);
|
|
34
|
+
const [virtualTour, setVirtualTour] = (0, _react.useState)(undefined);
|
|
35
|
+
const [showFloorplanModal, setShowFloorplanModal] = (0, _react.useState)(false);
|
|
36
|
+
const [totalPages, setTotalPages] = (0, _react.useState)(1);
|
|
37
|
+
const [toursCount, setToursCount] = (0, _react.useState)(0);
|
|
38
|
+
const [currentView, setCurrentView] = (0, _react.useState)("photo");
|
|
39
|
+
const [assetInFocus, setAssetInFocus] = (0, _react.useState)({});
|
|
40
|
+
const [assetIndex, setAssetIndex] = (0, _react.useState)(0);
|
|
41
|
+
const [showModal, setShowModal] = (0, _react.useState)(false);
|
|
42
|
+
const FIRST_PAGE_ASSET_COUNT = 5;
|
|
43
|
+
const GRID_SIZE = 8;
|
|
44
|
+
const imageClickedHandler = image => {
|
|
45
|
+
setShowModal(true);
|
|
46
|
+
setAssetInFocus(image);
|
|
47
|
+
setAssetIndex(assets.findIndex(value => value.id === image.id));
|
|
48
|
+
};
|
|
49
|
+
const modalCloseHandler = () => {
|
|
50
|
+
setShowModal(false);
|
|
51
|
+
setAssetInFocus({});
|
|
52
|
+
};
|
|
53
|
+
(0, _react.useEffect)(() => {
|
|
54
|
+
if (floorplan.virtualTourLink) setVirtualTour(floorplan.virtualTourLink);
|
|
55
|
+
const tourLinks = [];
|
|
56
|
+
if (floorplan.videoTourLink) tourLinks.push(floorplan.videoTourLink);
|
|
57
|
+
if (floorplan.threeSixtyVideoTourLink) tourLinks.push(floorplan.threeSixtyVideoTourLink);
|
|
58
|
+
setVideoTours(tourLinks);
|
|
59
|
+
let otherAssetCounts = (tourLinks.length > 0 ? 1 : 0) + (floorplan.virtualTourLink ? 1 : 0);
|
|
60
|
+
setToursCount(otherAssetCounts);
|
|
61
|
+
const images = [];
|
|
62
|
+
images.push({
|
|
63
|
+
id: (0, _Utils.extractIdFrom)(floorplan.coverImage),
|
|
64
|
+
name: "cover image"
|
|
65
|
+
});
|
|
66
|
+
if (floorplan.photosFolderId) {
|
|
67
|
+
(0, _AssetService.getAssetsFrom)(floorplan.photosFolderId).then(galleryAssets => {
|
|
68
|
+
images.push(...galleryAssets);
|
|
69
|
+
let totalAssets = images.length + otherAssetCounts;
|
|
70
|
+
if (totalAssets > FIRST_PAGE_ASSET_COUNT) {
|
|
71
|
+
let pages = Math.trunc((totalAssets - FIRST_PAGE_ASSET_COUNT) / 8 + 1);
|
|
72
|
+
if ((totalAssets - FIRST_PAGE_ASSET_COUNT) % 8 === 0) {
|
|
73
|
+
setTotalPages(pages);
|
|
74
|
+
} else setTotalPages(pages + 1);
|
|
75
|
+
}
|
|
76
|
+
}).finally(() => {
|
|
77
|
+
setAssets(images);
|
|
78
|
+
setIsAssetsLoading(false);
|
|
79
|
+
});
|
|
80
|
+
} else {
|
|
81
|
+
setAssets(images);
|
|
82
|
+
console.log(images);
|
|
83
|
+
setIsAssetsLoading(false);
|
|
84
|
+
}
|
|
85
|
+
}, [floorplan]);
|
|
86
|
+
const isFirstSliderPage = slideIndex => slideIndex === 0;
|
|
87
|
+
const imageCountForFirstPage = () => FIRST_PAGE_ASSET_COUNT - toursCount;
|
|
88
|
+
const getImagesForFirstSliderPage = assets.slice(0, assets.length >= imageCountForFirstPage() ? imageCountForFirstPage() : assets.length);
|
|
89
|
+
const assetsToShow = slideIndex => {
|
|
90
|
+
if (isFirstSliderPage(slideIndex)) return getImagesForFirstSliderPage;
|
|
91
|
+
const startIndex = imageCountForFirstPage() + (slideIndex - 1) * 8;
|
|
92
|
+
const endIndex = startIndex + GRID_SIZE;
|
|
93
|
+
return assets.slice(startIndex, endIndex);
|
|
94
|
+
};
|
|
95
|
+
const printFloorplanAddress = () => {
|
|
96
|
+
return floorplan.address + ", " + _RenaissanceData.renaissance.city + ", " + _RenaissanceData.renaissance.state + " " + floorplan.zipcode;
|
|
97
|
+
};
|
|
98
|
+
return /*#__PURE__*/_react.default.createElement("section", {
|
|
99
|
+
className: "section-short-term-floorplan--hero"
|
|
100
|
+
}, isAssetsLoading ? /*#__PURE__*/_react.default.createElement(_GalleryHeroSkeleton.GalleryHeroSkeleton, null) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("div", {
|
|
101
|
+
className: "gallery-hero"
|
|
102
|
+
}, /*#__PURE__*/_react.default.createElement(_GalleryModal.GalleryModal, {
|
|
103
|
+
assets: assets,
|
|
104
|
+
assetInFocus: assetInFocus,
|
|
105
|
+
setAssetInFocus: setAssetInFocus,
|
|
106
|
+
showModal: showModal,
|
|
107
|
+
assetIndex: assetIndex,
|
|
108
|
+
setAssetIndex: setAssetIndex,
|
|
109
|
+
modalCloseHandler: modalCloseHandler,
|
|
110
|
+
propertyId: floorplan.property.id
|
|
111
|
+
}), currentView === "photo" ? /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("div", {
|
|
112
|
+
className: "photo-view main"
|
|
113
|
+
}, /*#__PURE__*/_react.default.createElement(_muncherUi.ItemSlider, {
|
|
114
|
+
sliderItems: [...Array(totalPages)].map((x, i) => /*#__PURE__*/_react.default.createElement(_GalleryHeroMain.GalleryHeroMain, {
|
|
115
|
+
isAvailableNow: false,
|
|
116
|
+
virtualTour: virtualTour,
|
|
117
|
+
isFirst: i === 0,
|
|
118
|
+
toursCount: toursCount,
|
|
119
|
+
webSpecials: webSpecials,
|
|
120
|
+
setCurrentView: setCurrentView,
|
|
121
|
+
imageClickedHandler: imageClickedHandler,
|
|
122
|
+
assetsToShow: assetsToShow(i),
|
|
123
|
+
propertyId: floorplan.property.id
|
|
124
|
+
}))
|
|
125
|
+
})), /*#__PURE__*/_react.default.createElement("div", {
|
|
126
|
+
className: "photo-view mobile"
|
|
127
|
+
}, /*#__PURE__*/_react.default.createElement(_GalleryHeroMobile.GalleryHeroMobile, {
|
|
128
|
+
assets: assets,
|
|
129
|
+
toursCount: toursCount,
|
|
130
|
+
virtualTour: virtualTour,
|
|
131
|
+
setCurrentView: setCurrentView,
|
|
132
|
+
imageClickedHandler: imageClickedHandler,
|
|
133
|
+
webSpecials: webSpecials,
|
|
134
|
+
isAvailableNow: false,
|
|
135
|
+
propertyId: floorplan.property.id
|
|
136
|
+
}))) : "", currentView === "video tour" ? /*#__PURE__*/_react.default.createElement(_VideoTours.VideoTours, {
|
|
137
|
+
videoTourUrls: videoTours
|
|
138
|
+
}) : "", currentView === "virtual tour" ? /*#__PURE__*/_react.default.createElement(_VirtualTour.VirtualTour, {
|
|
139
|
+
virtualTourUrl: virtualTour
|
|
140
|
+
}) : "", /*#__PURE__*/_react.default.createElement(_HeroBadgeStats.HeroBadgeStats, {
|
|
141
|
+
currentView: currentView,
|
|
142
|
+
setCurrentView: setCurrentView,
|
|
143
|
+
totalAssets: assets === null || assets === void 0 ? void 0 : assets.length,
|
|
144
|
+
videoTours: videoTours,
|
|
145
|
+
virtualTour: virtualTour
|
|
146
|
+
}))), /*#__PURE__*/_react.default.createElement(_AssetModal.AssetModal, {
|
|
147
|
+
assetUrl: floorplan.photo,
|
|
148
|
+
assetTitle: "Floorplan image",
|
|
149
|
+
showModal: showFloorplanModal,
|
|
150
|
+
setShowModal: setShowFloorplanModal,
|
|
151
|
+
propertyId: floorplan.property.id
|
|
152
|
+
}), /*#__PURE__*/_react.default.createElement("div", {
|
|
153
|
+
className: "container"
|
|
154
|
+
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
155
|
+
className: "floorplan--two-columns"
|
|
156
|
+
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
157
|
+
className: "floorplan-column-left"
|
|
158
|
+
}, /*#__PURE__*/_react.default.createElement("h3", null, floorplan.name), /*#__PURE__*/_react.default.createElement("h4", null, "$", floorplan.shortTerm.priceFor4andMoreMonths, " - $", floorplan.shortTerm.priceFor5To13Days, "/mo"), /*#__PURE__*/_react.default.createElement("p", {
|
|
159
|
+
className: "floorplan--description"
|
|
160
|
+
}, printFloorplanAddress()), /*#__PURE__*/_react.default.createElement("div", {
|
|
161
|
+
className: "floorplan--featured"
|
|
162
|
+
}, /*#__PURE__*/_react.default.createElement(_muncherUi.Button, {
|
|
163
|
+
size: "small",
|
|
164
|
+
onClick: () => setShowFloorplanModal(true)
|
|
165
|
+
}, /*#__PURE__*/_react.default.createElement(_muncherUi.Icon, {
|
|
166
|
+
name: "max",
|
|
167
|
+
orientation: "right"
|
|
168
|
+
}, "ViewFloorplan")), "|\xA0\xA0", /*#__PURE__*/_react.default.createElement(_muncherUi.Button, {
|
|
169
|
+
size: "small",
|
|
170
|
+
onClick: () => handleRefToMap()
|
|
171
|
+
}, /*#__PURE__*/_react.default.createElement(_muncherUi.Icon, {
|
|
172
|
+
orientation: "right",
|
|
173
|
+
name: "map"
|
|
174
|
+
}, "View on Map")), floorplan.property.busRoutes.length > 0 ? /*#__PURE__*/_react.default.createElement("p", null, "Bus Routes:\xA0", floorplan.property.busRoutes.map((busRoute, index) => /*#__PURE__*/_react.default.createElement("span", {
|
|
175
|
+
key: "bus-route-" + index
|
|
176
|
+
}, /*#__PURE__*/_react.default.createElement("a", {
|
|
177
|
+
href: busRoute.busRouteLink,
|
|
178
|
+
target: "_blank",
|
|
179
|
+
rel: "noreferrer"
|
|
180
|
+
}, busRoute.busRoute), index < floorplan.property.busRoutes.length - 1 ? ", " : ""))) : "")), /*#__PURE__*/_react.default.createElement("div", {
|
|
181
|
+
className: "main"
|
|
182
|
+
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
183
|
+
className: " floorplan-column-right"
|
|
184
|
+
}, /*#__PURE__*/_react.default.createElement(_muncherUi.Button, {
|
|
185
|
+
variant: "primary",
|
|
186
|
+
size: "medium",
|
|
187
|
+
onClick: contactClickHandler
|
|
188
|
+
}, "contact us"), /*#__PURE__*/_react.default.createElement(_muncherUi.Button, {
|
|
189
|
+
variant: "tertiary",
|
|
190
|
+
size: "medium",
|
|
191
|
+
onClick: applyClickHandler
|
|
192
|
+
}, "apply"), /*#__PURE__*/_react.default.createElement(_muncherUi.ShareButton, {
|
|
193
|
+
title: "Check out this apartment",
|
|
194
|
+
size: "large"
|
|
195
|
+
}))))));
|
|
196
|
+
};
|
|
197
|
+
exports.ShortTermFloorplanHero = ShortTermFloorplanHero;
|
|
198
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_muncherUi","_Utils","_AssetService","_RenaissanceData","_GalleryHeroSkeleton","_GalleryModal","_GalleryHeroMain","_GalleryHeroMobile","_VideoTours","_VirtualTour","_HeroBadgeStats","_AssetModal","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","prototype","hasOwnProperty","call","i","set","ShortTermFloorplanHero","_ref","floorplan","contactClickHandler","applyClickHandler","handleRefToMap","webSpecials","assets","setAssets","useState","isAssetsLoading","setIsAssetsLoading","videoTours","setVideoTours","virtualTour","setVirtualTour","undefined","showFloorplanModal","setShowFloorplanModal","totalPages","setTotalPages","toursCount","setToursCount","currentView","setCurrentView","assetInFocus","setAssetInFocus","assetIndex","setAssetIndex","showModal","setShowModal","FIRST_PAGE_ASSET_COUNT","GRID_SIZE","imageClickedHandler","image","findIndex","value","id","modalCloseHandler","useEffect","virtualTourLink","tourLinks","videoTourLink","push","threeSixtyVideoTourLink","otherAssetCounts","length","images","extractIdFrom","coverImage","name","photosFolderId","getAssetsFrom","then","galleryAssets","totalAssets","pages","Math","trunc","finally","console","log","isFirstSliderPage","slideIndex","imageCountForFirstPage","getImagesForFirstSliderPage","slice","assetsToShow","startIndex","endIndex","printFloorplanAddress","address","renaissance","city","state","zipcode","createElement","className","GalleryHeroSkeleton","Fragment","GalleryModal","propertyId","property","ItemSlider","sliderItems","Array","map","x","GalleryHeroMain","isAvailableNow","isFirst","GalleryHeroMobile","VideoTours","videoTourUrls","VirtualTour","virtualTourUrl","HeroBadgeStats","AssetModal","assetUrl","photo","assetTitle","shortTerm","priceFor4andMoreMonths","priceFor5To13Days","Button","size","onClick","Icon","orientation","busRoutes","busRoute","index","key","href","busRouteLink","target","rel","variant","ShareButton","title","exports"],"sources":["../../src/short-term/ShortTermFloorplanHero.tsx"],"sourcesContent":["import React, {useEffect, useState} from \"react\";\nimport \"./assets/ShortTermFloorplanHero.scss\";\nimport {Button, Icon, ItemSlider, ShareButton} from \"@contentmunch/muncher-ui\";\nimport {FloorplanShortTerm} from \"./data/ShortTerm\";\nimport {Asset} from \"../asset/data/Asset\";\nimport {extractIdFrom} from \"../utils/Utils\";\nimport {getAssetsFrom} from \"../asset/service/AssetService\";\nimport {WebSpecial} from \"../floorplan/data/Floorplan\";\nimport {renaissance} from \"../data/RenaissanceData\";\nimport {GalleryHeroSkeleton} from \"../gallery/GalleryHeroSkeleton\";\nimport {GalleryModal} from \"../gallery/GalleryModal\";\nimport {GalleryHeroMain} from \"../gallery/GalleryHeroMain\";\nimport {GalleryHeroMobile} from \"../gallery/GalleryHeroMobile\";\nimport {VideoTours} from \"../gallery/VideoTours\";\nimport {VirtualTour} from \"../gallery/VirtualTour\";\nimport {HeroBadgeStats} from \"../floorplan/section/HeroBadgeStats\";\nimport {AssetModal} from \"../asset/AssetModal\";\n\nexport const ShortTermFloorplanHero: React.FC<ShortTermFloorplanHeroProps> = (\n    {floorplan, contactClickHandler, applyClickHandler, handleRefToMap, webSpecials}) => {\n    const [assets, setAssets] = useState<Asset[]>([]);\n    const [isAssetsLoading, setIsAssetsLoading] = useState(true);\n    const [videoTours, setVideoTours] = useState<string[]>([]);\n    const [virtualTour, setVirtualTour] = useState<string | undefined>(undefined);\n    const [showFloorplanModal, setShowFloorplanModal] = useState(false);\n    const [totalPages, setTotalPages] = useState(1);\n    const [toursCount, setToursCount] = useState(0);\n    const [currentView, setCurrentView] = useState<\"photo\" | \"virtual tour\" | \"video tour\">(\"photo\");\n    const [assetInFocus, setAssetInFocus] = useState<Asset>({} as Asset);\n    const [assetIndex, setAssetIndex] = useState(0);\n    const [showModal, setShowModal] = useState(false);\n\n    const FIRST_PAGE_ASSET_COUNT = 5;\n    const GRID_SIZE = 8;\n    const imageClickedHandler = (image: Asset) => {\n        setShowModal(true);\n        setAssetInFocus(image);\n        setAssetIndex(assets.findIndex(value => value.id === image.id));\n    };\n    const modalCloseHandler = () => {\n        setShowModal(false);\n        setAssetInFocus({} as Asset);\n    };\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        let otherAssetCounts = (tourLinks.length > 0 ? 1 : 0) + (floorplan.virtualTourLink ? 1 : 0);\n        setToursCount(otherAssetCounts);\n        const images: Asset[] = [];\n        images.push({id: extractIdFrom(floorplan.coverImage), name: \"cover image\"} as Asset);\n\n        if (floorplan.photosFolderId) {\n            getAssetsFrom(floorplan.photosFolderId).then(galleryAssets => {\n                images.push(...galleryAssets);\n\n                let totalAssets = images.length + otherAssetCounts;\n\n                if (totalAssets > FIRST_PAGE_ASSET_COUNT) {\n\n                    let pages = Math.trunc(((totalAssets - FIRST_PAGE_ASSET_COUNT) / 8) + 1);\n\n                    if ((totalAssets - FIRST_PAGE_ASSET_COUNT) % 8 === 0) {\n                        setTotalPages(pages);\n                    } else\n                        setTotalPages(pages + 1);\n                }\n\n            }).finally(() => {\n                setAssets(images);\n                setIsAssetsLoading(false);\n            });\n        } else {\n            setAssets(images);\n            console.log(images)\n            setIsAssetsLoading(false);\n        }\n\n    }, [floorplan])\n\n    const isFirstSliderPage = (slideIndex: number) => slideIndex === 0;\n    const imageCountForFirstPage = () => FIRST_PAGE_ASSET_COUNT - toursCount;\n\n    const getImagesForFirstSliderPage = assets.slice(0, assets.length >= imageCountForFirstPage() ? imageCountForFirstPage() : assets.length);\n    const assetsToShow = (slideIndex: number) => {\n\n        if (isFirstSliderPage(slideIndex))\n            return getImagesForFirstSliderPage;\n\n        const startIndex = imageCountForFirstPage() + (slideIndex - 1) * 8;\n        const endIndex = startIndex + GRID_SIZE;\n\n        return assets.slice(startIndex, endIndex);\n    };\n\n    const printFloorplanAddress = () => {\n\n        return floorplan.address + \", \" + renaissance.city + \", \" + renaissance.state + \" \" + floorplan.zipcode;\n    }\n    return (\n        <section className=\"section-short-term-floorplan--hero\">\n            {isAssetsLoading ? <GalleryHeroSkeleton/> :\n                <>\n                    <div className=\"gallery-hero\">\n                        <GalleryModal assets={assets} assetInFocus={assetInFocus}\n                                      setAssetInFocus={setAssetInFocus} showModal={showModal}\n                                      assetIndex={assetIndex} setAssetIndex={setAssetIndex}\n                                      modalCloseHandler={modalCloseHandler} propertyId={floorplan.property.id}/>\n                        {currentView === \"photo\" ?\n                            <>\n                                <div className=\"photo-view main\">\n                                    <ItemSlider\n                                        sliderItems={[...Array(totalPages)].map((x, i) =>\n                                            <GalleryHeroMain isAvailableNow={false}\n                                                             virtualTour={virtualTour} isFirst={i === 0}\n                                                             toursCount={toursCount}\n                                                             webSpecials={webSpecials}\n                                                             setCurrentView={setCurrentView}\n                                                             imageClickedHandler={imageClickedHandler}\n                                                             assetsToShow={assetsToShow(i)}\n                                                             propertyId={floorplan.property.id}/>\n                                        )}/>\n                                </div>\n                                <div className=\"photo-view mobile\">\n                                    <GalleryHeroMobile assets={assets} toursCount={toursCount}\n                                                       virtualTour={virtualTour}\n                                                       setCurrentView={setCurrentView}\n                                                       imageClickedHandler={imageClickedHandler}\n                                                       webSpecials={webSpecials}\n                                                       isAvailableNow={false}\n                                                       propertyId={floorplan.property.id}/>\n                                </div>\n                            </> : \"\"\n                        }\n\n                        {currentView === \"video tour\" ? <VideoTours videoTourUrls={videoTours}/> : \"\"}\n                        {currentView === \"virtual tour\" ? <VirtualTour virtualTourUrl={virtualTour}/> : \"\"}\n                        <HeroBadgeStats currentView={currentView} setCurrentView={setCurrentView}\n                                        totalAssets={assets?.length} videoTours={videoTours} virtualTour={virtualTour}/>\n\n                    </div>\n                </>\n\n            }\n            <AssetModal assetUrl={floorplan.photo} assetTitle=\"Floorplan image\" showModal={showFloorplanModal}\n                        setShowModal={setShowFloorplanModal} propertyId={floorplan.property.id}/>\n            <div className=\"container\">\n                <div className=\"floorplan--two-columns\">\n                    <div className=\"floorplan-column-left\">\n                        <h3>{floorplan.name}</h3>\n                        <h4>${floorplan.shortTerm.priceFor4andMoreMonths} -\n                            ${floorplan.shortTerm.priceFor5To13Days}/mo</h4>\n                        <p className=\"floorplan--description\">{printFloorplanAddress()}</p>\n\n                        <div className=\"floorplan--featured\">\n                            <Button size=\"small\" onClick={() => setShowFloorplanModal(true)}>\n                                <Icon name=\"max\" orientation=\"right\">ViewFloorplan</Icon>\n                            </Button>\n                            |&nbsp;&nbsp;\n                            <Button size=\"small\" onClick={() => handleRefToMap()}>\n                                <Icon orientation=\"right\" name=\"map\">View on Map</Icon>\n                            </Button>\n                            {floorplan.property.busRoutes.length > 0 ?\n                                <p>Bus Routes:&nbsp;\n                                    {floorplan.property.busRoutes.map((busRoute, index) =>\n                                        <span key={\"bus-route-\" + index}>\n                                            <a href={busRoute.busRouteLink} target=\"_blank\"\n                                               rel=\"noreferrer\">{busRoute.busRoute}</a>\n                                            {index < floorplan.property.busRoutes.length - 1 ? \", \" : \"\"}\n                                        </span>\n                                    )}\n                                </p>\n                                : \"\"}\n                        </div>\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                </div>\n            </div>\n        </section>\n    );\n};\n\nexport interface ShortTermFloorplanHeroProps {\n    floorplan: FloorplanShortTerm;\n    webSpecials: WebSpecial[];\n    contactClickHandler: () => void;\n    applyClickHandler: () => void;\n    handleRefToMap: () => void;\n}\n"],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import "./assets/ShortTermFloorplanSection.scss";
|
|
3
|
+
export declare const ShortTermFloorplanSection: React.FC<FloorplanSectionProps>;
|
|
4
|
+
export interface FloorplanSectionProps {
|
|
5
|
+
contactClickHandler: () => void;
|
|
6
|
+
applyClickHandler: () => void;
|
|
7
|
+
floorplanId: string;
|
|
8
|
+
locationRef?: React.Ref<HTMLDivElement>;
|
|
9
|
+
handleRefToLocation?: () => void;
|
|
10
|
+
}
|
|
@@ -0,0 +1,134 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.ShortTermFloorplanSection = void 0;
|
|
7
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
8
|
+
require("./assets/ShortTermFloorplanSection.scss");
|
|
9
|
+
var _muncherUi = require("@contentmunch/muncher-ui");
|
|
10
|
+
var _ShortTermService = require("./service/ShortTermService");
|
|
11
|
+
var _GalleryHeroSkeleton = require("../gallery/GalleryHeroSkeleton");
|
|
12
|
+
var _ShortTermFloorplanHero = require("./ShortTermFloorplanHero");
|
|
13
|
+
var _Card = require("../card/Card");
|
|
14
|
+
var _Utils = require("../utils/Utils");
|
|
15
|
+
var _MapSection = require("../map/MapSection");
|
|
16
|
+
var _RenaissanceData = require("../data/RenaissanceData");
|
|
17
|
+
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); }
|
|
18
|
+
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; }
|
|
19
|
+
const ShortTermFloorplanSection = _ref => {
|
|
20
|
+
var _floorplan$property;
|
|
21
|
+
let {
|
|
22
|
+
contactClickHandler,
|
|
23
|
+
applyClickHandler,
|
|
24
|
+
floorplanId,
|
|
25
|
+
locationRef,
|
|
26
|
+
handleRefToLocation
|
|
27
|
+
} = _ref;
|
|
28
|
+
const [floorplan, setFloorplan] = (0, _react.useState)({});
|
|
29
|
+
const [isLoading, setIsLoading] = (0, _react.useState)(true);
|
|
30
|
+
const [errorLoading, setErrorLoading] = (0, _react.useState)(false);
|
|
31
|
+
const mapRef = (0, _react.useRef)(null);
|
|
32
|
+
const handleRefToMap = () => {
|
|
33
|
+
if (handleRefToLocation) handleRefToLocation();else {
|
|
34
|
+
var _mapRef$current;
|
|
35
|
+
(_mapRef$current = mapRef.current) === null || _mapRef$current === void 0 || _mapRef$current.scrollIntoView({
|
|
36
|
+
behavior: "smooth",
|
|
37
|
+
block: "start"
|
|
38
|
+
});
|
|
39
|
+
}
|
|
40
|
+
};
|
|
41
|
+
(0, _react.useEffect)(() => {
|
|
42
|
+
(0, _ShortTermService.getShortTermFloorplan)(floorplanId).then(data => {
|
|
43
|
+
setFloorplan(data);
|
|
44
|
+
}).catch(() => {
|
|
45
|
+
setErrorLoading(true);
|
|
46
|
+
}).finally(() => {
|
|
47
|
+
setIsLoading(false);
|
|
48
|
+
});
|
|
49
|
+
}, [floorplanId]);
|
|
50
|
+
const generatePricing = price => price ? "".concat((0, _Utils.toUSD)(price), "/day/ ").concat((0, _Utils.toUSD)(price * 30), "/mo") : "-";
|
|
51
|
+
return /*#__PURE__*/_react.default.createElement("section", {
|
|
52
|
+
className: "section-short-term-floorplan"
|
|
53
|
+
}, isLoading ? /*#__PURE__*/_react.default.createElement("section", {
|
|
54
|
+
className: "section-floorplan--hero"
|
|
55
|
+
}, /*#__PURE__*/_react.default.createElement(_GalleryHeroSkeleton.GalleryHeroSkeleton, null)) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, errorLoading ? /*#__PURE__*/_react.default.createElement("section", {
|
|
56
|
+
className: "div-full--center"
|
|
57
|
+
}, /*#__PURE__*/_react.default.createElement("h2", null, "Uh-oh, this is a 404")) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_ShortTermFloorplanHero.ShortTermFloorplanHero, {
|
|
58
|
+
floorplan: floorplan,
|
|
59
|
+
contactClickHandler: contactClickHandler,
|
|
60
|
+
webSpecials: [],
|
|
61
|
+
applyClickHandler: applyClickHandler,
|
|
62
|
+
handleRefToMap: handleRefToMap
|
|
63
|
+
}), /*#__PURE__*/_react.default.createElement("div", {
|
|
64
|
+
className: "container"
|
|
65
|
+
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
66
|
+
className: "floorplan--cards"
|
|
67
|
+
}, /*#__PURE__*/_react.default.createElement(_Card.Card, {
|
|
68
|
+
title: "Details"
|
|
69
|
+
}, /*#__PURE__*/_react.default.createElement("p", {
|
|
70
|
+
className: "floorplan-card--featured"
|
|
71
|
+
}, floorplan.bedroom, " Bedroom | ", floorplan.bathroom, " Bathroom ", (0, _Utils.enumToString)(floorplan.style)), /*#__PURE__*/_react.default.createElement("p", {
|
|
72
|
+
className: "floorplan-card--featured"
|
|
73
|
+
}, floorplan.shortTerm.squareFoot, " Square Feet"), /*#__PURE__*/_react.default.createElement("div", {
|
|
74
|
+
className: "row-content"
|
|
75
|
+
}, /*#__PURE__*/_react.default.createElement("h4", {
|
|
76
|
+
className: "row-title"
|
|
77
|
+
}, "Pricing:"), /*#__PURE__*/_react.default.createElement("p", {
|
|
78
|
+
className: "floorplan-card--featured"
|
|
79
|
+
}, /*#__PURE__*/_react.default.createElement("span", {
|
|
80
|
+
className: "key"
|
|
81
|
+
}, "5-13 days:"), /*#__PURE__*/_react.default.createElement("span", {
|
|
82
|
+
className: "value"
|
|
83
|
+
}, generatePricing(floorplan.shortTerm.priceFor5To13Days))), /*#__PURE__*/_react.default.createElement("p", {
|
|
84
|
+
className: "floorplan-card--featured"
|
|
85
|
+
}, /*#__PURE__*/_react.default.createElement("span", {
|
|
86
|
+
className: "key"
|
|
87
|
+
}, "14-29 days:"), /*#__PURE__*/_react.default.createElement("span", {
|
|
88
|
+
className: "value"
|
|
89
|
+
}, generatePricing(floorplan.shortTerm.priceFor14To29Days))), /*#__PURE__*/_react.default.createElement("p", {
|
|
90
|
+
className: "floorplan-card--featured"
|
|
91
|
+
}, /*#__PURE__*/_react.default.createElement("span", {
|
|
92
|
+
className: "key"
|
|
93
|
+
}, "1-4 months:"), /*#__PURE__*/_react.default.createElement("span", {
|
|
94
|
+
className: "value"
|
|
95
|
+
}, generatePricing(floorplan.shortTerm.priceFor1To4Months))), /*#__PURE__*/_react.default.createElement("p", {
|
|
96
|
+
className: "floorplan-card--featured"
|
|
97
|
+
}, /*#__PURE__*/_react.default.createElement("span", {
|
|
98
|
+
className: "key"
|
|
99
|
+
}, "4+ months:"), /*#__PURE__*/_react.default.createElement("span", {
|
|
100
|
+
className: "value"
|
|
101
|
+
}, generatePricing(floorplan.shortTerm.priceFor4andMoreMonths)))), /*#__PURE__*/_react.default.createElement("p", null, floorplan.description)), floorplan.amenities.length > 0 ? /*#__PURE__*/_react.default.createElement(_Card.Card, {
|
|
102
|
+
title: "Amenities"
|
|
103
|
+
}, /*#__PURE__*/_react.default.createElement(_muncherUi.Ul, null, floorplan.amenities.filter(amenity => amenity.featured).map(amenity => /*#__PURE__*/_react.default.createElement(_muncherUi.Li, {
|
|
104
|
+
key: "floorplan-amenity-" + amenity.id,
|
|
105
|
+
bulletIcon: "star",
|
|
106
|
+
isFeatured: true
|
|
107
|
+
}, amenity.name)), floorplan.amenities.filter(amenity => !amenity.featured).map(amenity => /*#__PURE__*/_react.default.createElement(_muncherUi.Li, {
|
|
108
|
+
key: "floorplan-amenity-" + amenity.id,
|
|
109
|
+
bulletIcon: "dot"
|
|
110
|
+
}, amenity.name)))) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null), isLoading ? "" : /*#__PURE__*/_react.default.createElement(_Card.Card, null, /*#__PURE__*/_react.default.createElement("div", {
|
|
111
|
+
ref: locationRef ? locationRef : mapRef,
|
|
112
|
+
id: "location",
|
|
113
|
+
className: "reference"
|
|
114
|
+
}), /*#__PURE__*/_react.default.createElement(_MapSection.MapSection, {
|
|
115
|
+
src: (0, _Utils.floorplanAddressToGoogleMap)({
|
|
116
|
+
city: _RenaissanceData.renaissance.city,
|
|
117
|
+
state: _RenaissanceData.renaissance.state,
|
|
118
|
+
address: floorplan.address,
|
|
119
|
+
zipcode: floorplan.zipcode
|
|
120
|
+
})
|
|
121
|
+
})), /*#__PURE__*/_react.default.createElement("div", {
|
|
122
|
+
className: "contact-card"
|
|
123
|
+
}, /*#__PURE__*/_react.default.createElement(_Card.Card, {
|
|
124
|
+
featured: true
|
|
125
|
+
}, /*#__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:")), (_floorplan$property = floorplan.property) !== null && _floorplan$property !== void 0 && _floorplan$property.phone ? /*#__PURE__*/_react.default.createElement("p", null, /*#__PURE__*/_react.default.createElement("a", {
|
|
126
|
+
href: "tel:" + floorplan.property.phone
|
|
127
|
+
}, (0, _Utils.formatPhoneNumber)(floorplan.property.phone))) : "", /*#__PURE__*/_react.default.createElement(_muncherUi.Button, {
|
|
128
|
+
variant: "tertiary",
|
|
129
|
+
onClick: contactClickHandler,
|
|
130
|
+
size: "large"
|
|
131
|
+
}, "Contact Us \xBB"))))))));
|
|
132
|
+
};
|
|
133
|
+
exports.ShortTermFloorplanSection = ShortTermFloorplanSection;
|
|
134
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_muncherUi","_ShortTermService","_GalleryHeroSkeleton","_ShortTermFloorplanHero","_Card","_Utils","_MapSection","_RenaissanceData","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","prototype","hasOwnProperty","call","i","set","ShortTermFloorplanSection","_ref","_floorplan$property","contactClickHandler","applyClickHandler","floorplanId","locationRef","handleRefToLocation","floorplan","setFloorplan","useState","isLoading","setIsLoading","errorLoading","setErrorLoading","mapRef","useRef","handleRefToMap","_mapRef$current","current","scrollIntoView","behavior","block","useEffect","getShortTermFloorplan","then","data","catch","finally","generatePricing","price","concat","toUSD","createElement","className","GalleryHeroSkeleton","Fragment","ShortTermFloorplanHero","webSpecials","Card","title","bedroom","bathroom","enumToString","style","shortTerm","squareFoot","priceFor5To13Days","priceFor14To29Days","priceFor1To4Months","priceFor4andMoreMonths","description","amenities","length","Ul","filter","amenity","featured","map","Li","key","id","bulletIcon","isFeatured","name","ref","MapSection","src","floorplanAddressToGoogleMap","city","renaissance","state","address","zipcode","property","phone","href","formatPhoneNumber","Button","variant","onClick","size","exports"],"sources":["../../src/short-term/ShortTermFloorplanSection.tsx"],"sourcesContent":["import React, {useEffect, useRef, useState} from \"react\";\nimport \"./assets/ShortTermFloorplanSection.scss\";\nimport {Button, Li, Ul} from \"@contentmunch/muncher-ui\";\nimport {FloorplanShortTerm} from \"./data/ShortTerm\";\nimport {getShortTermFloorplan} from \"./service/ShortTermService\";\nimport {GalleryHeroSkeleton} from \"../gallery/GalleryHeroSkeleton\";\nimport {ShortTermFloorplanHero} from \"./ShortTermFloorplanHero\";\nimport {Card} from \"../card/Card\";\nimport {enumToString, floorplanAddressToGoogleMap, formatPhoneNumber, toUSD} from \"../utils/Utils\";\nimport {MapSection} from \"../map/MapSection\";\nimport {renaissance} from \"../data/RenaissanceData\";\n\nexport const ShortTermFloorplanSection: React.FC<FloorplanSectionProps> = (\n    {\n        contactClickHandler,\n        applyClickHandler,\n        floorplanId,\n        locationRef,\n        handleRefToLocation\n    }) => {\n    const [floorplan, setFloorplan] = useState<FloorplanShortTerm>({} as FloorplanShortTerm);\n    const [isLoading, setIsLoading] = useState(true);\n    const [errorLoading, setErrorLoading] = useState(false);\n\n    const mapRef: React.Ref<HTMLDivElement> = useRef<HTMLDivElement>(null);\n    const handleRefToMap = () => {\n        if (handleRefToLocation)\n            handleRefToLocation();\n        else {\n            mapRef.current?.scrollIntoView({\n                behavior: \"smooth\",\n                block: \"start\"\n            });\n        }\n\n    };\n    useEffect(() => {\n        getShortTermFloorplan(floorplanId)\n            .then((data) => {\n                setFloorplan(data)\n            })\n            .catch(() => {\n                setErrorLoading(true);\n            })\n            .finally(() => {\n                setIsLoading(false);\n            });\n\n    }, [floorplanId]);\n    const generatePricing = (price: number) => price ? `${toUSD(price)}/day/ ${toUSD(price * 30)}/mo` : \"-\";\n\n    return (\n        <section className=\"section-short-term-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                            <ShortTermFloorplanHero floorplan={floorplan} contactClickHandler={contactClickHandler}\n                                                    webSpecials={[]}\n                                                    applyClickHandler={applyClickHandler}\n                                                    handleRefToMap={handleRefToMap}/>\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                                            {floorplan.shortTerm.squareFoot} Square Feet\n                                        </p>\n\n\n                                        <div className=\"row-content\">\n                                                <h4 className=\"row-title\">Pricing:</h4>\n                                            <p className=\"floorplan-card--featured\">\n                                                <span className=\"key\">5-13 days:</span>\n                                                <span className=\"value\">\n                                                    {generatePricing(floorplan.shortTerm.priceFor5To13Days)}\n                                                </span>\n                                            </p>\n                                            <p className=\"floorplan-card--featured\">\n                                                <span className=\"key\">14-29 days:</span>\n                                                <span className=\"value\">\n                                                    {generatePricing(floorplan.shortTerm.priceFor14To29Days)}\n                                                </span>\n                                            </p>\n                                            <p className=\"floorplan-card--featured\">\n                                                <span className=\"key\">1-4 months:</span>\n                                                <span className=\"value\">\n                                                    {generatePricing(floorplan.shortTerm.priceFor1To4Months)}\n                                                </span>\n                                            </p>\n                                            <p className=\"floorplan-card--featured\">\n                                                <span className=\"key\">4+ months:</span>\n                                                <span className=\"value\">\n                                                    {generatePricing(floorplan.shortTerm.priceFor4andMoreMonths)}\n                                                </span>\n                                            </p>\n                                        </div>\n\n                                        <p>\n                                            {floorplan.description}\n                                        </p>\n                                    </Card>\n\n\n                                    {\n                                        floorplan.amenities.length > 0 ?\n                                            <Card title=\"Amenities\">\n                                                <Ul>\n                                                    {\n                                                        floorplan.amenities.filter(amenity => amenity.featured).map(amenity =>\n                                                            <Li key={\"floorplan-amenity-\" + amenity.id}\n                                                                bulletIcon=\"star\"\n                                                                isFeatured={true}>\n                                                                {amenity.name}\n\n                                                            </Li>\n                                                        )}\n                                                    {\n                                                        floorplan.amenities.filter(amenity => !amenity.featured).map(amenity =>\n                                                            <Li key={\"floorplan-amenity-\" + amenity.id}\n                                                                bulletIcon=\"dot\">\n                                                                {amenity.name}\n\n                                                            </Li>\n                                                        )\n                                                    }\n                                                </Ul>\n\n                                            </Card> : <></>\n                                    }\n\n\n                                    {isLoading ? \"\" :\n                                        <Card>\n                                            <div ref={locationRef ? locationRef : mapRef} id=\"location\"\n                                                 className=\"reference\">\n\n                                            </div>\n                                            <MapSection\n                                                src={floorplanAddressToGoogleMap({\n                                                    city: renaissance.city,\n                                                    state: renaissance.state,\n                                                    address: floorplan.address,\n                                                    zipcode: floorplan.zipcode\n                                                })}/>\n                                        </Card>\n                                    }\n\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                                            {floorplan.property?.phone ?\n                                                <p><a\n                                                    href={\"tel:\" + floorplan.property.phone}>{formatPhoneNumber(floorplan.property.phone)}</a>\n                                                </p>\n                                                : \"\"}\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                </>\n            }\n\n        </section>\n    );\n};\n\nexport interface FloorplanSectionProps {\n    contactClickHandler: () => void;\n    applyClickHandler: () => void;\n    floorplanId: string;\n    locationRef?: React.Ref<HTMLDivElement>;\n    handleRefToLocation?: () => void;\n}\n"],"mappings":"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"}
|
|
@@ -0,0 +1,165 @@
|
|
|
1
|
+
@import 'src/assets/variables';
|
|
2
|
+
$floorplan-hero-featured-color: $secondary-color !default;
|
|
3
|
+
|
|
4
|
+
.section-short-term-floorplan--hero {
|
|
5
|
+
padding: 0;
|
|
6
|
+
background: $primary-background-color;
|
|
7
|
+
width: 100vw;
|
|
8
|
+
position: relative;
|
|
9
|
+
|
|
10
|
+
a {
|
|
11
|
+
text-decoration: underline;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
.gallery-hero {
|
|
15
|
+
position: relative;
|
|
16
|
+
width: 100vw;
|
|
17
|
+
height: 40vh;
|
|
18
|
+
@media (min-width: $large-size) {
|
|
19
|
+
height: 40vw;
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
.virtual-tour-view {
|
|
23
|
+
iframe {
|
|
24
|
+
width: 100%;
|
|
25
|
+
height: 40vh;
|
|
26
|
+
@media (min-width: $large-size) {
|
|
27
|
+
height: 40vw;
|
|
28
|
+
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
.video-tour-view {
|
|
34
|
+
.single-video-layout {
|
|
35
|
+
iframe {
|
|
36
|
+
width: 100%;
|
|
37
|
+
height: 35vh;
|
|
38
|
+
@media (min-width: $large-size) {
|
|
39
|
+
height: 40vw;
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
.two-video-layout {
|
|
45
|
+
@media (min-width: $large-size) {
|
|
46
|
+
display: flex;
|
|
47
|
+
align-content: flex-start;
|
|
48
|
+
justify-content: space-evenly;
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
iframe {
|
|
52
|
+
width: 40%;
|
|
53
|
+
height: 35vh;
|
|
54
|
+
margin: 1rem;
|
|
55
|
+
@media (min-width: $large-size) {
|
|
56
|
+
height: 35vw;
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
.badge--stats {
|
|
63
|
+
position: absolute;
|
|
64
|
+
left: 50%;
|
|
65
|
+
transform: translate(-50%, -50%);
|
|
66
|
+
bottom: -2rem;
|
|
67
|
+
|
|
68
|
+
.muncher-badge {
|
|
69
|
+
color: $primary-background-color;
|
|
70
|
+
flex-wrap: nowrap;
|
|
71
|
+
break-inside: avoid;
|
|
72
|
+
align-content: center;
|
|
73
|
+
width: 60vw;
|
|
74
|
+
font-size: .7rem;
|
|
75
|
+
@media (min-width: $large-size) {
|
|
76
|
+
font-size: 1rem;
|
|
77
|
+
width: auto;
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
.muncher-button--small {
|
|
81
|
+
padding: 0;
|
|
82
|
+
color: $primary-background-color;
|
|
83
|
+
text-transform: capitalize;
|
|
84
|
+
font-size: .7rem;
|
|
85
|
+
font-family: $serif-font;
|
|
86
|
+
@media (min-width: $large-size) {
|
|
87
|
+
font-size: 1rem;
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
.selected {
|
|
91
|
+
text-decoration: underline;
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
|
|
100
|
+
.floorplan--two-columns {
|
|
101
|
+
padding: 2rem;
|
|
102
|
+
@media (min-width: $medium-size) {
|
|
103
|
+
display: flex;
|
|
104
|
+
justify-content: space-between;
|
|
105
|
+
align-items: flex-start;
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
.floorplan-column-left {
|
|
109
|
+
h3, h4 {
|
|
110
|
+
text-align: left;
|
|
111
|
+
font-family: $serif-font;
|
|
112
|
+
margin: .5rem 0;
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
h3 {
|
|
116
|
+
font-weight: 400;
|
|
117
|
+
font-size: 2rem;
|
|
118
|
+
text-transform: capitalize;
|
|
119
|
+
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
h4 {
|
|
123
|
+
color: $floorplan-hero-featured-color;
|
|
124
|
+
text-transform: none;
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
.floorplan--description {
|
|
128
|
+
font-family: $sans-serif-font;
|
|
129
|
+
//color: $tertiary-background-color;
|
|
130
|
+
font-weight: 300;
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
.floorplan--featured {
|
|
134
|
+
font-family: $sans-serif-font;
|
|
135
|
+
letter-spacing: .05rem;
|
|
136
|
+
font-size: 1.1rem;
|
|
137
|
+
|
|
138
|
+
.muncher-button {
|
|
139
|
+
font-family: $sans-serif-font;
|
|
140
|
+
letter-spacing: .05rem;
|
|
141
|
+
font-size: 1.1rem;
|
|
142
|
+
text-transform: capitalize;
|
|
143
|
+
text-decoration: underline;
|
|
144
|
+
}
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
|
|
148
|
+
.floorplan-column-right {
|
|
149
|
+
display: flex;
|
|
150
|
+
justify-content: space-evenly;
|
|
151
|
+
align-content: space-evenly;
|
|
152
|
+
align-items: center;
|
|
153
|
+
flex-direction: column;
|
|
154
|
+
|
|
155
|
+
> .muncher-button, .muncher-dropdown > .muncher-button {
|
|
156
|
+
margin: .5rem;
|
|
157
|
+
min-width: 10rem;
|
|
158
|
+
height: 3rem;
|
|
159
|
+
text-transform: capitalize;
|
|
160
|
+
}
|
|
161
|
+
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
|
|
165
|
+
}
|