@renaissancerentals/renaissance-component 10.0.25 → 10.0.28

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 (55) hide show
  1. package/lib/floorplan/card/FloorplanCard.d.ts +2 -2
  2. package/lib/floorplan/card/FloorplanCard.js +7 -7
  3. package/lib/floorplan/card/FloorplanCardSlider.js +13 -73
  4. package/lib/floorplan/card/FloorplanSliderCard.d.ts +8 -0
  5. package/lib/floorplan/card/FloorplanSliderCard.js +50 -0
  6. package/lib/floorplan/card/SimilarFloorplanCard.js +24 -42
  7. package/lib/floorplan/card/TestimonialsCard.js +8 -44
  8. package/lib/floorplan/card/assets/SimilarFloorplanCard.scss +47 -37
  9. package/lib/floorplan/card/assets/TestimonialsCard.scss +3 -23
  10. package/lib/floorplan/card/assets/camera-icon.png +0 -0
  11. package/lib/floorplan/data/Calendar.js +2 -2
  12. package/lib/floorplan/data/Floorplan.d.ts +17 -2
  13. package/lib/floorplan/data/Floorplan.js +2 -2
  14. package/lib/floorplan/data/FloorplanFilters.d.ts +1 -1
  15. package/lib/floorplan/data/FloorplanFilters.js +1 -1
  16. package/lib/floorplan/data/Unit.d.ts +6 -0
  17. package/lib/floorplan/data/Unit.js +1 -1
  18. package/lib/floorplan/section/FloorplanHero.d.ts +1 -0
  19. package/lib/floorplan/section/FloorplanHero.js +135 -12
  20. package/lib/floorplan/section/FloorplanSection.d.ts +0 -1
  21. package/lib/floorplan/section/FloorplanSection.js +75 -31
  22. package/lib/floorplan/section/FloorplansHeader.d.ts +3 -3
  23. package/lib/floorplan/section/FloorplansHeader.js +1 -1
  24. package/lib/floorplan/section/FloorplansSection.d.ts +2 -2
  25. package/lib/floorplan/section/FloorplansSection.js +1 -1
  26. package/lib/floorplan/section/HeroBadgeStats.d.ts +10 -0
  27. package/lib/floorplan/section/HeroBadgeStats.js +86 -0
  28. package/lib/floorplan/section/assets/BadgeStats.scss +5 -0
  29. package/lib/floorplan/section/assets/FloorplanHero.scss +90 -1
  30. package/lib/floorplan/section/assets/FloorplanSection.scss +0 -3
  31. package/lib/floorplan/section/assets/HeroBadgeStats.scss +74 -0
  32. package/lib/floorplan/section/filter/Availability.d.ts +4 -5
  33. package/lib/floorplan/section/filter/Availability.js +4 -4
  34. package/lib/floorplan/service/FloorplanService.d.ts +7 -6
  35. package/lib/floorplan/service/FloorplanService.js +76 -10
  36. package/lib/gallery/GalleryHeroMain.d.ts +13 -0
  37. package/lib/gallery/GalleryHeroMain.js +101 -0
  38. package/lib/gallery/GalleryHeroMobile.d.ts +11 -0
  39. package/lib/gallery/GalleryHeroMobile.js +100 -0
  40. package/lib/gallery/HeroImageCard.d.ts +8 -0
  41. package/lib/gallery/HeroImageCard.js +34 -0
  42. package/lib/gallery/assets/GalleryHero.scss +45 -153
  43. package/lib/gallery/assets/HeroImageCard.scss +29 -0
  44. package/lib/index.d.ts +5 -5
  45. package/lib/index.js +6 -6
  46. package/lib/property/assets/PropertyLocation.scss +1 -0
  47. package/lib/property/data/Property.d.ts +6 -1
  48. package/lib/property/data/Property.js +1 -1
  49. package/lib/service/GraphqlQuery.d.ts +2 -0
  50. package/lib/service/GraphqlQuery.js +22 -0
  51. package/lib/utils/Utils.d.ts +2 -0
  52. package/lib/utils/Utils.js +23 -11
  53. package/package.json +2 -2
  54. package/lib/gallery/GalleryHero.d.ts +0 -10
  55. package/lib/gallery/GalleryHero.js +0 -278
@@ -3,11 +3,99 @@
3
3
  .section-floorplan--hero {
4
4
  padding: 0;
5
5
  background: $primary-background-color;
6
+ width: 100vw;
7
+ position: relative;
6
8
 
7
9
  a {
8
10
  text-decoration: underline;
9
11
  }
10
12
 
13
+ .gallery-hero {
14
+ position: relative;
15
+ width: 100vw;
16
+ height: 40vh;
17
+ @media (min-width: $large-size) {
18
+ height: 40vw;
19
+ }
20
+
21
+ .virtual-tour-view {
22
+ iframe {
23
+ width: 100%;
24
+ height: 40vh;
25
+ @media (min-width: $large-size) {
26
+ height: 40vw;
27
+
28
+ }
29
+ }
30
+ }
31
+
32
+ .video-tour-view {
33
+ .single-video-layout {
34
+ iframe {
35
+ width: 100%;
36
+ height: 35vh;
37
+ @media (min-width: $large-size) {
38
+ height: 40vw;
39
+ }
40
+ }
41
+ }
42
+
43
+ .two-video-layout {
44
+ @media (min-width: $large-size) {
45
+ display: flex;
46
+ align-content: flex-start;
47
+ justify-content: space-evenly;
48
+ }
49
+
50
+ iframe {
51
+ width: 40%;
52
+ height: 35vh;
53
+ margin: 1rem;
54
+ @media (min-width: $large-size) {
55
+ height: 35vw;
56
+ }
57
+ }
58
+ }
59
+ }
60
+
61
+ .badge--stats {
62
+ position: absolute;
63
+ left: 50%;
64
+ transform: translate(-50%, -50%);
65
+ bottom: -2rem;
66
+
67
+ .muncher-badge {
68
+ color: $primary-background-color;
69
+ flex-wrap: nowrap;
70
+ break-inside: avoid;
71
+ align-content: center;
72
+ width: 60vw;
73
+ font-size: .7rem;
74
+ @media (min-width: $large-size) {
75
+ font-size: 1rem;
76
+ width: auto;
77
+ }
78
+
79
+ .muncher-button--small {
80
+ padding: 0;
81
+ color: $primary-background-color;
82
+ text-transform: capitalize;
83
+ font-size: .7rem;
84
+ font-family: $serif-font;
85
+ @media (min-width: $large-size) {
86
+ font-size: 1rem;
87
+ }
88
+
89
+ .selected {
90
+ text-decoration: underline;
91
+ }
92
+ }
93
+
94
+ }
95
+ }
96
+ }
97
+
98
+
11
99
  .floorplan--two-columns {
12
100
  padding: 2rem;
13
101
  @media (min-width: $medium-size) {
@@ -45,7 +133,8 @@
45
133
  font-family: $sans-serif-font;
46
134
  letter-spacing: .05rem;
47
135
  font-size: 1.1rem;
48
- .muncher-button{
136
+
137
+ .muncher-button {
49
138
  font-family: $sans-serif-font;
50
139
  letter-spacing: .05rem;
51
140
  font-size: 1.1rem;
@@ -43,9 +43,6 @@ $floorplan-background-color: $tertiary-color !default;
43
43
 
44
44
  li {
45
45
  font-size: 1rem;
46
- letter-spacing: .03rem;
47
- line-height: 1.5rem;
48
- font-weight: 300;
49
46
  }
50
47
  }
51
48
 
@@ -0,0 +1,74 @@
1
+ @import 'src/assets/variables';
2
+
3
+ .hero-badge--stats {
4
+ position: absolute;
5
+ left: 50%;
6
+ transform: translate(-50%, -50%);
7
+
8
+ .muncher-badge {
9
+ color: $primary-background-color;
10
+ flex-wrap: nowrap;
11
+ break-inside: avoid;
12
+ align-content: center;
13
+ justify-content: space-evenly;
14
+ width: 50vw;
15
+ font-size: .7rem;
16
+ margin: 0;
17
+ padding: .2rem;
18
+ @media (min-width: $large-size) {
19
+ font-size: 1rem;
20
+ width: auto;
21
+ }
22
+
23
+ .muncher-button--rounded {
24
+ border-radius: .5rem;
25
+ margin: .25rem;
26
+ min-height: 1.8rem;
27
+ min-width: 3rem;
28
+ }
29
+
30
+ .item {
31
+ display: flex;
32
+ flex-direction: column;
33
+ flex-wrap: wrap;
34
+ justify-content: center;
35
+ align-items: center;
36
+ @media (min-width: $large-size) {
37
+ padding: .25rem;
38
+ }
39
+
40
+ p {
41
+ font-size: .6rem;
42
+ margin: 0;
43
+ }
44
+ }
45
+
46
+ .selected {
47
+ text-decoration: underline;
48
+ font-weight: bold;
49
+ }
50
+
51
+ .muncher-button--small {
52
+ color: $primary-background-color;
53
+ text-transform: capitalize;
54
+ font-size: .7rem;
55
+ font-family: $serif-font;
56
+
57
+ img {
58
+ margin-right: .4rem;
59
+ }
60
+
61
+ p {
62
+ font-size: .7rem;
63
+ }
64
+ }
65
+
66
+ .camera-icon, .virtual-tour-icon {
67
+ height: .9rem;
68
+ }
69
+
70
+ .video-tour-icon {
71
+ height: .8rem;
72
+ }
73
+ }
74
+ }
@@ -1,9 +1,8 @@
1
1
  import React from "react";
2
- import { Month } from "../../data/Calendar";
3
- export declare const sortAvailability: (a: Month, b: Month) => number;
2
+ export declare const sortAvailability: (a: string, b: string) => number;
4
3
  export declare const AvailabilityFilter: React.FC<AvailabilityFilterProps>;
5
4
  export interface AvailabilityFilterProps {
6
- filters: Set<Month>;
7
- handleFilterChange: (filter: Month) => void;
8
- currentFilters: Month[];
5
+ filters: Set<string>;
6
+ handleFilterChange: (filter: string) => void;
7
+ currentFilters: string[];
9
8
  }
@@ -9,14 +9,14 @@ var _react = _interopRequireDefault(require("react"));
9
9
 
10
10
  var _muncherUi = require("@contentmunch/muncher-ui");
11
11
 
12
- var _Calendar = require("../../data/Calendar");
13
-
14
12
  var _FloorplanDropDown = require("../../filter/FloorplanDropDown");
15
13
 
14
+ var _moment = _interopRequireDefault(require("moment"));
15
+
16
16
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
17
17
 
18
18
  var sortAvailability = function sortAvailability(a, b) {
19
- return _Calendar.fullMonths[a] - _Calendar.fullMonths[b];
19
+ return (0, _moment.default)(a, "MMM YYYY").diff((0, _moment.default)(b, "MMM YYYY"));
20
20
  };
21
21
 
22
22
  exports.sortAvailability = sortAvailability;
@@ -43,4 +43,4 @@ var AvailabilityFilter = function AvailabilityFilter(_ref) {
43
43
  };
44
44
 
45
45
  exports.AvailabilityFilter = AvailabilityFilter;
46
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJzb3J0QXZhaWxhYmlsaXR5IiwiYSIsImIiLCJmdWxsTW9udGhzIiwiQXZhaWxhYmlsaXR5RmlsdGVyIiwiZmlsdGVycyIsImhhbmRsZUZpbHRlckNoYW5nZSIsImN1cnJlbnRGaWx0ZXJzIiwiQXJyYXkiLCJmcm9tIiwia2V5cyIsInNvcnQiLCJtYXAiLCJmaWx0ZXIiLCJ0b1N0cmluZyIsImluZGV4T2YiXSwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvZmxvb3JwbGFuL3NlY3Rpb24vZmlsdGVyL0F2YWlsYWJpbGl0eS50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHtDaGVja2JveH0gZnJvbSBcIkBjb250ZW50bXVuY2gvbXVuY2hlci11aVwiO1xuaW1wb3J0IHtmdWxsTW9udGhzLCBNb250aH0gZnJvbSBcIi4uLy4uL2RhdGEvQ2FsZW5kYXJcIjtcbmltcG9ydCB7RHJvcERvd25GaWx0ZXJ9IGZyb20gXCIuLi8uLi9maWx0ZXIvRmxvb3JwbGFuRHJvcERvd25cIjtcblxuZXhwb3J0IGNvbnN0IHNvcnRBdmFpbGFiaWxpdHkgPSAoYTogTW9udGgsIGI6IE1vbnRoKSA9PiAoZnVsbE1vbnRoc1thXSAtIGZ1bGxNb250aHNbYl0pO1xuZXhwb3J0IGNvbnN0IEF2YWlsYWJpbGl0eUZpbHRlcjogUmVhY3QuRkM8QXZhaWxhYmlsaXR5RmlsdGVyUHJvcHM+ID0gKHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZmlsdGVycyxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaGFuZGxlRmlsdGVyQ2hhbmdlLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBjdXJyZW50RmlsdGVyc1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIH0pID0+IHtcblxuICAgIHJldHVybiAoXG4gICAgICAgIDxEcm9wRG93bkZpbHRlciBsYWJlbD1cIkF2YWlsYWJpbGl0eVwiPlxuICAgICAgICAgICAge0FycmF5LmZyb20oZmlsdGVycy5rZXlzKCkpLnNvcnQoc29ydEF2YWlsYWJpbGl0eSkubWFwKChmaWx0ZXI6IE1vbnRoKSA9PiAoXG4gICAgICAgICAgICAgICAgPENoZWNrYm94IGtleT17ZmlsdGVyLnRvU3RyaW5nKCl9IGxhYmVsPXtmaWx0ZXIudG9TdHJpbmcoKX0gbmFtZT17ZmlsdGVyLnRvU3RyaW5nKCl9XG4gICAgICAgICAgICAgICAgICAgICAgICAgIG9uQ2hhbmdlPXsoKSA9PiB7XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICBoYW5kbGVGaWx0ZXJDaGFuZ2UoZmlsdGVyKVxuICAgICAgICAgICAgICAgICAgICAgICAgICB9fVxuICAgICAgICAgICAgICAgICAgICAgICAgICBjaGVja2VkPXsoKSA9PiBjdXJyZW50RmlsdGVycy5pbmRleE9mKGZpbHRlcikgPiAtMX1cbiAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgKSl9XG4gICAgICAgIDwvRHJvcERvd25GaWx0ZXI+XG4gICAgKTtcbn07XG5cbmV4cG9ydCBpbnRlcmZhY2UgQXZhaWxhYmlsaXR5RmlsdGVyUHJvcHMge1xuICAgIGZpbHRlcnM6IFNldDxNb250aD47XG4gICAgaGFuZGxlRmlsdGVyQ2hhbmdlOiAoZmlsdGVyOiBNb250aCkgPT4gdm9pZDtcbiAgICBjdXJyZW50RmlsdGVyczogTW9udGhbXTtcbn0iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFBQTs7QUFDQTs7QUFDQTs7QUFDQTs7OztBQUVPLElBQU1BLGdCQUFnQixHQUFHLFNBQW5CQSxnQkFBbUIsQ0FBQ0MsQ0FBRCxFQUFXQyxDQUFYO0VBQUEsT0FBeUJDLG9CQUFBLENBQVdGLENBQVgsSUFBZ0JFLG9CQUFBLENBQVdELENBQVgsQ0FBekM7QUFBQSxDQUF6Qjs7OztBQUNBLElBQU1FLGtCQUFxRCxHQUFHLFNBQXhEQSxrQkFBd0QsT0FJTztFQUFBLElBSEZDLE9BR0UsUUFIRkEsT0FHRTtFQUFBLElBRkZDLGtCQUVFLFFBRkZBLGtCQUVFO0VBQUEsSUFERkMsY0FDRSxRQURGQSxjQUNFO0VBRXhFLG9CQUNJLDZCQUFDLGlDQUFEO0lBQWdCLEtBQUssRUFBQztFQUF0QixHQUNLQyxLQUFLLENBQUNDLElBQU4sQ0FBV0osT0FBTyxDQUFDSyxJQUFSLEVBQVgsRUFBMkJDLElBQTNCLENBQWdDWCxnQkFBaEMsRUFBa0RZLEdBQWxELENBQXNELFVBQUNDLE1BQUQ7SUFBQSxvQkFDbkQsNkJBQUMsbUJBQUQ7TUFBVSxHQUFHLEVBQUVBLE1BQU0sQ0FBQ0MsUUFBUCxFQUFmO01BQWtDLEtBQUssRUFBRUQsTUFBTSxDQUFDQyxRQUFQLEVBQXpDO01BQTRELElBQUksRUFBRUQsTUFBTSxDQUFDQyxRQUFQLEVBQWxFO01BQ1UsUUFBUSxFQUFFLG9CQUFNO1FBQ1pSLGtCQUFrQixDQUFDTyxNQUFELENBQWxCO01BQ0gsQ0FIWDtNQUlVLE9BQU8sRUFBRTtRQUFBLE9BQU1OLGNBQWMsQ0FBQ1EsT0FBZixDQUF1QkYsTUFBdkIsSUFBaUMsQ0FBQyxDQUF4QztNQUFBO0lBSm5CLEVBRG1EO0VBQUEsQ0FBdEQsQ0FETCxDQURKO0FBWUgsQ0FsQk0ifQ==
46
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJzb3J0QXZhaWxhYmlsaXR5IiwiYSIsImIiLCJtb21lbnQiLCJkaWZmIiwiQXZhaWxhYmlsaXR5RmlsdGVyIiwiZmlsdGVycyIsImhhbmRsZUZpbHRlckNoYW5nZSIsImN1cnJlbnRGaWx0ZXJzIiwiQXJyYXkiLCJmcm9tIiwia2V5cyIsInNvcnQiLCJtYXAiLCJmaWx0ZXIiLCJ0b1N0cmluZyIsImluZGV4T2YiXSwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvZmxvb3JwbGFuL3NlY3Rpb24vZmlsdGVyL0F2YWlsYWJpbGl0eS50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHtDaGVja2JveH0gZnJvbSBcIkBjb250ZW50bXVuY2gvbXVuY2hlci11aVwiO1xuaW1wb3J0IHtEcm9wRG93bkZpbHRlcn0gZnJvbSBcIi4uLy4uL2ZpbHRlci9GbG9vcnBsYW5Ecm9wRG93blwiO1xuaW1wb3J0IG1vbWVudCBmcm9tIFwibW9tZW50XCI7XG5cbmV4cG9ydCBjb25zdCBzb3J0QXZhaWxhYmlsaXR5ID0gKGE6IHN0cmluZywgYjogc3RyaW5nKSA9PiBtb21lbnQoYSwgXCJNTU0gWVlZWVwiKS5kaWZmKG1vbWVudChiLCBcIk1NTSBZWVlZXCIpKTtcblxuZXhwb3J0IGNvbnN0IEF2YWlsYWJpbGl0eUZpbHRlcjogUmVhY3QuRkM8QXZhaWxhYmlsaXR5RmlsdGVyUHJvcHM+ID0gKHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZmlsdGVycyxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaGFuZGxlRmlsdGVyQ2hhbmdlLFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBjdXJyZW50RmlsdGVyc1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIH0pID0+IHtcblxuICAgIHJldHVybiAoXG4gICAgICAgIDxEcm9wRG93bkZpbHRlciBsYWJlbD1cIkF2YWlsYWJpbGl0eVwiPlxuICAgICAgICAgICAge0FycmF5LmZyb20oZmlsdGVycy5rZXlzKCkpLnNvcnQoc29ydEF2YWlsYWJpbGl0eSkubWFwKChmaWx0ZXI6IHN0cmluZykgPT4gKFxuICAgICAgICAgICAgICAgIDxDaGVja2JveCBrZXk9e2ZpbHRlci50b1N0cmluZygpfSBsYWJlbD17ZmlsdGVyLnRvU3RyaW5nKCl9IG5hbWU9e2ZpbHRlci50b1N0cmluZygpfVxuICAgICAgICAgICAgICAgICAgICAgICAgICBvbkNoYW5nZT17KCkgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgaGFuZGxlRmlsdGVyQ2hhbmdlKGZpbHRlcilcbiAgICAgICAgICAgICAgICAgICAgICAgICAgfX1cbiAgICAgICAgICAgICAgICAgICAgICAgICAgY2hlY2tlZD17KCkgPT4gY3VycmVudEZpbHRlcnMuaW5kZXhPZihmaWx0ZXIpID4gLTF9XG4gICAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICkpfVxuICAgICAgICA8L0Ryb3BEb3duRmlsdGVyPlxuICAgICk7XG59O1xuXG5leHBvcnQgaW50ZXJmYWNlIEF2YWlsYWJpbGl0eUZpbHRlclByb3BzIHtcbiAgICBmaWx0ZXJzOiBTZXQ8c3RyaW5nPjtcbiAgICBoYW5kbGVGaWx0ZXJDaGFuZ2U6IChmaWx0ZXI6IHN0cmluZykgPT4gdm9pZDtcbiAgICBjdXJyZW50RmlsdGVyczogc3RyaW5nW107XG59Il0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQUE7O0FBQ0E7O0FBQ0E7O0FBQ0E7Ozs7QUFFTyxJQUFNQSxnQkFBZ0IsR0FBRyxTQUFuQkEsZ0JBQW1CLENBQUNDLENBQUQsRUFBWUMsQ0FBWjtFQUFBLE9BQTBCLElBQUFDLGVBQUEsRUFBT0YsQ0FBUCxFQUFVLFVBQVYsRUFBc0JHLElBQXRCLENBQTJCLElBQUFELGVBQUEsRUFBT0QsQ0FBUCxFQUFVLFVBQVYsQ0FBM0IsQ0FBMUI7QUFBQSxDQUF6Qjs7OztBQUVBLElBQU1HLGtCQUFxRCxHQUFHLFNBQXhEQSxrQkFBd0QsT0FJTztFQUFBLElBSEZDLE9BR0UsUUFIRkEsT0FHRTtFQUFBLElBRkZDLGtCQUVFLFFBRkZBLGtCQUVFO0VBQUEsSUFERkMsY0FDRSxRQURGQSxjQUNFO0VBRXhFLG9CQUNJLDZCQUFDLGlDQUFEO0lBQWdCLEtBQUssRUFBQztFQUF0QixHQUNLQyxLQUFLLENBQUNDLElBQU4sQ0FBV0osT0FBTyxDQUFDSyxJQUFSLEVBQVgsRUFBMkJDLElBQTNCLENBQWdDWixnQkFBaEMsRUFBa0RhLEdBQWxELENBQXNELFVBQUNDLE1BQUQ7SUFBQSxvQkFDbkQsNkJBQUMsbUJBQUQ7TUFBVSxHQUFHLEVBQUVBLE1BQU0sQ0FBQ0MsUUFBUCxFQUFmO01BQWtDLEtBQUssRUFBRUQsTUFBTSxDQUFDQyxRQUFQLEVBQXpDO01BQTRELElBQUksRUFBRUQsTUFBTSxDQUFDQyxRQUFQLEVBQWxFO01BQ1UsUUFBUSxFQUFFLG9CQUFNO1FBQ1pSLGtCQUFrQixDQUFDTyxNQUFELENBQWxCO01BQ0gsQ0FIWDtNQUlVLE9BQU8sRUFBRTtRQUFBLE9BQU1OLGNBQWMsQ0FBQ1EsT0FBZixDQUF1QkYsTUFBdkIsSUFBaUMsQ0FBQyxDQUF4QztNQUFBO0lBSm5CLEVBRG1EO0VBQUEsQ0FBdEQsQ0FETCxDQURKO0FBWUgsQ0FsQk0ifQ==
@@ -1,12 +1,13 @@
1
1
  import { CurrentFilters, FloorplanFilters, SortBy } from "../data/FloorplanFilters";
2
- import { Floorplan, FloorplanDetails, FloorplanSpotlight, FloorplanVariation, SimilarFloorplan, Testimonial } from "../data/Floorplan";
3
- import { PropertyId } from "../../property/data/Property";
2
+ import { Floorplan, FloorplanCardData, FloorplanDetails, FloorplanSpotlight, FloorplanVariation, SimilarFloorplan, Testimonial } from "../data/Floorplan";
3
+ import { PropertyFilterData, PropertyId } from "../../property/data/Property";
4
4
  import { Unit } from "../data/Unit";
5
5
  export declare const convertToHttps: (url: string) => string;
6
- export declare const getFloorplans: (propertyId: PropertyId) => Promise<FloorplanDetails[]>;
7
- export declare const sortAndFilter: (floorplans: FloorplanDetails[], currentFilters: CurrentFilters) => FloorplanDetails[];
8
- export declare const sortFloorplans: (floorplans: FloorplanDetails[], sortBy: SortBy) => FloorplanDetails[];
9
- export declare const filtersFrom: (floorplans: FloorplanDetails[]) => FloorplanFilters;
6
+ export declare const getAllPropertyFilterData: () => Promise<PropertyFilterData[]>;
7
+ export declare const getFloorplansFilterData: (propertyId: PropertyId) => Promise<FloorplanCardData[]>;
8
+ export declare const sortAndFilter: (floorplans: FloorplanCardData[], currentFilters: CurrentFilters) => FloorplanCardData[];
9
+ export declare const sortFloorplans: (floorplans: FloorplanCardData[], sortBy: SortBy) => FloorplanCardData[];
10
+ export declare const filtersFrom: (floorplans: FloorplanCardData[]) => FloorplanFilters;
10
11
  export declare const getFeaturedFloorplans: () => Promise<FloorplanSpotlight[]>;
11
12
  export declare const getAllActiveFloorplans: () => Promise<FloorplanDetails[]>;
12
13
  export declare const getFloorplan: (floorplanId: string) => Promise<Floorplan>;
@@ -3,7 +3,7 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
- exports.sortFloorplans = exports.sortAndFilter = exports.petPolicy = exports.permittedPets = exports.notPermittedPets = exports.isFloorplanAvailable = exports.getUnitsFor = exports.getTestimonials = exports.getSimilarFloorplans = exports.getFloorplans = exports.getFloorplanVariations = exports.getFloorplan = exports.getFeaturedFloorplans = exports.getAllActiveFloorplans = exports.filtersFrom = exports.convertToHttps = void 0;
6
+ exports.sortFloorplans = exports.sortAndFilter = exports.petPolicy = exports.permittedPets = exports.notPermittedPets = exports.isFloorplanAvailable = exports.getUnitsFor = exports.getTestimonials = exports.getSimilarFloorplans = exports.getFloorplansFilterData = exports.getFloorplanVariations = exports.getFloorplan = exports.getFeaturedFloorplans = exports.getAllPropertyFilterData = exports.getAllActiveFloorplans = exports.filtersFrom = exports.convertToHttps = void 0;
7
7
 
8
8
  var _lodash = _interopRequireDefault(require("lodash"));
9
9
 
@@ -17,6 +17,8 @@ var _Utils = require("../../utils/Utils");
17
17
 
18
18
  var _Unit = require("../data/Unit");
19
19
 
20
+ var _GraphqlQuery = _interopRequireDefault(require("../../service/GraphqlQuery"));
21
+
20
22
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
21
23
 
22
24
  function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
@@ -38,13 +40,71 @@ var convertToHttps = function convertToHttps(url) {
38
40
 
39
41
  exports.convertToHttps = convertToHttps;
40
42
 
41
- var getFloorplans = function getFloorplans(propertyId) {
42
- return _AdminApi.default.get("properties/" + propertyId + "/floorplans?projection=details").then(function (response) {
43
- return response.data._embedded.floorplans;
43
+ var getAllPropertyFilterDataQuery = function getAllPropertyFilterDataQuery() {
44
+ return '{ \
45
+ properties { \
46
+ name active \
47
+ floorplans { \
48
+ id name active bedroom bathroom coverImage featured \
49
+ threeSixtyVideoTourLink videoTourLink style \
50
+ units { \
51
+ rent squareFoot active moveInDate \
52
+ } \
53
+ } \
54
+ } \
55
+ }';
56
+ };
57
+
58
+ var getAllPropertyFilterData = function getAllPropertyFilterData() {
59
+ return (0, _GraphqlQuery.default)(getAllPropertyFilterDataQuery()).then(function (response) {
60
+ var properties = response.data.data.properties.filter(function (property) {
61
+ return property.active;
62
+ });
63
+ properties.forEach(function (property) {
64
+ property.floorplans = property.floorplans.filter(function (floorplan) {
65
+ return floorplan.active;
66
+ });
67
+ property.floorplans.forEach(function (floorplan) {
68
+ floorplan.units = floorplan.units.filter(function (unit) {
69
+ return unit.active;
70
+ });
71
+ });
72
+ });
73
+ return properties;
44
74
  });
45
75
  };
46
76
 
47
- exports.getFloorplans = getFloorplans;
77
+ exports.getAllPropertyFilterData = getAllPropertyFilterData;
78
+
79
+ var getFloorplansFilterDataQuery = function getFloorplansFilterDataQuery(propertyId) {
80
+ return '{ \
81
+ property(id: "' + propertyId + '") { \
82
+ floorplans { \
83
+ id name active bedroom bathroom coverImage featured \
84
+ threeSixtyVideoTourLink videoTourLink style \
85
+ units { \
86
+ rent squareFoot active moveInDate \
87
+ } \
88
+ } \
89
+ } \
90
+ }';
91
+ };
92
+
93
+ var getFloorplansFilterData = function getFloorplansFilterData(propertyId) {
94
+ return (0, _GraphqlQuery.default)(getFloorplansFilterDataQuery(propertyId)).then(function (response) {
95
+ var floorplans = response.data.data.property.floorplans.filter(function (floorplan) {
96
+ return floorplan.active;
97
+ });
98
+ floorplans.forEach(function (floorplan) {
99
+ floorplan.units = floorplan.units.filter(function (unit) {
100
+ return unit.active;
101
+ });
102
+ });
103
+ return floorplans;
104
+ });
105
+ };
106
+
107
+ exports.getFloorplansFilterData = getFloorplansFilterData;
48
108
 
49
109
  var sortAndFilter = function sortAndFilter(floorplans, currentFilters) {
50
110
  return sortFloorplans(floorplans.filter(function (floorplan) {
@@ -54,13 +114,19 @@ var sortAndFilter = function sortAndFilter(floorplans, currentFilters) {
54
114
 
55
115
  exports.sortAndFilter = sortAndFilter;
56
116
 
57
- var moveInDateToMonth = function moveInDateToMonth(moveInDate) {
58
- return (0, _moment.default)(moveInDate, "YYYY-MM-DD").format('MMM');
117
+ var isDateWithinTwelveMonths = function isDateWithinTwelveMonths(date) {
118
+ var today = (0, _moment.default)();
119
+ var diff = (0, _moment.default)(date, "YYYY-MM-DD").diff(today, 'months', false);
120
+ return diff > 0 && diff < 12;
121
+ };
122
+
123
+ var moveInDateToMonthYear = function moveInDateToMonthYear(moveInDate) {
124
+ return (0, _moment.default)(moveInDate, "YYYY-MM-DD").format('MMM YYYY');
59
125
  };
60
126
 
61
127
  var isAvailable = function isAvailable(floorplan, availabilityFilters) {
62
128
  return availabilityFilters.length === 0 ? true : floorplan.units.some(function (unit) {
63
- return availabilityFilters.indexOf(moveInDateToMonth(unit.moveInDate)) > -1;
129
+ return availabilityFilters.indexOf(moveInDateToMonthYear(unit.moveInDate)) > -1;
64
130
  });
65
131
  };
66
132
 
@@ -107,7 +173,7 @@ var filtersFrom = function filtersFrom(floorplans) {
107
173
  bedroomFilters.add(floorplan.bedroom);
108
174
  styleFilters.add(floorplan.style);
109
175
  floorplan.units.forEach(function (value) {
110
- if (value.moveInDate) availabilityFilters.add(moveInDateToMonth(value.moveInDate));
176
+ if (value.moveInDate && isDateWithinTwelveMonths(value.moveInDate)) availabilityFilters.add(moveInDateToMonthYear(value.moveInDate));
111
177
  });
112
178
  });
113
179
  return {
@@ -249,4 +315,4 @@ var unitWithMostAllowedPet = function unitWithMostAllowedPet(units) {
249
315
  return petOrdinal(b.allowedPet) - petOrdinal(a.allowedPet);
250
316
  }).pop();
251
317
  };
252
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["convertToHttps","url","replace","getFloorplans","propertyId","AdminApi","get","then","response","data","_embedded","floorplans","sortAndFilter","currentFilters","sortFloorplans","filter","floorplan","filterMatches","sortBy","moveInDateToMonth","moveInDate","moment","format","isAvailable","availabilityFilters","length","units","some","unit","indexOf","isBedroomsMatch","bedroomFilters","bedroom","isStyleMatch","styleFilters","style","isInPriceRange","minRent","maxRent","minMax","minumMaximum","min","max","SortFields","sortField","order","sort","a","b","_","orderBy","filtersFrom","Set","forEach","add","value","availability","getFeaturedFloorplans","featured","property","active","getAllActiveFloorplans","getFloorplan","floorplanId","getUnitsFor","getSimilarFloorplans","getFloorplanVariations","today","isFloorplanAvailable","isAfter","dateToMoment","getTestimonials","permittedPets","unitWithMostAllowedPet","allowedPet","Pet","LARGE_DOG_SMALL_DOG_CAT","SMALL_DOG_CAT","CAT","notPermittedPets","NO_PET","petPolicy","petOrdinal","pet","Object","keys","pop"],"sources":["../../../src/floorplan/service/FloorplanService.ts"],"sourcesContent":["import _ from 'lodash';\nimport {Month} from \"../data/Calendar\";\nimport {CurrentFilters, FloorplanFilters, SortBy, SortFields} from \"../data/FloorplanFilters\";\nimport moment from \"moment\";\nimport AdminApi from \"../../service/AdminApi\";\nimport {\n    Floorplan,\n    FloorplanDetails,\n    FloorplanSpotlight,\n    FloorplanStyle,\n    FloorplanVariation,\n    SimilarFloorplan,\n    Testimonial\n} from \"../data/Floorplan\";\nimport {dateToMoment, minumMaximum} from \"../../utils/Utils\";\nimport {PropertyId} from \"../../property/data/Property\";\nimport {Pet, Unit} from \"../data/Unit\";\n\n\nexport const convertToHttps = (url: string): string => {\n    if (url === null)\n        return \"\";\n    return url.replace(/^http:\\/\\//i, 'https://');\n};\nexport const getFloorplans = (propertyId: PropertyId): Promise<FloorplanDetails[]> => {\n\n    return AdminApi.get(\"properties/\" + propertyId + \"/floorplans?projection=details\").then(response => response.data._embedded.floorplans);\n};\nexport const sortAndFilter = (floorplans: FloorplanDetails[], currentFilters: CurrentFilters): FloorplanDetails[] => {\n    return sortFloorplans(floorplans.filter(floorplan => filterMatches(floorplan, currentFilters)), currentFilters.sortBy);\n};\n\nconst moveInDateToMonth = (moveInDate: string | null): string => moment(moveInDate, \"YYYY-MM-DD\").format('MMM');\n\nconst isAvailable = (floorplan: FloorplanDetails, availabilityFilters: Month[]): boolean => {\n    return availabilityFilters.length === 0 ? true :\n        floorplan.units.some((unit) => availabilityFilters.indexOf(moveInDateToMonth(unit.moveInDate)) > -1);\n};\nconst isBedroomsMatch = (floorplan: FloorplanDetails, bedroomFilters: number[]): boolean => {\n    return bedroomFilters.length === 0 ? true : bedroomFilters.indexOf(floorplan.bedroom) > -1;\n};\nconst isStyleMatch = (floorplan: FloorplanDetails, styleFilters: FloorplanStyle[]): boolean => {\n    return styleFilters.length === 0 ? true : styleFilters.indexOf(floorplan.style) > -1;\n}\nconst isInPriceRange = (floorplan: FloorplanDetails, minRent: number, maxRent: number): boolean => {\n    const minMax = minumMaximum(floorplan.units, \"rent\");\n    return minMax.min >= minRent && minMax.max <= maxRent;\n}\n\nconst filterMatches = (floorplan: FloorplanDetails, currentFilters: CurrentFilters) => {\n    return isAvailable(floorplan, currentFilters.availabilityFilters) &&\n        isInPriceRange(floorplan, currentFilters.minRent, currentFilters.maxRent) &&\n        isStyleMatch(floorplan, currentFilters.styleFilters) &&\n        isBedroomsMatch(floorplan, currentFilters.bedroomFilters);\n}\nexport const sortFloorplans = (floorplans: FloorplanDetails[], sortBy: SortBy): FloorplanDetails[] => {\n    if (SortFields[sortBy].sortField === \"minRate\" && SortFields[sortBy].order === \"asc\") {\n        return floorplans.sort((a, b) => minumMaximum(a.units, \"rent\").min - minumMaximum(b.units, \"rent\").min);\n    }\n    if (SortFields[sortBy].sortField === \"minRate\" && SortFields[sortBy].order === \"desc\") {\n        return floorplans.sort((a, b) => minumMaximum(b.units, \"rent\").min - minumMaximum(a.units, \"rent\").min);\n    }\n    return _.orderBy(floorplans, SortFields[sortBy].sortField, SortFields[sortBy].order);\n};\n\n\nexport const filtersFrom = (floorplans: FloorplanDetails[]): FloorplanFilters => {\n\n    const bedroomFilters = new Set<number>();\n    const availabilityFilters = new Set<Month>();\n    const styleFilters = new Set<FloorplanStyle>();\n\n    floorplans.forEach(floorplan => {\n        bedroomFilters.add(floorplan.bedroom);\n        styleFilters.add(floorplan.style);\n\n        floorplan.units.forEach((value) => {\n            if (value.moveInDate)\n                availabilityFilters.add(moveInDateToMonth(value.moveInDate));\n        });\n    });\n    return {\n        bedroom: bedroomFilters,\n        availability: availabilityFilters,\n        style: styleFilters\n    }\n};\n\n\nexport const getFeaturedFloorplans = (): Promise<FloorplanSpotlight[]> => {\n\n    return AdminApi.get(\"floorplans?projection=spotlight&size=200\")\n        .then(response =>\n            response.data._embedded.floorplans.filter((floorplan: FloorplanSpotlight) => floorplan.featured && floorplan.property.active)\n        );\n};\n\nexport const getAllActiveFloorplans = (): Promise<FloorplanDetails[]> => {\n\n    return AdminApi.get(\"floorplans?projection=details&size=200\")\n        .then(response =>\n            response.data._embedded.floorplans\n                .filter((floorplan: Floorplan) => floorplan.active)\n                .filter((floorplan: Floorplan) => floorplan.style !== \"GARAGE\")\n        );\n};\n\nexport const getFloorplan = (floorplanId: string): Promise<Floorplan> =>\n    AdminApi.get(\"floorplans/\" + floorplanId + \"?projection=withId\").then(response => response.data);\n\nexport const getUnitsFor = (floorplanId: string): Promise<Unit[]> =>\n    AdminApi.get(\"units/byFloorplan?floorplanId=\" + floorplanId).then(response => response.data);\n\nexport const getSimilarFloorplans = (floorplanId: string): Promise<SimilarFloorplan[]> =>\n    AdminApi.get(\"similarFloorplans/byFloorplan?floorplanId=\" + floorplanId).then(response => response.data);\n\nexport const getFloorplanVariations = (floorplanId: string): Promise<FloorplanVariation[]> =>\n    AdminApi.get(\"floorplanVariations/byFloorplan?floorplanId=\" + floorplanId).then(response => response.data);\nconst today = moment();\nexport const isFloorplanAvailable = (floorplan: Floorplan): boolean => floorplan.units.some((unit) => today.isAfter(dateToMoment(unit.moveInDate)));\nexport const getTestimonials = (floorplanId: string): Promise<Testimonial[]> =>\n    AdminApi.get(\"testimonials/byFloorplan?floorplanId=\" + floorplanId).then(response => response.data);\n\n\nexport const permittedPets = (floorplan: Floorplan): string[] => {\n\n    const unit = unitWithMostAllowedPet([...floorplan.units]);\n\n    switch (unit?.allowedPet) {\n        case Pet.LARGE_DOG_SMALL_DOG_CAT:\n            return ['Large Dog', 'Small Dog', 'Cat'];\n        case Pet.SMALL_DOG_CAT:\n            return ['Small Dog', 'Cat'];\n        case Pet.CAT:\n            return ['Cat'];\n        default:\n            return ['None'];\n    }\n}\n\nexport const notPermittedPets = (floorplan: Floorplan): string[] => {\n\n    const unit = unitWithMostAllowedPet([...floorplan.units]);\n\n    switch (unit?.allowedPet) {\n        case Pet.LARGE_DOG_SMALL_DOG_CAT:\n            return [];\n        case Pet.SMALL_DOG_CAT:\n            return ['Large Dog'];\n        case Pet.CAT:\n            return ['Large Dog', 'Small Dog'];\n        case Pet.NO_PET:\n            return ['Large Dog', 'Small Dog', 'Cat'];\n        default:\n            return [];\n    }\n}\nexport const petPolicy = (floorplan: Floorplan): string | undefined => {\n    const unit = unitWithMostAllowedPet([...floorplan.units]);\n    return unit?.petPolicy;\n}\nconst unitWithMostAllowedPet = (units: Unit[]): Unit | undefined => {\n\n    const petOrdinal = (pet: Pet) => Object.keys(Pet).indexOf(pet);\n    return units.sort((a, b) => petOrdinal(b.allowedPet) - petOrdinal(a.allowedPet)).pop();\n\n\n}"],"mappings":"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"}
318
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["convertToHttps","url","replace","getAllPropertyFilterDataQuery","getAllPropertyFilterData","GraphqlQuery","then","response","properties","data","filter","property","active","forEach","floorplans","floorplan","units","unit","getFloorplansFilterDataQuery","propertyId","getFloorplansFilterData","sortAndFilter","currentFilters","sortFloorplans","filterMatches","sortBy","isDateWithinTwelveMonths","date","today","moment","diff","moveInDateToMonthYear","moveInDate","format","isAvailable","availabilityFilters","length","some","indexOf","isBedroomsMatch","bedroomFilters","bedroom","isStyleMatch","styleFilters","style","isInPriceRange","minRent","maxRent","minMax","minumMaximum","min","max","SortFields","sortField","order","sort","a","b","_","orderBy","filtersFrom","Set","add","value","availability","getFeaturedFloorplans","AdminApi","get","_embedded","featured","getAllActiveFloorplans","getFloorplan","floorplanId","getUnitsFor","getSimilarFloorplans","getFloorplanVariations","isFloorplanAvailable","isAfter","dateToMoment","getTestimonials","permittedPets","unitWithMostAllowedPet","allowedPet","Pet","LARGE_DOG_SMALL_DOG_CAT","SMALL_DOG_CAT","CAT","notPermittedPets","NO_PET","petPolicy","petOrdinal","pet","Object","keys","pop"],"sources":["../../../src/floorplan/service/FloorplanService.ts"],"sourcesContent":["import _ from 'lodash';\nimport {Month} from \"../data/Calendar\";\nimport {CurrentFilters, FloorplanFilters, SortBy, SortFields} from \"../data/FloorplanFilters\";\nimport moment from \"moment\";\nimport AdminApi from \"../../service/AdminApi\";\nimport {\n    Floorplan,\n    FloorplanCardData,\n    FloorplanDetails,\n    FloorplanSpotlight,\n    FloorplanStyle,\n    FloorplanVariation,\n    SimilarFloorplan,\n    Testimonial\n} from \"../data/Floorplan\";\nimport {dateToMoment, minumMaximum} from \"../../utils/Utils\";\nimport {PropertyFilterData, PropertyId} from \"../../property/data/Property\";\nimport {Pet, Unit} from \"../data/Unit\";\nimport GraphqlQuery from \"../../service/GraphqlQuery\";\n\n\nexport const convertToHttps = (url: string): string => {\n    if (url === null)\n        return \"\";\n    return url.replace(/^http:\\/\\//i, 'https://');\n};\nconst getAllPropertyFilterDataQuery = () => {\n    return '{                                                       \\\n        properties {                                                \\\n            name active                                             \\\n            floorplans {                                            \\\n                id name active bedroom bathroom coverImage featured \\\n                threeSixtyVideoTourLink videoTourLink style         \\\n                units {                                             \\\n                    rent squareFoot active moveInDate               \\\n                }                                                   \\\n            }                                                       \\\n        }                                                           \\\n    }'\n}\nexport const getAllPropertyFilterData = (): Promise<PropertyFilterData[]> => {\n    return GraphqlQuery(getAllPropertyFilterDataQuery()).then(response => {\n            const properties: PropertyFilterData[] = response.data.data.properties.filter((property: PropertyFilterData) => property.active);\n\n            properties.forEach(property => {\n                property.floorplans = property.floorplans.filter(floorplan => floorplan.active);\n                property.floorplans.forEach(floorplan => {\n                    floorplan.units = floorplan.units.filter(unit => unit.active);\n                });\n            });\n            return properties;\n        }\n    );\n}\nconst getFloorplansFilterDataQuery = (propertyId: String) => {\n    return '{                                                       \\\n        property(id: \"' + propertyId + '\") {                        \\\n            floorplans {                                            \\\n                id name active bedroom bathroom coverImage featured \\\n                threeSixtyVideoTourLink videoTourLink style         \\\n                units {                                             \\\n                    rent squareFoot active moveInDate               \\\n                }                                                   \\\n            }                                                       \\\n        }                                                           \\\n    }'\n}\nexport const getFloorplansFilterData = (propertyId: PropertyId): Promise<FloorplanCardData[]> => {\n    return GraphqlQuery(getFloorplansFilterDataQuery(propertyId)).then(response => {\n            const floorplans: FloorplanCardData[] = response.data.data.property.floorplans.filter((floorplan: FloorplanCardData) => floorplan.active);\n            floorplans.forEach(floorplan => {\n                floorplan.units = floorplan.units.filter(unit => unit.active);\n            });\n            return floorplans;\n        }\n    );\n};\nexport const sortAndFilter = (floorplans: FloorplanCardData[], currentFilters: CurrentFilters): FloorplanCardData[] => {\n    return sortFloorplans(floorplans.filter(floorplan => filterMatches(floorplan, currentFilters)), currentFilters.sortBy);\n};\n\n\nconst isDateWithinTwelveMonths = (date: string) => {\n    const today = moment();\n    const diff = moment(date, \"YYYY-MM-DD\").diff(today, 'months', false);\n    return diff > 0 && diff < 12;\n}\nconst moveInDateToMonthYear = (moveInDate: string | null): string => moment(moveInDate, \"YYYY-MM-DD\").format('MMM YYYY');\nconst isAvailable = (floorplan: FloorplanCardData, availabilityFilters: Month[]): boolean => {\n    return availabilityFilters.length === 0 ? true :\n        floorplan.units.some((unit) => availabilityFilters.indexOf(moveInDateToMonthYear(unit.moveInDate)) > -1);\n};\nconst isBedroomsMatch = (floorplan: FloorplanCardData, bedroomFilters: number[]): boolean => {\n    return bedroomFilters.length === 0 ? true : bedroomFilters.indexOf(floorplan.bedroom) > -1;\n};\nconst isStyleMatch = (floorplan: FloorplanCardData, styleFilters: FloorplanStyle[]): boolean => {\n    return styleFilters.length === 0 ? true : styleFilters.indexOf(floorplan.style) > -1;\n}\nconst isInPriceRange = (floorplan: FloorplanCardData, minRent: number, maxRent: number): boolean => {\n    const minMax = minumMaximum(floorplan.units, \"rent\");\n    return minMax.min >= minRent && minMax.max <= maxRent;\n}\n\nconst filterMatches = (floorplan: FloorplanCardData, currentFilters: CurrentFilters) => {\n    return isAvailable(floorplan, currentFilters.availabilityFilters) &&\n        isInPriceRange(floorplan, currentFilters.minRent, currentFilters.maxRent) &&\n        isStyleMatch(floorplan, currentFilters.styleFilters) &&\n        isBedroomsMatch(floorplan, currentFilters.bedroomFilters);\n}\nexport const sortFloorplans = (floorplans: FloorplanCardData[], sortBy: SortBy): FloorplanCardData[] => {\n    if (SortFields[sortBy].sortField === \"minRate\" && SortFields[sortBy].order === \"asc\") {\n        return floorplans.sort((a, b) => minumMaximum(a.units, \"rent\").min - minumMaximum(b.units, \"rent\").min);\n    }\n    if (SortFields[sortBy].sortField === \"minRate\" && SortFields[sortBy].order === \"desc\") {\n        return floorplans.sort((a, b) => minumMaximum(b.units, \"rent\").min - minumMaximum(a.units, \"rent\").min);\n    }\n    return _.orderBy(floorplans, SortFields[sortBy].sortField, SortFields[sortBy].order);\n};\n\n\nexport const filtersFrom = (floorplans: FloorplanCardData[]): FloorplanFilters => {\n\n    const bedroomFilters = new Set<number>();\n    const availabilityFilters = new Set<string>();\n    const styleFilters = new Set<FloorplanStyle>();\n\n    floorplans.forEach(floorplan => {\n        bedroomFilters.add(floorplan.bedroom);\n        styleFilters.add(floorplan.style);\n\n        floorplan.units.forEach((value) => {\n            if (value.moveInDate && isDateWithinTwelveMonths(value.moveInDate))\n                availabilityFilters.add(moveInDateToMonthYear(value.moveInDate));\n        });\n    });\n    return {\n        bedroom: bedroomFilters,\n        availability: availabilityFilters,\n        style: styleFilters\n    }\n};\n\n\nexport const getFeaturedFloorplans = (): Promise<FloorplanSpotlight[]> => {\n\n    return AdminApi.get(\"floorplans?projection=spotlight&size=200\")\n        .then(response =>\n            response.data._embedded.floorplans.filter((floorplan: FloorplanSpotlight) => floorplan.featured && floorplan.property.active)\n        );\n};\n\nexport const getAllActiveFloorplans = (): Promise<FloorplanDetails[]> => {\n\n    return AdminApi.get(\"floorplans?projection=details&size=200\")\n        .then(response =>\n            response.data._embedded.floorplans\n                .filter((floorplan: Floorplan) => floorplan.active)\n                .filter((floorplan: Floorplan) => floorplan.style !== \"GARAGE\")\n        );\n};\n\nexport const getFloorplan = (floorplanId: string): Promise<Floorplan> =>\n    AdminApi.get(\"floorplans/\" + floorplanId + \"?projection=withId\").then(response => response.data);\n\nexport const getUnitsFor = (floorplanId: string): Promise<Unit[]> =>\n    AdminApi.get(\"units/byFloorplan?floorplanId=\" + floorplanId).then(response => response.data);\n\nexport const getSimilarFloorplans = (floorplanId: string): Promise<SimilarFloorplan[]> =>\n    AdminApi.get(\"similarFloorplans/byFloorplan?floorplanId=\" + floorplanId).then(response => response.data);\n\nexport const getFloorplanVariations = (floorplanId: string): Promise<FloorplanVariation[]> =>\n    AdminApi.get(\"floorplanVariations/byFloorplan?floorplanId=\" + floorplanId).then(response => response.data);\nconst today = moment();\nexport const isFloorplanAvailable = (floorplan: Floorplan): boolean => floorplan.units.some((unit) => today.isAfter(dateToMoment(unit.moveInDate)));\nexport const getTestimonials = (floorplanId: string): Promise<Testimonial[]> =>\n    AdminApi.get(\"testimonials/byFloorplan?floorplanId=\" + floorplanId).then(response => response.data);\n\n\nexport const permittedPets = (floorplan: Floorplan): string[] => {\n\n    const unit = unitWithMostAllowedPet([...floorplan.units]);\n\n    switch (unit?.allowedPet) {\n        case Pet.LARGE_DOG_SMALL_DOG_CAT:\n            return ['Large Dog', 'Small Dog', 'Cat'];\n        case Pet.SMALL_DOG_CAT:\n            return ['Small Dog', 'Cat'];\n        case Pet.CAT:\n            return ['Cat'];\n        default:\n            return ['None'];\n    }\n}\n\nexport const notPermittedPets = (floorplan: Floorplan): string[] => {\n\n    const unit = unitWithMostAllowedPet([...floorplan.units]);\n\n    switch (unit?.allowedPet) {\n        case Pet.LARGE_DOG_SMALL_DOG_CAT:\n            return [];\n        case Pet.SMALL_DOG_CAT:\n            return ['Large Dog'];\n        case Pet.CAT:\n            return ['Large Dog', 'Small Dog'];\n        case Pet.NO_PET:\n            return ['Large Dog', 'Small Dog', 'Cat'];\n        default:\n            return [];\n    }\n}\nexport const petPolicy = (floorplan: Floorplan): string | undefined => {\n    const unit = unitWithMostAllowedPet([...floorplan.units]);\n    return unit?.petPolicy;\n}\nconst unitWithMostAllowedPet = (units: Unit[]): Unit | undefined => {\n\n    const petOrdinal = (pet: Pet) => Object.keys(Pet).indexOf(pet);\n    return units.sort((a, b) => petOrdinal(b.allowedPet) - petOrdinal(a.allowedPet)).pop();\n\n\n}"],"mappings":"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"}
@@ -0,0 +1,13 @@
1
+ import React from "react";
2
+ import './assets/GalleryHero.scss';
3
+ import { Asset } from "../asset/data/Asset";
4
+ export declare const GalleryHeroMain: React.FC<GalleryHeroProps>;
5
+ export interface GalleryHeroProps {
6
+ assetsToShow: Asset[];
7
+ virtualTour?: string;
8
+ isAvailableNow?: boolean;
9
+ isFirst: boolean;
10
+ toursCount: number;
11
+ setCurrentView: (view: "photo" | "virtual tour" | "video tour") => void;
12
+ imageClickedHandler: (image: Asset) => void;
13
+ }
@@ -0,0 +1,101 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.GalleryHeroMain = void 0;
7
+
8
+ var _react = _interopRequireDefault(require("react"));
9
+
10
+ require("./assets/GalleryHero.scss");
11
+
12
+ var _AssetService = require("../asset/service/AssetService");
13
+
14
+ var _muncherUi = require("@contentmunch/muncher-ui");
15
+
16
+ var _HeroImageCard = require("./HeroImageCard");
17
+
18
+ var _icon = _interopRequireDefault(require("../floorplan/card/assets/360-icon.png"));
19
+
20
+ var _videoIcon = _interopRequireDefault(require("../floorplan/card/assets/video-icon.png"));
21
+
22
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
23
+
24
+ function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
25
+
26
+ function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
27
+
28
+ function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
29
+
30
+ function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
31
+
32
+ function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
33
+
34
+ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
35
+
36
+ var GalleryHeroMain = function GalleryHeroMain(_ref) {
37
+ var virtualTour = _ref.virtualTour,
38
+ setCurrentView = _ref.setCurrentView,
39
+ isAvailableNow = _ref.isAvailableNow,
40
+ assetsToShow = _ref.assetsToShow,
41
+ isFirst = _ref.isFirst,
42
+ toursCount = _ref.toursCount,
43
+ imageClickedHandler = _ref.imageClickedHandler;
44
+
45
+ var cardImageIcon = function cardImageIcon(i) {
46
+ return virtualTour && i === 0 ? /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("img", {
47
+ src: _icon.default,
48
+ alt: "tour icon",
49
+ height: 50
50
+ }), /*#__PURE__*/_react.default.createElement("p", null, "Virtual Tour")) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("img", {
51
+ src: _videoIcon.default,
52
+ alt: "video icon",
53
+ height: 40
54
+ }), /*#__PURE__*/_react.default.createElement("p", null, "Video Tour"));
55
+ };
56
+
57
+ return /*#__PURE__*/_react.default.createElement("div", {
58
+ className: "div-gallery"
59
+ }, isFirst && isAvailableNow ? /*#__PURE__*/_react.default.createElement("div", {
60
+ className: "badge--info"
61
+ }, /*#__PURE__*/_react.default.createElement(_muncherUi.Badge, {
62
+ variant: "secondary"
63
+ }, "Available Now")) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null), /*#__PURE__*/_react.default.createElement("div", {
64
+ className: "gallery-hero-two-columns"
65
+ }, isFirst ? /*#__PURE__*/_react.default.createElement("div", {
66
+ className: assetsToShow.length < 2 ? "gallery-hero-one" : "gallery-hero-column-one"
67
+ }, assetsToShow.slice(0, 1).map(function (asset) {
68
+ return /*#__PURE__*/_react.default.createElement("img", {
69
+ src: (0, _AssetService.assetUrlFrom)(asset.id),
70
+ alt: asset.name,
71
+ key: asset.id,
72
+ className: "gallery-hero--image",
73
+ onClick: function onClick() {
74
+ return imageClickedHandler(asset);
75
+ }
76
+ });
77
+ })) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null), assetsToShow.length > 1 ? /*#__PURE__*/_react.default.createElement("div", {
78
+ className: isFirst ? "gallery-hero-column-two" : "gallery-hero-column"
79
+ }, isFirst ? _toConsumableArray(Array(toursCount)).map(function (x, i) {
80
+ return /*#__PURE__*/_react.default.createElement(_HeroImageCard.HeroImageCard, {
81
+ backgroundImage: (0, _AssetService.assetUrlFrom)(assetsToShow[i].id),
82
+ key: "tour" + i,
83
+ onClick: function onClick() {
84
+ virtualTour && i === 0 ? setCurrentView("virtual tour") : setCurrentView("video tour");
85
+ }
86
+ }, cardImageIcon(i));
87
+ }) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null), assetsToShow.slice(isFirst ? 1 : 0, assetsToShow.length).map(function (asset) {
88
+ return /*#__PURE__*/_react.default.createElement("img", {
89
+ src: (0, _AssetService.assetUrlFrom)(asset.id),
90
+ alt: asset.name,
91
+ key: asset.id,
92
+ className: "gallery-hero--image",
93
+ onClick: function onClick() {
94
+ return imageClickedHandler(asset);
95
+ }
96
+ });
97
+ })) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null)));
98
+ };
99
+
100
+ exports.GalleryHeroMain = GalleryHeroMain;
101
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["GalleryHeroMain","virtualTour","setCurrentView","isAvailableNow","assetsToShow","isFirst","toursCount","imageClickedHandler","cardImageIcon","i","tourIcon","videoIcon","length","slice","map","asset","assetUrlFrom","id","name","Array","x"],"sources":["../../src/gallery/GalleryHeroMain.tsx"],"sourcesContent":["import React from \"react\";\nimport './assets/GalleryHero.scss';\nimport {Asset} from \"../asset/data/Asset\";\nimport {assetUrlFrom} from \"../asset/service/AssetService\";\nimport {Badge, Icon} from \"@contentmunch/muncher-ui\";\nimport {HeroImageCard} from \"./HeroImageCard\";\nimport tourIcon from \"../floorplan/card/assets/360-icon.png\";\nimport videoIcon from \"../floorplan/card/assets/video-icon.png\";\n\nexport const GalleryHeroMain: React.FC<GalleryHeroProps> = (\n    {\n        virtualTour, setCurrentView, isAvailableNow,\n        assetsToShow, isFirst, toursCount, imageClickedHandler,\n    }) => {\n\n    const cardImageIcon = (i: number) => virtualTour && i === 0 ?\n        <>\n            <img src={tourIcon} alt=\"tour icon\" height={50}/>\n            <p>Virtual Tour</p>\n        </> :\n        <>\n            <img src={videoIcon} alt=\"video icon\" height={40}/>\n            <p>Video Tour</p>\n        </>\n\n    return (\n        <div className=\"div-gallery\">\n            {isFirst && isAvailableNow ?\n                <div className=\"badge--info\"><Badge variant=\"secondary\">Available Now</Badge></div> : <></>}\n\n            <div className=\"gallery-hero-two-columns\">\n                {isFirst ?\n                    <div\n                        className={assetsToShow.length < 2 ? \"gallery-hero-one\" : \"gallery-hero-column-one\"}>\n                        {\n                            assetsToShow.slice(0, 1).map((asset) =>\n                                <img src={assetUrlFrom(asset.id)}\n                                     alt={asset.name}\n                                     key={asset.id}\n                                     className=\"gallery-hero--image\"\n                                     onClick={() => imageClickedHandler(asset)}\n                                />\n                            )\n                        }\n                    </div> : <></>}\n                {assetsToShow.length > 1 ?\n                    <div className={isFirst ? \"gallery-hero-column-two\" : \"gallery-hero-column\"}>\n                        {isFirst ?\n                            [...Array(toursCount)].map((x, i) =>\n\n                                <HeroImageCard backgroundImage={assetUrlFrom(assetsToShow[i].id)}\n                                               key={\"tour\" + i}\n                                               onClick={() => {\n                                                   virtualTour && i === 0 ? setCurrentView(\"virtual tour\") : setCurrentView(\"video tour\");\n                                               }}>\n                                    {cardImageIcon(i)}\n                                </HeroImageCard>\n                            ) : <></>\n                        }\n                        {\n\n                            assetsToShow.slice(isFirst ? 1 : 0, assetsToShow.length).map((asset) =>\n                                <img src={assetUrlFrom(asset.id)}\n                                     alt={asset.name}\n                                     key={asset.id}\n                                     className=\"gallery-hero--image\"\n                                     onClick={() => imageClickedHandler(asset)}\n                                />\n                            )\n                        }\n                    </div> : <></>\n                }\n\n            </div>\n        </div>\n    );\n};\n\n\nexport interface GalleryHeroProps {\n\n    assetsToShow: Asset[];\n    virtualTour?: string;\n    isAvailableNow?: boolean;\n    isFirst: boolean;\n    toursCount: number;\n\n    setCurrentView: (view: \"photo\" | \"virtual tour\" | \"video tour\") => void;\n    imageClickedHandler: (image: Asset) => void;\n\n}"],"mappings":"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"}
@@ -0,0 +1,11 @@
1
+ import React from "react";
2
+ import './assets/GalleryHero.scss';
3
+ import { Asset } from "../asset/data/Asset";
4
+ export declare const GalleryHeroMobile: React.FC<GalleryHeroMobileProps>;
5
+ export interface GalleryHeroMobileProps {
6
+ assets: Asset[];
7
+ virtualTour?: string;
8
+ toursCount: number;
9
+ setCurrentView: (view: "photo" | "virtual tour" | "video tour") => void;
10
+ imageClickedHandler: (image: Asset) => void;
11
+ }