@renaissancerentals/renaissance-component 12.3.8 → 12.3.10

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,234 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.UnitHero = void 0;
7
+ var _react = _interopRequireWildcard(require("react"));
8
+ require("../../floorplan/section/assets/FloorplanHero.scss");
9
+ var _muncherUi = require("@contentmunch/muncher-ui");
10
+ var _AssetService = require("../../asset/service/AssetService");
11
+ var _GridGallerySkeleton = require("../../gallery/GridGallerySkeleton");
12
+ var _Utils = require("../../utils/Utils");
13
+ var _AssetModal = require("../../asset/AssetModal");
14
+ var _VideoTours = require("../../gallery/VideoTours");
15
+ var _VirtualTour = require("../../gallery/VirtualTour");
16
+ var _GalleryModal = require("../../gallery/GalleryModal");
17
+ var _GridGalleryMobile = require("../../gallery/GridGalleryMobile");
18
+ var _GridGalleryCover = require("../../gallery/GridGalleryCover");
19
+ var _GridGallery = require("../../gallery/GridGallery");
20
+ var _UnitService = require("../service/UnitService");
21
+ var _HeroBadgeStats = require("../../floorplan/section/HeroBadgeStats");
22
+ var _UnitPrice = require("./UnitPrice");
23
+ 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); }
24
+ 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; }
25
+ const UnitHero = _ref => {
26
+ let {
27
+ unit,
28
+ contactClickHandler,
29
+ applyClickHandler,
30
+ handleRefToMap,
31
+ webSpecials
32
+ } = _ref;
33
+ const [assets, setAssets] = (0, _react.useState)([]);
34
+ const [isAssetsLoading, setIsAssetsLoading] = (0, _react.useState)(true);
35
+ const [videoTours, setVideoTours] = (0, _react.useState)([]);
36
+ const [virtualTour, setVirtualTour] = (0, _react.useState)(undefined);
37
+ const [videoTourImageBackground, setVideoTourImageBackground] = (0, _react.useState)();
38
+ const [virtualTourImageBackground, setVirtualTourImageBackground] = (0, _react.useState)();
39
+ const [showFloorplanModal, setShowFloorplanModal] = (0, _react.useState)(false);
40
+ const [totalPages, setTotalPages] = (0, _react.useState)(1);
41
+ const [toursCount, setToursCount] = (0, _react.useState)(1);
42
+ const [currentView, setCurrentView] = (0, _react.useState)("photo");
43
+ const [assetInFocus, setAssetInFocus] = (0, _react.useState)({});
44
+ const [assetIndex, setAssetIndex] = (0, _react.useState)(0);
45
+ const [showModal, setShowModal] = (0, _react.useState)(false);
46
+ const [firstPageImageCount, setFirstPageImageCount] = (0, _react.useState)(4);
47
+ const GRID_SIZE = 8;
48
+ const imageClickedHandler = image => {
49
+ setShowModal(true);
50
+ setAssetInFocus(image);
51
+ setAssetIndex(assets.findIndex(value => value.id === image.id));
52
+ };
53
+ const modalCloseHandler = () => {
54
+ setShowModal(false);
55
+ setAssetInFocus({});
56
+ };
57
+ (0, _react.useEffect)(() => {
58
+ const images = [];
59
+ if (unit.coverImage) images.push({
60
+ id: (0, _Utils.extractIdFrom)(unit.coverImage),
61
+ name: "cover image"
62
+ });else if (unit.floorplan.coverImage) images.push({
63
+ id: (0, _Utils.extractIdFrom)(unit.floorplan.coverImage),
64
+ name: "cover image"
65
+ });
66
+ let firstPageCount = firstPageImageCount;
67
+ if (unit.photosFolderId) {
68
+ (0, _AssetService.getAssetsFrom)(unit.photosFolderId).then(galleryAssets => {
69
+ images.push(...galleryAssets);
70
+ if (images.length > 1) {
71
+ const backgroundImageUrl = (0, _AssetService.assetUrlFrom)(images[1].id, unit.floorplan.property.id);
72
+ if (unit.virtualTourLink) {
73
+ setVirtualTour(unit.virtualTourLink);
74
+ setVirtualTourImageBackground(backgroundImageUrl);
75
+ firstPageCount -= 1;
76
+ }
77
+ const tourLinks = [];
78
+ if (unit.videoTourLink) tourLinks.push(unit.videoTourLink);
79
+ if (unit.threeSixtyVideoTourLink) tourLinks.push(unit.threeSixtyVideoTourLink);
80
+ setVideoTours(tourLinks);
81
+ if (tourLinks.length > 0) {
82
+ setVideoTourImageBackground(backgroundImageUrl);
83
+ firstPageCount -= 1;
84
+ }
85
+ let otherAssetCounts = (tourLinks.length > 0 ? 1 : 0) + (unit.virtualTourLink ? 1 : 0);
86
+ setToursCount(otherAssetCounts);
87
+ }
88
+ }).finally(() => {
89
+ let pages = 1;
90
+ if (images.length > firstPageCount) {
91
+ const remaining = images.length - firstPageCount;
92
+ pages += remaining / 8;
93
+ if (remaining % 8 > 0) pages += 1;
94
+ }
95
+ setTotalPages(Math.trunc(pages));
96
+ setFirstPageImageCount(firstPageCount);
97
+ setAssets(images);
98
+ setIsAssetsLoading(false);
99
+ });
100
+ } else {
101
+ setAssets(images);
102
+ setIsAssetsLoading(false);
103
+ }
104
+ }, [unit]);
105
+ const printUnitAddress = () => {
106
+ const address = (0, _UnitService.addressFromUnit)(unit);
107
+ let printAddress = "";
108
+ if (address.address) {
109
+ printAddress += address.address + ", ";
110
+ }
111
+ printAddress += address.city + ", " + address.state + " " + address.zipcode;
112
+ return printAddress;
113
+ };
114
+ const isFirstSliderPage = slideIndex => slideIndex === 0;
115
+ const assetsToShow = slideIndex => {
116
+ if (isFirstSliderPage(slideIndex)) {
117
+ console.log("firstPageImageCount", firstPageImageCount);
118
+ return assets.slice(0, firstPageImageCount - 1);
119
+ }
120
+ const startIndex = firstPageImageCount - 1 + GRID_SIZE * (slideIndex - 1);
121
+ const endIndex = firstPageImageCount - 1 + GRID_SIZE * slideIndex;
122
+ return assets.slice(startIndex, endIndex > assets.length ? assets.length : endIndex);
123
+ };
124
+ return /*#__PURE__*/_react.default.createElement("section", {
125
+ className: "section-floorplan--hero"
126
+ }, isAssetsLoading ? /*#__PURE__*/_react.default.createElement(_GridGallerySkeleton.GridGallerySkeleton, null) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("div", {
127
+ className: "gallery-hero"
128
+ }, /*#__PURE__*/_react.default.createElement(_GalleryModal.GalleryModal, {
129
+ assets: assets,
130
+ assetInFocus: assetInFocus,
131
+ setAssetInFocus: setAssetInFocus,
132
+ showModal: showModal,
133
+ assetIndex: assetIndex,
134
+ setAssetIndex: setAssetIndex,
135
+ modalCloseHandler: modalCloseHandler,
136
+ propertyId: unit.floorplan.property.id
137
+ }), currentView === "photo" ? /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("div", {
138
+ className: "photo-view main"
139
+ }, /*#__PURE__*/_react.default.createElement(_muncherUi.ItemSlider, {
140
+ sliderItems: [...Array(totalPages)].map((x, i) => i == 0 ? /*#__PURE__*/_react.default.createElement(_GridGalleryCover.GridGalleryCover, {
141
+ assets: assetsToShow(i),
142
+ address: (0, _UnitService.addressFromUnit)(unit),
143
+ propertyId: unit.floorplan.property.id,
144
+ heroImage: assets[0],
145
+ imageClickedHandler: imageClickedHandler,
146
+ webSpecials: webSpecials,
147
+ isAvailableNow: (0, _UnitService.isUnitAvailable)(unit),
148
+ setCurrentView: setCurrentView,
149
+ videoTourImageBackground: videoTourImageBackground,
150
+ virtualTourImageBackground: virtualTourImageBackground,
151
+ showOnlyHeroImage: assets.length === 1
152
+ }) : /*#__PURE__*/_react.default.createElement(_GridGallery.GridGallery, {
153
+ imageClickedHandler: imageClickedHandler,
154
+ propertyId: unit.floorplan.property.id,
155
+ assets: assetsToShow(i)
156
+ }))
157
+ })), /*#__PURE__*/_react.default.createElement("div", {
158
+ className: "photo-view mobile"
159
+ }, /*#__PURE__*/_react.default.createElement(_GridGalleryMobile.GridGalleryMobile, {
160
+ assets: assets,
161
+ toursCount: toursCount,
162
+ address: (0, _UnitService.addressFromUnit)(unit),
163
+ virtualTour: virtualTour,
164
+ setCurrentView: setCurrentView,
165
+ imageClickedHandler: imageClickedHandler,
166
+ webSpecials: webSpecials,
167
+ isAvailableNow: (0, _UnitService.isUnitAvailable)(unit),
168
+ propertyId: unit.floorplan.property.id
169
+ }))) : "", currentView === "Video Tour" ? /*#__PURE__*/_react.default.createElement(_VideoTours.VideoTours, {
170
+ videoTourUrls: videoTours
171
+ }) : "", currentView === "Virtual Tour" ? /*#__PURE__*/_react.default.createElement(_VirtualTour.VirtualTour, {
172
+ virtualTourUrl: virtualTour
173
+ }) : "", /*#__PURE__*/_react.default.createElement(_HeroBadgeStats.HeroBadgeStats, {
174
+ currentView: currentView,
175
+ setCurrentView: setCurrentView,
176
+ totalAssets: assets === null || assets === void 0 ? void 0 : assets.length,
177
+ videoTours: videoTours,
178
+ virtualTour: virtualTour
179
+ }))), /*#__PURE__*/_react.default.createElement(_AssetModal.AssetModal, {
180
+ assetUrl: unit.floorplanImage ? unit.floorplanImage : unit.floorplan.photo,
181
+ assetTitle: "Floorplan image",
182
+ showModal: showFloorplanModal,
183
+ setShowModal: setShowFloorplanModal,
184
+ propertyId: unit.floorplan.property.id
185
+ }), /*#__PURE__*/_react.default.createElement("div", {
186
+ className: "container"
187
+ }, /*#__PURE__*/_react.default.createElement("div", {
188
+ className: "floorplan--two-columns"
189
+ }, /*#__PURE__*/_react.default.createElement("div", {
190
+ className: "floorplan-column-left"
191
+ }, /*#__PURE__*/_react.default.createElement("h3", null, unit.floorplan.name), /*#__PURE__*/_react.default.createElement("h4", null, /*#__PURE__*/_react.default.createElement(_UnitPrice.UnitPrice, {
192
+ unit: unit,
193
+ invertColor: true
194
+ })), /*#__PURE__*/_react.default.createElement("p", {
195
+ className: "floorplan--description"
196
+ }, printUnitAddress()), /*#__PURE__*/_react.default.createElement("div", {
197
+ className: "floorplan--featured"
198
+ }, /*#__PURE__*/_react.default.createElement(_muncherUi.Button, {
199
+ size: "small",
200
+ onClick: () => setShowFloorplanModal(true)
201
+ }, /*#__PURE__*/_react.default.createElement(_muncherUi.Icon, {
202
+ name: "max",
203
+ orientation: "right"
204
+ }, "ViewFloorplan")), "|\xA0\xA0", /*#__PURE__*/_react.default.createElement(_muncherUi.Button, {
205
+ size: "small",
206
+ onClick: () => handleRefToMap()
207
+ }, /*#__PURE__*/_react.default.createElement(_muncherUi.Icon, {
208
+ orientation: "right",
209
+ name: "map"
210
+ }, "View on Map")), unit.floorplan.property.busRoutes.length > 0 ? /*#__PURE__*/_react.default.createElement("p", null, "Bus Routes:\xA0", unit.floorplan.property.busRoutes.map((busRoute, index) => /*#__PURE__*/_react.default.createElement("span", {
211
+ key: "bus-route-" + index
212
+ }, /*#__PURE__*/_react.default.createElement("a", {
213
+ href: busRoute.busRouteLink,
214
+ target: "_blank",
215
+ rel: "noreferrer"
216
+ }, busRoute.busRoute), index < unit.floorplan.property.busRoutes.length - 1 ? ", " : ""))) : "")), /*#__PURE__*/_react.default.createElement("div", {
217
+ className: "main"
218
+ }, /*#__PURE__*/_react.default.createElement("div", {
219
+ className: " floorplan-column-right"
220
+ }, /*#__PURE__*/_react.default.createElement(_muncherUi.Button, {
221
+ variant: "primary",
222
+ size: "medium",
223
+ onClick: contactClickHandler
224
+ }, "contact us"), /*#__PURE__*/_react.default.createElement(_muncherUi.Button, {
225
+ variant: "tertiary",
226
+ size: "medium",
227
+ onClick: applyClickHandler
228
+ }, "apply"), /*#__PURE__*/_react.default.createElement(_muncherUi.ShareButton, {
229
+ title: "Check out this apartment",
230
+ size: "large"
231
+ }))))));
232
+ };
233
+ exports.UnitHero = UnitHero;
234
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_muncherUi","_AssetService","_GridGallerySkeleton","_Utils","_AssetModal","_VideoTours","_VirtualTour","_GalleryModal","_GridGalleryMobile","_GridGalleryCover","_GridGallery","_UnitService","_HeroBadgeStats","_UnitPrice","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","prototype","hasOwnProperty","call","i","set","UnitHero","_ref","unit","contactClickHandler","applyClickHandler","handleRefToMap","webSpecials","assets","setAssets","useState","isAssetsLoading","setIsAssetsLoading","videoTours","setVideoTours","virtualTour","setVirtualTour","undefined","videoTourImageBackground","setVideoTourImageBackground","virtualTourImageBackground","setVirtualTourImageBackground","showFloorplanModal","setShowFloorplanModal","totalPages","setTotalPages","toursCount","setToursCount","currentView","setCurrentView","assetInFocus","setAssetInFocus","assetIndex","setAssetIndex","showModal","setShowModal","firstPageImageCount","setFirstPageImageCount","GRID_SIZE","imageClickedHandler","image","findIndex","value","id","modalCloseHandler","useEffect","images","coverImage","push","extractIdFrom","name","floorplan","firstPageCount","photosFolderId","getAssetsFrom","then","galleryAssets","length","backgroundImageUrl","assetUrlFrom","property","virtualTourLink","tourLinks","videoTourLink","threeSixtyVideoTourLink","otherAssetCounts","finally","pages","remaining","Math","trunc","printUnitAddress","address","addressFromUnit","printAddress","city","state","zipcode","isFirstSliderPage","slideIndex","assetsToShow","console","log","slice","startIndex","endIndex","createElement","className","GridGallerySkeleton","Fragment","GalleryModal","propertyId","ItemSlider","sliderItems","Array","map","x","GridGalleryCover","heroImage","isAvailableNow","isUnitAvailable","showOnlyHeroImage","GridGallery","GridGalleryMobile","VideoTours","videoTourUrls","VirtualTour","virtualTourUrl","HeroBadgeStats","totalAssets","AssetModal","assetUrl","floorplanImage","photo","assetTitle","UnitPrice","invertColor","Button","size","onClick","Icon","orientation","busRoutes","busRoute","index","key","href","busRouteLink","target","rel","variant","ShareButton","title","exports"],"sources":["../../../src/unit/section/UnitHero.tsx"],"sourcesContent":["import React, {useEffect, useState} from \"react\";\nimport \"../../floorplan/section/assets/FloorplanHero.scss\";\nimport {Button, Icon, ItemSlider, ShareButton} from \"@contentmunch/muncher-ui\";\nimport {Asset} from \"../../asset/data/Asset\";\nimport {assetUrlFrom, getAssetsFrom} from \"../../asset/service/AssetService\";\nimport {GridGallerySkeleton} from \"../../gallery/GridGallerySkeleton\";\nimport {extractIdFrom} from \"../../utils/Utils\";\nimport {AssetModal} from \"../../asset/AssetModal\";\nimport {VideoTours} from \"../../gallery/VideoTours\";\nimport {VirtualTour} from \"../../gallery/VirtualTour\";\nimport {GalleryModal} from \"../../gallery/GalleryModal\";\nimport {GridGalleryMobile} from \"../../gallery/GridGalleryMobile\";\nimport {GridGalleryCover, TourType} from \"../../gallery/GridGalleryCover\";\nimport {GridGallery} from \"../../gallery/GridGallery\";\nimport {UnitFloorplan} from \"../data/Unit\";\nimport {addressFromUnit, isUnitAvailable} from \"../service/UnitService\";\nimport {HeroBadgeStats} from \"../../floorplan/section/HeroBadgeStats\";\nimport {WebSpecial} from \"../../floorplan/data/Floorplan\";\nimport {UnitPrice} from \"./UnitPrice\";\n\nexport const UnitHero: React.FC<UnitHeroProps> = (\n    {unit, 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\n    const [videoTourImageBackground, setVideoTourImageBackground] = useState<string>();\n    const [virtualTourImageBackground, setVirtualTourImageBackground] = useState<string>();\n\n    const [showFloorplanModal, setShowFloorplanModal] = useState(false);\n    const [totalPages, setTotalPages] = useState(1);\n    const [toursCount, setToursCount] = useState(1);\n    const [currentView, setCurrentView] = useState<\"photo\" | TourType>(\"photo\");\n    const [assetInFocus, setAssetInFocus] = useState<Asset>({} as Asset);\n    const [assetIndex, setAssetIndex] = useState(0);\n    const [showModal, setShowModal] = useState(false);\n    const [firstPageImageCount, setFirstPageImageCount] = useState(4);\n\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\n\n        const images: Asset[] = [];\n        if (unit.coverImage)\n            images.push({id: extractIdFrom(unit.coverImage), name: \"cover image\"} as Asset);\n        else if (unit.floorplan.coverImage)\n            images.push({id: extractIdFrom(unit.floorplan.coverImage), name: \"cover image\"} as Asset);\n\n\n        let firstPageCount = firstPageImageCount;\n\n        if (unit.photosFolderId) {\n            getAssetsFrom(unit.photosFolderId).then(galleryAssets => {\n\n                images.push(...galleryAssets);\n\n                if (images.length > 1) {\n                    const backgroundImageUrl = assetUrlFrom(images[1].id, unit.floorplan.property.id);\n                    if (unit.virtualTourLink) {\n                        setVirtualTour(unit.virtualTourLink);\n                        setVirtualTourImageBackground(backgroundImageUrl);\n                        firstPageCount -= 1;\n                    }\n\n                    const tourLinks = [];\n                    if (unit.videoTourLink)\n                        tourLinks.push(unit.videoTourLink);\n                    if (unit.threeSixtyVideoTourLink)\n                        tourLinks.push(unit.threeSixtyVideoTourLink);\n                    setVideoTours(tourLinks);\n                    if (tourLinks.length > 0) {\n                        setVideoTourImageBackground(backgroundImageUrl);\n                        firstPageCount -= 1;\n                    }\n\n                    let otherAssetCounts = (tourLinks.length > 0 ? 1 : 0) + (unit.virtualTourLink ? 1 : 0);\n                    setToursCount(otherAssetCounts);\n\n                }\n\n            }).finally(() => {\n\n                let pages = 1;\n\n                if (images.length > firstPageCount) {\n                    const remaining = images.length - firstPageCount;\n                    pages += remaining / 8;\n                    if (remaining % 8 > 0)\n                        pages += 1;\n                }\n\n                setTotalPages(Math.trunc(pages));\n                setFirstPageImageCount(firstPageCount);\n                setAssets(images);\n                setIsAssetsLoading(false);\n            });\n        } else {\n            setAssets(images);\n            setIsAssetsLoading(false);\n        }\n\n    }, [unit])\n\n\n    const printUnitAddress = () => {\n        const address = addressFromUnit(unit);\n\n        let printAddress = \"\";\n        if (address.address) {\n            printAddress += address.address + \", \";\n        }\n        printAddress += address.city + \", \" + address.state + \" \" + address.zipcode;\n        return printAddress;\n    }\n    const isFirstSliderPage = (slideIndex: number) => slideIndex === 0;\n\n    const assetsToShow = (slideIndex: number) => {\n\n        if (isFirstSliderPage(slideIndex)) {\n            console.log(\"firstPageImageCount\", firstPageImageCount);\n            return assets.slice(0, firstPageImageCount - 1);\n        }\n\n\n        const startIndex = firstPageImageCount - 1 + (GRID_SIZE * (slideIndex - 1))\n        const endIndex = firstPageImageCount - 1 + (GRID_SIZE * slideIndex)\n\n        return assets.slice(startIndex, endIndex > assets.length ? assets.length : endIndex);\n    };\n    return (\n        <section className=\"section-floorplan--hero\">\n            {isAssetsLoading ? <GridGallerySkeleton/> :\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={unit.floorplan.property.id}/>\n                        {currentView === \"photo\" ?\n                            <>\n                                <div className=\"photo-view main\">\n                                    <ItemSlider\n                                        sliderItems={[...Array(totalPages)].map((x, i) =>\n                                            (i == 0) ?\n                                                <GridGalleryCover\n                                                    assets={assetsToShow(i)}\n                                                    address={addressFromUnit(unit)}\n                                                    propertyId={unit.floorplan.property.id}\n                                                    heroImage={assets[0]}\n                                                    imageClickedHandler={imageClickedHandler}\n                                                    webSpecials={webSpecials}\n                                                    isAvailableNow={isUnitAvailable(unit)}\n                                                    setCurrentView={setCurrentView}\n                                                    videoTourImageBackground={videoTourImageBackground}\n                                                    virtualTourImageBackground={virtualTourImageBackground}\n                                                    showOnlyHeroImage={assets.length === 1}\n                                                />\n                                                :\n                                                <GridGallery\n                                                    imageClickedHandler={imageClickedHandler}\n                                                    propertyId={unit.floorplan.property.id}\n                                                    assets={assetsToShow(i)}\n                                                />\n                                        )}/>\n                                </div>\n                                <div className=\"photo-view mobile\">\n                                    <GridGalleryMobile assets={assets} toursCount={toursCount}\n                                                       address={addressFromUnit(unit)}\n                                                       virtualTour={virtualTour}\n                                                       setCurrentView={setCurrentView}\n                                                       imageClickedHandler={imageClickedHandler}\n                                                       webSpecials={webSpecials}\n                                                       isAvailableNow={isUnitAvailable(unit)}\n                                                       propertyId={unit.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={unit.floorplanImage ? unit.floorplanImage : unit.floorplan.photo}\n                        assetTitle=\"Floorplan image\" showModal={showFloorplanModal}\n                        setShowModal={setShowFloorplanModal} propertyId={unit.floorplan.property.id}/>\n            <div className=\"container\">\n                <div className=\"floorplan--two-columns\">\n                    <div className=\"floorplan-column-left\">\n                        <h3>{unit.floorplan.name}</h3>\n                        <h4><UnitPrice unit={unit} invertColor={true}/></h4>\n                        <p className=\"floorplan--description\">{printUnitAddress()}</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                            {unit.floorplan.property.busRoutes.length > 0 ?\n                                <p>Bus Routes:&nbsp;\n                                    {unit.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 < unit.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 UnitHeroProps {\n    unit: UnitFloorplan;\n    webSpecials: WebSpecial[];\n    contactClickHandler: () => void;\n    applyClickHandler: () => void;\n    handleRefToMap: () => void;\n}\n"],"mappings":"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"}
@@ -0,0 +1,8 @@
1
+ import React from "react";
2
+ import "../../floorplan/card/assets/FloorplanPrice.scss";
3
+ import { UnitFloorplan } from "../data/Unit";
4
+ export declare const UnitPrice: React.FC<UnitPriceProps>;
5
+ export interface UnitPriceProps {
6
+ unit: UnitFloorplan;
7
+ invertColor?: boolean;
8
+ }
@@ -0,0 +1,41 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.UnitPrice = void 0;
7
+ var _react = _interopRequireDefault(require("react"));
8
+ var _Utils = require("../../utils/Utils");
9
+ var _moment = _interopRequireDefault(require("moment/moment"));
10
+ require("../../floorplan/card/assets/FloorplanPrice.scss");
11
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
12
+ const UnitPrice = _ref => {
13
+ let {
14
+ unit,
15
+ invertColor
16
+ } = _ref;
17
+ const hasSpecialRent = () => {
18
+ const currentDate = (0, _moment.default)();
19
+ if (unit.discountedRent && unit.discountedRentStartDate && unit.discountedRentEndDate) {
20
+ const startDate = (0, _Utils.dateToMoment)(unit.discountedRentStartDate);
21
+ const endDate = (0, _Utils.dateToMoment)(unit.discountedRentEndDate);
22
+ return currentDate.isBetween(startDate, endDate);
23
+ }
24
+ return false;
25
+ };
26
+ const getRentClass = () => hasSpecialRent() ? "strike-through" : "";
27
+ const priceForSpecialRent = () => hasSpecialRent() ? /*#__PURE__*/_react.default.createElement("span", {
28
+ className: "special"
29
+ }, "Now starting at ", (0, _Utils.toUSD)(unit.discountedRent), "/mo") : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null);
30
+ return /*#__PURE__*/_react.default.createElement("span", {
31
+ className: invertColor ? "floorplan-price floorplan-price-inverted" : "floorplan-price"
32
+ }, /*#__PURE__*/_react.default.createElement("span", {
33
+ className: getRentClass()
34
+ }, /*#__PURE__*/_react.default.createElement("span", {
35
+ className: "rent"
36
+ }, (0, _Utils.toUSD)(unit.rent))), /*#__PURE__*/_react.default.createElement("span", {
37
+ className: "floorplan-special-price"
38
+ }, priceForSpecialRent()));
39
+ };
40
+ exports.UnitPrice = UnitPrice;
41
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIl9VdGlscyIsIl9tb21lbnQiLCJvYmoiLCJfX2VzTW9kdWxlIiwiZGVmYXVsdCIsIlVuaXRQcmljZSIsIl9yZWYiLCJ1bml0IiwiaW52ZXJ0Q29sb3IiLCJoYXNTcGVjaWFsUmVudCIsImN1cnJlbnREYXRlIiwibW9tZW50IiwiZGlzY291bnRlZFJlbnQiLCJkaXNjb3VudGVkUmVudFN0YXJ0RGF0ZSIsImRpc2NvdW50ZWRSZW50RW5kRGF0ZSIsInN0YXJ0RGF0ZSIsImRhdGVUb01vbWVudCIsImVuZERhdGUiLCJpc0JldHdlZW4iLCJnZXRSZW50Q2xhc3MiLCJwcmljZUZvclNwZWNpYWxSZW50IiwiY3JlYXRlRWxlbWVudCIsImNsYXNzTmFtZSIsInRvVVNEIiwiRnJhZ21lbnQiLCJyZW50IiwiZXhwb3J0cyJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy91bml0L3NlY3Rpb24vVW5pdFByaWNlLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQge2RhdGVUb01vbWVudCwgdG9VU0R9IGZyb20gXCIuLi8uLi91dGlscy9VdGlsc1wiO1xuaW1wb3J0IG1vbWVudCBmcm9tIFwibW9tZW50L21vbWVudFwiO1xuaW1wb3J0IFwiLi4vLi4vZmxvb3JwbGFuL2NhcmQvYXNzZXRzL0Zsb29ycGxhblByaWNlLnNjc3NcIjtcbmltcG9ydCB7VW5pdEZsb29ycGxhbn0gZnJvbSBcIi4uL2RhdGEvVW5pdFwiO1xuXG5leHBvcnQgY29uc3QgVW5pdFByaWNlOiBSZWFjdC5GQzxVbml0UHJpY2VQcm9wcz4gPSAoXG4gICAge1xuICAgICAgICB1bml0LFxuICAgICAgICBpbnZlcnRDb2xvclxuICAgIH0pID0+IHtcblxuICAgIGNvbnN0IGhhc1NwZWNpYWxSZW50ID0gKCkgPT4ge1xuICAgICAgICBjb25zdCBjdXJyZW50RGF0ZSA9IG1vbWVudCgpO1xuXG4gICAgICAgIGlmICh1bml0LmRpc2NvdW50ZWRSZW50ICYmIHVuaXQuZGlzY291bnRlZFJlbnRTdGFydERhdGUgJiYgdW5pdC5kaXNjb3VudGVkUmVudEVuZERhdGUpIHtcbiAgICAgICAgICAgIGNvbnN0IHN0YXJ0RGF0ZSA9IGRhdGVUb01vbWVudCh1bml0LmRpc2NvdW50ZWRSZW50U3RhcnREYXRlKTtcbiAgICAgICAgICAgIGNvbnN0IGVuZERhdGUgPSBkYXRlVG9Nb21lbnQodW5pdC5kaXNjb3VudGVkUmVudEVuZERhdGUpO1xuXG4gICAgICAgICAgICByZXR1cm4gY3VycmVudERhdGUuaXNCZXR3ZWVuKHN0YXJ0RGF0ZSwgZW5kRGF0ZSk7XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cblxuICAgIGNvbnN0IGdldFJlbnRDbGFzcyA9ICgpID0+IGhhc1NwZWNpYWxSZW50KCkgPyBcInN0cmlrZS10aHJvdWdoXCIgOiBcIlwiO1xuXG5cbiAgICBjb25zdCBwcmljZUZvclNwZWNpYWxSZW50ID0gKCkgPT4gaGFzU3BlY2lhbFJlbnQoKSA/IDxzcGFuXG4gICAgICAgIGNsYXNzTmFtZT1cInNwZWNpYWxcIj5Ob3cgc3RhcnRpbmcgYXQge3RvVVNEKHVuaXQuZGlzY291bnRlZFJlbnQhISl9L21vPC9zcGFuPiA6IDw+PC8+XG4gICAgcmV0dXJuIChcbiAgICAgICAgPHNwYW4gY2xhc3NOYW1lPXtpbnZlcnRDb2xvciA/IFwiZmxvb3JwbGFuLXByaWNlIGZsb29ycGxhbi1wcmljZS1pbnZlcnRlZFwiIDogXCJmbG9vcnBsYW4tcHJpY2VcIn0+XG4gICAgICAgICAgICAgICAgPHNwYW4gY2xhc3NOYW1lPXtnZXRSZW50Q2xhc3MoKX0+PHNwYW4gY2xhc3NOYW1lPVwicmVudFwiPnt0b1VTRCh1bml0LnJlbnQpfTwvc3Bhbj48L3NwYW4+XG4gICAgICAgICAgICA8c3BhbiBjbGFzc05hbWU9XCJmbG9vcnBsYW4tc3BlY2lhbC1wcmljZVwiPntwcmljZUZvclNwZWNpYWxSZW50KCl9PC9zcGFuPlxuICAgICAgICAgICAgPC9zcGFuPlxuXG4gICAgKTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBVbml0UHJpY2VQcm9wcyB7XG4gICAgdW5pdDogVW5pdEZsb29ycGxhbjtcbiAgICBpbnZlcnRDb2xvcj86IGJvb2xlYW47XG59XG4iXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLElBQUFBLE1BQUEsR0FBQUMsc0JBQUEsQ0FBQUMsT0FBQTtBQUNBLElBQUFDLE1BQUEsR0FBQUQsT0FBQTtBQUNBLElBQUFFLE9BQUEsR0FBQUgsc0JBQUEsQ0FBQUMsT0FBQTtBQUNBQSxPQUFBO0FBQXlELFNBQUFELHVCQUFBSSxHQUFBLFdBQUFBLEdBQUEsSUFBQUEsR0FBQSxDQUFBQyxVQUFBLEdBQUFELEdBQUEsS0FBQUUsT0FBQSxFQUFBRixHQUFBO0FBR2xELE1BQU1HLFNBQW1DLEdBQUdDLElBQUEsSUFJekM7RUFBQSxJQUhOO0lBQ0lDLElBQUk7SUFDSkM7RUFDSixDQUFDLEdBQUFGLElBQUE7RUFFRCxNQUFNRyxjQUFjLEdBQUdBLENBQUEsS0FBTTtJQUN6QixNQUFNQyxXQUFXLEdBQUcsSUFBQUMsZUFBTSxFQUFDLENBQUM7SUFFNUIsSUFBSUosSUFBSSxDQUFDSyxjQUFjLElBQUlMLElBQUksQ0FBQ00sdUJBQXVCLElBQUlOLElBQUksQ0FBQ08scUJBQXFCLEVBQUU7TUFDbkYsTUFBTUMsU0FBUyxHQUFHLElBQUFDLG1CQUFZLEVBQUNULElBQUksQ0FBQ00sdUJBQXVCLENBQUM7TUFDNUQsTUFBTUksT0FBTyxHQUFHLElBQUFELG1CQUFZLEVBQUNULElBQUksQ0FBQ08scUJBQXFCLENBQUM7TUFFeEQsT0FBT0osV0FBVyxDQUFDUSxTQUFTLENBQUNILFNBQVMsRUFBRUUsT0FBTyxDQUFDO0lBQ3BEO0lBQ0EsT0FBTyxLQUFLO0VBQ2hCLENBQUM7RUFFRCxNQUFNRSxZQUFZLEdBQUdBLENBQUEsS0FBTVYsY0FBYyxDQUFDLENBQUMsR0FBRyxnQkFBZ0IsR0FBRyxFQUFFO0VBR25FLE1BQU1XLG1CQUFtQixHQUFHQSxDQUFBLEtBQU1YLGNBQWMsQ0FBQyxDQUFDLGdCQUFHWixNQUFBLENBQUFPLE9BQUEsQ0FBQWlCLGFBQUE7SUFDakRDLFNBQVMsRUFBQztFQUFTLEdBQUMsa0JBQWdCLEVBQUMsSUFBQUMsWUFBSyxFQUFDaEIsSUFBSSxDQUFDSyxjQUFnQixDQUFDLEVBQUMsS0FBUyxDQUFDLGdCQUFHZixNQUFBLENBQUFPLE9BQUEsQ0FBQWlCLGFBQUEsQ0FBQXhCLE1BQUEsQ0FBQU8sT0FBQSxDQUFBb0IsUUFBQSxNQUFJLENBQUM7RUFDeEYsb0JBQ0kzQixNQUFBLENBQUFPLE9BQUEsQ0FBQWlCLGFBQUE7SUFBTUMsU0FBUyxFQUFFZCxXQUFXLEdBQUcsMENBQTBDLEdBQUc7RUFBa0IsZ0JBQ3RGWCxNQUFBLENBQUFPLE9BQUEsQ0FBQWlCLGFBQUE7SUFBTUMsU0FBUyxFQUFFSCxZQUFZLENBQUM7RUFBRSxnQkFBQ3RCLE1BQUEsQ0FBQU8sT0FBQSxDQUFBaUIsYUFBQTtJQUFNQyxTQUFTLEVBQUM7RUFBTSxHQUFFLElBQUFDLFlBQUssRUFBQ2hCLElBQUksQ0FBQ2tCLElBQUksQ0FBUSxDQUFPLENBQUMsZUFDNUY1QixNQUFBLENBQUFPLE9BQUEsQ0FBQWlCLGFBQUE7SUFBTUMsU0FBUyxFQUFDO0VBQXlCLEdBQUVGLG1CQUFtQixDQUFDLENBQVEsQ0FDakUsQ0FBQztBQUduQixDQUFDO0FBQUFNLE9BQUEsQ0FBQXJCLFNBQUEsR0FBQUEsU0FBQSJ9
@@ -0,0 +1,11 @@
1
+ import React from "react";
2
+ import "./assets/UnitSection.scss";
3
+ export declare const UnitSection: React.FC<UnitSectionProps>;
4
+ export interface UnitSectionProps {
5
+ contactClickHandler: () => void;
6
+ applyClickHandler: () => void;
7
+ unitId: string;
8
+ locationRef?: React.Ref<HTMLDivElement>;
9
+ handleRefToLocation?: () => void;
10
+ handleHtmlTitleUpdate?: (title: string) => void;
11
+ }