@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.
Files changed (40) hide show
  1. package/lib/data/RenaissanceData.d.ts +2 -0
  2. package/lib/data/RenaissanceData.js +4 -2
  3. package/lib/floorplan/data/Floorplan.d.ts +2 -1
  4. package/lib/floorplan/data/Floorplan.js +1 -1
  5. package/lib/floorplan/section/FloorplanSection.js +1 -1
  6. package/lib/floorplan/service/FloorplanService.js +24 -23
  7. package/lib/index.d.ts +4 -0
  8. package/lib/index.js +35 -1
  9. package/lib/property/data/Property.d.ts +5 -0
  10. package/lib/property/data/Property.js +7 -2
  11. package/lib/short-term/ShortTermFloorplanCard.d.ts +11 -0
  12. package/lib/short-term/ShortTermFloorplanCard.js +105 -0
  13. package/lib/short-term/ShortTermFloorplanHero.d.ts +12 -0
  14. package/lib/short-term/ShortTermFloorplanHero.js +198 -0
  15. package/lib/short-term/ShortTermFloorplanSection.d.ts +10 -0
  16. package/lib/short-term/ShortTermFloorplanSection.js +134 -0
  17. package/lib/short-term/ShortTermFloorplansHeader.d.ts +15 -0
  18. package/lib/short-term/ShortTermFloorplansHeader.js +145 -0
  19. package/lib/short-term/ShortTermFloorplansSection.d.ts +17 -0
  20. package/lib/short-term/ShortTermFloorplansSection.js +80 -0
  21. package/lib/short-term/ShortTermPricingCard.d.ts +7 -0
  22. package/lib/short-term/ShortTermPricingCard.js +63 -0
  23. package/lib/short-term/ShortTermSort.d.ts +7 -0
  24. package/lib/short-term/ShortTermSort.js +41 -0
  25. package/lib/short-term/ShortTermStyleFilter.d.ts +8 -0
  26. package/lib/short-term/ShortTermStyleFilter.js +31 -0
  27. package/lib/short-term/assets/ShortTermFloorplanCard.scss +232 -0
  28. package/lib/short-term/assets/ShortTermFloorplanHero.scss +165 -0
  29. package/lib/short-term/assets/ShortTermFloorplanSection.scss +124 -0
  30. package/lib/short-term/assets/ShortTermFloorplansHeader.scss +70 -0
  31. package/lib/short-term/assets/ShortTermFloorplansSection.scss +18 -0
  32. package/lib/short-term/assets/ShortTermPricingCard.scss +59 -0
  33. package/lib/short-term/data/ShortTerm.d.ts +44 -0
  34. package/lib/short-term/data/ShortTerm.js +14 -0
  35. package/lib/short-term/data/ShortTermFilters.d.ts +16 -0
  36. package/lib/short-term/data/ShortTermFilters.js +41 -0
  37. package/lib/short-term/service/ShortTermService.d.ts +7 -0
  38. package/lib/short-term/service/ShortTermService.js +54 -0
  39. package/lib/utils/Utils.js +3 -2
  40. 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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"}
@@ -0,0 +1,7 @@
1
+ import React from "react";
2
+ import { ShortTermSortBy } from "./data/ShortTermFilters";
3
+ export declare const ShortTermSort: React.FC<SortProps>;
4
+ export interface SortProps {
5
+ sortBy: ShortTermSortBy;
6
+ handleSortChange: (sortBy: ShortTermSortBy) => void;
7
+ }