@renaissancerentals/renaissance-component 10.0.26 → 10.0.29

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.
Files changed (38) hide show
  1. package/lib/asset/service/AssetService.js +3 -3
  2. package/lib/floorplan/card/FloorplanCard.js +7 -7
  3. package/lib/floorplan/card/FloorplanCardSlider.js +13 -73
  4. package/lib/floorplan/card/FloorplanSliderCard.d.ts +8 -0
  5. package/lib/floorplan/card/FloorplanSliderCard.js +50 -0
  6. package/lib/floorplan/card/SimilarFloorplanCard.js +24 -42
  7. package/lib/floorplan/card/TestimonialsCard.js +8 -44
  8. package/lib/floorplan/card/assets/SimilarFloorplanCard.scss +47 -37
  9. package/lib/floorplan/card/assets/TestimonialsCard.scss +3 -23
  10. package/lib/floorplan/card/assets/camera-icon.png +0 -0
  11. package/lib/floorplan/data/Floorplan.d.ts +3 -1
  12. package/lib/floorplan/data/Floorplan.js +1 -1
  13. package/lib/floorplan/section/FloorplanHero.d.ts +1 -0
  14. package/lib/floorplan/section/FloorplanHero.js +151 -16
  15. package/lib/floorplan/section/FloorplanSection.d.ts +0 -1
  16. package/lib/floorplan/section/FloorplanSection.js +75 -31
  17. package/lib/floorplan/section/HeroBadgeStats.d.ts +10 -0
  18. package/lib/floorplan/section/HeroBadgeStats.js +86 -0
  19. package/lib/floorplan/section/assets/BadgeStats.scss +5 -0
  20. package/lib/floorplan/section/assets/FloorplanHero.scss +90 -1
  21. package/lib/floorplan/section/assets/FloorplanSection.scss +0 -3
  22. package/lib/floorplan/section/assets/HeroBadgeStats.scss +74 -0
  23. package/lib/gallery/GalleryHeroMain.d.ts +13 -0
  24. package/lib/gallery/GalleryHeroMain.js +101 -0
  25. package/lib/gallery/GalleryHeroMobile.d.ts +11 -0
  26. package/lib/gallery/GalleryHeroMobile.js +101 -0
  27. package/lib/gallery/HeroImageCard.d.ts +8 -0
  28. package/lib/gallery/HeroImageCard.js +34 -0
  29. package/lib/gallery/assets/GalleryHero.scss +46 -153
  30. package/lib/gallery/assets/HeroImageCard.scss +29 -0
  31. package/lib/index.d.ts +1 -1
  32. package/lib/index.js +4 -4
  33. package/lib/property/assets/PropertyLocation.scss +1 -0
  34. package/lib/utils/Utils.d.ts +1 -1
  35. package/lib/utils/Utils.js +7 -5
  36. package/package.json +2 -2
  37. package/lib/gallery/GalleryHero.d.ts +0 -10
  38. package/lib/gallery/GalleryHero.js +0 -278
@@ -31,6 +31,10 @@ var _SimilarFloorplanCard = require("../card/SimilarFloorplanCard");
31
31
 
32
32
  var _muncherUi = require("@contentmunch/muncher-ui");
33
33
 
34
+ var _moment = _interopRequireDefault(require("moment"));
35
+
36
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
37
+
34
38
  function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
35
39
 
36
40
  function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
@@ -54,12 +58,11 @@ function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Sy
54
58
  function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
55
59
 
56
60
  var FloorplanSection = function FloorplanSection(_ref) {
57
- var _floorplan$units$, _floorplan$units$2;
61
+ var _floorplan$units$, _floorplan$units$2, _floorplan$property;
58
62
 
59
63
  var contactClickHandler = _ref.contactClickHandler,
60
64
  applyClickHandler = _ref.applyClickHandler,
61
- floorplanId = _ref.floorplanId,
62
- contactPhone = _ref.contactPhone;
65
+ floorplanId = _ref.floorplanId;
63
66
 
64
67
  var _useState = (0, _react.useState)({}),
65
68
  _useState2 = _slicedToArray(_useState, 2),
@@ -91,6 +94,17 @@ var FloorplanSection = function FloorplanSection(_ref) {
91
94
  errorLoading = _useState12[0],
92
95
  setErrorLoading = _useState12[1];
93
96
 
97
+ var mapRef = (0, _react.useRef)(null);
98
+
99
+ var handleRefToMap = function handleRefToMap() {
100
+ var _mapRef$current;
101
+
102
+ (_mapRef$current = mapRef.current) === null || _mapRef$current === void 0 ? void 0 : _mapRef$current.scrollIntoView({
103
+ behavior: "smooth",
104
+ block: "center"
105
+ });
106
+ };
107
+
94
108
  (0, _react.useEffect)(function () {
95
109
  Promise.all([(0, _FloorplanService.getFloorplan)(floorplanId), (0, _FloorplanService.getFloorplanVariations)(floorplanId), (0, _FloorplanService.getSimilarFloorplans)(floorplanId), (0, _FloorplanService.getTestimonials)(floorplanId)]).then(function (data) {
96
110
  var floorplanData = _objectSpread({}, data[0]);
@@ -109,6 +123,19 @@ var FloorplanSection = function FloorplanSection(_ref) {
109
123
  setIsLoading(false);
110
124
  });
111
125
  }, [floorplanId]);
126
+
127
+ var availableDates = function availableDates() {
128
+ var sortAvailabileDates = function sortAvailabileDates(a, b) {
129
+ return (0, _moment.default)(a, "MMMM YYYY").diff((0, _moment.default)(b, "MMMM YYYY"));
130
+ };
131
+
132
+ var dates = new Set();
133
+ floorplan.units.forEach(function (unit) {
134
+ dates.add((0, _Utils.dateToMoment)(unit.moveInDate).format("MMMM YYYY"));
135
+ });
136
+ return Array.from(dates).sort(sortAvailabileDates);
137
+ };
138
+
112
139
  return /*#__PURE__*/_react.default.createElement("section", {
113
140
  className: "section-floorplan"
114
141
  }, isLoading ? /*#__PURE__*/_react.default.createElement("section", {
@@ -118,7 +145,8 @@ var FloorplanSection = function FloorplanSection(_ref) {
118
145
  }, /*#__PURE__*/_react.default.createElement("h2", null, "Uh-oh, this is a 404")) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_FloorplanHero.FloorplanHero, {
119
146
  floorplan: floorplan,
120
147
  contactClickHandler: contactClickHandler,
121
- applyClickHandler: applyClickHandler
148
+ applyClickHandler: applyClickHandler,
149
+ handleRefToMap: handleRefToMap
122
150
  }), /*#__PURE__*/_react.default.createElement("div", {
123
151
  className: "container"
124
152
  }, /*#__PURE__*/_react.default.createElement("div", {
@@ -129,56 +157,72 @@ var FloorplanSection = function FloorplanSection(_ref) {
129
157
  className: "floorplan-card--featured"
130
158
  }, floorplan.bedroom, " Bedroom | ", floorplan.bathroom, " Bathroom ", (0, _Utils.enumToString)(floorplan.style)), /*#__PURE__*/_react.default.createElement("p", {
131
159
  className: "floorplan-card--featured"
132
- }, "$", (0, _Utils.rangeFrom)(floorplan.units, "squareFoot"), " Square Feet"), /*#__PURE__*/_react.default.createElement("p", {
160
+ }, (0, _Utils.rangeFrom)(floorplan.units, "squareFoot"), " Square Feet"), /*#__PURE__*/_react.default.createElement("p", {
133
161
  className: "floorplan-card--featured"
134
162
  }, "$", (0, _Utils.rangeFrom)(floorplan.units, "rent"), "/mo"), /*#__PURE__*/_react.default.createElement("p", {
135
163
  className: "floorplan-card--featured"
136
164
  }, "$", (0, _Utils.rangeFrom)(floorplan.units, "deposit"), " Security Deposit"), /*#__PURE__*/_react.default.createElement("p", null, floorplan.description)), floorplan.amenities.length > 0 ? /*#__PURE__*/_react.default.createElement(_Card.Card, {
137
165
  title: "Amenities"
138
- }, floorplan.amenities.filter(function (amenity) {
166
+ }, /*#__PURE__*/_react.default.createElement(_muncherUi.Ul, null, floorplan.amenities.filter(function (amenity) {
139
167
  return amenity.featured;
140
168
  }).map(function (amenity) {
141
- return /*#__PURE__*/_react.default.createElement("p", {
142
- className: "floorplan-card--featured",
143
- key: "floorplan-amenity-featured-" + amenity.id
169
+ return /*#__PURE__*/_react.default.createElement(_muncherUi.Li, {
170
+ key: "floorplan-amenity-" + amenity.id,
171
+ isFeatured: true
144
172
  }, amenity.name);
145
- }), /*#__PURE__*/_react.default.createElement("ul", null, floorplan.amenities.filter(function (amenity) {
173
+ }), floorplan.amenities.filter(function (amenity) {
146
174
  return !amenity.featured;
147
175
  }).map(function (amenity) {
148
- return /*#__PURE__*/_react.default.createElement("li", {
176
+ return /*#__PURE__*/_react.default.createElement(_muncherUi.Li, {
149
177
  key: "floorplan-amenity-" + amenity.id
150
178
  }, amenity.name);
151
- })), floorplanVariations.length > 0 ? /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("h5", null, "Variations"), /*#__PURE__*/_react.default.createElement("ul", null, floorplanVariations.map(function (variation, i) {
152
- return /*#__PURE__*/_react.default.createElement("li", {
179
+ })), floorplanVariations.length > 0 ? /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("h5", null, "Variations"), /*#__PURE__*/_react.default.createElement(_muncherUi.Ul, null, floorplanVariations.map(function (variation, i) {
180
+ return /*#__PURE__*/_react.default.createElement(_muncherUi.Li, {
153
181
  key: "floorplan-variation-" + i
154
182
  }, variation.variation);
155
183
  }))) : "") : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null), testimonials.length > 0 ? /*#__PURE__*/_react.default.createElement(_TestimonialsCard.TestimonialsCard, {
156
184
  testimonials: testimonials
157
- }) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null), /*#__PURE__*/_react.default.createElement(_Card.Card, null, /*#__PURE__*/_react.default.createElement(_MapSection.MapSection, {
185
+ }) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null), /*#__PURE__*/_react.default.createElement(_Card.Card, null, /*#__PURE__*/_react.default.createElement("div", {
186
+ ref: mapRef,
187
+ id: "location"
188
+ }, /*#__PURE__*/_react.default.createElement(_MapSection.MapSection, {
158
189
  src: (0, _Utils.addressToGoogleMap)((_floorplan$units$ = floorplan.units[0]) === null || _floorplan$units$ === void 0 ? void 0 : _floorplan$units$.address, (_floorplan$units$2 = floorplan.units[0]) === null || _floorplan$units$2 === void 0 ? void 0 : _floorplan$units$2.zipcode)
159
- })), /*#__PURE__*/_react.default.createElement(_Card.Card, {
190
+ }))), /*#__PURE__*/_react.default.createElement(_Card.Card, {
160
191
  title: "Pets"
161
- }, /*#__PURE__*/_react.default.createElement("h5", null, "Permitted"), /*#__PURE__*/_react.default.createElement("ul", null, (0, _FloorplanService.permittedPets)(floorplan).map(function (pet, i) {
162
- return /*#__PURE__*/_react.default.createElement("li", {
163
- key: "floorplan-permitted-pet-" + i
192
+ }, /*#__PURE__*/_react.default.createElement("h5", null, "Permitted"), /*#__PURE__*/_react.default.createElement(_muncherUi.Ul, null, (0, _FloorplanService.permittedPets)(floorplan).map(function (pet, i) {
193
+ return /*#__PURE__*/_react.default.createElement(_muncherUi.Li, {
194
+ key: "floorplan-permitted-pet-" + i,
195
+ bulletIcon: "check",
196
+ bulletColor: "green"
164
197
  }, pet);
165
- })), (0, _FloorplanService.notPermittedPets)(floorplan).length > 0 ? /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("h5", null, "Not Permitted"), /*#__PURE__*/_react.default.createElement("ul", null, (0, _FloorplanService.notPermittedPets)(floorplan).map(function (pet, i) {
166
- return /*#__PURE__*/_react.default.createElement("li", {
167
- key: "floorplan-not-permitted-pet-" + i
198
+ })), (0, _FloorplanService.notPermittedPets)(floorplan).length > 0 ? /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("h5", null, "Not Permitted"), /*#__PURE__*/_react.default.createElement(_muncherUi.Ul, null, (0, _FloorplanService.notPermittedPets)(floorplan).map(function (pet, i) {
199
+ return /*#__PURE__*/_react.default.createElement(_muncherUi.Li, {
200
+ key: "floorplan-not-permitted-pet-" + i,
201
+ bulletColor: "brown",
202
+ bulletIcon: "close"
168
203
  }, pet);
169
204
  }))) : "", (0, _FloorplanService.petPolicy)(floorplan) ? /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("h5", null, "Additional Information"), /*#__PURE__*/_react.default.createElement("p", null, (0, _FloorplanService.petPolicy)(floorplan))) : ""), /*#__PURE__*/_react.default.createElement(_Card.Card, {
205
+ title: "Availability"
206
+ }, /*#__PURE__*/_react.default.createElement(_muncherUi.Ul, null, availableDates().map(function (availableDate) {
207
+ return /*#__PURE__*/_react.default.createElement(_muncherUi.Li, {
208
+ key: "floorplan-unit-availability-" + availableDate,
209
+ bulletIcon: "calendar"
210
+ }, "Available in ", /*#__PURE__*/_react.default.createElement("strong", null, (0, _Utils.capitalizeFirstLetter)(availableDate)));
211
+ }))), /*#__PURE__*/_react.default.createElement(_Card.Card, {
170
212
  title: "Utilities"
171
- }, /*#__PURE__*/_react.default.createElement("h5", null, "Paid By Landlord"), /*#__PURE__*/_react.default.createElement("ul", null, floorplan.utilities.filter(function (utility) {
213
+ }, /*#__PURE__*/_react.default.createElement("h5", null, "Paid By Landlord"), /*#__PURE__*/_react.default.createElement(_muncherUi.Ul, null, floorplan.utilities.filter(function (utility) {
172
214
  return utility.type === _Floorplan.UtilityType.INCLUDED_UTILITY;
173
215
  }).map(function (utility) {
174
- return /*#__PURE__*/_react.default.createElement("li", {
175
- key: "floorplan-included-utility-" + utility.id
216
+ return /*#__PURE__*/_react.default.createElement(_muncherUi.Li, {
217
+ key: "floorplan-included-utility-" + utility.id,
218
+ bulletIcon: "home"
176
219
  }, (0, _Utils.capitalizeFirstLetter)(utility.name));
177
- })), /*#__PURE__*/_react.default.createElement("h5", null, "Paid By Tenant"), /*#__PURE__*/_react.default.createElement("ul", null, floorplan.utilities.filter(function (utility) {
220
+ })), /*#__PURE__*/_react.default.createElement("h5", null, "Paid By Tenant"), /*#__PURE__*/_react.default.createElement(_muncherUi.Ul, null, floorplan.utilities.filter(function (utility) {
178
221
  return utility.type === _Floorplan.UtilityType.RESIDENT_UTILITY;
179
222
  }).map(function (utility) {
180
- return /*#__PURE__*/_react.default.createElement("li", {
181
- key: "floorplan-resident-utility-" + utility.id
223
+ return /*#__PURE__*/_react.default.createElement(_muncherUi.Li, {
224
+ key: "floorplan-resident-utility-" + utility.id,
225
+ bulletIcon: "dollar"
182
226
  }, (0, _Utils.capitalizeFirstLetter)(utility.name));
183
227
  }))), similarFloorplans.length > 0 ? /*#__PURE__*/_react.default.createElement(_SimilarFloorplanCard.SimilarFloorplanCard, {
184
228
  similarFloorplans: similarFloorplans
@@ -186,9 +230,9 @@ var FloorplanSection = function FloorplanSection(_ref) {
186
230
  className: "contact-card"
187
231
  }, /*#__PURE__*/_react.default.createElement(_Card.Card, {
188
232
  featured: true
189
- }, /*#__PURE__*/_react.default.createElement("p", null, /*#__PURE__*/_react.default.createElement("i", null, "Questions?")), /*#__PURE__*/_react.default.createElement("p", null, /*#__PURE__*/_react.default.createElement("i", null, "Call or text us anytime:")), /*#__PURE__*/_react.default.createElement("p", null, /*#__PURE__*/_react.default.createElement("a", {
190
- href: "tel:" + contactPhone
191
- }, (0, _Utils.formatPhoneNumber)(contactPhone))), /*#__PURE__*/_react.default.createElement(_muncherUi.Button, {
233
+ }, /*#__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", {
234
+ href: "tel:" + floorplan.property.phone
235
+ }, (0, _Utils.formatPhoneNumber)(floorplan.property.phone))) : "", /*#__PURE__*/_react.default.createElement(_muncherUi.Button, {
192
236
  variant: "tertiary",
193
237
  onClick: contactClickHandler,
194
238
  size: "large"
@@ -196,4 +240,4 @@ var FloorplanSection = function FloorplanSection(_ref) {
196
240
  };
197
241
 
198
242
  exports.FloorplanSection = FloorplanSection;
199
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["FloorplanSection","contactClickHandler","applyClickHandler","floorplanId","contactPhone","useState","floorplan","setFloorplan","similarFloorplans","setSimilarFloorplans","floorplanVariations","setFloorplanVariations","testimonials","setTestimonials","isLoading","setIsLoading","errorLoading","setErrorLoading","useEffect","Promise","all","getFloorplan","getFloorplanVariations","getSimilarFloorplans","getTestimonials","then","data","floorplanData","activeUnits","units","filter","unit","active","catch","finally","bedroom","bathroom","enumToString","style","rangeFrom","description","amenities","length","amenity","featured","map","id","name","variation","i","addressToGoogleMap","address","zipcode","permittedPets","pet","notPermittedPets","petPolicy","utilities","utility","type","UtilityType","INCLUDED_UTILITY","capitalizeFirstLetter","RESIDENT_UTILITY","formatPhoneNumber"],"sources":["../../../src/floorplan/section/FloorplanSection.tsx"],"sourcesContent":["import React, {useEffect, useState} from \"react\";\nimport {Floorplan, FloorplanVariation, SimilarFloorplan, Testimonial, UtilityType} from \"../data/Floorplan\";\nimport {\n    getFloorplan,\n    getFloorplanVariations,\n    getSimilarFloorplans,\n    getTestimonials,\n    notPermittedPets,\n    permittedPets,\n    petPolicy\n} from \"../service/FloorplanService\";\nimport \"./assets/FloorplanSection.scss\";\nimport {GalleryHeroSkeleton} from \"../../gallery/GalleryHeroSkeleton\";\nimport {FloorplanHero} from \"./FloorplanHero\";\nimport {addressToGoogleMap, capitalizeFirstLetter, enumToString, formatPhoneNumber, rangeFrom} from \"../../utils/Utils\";\nimport {Card} from \"../../card/Card\";\nimport {TestimonialsCard} from \"../card/TestimonialsCard\";\nimport {MapSection} from \"../../map/MapSection\";\nimport {SimilarFloorplanCard} from \"../card/SimilarFloorplanCard\";\nimport {Button} from \"@contentmunch/muncher-ui\";\n\nexport const FloorplanSection: React.FC<FloorplanSectionProps> = (\n    {\n        contactClickHandler,\n        applyClickHandler,\n        floorplanId,\n        contactPhone\n    }) => {\n    const [floorplan, setFloorplan] = useState<Floorplan>({} as Floorplan);\n    const [similarFloorplans, setSimilarFloorplans] = useState<SimilarFloorplan[]>([]);\n    const [floorplanVariations, setFloorplanVariations] = useState<FloorplanVariation[]>([]);\n    const [testimonials, setTestimonials] = useState<Testimonial[]>([]);\n    const [isLoading, setIsLoading] = useState(true);\n    const [errorLoading, setErrorLoading] = useState(false);\n    useEffect(() => {\n        Promise.all([\n            getFloorplan(floorplanId),\n            getFloorplanVariations(floorplanId),\n            getSimilarFloorplans(floorplanId),\n            getTestimonials(floorplanId)\n        ])\n            .then((data) => {\n                const floorplanData = {...data[0]};\n                const activeUnits = floorplanData.units.filter(unit => unit.active);\n                floorplanData.units = activeUnits;\n                setFloorplan(floorplanData);\n                setFloorplanVariations(data[1]);\n                setSimilarFloorplans(data[2]);\n                setTestimonials(data[3]);\n            })\n            .catch(() => {\n                setErrorLoading(true);\n            })\n            .finally(() => {\n                setIsLoading(false);\n            });\n\n    }, [floorplanId]);\n    return (\n        <section className=\"section-floorplan\">\n            {\n                isLoading ? <section className=\"section-floorplan--hero\"><GalleryHeroSkeleton/></section> : <>\n                    {errorLoading ?\n                        <section className=\"div-full--center\">\n                            <h2>Uh-oh, this is a 404</h2>\n                        </section> :\n                        <>\n                            <FloorplanHero floorplan={floorplan} contactClickHandler={contactClickHandler}\n                                           applyClickHandler={applyClickHandler}/>\n                            <div className=\"container\">\n                                <div className=\"floorplan--cards\">\n                                    <Card title=\"Details\">\n                                        <p className=\"floorplan-card--featured\">\n                                            {floorplan.bedroom} Bedroom\n                                            | {floorplan.bathroom} Bathroom {enumToString(floorplan.style)}\n                                        </p>\n                                        <p className=\"floorplan-card--featured\">\n                                            ${rangeFrom(floorplan.units, \"squareFoot\")} Square Feet\n                                        </p>\n                                        <p className=\"floorplan-card--featured\">\n                                            ${rangeFrom(floorplan.units, \"rent\")}/mo\n                                        </p>\n                                        <p className=\"floorplan-card--featured\">\n                                            ${rangeFrom(floorplan.units, \"deposit\")} Security Deposit</p>\n                                        <p>\n                                            {floorplan.description}\n                                        </p>\n                                    </Card>\n                                    {\n                                        floorplan.amenities.length > 0 ?\n                                            <Card title=\"Amenities\">\n                                                {\n                                                    floorplan.amenities.filter(amenity => amenity.featured).map(amenity =>\n                                                        <p className=\"floorplan-card--featured\"\n                                                           key={\"floorplan-amenity-featured-\" + amenity.id}>\n                                                            {amenity.name}\n                                                        </p>\n                                                    )}\n                                                <ul>\n                                                    {\n                                                        floorplan.amenities.filter(amenity => !amenity.featured).map(amenity =>\n                                                            <li key={\"floorplan-amenity-\" + amenity.id}>\n                                                                {amenity.name}\n                                                            </li>\n                                                        )\n                                                    }\n                                                </ul>\n                                                {\n                                                    floorplanVariations.length > 0 ?\n                                                        <>\n                                                            <h5>Variations</h5>\n                                                            <ul>\n                                                                {\n                                                                    floorplanVariations.map((variation, i) =>\n                                                                        <li key={\"floorplan-variation-\" + i}>\n                                                                            {variation.variation}\n                                                                        </li>\n                                                                    )\n                                                                }\n                                                            </ul>\n\n                                                        </> : \"\"}\n\n                                            </Card> : <></>\n                                    }\n\n                                    {\n                                        testimonials.length > 0 ?\n                                            <TestimonialsCard testimonials={testimonials}/> : <></>\n                                    }\n                                    <Card>\n                                        <MapSection\n                                            src={addressToGoogleMap(floorplan.units[0]?.address, floorplan.units[0]?.zipcode)}/>\n                                    </Card>\n\n                                    <Card title=\"Pets\">\n                                        <h5>Permitted</h5>\n                                        <ul>\n                                            {\n                                                permittedPets(floorplan).map((pet, i) =>\n                                                    <li key={\"floorplan-permitted-pet-\" + i}>\n                                                        {pet}\n                                                    </li>\n                                                )\n                                            }\n                                        </ul>\n                                        {notPermittedPets(floorplan).length > 0 ?\n                                            <><h5>Not Permitted</h5>\n                                                <ul>\n                                                    {\n                                                        notPermittedPets(floorplan).map((pet, i) =>\n                                                            <li key={\"floorplan-not-permitted-pet-\" + i}>\n                                                                {pet}\n                                                            </li>\n                                                        )\n                                                    }\n                                                </ul>\n                                            </> : \"\"}\n\n                                        {\n                                            petPolicy(floorplan) ?\n                                                <>\n                                                    <h5>Additional Information</h5>\n                                                    <p>{petPolicy(floorplan)}</p>\n                                                </> : \"\"\n\n                                        }\n\n                                    </Card>\n\n\n                                    <Card title=\"Utilities\">\n                                        <h5>Paid By Landlord</h5>\n                                        <ul>\n                                            {\n                                                floorplan.utilities.filter(utility => utility.type === UtilityType.INCLUDED_UTILITY).map(utility =>\n                                                    <li key={\"floorplan-included-utility-\" + utility.id}>\n                                                        {capitalizeFirstLetter(utility.name)}\n                                                    </li>\n                                                )\n                                            }\n                                        </ul>\n                                        <h5>Paid By Tenant</h5>\n                                        <ul>\n                                            {\n                                                floorplan.utilities.filter(utility => utility.type === UtilityType.RESIDENT_UTILITY).map(utility =>\n                                                    <li key={\"floorplan-resident-utility-\" + utility.id}>\n                                                        {capitalizeFirstLetter(utility.name)}\n                                                    </li>\n                                                )\n                                            }\n                                        </ul>\n\n                                    </Card>\n                                    {similarFloorplans.length > 0 ?\n                                        <SimilarFloorplanCard similarFloorplans={similarFloorplans}/> : \"\"}\n\n                                    <div className=\"contact-card\">\n                                        <Card featured={true}>\n                                            <p><i>Questions?</i></p>\n                                            <p><i>Call or text us anytime:</i></p>\n                                            <p><a\n                                                href={\"tel:\" + contactPhone}>{formatPhoneNumber(contactPhone)}</a>\n                                            </p>\n                                            <Button variant=\"tertiary\" onClick={contactClickHandler} size=\"large\">Contact\n                                                Us\n                                                »</Button>\n                                        </Card>\n                                    </div>\n                                </div>\n                            </div>\n                        </>\n                    }\n\n                </>\n            }\n\n        </section>\n    );\n};\n\nexport interface FloorplanSectionProps {\n    contactClickHandler: () => void;\n    applyClickHandler: () => void;\n    floorplanId: string;\n    contactPhone?: string;\n}\n"],"mappings":"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"}
243
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["FloorplanSection","contactClickHandler","applyClickHandler","floorplanId","useState","floorplan","setFloorplan","similarFloorplans","setSimilarFloorplans","floorplanVariations","setFloorplanVariations","testimonials","setTestimonials","isLoading","setIsLoading","errorLoading","setErrorLoading","mapRef","useRef","handleRefToMap","current","scrollIntoView","behavior","block","useEffect","Promise","all","getFloorplan","getFloorplanVariations","getSimilarFloorplans","getTestimonials","then","data","floorplanData","activeUnits","units","filter","unit","active","catch","finally","availableDates","sortAvailabileDates","a","b","moment","diff","dates","Set","forEach","add","dateToMoment","moveInDate","format","Array","from","sort","bedroom","bathroom","enumToString","style","rangeFrom","description","amenities","length","amenity","featured","map","id","name","variation","i","addressToGoogleMap","address","zipcode","permittedPets","pet","notPermittedPets","petPolicy","availableDate","capitalizeFirstLetter","utilities","utility","type","UtilityType","INCLUDED_UTILITY","RESIDENT_UTILITY","property","phone","formatPhoneNumber"],"sources":["../../../src/floorplan/section/FloorplanSection.tsx"],"sourcesContent":["import React, {useEffect, useRef, useState} from \"react\";\nimport {Floorplan, FloorplanVariation, SimilarFloorplan, Testimonial, UtilityType} from \"../data/Floorplan\";\nimport {\n    getFloorplan,\n    getFloorplanVariations,\n    getSimilarFloorplans,\n    getTestimonials,\n    notPermittedPets,\n    permittedPets,\n    petPolicy\n} from \"../service/FloorplanService\";\nimport \"./assets/FloorplanSection.scss\";\nimport {GalleryHeroSkeleton} from \"../../gallery/GalleryHeroSkeleton\";\nimport {FloorplanHero} from \"./FloorplanHero\";\nimport {\n    addressToGoogleMap,\n    capitalizeFirstLetter,\n    dateToMoment,\n    enumToString,\n    formatPhoneNumber,\n    rangeFrom\n} from \"../../utils/Utils\";\nimport {Card} from \"../../card/Card\";\nimport {TestimonialsCard} from \"../card/TestimonialsCard\";\nimport {MapSection} from \"../../map/MapSection\";\nimport {SimilarFloorplanCard} from \"../card/SimilarFloorplanCard\";\nimport {Button, Li, Ul} from \"@contentmunch/muncher-ui\";\nimport moment from \"moment\";\n\nexport const FloorplanSection: React.FC<FloorplanSectionProps> = (\n    {\n        contactClickHandler,\n        applyClickHandler,\n        floorplanId\n    }) => {\n    const [floorplan, setFloorplan] = useState<Floorplan>({} as Floorplan);\n    const [similarFloorplans, setSimilarFloorplans] = useState<SimilarFloorplan[]>([]);\n    const [floorplanVariations, setFloorplanVariations] = useState<FloorplanVariation[]>([]);\n    const [testimonials, setTestimonials] = useState<Testimonial[]>([]);\n    const [isLoading, setIsLoading] = useState(true);\n    const [errorLoading, setErrorLoading] = useState(false);\n\n    const mapRef = useRef<HTMLDivElement>(null);\n    const handleRefToMap = () => {\n        mapRef.current?.scrollIntoView({\n            behavior: \"smooth\",\n            block: \"center\"\n        });\n    };\n    useEffect(() => {\n        Promise.all([\n            getFloorplan(floorplanId),\n            getFloorplanVariations(floorplanId),\n            getSimilarFloorplans(floorplanId),\n            getTestimonials(floorplanId)\n        ])\n            .then((data) => {\n                const floorplanData = {...data[0]};\n                const activeUnits = floorplanData.units.filter(unit => unit.active);\n                floorplanData.units = activeUnits;\n                setFloorplan(floorplanData);\n                setFloorplanVariations(data[1]);\n                setSimilarFloorplans(data[2]);\n                setTestimonials(data[3]);\n            })\n            .catch(() => {\n                setErrorLoading(true);\n            })\n            .finally(() => {\n                setIsLoading(false);\n            });\n\n    }, [floorplanId]);\n\n    const availableDates = (): string[] => {\n        const sortAvailabileDates = (a: string, b: string) => moment(a, \"MMMM YYYY\").diff(moment(b, \"MMMM YYYY\"));\n        const dates = new Set<string>();\n        floorplan.units.forEach(unit => {\n            dates.add(dateToMoment(unit.moveInDate).format(\"MMMM YYYY\"));\n        });\n\n        return Array.from(dates).sort(sortAvailabileDates);\n    }\n    return (\n        <section className=\"section-floorplan\">\n            {\n                isLoading ? <section className=\"section-floorplan--hero\"><GalleryHeroSkeleton/></section> : <>\n                    {errorLoading ?\n                        <section className=\"div-full--center\">\n                            <h2>Uh-oh, this is a 404</h2>\n                        </section> :\n                        <>\n                            <FloorplanHero floorplan={floorplan} contactClickHandler={contactClickHandler}\n                                           applyClickHandler={applyClickHandler} 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                                            {rangeFrom(floorplan.units, \"squareFoot\")} Square Feet\n                                        </p>\n                                        <p className=\"floorplan-card--featured\">\n                                            ${rangeFrom(floorplan.units, \"rent\")}/mo\n                                        </p>\n                                        <p className=\"floorplan-card--featured\">\n                                            ${rangeFrom(floorplan.units, \"deposit\")} Security Deposit</p>\n                                        <p>\n                                            {floorplan.description}\n                                        </p>\n                                    </Card>\n                                    {\n                                        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                                                                isFeatured={true}>\n                                                                {amenity.name}\n                                                            </Li>\n                                                        )}\n                                                    {\n                                                        floorplan.amenities.filter(amenity => !amenity.featured).map(amenity =>\n                                                            <Li key={\"floorplan-amenity-\" + amenity.id}>\n                                                                {amenity.name}\n                                                            </Li>\n                                                        )\n                                                    }\n                                                </Ul>\n                                                {\n                                                    floorplanVariations.length > 0 ?\n                                                        <>\n                                                            <h5>Variations</h5>\n                                                            <Ul>\n                                                                {\n                                                                    floorplanVariations.map((variation, i) =>\n                                                                        <Li key={\"floorplan-variation-\" + i}>\n                                                                            {variation.variation}\n                                                                        </Li>\n                                                                    )\n                                                                }\n                                                            </Ul>\n\n                                                        </> : \"\"}\n\n                                            </Card> : <></>\n                                    }\n\n                                    {\n                                        testimonials.length > 0 ?\n                                            <TestimonialsCard testimonials={testimonials}/> : <></>\n                                    }\n                                    <Card>\n                                        <div ref={mapRef} id=\"location\">\n                                            <MapSection\n                                                src={addressToGoogleMap(floorplan.units[0]?.address, floorplan.units[0]?.zipcode)}/>\n                                        </div>\n                                    </Card>\n\n                                    <Card title=\"Pets\">\n                                        <h5>Permitted</h5>\n                                        <Ul>\n                                            {\n                                                permittedPets(floorplan).map((pet, i) =>\n                                                    <Li key={\"floorplan-permitted-pet-\" + i} bulletIcon=\"check\"\n                                                        bulletColor=\"green\">\n                                                        {pet}\n                                                    </Li>\n                                                )\n                                            }\n                                        </Ul>\n                                        {notPermittedPets(floorplan).length > 0 ?\n                                            <><h5>Not Permitted</h5>\n                                                <Ul>\n                                                    {\n                                                        notPermittedPets(floorplan).map((pet, i) =>\n                                                            <Li key={\"floorplan-not-permitted-pet-\" + i}\n                                                                bulletColor=\"brown\" bulletIcon=\"close\">\n                                                                {pet}\n                                                            </Li>\n                                                        )\n                                                    }\n                                                </Ul>\n                                            </> : \"\"}\n\n                                        {\n                                            petPolicy(floorplan) ?\n                                                <>\n                                                    <h5>Additional Information</h5>\n                                                    <p>{petPolicy(floorplan)}</p>\n                                                </> : \"\"\n\n                                        }\n\n                                    </Card>\n                                    <Card title=\"Availability\">\n                                        <Ul>\n                                            {\n                                                availableDates().map(availableDate =>\n                                                    <Li key={\"floorplan-unit-availability-\" + availableDate}\n                                                        bulletIcon=\"calendar\">\n                                                        Available\n                                                        in <strong>{capitalizeFirstLetter(availableDate)}</strong>\n                                                    </Li>\n                                                )\n                                            }\n                                        </Ul>\n\n                                    </Card>\n\n                                    <Card title=\"Utilities\">\n                                        <h5>Paid By Landlord</h5>\n                                        <Ul>\n                                            {\n                                                floorplan.utilities.filter(utility => utility.type === UtilityType.INCLUDED_UTILITY).map(utility =>\n                                                    <Li key={\"floorplan-included-utility-\" + utility.id}\n                                                        bulletIcon=\"home\">\n                                                        {capitalizeFirstLetter(utility.name)}\n                                                    </Li>\n                                                )\n                                            }\n                                        </Ul>\n                                        <h5>Paid By Tenant</h5>\n                                        <Ul>\n                                            {\n                                                floorplan.utilities.filter(utility => utility.type === UtilityType.RESIDENT_UTILITY).map(utility =>\n                                                    <Li key={\"floorplan-resident-utility-\" + utility.id}\n                                                        bulletIcon=\"dollar\">\n                                                        {capitalizeFirstLetter(utility.name)}\n                                                    </Li>\n                                                )\n                                            }\n                                        </Ul>\n\n                                    </Card>\n                                    {similarFloorplans.length > 0 ?\n                                        <SimilarFloorplanCard similarFloorplans={similarFloorplans}/> : \"\"}\n\n                                    <div className=\"contact-card\">\n                                        <Card featured={true}>\n                                            <p><i>Questions?</i></p>\n                                            <p><i>Call or text us anytime:</i></p>\n                                            {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}\n"],"mappings":"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"}
@@ -0,0 +1,10 @@
1
+ import React from "react";
2
+ import "./assets/HeroBadgeStats.scss";
3
+ export declare const HeroBadgeStats: React.FC<HeroBadgeStatsProps>;
4
+ export interface HeroBadgeStatsProps {
5
+ currentView: "photo" | "virtual tour" | "video tour";
6
+ setCurrentView: (currentView: "photo" | "virtual tour" | "video tour") => void;
7
+ totalAssets: number;
8
+ virtualTour?: string;
9
+ videoTours: string[];
10
+ }
@@ -0,0 +1,86 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.HeroBadgeStats = void 0;
7
+
8
+ var _react = _interopRequireDefault(require("react"));
9
+
10
+ var _muncherUi = require("@contentmunch/muncher-ui");
11
+
12
+ var _cameraIcon = _interopRequireDefault(require("../card/assets/camera-icon.png"));
13
+
14
+ var _icon = _interopRequireDefault(require("../card/assets/360-icon.png"));
15
+
16
+ var _videoIcon = _interopRequireDefault(require("../card/assets/video-icon.png"));
17
+
18
+ require("./assets/HeroBadgeStats.scss");
19
+
20
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
21
+
22
+ var HeroBadgeStats = function HeroBadgeStats(_ref) {
23
+ var currentView = _ref.currentView,
24
+ setCurrentView = _ref.setCurrentView,
25
+ totalAssets = _ref.totalAssets,
26
+ virtualTour = _ref.virtualTour,
27
+ videoTours = _ref.videoTours;
28
+
29
+ var makePlural = function makePlural(length) {
30
+ return length > 1 ? "s" : "";
31
+ };
32
+
33
+ return /*#__PURE__*/_react.default.createElement("div", {
34
+ className: "hero-badge--stats"
35
+ }, /*#__PURE__*/_react.default.createElement(_muncherUi.Badge, {
36
+ variant: "tertiary"
37
+ }, /*#__PURE__*/_react.default.createElement("div", {
38
+ className: currentView === "photo" ? "item selected" : "item"
39
+ }, /*#__PURE__*/_react.default.createElement(_muncherUi.Button, {
40
+ size: "small",
41
+ variant: "primary",
42
+ rounded: true,
43
+ onClick: function onClick() {
44
+ setCurrentView("photo");
45
+ }
46
+ }, /*#__PURE__*/_react.default.createElement("img", {
47
+ className: "camera-icon",
48
+ src: _cameraIcon.default,
49
+ alt: "camera icon"
50
+ }), /*#__PURE__*/_react.default.createElement("p", null, totalAssets)), /*#__PURE__*/_react.default.createElement("p", {
51
+ className: "main"
52
+ }, totalAssets, " Photo", makePlural(totalAssets))), virtualTour ? /*#__PURE__*/_react.default.createElement("div", {
53
+ className: currentView === "virtual tour" ? "item selected" : "item"
54
+ }, /*#__PURE__*/_react.default.createElement(_muncherUi.Button, {
55
+ size: "small",
56
+ variant: "primary",
57
+ rounded: true,
58
+ onClick: function onClick() {
59
+ setCurrentView("virtual tour");
60
+ }
61
+ }, /*#__PURE__*/_react.default.createElement("img", {
62
+ className: "virtual-tour-icon",
63
+ src: _icon.default,
64
+ alt: "virtual tour icon"
65
+ }), /*#__PURE__*/_react.default.createElement("p", null, "1")), /*#__PURE__*/_react.default.createElement("p", {
66
+ className: "main"
67
+ }, "1 Virtual Tour")) : "", videoTours.length > 0 ? /*#__PURE__*/_react.default.createElement("div", {
68
+ className: currentView === "video tour" ? "item selected" : "item"
69
+ }, /*#__PURE__*/_react.default.createElement(_muncherUi.Button, {
70
+ size: "small",
71
+ variant: "primary",
72
+ rounded: true,
73
+ onClick: function onClick() {
74
+ setCurrentView("video tour");
75
+ }
76
+ }, /*#__PURE__*/_react.default.createElement("img", {
77
+ className: "video-tour-icon",
78
+ src: _videoIcon.default,
79
+ alt: "video tour icon"
80
+ }), /*#__PURE__*/_react.default.createElement("p", null, videoTours.length)), /*#__PURE__*/_react.default.createElement("p", {
81
+ className: "main"
82
+ }, videoTours.length, " Video Tour", makePlural(videoTours.length))) : ""));
83
+ };
84
+
85
+ exports.HeroBadgeStats = HeroBadgeStats;
86
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJIZXJvQmFkZ2VTdGF0cyIsImN1cnJlbnRWaWV3Iiwic2V0Q3VycmVudFZpZXciLCJ0b3RhbEFzc2V0cyIsInZpcnR1YWxUb3VyIiwidmlkZW9Ub3VycyIsIm1ha2VQbHVyYWwiLCJsZW5ndGgiLCJjYW1lcmFJY29uIiwidG91ckljb24iLCJ2aWRlb0ljb24iXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvZmxvb3JwbGFuL3NlY3Rpb24vSGVyb0JhZGdlU3RhdHMudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCB7QmFkZ2UsIEJ1dHRvbn0gZnJvbSBcIkBjb250ZW50bXVuY2gvbXVuY2hlci11aVwiO1xuaW1wb3J0IGNhbWVyYUljb24gZnJvbSBcIi4uL2NhcmQvYXNzZXRzL2NhbWVyYS1pY29uLnBuZ1wiO1xuaW1wb3J0IHRvdXJJY29uIGZyb20gXCIuLi9jYXJkL2Fzc2V0cy8zNjAtaWNvbi5wbmdcIjtcbmltcG9ydCB2aWRlb0ljb24gZnJvbSBcIi4uL2NhcmQvYXNzZXRzL3ZpZGVvLWljb24ucG5nXCI7XG5pbXBvcnQgXCIuL2Fzc2V0cy9IZXJvQmFkZ2VTdGF0cy5zY3NzXCI7XG5cbmV4cG9ydCBjb25zdCBIZXJvQmFkZ2VTdGF0czogUmVhY3QuRkM8SGVyb0JhZGdlU3RhdHNQcm9wcz4gPSAoXG4gICAge2N1cnJlbnRWaWV3LCBzZXRDdXJyZW50VmlldywgdG90YWxBc3NldHMsIHZpcnR1YWxUb3VyLCB2aWRlb1RvdXJzfSkgPT4ge1xuICAgIGNvbnN0IG1ha2VQbHVyYWwgPSAobGVuZ3RoOiBudW1iZXIpID0+IGxlbmd0aCA+IDEgPyBcInNcIiA6IFwiXCI7XG4gICAgcmV0dXJuIChcbiAgICAgICAgPGRpdiBjbGFzc05hbWU9XCJoZXJvLWJhZGdlLS1zdGF0c1wiPlxuICAgICAgICAgICAgPEJhZGdlIHZhcmlhbnQ9XCJ0ZXJ0aWFyeVwiPlxuICAgICAgICAgICAgICAgIDxkaXYgY2xhc3NOYW1lPXtjdXJyZW50VmlldyA9PT0gXCJwaG90b1wiID8gXCJpdGVtIHNlbGVjdGVkXCIgOiBcIml0ZW1cIn0+XG4gICAgICAgICAgICAgICAgICAgIDxCdXR0b24gc2l6ZT1cInNtYWxsXCIgdmFyaWFudD1cInByaW1hcnlcIiByb3VuZGVkPXt0cnVlfVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIG9uQ2xpY2s9eygpID0+IHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgc2V0Q3VycmVudFZpZXcoXCJwaG90b1wiKTtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICB9fT48aW1nIGNsYXNzTmFtZT1cImNhbWVyYS1pY29uXCIgc3JjPXtjYW1lcmFJY29ufSBhbHQ9XCJjYW1lcmEgaWNvblwiIC8+PHA+e3RvdGFsQXNzZXRzfTwvcD5cbiAgICAgICAgICAgICAgICAgICAgPC9CdXR0b24+XG4gICAgICAgICAgICAgICAgICAgIDxwIGNsYXNzTmFtZT1cIm1haW5cIj57dG90YWxBc3NldHN9IFBob3Rve21ha2VQbHVyYWwodG90YWxBc3NldHMpfTwvcD5cbiAgICAgICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgICAgICB7dmlydHVhbFRvdXIgP1xuICAgICAgICAgICAgICAgICAgICA8ZGl2IGNsYXNzTmFtZT17Y3VycmVudFZpZXcgPT09IFwidmlydHVhbCB0b3VyXCIgPyBcIml0ZW0gc2VsZWN0ZWRcIiA6IFwiaXRlbVwifT5cbiAgICAgICAgICAgICAgICAgICAgICAgIDxCdXR0b24gc2l6ZT1cInNtYWxsXCIgdmFyaWFudD1cInByaW1hcnlcIiByb3VuZGVkPXt0cnVlfVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBvbkNsaWNrPXsoKSA9PiB7XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBzZXRDdXJyZW50VmlldyhcInZpcnR1YWwgdG91clwiKTtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgfX0+XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgPGltZyBjbGFzc05hbWU9XCJ2aXJ0dWFsLXRvdXItaWNvblwiIHNyYz17dG91ckljb259IGFsdD1cInZpcnR1YWwgdG91ciBpY29uXCIgLz5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICA8cD4xPC9wPlxuICAgICAgICAgICAgICAgICAgICAgICAgPC9CdXR0b24+XG4gICAgICAgICAgICAgICAgICAgICAgICA8cCBjbGFzc05hbWU9XCJtYWluXCI+MSBWaXJ0dWFsIFRvdXI8L3A+XG4gICAgICAgICAgICAgICAgICAgIDwvZGl2PiA6IFwiXCJ9XG4gICAgICAgICAgICAgICAge3ZpZGVvVG91cnMubGVuZ3RoID4gMCA/XG4gICAgICAgICAgICAgICAgICAgIDxkaXYgY2xhc3NOYW1lPXtjdXJyZW50VmlldyA9PT0gXCJ2aWRlbyB0b3VyXCIgPyBcIml0ZW0gc2VsZWN0ZWRcIiA6IFwiaXRlbVwifT5cbiAgICAgICAgICAgICAgICAgICAgICAgIDxCdXR0b24gc2l6ZT1cInNtYWxsXCIgdmFyaWFudD1cInByaW1hcnlcIiByb3VuZGVkPXt0cnVlfVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBvbkNsaWNrPXsoKSA9PiB7XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBzZXRDdXJyZW50VmlldyhcInZpZGVvIHRvdXJcIik7XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIH19PlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIDxpbWcgY2xhc3NOYW1lPVwidmlkZW8tdG91ci1pY29uXCIgc3JjPXt2aWRlb0ljb259IGFsdD1cInZpZGVvIHRvdXIgaWNvblwiIC8+XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgPHA+e3ZpZGVvVG91cnMubGVuZ3RofTwvcD5cbiAgICAgICAgICAgICAgICAgICAgICAgIDwvQnV0dG9uPlxuICAgICAgICAgICAgICAgICAgICAgICAgPHAgY2xhc3NOYW1lPVwibWFpblwiPnt2aWRlb1RvdXJzLmxlbmd0aH0gVmlkZW8gVG91cnttYWtlUGx1cmFsKHZpZGVvVG91cnMubGVuZ3RoKX08L3A+XG4gICAgICAgICAgICAgICAgICAgIDwvZGl2PiA6IFwiXCJ9XG4gICAgICAgICAgICA8L0JhZGdlPlxuICAgICAgICA8L2Rpdj5cbiAgICApO1xufTtcblxuZXhwb3J0IGludGVyZmFjZSBIZXJvQmFkZ2VTdGF0c1Byb3BzIHtcbiAgICBjdXJyZW50VmlldzogXCJwaG90b1wiIHwgXCJ2aXJ0dWFsIHRvdXJcIiB8IFwidmlkZW8gdG91clwiO1xuICAgIHNldEN1cnJlbnRWaWV3OiAoY3VycmVudFZpZXc6IFwicGhvdG9cIiB8IFwidmlydHVhbCB0b3VyXCIgfCBcInZpZGVvIHRvdXJcIikgPT4gdm9pZDtcbiAgICB0b3RhbEFzc2V0czogbnVtYmVyO1xuICAgIHZpcnR1YWxUb3VyPzogc3RyaW5nO1xuICAgIHZpZGVvVG91cnM6IHN0cmluZ1tdO1xufSJdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUFBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOzs7O0FBRU8sSUFBTUEsY0FBNkMsR0FBRyxTQUFoREEsY0FBZ0QsT0FDZTtFQUFBLElBQXZFQyxXQUF1RSxRQUF2RUEsV0FBdUU7RUFBQSxJQUExREMsY0FBMEQsUUFBMURBLGNBQTBEO0VBQUEsSUFBMUNDLFdBQTBDLFFBQTFDQSxXQUEwQztFQUFBLElBQTdCQyxXQUE2QixRQUE3QkEsV0FBNkI7RUFBQSxJQUFoQkMsVUFBZ0IsUUFBaEJBLFVBQWdCOztFQUN4RSxJQUFNQyxVQUFVLEdBQUcsU0FBYkEsVUFBYSxDQUFDQyxNQUFEO0lBQUEsT0FBb0JBLE1BQU0sR0FBRyxDQUFULEdBQWEsR0FBYixHQUFtQixFQUF2QztFQUFBLENBQW5COztFQUNBLG9CQUNJO0lBQUssU0FBUyxFQUFDO0VBQWYsZ0JBQ0ksNkJBQUMsZ0JBQUQ7SUFBTyxPQUFPLEVBQUM7RUFBZixnQkFDSTtJQUFLLFNBQVMsRUFBRU4sV0FBVyxLQUFLLE9BQWhCLEdBQTBCLGVBQTFCLEdBQTRDO0VBQTVELGdCQUNJLDZCQUFDLGlCQUFEO0lBQVEsSUFBSSxFQUFDLE9BQWI7SUFBcUIsT0FBTyxFQUFDLFNBQTdCO0lBQXVDLE9BQU8sRUFBRSxJQUFoRDtJQUNRLE9BQU8sRUFBRSxtQkFBTTtNQUNYQyxjQUFjLENBQUMsT0FBRCxDQUFkO0lBQ0g7RUFIVCxnQkFHVztJQUFLLFNBQVMsRUFBQyxhQUFmO0lBQTZCLEdBQUcsRUFBRU0sbUJBQWxDO0lBQThDLEdBQUcsRUFBQztFQUFsRCxFQUhYLGVBRzZFLHdDQUFJTCxXQUFKLENBSDdFLENBREosZUFNSTtJQUFHLFNBQVMsRUFBQztFQUFiLEdBQXFCQSxXQUFyQixZQUF3Q0csVUFBVSxDQUFDSCxXQUFELENBQWxELENBTkosQ0FESixFQVNLQyxXQUFXLGdCQUNSO0lBQUssU0FBUyxFQUFFSCxXQUFXLEtBQUssY0FBaEIsR0FBaUMsZUFBakMsR0FBbUQ7RUFBbkUsZ0JBQ0ksNkJBQUMsaUJBQUQ7SUFBUSxJQUFJLEVBQUMsT0FBYjtJQUFxQixPQUFPLEVBQUMsU0FBN0I7SUFBdUMsT0FBTyxFQUFFLElBQWhEO0lBQ1EsT0FBTyxFQUFFLG1CQUFNO01BQ1hDLGNBQWMsQ0FBQyxjQUFELENBQWQ7SUFDSDtFQUhULGdCQUlJO0lBQUssU0FBUyxFQUFDLG1CQUFmO0lBQW1DLEdBQUcsRUFBRU8sYUFBeEM7SUFBa0QsR0FBRyxFQUFDO0VBQXRELEVBSkosZUFLSSw0Q0FMSixDQURKLGVBUUk7SUFBRyxTQUFTLEVBQUM7RUFBYixvQkFSSixDQURRLEdBVUMsRUFuQmpCLEVBb0JLSixVQUFVLENBQUNFLE1BQVgsR0FBb0IsQ0FBcEIsZ0JBQ0c7SUFBSyxTQUFTLEVBQUVOLFdBQVcsS0FBSyxZQUFoQixHQUErQixlQUEvQixHQUFpRDtFQUFqRSxnQkFDSSw2QkFBQyxpQkFBRDtJQUFRLElBQUksRUFBQyxPQUFiO0lBQXFCLE9BQU8sRUFBQyxTQUE3QjtJQUF1QyxPQUFPLEVBQUUsSUFBaEQ7SUFDUSxPQUFPLEVBQUUsbUJBQU07TUFDWEMsY0FBYyxDQUFDLFlBQUQsQ0FBZDtJQUNIO0VBSFQsZ0JBSUk7SUFBSyxTQUFTLEVBQUMsaUJBQWY7SUFBaUMsR0FBRyxFQUFFUSxrQkFBdEM7SUFBaUQsR0FBRyxFQUFDO0VBQXJELEVBSkosZUFLSSx3Q0FBSUwsVUFBVSxDQUFDRSxNQUFmLENBTEosQ0FESixlQVFJO0lBQUcsU0FBUyxFQUFDO0VBQWIsR0FBcUJGLFVBQVUsQ0FBQ0UsTUFBaEMsaUJBQW1ERCxVQUFVLENBQUNELFVBQVUsQ0FBQ0UsTUFBWixDQUE3RCxDQVJKLENBREgsR0FVWSxFQTlCakIsQ0FESixDQURKO0FBb0NILENBdkNNIn0=
@@ -0,0 +1,5 @@
1
+ @import "src/assets/variables";
2
+
3
+ .hero-badge--stats {
4
+
5
+ }
@@ -3,11 +3,99 @@
3
3
  .section-floorplan--hero {
4
4
  padding: 0;
5
5
  background: $primary-background-color;
6
+ width: 100vw;
7
+ position: relative;
6
8
 
7
9
  a {
8
10
  text-decoration: underline;
9
11
  }
10
12
 
13
+ .gallery-hero {
14
+ position: relative;
15
+ width: 100vw;
16
+ height: 40vh;
17
+ @media (min-width: $large-size) {
18
+ height: 40vw;
19
+ }
20
+
21
+ .virtual-tour-view {
22
+ iframe {
23
+ width: 100%;
24
+ height: 40vh;
25
+ @media (min-width: $large-size) {
26
+ height: 40vw;
27
+
28
+ }
29
+ }
30
+ }
31
+
32
+ .video-tour-view {
33
+ .single-video-layout {
34
+ iframe {
35
+ width: 100%;
36
+ height: 35vh;
37
+ @media (min-width: $large-size) {
38
+ height: 40vw;
39
+ }
40
+ }
41
+ }
42
+
43
+ .two-video-layout {
44
+ @media (min-width: $large-size) {
45
+ display: flex;
46
+ align-content: flex-start;
47
+ justify-content: space-evenly;
48
+ }
49
+
50
+ iframe {
51
+ width: 40%;
52
+ height: 35vh;
53
+ margin: 1rem;
54
+ @media (min-width: $large-size) {
55
+ height: 35vw;
56
+ }
57
+ }
58
+ }
59
+ }
60
+
61
+ .badge--stats {
62
+ position: absolute;
63
+ left: 50%;
64
+ transform: translate(-50%, -50%);
65
+ bottom: -2rem;
66
+
67
+ .muncher-badge {
68
+ color: $primary-background-color;
69
+ flex-wrap: nowrap;
70
+ break-inside: avoid;
71
+ align-content: center;
72
+ width: 60vw;
73
+ font-size: .7rem;
74
+ @media (min-width: $large-size) {
75
+ font-size: 1rem;
76
+ width: auto;
77
+ }
78
+
79
+ .muncher-button--small {
80
+ padding: 0;
81
+ color: $primary-background-color;
82
+ text-transform: capitalize;
83
+ font-size: .7rem;
84
+ font-family: $serif-font;
85
+ @media (min-width: $large-size) {
86
+ font-size: 1rem;
87
+ }
88
+
89
+ .selected {
90
+ text-decoration: underline;
91
+ }
92
+ }
93
+
94
+ }
95
+ }
96
+ }
97
+
98
+
11
99
  .floorplan--two-columns {
12
100
  padding: 2rem;
13
101
  @media (min-width: $medium-size) {
@@ -45,7 +133,8 @@
45
133
  font-family: $sans-serif-font;
46
134
  letter-spacing: .05rem;
47
135
  font-size: 1.1rem;
48
- .muncher-button{
136
+
137
+ .muncher-button {
49
138
  font-family: $sans-serif-font;
50
139
  letter-spacing: .05rem;
51
140
  font-size: 1.1rem;
@@ -43,9 +43,6 @@ $floorplan-background-color: $tertiary-color !default;
43
43
 
44
44
  li {
45
45
  font-size: 1rem;
46
- letter-spacing: .03rem;
47
- line-height: 1.5rem;
48
- font-weight: 300;
49
46
  }
50
47
  }
51
48
 
@@ -0,0 +1,74 @@
1
+ @import 'src/assets/variables';
2
+
3
+ .hero-badge--stats {
4
+ position: absolute;
5
+ left: 50%;
6
+ transform: translate(-50%, -50%);
7
+
8
+ .muncher-badge {
9
+ color: $primary-background-color;
10
+ flex-wrap: nowrap;
11
+ break-inside: avoid;
12
+ align-content: center;
13
+ justify-content: space-evenly;
14
+ width: 50vw;
15
+ font-size: .7rem;
16
+ margin: 0;
17
+ padding: .2rem;
18
+ @media (min-width: $large-size) {
19
+ font-size: 1rem;
20
+ width: auto;
21
+ }
22
+
23
+ .muncher-button--rounded {
24
+ border-radius: .5rem;
25
+ margin: .25rem;
26
+ min-height: 1.8rem;
27
+ min-width: 3rem;
28
+ }
29
+
30
+ .item {
31
+ display: flex;
32
+ flex-direction: column;
33
+ flex-wrap: wrap;
34
+ justify-content: center;
35
+ align-items: center;
36
+ @media (min-width: $large-size) {
37
+ padding: .25rem;
38
+ }
39
+
40
+ p {
41
+ font-size: .6rem;
42
+ margin: 0;
43
+ }
44
+ }
45
+
46
+ .selected {
47
+ text-decoration: underline;
48
+ font-weight: bold;
49
+ }
50
+
51
+ .muncher-button--small {
52
+ color: $primary-background-color;
53
+ text-transform: capitalize;
54
+ font-size: .7rem;
55
+ font-family: $serif-font;
56
+
57
+ img {
58
+ margin-right: .4rem;
59
+ }
60
+
61
+ p {
62
+ font-size: .7rem;
63
+ }
64
+ }
65
+
66
+ .camera-icon, .virtual-tour-icon {
67
+ height: .9rem;
68
+ }
69
+
70
+ .video-tour-icon {
71
+ height: .8rem;
72
+ }
73
+ }
74
+ }
@@ -0,0 +1,13 @@
1
+ import React from "react";
2
+ import './assets/GalleryHero.scss';
3
+ import { Asset } from "../asset/data/Asset";
4
+ export declare const GalleryHeroMain: React.FC<GalleryHeroProps>;
5
+ export interface GalleryHeroProps {
6
+ assetsToShow: Asset[];
7
+ virtualTour?: string;
8
+ isAvailableNow?: boolean;
9
+ isFirst: boolean;
10
+ toursCount: number;
11
+ setCurrentView: (view: "photo" | "virtual tour" | "video tour") => void;
12
+ imageClickedHandler: (image: Asset) => void;
13
+ }