@renaissancerentals/renaissance-component 12.2.10 → 12.2.11
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/data/Calendar.js +21 -0
- package/lib/data/SortField.d.ts +10 -0
- package/lib/data/SortField.js +62 -0
- package/lib/floorplan/card/FloorplanCard.js +3 -1
- package/lib/floorplan/data/Floorplan.d.ts +10 -2
- package/lib/floorplan/data/Floorplan.js +1 -1
- package/lib/floorplan/data/FloorplanFilters.d.ts +2 -11
- package/lib/floorplan/data/FloorplanFilters.js +1 -43
- package/lib/floorplan/section/FloorplansHeader.js +1 -1
- package/lib/floorplan/section/filter/Sort.d.ts +1 -1
- package/lib/floorplan/section/filter/Sort.js +5 -5
- package/lib/floorplan/service/FloorplanService.d.ts +6 -5
- package/lib/floorplan/service/FloorplanService.js +8 -20
- package/lib/index.d.ts +8 -5
- package/lib/index.js +76 -2
- package/lib/property/service/PropertyService.d.ts +2 -1
- package/lib/property/service/PropertyService.js +18 -4
- package/lib/short-term/data/ShortTermFilters.d.ts +1 -1
- package/lib/short-term/data/ShortTermFilters.js +1 -1
- package/lib/unit/card/UnitCard.d.ts +11 -0
- package/lib/unit/card/UnitCard.js +140 -0
- package/lib/unit/card/assets/360-icon.png +0 -0
- package/lib/unit/card/assets/UnitCard.scss +268 -0
- package/lib/unit/card/assets/camera-icon.png +0 -0
- package/lib/unit/card/assets/video-icon.png +0 -0
- package/lib/{floorplan → unit}/data/Unit.d.ts +18 -1
- package/lib/unit/data/Unit.js +26 -0
- package/lib/unit/data/UnitFilters.d.ts +16 -0
- package/lib/unit/data/UnitFilters.js +6 -0
- package/lib/unit/section/UnitsHeader.d.ts +14 -0
- package/lib/unit/section/UnitsHeader.js +214 -0
- package/lib/unit/section/UnitsSection.d.ts +11 -0
- package/lib/unit/section/UnitsSection.js +87 -0
- package/lib/unit/section/assets/UnitsHeader.scss +70 -0
- package/lib/unit/section/assets/UnitsSection.scss +18 -0
- package/lib/unit/service/UnitService.d.ts +12 -0
- package/lib/unit/service/UnitService.js +133 -0
- package/lib/utils/Utils.d.ts +1 -0
- package/lib/utils/Utils.js +10 -2
- package/package.json +1 -1
- package/lib/floorplan/data/Calendar.js +0 -21
- package/lib/floorplan/data/Unit.js +0 -26
- /package/lib/{floorplan/data → data}/Calendar.d.ts +0 -0
|
@@ -0,0 +1,214 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.UnitsHeader = void 0;
|
|
7
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
8
|
+
require("./assets/UnitsHeader.scss");
|
|
9
|
+
var _muncherUi = require("@contentmunch/muncher-ui");
|
|
10
|
+
var _Utils = require("../../utils/Utils");
|
|
11
|
+
var _FloorplanService = require("../../floorplan/service/FloorplanService");
|
|
12
|
+
var _Floorplan = require("../../floorplan/data/Floorplan");
|
|
13
|
+
var _UnitService = require("../service/UnitService");
|
|
14
|
+
var _Bedroom = require("../../floorplan/section/filter/Bedroom");
|
|
15
|
+
var _Availability = require("../../floorplan/section/filter/Availability");
|
|
16
|
+
var _Price = require("../../floorplan/section/filter/Price");
|
|
17
|
+
var _Style = require("../../floorplan/section/filter/Style");
|
|
18
|
+
var _Sort = require("../../floorplan/section/filter/Sort");
|
|
19
|
+
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); }
|
|
20
|
+
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; }
|
|
21
|
+
const UnitsHeader = _ref => {
|
|
22
|
+
let {
|
|
23
|
+
title,
|
|
24
|
+
filters,
|
|
25
|
+
units,
|
|
26
|
+
setCurrentUnits,
|
|
27
|
+
isCondensed,
|
|
28
|
+
currentUnitCounts,
|
|
29
|
+
defaultFloorplanStyle,
|
|
30
|
+
defaultBedRooms,
|
|
31
|
+
defaultAvailability,
|
|
32
|
+
defaultMaxRent,
|
|
33
|
+
defaultMinRent,
|
|
34
|
+
defaultFloorplanIds
|
|
35
|
+
} = _ref;
|
|
36
|
+
const [bedroomFilters, setBedroomFilters] = (0, _react.useState)(defaultBedRooms ? [defaultBedRooms] : []);
|
|
37
|
+
const [availabilityFilters, setAvailabilityFilters] = (0, _react.useState)(defaultAvailability ? [(0, _FloorplanService.defaultAvailabilityToMonthYear)(defaultAvailability)] : []);
|
|
38
|
+
const [styleFilters, setStyleFilters] = (0, _react.useState)(defaultFloorplanStyle ? [defaultFloorplanStyle] : []);
|
|
39
|
+
const [minRent, setMinRent] = (0, _react.useState)(defaultMinRent ? defaultMinRent : _Floorplan.MIN_RENT);
|
|
40
|
+
const [maxRent, setMaxRent] = (0, _react.useState)(defaultMaxRent ? defaultMaxRent : _Floorplan.MAX_RENT);
|
|
41
|
+
const [sortBy, setSortBy] = (0, _react.useState)("featured");
|
|
42
|
+
const [floorplanIds, setFloorplanIds] = (0, _react.useState)(defaultFloorplanIds ? defaultFloorplanIds : []);
|
|
43
|
+
const currentFilters = {
|
|
44
|
+
bedroomFilters,
|
|
45
|
+
availabilityFilters,
|
|
46
|
+
styleFilters,
|
|
47
|
+
minRent,
|
|
48
|
+
maxRent,
|
|
49
|
+
sortBy,
|
|
50
|
+
floorplanIds
|
|
51
|
+
};
|
|
52
|
+
const handleSortAndFilter = withCurrentFilters => {
|
|
53
|
+
setCurrentUnits((0, _UnitService.sortAndFilterUnits)(units, withCurrentFilters));
|
|
54
|
+
};
|
|
55
|
+
const handleMinRentChange = rent => {
|
|
56
|
+
setMinRent(rent);
|
|
57
|
+
handleSortAndFilter({
|
|
58
|
+
...currentFilters,
|
|
59
|
+
minRent: rent
|
|
60
|
+
});
|
|
61
|
+
};
|
|
62
|
+
const handleMaxRentChange = rent => {
|
|
63
|
+
setMaxRent(rent);
|
|
64
|
+
handleSortAndFilter({
|
|
65
|
+
...currentFilters,
|
|
66
|
+
maxRent: rent
|
|
67
|
+
});
|
|
68
|
+
};
|
|
69
|
+
const handleBedroomFilterChange = filter => {
|
|
70
|
+
const index = bedroomFilters.indexOf(filter);
|
|
71
|
+
const currentBedroomFilters = [...bedroomFilters];
|
|
72
|
+
if (index > -1) {
|
|
73
|
+
currentBedroomFilters.splice(index, 1);
|
|
74
|
+
} else {
|
|
75
|
+
currentBedroomFilters.push(filter);
|
|
76
|
+
}
|
|
77
|
+
setBedroomFilters(currentBedroomFilters);
|
|
78
|
+
handleSortAndFilter({
|
|
79
|
+
...currentFilters,
|
|
80
|
+
bedroomFilters: currentBedroomFilters
|
|
81
|
+
});
|
|
82
|
+
};
|
|
83
|
+
const handleAvailabilityFilterChange = filter => {
|
|
84
|
+
const index = availabilityFilters.indexOf(filter);
|
|
85
|
+
const currentAvailabilityFilters = [...availabilityFilters];
|
|
86
|
+
if (index > -1) {
|
|
87
|
+
currentAvailabilityFilters.splice(index, 1);
|
|
88
|
+
} else {
|
|
89
|
+
currentAvailabilityFilters.push(filter);
|
|
90
|
+
}
|
|
91
|
+
setAvailabilityFilters(currentAvailabilityFilters);
|
|
92
|
+
handleSortAndFilter({
|
|
93
|
+
...currentFilters,
|
|
94
|
+
availabilityFilters: currentAvailabilityFilters
|
|
95
|
+
});
|
|
96
|
+
};
|
|
97
|
+
const handleFloorplanIdChange = floorplanId => {
|
|
98
|
+
const index = floorplanIds.indexOf(floorplanId);
|
|
99
|
+
const currentFloorplanIds = [...floorplanIds];
|
|
100
|
+
if (index > -1) {
|
|
101
|
+
currentFloorplanIds.splice(index, 1);
|
|
102
|
+
}
|
|
103
|
+
setFloorplanIds(currentFloorplanIds);
|
|
104
|
+
handleSortAndFilter({
|
|
105
|
+
...currentFilters,
|
|
106
|
+
floorplanIds: currentFloorplanIds
|
|
107
|
+
});
|
|
108
|
+
};
|
|
109
|
+
const handlePriceChange = range => {
|
|
110
|
+
setMinRent(range.min);
|
|
111
|
+
setMaxRent(range.max);
|
|
112
|
+
handleSortAndFilter({
|
|
113
|
+
...currentFilters,
|
|
114
|
+
minRent: range.min,
|
|
115
|
+
maxRent: range.max
|
|
116
|
+
});
|
|
117
|
+
};
|
|
118
|
+
const handleStyleFilterChange = filter => {
|
|
119
|
+
const index = styleFilters.indexOf(filter);
|
|
120
|
+
const currentSyleFilters = [...styleFilters];
|
|
121
|
+
if (index > -1) {
|
|
122
|
+
currentSyleFilters.splice(index, 1);
|
|
123
|
+
} else {
|
|
124
|
+
currentSyleFilters.push(filter);
|
|
125
|
+
}
|
|
126
|
+
setStyleFilters(currentSyleFilters);
|
|
127
|
+
handleSortAndFilter({
|
|
128
|
+
...currentFilters,
|
|
129
|
+
styleFilters: currentSyleFilters
|
|
130
|
+
});
|
|
131
|
+
};
|
|
132
|
+
const handleSortChange = sortBy => {
|
|
133
|
+
setSortBy(sortBy);
|
|
134
|
+
handleSortAndFilter({
|
|
135
|
+
...currentFilters,
|
|
136
|
+
sortBy: sortBy
|
|
137
|
+
});
|
|
138
|
+
};
|
|
139
|
+
return /*#__PURE__*/_react.default.createElement("header", {
|
|
140
|
+
className: "units-header"
|
|
141
|
+
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
142
|
+
className: isCondensed ? "" : "container"
|
|
143
|
+
}, /*#__PURE__*/_react.default.createElement("h2", null, title), /*#__PURE__*/_react.default.createElement("div", {
|
|
144
|
+
className: "units-filters"
|
|
145
|
+
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
146
|
+
className: "filter-group"
|
|
147
|
+
}, /*#__PURE__*/_react.default.createElement("label", {
|
|
148
|
+
className: "filter-label"
|
|
149
|
+
}, "Filter By:"), /*#__PURE__*/_react.default.createElement("div", {
|
|
150
|
+
className: "filters"
|
|
151
|
+
}, /*#__PURE__*/_react.default.createElement(_Bedroom.BedroomFilter, {
|
|
152
|
+
filters: filters.bedroom,
|
|
153
|
+
handleFilterChange: handleBedroomFilterChange,
|
|
154
|
+
currentFilters: bedroomFilters
|
|
155
|
+
}), /*#__PURE__*/_react.default.createElement(_Availability.AvailabilityFilter, {
|
|
156
|
+
filters: filters.availability,
|
|
157
|
+
handleFilterChange: handleAvailabilityFilterChange,
|
|
158
|
+
currentFilters: availabilityFilters
|
|
159
|
+
}), /*#__PURE__*/_react.default.createElement(_Price.PriceFilter, {
|
|
160
|
+
minValue: minRent,
|
|
161
|
+
maxValue: maxRent,
|
|
162
|
+
setMinValue: handleMinRentChange,
|
|
163
|
+
setMaxValue: handleMaxRentChange
|
|
164
|
+
}), /*#__PURE__*/_react.default.createElement(_Style.StyleFilter, {
|
|
165
|
+
filters: filters.style,
|
|
166
|
+
handleFilterChange: handleStyleFilterChange,
|
|
167
|
+
currentFilters: styleFilters
|
|
168
|
+
}))), /*#__PURE__*/_react.default.createElement("div", {
|
|
169
|
+
className: "filter-group"
|
|
170
|
+
}, /*#__PURE__*/_react.default.createElement("label", {
|
|
171
|
+
className: "filter-label"
|
|
172
|
+
}, "Sort By:"), /*#__PURE__*/_react.default.createElement("div", {
|
|
173
|
+
className: "filters"
|
|
174
|
+
}, /*#__PURE__*/_react.default.createElement(_Sort.Sort, {
|
|
175
|
+
sortBy: sortBy,
|
|
176
|
+
handleSortChange: handleSortChange
|
|
177
|
+
})))), /*#__PURE__*/_react.default.createElement("div", {
|
|
178
|
+
className: "pills"
|
|
179
|
+
}, bedroomFilters.sort(_Bedroom.sortBedrooms).map(bedroom => /*#__PURE__*/_react.default.createElement(_muncherUi.Pill, {
|
|
180
|
+
key: bedroom,
|
|
181
|
+
pillCloseHandler: () => {
|
|
182
|
+
handleBedroomFilterChange(bedroom);
|
|
183
|
+
}
|
|
184
|
+
}, bedroom + " bedroom")), availabilityFilters.sort(_Availability.sortAvailability).map(availability => /*#__PURE__*/_react.default.createElement(_muncherUi.Pill, {
|
|
185
|
+
key: availability.toString(),
|
|
186
|
+
pillCloseHandler: () => {
|
|
187
|
+
handleAvailabilityFilterChange(availability);
|
|
188
|
+
}
|
|
189
|
+
}, availability.toString() + " availability")), minRent === _Floorplan.MIN_RENT && maxRent === _Floorplan.MAX_RENT ? "" : /*#__PURE__*/_react.default.createElement(_muncherUi.Pill, {
|
|
190
|
+
key: "rent",
|
|
191
|
+
pillCloseHandler: () => {
|
|
192
|
+
handlePriceChange({
|
|
193
|
+
min: _Floorplan.MIN_RENT,
|
|
194
|
+
max: _Floorplan.MAX_RENT
|
|
195
|
+
});
|
|
196
|
+
}
|
|
197
|
+
}, "$" + minRent + " - $" + maxRent), styleFilters.map(style => /*#__PURE__*/_react.default.createElement(_muncherUi.Pill, {
|
|
198
|
+
key: style,
|
|
199
|
+
pillCloseHandler: () => {
|
|
200
|
+
handleStyleFilterChange(style);
|
|
201
|
+
}
|
|
202
|
+
}, (0, _Utils.capitalizeFirstLetter)((0, _Utils.enumToString)(style)))), floorplanIds.sort().map(floorplanId => /*#__PURE__*/_react.default.createElement(_muncherUi.Pill, {
|
|
203
|
+
key: floorplanId,
|
|
204
|
+
pillCloseHandler: () => {
|
|
205
|
+
handleFloorplanIdChange(floorplanId);
|
|
206
|
+
}
|
|
207
|
+
}, floorplanId)), /*#__PURE__*/_react.default.createElement("div", {
|
|
208
|
+
className: "filter-result"
|
|
209
|
+
}, /*#__PURE__*/_react.default.createElement(_muncherUi.Icon, {
|
|
210
|
+
name: "filter"
|
|
211
|
+
}), "\xA0Total: ", currentUnitCounts, " Results"))));
|
|
212
|
+
};
|
|
213
|
+
exports.UnitsHeader = UnitsHeader;
|
|
214
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_muncherUi","_Utils","_FloorplanService","_Floorplan","_UnitService","_Bedroom","_Availability","_Price","_Style","_Sort","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","prototype","hasOwnProperty","call","i","set","UnitsHeader","_ref","title","filters","units","setCurrentUnits","isCondensed","currentUnitCounts","defaultFloorplanStyle","defaultBedRooms","defaultAvailability","defaultMaxRent","defaultMinRent","defaultFloorplanIds","bedroomFilters","setBedroomFilters","useState","availabilityFilters","setAvailabilityFilters","defaultAvailabilityToMonthYear","styleFilters","setStyleFilters","minRent","setMinRent","MIN_RENT","maxRent","setMaxRent","MAX_RENT","sortBy","setSortBy","floorplanIds","setFloorplanIds","currentFilters","handleSortAndFilter","withCurrentFilters","sortAndFilterUnits","handleMinRentChange","rent","handleMaxRentChange","handleBedroomFilterChange","filter","index","indexOf","currentBedroomFilters","splice","push","handleAvailabilityFilterChange","currentAvailabilityFilters","handleFloorplanIdChange","floorplanId","currentFloorplanIds","handlePriceChange","range","min","max","handleStyleFilterChange","currentSyleFilters","handleSortChange","createElement","className","BedroomFilter","bedroom","handleFilterChange","AvailabilityFilter","availability","PriceFilter","minValue","maxValue","setMinValue","setMaxValue","StyleFilter","style","Sort","sort","sortBedrooms","map","Pill","key","pillCloseHandler","sortAvailability","toString","capitalizeFirstLetter","enumToString","Icon","name","exports"],"sources":["../../../src/unit/section/UnitsHeader.tsx"],"sourcesContent":["import React, {useState} from \"react\";\nimport \"./assets/UnitsHeader.scss\";\nimport {Icon, Pill, Range} from \"@contentmunch/muncher-ui\";\nimport {capitalizeFirstLetter, enumToString} from \"../../utils/Utils\";\nimport {SortBy} from \"../../data/SortField\";\nimport {DefaultFloorplanFilters} from \"../../floorplan/section/FloorplansSection\";\nimport {UnitCardData} from \"../data/Unit\";\nimport {defaultAvailabilityToMonthYear} from \"../../floorplan/service/FloorplanService\";\nimport {FloorplanStyle, MAX_RENT, MIN_RENT} from \"../../floorplan/data/Floorplan\";\nimport {CurrentFloorplanFilters, FloorplanFilters} from \"../../floorplan/data/FloorplanFilters\";\nimport {sortAndFilterUnits} from \"../service/UnitService\";\nimport {BedroomFilter, sortBedrooms} from \"../../floorplan/section/filter/Bedroom\";\nimport {AvailabilityFilter, sortAvailability} from \"../../floorplan/section/filter/Availability\";\nimport {PriceFilter} from \"../../floorplan/section/filter/Price\";\nimport {StyleFilter} from \"../../floorplan/section/filter/Style\";\nimport {Sort} from \"../../floorplan/section/filter/Sort\";\n\nexport const UnitsHeader: React.FC<UnitsHeaderProps> = (\n    {\n        title,\n        filters,\n        units,\n        setCurrentUnits,\n        isCondensed,\n        currentUnitCounts,\n        defaultFloorplanStyle, defaultBedRooms, defaultAvailability, defaultMaxRent, defaultMinRent, defaultFloorplanIds\n    }) => {\n\n    const [bedroomFilters, setBedroomFilters] = useState<number[]>(defaultBedRooms ? [defaultBedRooms] : []);\n    const [availabilityFilters, setAvailabilityFilters] = useState<string[]>(defaultAvailability ? [defaultAvailabilityToMonthYear(defaultAvailability)] : []);\n    const [styleFilters, setStyleFilters] = useState<FloorplanStyle[]>(defaultFloorplanStyle ? [defaultFloorplanStyle] : []);\n    const [minRent, setMinRent] = useState<number>(defaultMinRent ? defaultMinRent : MIN_RENT);\n    const [maxRent, setMaxRent] = useState<number>(defaultMaxRent ? defaultMaxRent : MAX_RENT);\n    const [sortBy, setSortBy] = useState<SortBy>(\"featured\");\n    const [floorplanIds, setFloorplanIds] = useState<string[]>(defaultFloorplanIds ? defaultFloorplanIds : []);\n\n    const currentFilters: CurrentFloorplanFilters = {\n        bedroomFilters, availabilityFilters, styleFilters, minRent, maxRent, sortBy, floorplanIds\n    };\n\n    const handleSortAndFilter = (withCurrentFilters: CurrentFloorplanFilters) => {\n        setCurrentUnits(sortAndFilterUnits(units, withCurrentFilters));\n    };\n    const handleMinRentChange = (rent: number) => {\n        setMinRent(rent);\n        handleSortAndFilter({...currentFilters, minRent: rent});\n    }\n    const handleMaxRentChange = (rent: number) => {\n        setMaxRent(rent);\n        handleSortAndFilter({...currentFilters, maxRent: rent});\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    const handleAvailabilityFilterChange = (filter: string) => {\n        const index = availabilityFilters.indexOf(filter);\n        const currentAvailabilityFilters = [...availabilityFilters];\n        if (index > -1) {\n            currentAvailabilityFilters.splice(index, 1);\n        } else {\n            currentAvailabilityFilters.push(filter);\n        }\n        setAvailabilityFilters(currentAvailabilityFilters);\n        handleSortAndFilter({...currentFilters, availabilityFilters: currentAvailabilityFilters});\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 handlePriceChange = (range: Range) => {\n        setMinRent(range.min);\n        setMaxRent(range.max);\n        handleSortAndFilter({...currentFilters, minRent: range.min, maxRent: range.max});\n    }\n    const handleStyleFilterChange = (filter: FloorplanStyle) => {\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: SortBy) => {\n        setSortBy(sortBy);\n        handleSortAndFilter({...currentFilters, sortBy: sortBy});\n    }\n    return (\n        <header className=\"units-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                            <AvailabilityFilter filters={filters.availability}\n                                                handleFilterChange={handleAvailabilityFilterChange}\n                                                currentFilters={availabilityFilters}/>\n\n                            <PriceFilter minValue={minRent} maxValue={maxRent} setMinValue={handleMinRentChange}\n                                         setMaxValue={handleMaxRentChange}/>\n                            <StyleFilter 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                            <Sort 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                    {availabilityFilters.sort(sortAvailability).map((availability: string) => (\n                        <Pill key={availability.toString()} pillCloseHandler={() => {\n                            handleAvailabilityFilterChange(availability)\n                        }}>\n                            {availability.toString() + \" availability\"}\n                        </Pill>\n                    ))}\n                    {\n                        minRent === MIN_RENT && maxRent === MAX_RENT ? \"\" :\n                            <Pill key=\"rent\" pillCloseHandler={() => {\n                                handlePriceChange({\n                                    min: MIN_RENT,\n                                    max: MAX_RENT\n                                })\n                            }}>\n                                {\"$\" + minRent + \" - $\" + maxRent}\n                            </Pill>\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: {currentUnitCounts} Results\n                    </div>\n                </div>\n            </div>\n        </header>\n    );\n}\n\nexport interface UnitsHeaderProps extends DefaultFloorplanFilters {\n    title?: string;\n    filters: FloorplanFilters;\n    units: UnitCardData[];\n    setCurrentUnits: (units: UnitCardData[]) => void;\n    isCondensed?: boolean;\n    currentUnitCounts: number;\n}\n"],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import "./assets/UnitsSection.scss";
|
|
3
|
+
import { UnitCardData } from "../data/Unit";
|
|
4
|
+
import { DefaultFloorplanFilters } from "../../floorplan/section/FloorplansSection";
|
|
5
|
+
export declare const UnitsSection: React.FC<UnitsSectionProps>;
|
|
6
|
+
export interface UnitsSectionProps extends DefaultFloorplanFilters {
|
|
7
|
+
units: UnitCardData[];
|
|
8
|
+
title?: string;
|
|
9
|
+
isCondensed?: boolean;
|
|
10
|
+
propertyId: string;
|
|
11
|
+
}
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.UnitsSection = void 0;
|
|
7
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
8
|
+
var _VideoModal = require("../../asset/VideoModal");
|
|
9
|
+
require("./assets/UnitsSection.scss");
|
|
10
|
+
var _UnitService = require("../service/UnitService");
|
|
11
|
+
var _UnitCard = require("../card/UnitCard");
|
|
12
|
+
var _FloorplanService = require("../../floorplan/service/FloorplanService");
|
|
13
|
+
var _Floorplan = require("../../floorplan/data/Floorplan");
|
|
14
|
+
var _UnitsHeader = require("./UnitsHeader");
|
|
15
|
+
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); }
|
|
16
|
+
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; }
|
|
17
|
+
const UnitsSection = _ref => {
|
|
18
|
+
let {
|
|
19
|
+
units,
|
|
20
|
+
title,
|
|
21
|
+
isCondensed,
|
|
22
|
+
propertyId,
|
|
23
|
+
defaultFloorplanStyle,
|
|
24
|
+
defaultBedRooms,
|
|
25
|
+
defaultAvailability,
|
|
26
|
+
defaultMaxRent,
|
|
27
|
+
defaultMinRent,
|
|
28
|
+
defaultFloorplanIds
|
|
29
|
+
} = _ref;
|
|
30
|
+
const [filteredUnits, setFilteredUnits] = (0, _react.useState)((0, _UnitService.sortAndFilterUnits)(units, {
|
|
31
|
+
bedroomFilters: defaultBedRooms ? [defaultBedRooms] : [],
|
|
32
|
+
availabilityFilters: defaultAvailability ? [(0, _FloorplanService.defaultAvailabilityToMonthYear)(defaultAvailability)] : [],
|
|
33
|
+
styleFilters: defaultFloorplanStyle ? [defaultFloorplanStyle] : [],
|
|
34
|
+
minRent: defaultMinRent ? defaultMinRent : _Floorplan.MIN_RENT,
|
|
35
|
+
maxRent: defaultMaxRent ? defaultMaxRent : _Floorplan.MAX_RENT,
|
|
36
|
+
sortBy: "featured",
|
|
37
|
+
floorplanIds: defaultFloorplanIds ? defaultFloorplanIds : []
|
|
38
|
+
}));
|
|
39
|
+
const [showVideoModal, setShowVideoModal] = (0, _react.useState)(false);
|
|
40
|
+
const [video, setVideo] = (0, _react.useState)({});
|
|
41
|
+
const setCurrentUnits = currentUnits => {
|
|
42
|
+
setFilteredUnits(currentUnits);
|
|
43
|
+
};
|
|
44
|
+
const handleVideoClicked = data => {
|
|
45
|
+
setVideo(data);
|
|
46
|
+
setShowVideoModal(true);
|
|
47
|
+
};
|
|
48
|
+
return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("section", {
|
|
49
|
+
className: "section-units"
|
|
50
|
+
}, /*#__PURE__*/_react.default.createElement(_VideoModal.VideoModal, {
|
|
51
|
+
video: video,
|
|
52
|
+
showModal: showVideoModal,
|
|
53
|
+
setShowModal: setShowVideoModal
|
|
54
|
+
}), /*#__PURE__*/_react.default.createElement("div", {
|
|
55
|
+
className: isCondensed ? "container" : ""
|
|
56
|
+
}, /*#__PURE__*/_react.default.createElement(_UnitsHeader.UnitsHeader, {
|
|
57
|
+
title: title,
|
|
58
|
+
filters: (0, _UnitService.filtersFromUnits)(units),
|
|
59
|
+
units: units,
|
|
60
|
+
setCurrentUnits: setCurrentUnits,
|
|
61
|
+
currentUnitCounts: 0,
|
|
62
|
+
isCondensed: isCondensed,
|
|
63
|
+
defaultFloorplanStyle: defaultFloorplanStyle,
|
|
64
|
+
defaultBedRooms: defaultBedRooms,
|
|
65
|
+
defaultAvailability: defaultAvailability,
|
|
66
|
+
defaultMaxRent: defaultMaxRent,
|
|
67
|
+
defaultMinRent: defaultMinRent,
|
|
68
|
+
defaultFloorplanIds: defaultFloorplanIds
|
|
69
|
+
}), /*#__PURE__*/_react.default.createElement("div", {
|
|
70
|
+
className: isCondensed ? "" : "container"
|
|
71
|
+
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
72
|
+
className: "units-body"
|
|
73
|
+
}, filteredUnits.length === 0 ? /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("p", {
|
|
74
|
+
className: "units-banner"
|
|
75
|
+
}, "No matches found...")) : filteredUnits.map((unit, i) => /*#__PURE__*/_react.default.createElement(_UnitCard.UnitCard, {
|
|
76
|
+
unit: unit,
|
|
77
|
+
key: i,
|
|
78
|
+
propertyId: propertyId,
|
|
79
|
+
videoClickHandler: handleVideoClicked
|
|
80
|
+
})))))));
|
|
81
|
+
};
|
|
82
|
+
exports.UnitsSection = UnitsSection;
|
|
83
|
+
UnitsSection.defaultProps = {
|
|
84
|
+
title: "Units",
|
|
85
|
+
isCondensed: true
|
|
86
|
+
};
|
|
87
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_VideoModal","_UnitService","_UnitCard","_FloorplanService","_Floorplan","_UnitsHeader","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","prototype","hasOwnProperty","call","i","set","UnitsSection","_ref","units","title","isCondensed","propertyId","defaultFloorplanStyle","defaultBedRooms","defaultAvailability","defaultMaxRent","defaultMinRent","defaultFloorplanIds","filteredUnits","setFilteredUnits","useState","sortAndFilterUnits","bedroomFilters","availabilityFilters","defaultAvailabilityToMonthYear","styleFilters","minRent","MIN_RENT","maxRent","MAX_RENT","sortBy","floorplanIds","showVideoModal","setShowVideoModal","video","setVideo","setCurrentUnits","currentUnits","handleVideoClicked","data","createElement","Fragment","className","VideoModal","showModal","setShowModal","UnitsHeader","filters","filtersFromUnits","currentUnitCounts","length","map","unit","UnitCard","key","videoClickHandler","exports","defaultProps"],"sources":["../../../src/unit/section/UnitsSection.tsx"],"sourcesContent":["import React, {useState} from \"react\";\nimport {VideoModal} from \"../../asset/VideoModal\";\nimport {Video} from \"../../asset/data/Asset\";\nimport \"./assets/UnitsSection.scss\";\nimport {UnitCardData} from \"../data/Unit\";\nimport {filtersFromUnits, sortAndFilterUnits} from \"../service/UnitService\";\nimport {UnitCard} from \"../card/UnitCard\";\nimport {defaultAvailabilityToMonthYear} from \"../../floorplan/service/FloorplanService\";\nimport {MAX_RENT, MIN_RENT} from \"../../floorplan/data/Floorplan\";\nimport {DefaultFloorplanFilters} from \"../../floorplan/section/FloorplansSection\";\nimport {UnitsHeader} from \"./UnitsHeader\";\n\nexport const UnitsSection: React.FC<UnitsSectionProps> = (\n    {\n        units, title, isCondensed, propertyId,\n        defaultFloorplanStyle, defaultBedRooms, defaultAvailability, defaultMaxRent, defaultMinRent, defaultFloorplanIds\n    }) => {\n    const [filteredUnits, setFilteredUnits] = useState<UnitCardData[]>(sortAndFilterUnits(units, {\n        bedroomFilters: defaultBedRooms ? [defaultBedRooms] : [],\n        availabilityFilters: defaultAvailability ? [defaultAvailabilityToMonthYear(defaultAvailability)] : [],\n        styleFilters: defaultFloorplanStyle ? [defaultFloorplanStyle] : [],\n        minRent: defaultMinRent ? defaultMinRent : MIN_RENT,\n        maxRent: defaultMaxRent ? defaultMaxRent : MAX_RENT,\n        sortBy: \"featured\",\n        floorplanIds: defaultFloorplanIds ? defaultFloorplanIds : []\n    }));\n\n    const [showVideoModal, setShowVideoModal] = useState(false);\n    const [video, setVideo] = useState<Video>({} as Video);\n\n    const setCurrentUnits = (currentUnits: UnitCardData[]) => {\n        setFilteredUnits(currentUnits);\n    }\n\n    const handleVideoClicked = (data: Video) => {\n        setVideo(data);\n        setShowVideoModal(true);\n    };\n\n    return (\n        <>\n            <section className=\"section-units\">\n                <VideoModal video={video} showModal={showVideoModal} setShowModal={setShowVideoModal}/>\n                <div className={isCondensed ? \"container\" : \"\"}>\n                    <UnitsHeader title={title} filters={filtersFromUnits(units)} units={units}\n                                 setCurrentUnits={setCurrentUnits} currentUnitCounts={0}\n                                 isCondensed={isCondensed}\n                                 defaultFloorplanStyle={defaultFloorplanStyle}\n                                 defaultBedRooms={defaultBedRooms}\n                                 defaultAvailability={defaultAvailability}\n                                 defaultMaxRent={defaultMaxRent}\n                                 defaultMinRent={defaultMinRent}\n                                 defaultFloorplanIds={defaultFloorplanIds}\n                    />\n\n                    <div className={isCondensed ? \"\" : \"container\"}>\n                        <div className=\"units-body\">\n\n                            {\n                                filteredUnits.length === 0 ?\n                                    <>\n                                        <p className=\"units-banner\">No matches found...</p>\n                                    </> :\n                                    filteredUnits.map((unit, i) => (\n                                        <UnitCard unit={unit} key={i} propertyId={propertyId}\n                                                  videoClickHandler={handleVideoClicked}/>))\n                            }\n                        </div>\n                    </div>\n                </div>\n            </section>\n        </>\n    );\n};\n\nexport interface UnitsSectionProps extends DefaultFloorplanFilters {\n    units: UnitCardData[];\n    title?: string;\n    isCondensed?: boolean;\n    propertyId: string;\n}\n\nUnitsSection.defaultProps = {\n    title: \"Units\",\n    isCondensed: true,\n}\n"],"mappings":"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"}
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
@import "src/assets/variables";
|
|
2
|
+
|
|
3
|
+
$search-unit-header-background-color: $secondary-nav-background-color !default;
|
|
4
|
+
$search-unit-header-dropdown-background-color: $primary-background-color !default;
|
|
5
|
+
.units-header {
|
|
6
|
+
background-color: $search-unit-header-background-color;
|
|
7
|
+
padding: 1rem;
|
|
8
|
+
|
|
9
|
+
.pills {
|
|
10
|
+
padding: 1rem;
|
|
11
|
+
font-size: .8rem;
|
|
12
|
+
}
|
|
13
|
+
.filter-result {
|
|
14
|
+
display: flex;
|
|
15
|
+
justify-content: flex-end;
|
|
16
|
+
align-items: center;
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
.units-filters {
|
|
20
|
+
display: flex;
|
|
21
|
+
flex-wrap: wrap;
|
|
22
|
+
justify-content: space-between;
|
|
23
|
+
align-items: center;
|
|
24
|
+
|
|
25
|
+
.filter-group {
|
|
26
|
+
display: flex;
|
|
27
|
+
justify-content: center;
|
|
28
|
+
align-items: center;
|
|
29
|
+
|
|
30
|
+
.filter-label {
|
|
31
|
+
text-align: right;
|
|
32
|
+
min-width: 5rem;
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
.filters {
|
|
37
|
+
display: flex;
|
|
38
|
+
justify-content: left;
|
|
39
|
+
align-items: center;
|
|
40
|
+
flex-wrap: wrap;
|
|
41
|
+
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
.sort-filters {
|
|
45
|
+
.muncher-button {
|
|
46
|
+
display: flex;
|
|
47
|
+
text-transform: none;
|
|
48
|
+
padding: .3rem;
|
|
49
|
+
min-width: 8rem;
|
|
50
|
+
justify-content: left;
|
|
51
|
+
|
|
52
|
+
}
|
|
53
|
+
.muncher-button:hover{
|
|
54
|
+
background-color: $tertiary-background-color;
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
.muncher-dropdown--content{
|
|
58
|
+
background-color: $search-unit-header-dropdown-background-color;
|
|
59
|
+
}
|
|
60
|
+
.price-dropdown {
|
|
61
|
+
width: 10rem;
|
|
62
|
+
@media (min-width: $large-size) {
|
|
63
|
+
width: auto;
|
|
64
|
+
}
|
|
65
|
+
.price-dropdown-content{
|
|
66
|
+
width: 15rem;
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
@import "src/assets/variables";
|
|
2
|
+
|
|
3
|
+
.section-units {
|
|
4
|
+
padding: 0;
|
|
5
|
+
.units-body {
|
|
6
|
+
display: flex;
|
|
7
|
+
flex-wrap: wrap;
|
|
8
|
+
justify-content: center;
|
|
9
|
+
align-items: center;
|
|
10
|
+
.unit-card {
|
|
11
|
+
margin: 1rem;
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
.units-banner {
|
|
15
|
+
padding-top: 3rem;
|
|
16
|
+
padding-bottom: 3rem;
|
|
17
|
+
}
|
|
18
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { UnitCardData } from "../data/Unit";
|
|
2
|
+
import { FloorplanCardData } from "../../floorplan/data/Floorplan";
|
|
3
|
+
import { CurrentFloorplanFilters, FloorplanFilters } from "../../floorplan/data/FloorplanFilters";
|
|
4
|
+
import { SortBy } from "../../data/SortField";
|
|
5
|
+
import { PropertyFilterData } from "../../property/data/Property";
|
|
6
|
+
export declare const isUnitAvailable: (unit: UnitCardData) => boolean;
|
|
7
|
+
export declare const sortAndFilterUnits: (units: UnitCardData[], currentFilters: CurrentFloorplanFilters) => UnitCardData[];
|
|
8
|
+
export declare const sortUnits: (units: UnitCardData[], sortBy: SortBy) => UnitCardData[];
|
|
9
|
+
export declare const filtersFromUnits: (units: UnitCardData[]) => FloorplanFilters;
|
|
10
|
+
export declare const unitsFromProperties: (properties: PropertyFilterData[]) => UnitCardData[];
|
|
11
|
+
export declare const unitsFromFloorplans: (floorplans: FloorplanCardData[]) => UnitCardData[];
|
|
12
|
+
export declare const toUnits: (floorplan: FloorplanCardData) => UnitCardData[];
|