@renaissancerentals/renaissance-component 12.1.14 → 12.1.16
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/data/RenaissanceData.d.ts +2 -0
- package/lib/data/RenaissanceData.js +4 -2
- package/lib/floorplan/data/Floorplan.d.ts +2 -1
- package/lib/floorplan/data/Floorplan.js +1 -1
- package/lib/floorplan/section/FloorplanSection.js +1 -1
- package/lib/floorplan/service/FloorplanService.js +24 -23
- package/lib/index.d.ts +4 -0
- package/lib/index.js +35 -1
- package/lib/property/data/Property.d.ts +5 -0
- package/lib/property/data/Property.js +7 -2
- package/lib/short-term/ShortTermFloorplanCard.d.ts +11 -0
- package/lib/short-term/ShortTermFloorplanCard.js +105 -0
- package/lib/short-term/ShortTermFloorplanHero.d.ts +12 -0
- package/lib/short-term/ShortTermFloorplanHero.js +198 -0
- package/lib/short-term/ShortTermFloorplanSection.d.ts +10 -0
- package/lib/short-term/ShortTermFloorplanSection.js +134 -0
- package/lib/short-term/ShortTermFloorplansHeader.d.ts +15 -0
- package/lib/short-term/ShortTermFloorplansHeader.js +145 -0
- package/lib/short-term/ShortTermFloorplansSection.d.ts +17 -0
- package/lib/short-term/ShortTermFloorplansSection.js +80 -0
- package/lib/short-term/ShortTermPricingCard.d.ts +7 -0
- package/lib/short-term/ShortTermPricingCard.js +63 -0
- package/lib/short-term/ShortTermSort.d.ts +7 -0
- package/lib/short-term/ShortTermSort.js +41 -0
- package/lib/short-term/ShortTermStyleFilter.d.ts +8 -0
- package/lib/short-term/ShortTermStyleFilter.js +31 -0
- package/lib/short-term/assets/ShortTermFloorplanCard.scss +232 -0
- package/lib/short-term/assets/ShortTermFloorplanHero.scss +165 -0
- package/lib/short-term/assets/ShortTermFloorplanSection.scss +124 -0
- package/lib/short-term/assets/ShortTermFloorplansHeader.scss +70 -0
- package/lib/short-term/assets/ShortTermFloorplansSection.scss +18 -0
- package/lib/short-term/assets/ShortTermPricingCard.scss +59 -0
- package/lib/short-term/data/ShortTerm.d.ts +44 -0
- package/lib/short-term/data/ShortTerm.js +14 -0
- package/lib/short-term/data/ShortTermFilters.d.ts +16 -0
- package/lib/short-term/data/ShortTermFilters.js +41 -0
- package/lib/short-term/service/ShortTermService.d.ts +7 -0
- package/lib/short-term/service/ShortTermService.js +54 -0
- package/lib/utils/Utils.js +3 -2
- package/package.json +1 -1
|
@@ -0,0 +1,134 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.ShortTermFloorplanSection = void 0;
|
|
7
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
8
|
+
require("./assets/ShortTermFloorplanSection.scss");
|
|
9
|
+
var _muncherUi = require("@contentmunch/muncher-ui");
|
|
10
|
+
var _ShortTermService = require("./service/ShortTermService");
|
|
11
|
+
var _GalleryHeroSkeleton = require("../gallery/GalleryHeroSkeleton");
|
|
12
|
+
var _ShortTermFloorplanHero = require("./ShortTermFloorplanHero");
|
|
13
|
+
var _Card = require("../card/Card");
|
|
14
|
+
var _Utils = require("../utils/Utils");
|
|
15
|
+
var _MapSection = require("../map/MapSection");
|
|
16
|
+
var _RenaissanceData = require("../data/RenaissanceData");
|
|
17
|
+
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
|
|
18
|
+
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
|
|
19
|
+
const ShortTermFloorplanSection = _ref => {
|
|
20
|
+
var _floorplan$property;
|
|
21
|
+
let {
|
|
22
|
+
contactClickHandler,
|
|
23
|
+
applyClickHandler,
|
|
24
|
+
floorplanId,
|
|
25
|
+
locationRef,
|
|
26
|
+
handleRefToLocation
|
|
27
|
+
} = _ref;
|
|
28
|
+
const [floorplan, setFloorplan] = (0, _react.useState)({});
|
|
29
|
+
const [isLoading, setIsLoading] = (0, _react.useState)(true);
|
|
30
|
+
const [errorLoading, setErrorLoading] = (0, _react.useState)(false);
|
|
31
|
+
const mapRef = (0, _react.useRef)(null);
|
|
32
|
+
const handleRefToMap = () => {
|
|
33
|
+
if (handleRefToLocation) handleRefToLocation();else {
|
|
34
|
+
var _mapRef$current;
|
|
35
|
+
(_mapRef$current = mapRef.current) === null || _mapRef$current === void 0 || _mapRef$current.scrollIntoView({
|
|
36
|
+
behavior: "smooth",
|
|
37
|
+
block: "start"
|
|
38
|
+
});
|
|
39
|
+
}
|
|
40
|
+
};
|
|
41
|
+
(0, _react.useEffect)(() => {
|
|
42
|
+
(0, _ShortTermService.getShortTermFloorplan)(floorplanId).then(data => {
|
|
43
|
+
setFloorplan(data);
|
|
44
|
+
}).catch(() => {
|
|
45
|
+
setErrorLoading(true);
|
|
46
|
+
}).finally(() => {
|
|
47
|
+
setIsLoading(false);
|
|
48
|
+
});
|
|
49
|
+
}, [floorplanId]);
|
|
50
|
+
const generatePricing = price => price ? "".concat((0, _Utils.toUSD)(price), "/day/ ").concat((0, _Utils.toUSD)(price * 30), "/mo") : "-";
|
|
51
|
+
return /*#__PURE__*/_react.default.createElement("section", {
|
|
52
|
+
className: "section-short-term-floorplan"
|
|
53
|
+
}, isLoading ? /*#__PURE__*/_react.default.createElement("section", {
|
|
54
|
+
className: "section-floorplan--hero"
|
|
55
|
+
}, /*#__PURE__*/_react.default.createElement(_GalleryHeroSkeleton.GalleryHeroSkeleton, null)) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, errorLoading ? /*#__PURE__*/_react.default.createElement("section", {
|
|
56
|
+
className: "div-full--center"
|
|
57
|
+
}, /*#__PURE__*/_react.default.createElement("h2", null, "Uh-oh, this is a 404")) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_ShortTermFloorplanHero.ShortTermFloorplanHero, {
|
|
58
|
+
floorplan: floorplan,
|
|
59
|
+
contactClickHandler: contactClickHandler,
|
|
60
|
+
webSpecials: [],
|
|
61
|
+
applyClickHandler: applyClickHandler,
|
|
62
|
+
handleRefToMap: handleRefToMap
|
|
63
|
+
}), /*#__PURE__*/_react.default.createElement("div", {
|
|
64
|
+
className: "container"
|
|
65
|
+
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
66
|
+
className: "floorplan--cards"
|
|
67
|
+
}, /*#__PURE__*/_react.default.createElement(_Card.Card, {
|
|
68
|
+
title: "Details"
|
|
69
|
+
}, /*#__PURE__*/_react.default.createElement("p", {
|
|
70
|
+
className: "floorplan-card--featured"
|
|
71
|
+
}, floorplan.bedroom, " Bedroom | ", floorplan.bathroom, " Bathroom ", (0, _Utils.enumToString)(floorplan.style)), /*#__PURE__*/_react.default.createElement("p", {
|
|
72
|
+
className: "floorplan-card--featured"
|
|
73
|
+
}, floorplan.shortTerm.squareFoot, " Square Feet"), /*#__PURE__*/_react.default.createElement("div", {
|
|
74
|
+
className: "row-content"
|
|
75
|
+
}, /*#__PURE__*/_react.default.createElement("h4", {
|
|
76
|
+
className: "row-title"
|
|
77
|
+
}, "Pricing:"), /*#__PURE__*/_react.default.createElement("p", {
|
|
78
|
+
className: "floorplan-card--featured"
|
|
79
|
+
}, /*#__PURE__*/_react.default.createElement("span", {
|
|
80
|
+
className: "key"
|
|
81
|
+
}, "5-13 days:"), /*#__PURE__*/_react.default.createElement("span", {
|
|
82
|
+
className: "value"
|
|
83
|
+
}, generatePricing(floorplan.shortTerm.priceFor5To13Days))), /*#__PURE__*/_react.default.createElement("p", {
|
|
84
|
+
className: "floorplan-card--featured"
|
|
85
|
+
}, /*#__PURE__*/_react.default.createElement("span", {
|
|
86
|
+
className: "key"
|
|
87
|
+
}, "14-29 days:"), /*#__PURE__*/_react.default.createElement("span", {
|
|
88
|
+
className: "value"
|
|
89
|
+
}, generatePricing(floorplan.shortTerm.priceFor14To29Days))), /*#__PURE__*/_react.default.createElement("p", {
|
|
90
|
+
className: "floorplan-card--featured"
|
|
91
|
+
}, /*#__PURE__*/_react.default.createElement("span", {
|
|
92
|
+
className: "key"
|
|
93
|
+
}, "1-4 months:"), /*#__PURE__*/_react.default.createElement("span", {
|
|
94
|
+
className: "value"
|
|
95
|
+
}, generatePricing(floorplan.shortTerm.priceFor1To4Months))), /*#__PURE__*/_react.default.createElement("p", {
|
|
96
|
+
className: "floorplan-card--featured"
|
|
97
|
+
}, /*#__PURE__*/_react.default.createElement("span", {
|
|
98
|
+
className: "key"
|
|
99
|
+
}, "4+ months:"), /*#__PURE__*/_react.default.createElement("span", {
|
|
100
|
+
className: "value"
|
|
101
|
+
}, generatePricing(floorplan.shortTerm.priceFor4andMoreMonths)))), /*#__PURE__*/_react.default.createElement("p", null, floorplan.description)), floorplan.amenities.length > 0 ? /*#__PURE__*/_react.default.createElement(_Card.Card, {
|
|
102
|
+
title: "Amenities"
|
|
103
|
+
}, /*#__PURE__*/_react.default.createElement(_muncherUi.Ul, null, floorplan.amenities.filter(amenity => amenity.featured).map(amenity => /*#__PURE__*/_react.default.createElement(_muncherUi.Li, {
|
|
104
|
+
key: "floorplan-amenity-" + amenity.id,
|
|
105
|
+
bulletIcon: "star",
|
|
106
|
+
isFeatured: true
|
|
107
|
+
}, amenity.name)), floorplan.amenities.filter(amenity => !amenity.featured).map(amenity => /*#__PURE__*/_react.default.createElement(_muncherUi.Li, {
|
|
108
|
+
key: "floorplan-amenity-" + amenity.id,
|
|
109
|
+
bulletIcon: "dot"
|
|
110
|
+
}, amenity.name)))) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null), isLoading ? "" : /*#__PURE__*/_react.default.createElement(_Card.Card, null, /*#__PURE__*/_react.default.createElement("div", {
|
|
111
|
+
ref: locationRef ? locationRef : mapRef,
|
|
112
|
+
id: "location",
|
|
113
|
+
className: "reference"
|
|
114
|
+
}), /*#__PURE__*/_react.default.createElement(_MapSection.MapSection, {
|
|
115
|
+
src: (0, _Utils.floorplanAddressToGoogleMap)({
|
|
116
|
+
city: _RenaissanceData.renaissance.city,
|
|
117
|
+
state: _RenaissanceData.renaissance.state,
|
|
118
|
+
address: floorplan.address,
|
|
119
|
+
zipcode: floorplan.zipcode
|
|
120
|
+
})
|
|
121
|
+
})), /*#__PURE__*/_react.default.createElement("div", {
|
|
122
|
+
className: "contact-card"
|
|
123
|
+
}, /*#__PURE__*/_react.default.createElement(_Card.Card, {
|
|
124
|
+
featured: true
|
|
125
|
+
}, /*#__PURE__*/_react.default.createElement("p", null, /*#__PURE__*/_react.default.createElement("i", null, "Questions?")), /*#__PURE__*/_react.default.createElement("p", null, /*#__PURE__*/_react.default.createElement("i", null, "Call or text us anytime:")), (_floorplan$property = floorplan.property) !== null && _floorplan$property !== void 0 && _floorplan$property.phone ? /*#__PURE__*/_react.default.createElement("p", null, /*#__PURE__*/_react.default.createElement("a", {
|
|
126
|
+
href: "tel:" + floorplan.property.phone
|
|
127
|
+
}, (0, _Utils.formatPhoneNumber)(floorplan.property.phone))) : "", /*#__PURE__*/_react.default.createElement(_muncherUi.Button, {
|
|
128
|
+
variant: "tertiary",
|
|
129
|
+
onClick: contactClickHandler,
|
|
130
|
+
size: "large"
|
|
131
|
+
}, "Contact Us \xBB"))))))));
|
|
132
|
+
};
|
|
133
|
+
exports.ShortTermFloorplanSection = ShortTermFloorplanSection;
|
|
134
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_muncherUi","_ShortTermService","_GalleryHeroSkeleton","_ShortTermFloorplanHero","_Card","_Utils","_MapSection","_RenaissanceData","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","prototype","hasOwnProperty","call","i","set","ShortTermFloorplanSection","_ref","_floorplan$property","contactClickHandler","applyClickHandler","floorplanId","locationRef","handleRefToLocation","floorplan","setFloorplan","useState","isLoading","setIsLoading","errorLoading","setErrorLoading","mapRef","useRef","handleRefToMap","_mapRef$current","current","scrollIntoView","behavior","block","useEffect","getShortTermFloorplan","then","data","catch","finally","generatePricing","price","concat","toUSD","createElement","className","GalleryHeroSkeleton","Fragment","ShortTermFloorplanHero","webSpecials","Card","title","bedroom","bathroom","enumToString","style","shortTerm","squareFoot","priceFor5To13Days","priceFor14To29Days","priceFor1To4Months","priceFor4andMoreMonths","description","amenities","length","Ul","filter","amenity","featured","map","Li","key","id","bulletIcon","isFeatured","name","ref","MapSection","src","floorplanAddressToGoogleMap","city","renaissance","state","address","zipcode","property","phone","href","formatPhoneNumber","Button","variant","onClick","size","exports"],"sources":["../../src/short-term/ShortTermFloorplanSection.tsx"],"sourcesContent":["import React, {useEffect, useRef, useState} from \"react\";\nimport \"./assets/ShortTermFloorplanSection.scss\";\nimport {Button, Li, Ul} from \"@contentmunch/muncher-ui\";\nimport {FloorplanShortTerm} from \"./data/ShortTerm\";\nimport {getShortTermFloorplan} from \"./service/ShortTermService\";\nimport {GalleryHeroSkeleton} from \"../gallery/GalleryHeroSkeleton\";\nimport {ShortTermFloorplanHero} from \"./ShortTermFloorplanHero\";\nimport {Card} from \"../card/Card\";\nimport {enumToString, floorplanAddressToGoogleMap, formatPhoneNumber, toUSD} from \"../utils/Utils\";\nimport {MapSection} from \"../map/MapSection\";\nimport {renaissance} from \"../data/RenaissanceData\";\n\nexport const ShortTermFloorplanSection: React.FC<FloorplanSectionProps> = (\n    {\n        contactClickHandler,\n        applyClickHandler,\n        floorplanId,\n        locationRef,\n        handleRefToLocation\n    }) => {\n    const [floorplan, setFloorplan] = useState<FloorplanShortTerm>({} as FloorplanShortTerm);\n    const [isLoading, setIsLoading] = useState(true);\n    const [errorLoading, setErrorLoading] = useState(false);\n\n    const mapRef: React.Ref<HTMLDivElement> = useRef<HTMLDivElement>(null);\n    const handleRefToMap = () => {\n        if (handleRefToLocation)\n            handleRefToLocation();\n        else {\n            mapRef.current?.scrollIntoView({\n                behavior: \"smooth\",\n                block: \"start\"\n            });\n        }\n\n    };\n    useEffect(() => {\n        getShortTermFloorplan(floorplanId)\n            .then((data) => {\n                setFloorplan(data)\n            })\n            .catch(() => {\n                setErrorLoading(true);\n            })\n            .finally(() => {\n                setIsLoading(false);\n            });\n\n    }, [floorplanId]);\n    const generatePricing = (price: number) => price ? `${toUSD(price)}/day/ ${toUSD(price * 30)}/mo` : \"-\";\n\n    return (\n        <section className=\"section-short-term-floorplan\">\n            {\n                isLoading ? <section className=\"section-floorplan--hero\"><GalleryHeroSkeleton/></section> : <>\n                    {errorLoading ?\n                        <section className=\"div-full--center\">\n                            <h2>Uh-oh, this is a 404</h2>\n                        </section> :\n                        <>\n                            <ShortTermFloorplanHero floorplan={floorplan} contactClickHandler={contactClickHandler}\n                                                    webSpecials={[]}\n                                                    applyClickHandler={applyClickHandler}\n                                                    handleRefToMap={handleRefToMap}/>\n                            <div className=\"container\">\n                                <div className=\"floorplan--cards\">\n                                    <Card title=\"Details\">\n                                        <p className=\"floorplan-card--featured\">\n                                            {floorplan.bedroom} Bedroom\n                                            | {floorplan.bathroom} Bathroom {enumToString(floorplan.style)}\n                                        </p>\n                                        <p className=\"floorplan-card--featured\">\n                                            {floorplan.shortTerm.squareFoot} Square Feet\n                                        </p>\n\n\n                                        <div className=\"row-content\">\n                                                <h4 className=\"row-title\">Pricing:</h4>\n                                            <p className=\"floorplan-card--featured\">\n                                                <span className=\"key\">5-13 days:</span>\n                                                <span className=\"value\">\n                                                    {generatePricing(floorplan.shortTerm.priceFor5To13Days)}\n                                                </span>\n                                            </p>\n                                            <p className=\"floorplan-card--featured\">\n                                                <span className=\"key\">14-29 days:</span>\n                                                <span className=\"value\">\n                                                    {generatePricing(floorplan.shortTerm.priceFor14To29Days)}\n                                                </span>\n                                            </p>\n                                            <p className=\"floorplan-card--featured\">\n                                                <span className=\"key\">1-4 months:</span>\n                                                <span className=\"value\">\n                                                    {generatePricing(floorplan.shortTerm.priceFor1To4Months)}\n                                                </span>\n                                            </p>\n                                            <p className=\"floorplan-card--featured\">\n                                                <span className=\"key\">4+ months:</span>\n                                                <span className=\"value\">\n                                                    {generatePricing(floorplan.shortTerm.priceFor4andMoreMonths)}\n                                                </span>\n                                            </p>\n                                        </div>\n\n                                        <p>\n                                            {floorplan.description}\n                                        </p>\n                                    </Card>\n\n\n                                    {\n                                        floorplan.amenities.length > 0 ?\n                                            <Card title=\"Amenities\">\n                                                <Ul>\n                                                    {\n                                                        floorplan.amenities.filter(amenity => amenity.featured).map(amenity =>\n                                                            <Li key={\"floorplan-amenity-\" + amenity.id}\n                                                                bulletIcon=\"star\"\n                                                                isFeatured={true}>\n                                                                {amenity.name}\n\n                                                            </Li>\n                                                        )}\n                                                    {\n                                                        floorplan.amenities.filter(amenity => !amenity.featured).map(amenity =>\n                                                            <Li key={\"floorplan-amenity-\" + amenity.id}\n                                                                bulletIcon=\"dot\">\n                                                                {amenity.name}\n\n                                                            </Li>\n                                                        )\n                                                    }\n                                                </Ul>\n\n                                            </Card> : <></>\n                                    }\n\n\n                                    {isLoading ? \"\" :\n                                        <Card>\n                                            <div ref={locationRef ? locationRef : mapRef} id=\"location\"\n                                                 className=\"reference\">\n\n                                            </div>\n                                            <MapSection\n                                                src={floorplanAddressToGoogleMap({\n                                                    city: renaissance.city,\n                                                    state: renaissance.state,\n                                                    address: floorplan.address,\n                                                    zipcode: floorplan.zipcode\n                                                })}/>\n                                        </Card>\n                                    }\n\n\n                                    <div className=\"contact-card\">\n                                        <Card featured={true}>\n                                            <p><i>Questions?</i></p>\n                                            <p><i>Call or text us anytime:</i></p>\n                                            {floorplan.property?.phone ?\n                                                <p><a\n                                                    href={\"tel:\" + floorplan.property.phone}>{formatPhoneNumber(floorplan.property.phone)}</a>\n                                                </p>\n                                                : \"\"}\n                                            <Button variant=\"tertiary\" onClick={contactClickHandler} size=\"large\">Contact\n                                                Us\n                                                »</Button>\n                                        </Card>\n                                    </div>\n                                </div>\n                            </div>\n                        </>\n                    }\n\n                </>\n            }\n\n        </section>\n    );\n};\n\nexport interface FloorplanSectionProps {\n    contactClickHandler: () => void;\n    applyClickHandler: () => void;\n    floorplanId: string;\n    locationRef?: React.Ref<HTMLDivElement>;\n    handleRefToLocation?: () => void;\n}\n"],"mappings":"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"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import "./assets/ShortTermFloorplansHeader.scss";
|
|
3
|
+
import "../floorplan/filter/assets/FloorplanDropDown.scss";
|
|
4
|
+
import { DefaultShortTermFilters } from "./ShortTermFloorplansSection";
|
|
5
|
+
import { ShortTermFilters } from "./data/ShortTermFilters";
|
|
6
|
+
import { FloorplanShortTerm } from "./data/ShortTerm";
|
|
7
|
+
export declare const ShortTermFloorplansHeader: React.FC<ShortTermFloorplansHeaderProps>;
|
|
8
|
+
export interface ShortTermFloorplansHeaderProps extends DefaultShortTermFilters {
|
|
9
|
+
title?: string;
|
|
10
|
+
filters: ShortTermFilters;
|
|
11
|
+
floorplans: FloorplanShortTerm[];
|
|
12
|
+
setCurrentFloorplans: (floorplans: FloorplanShortTerm[]) => void;
|
|
13
|
+
isCondensed?: boolean;
|
|
14
|
+
currentFloorplansCount: number;
|
|
15
|
+
}
|
|
@@ -0,0 +1,145 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.ShortTermFloorplansHeader = void 0;
|
|
7
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
8
|
+
require("./assets/ShortTermFloorplansHeader.scss");
|
|
9
|
+
require("../floorplan/filter/assets/FloorplanDropDown.scss");
|
|
10
|
+
var _muncherUi = require("@contentmunch/muncher-ui");
|
|
11
|
+
var _ShortTermService = require("./service/ShortTermService");
|
|
12
|
+
var _Bedroom = require("../floorplan/section/filter/Bedroom");
|
|
13
|
+
var _ShortTermStyleFilter = require("./ShortTermStyleFilter");
|
|
14
|
+
var _Utils = require("../utils/Utils");
|
|
15
|
+
var _ShortTermSort = require("./ShortTermSort");
|
|
16
|
+
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); }
|
|
17
|
+
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; }
|
|
18
|
+
const ShortTermFloorplansHeader = _ref => {
|
|
19
|
+
let {
|
|
20
|
+
title,
|
|
21
|
+
filters,
|
|
22
|
+
floorplans,
|
|
23
|
+
setCurrentFloorplans,
|
|
24
|
+
isCondensed,
|
|
25
|
+
currentFloorplansCount,
|
|
26
|
+
defaultFloorplanStyle,
|
|
27
|
+
defaultBedRooms,
|
|
28
|
+
defaultMaxRent,
|
|
29
|
+
defaultMinRent,
|
|
30
|
+
defaultFloorplanIds
|
|
31
|
+
} = _ref;
|
|
32
|
+
const [bedroomFilters, setBedroomFilters] = (0, _react.useState)(defaultBedRooms ? [defaultBedRooms] : []);
|
|
33
|
+
const [styleFilters, setStyleFilters] = (0, _react.useState)(defaultFloorplanStyle ? [defaultFloorplanStyle] : []);
|
|
34
|
+
const [sortBy, setSortBy] = (0, _react.useState)("priceAsc");
|
|
35
|
+
const [floorplanIds, setFloorplanIds] = (0, _react.useState)(defaultFloorplanIds ? defaultFloorplanIds : []);
|
|
36
|
+
const currentFilters = {
|
|
37
|
+
bedroomFilters,
|
|
38
|
+
styleFilters,
|
|
39
|
+
sortBy,
|
|
40
|
+
floorplanIds
|
|
41
|
+
};
|
|
42
|
+
const handleSortAndFilter = withCurrentFilters => {
|
|
43
|
+
setCurrentFloorplans((0, _ShortTermService.sortAndFilter)(floorplans, withCurrentFilters));
|
|
44
|
+
};
|
|
45
|
+
const handleBedroomFilterChange = filter => {
|
|
46
|
+
const index = bedroomFilters.indexOf(filter);
|
|
47
|
+
const currentBedroomFilters = [...bedroomFilters];
|
|
48
|
+
if (index > -1) {
|
|
49
|
+
currentBedroomFilters.splice(index, 1);
|
|
50
|
+
} else {
|
|
51
|
+
currentBedroomFilters.push(filter);
|
|
52
|
+
}
|
|
53
|
+
setBedroomFilters(currentBedroomFilters);
|
|
54
|
+
handleSortAndFilter({
|
|
55
|
+
...currentFilters,
|
|
56
|
+
bedroomFilters: currentBedroomFilters
|
|
57
|
+
});
|
|
58
|
+
};
|
|
59
|
+
const handleFloorplanIdChange = floorplanId => {
|
|
60
|
+
const index = floorplanIds.indexOf(floorplanId);
|
|
61
|
+
const currentFloorplanIds = [...floorplanIds];
|
|
62
|
+
if (index > -1) {
|
|
63
|
+
currentFloorplanIds.splice(index, 1);
|
|
64
|
+
}
|
|
65
|
+
setFloorplanIds(currentFloorplanIds);
|
|
66
|
+
handleSortAndFilter({
|
|
67
|
+
...currentFilters,
|
|
68
|
+
floorplanIds: currentFloorplanIds
|
|
69
|
+
});
|
|
70
|
+
};
|
|
71
|
+
const handleStyleFilterChange = filter => {
|
|
72
|
+
const index = styleFilters.indexOf(filter);
|
|
73
|
+
const currentSyleFilters = [...styleFilters];
|
|
74
|
+
if (index > -1) {
|
|
75
|
+
currentSyleFilters.splice(index, 1);
|
|
76
|
+
} else {
|
|
77
|
+
currentSyleFilters.push(filter);
|
|
78
|
+
}
|
|
79
|
+
setStyleFilters(currentSyleFilters);
|
|
80
|
+
handleSortAndFilter({
|
|
81
|
+
...currentFilters,
|
|
82
|
+
styleFilters: currentSyleFilters
|
|
83
|
+
});
|
|
84
|
+
};
|
|
85
|
+
const handleSortChange = sortBy => {
|
|
86
|
+
setSortBy(sortBy);
|
|
87
|
+
handleSortAndFilter({
|
|
88
|
+
...currentFilters,
|
|
89
|
+
sortBy: sortBy
|
|
90
|
+
});
|
|
91
|
+
};
|
|
92
|
+
return /*#__PURE__*/_react.default.createElement("header", {
|
|
93
|
+
className: "short-term-floorplans-header"
|
|
94
|
+
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
95
|
+
className: isCondensed ? "" : "container"
|
|
96
|
+
}, /*#__PURE__*/_react.default.createElement("h2", null, title), /*#__PURE__*/_react.default.createElement("div", {
|
|
97
|
+
className: "units-filters"
|
|
98
|
+
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
99
|
+
className: "filter-group"
|
|
100
|
+
}, /*#__PURE__*/_react.default.createElement("label", {
|
|
101
|
+
className: "filter-label"
|
|
102
|
+
}, "Filter By:"), /*#__PURE__*/_react.default.createElement("div", {
|
|
103
|
+
className: "filters"
|
|
104
|
+
}, /*#__PURE__*/_react.default.createElement(_Bedroom.BedroomFilter, {
|
|
105
|
+
filters: filters.bedroom,
|
|
106
|
+
handleFilterChange: handleBedroomFilterChange,
|
|
107
|
+
currentFilters: bedroomFilters
|
|
108
|
+
}), /*#__PURE__*/_react.default.createElement(_ShortTermStyleFilter.ShortTermStyleFilter, {
|
|
109
|
+
filters: filters.style,
|
|
110
|
+
handleFilterChange: handleStyleFilterChange,
|
|
111
|
+
currentFilters: styleFilters
|
|
112
|
+
}))), /*#__PURE__*/_react.default.createElement("div", {
|
|
113
|
+
className: "filter-group"
|
|
114
|
+
}, /*#__PURE__*/_react.default.createElement("label", {
|
|
115
|
+
className: "filter-label"
|
|
116
|
+
}, "Sort By:"), /*#__PURE__*/_react.default.createElement("div", {
|
|
117
|
+
className: "filters"
|
|
118
|
+
}, /*#__PURE__*/_react.default.createElement(_ShortTermSort.ShortTermSort, {
|
|
119
|
+
sortBy: sortBy,
|
|
120
|
+
handleSortChange: handleSortChange
|
|
121
|
+
})))), /*#__PURE__*/_react.default.createElement("div", {
|
|
122
|
+
className: "pills"
|
|
123
|
+
}, bedroomFilters.sort(_Bedroom.sortBedrooms).map(bedroom => /*#__PURE__*/_react.default.createElement(_muncherUi.Pill, {
|
|
124
|
+
key: bedroom,
|
|
125
|
+
pillCloseHandler: () => {
|
|
126
|
+
handleBedroomFilterChange(bedroom);
|
|
127
|
+
}
|
|
128
|
+
}, bedroom + " bedroom")), styleFilters.map(style => /*#__PURE__*/_react.default.createElement(_muncherUi.Pill, {
|
|
129
|
+
key: style,
|
|
130
|
+
pillCloseHandler: () => {
|
|
131
|
+
handleStyleFilterChange(style);
|
|
132
|
+
}
|
|
133
|
+
}, (0, _Utils.capitalizeFirstLetter)((0, _Utils.enumToString)(style)))), floorplanIds.sort().map(floorplanId => /*#__PURE__*/_react.default.createElement(_muncherUi.Pill, {
|
|
134
|
+
key: floorplanId,
|
|
135
|
+
pillCloseHandler: () => {
|
|
136
|
+
handleFloorplanIdChange(floorplanId);
|
|
137
|
+
}
|
|
138
|
+
}, floorplanId)), /*#__PURE__*/_react.default.createElement("div", {
|
|
139
|
+
className: "filter-result"
|
|
140
|
+
}, /*#__PURE__*/_react.default.createElement(_muncherUi.Icon, {
|
|
141
|
+
name: "filter"
|
|
142
|
+
}), "\xA0Total: ", currentFloorplansCount, " Results"))));
|
|
143
|
+
};
|
|
144
|
+
exports.ShortTermFloorplansHeader = ShortTermFloorplansHeader;
|
|
145
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_muncherUi","_ShortTermService","_Bedroom","_ShortTermStyleFilter","_Utils","_ShortTermSort","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","prototype","hasOwnProperty","call","i","set","ShortTermFloorplansHeader","_ref","title","filters","floorplans","setCurrentFloorplans","isCondensed","currentFloorplansCount","defaultFloorplanStyle","defaultBedRooms","defaultMaxRent","defaultMinRent","defaultFloorplanIds","bedroomFilters","setBedroomFilters","useState","styleFilters","setStyleFilters","sortBy","setSortBy","floorplanIds","setFloorplanIds","currentFilters","handleSortAndFilter","withCurrentFilters","sortAndFilter","handleBedroomFilterChange","filter","index","indexOf","currentBedroomFilters","splice","push","handleFloorplanIdChange","floorplanId","currentFloorplanIds","handleStyleFilterChange","currentSyleFilters","handleSortChange","createElement","className","BedroomFilter","bedroom","handleFilterChange","ShortTermStyleFilter","style","ShortTermSort","sort","sortBedrooms","map","Pill","key","pillCloseHandler","capitalizeFirstLetter","enumToString","Icon","name","exports"],"sources":["../../src/short-term/ShortTermFloorplansHeader.tsx"],"sourcesContent":["import React, {useState} from \"react\";\nimport \"./assets/ShortTermFloorplansHeader.scss\";\nimport \"../floorplan/filter/assets/FloorplanDropDown.scss\";\nimport {Icon, Pill} from \"@contentmunch/muncher-ui\";\nimport {DefaultShortTermFilters} from \"./ShortTermFloorplansSection\";\nimport {CurrentShortTermFilters, ShortTermFilters, ShortTermSortBy} from \"./data/ShortTermFilters\";\nimport {FloorplanShortTerm, ShortTermStyle} from \"./data/ShortTerm\";\nimport {sortAndFilter} from \"./service/ShortTermService\";\nimport {BedroomFilter, sortBedrooms} from \"../floorplan/section/filter/Bedroom\";\nimport {ShortTermStyleFilter} from \"./ShortTermStyleFilter\";\nimport {capitalizeFirstLetter, enumToString} from \"../utils/Utils\";\nimport {ShortTermSort} from \"./ShortTermSort\";\n\n\nexport const ShortTermFloorplansHeader: React.FC<ShortTermFloorplansHeaderProps> = (\n    {\n        title,\n        filters,\n        floorplans,\n        setCurrentFloorplans,\n        isCondensed,\n        currentFloorplansCount,\n        defaultFloorplanStyle, defaultBedRooms, defaultMaxRent, defaultMinRent, defaultFloorplanIds\n    }) => {\n\n    const [bedroomFilters, setBedroomFilters] = useState<number[]>(defaultBedRooms ? [defaultBedRooms] : []);\n    const [styleFilters, setStyleFilters] = useState<ShortTermStyle[]>(defaultFloorplanStyle ? [defaultFloorplanStyle] : []);\n\n    const [sortBy, setSortBy] = useState<ShortTermSortBy>(\"priceAsc\");\n    const [floorplanIds, setFloorplanIds] = useState<string[]>(defaultFloorplanIds ? defaultFloorplanIds : []);\n\n    const currentFilters: CurrentShortTermFilters = {\n        bedroomFilters, styleFilters, sortBy, floorplanIds\n    };\n\n    const handleSortAndFilter = (withCurrentFilters: CurrentShortTermFilters) => {\n        setCurrentFloorplans(sortAndFilter(floorplans, withCurrentFilters));\n    };\n    const handleBedroomFilterChange = (filter: number) => {\n        const index = bedroomFilters.indexOf(filter);\n        const currentBedroomFilters = [...bedroomFilters];\n        if (index > -1) {\n            currentBedroomFilters.splice(index, 1);\n        } else {\n            currentBedroomFilters.push(filter);\n        }\n        setBedroomFilters(currentBedroomFilters);\n        handleSortAndFilter({...currentFilters, bedroomFilters: currentBedroomFilters});\n    };\n\n    const handleFloorplanIdChange = (floorplanId: string) => {\n        const index = floorplanIds.indexOf(floorplanId);\n        const currentFloorplanIds = [...floorplanIds];\n        if (index > -1) {\n            currentFloorplanIds.splice(index, 1);\n        }\n        setFloorplanIds(currentFloorplanIds);\n        handleSortAndFilter({...currentFilters, floorplanIds: currentFloorplanIds});\n    };\n    const handleStyleFilterChange = (filter: ShortTermStyle) => {\n        const index = styleFilters.indexOf(filter);\n        const currentSyleFilters = [...styleFilters];\n        if (index > -1) {\n            currentSyleFilters.splice(index, 1);\n        } else {\n            currentSyleFilters.push(filter);\n        }\n        setStyleFilters(currentSyleFilters);\n        handleSortAndFilter({...currentFilters, styleFilters: currentSyleFilters});\n    };\n    const handleSortChange = (sortBy: ShortTermSortBy) => {\n        setSortBy(sortBy);\n        handleSortAndFilter({...currentFilters, sortBy: sortBy});\n    }\n    return (\n        <header className=\"short-term-floorplans-header\">\n            <div className={isCondensed ? \"\" : \"container\"}>\n                <h2>{title}</h2>\n                <div className=\"units-filters\">\n                    <div className=\"filter-group\">\n                        <label className=\"filter-label\">Filter By:</label>\n                        <div className=\"filters\">\n                            <BedroomFilter filters={filters.bedroom} handleFilterChange={handleBedroomFilterChange}\n                                           currentFilters={bedroomFilters}/>\n\n                            <ShortTermStyleFilter filters={filters.style} handleFilterChange={handleStyleFilterChange}\n                                                  currentFilters={styleFilters}\n                            />\n                        </div>\n                    </div>\n                    <div className=\"filter-group\">\n                        <label className=\"filter-label\">Sort By:</label>\n                        <div className=\"filters\">\n                            <ShortTermSort sortBy={sortBy} handleSortChange={handleSortChange}/>\n                        </div>\n                    </div>\n                </div>\n                <div className=\"pills\">\n                    {bedroomFilters.sort(sortBedrooms).map(bedroom => (\n                        <Pill key={bedroom} pillCloseHandler={() => {\n                            handleBedroomFilterChange(bedroom)\n                        }}>\n                            {bedroom + \" bedroom\"}\n                        </Pill>\n                    ))}\n\n                    {styleFilters.map(style => (\n                        <Pill key={style} pillCloseHandler={() => {\n                            handleStyleFilterChange(style)\n                        }}>\n                            {capitalizeFirstLetter(enumToString(style))}\n                        </Pill>\n                    ))}\n                    {floorplanIds.sort().map(floorplanId => (\n                        <Pill key={floorplanId} pillCloseHandler={() => {\n                            handleFloorplanIdChange(floorplanId)\n                        }}>\n                            {floorplanId}\n                        </Pill>\n                    ))}\n                    <div className=\"filter-result\">\n                        <Icon name=\"filter\"/>&nbsp;Total: {currentFloorplansCount} Results\n                    </div>\n                </div>\n            </div>\n        </header>\n    );\n}\n\nexport interface ShortTermFloorplansHeaderProps extends DefaultShortTermFilters {\n    title?: string;\n    filters: ShortTermFilters;\n    floorplans: FloorplanShortTerm[];\n    setCurrentFloorplans: (floorplans: FloorplanShortTerm[]) => void;\n    isCondensed?: boolean;\n    currentFloorplansCount: number;\n}\n"],"mappings":"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"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import "./assets/ShortTermFloorplansSection.scss";
|
|
3
|
+
import { FloorplanShortTerm, ShortTermStyle } from "./data/ShortTerm";
|
|
4
|
+
export declare const ShortTermFloorplansSection: React.FC<ShortTermFloorplansSectionProps>;
|
|
5
|
+
export interface ShortTermFloorplansSectionProps extends DefaultShortTermFilters {
|
|
6
|
+
floorplans: FloorplanShortTerm[];
|
|
7
|
+
title?: string;
|
|
8
|
+
isCondensed?: boolean;
|
|
9
|
+
propertyId: string;
|
|
10
|
+
}
|
|
11
|
+
export interface DefaultShortTermFilters {
|
|
12
|
+
defaultBedRooms?: number;
|
|
13
|
+
defaultFloorplanStyle?: ShortTermStyle;
|
|
14
|
+
defaultMinRent?: number;
|
|
15
|
+
defaultMaxRent?: number;
|
|
16
|
+
defaultFloorplanIds?: string[];
|
|
17
|
+
}
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.ShortTermFloorplansSection = void 0;
|
|
7
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
8
|
+
require("./assets/ShortTermFloorplansSection.scss");
|
|
9
|
+
var _VideoModal = require("../asset/VideoModal");
|
|
10
|
+
var _ShortTermService = require("./service/ShortTermService");
|
|
11
|
+
var _ShortTermFloorplanCard = require("./ShortTermFloorplanCard");
|
|
12
|
+
var _ShortTermFloorplansHeader = require("./ShortTermFloorplansHeader");
|
|
13
|
+
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); }
|
|
14
|
+
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; }
|
|
15
|
+
const ShortTermFloorplansSection = _ref => {
|
|
16
|
+
let {
|
|
17
|
+
floorplans,
|
|
18
|
+
title,
|
|
19
|
+
isCondensed,
|
|
20
|
+
propertyId,
|
|
21
|
+
defaultFloorplanStyle,
|
|
22
|
+
defaultBedRooms,
|
|
23
|
+
defaultMaxRent,
|
|
24
|
+
defaultMinRent,
|
|
25
|
+
defaultFloorplanIds
|
|
26
|
+
} = _ref;
|
|
27
|
+
const [filteredFloorplans, setFilteredFloorplans] = (0, _react.useState)((0, _ShortTermService.sortAndFilter)(floorplans, {
|
|
28
|
+
bedroomFilters: defaultBedRooms ? [defaultBedRooms] : [],
|
|
29
|
+
styleFilters: defaultFloorplanStyle ? [defaultFloorplanStyle] : [],
|
|
30
|
+
sortBy: "priceAsc",
|
|
31
|
+
floorplanIds: defaultFloorplanIds ? defaultFloorplanIds : []
|
|
32
|
+
}));
|
|
33
|
+
const [showVideoModal, setShowVideoModal] = (0, _react.useState)(false);
|
|
34
|
+
const [video, setVideo] = (0, _react.useState)({});
|
|
35
|
+
const setCurrentFloorplans = currentFloorplans => {
|
|
36
|
+
setFilteredFloorplans(currentFloorplans);
|
|
37
|
+
};
|
|
38
|
+
const handleVideoClicked = data => {
|
|
39
|
+
setVideo(data);
|
|
40
|
+
setShowVideoModal(true);
|
|
41
|
+
};
|
|
42
|
+
return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("section", {
|
|
43
|
+
className: "section-short-term-floorplans"
|
|
44
|
+
}, /*#__PURE__*/_react.default.createElement(_VideoModal.VideoModal, {
|
|
45
|
+
video: video,
|
|
46
|
+
showModal: showVideoModal,
|
|
47
|
+
setShowModal: setShowVideoModal
|
|
48
|
+
}), /*#__PURE__*/_react.default.createElement("div", {
|
|
49
|
+
className: isCondensed ? "container" : ""
|
|
50
|
+
}, /*#__PURE__*/_react.default.createElement(_ShortTermFloorplansHeader.ShortTermFloorplansHeader, {
|
|
51
|
+
title: title,
|
|
52
|
+
filters: (0, _ShortTermService.shortTermFiltersFrom)(floorplans),
|
|
53
|
+
floorplans: floorplans,
|
|
54
|
+
setCurrentFloorplans: setCurrentFloorplans,
|
|
55
|
+
isCondensed: isCondensed,
|
|
56
|
+
currentFloorplansCount: filteredFloorplans.length,
|
|
57
|
+
defaultFloorplanStyle: defaultFloorplanStyle,
|
|
58
|
+
defaultBedRooms: defaultBedRooms,
|
|
59
|
+
defaultMaxRent: defaultMaxRent,
|
|
60
|
+
defaultMinRent: defaultMinRent,
|
|
61
|
+
defaultFloorplanIds: defaultFloorplanIds
|
|
62
|
+
}), /*#__PURE__*/_react.default.createElement("div", {
|
|
63
|
+
className: isCondensed ? "" : "container"
|
|
64
|
+
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
65
|
+
className: "floorplans-body"
|
|
66
|
+
}, filteredFloorplans.length === 0 ? /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("p", {
|
|
67
|
+
className: "floorplan-banner"
|
|
68
|
+
}, "No matches found...")) : filteredFloorplans.map((floorplan, i) => /*#__PURE__*/_react.default.createElement(_ShortTermFloorplanCard.ShortTermFloorplanCard, {
|
|
69
|
+
floorplan: floorplan,
|
|
70
|
+
key: i,
|
|
71
|
+
propertyId: propertyId,
|
|
72
|
+
videoClickHandler: handleVideoClicked
|
|
73
|
+
})))))));
|
|
74
|
+
};
|
|
75
|
+
exports.ShortTermFloorplansSection = ShortTermFloorplansSection;
|
|
76
|
+
ShortTermFloorplansSection.defaultProps = {
|
|
77
|
+
title: "Floor plans",
|
|
78
|
+
isCondensed: true
|
|
79
|
+
};
|
|
80
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_VideoModal","_ShortTermService","_ShortTermFloorplanCard","_ShortTermFloorplansHeader","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","prototype","hasOwnProperty","call","i","set","ShortTermFloorplansSection","_ref","floorplans","title","isCondensed","propertyId","defaultFloorplanStyle","defaultBedRooms","defaultMaxRent","defaultMinRent","defaultFloorplanIds","filteredFloorplans","setFilteredFloorplans","useState","sortAndFilter","bedroomFilters","styleFilters","sortBy","floorplanIds","showVideoModal","setShowVideoModal","video","setVideo","setCurrentFloorplans","currentFloorplans","handleVideoClicked","data","createElement","Fragment","className","VideoModal","showModal","setShowModal","ShortTermFloorplansHeader","filters","shortTermFiltersFrom","currentFloorplansCount","length","map","floorplan","ShortTermFloorplanCard","key","videoClickHandler","exports","defaultProps"],"sources":["../../src/short-term/ShortTermFloorplansSection.tsx"],"sourcesContent":["import React, {useState} from \"react\";\nimport \"./assets/ShortTermFloorplansSection.scss\";\nimport {Video} from \"../asset/data/Asset\";\nimport {VideoModal} from \"../asset/VideoModal\";\nimport {FloorplanShortTerm, ShortTermStyle} from \"./data/ShortTerm\";\nimport {shortTermFiltersFrom, sortAndFilter} from \"./service/ShortTermService\";\nimport {ShortTermFloorplanCard} from \"./ShortTermFloorplanCard\";\nimport {ShortTermFloorplansHeader} from \"./ShortTermFloorplansHeader\";\n\nexport const ShortTermFloorplansSection: React.FC<ShortTermFloorplansSectionProps> = (\n    {\n        floorplans, title, isCondensed, propertyId,\n        defaultFloorplanStyle, defaultBedRooms, defaultMaxRent, defaultMinRent, defaultFloorplanIds\n    }) => {\n    const [filteredFloorplans, setFilteredFloorplans] = useState<FloorplanShortTerm[]>(sortAndFilter(floorplans, {\n        bedroomFilters: defaultBedRooms ? [defaultBedRooms] : [],\n        styleFilters: defaultFloorplanStyle ? [defaultFloorplanStyle] : [],\n        sortBy: \"priceAsc\",\n        floorplanIds: defaultFloorplanIds ? defaultFloorplanIds : []\n    }));\n\n    const [showVideoModal, setShowVideoModal] = useState(false);\n    const [video, setVideo] = useState<Video>({} as Video);\n\n    const setCurrentFloorplans = (currentFloorplans: FloorplanShortTerm[]) => {\n        setFilteredFloorplans(currentFloorplans);\n    }\n\n    const handleVideoClicked = (data: Video) => {\n        setVideo(data);\n        setShowVideoModal(true);\n    };\n\n    return (\n        <>\n            <section className=\"section-short-term-floorplans\">\n                <VideoModal video={video} showModal={showVideoModal} setShowModal={setShowVideoModal}/>\n                <div className={isCondensed ? \"container\" : \"\"}>\n                    <ShortTermFloorplansHeader title={title} filters={shortTermFiltersFrom(floorplans)}\n                                               floorplans={floorplans}\n                                               setCurrentFloorplans={setCurrentFloorplans}\n                                               isCondensed={isCondensed}\n                                               currentFloorplansCount={filteredFloorplans.length}\n                                               defaultFloorplanStyle={defaultFloorplanStyle}\n                                               defaultBedRooms={defaultBedRooms}\n                                               defaultMaxRent={defaultMaxRent}\n                                               defaultMinRent={defaultMinRent}\n                                               defaultFloorplanIds={defaultFloorplanIds}\n                    />\n\n                    <div className={isCondensed ? \"\" : \"container\"}>\n                        <div className=\"floorplans-body\">\n\n                            {\n                                filteredFloorplans.length === 0 ?\n                                    <>\n                                        <p className=\"floorplan-banner\">No matches found...</p>\n                                    </> :\n                                    filteredFloorplans.map((floorplan, i) => (\n                                        <ShortTermFloorplanCard floorplan={floorplan} key={i} propertyId={propertyId}\n                                                                videoClickHandler={handleVideoClicked}/>))\n                            }\n                        </div>\n                    </div>\n                </div>\n            </section>\n        </>\n    );\n};\n\nexport interface ShortTermFloorplansSectionProps extends DefaultShortTermFilters {\n    floorplans: FloorplanShortTerm[];\n    title?: string;\n    isCondensed?: boolean;\n    propertyId: string;\n}\n\nexport interface DefaultShortTermFilters {\n    defaultBedRooms?: number;\n    defaultFloorplanStyle?: ShortTermStyle;\n    defaultMinRent?: number;\n    defaultMaxRent?: number;\n    defaultFloorplanIds?: string[];\n}\n\nShortTermFloorplansSection.defaultProps = {\n    title: \"Floor plans\",\n    isCondensed: true,\n}\n"],"mappings":"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"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import "./assets/ShortTermPricingCard.scss";
|
|
3
|
+
import { FloorplanShortTerm } from "./data/ShortTerm";
|
|
4
|
+
export declare const ShortTermPricingCard: React.FC<ShortTermPricingCardProps>;
|
|
5
|
+
export interface ShortTermPricingCardProps {
|
|
6
|
+
floorplans: FloorplanShortTerm[];
|
|
7
|
+
}
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.ShortTermPricingCard = void 0;
|
|
7
|
+
var _react = _interopRequireDefault(require("react"));
|
|
8
|
+
require("./assets/ShortTermPricingCard.scss");
|
|
9
|
+
var _Utils = require("../utils/Utils");
|
|
10
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
11
|
+
const ShortTermPricingCard = _ref => {
|
|
12
|
+
let {
|
|
13
|
+
floorplans
|
|
14
|
+
} = _ref;
|
|
15
|
+
const generatePricingRow = floorplan => /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("div", {
|
|
16
|
+
className: "col"
|
|
17
|
+
}, floorplan.bedroom, "-", (0, _Utils.capitalizeFirstLetter)((0, _Utils.enumToString)(floorplan.style))), /*#__PURE__*/_react.default.createElement("div", {
|
|
18
|
+
className: "col"
|
|
19
|
+
}, floorplan.bathroom), /*#__PURE__*/_react.default.createElement("div", {
|
|
20
|
+
className: "col"
|
|
21
|
+
}, floorplan.shortTerm.squareFoot, "+"), /*#__PURE__*/_react.default.createElement("div", {
|
|
22
|
+
className: "col"
|
|
23
|
+
}, "Call or Text"), /*#__PURE__*/_react.default.createElement("div", {
|
|
24
|
+
className: "col"
|
|
25
|
+
}, (0, _Utils.toUSD)(floorplan.shortTerm.priceFor5To13Days), "/day + tax"), /*#__PURE__*/_react.default.createElement("div", {
|
|
26
|
+
className: "col"
|
|
27
|
+
}, (0, _Utils.toUSD)(floorplan.shortTerm.priceFor14To29Days), "/day + tax"), /*#__PURE__*/_react.default.createElement("div", {
|
|
28
|
+
className: "col"
|
|
29
|
+
}, (0, _Utils.toUSD)(floorplan.shortTerm.priceFor1To4Months), "/day/ ", (0, _Utils.toUSD)(floorplan.shortTerm.priceFor1To4Months * 30), "/mo"), /*#__PURE__*/_react.default.createElement("div", {
|
|
30
|
+
className: "col"
|
|
31
|
+
}, (0, _Utils.toUSD)(floorplan.shortTerm.priceFor4andMoreMonths), "/day/ ", (0, _Utils.toUSD)(floorplan.shortTerm.priceFor4andMoreMonths * 30), "/mo"));
|
|
32
|
+
return /*#__PURE__*/_react.default.createElement("section", {
|
|
33
|
+
className: "section-pricing-card"
|
|
34
|
+
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
35
|
+
className: "container"
|
|
36
|
+
}, /*#__PURE__*/_react.default.createElement("h2", {
|
|
37
|
+
className: "heading"
|
|
38
|
+
}, /*#__PURE__*/_react.default.createElement("span", {
|
|
39
|
+
className: "emphasized"
|
|
40
|
+
}, "Short Term Pricing")), /*#__PURE__*/_react.default.createElement("div", {
|
|
41
|
+
className: "container"
|
|
42
|
+
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
43
|
+
className: "row"
|
|
44
|
+
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
45
|
+
className: "col head"
|
|
46
|
+
}, "bedrooms"), /*#__PURE__*/_react.default.createElement("div", {
|
|
47
|
+
className: "col head"
|
|
48
|
+
}, "bath"), /*#__PURE__*/_react.default.createElement("div", {
|
|
49
|
+
className: "col head"
|
|
50
|
+
}, "sq. ft."), /*#__PURE__*/_react.default.createElement("div", {
|
|
51
|
+
className: "col head tall"
|
|
52
|
+
}, "2-4 days ", /*#__PURE__*/_react.default.createElement("br", null), "immediate only"), /*#__PURE__*/_react.default.createElement("div", {
|
|
53
|
+
className: "col head tall"
|
|
54
|
+
}, "5-13 days"), /*#__PURE__*/_react.default.createElement("div", {
|
|
55
|
+
className: "col head"
|
|
56
|
+
}, "14-29 days"), /*#__PURE__*/_react.default.createElement("div", {
|
|
57
|
+
className: "col head"
|
|
58
|
+
}, "1-4 months"), /*#__PURE__*/_react.default.createElement("div", {
|
|
59
|
+
className: "col head"
|
|
60
|
+
}, "4+ months"), floorplans.sort((a, b) => parseInt(a.name) - parseInt(b.name)).map(floorplan => generatePricingRow(floorplan))))));
|
|
61
|
+
};
|
|
62
|
+
exports.ShortTermPricingCard = ShortTermPricingCard;
|
|
63
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_Utils","obj","__esModule","default","ShortTermPricingCard","_ref","floorplans","generatePricingRow","floorplan","createElement","Fragment","className","bedroom","capitalizeFirstLetter","enumToString","style","bathroom","shortTerm","squareFoot","toUSD","priceFor5To13Days","priceFor14To29Days","priceFor1To4Months","priceFor4andMoreMonths","sort","a","b","parseInt","name","map","exports"],"sources":["../../src/short-term/ShortTermPricingCard.tsx"],"sourcesContent":["import React from \"react\";\nimport \"./assets/ShortTermPricingCard.scss\";\nimport {capitalizeFirstLetter, enumToString, toUSD} from \"../utils/Utils\";\nimport {FloorplanShortTerm} from \"./data/ShortTerm\";\n\nexport const ShortTermPricingCard: React.FC<ShortTermPricingCardProps> = ({floorplans}) => {\n\n    const generatePricingRow = (floorplan: FloorplanShortTerm) =>\n        <>\n            <div className=\"col\">\n                {floorplan.bedroom}-{capitalizeFirstLetter(enumToString(floorplan.style))}\n            </div>\n            <div className=\"col\">\n                {floorplan.bathroom}\n            </div>\n            <div className=\"col\">\n                {floorplan.shortTerm.squareFoot}+\n            </div>\n            <div className=\"col\">\n                Call or Text\n            </div>\n            <div className=\"col\">\n                {toUSD(floorplan.shortTerm.priceFor5To13Days)}/day + tax\n            </div>\n            <div className=\"col\">\n                {toUSD(floorplan.shortTerm.priceFor14To29Days)}/day + tax\n            </div>\n            <div className=\"col\">\n                {toUSD(floorplan.shortTerm.priceFor1To4Months)}/day/ {toUSD(floorplan.shortTerm.priceFor1To4Months * 30)}/mo\n            </div>\n            <div className=\"col\">\n                {toUSD(floorplan.shortTerm.priceFor4andMoreMonths)}/day/ {toUSD(floorplan.shortTerm.priceFor4andMoreMonths * 30)}/mo\n            </div>\n        </>\n\n    return (\n\n        <section className=\"section-pricing-card\">\n            <div className=\"container\">\n                <h2 className=\"heading\"><span className=\"emphasized\">Short Term Pricing</span></h2>\n                <div className=\"container\">\n                    <div className=\"row\">\n                        <div className=\"col head\">\n                            bedrooms\n                        </div>\n                        <div className=\"col head\">\n                            bath\n                        </div>\n                        <div className=\"col head\">\n                            sq. ft.\n                        </div>\n                        <div className=\"col head tall\">\n                            2-4 days <br/>immediate only\n                        </div>\n                        <div className=\"col head tall\">\n                            5-13 days\n                        </div>\n                        <div className=\"col head\">\n                            14-29 days\n                        </div>\n                        <div className=\"col head\">\n                            1-4 months\n                        </div>\n                        <div className=\"col head\">\n                            4+ months\n                        </div>\n                        {\n                            floorplans.sort((a, b) => parseInt(a.name) - parseInt(b.name)).map(floorplan => generatePricingRow(floorplan))\n                        }\n                    </div>\n                </div>\n\n            </div>\n        </section>\n\n    );\n};\n\nexport interface ShortTermPricingCardProps {\n    floorplans: FloorplanShortTerm[]\n}\n"],"mappings":"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"}
|