@renaissancerentals/renaissance-component 12.2.9 → 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.
Files changed (49) hide show
  1. package/lib/data/Calendar.js +21 -0
  2. package/lib/data/SortField.d.ts +10 -0
  3. package/lib/data/SortField.js +62 -0
  4. package/lib/floorplan/card/FloorplanCard.js +3 -1
  5. package/lib/floorplan/data/Floorplan.d.ts +10 -2
  6. package/lib/floorplan/data/Floorplan.js +1 -1
  7. package/lib/floorplan/data/FloorplanFilters.d.ts +2 -11
  8. package/lib/floorplan/data/FloorplanFilters.js +1 -43
  9. package/lib/floorplan/section/FloorplansHeader.js +1 -1
  10. package/lib/floorplan/section/filter/Sort.d.ts +1 -1
  11. package/lib/floorplan/section/filter/Sort.js +5 -5
  12. package/lib/floorplan/service/FloorplanService.d.ts +6 -5
  13. package/lib/floorplan/service/FloorplanService.js +8 -20
  14. package/lib/index.d.ts +9 -5
  15. package/lib/index.js +89 -2
  16. package/lib/property/PropertyVideo.d.ts +5 -0
  17. package/lib/property/PropertyVideo.js +21 -0
  18. package/lib/property/data/Property.d.ts +1 -0
  19. package/lib/property/data/Property.js +1 -1
  20. package/lib/property/service/PropertyService.d.ts +3 -1
  21. package/lib/property/service/PropertyService.js +35 -4
  22. package/lib/short-term/data/ShortTermFilters.d.ts +1 -1
  23. package/lib/short-term/data/ShortTermFilters.js +1 -1
  24. package/lib/unit/card/UnitCard.d.ts +11 -0
  25. package/lib/unit/card/UnitCard.js +140 -0
  26. package/lib/unit/card/assets/360-icon.png +0 -0
  27. package/lib/unit/card/assets/UnitCard.scss +268 -0
  28. package/lib/unit/card/assets/camera-icon.png +0 -0
  29. package/lib/unit/card/assets/video-icon.png +0 -0
  30. package/lib/{floorplan → unit}/data/Unit.d.ts +18 -1
  31. package/lib/unit/data/Unit.js +26 -0
  32. package/lib/unit/data/UnitFilters.d.ts +16 -0
  33. package/lib/unit/data/UnitFilters.js +6 -0
  34. package/lib/unit/section/UnitsHeader.d.ts +14 -0
  35. package/lib/unit/section/UnitsHeader.js +214 -0
  36. package/lib/unit/section/UnitsSection.d.ts +11 -0
  37. package/lib/unit/section/UnitsSection.js +87 -0
  38. package/lib/unit/section/assets/UnitsHeader.scss +70 -0
  39. package/lib/unit/section/assets/UnitsSection.scss +18 -0
  40. package/lib/unit/service/UnitService.d.ts +12 -0
  41. package/lib/unit/service/UnitService.js +133 -0
  42. package/lib/utils/Utils.d.ts +1 -0
  43. package/lib/utils/Utils.js +10 -2
  44. package/lib/video/data/VideoAsset.d.ts +9 -0
  45. package/lib/video/data/VideoAsset.js +6 -0
  46. package/package.json +1 -1
  47. package/lib/floorplan/data/Calendar.js +0 -21
  48. package/lib/floorplan/data/Unit.js +0 -26
  49. /package/lib/{floorplan/data → data}/Calendar.d.ts +0 -0
@@ -0,0 +1,14 @@
1
+ import React from "react";
2
+ import "./assets/UnitsHeader.scss";
3
+ import { DefaultFloorplanFilters } from "../../floorplan/section/FloorplansSection";
4
+ import { UnitCardData } from "../data/Unit";
5
+ import { FloorplanFilters } from "../../floorplan/data/FloorplanFilters";
6
+ export declare const UnitsHeader: React.FC<UnitsHeaderProps>;
7
+ export interface UnitsHeaderProps extends DefaultFloorplanFilters {
8
+ title?: string;
9
+ filters: FloorplanFilters;
10
+ units: UnitCardData[];
11
+ setCurrentUnits: (units: UnitCardData[]) => void;
12
+ isCondensed?: boolean;
13
+ currentUnitCounts: number;
14
+ }
@@ -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[];