@renaissancerentals/renaissance-component 12.1.14 → 12.1.15
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/floorplan/data/Floorplan.js +1 -1
- package/lib/floorplan/service/FloorplanService.js +21 -21
- package/lib/index.d.ts +4 -0
- package/lib/index.js +35 -1
- package/lib/short-term/ShortTermFloorplanCard.d.ts +11 -0
- package/lib/short-term/ShortTermFloorplanCard.js +105 -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/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 +39 -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,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,41 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.ShortTermSort = void 0;
|
|
7
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
8
|
+
var _muncherUi = require("@contentmunch/muncher-ui");
|
|
9
|
+
var _ShortTermFilters = require("./data/ShortTermFilters");
|
|
10
|
+
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); }
|
|
11
|
+
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; }
|
|
12
|
+
const ShortTermSort = _ref => {
|
|
13
|
+
let {
|
|
14
|
+
sortBy,
|
|
15
|
+
handleSortChange
|
|
16
|
+
} = _ref;
|
|
17
|
+
const [showSortDropDown, setShowSortDropDown] = (0, _react.useState)(false);
|
|
18
|
+
return /*#__PURE__*/_react.default.createElement("div", {
|
|
19
|
+
className: "unit-dropdown"
|
|
20
|
+
}, /*#__PURE__*/_react.default.createElement(_muncherUi.DropdownButton, {
|
|
21
|
+
element: /*#__PURE__*/_react.default.createElement("h5", null, _ShortTermFilters.ShortTermSortFields[sortBy].element, "\xA0\xA0", /*#__PURE__*/_react.default.createElement("span", {
|
|
22
|
+
className: "small"
|
|
23
|
+
}, "\u25BC")),
|
|
24
|
+
showContent: showSortDropDown,
|
|
25
|
+
setShowContent: setShowSortDropDown,
|
|
26
|
+
size: "medium",
|
|
27
|
+
variant: "primary",
|
|
28
|
+
drop: "left"
|
|
29
|
+
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
30
|
+
className: "sort-filters"
|
|
31
|
+
}, Object.keys(_ShortTermFilters.ShortTermSortFields).map(sortField => /*#__PURE__*/_react.default.createElement(_muncherUi.Button, {
|
|
32
|
+
key: sortField,
|
|
33
|
+
active: sortBy === sortField,
|
|
34
|
+
onClick: () => {
|
|
35
|
+
handleSortChange(sortField);
|
|
36
|
+
setShowSortDropDown(false);
|
|
37
|
+
}
|
|
38
|
+
}, _ShortTermFilters.ShortTermSortFields[sortField].element)))));
|
|
39
|
+
};
|
|
40
|
+
exports.ShortTermSort = ShortTermSort;
|
|
41
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVXaWxkY2FyZCIsInJlcXVpcmUiLCJfbXVuY2hlclVpIiwiX1Nob3J0VGVybUZpbHRlcnMiLCJfZ2V0UmVxdWlyZVdpbGRjYXJkQ2FjaGUiLCJlIiwiV2Vha01hcCIsInIiLCJ0IiwiX19lc01vZHVsZSIsImRlZmF1bHQiLCJoYXMiLCJnZXQiLCJuIiwiX19wcm90b19fIiwiYSIsIk9iamVjdCIsImRlZmluZVByb3BlcnR5IiwiZ2V0T3duUHJvcGVydHlEZXNjcmlwdG9yIiwidSIsInByb3RvdHlwZSIsImhhc093blByb3BlcnR5IiwiY2FsbCIsImkiLCJzZXQiLCJTaG9ydFRlcm1Tb3J0IiwiX3JlZiIsInNvcnRCeSIsImhhbmRsZVNvcnRDaGFuZ2UiLCJzaG93U29ydERyb3BEb3duIiwic2V0U2hvd1NvcnREcm9wRG93biIsInVzZVN0YXRlIiwiY3JlYXRlRWxlbWVudCIsImNsYXNzTmFtZSIsIkRyb3Bkb3duQnV0dG9uIiwiZWxlbWVudCIsIlNob3J0VGVybVNvcnRGaWVsZHMiLCJzaG93Q29udGVudCIsInNldFNob3dDb250ZW50Iiwic2l6ZSIsInZhcmlhbnQiLCJkcm9wIiwia2V5cyIsIm1hcCIsInNvcnRGaWVsZCIsIkJ1dHRvbiIsImtleSIsImFjdGl2ZSIsIm9uQ2xpY2siLCJleHBvcnRzIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL3Nob3J0LXRlcm0vU2hvcnRUZXJtU29ydC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7dXNlU3RhdGV9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHtCdXR0b24sIERyb3Bkb3duQnV0dG9ufSBmcm9tIFwiQGNvbnRlbnRtdW5jaC9tdW5jaGVyLXVpXCI7XG5pbXBvcnQge1Nob3J0VGVybVNvcnRCeSwgU2hvcnRUZXJtU29ydEZpZWxkc30gZnJvbSBcIi4vZGF0YS9TaG9ydFRlcm1GaWx0ZXJzXCI7XG5cbmV4cG9ydCBjb25zdCBTaG9ydFRlcm1Tb3J0OiBSZWFjdC5GQzxTb3J0UHJvcHM+ID0gKHtzb3J0QnksIGhhbmRsZVNvcnRDaGFuZ2V9KSA9PiB7XG4gICAgY29uc3QgW3Nob3dTb3J0RHJvcERvd24sIHNldFNob3dTb3J0RHJvcERvd25dID0gdXNlU3RhdGUoZmFsc2UpO1xuXG4gICAgcmV0dXJuIChcbiAgICAgICAgPGRpdiBjbGFzc05hbWU9XCJ1bml0LWRyb3Bkb3duXCI+XG4gICAgICAgICAgICA8RHJvcGRvd25CdXR0b25cbiAgICAgICAgICAgICAgICBlbGVtZW50PXs8aDU+e1Nob3J0VGVybVNvcnRGaWVsZHNbc29ydEJ5XS5lbGVtZW50fSZuYnNwOyZuYnNwOzxzcGFuXG4gICAgICAgICAgICAgICAgICAgIGNsYXNzTmFtZT1cInNtYWxsXCI+4pa8PC9zcGFuPjwvaDU+fVxuICAgICAgICAgICAgICAgIHNob3dDb250ZW50PXtzaG93U29ydERyb3BEb3dufVxuICAgICAgICAgICAgICAgIHNldFNob3dDb250ZW50PXtzZXRTaG93U29ydERyb3BEb3dufVxuICAgICAgICAgICAgICAgIHNpemU9XCJtZWRpdW1cIlxuICAgICAgICAgICAgICAgIHZhcmlhbnQ9XCJwcmltYXJ5XCJcbiAgICAgICAgICAgICAgICBkcm9wPVwibGVmdFwiXG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgPGRpdiBjbGFzc05hbWU9XCJzb3J0LWZpbHRlcnNcIj5cbiAgICAgICAgICAgICAgICAgICAge09iamVjdC5rZXlzKFNob3J0VGVybVNvcnRGaWVsZHMpLm1hcCgoc29ydEZpZWxkKSA9PiAoXG4gICAgICAgICAgICAgICAgICAgICAgICA8QnV0dG9uXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAga2V5PXtzb3J0RmllbGR9XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgYWN0aXZlPXtzb3J0QnkgPT09IHNvcnRGaWVsZH1cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBvbkNsaWNrPXsoKSA9PiB7XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGhhbmRsZVNvcnRDaGFuZ2Uoc29ydEZpZWxkKTtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgc2V0U2hvd1NvcnREcm9wRG93bihmYWxzZSk7XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgfX0+XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAge1Nob3J0VGVybVNvcnRGaWVsZHNbc29ydEZpZWxkXS5lbGVtZW50fVxuICAgICAgICAgICAgICAgICAgICAgICAgPC9CdXR0b24+XG4gICAgICAgICAgICAgICAgICAgICkpfVxuICAgICAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgPC9Ecm9wZG93bkJ1dHRvbj5cbiAgICAgICAgPC9kaXY+XG4gICAgKTtcbn07XG5cbmV4cG9ydCBpbnRlcmZhY2UgU29ydFByb3BzIHtcbiAgICBzb3J0Qnk6IFNob3J0VGVybVNvcnRCeTtcbiAgICBoYW5kbGVTb3J0Q2hhbmdlOiAoc29ydEJ5OiBTaG9ydFRlcm1Tb3J0QnkpID0+IHZvaWQ7XG59XG4iXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLElBQUFBLE1BQUEsR0FBQUMsdUJBQUEsQ0FBQUMsT0FBQTtBQUNBLElBQUFDLFVBQUEsR0FBQUQsT0FBQTtBQUNBLElBQUFFLGlCQUFBLEdBQUFGLE9BQUE7QUFBNkUsU0FBQUcseUJBQUFDLENBQUEsNkJBQUFDLE9BQUEsbUJBQUFDLENBQUEsT0FBQUQsT0FBQSxJQUFBRSxDQUFBLE9BQUFGLE9BQUEsWUFBQUYsd0JBQUEsWUFBQUEsQ0FBQUMsQ0FBQSxXQUFBQSxDQUFBLEdBQUFHLENBQUEsR0FBQUQsQ0FBQSxLQUFBRixDQUFBO0FBQUEsU0FBQUwsd0JBQUFLLENBQUEsRUFBQUUsQ0FBQSxTQUFBQSxDQUFBLElBQUFGLENBQUEsSUFBQUEsQ0FBQSxDQUFBSSxVQUFBLFNBQUFKLENBQUEsZUFBQUEsQ0FBQSx1QkFBQUEsQ0FBQSx5QkFBQUEsQ0FBQSxXQUFBSyxPQUFBLEVBQUFMLENBQUEsUUFB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
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { ShortTermStyle } from "./data/ShortTerm";
|
|
3
|
+
export declare const ShortTermStyleFilter: React.FC<StyleFilterProps>;
|
|
4
|
+
export interface StyleFilterProps {
|
|
5
|
+
filters: Set<ShortTermStyle>;
|
|
6
|
+
handleFilterChange: (filter: ShortTermStyle) => void;
|
|
7
|
+
currentFilters: string[];
|
|
8
|
+
}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.ShortTermStyleFilter = void 0;
|
|
7
|
+
var _react = _interopRequireDefault(require("react"));
|
|
8
|
+
var _muncherUi = require("@contentmunch/muncher-ui");
|
|
9
|
+
var _FloorplanDropDown = require("../floorplan/filter/FloorplanDropDown");
|
|
10
|
+
var _Utils = require("../utils/Utils");
|
|
11
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
12
|
+
const ShortTermStyleFilter = _ref => {
|
|
13
|
+
let {
|
|
14
|
+
filters,
|
|
15
|
+
handleFilterChange,
|
|
16
|
+
currentFilters
|
|
17
|
+
} = _ref;
|
|
18
|
+
return /*#__PURE__*/_react.default.createElement(_FloorplanDropDown.DropDownFilter, {
|
|
19
|
+
label: "Home Type"
|
|
20
|
+
}, Array.from(filters.keys()).map(filter => /*#__PURE__*/_react.default.createElement(_muncherUi.Checkbox, {
|
|
21
|
+
key: filter,
|
|
22
|
+
label: (0, _Utils.capitalizeFirstLetter)((0, _Utils.enumToString)(filter)),
|
|
23
|
+
name: filter,
|
|
24
|
+
onChange: () => {
|
|
25
|
+
handleFilterChange(filter);
|
|
26
|
+
},
|
|
27
|
+
checked: () => currentFilters.indexOf(filter) > -1
|
|
28
|
+
})));
|
|
29
|
+
};
|
|
30
|
+
exports.ShortTermStyleFilter = ShortTermStyleFilter;
|
|
31
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIl9tdW5jaGVyVWkiLCJfRmxvb3JwbGFuRHJvcERvd24iLCJfVXRpbHMiLCJvYmoiLCJfX2VzTW9kdWxlIiwiZGVmYXVsdCIsIlNob3J0VGVybVN0eWxlRmlsdGVyIiwiX3JlZiIsImZpbHRlcnMiLCJoYW5kbGVGaWx0ZXJDaGFuZ2UiLCJjdXJyZW50RmlsdGVycyIsImNyZWF0ZUVsZW1lbnQiLCJEcm9wRG93bkZpbHRlciIsImxhYmVsIiwiQXJyYXkiLCJmcm9tIiwia2V5cyIsIm1hcCIsImZpbHRlciIsIkNoZWNrYm94Iiwia2V5IiwiY2FwaXRhbGl6ZUZpcnN0TGV0dGVyIiwiZW51bVRvU3RyaW5nIiwibmFtZSIsIm9uQ2hhbmdlIiwiY2hlY2tlZCIsImluZGV4T2YiLCJleHBvcnRzIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL3Nob3J0LXRlcm0vU2hvcnRUZXJtU3R5bGVGaWx0ZXIudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCB7Q2hlY2tib3h9IGZyb20gXCJAY29udGVudG11bmNoL211bmNoZXItdWlcIjtcbmltcG9ydCB7U2hvcnRUZXJtU3R5bGV9IGZyb20gXCIuL2RhdGEvU2hvcnRUZXJtXCI7XG5pbXBvcnQge0Ryb3BEb3duRmlsdGVyfSBmcm9tIFwiLi4vZmxvb3JwbGFuL2ZpbHRlci9GbG9vcnBsYW5Ecm9wRG93blwiO1xuaW1wb3J0IHtjYXBpdGFsaXplRmlyc3RMZXR0ZXIsIGVudW1Ub1N0cmluZ30gZnJvbSBcIi4uL3V0aWxzL1V0aWxzXCI7XG5cbmV4cG9ydCBjb25zdCBTaG9ydFRlcm1TdHlsZUZpbHRlcjogUmVhY3QuRkM8U3R5bGVGaWx0ZXJQcm9wcz4gPSAoe2ZpbHRlcnMsIGhhbmRsZUZpbHRlckNoYW5nZSwgY3VycmVudEZpbHRlcnN9KSA9PiB7XG5cbiAgICByZXR1cm4gKFxuICAgICAgICA8RHJvcERvd25GaWx0ZXIgbGFiZWw9XCJIb21lIFR5cGVcIj5cbiAgICAgICAgICAgIHtBcnJheS5mcm9tKGZpbHRlcnMua2V5cygpKS5tYXAoKGZpbHRlcjogU2hvcnRUZXJtU3R5bGUpID0+IChcbiAgICAgICAgICAgICAgICA8Q2hlY2tib3gga2V5PXtmaWx0ZXJ9IGxhYmVsPXtjYXBpdGFsaXplRmlyc3RMZXR0ZXIoZW51bVRvU3RyaW5nKGZpbHRlcikpfSBuYW1lPXtmaWx0ZXJ9XG4gICAgICAgICAgICAgICAgICAgICAgICAgIG9uQ2hhbmdlPXsoKSA9PiB7XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICBoYW5kbGVGaWx0ZXJDaGFuZ2UoZmlsdGVyKVxuICAgICAgICAgICAgICAgICAgICAgICAgICB9fVxuICAgICAgICAgICAgICAgICAgICAgICAgICBjaGVja2VkPXsoKSA9PiBjdXJyZW50RmlsdGVycy5pbmRleE9mKGZpbHRlcikgPiAtMX1cbiAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgKSl9XG4gICAgICAgIDwvRHJvcERvd25GaWx0ZXI+XG4gICAgKTtcbn07XG5cbmV4cG9ydCBpbnRlcmZhY2UgU3R5bGVGaWx0ZXJQcm9wcyB7XG4gICAgZmlsdGVyczogU2V0PFNob3J0VGVybVN0eWxlPjtcbiAgICBoYW5kbGVGaWx0ZXJDaGFuZ2U6IChmaWx0ZXI6IFNob3J0VGVybVN0eWxlKSA9PiB2b2lkO1xuICAgIGN1cnJlbnRGaWx0ZXJzOiBzdHJpbmdbXTtcbn1cbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsSUFBQUEsTUFBQSxHQUFBQyxzQkFBQSxDQUFBQyxPQUFBO0FBQ0EsSUFBQUMsVUFBQSxHQUFBRCxPQUFBO0FBRUEsSUFBQUUsa0JBQUEsR0FBQUYsT0FBQTtBQUNBLElBQUFHLE1BQUEsR0FBQUgsT0FBQTtBQUFtRSxTQUFBRCx1QkFBQUssR0FBQSxXQUFBQSxHQUFBLElBQUFBLEdBQUEsQ0FBQUMsVUFBQSxHQUFBRCxHQUFBLEtBQUFFLE9BQUEsRUFBQUYsR0FBQTtBQUU1RCxNQUFNRyxvQkFBZ0QsR0FBR0MsSUFBQSxJQUFtRDtFQUFBLElBQWxEO0lBQUNDLE9BQU87SUFBRUMsa0JBQWtCO0lBQUVDO0VBQWMsQ0FBQyxHQUFBSCxJQUFBO0VBRTFHLG9CQUNJVixNQUFBLENBQUFRLE9BQUEsQ0FBQU0sYUFBQSxDQUFDVixrQkFBQSxDQUFBVyxjQUFjO0lBQUNDLEtBQUssRUFBQztFQUFXLEdBQzVCQyxLQUFLLENBQUNDLElBQUksQ0FBQ1AsT0FBTyxDQUFDUSxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUNDLEdBQUcsQ0FBRUMsTUFBc0IsaUJBQ25EckIsTUFBQSxDQUFBUSxPQUFBLENBQUFNLGFBQUEsQ0FBQ1gsVUFBQSxDQUFBbUIsUUFBUTtJQUFDQyxHQUFHLEVBQUVGLE1BQU87SUFBQ0wsS0FBSyxFQUFFLElBQUFRLDRCQUFxQixFQUFDLElBQUFDLG1CQUFZLEVBQUNKLE1BQU0sQ0FBQyxDQUFFO0lBQUNLLElBQUksRUFBRUwsTUFBTztJQUM5RU0sUUFBUSxFQUFFQSxDQUFBLEtBQU07TUFDWmYsa0JBQWtCLENBQUNTLE1BQU0sQ0FBQztJQUM5QixDQUFFO0lBQ0ZPLE9BQU8sRUFBRUEsQ0FBQSxLQUFNZixjQUFjLENBQUNnQixPQUFPLENBQUNSLE1BQU0sQ0FBQyxHQUFHLENBQUM7RUFBRSxDQUM1RCxDQUNKLENBQ1csQ0FBQztBQUV6QixDQUFDO0FBQUNTLE9BQUEsQ0FBQXJCLG9CQUFBLEdBQUFBLG9CQUFBIn0=
|