@renaissancerentals/renaissance-component 12.1.15 → 12.1.16

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.
@@ -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
+ }