@renaissancerentals/renaissance-component 10.0.12 → 10.0.15

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (36) hide show
  1. package/lib/asset/AssetModal.d.ts +10 -0
  2. package/lib/asset/AssetModal.js +84 -0
  3. package/lib/asset/assets/AssetModal.scss +37 -0
  4. package/lib/assets/_variables.scss +1 -0
  5. package/lib/floorplan/card/FloorplanCard.js +2 -2
  6. package/lib/floorplan/card/SimilarFloorplanCard.d.ts +7 -0
  7. package/lib/floorplan/card/SimilarFloorplanCard.js +117 -0
  8. package/lib/floorplan/card/TestimonialsCard.d.ts +7 -0
  9. package/lib/floorplan/card/TestimonialsCard.js +68 -0
  10. package/lib/floorplan/card/assets/SimilarFloorplanCard.scss +53 -0
  11. package/lib/floorplan/card/assets/TestimonialsCard.scss +65 -0
  12. package/lib/floorplan/data/Floorplan.d.ts +39 -1
  13. package/lib/floorplan/data/Floorplan.js +1 -1
  14. package/lib/floorplan/section/FloorplanHero.d.ts +9 -0
  15. package/lib/floorplan/section/FloorplanHero.js +126 -0
  16. package/lib/floorplan/section/FloorplanSection.d.ts +13 -0
  17. package/lib/floorplan/section/FloorplanSection.js +187 -0
  18. package/lib/floorplan/section/assets/FloorplanHero.scss +75 -0
  19. package/lib/floorplan/section/assets/FloorplanSection.scss +89 -0
  20. package/lib/floorplan/service/FloorplanService.d.ts +11 -1
  21. package/lib/floorplan/service/FloorplanService.js +127 -2
  22. package/lib/gallery/GalleryHero.d.ts +2 -2
  23. package/lib/gallery/GalleryHero.js +53 -8
  24. package/lib/gallery/GalleryModal.js +5 -5
  25. package/lib/gallery/VideoTours.d.ts +5 -0
  26. package/lib/gallery/VideoTours.js +56 -0
  27. package/lib/gallery/VirtualTour.d.ts +5 -0
  28. package/lib/gallery/VirtualTour.js +28 -0
  29. package/lib/gallery/assets/GalleryHero.scss +64 -3
  30. package/lib/index.d.ts +4 -3
  31. package/lib/index.js +77 -1
  32. package/lib/utils/Utils.d.ts +3 -0
  33. package/lib/utils/Utils.js +16 -2
  34. package/package.json +2 -1
  35. package/lib/card/data/ImageCardData.d.ts +0 -6
  36. package/lib/card/data/ImageCardData.js +0 -6
@@ -3,7 +3,7 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
- exports.sortFloorplans = exports.sortAndFilter = exports.getFloorplans = exports.filtersFrom = exports.convertToHttps = void 0;
6
+ exports.sortFloorplans = exports.sortAndFilter = exports.petPolicy = exports.permittedPets = exports.notPermittedPets = exports.isFloorplanAvailable = exports.getTestimonials = exports.getSimilarFloorplans = exports.getFloorplans = exports.getFloorplanVariations = exports.getFloorplan = exports.getFeaturedFloorplans = exports.getAllActiveFloorplans = exports.filtersFrom = exports.convertToHttps = void 0;
7
7
 
8
8
  var _lodash = _interopRequireDefault(require("lodash"));
9
9
 
@@ -15,6 +15,8 @@ var _AdminApi = _interopRequireDefault(require("../../service/AdminApi"));
15
15
 
16
16
  var _Utils = require("../../utils/Utils");
17
17
 
18
+ var _Unit = require("../data/Unit");
19
+
18
20
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
19
21
 
20
22
  var convertToHttps = function convertToHttps(url) {
@@ -104,4 +106,127 @@ var filtersFrom = function filtersFrom(floorplans) {
104
106
  };
105
107
 
106
108
  exports.filtersFrom = filtersFrom;
107
- //# 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"],"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 {FloorplanDetails, FloorplanStyle} from \"../data/Floorplan\";\nimport {minumMaximum} from \"../../utils/Utils\";\nimport {PropertyId} from \"../../property/data/Property\";\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"],"mappings":";;;;;;;AAAA;;AAEA;;AACA;;AACA;;AAEA;;;;AAIO,IAAMA,cAAc,GAAG,SAAjBA,cAAiB,CAACC,GAAD,EAAyB;EACnD,IAAIA,GAAG,KAAK,IAAZ,EACI,OAAO,EAAP;EACJ,OAAOA,GAAG,CAACC,OAAJ,CAAY,aAAZ,EAA2B,UAA3B,CAAP;AACH,CAJM;;;;AAKA,IAAMC,aAAa,GAAG,SAAhBA,aAAgB,CAACC,UAAD,EAAyD;EAElF,OAAOC,iBAAA,CAASC,GAAT,CAAa,gBAAgBF,UAAhB,GAA6B,gCAA1C,EAA4EG,IAA5E,CAAiF,UAAAC,QAAQ;IAAA,OAAIA,QAAQ,CAACC,IAAT,CAAcC,SAAd,CAAwBC,UAA5B;EAAA,CAAzF,CAAP;AACH,CAHM;;;;AAIA,IAAMC,aAAa,GAAG,SAAhBA,aAAgB,CAACD,UAAD,EAAiCE,cAAjC,EAAwF;EACjH,OAAOC,cAAc,CAACH,UAAU,CAACI,MAAX,CAAkB,UAAAC,SAAS;IAAA,OAAIC,aAAa,CAACD,SAAD,EAAYH,cAAZ,CAAjB;EAAA,CAA3B,CAAD,EAA2EA,cAAc,CAACK,MAA1F,CAArB;AACH,CAFM;;;;AAIP,IAAMC,iBAAiB,GAAG,SAApBA,iBAAoB,CAACC,UAAD;EAAA,OAAuC,IAAAC,eAAA,EAAOD,UAAP,EAAmB,YAAnB,EAAiCE,MAAjC,CAAwC,KAAxC,CAAvC;AAAA,CAA1B;;AAEA,IAAMC,WAAW,GAAG,SAAdA,WAAc,CAACP,SAAD,EAA8BQ,mBAA9B,EAAwE;EACxF,OAAOA,mBAAmB,CAACC,MAApB,KAA+B,CAA/B,GAAmC,IAAnC,GACHT,SAAS,CAACU,KAAV,CAAgBC,IAAhB,CAAqB,UAACC,IAAD;IAAA,OAAUJ,mBAAmB,CAACK,OAApB,CAA4BV,iBAAiB,CAACS,IAAI,CAACR,UAAN,CAA7C,IAAkE,CAAC,CAA7E;EAAA,CAArB,CADJ;AAEH,CAHD;;AAIA,IAAMU,eAAe,GAAG,SAAlBA,eAAkB,CAACd,SAAD,EAA8Be,cAA9B,EAAoE;EACxF,OAAOA,cAAc,CAACN,MAAf,KAA0B,CAA1B,GAA8B,IAA9B,GAAqCM,cAAc,CAACF,OAAf,CAAuBb,SAAS,CAACgB,OAAjC,IAA4C,CAAC,CAAzF;AACH,CAFD;;AAGA,IAAMC,YAAY,GAAG,SAAfA,YAAe,CAACjB,SAAD,EAA8BkB,YAA9B,EAA0E;EAC3F,OAAOA,YAAY,CAACT,MAAb,KAAwB,CAAxB,GAA4B,IAA5B,GAAmCS,YAAY,CAACL,OAAb,CAAqBb,SAAS,CAACmB,KAA/B,IAAwC,CAAC,CAAnF;AACH,CAFD;;AAGA,IAAMC,cAAc,GAAG,SAAjBA,cAAiB,CAACpB,SAAD,EAA8BqB,OAA9B,EAA+CC,OAA/C,EAA4E;EAC/F,IAAMC,MAAM,GAAG,IAAAC,mBAAA,EAAaxB,SAAS,CAACU,KAAvB,EAA8B,MAA9B,CAAf;EACA,OAAOa,MAAM,CAACE,GAAP,IAAcJ,OAAd,IAAyBE,MAAM,CAACG,GAAP,IAAcJ,OAA9C;AACH,CAHD;;AAKA,IAAMrB,aAAa,GAAG,SAAhBA,aAAgB,CAACD,SAAD,EAA8BH,cAA9B,EAAiE;EACnF,OAAOU,WAAW,CAACP,SAAD,EAAYH,cAAc,CAACW,mBAA3B,CAAX,IACHY,cAAc,CAACpB,SAAD,EAAYH,cAAc,CAACwB,OAA3B,EAAoCxB,cAAc,CAACyB,OAAnD,CADX,IAEHL,YAAY,CAACjB,SAAD,EAAYH,cAAc,CAACqB,YAA3B,CAFT,IAGHJ,eAAe,CAACd,SAAD,EAAYH,cAAc,CAACkB,cAA3B,CAHnB;AAIH,CALD;;AAMO,IAAMjB,cAAc,GAAG,SAAjBA,cAAiB,CAACH,UAAD,EAAiCO,MAAjC,EAAwE;EAClG,IAAIyB,4BAAA,CAAWzB,MAAX,EAAmB0B,SAAnB,KAAiC,SAAjC,IAA8CD,4BAAA,CAAWzB,MAAX,EAAmB2B,KAAnB,KAA6B,KAA/E,EAAsF;IAClF,OAAOlC,UAAU,CAACmC,IAAX,CAAgB,UAACC,CAAD,EAAIC,CAAJ;MAAA,OAAU,IAAAR,mBAAA,EAAaO,CAAC,CAACrB,KAAf,EAAsB,MAAtB,EAA8Be,GAA9B,GAAoC,IAAAD,mBAAA,EAAaQ,CAAC,CAACtB,KAAf,EAAsB,MAAtB,EAA8Be,GAA5E;IAAA,CAAhB,CAAP;EACH;;EACD,IAAIE,4BAAA,CAAWzB,MAAX,EAAmB0B,SAAnB,KAAiC,SAAjC,IAA8CD,4BAAA,CAAWzB,MAAX,EAAmB2B,KAAnB,KAA6B,MAA/E,EAAuF;IACnF,OAAOlC,UAAU,CAACmC,IAAX,CAAgB,UAACC,CAAD,EAAIC,CAAJ;MAAA,OAAU,IAAAR,mBAAA,EAAaQ,CAAC,CAACtB,KAAf,EAAsB,MAAtB,EAA8Be,GAA9B,GAAoC,IAAAD,mBAAA,EAAaO,CAAC,CAACrB,KAAf,EAAsB,MAAtB,EAA8Be,GAA5E;IAAA,CAAhB,CAAP;EACH;;EACD,OAAOQ,eAAA,CAAEC,OAAF,CAAUvC,UAAV,EAAsBgC,4BAAA,CAAWzB,MAAX,EAAmB0B,SAAzC,EAAoDD,4BAAA,CAAWzB,MAAX,EAAmB2B,KAAvE,CAAP;AACH,CARM;;;;AAWA,IAAMM,WAAW,GAAG,SAAdA,WAAc,CAACxC,UAAD,EAAsD;EAE7E,IAAMoB,cAAc,GAAG,IAAIqB,GAAJ,EAAvB;EACA,IAAM5B,mBAAmB,GAAG,IAAI4B,GAAJ,EAA5B;EACA,IAAMlB,YAAY,GAAG,IAAIkB,GAAJ,EAArB;EAEAzC,UAAU,CAAC0C,OAAX,CAAmB,UAAArC,SAAS,EAAI;IAC5Be,cAAc,CAACuB,GAAf,CAAmBtC,SAAS,CAACgB,OAA7B;IACAE,YAAY,CAACoB,GAAb,CAAiBtC,SAAS,CAACmB,KAA3B;IAEAnB,SAAS,CAACU,KAAV,CAAgB2B,OAAhB,CAAwB,UAACE,KAAD,EAAW;MAC/B,IAAIA,KAAK,CAACnC,UAAV,EACII,mBAAmB,CAAC8B,GAApB,CAAwBnC,iBAAiB,CAACoC,KAAK,CAACnC,UAAP,CAAzC;IACP,CAHD;EAIH,CARD;EASA,OAAO;IACHY,OAAO,EAAED,cADN;IAEHyB,YAAY,EAAEhC,mBAFX;IAGHW,KAAK,EAAED;EAHJ,CAAP;AAKH,CApBM"}
109
+
110
+ var getFeaturedFloorplans = function getFeaturedFloorplans() {
111
+ return _AdminApi.default.get("floorplans?projection=spotlight&size=200").then(function (response) {
112
+ return response.data._embedded.floorplans.filter(function (floorplan) {
113
+ return floorplan.featured && floorplan.property.active;
114
+ });
115
+ });
116
+ };
117
+
118
+ exports.getFeaturedFloorplans = getFeaturedFloorplans;
119
+
120
+ var getAllActiveFloorplans = function getAllActiveFloorplans() {
121
+ return _AdminApi.default.get("floorplans?projection=details&size=200").then(function (response) {
122
+ return response.data._embedded.floorplans.filter(function (floorplan) {
123
+ return floorplan.active;
124
+ }).filter(function (floorplan) {
125
+ return floorplan.style !== "GARAGE";
126
+ });
127
+ });
128
+ };
129
+
130
+ exports.getAllActiveFloorplans = getAllActiveFloorplans;
131
+
132
+ var getFloorplan = function getFloorplan(floorplanId) {
133
+ return _AdminApi.default.get("floorplans/" + floorplanId + "?projection=withId").then(function (response) {
134
+ return response.data;
135
+ });
136
+ };
137
+
138
+ exports.getFloorplan = getFloorplan;
139
+
140
+ var getSimilarFloorplans = function getSimilarFloorplans(floorplanId) {
141
+ return _AdminApi.default.get("similarFloorplans/byFloorplan?floorplanId=" + floorplanId).then(function (response) {
142
+ return response.data;
143
+ });
144
+ };
145
+
146
+ exports.getSimilarFloorplans = getSimilarFloorplans;
147
+
148
+ var getFloorplanVariations = function getFloorplanVariations(floorplanId) {
149
+ return _AdminApi.default.get("floorplanVariations/byFloorplan?floorplanId=" + floorplanId).then(function (response) {
150
+ return response.data;
151
+ });
152
+ };
153
+
154
+ exports.getFloorplanVariations = getFloorplanVariations;
155
+ var today = (0, _moment.default)();
156
+
157
+ var isFloorplanAvailable = function isFloorplanAvailable(floorplan) {
158
+ return floorplan.units.some(function (unit) {
159
+ return today.isAfter((0, _Utils.dateToMoment)(unit.moveInDate));
160
+ });
161
+ };
162
+
163
+ exports.isFloorplanAvailable = isFloorplanAvailable;
164
+
165
+ var getTestimonials = function getTestimonials(floorplanId) {
166
+ return _AdminApi.default.get("testimonials/byFloorplan?floorplanId=" + floorplanId).then(function (response) {
167
+ return response.data;
168
+ });
169
+ };
170
+
171
+ exports.getTestimonials = getTestimonials;
172
+
173
+ var permittedPets = function permittedPets(floorplan) {
174
+ var unit = unitWithMostAllowedPet(floorplan);
175
+
176
+ switch (unit === null || unit === void 0 ? void 0 : unit.allowedPet) {
177
+ case _Unit.Pet.LARGE_DOG_SMALL_DOG_CAT:
178
+ return ['Large Dog', 'Small Dog', 'Cat'];
179
+
180
+ case _Unit.Pet.SMALL_DOG_CAT:
181
+ return ['Small Dog', 'Cat'];
182
+
183
+ case _Unit.Pet.CAT:
184
+ return ['Cat'];
185
+
186
+ default:
187
+ return ['None'];
188
+ }
189
+ };
190
+
191
+ exports.permittedPets = permittedPets;
192
+
193
+ var notPermittedPets = function notPermittedPets(floorplan) {
194
+ var unit = unitWithMostAllowedPet(floorplan);
195
+
196
+ switch (unit === null || unit === void 0 ? void 0 : unit.allowedPet) {
197
+ case _Unit.Pet.LARGE_DOG_SMALL_DOG_CAT:
198
+ return [];
199
+
200
+ case _Unit.Pet.SMALL_DOG_CAT:
201
+ return ['Large Dog'];
202
+
203
+ case _Unit.Pet.CAT:
204
+ return ['Large Dog', 'Small Dog'];
205
+
206
+ case _Unit.Pet.NO_PET:
207
+ return ['Large Dog', 'Small Dog', 'Cat'];
208
+
209
+ default:
210
+ return [];
211
+ }
212
+ };
213
+
214
+ exports.notPermittedPets = notPermittedPets;
215
+
216
+ var petPolicy = function petPolicy(floorplan) {
217
+ var unit = unitWithMostAllowedPet(floorplan);
218
+ return unit === null || unit === void 0 ? void 0 : unit.petPolicy;
219
+ };
220
+
221
+ exports.petPolicy = petPolicy;
222
+
223
+ var unitWithMostAllowedPet = function unitWithMostAllowedPet(floorplan) {
224
+ var petOrdinal = function petOrdinal(pet) {
225
+ return Object.keys(_Unit.Pet).indexOf(pet);
226
+ };
227
+
228
+ return floorplan.units.sort(function (a, b) {
229
+ return petOrdinal(b.allowedPet) - petOrdinal(a.allowedPet);
230
+ }).pop();
231
+ };
232
+ //# 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","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, 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\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 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);\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);\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);\n    return unit?.petPolicy;\n}\nconst unitWithMostAllowedPet = (floorplan: Floorplan): Unit | undefined => {\n\n    const petOrdinal = (pet: Pet) => Object.keys(Pet).indexOf(pet);\n    return floorplan.units.sort((a, b) => petOrdinal(b.allowedPet) - petOrdinal(a.allowedPet)).pop();\n\n\n}"],"mappings":"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"}
@@ -4,7 +4,7 @@ import { Asset } from "../asset/data/Asset";
4
4
  export declare const GalleryHero: React.FC<GalleryHeroProps>;
5
5
  export interface GalleryHeroProps {
6
6
  assets: Asset[];
7
- virtualTourCount?: number;
8
- videoTourCount?: number;
7
+ virtualTour?: string;
8
+ videoTours: string[];
9
9
  isAvailableNow?: boolean;
10
10
  }
@@ -17,6 +17,10 @@ var _muncherUi = require("@contentmunch/muncher-ui");
17
17
 
18
18
  var _GalleryModal = require("./GalleryModal");
19
19
 
20
+ var _VirtualTour = require("./VirtualTour");
21
+
22
+ var _VideoTours = require("./VideoTours");
23
+
20
24
  function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
21
25
 
22
26
  function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
@@ -47,8 +51,8 @@ var calculateTotalPages = function calculateTotalPages(assets) {
47
51
 
48
52
  var GalleryHero = function GalleryHero(_ref) {
49
53
  var assets = _ref.assets,
50
- videoTourCount = _ref.videoTourCount,
51
- virtualTourCount = _ref.virtualTourCount,
54
+ videoTours = _ref.videoTours,
55
+ virtualTour = _ref.virtualTour,
52
56
  isAvailableNow = _ref.isAvailableNow;
53
57
 
54
58
  var _useState = (0, _react.useState)(false),
@@ -73,6 +77,11 @@ var GalleryHero = function GalleryHero(_ref) {
73
77
 
74
78
  var totalPages = calculateTotalPages(assets);
75
79
 
80
+ var _useState9 = (0, _react.useState)("photo"),
81
+ _useState10 = _slicedToArray(_useState9, 2),
82
+ currentView = _useState10[0],
83
+ setCurrentView = _useState10[1];
84
+
76
85
  var imageClickedHandler = function imageClickedHandler(image) {
77
86
  setShowModal(true);
78
87
  setAssetInFocus(image);
@@ -99,15 +108,39 @@ var GalleryHero = function GalleryHero(_ref) {
99
108
  };
100
109
 
101
110
  var photoStat = function photoStat() {
102
- return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, assets.length, " Photo", makePlural(assets.length));
111
+ return /*#__PURE__*/_react.default.createElement(_muncherUi.Button, {
112
+ size: "small",
113
+ variant: "transparent",
114
+ onClick: function onClick() {
115
+ setCurrentView("photo");
116
+ }
117
+ }, /*#__PURE__*/_react.default.createElement("span", {
118
+ className: currentView === "photo" ? "selected" : ""
119
+ }, assets.length, " Photo", makePlural(assets.length)));
103
120
  };
104
121
 
105
122
  var virtualTourStat = function virtualTourStat() {
106
- return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, virtualTourCount && virtualTourCount > 0 ? /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, "\xA0|\xA0", virtualTourCount, " Virtual Tour", makePlural(virtualTourCount)) : "");
123
+ return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, virtualTour ? /*#__PURE__*/_react.default.createElement(_muncherUi.Button, {
124
+ size: "small",
125
+ variant: "transparent",
126
+ onClick: function onClick() {
127
+ setCurrentView("virtual tour");
128
+ }
129
+ }, "\xA0|\xA0", /*#__PURE__*/_react.default.createElement("span", {
130
+ className: currentView === "virtual tour" ? "selected" : ""
131
+ }, "1 Virtual Tour")) : "");
107
132
  };
108
133
 
109
134
  var videoTourStat = function videoTourStat() {
110
- return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, videoTourCount && videoTourCount > 0 ? /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, "\xA0|\xA0", videoTourCount, " Video Tour", makePlural(videoTourCount)) : "");
135
+ return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, videoTours.length > 0 ? /*#__PURE__*/_react.default.createElement(_muncherUi.Button, {
136
+ size: "small",
137
+ variant: "transparent",
138
+ onClick: function onClick() {
139
+ setCurrentView("video tour");
140
+ }
141
+ }, "\xA0|\xA0", /*#__PURE__*/_react.default.createElement("span", {
142
+ className: currentView === "video tour" ? "selected" : ""
143
+ }, videoTours.length, " Video Tour", makePlural(videoTours.length))) : "");
111
144
  };
112
145
 
113
146
  return /*#__PURE__*/_react.default.createElement("div", {
@@ -122,6 +155,8 @@ var GalleryHero = function GalleryHero(_ref) {
122
155
  modalCloseHandler: modalCloseHandler
123
156
  }), /*#__PURE__*/_react.default.createElement("div", {
124
157
  className: "gallery-hero main"
158
+ }, currentView === "photo" ? /*#__PURE__*/_react.default.createElement("div", {
159
+ className: "photo-view"
125
160
  }, isAvailableNow && page === 0 ? /*#__PURE__*/_react.default.createElement("div", {
126
161
  className: "badge--info"
127
162
  }, /*#__PURE__*/_react.default.createElement(_muncherUi.Badge, {
@@ -174,12 +209,18 @@ var GalleryHero = function GalleryHero(_ref) {
174
209
  setPage(page + 1);
175
210
  }
176
211
  }
177
- })) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null), /*#__PURE__*/_react.default.createElement("div", {
212
+ })) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null)) : "", currentView === "video tour" ? /*#__PURE__*/_react.default.createElement(_VideoTours.VideoTours, {
213
+ videoTourUrls: videoTours
214
+ }) : "", currentView === "virtual tour" ? /*#__PURE__*/_react.default.createElement(_VirtualTour.VirtualTour, {
215
+ virtualTourUrl: virtualTour
216
+ }) : "", /*#__PURE__*/_react.default.createElement("div", {
178
217
  className: "badge--stats"
179
218
  }, /*#__PURE__*/_react.default.createElement(_muncherUi.Badge, {
180
219
  variant: "tertiary"
181
220
  }, photoStat(), virtualTourStat(), videoTourStat()))), /*#__PURE__*/_react.default.createElement("div", {
182
221
  className: "gallery-hero mobile"
222
+ }, currentView === "photo" ? /*#__PURE__*/_react.default.createElement("div", {
223
+ className: "photo-view"
183
224
  }, isAvailableNow && assetIndex === 0 ? /*#__PURE__*/_react.default.createElement("div", {
184
225
  className: "badge--info"
185
226
  }, /*#__PURE__*/_react.default.createElement(_muncherUi.Badge, {
@@ -222,7 +263,11 @@ var GalleryHero = function GalleryHero(_ref) {
222
263
  setAssetIndex(assetIndex + 1);
223
264
  }
224
265
  }
225
- })) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null), /*#__PURE__*/_react.default.createElement("div", {
266
+ })) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null)) : "", currentView === "video tour" ? /*#__PURE__*/_react.default.createElement(_VideoTours.VideoTours, {
267
+ videoTourUrls: videoTours
268
+ }) : "", currentView === "virtual tour" ? /*#__PURE__*/_react.default.createElement(_VirtualTour.VirtualTour, {
269
+ virtualTourUrl: virtualTour
270
+ }) : "", /*#__PURE__*/_react.default.createElement("div", {
226
271
  className: "badge--stats"
227
272
  }, /*#__PURE__*/_react.default.createElement(_muncherUi.Badge, {
228
273
  variant: "tertiary"
@@ -230,4 +275,4 @@ var GalleryHero = function GalleryHero(_ref) {
230
275
  };
231
276
 
232
277
  exports.GalleryHero = GalleryHero;
233
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["calculateTotalPages","assets","total","length","remainder","GalleryHero","videoTourCount","virtualTourCount","isAvailableNow","useState","showModal","setShowModal","assetInFocus","setAssetInFocus","assetIndex","setAssetIndex","page","setPage","totalPages","imageClickedHandler","image","findIndex","value","id","modalCloseHandler","sliceStart","sliceEnd","makePlural","photoStat","virtualTourStat","videoTourStat","slice","map","asset","assetUrlFrom","name"],"sources":["../../src/gallery/GalleryHero.tsx"],"sourcesContent":["import React, {useState} 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 {GalleryModal} from \"./GalleryModal\";\n\nconst calculateTotalPages = (assets: Asset[]) => {\n    let total = 0;\n    if (assets.length > 5) {\n        total = total + ((assets.length - 5) / 8) + 1;\n\n        const remainder = (assets.length - 5) % 8;\n        if (remainder > 0)\n            total += 1;\n\n    }\n    return total;\n}\nexport const GalleryHero: React.FC<GalleryHeroProps> = (\n    {assets, videoTourCount, virtualTourCount, isAvailableNow}) => {\n    const [showModal, setShowModal] = useState(false);\n    const [assetInFocus, setAssetInFocus] = useState<Asset>({} as Asset);\n    const [assetIndex, setAssetIndex] = useState(0);\n    const [page, setPage] = useState(0);\n    const totalPages = calculateTotalPages(assets);\n\n    const imageClickedHandler = (image: Asset) => {\n        setShowModal(true);\n        setAssetInFocus(image);\n        setAssetIndex(assets.findIndex(value => value.id === image.id));\n    };\n    const modalCloseHandler = () => {\n        setShowModal(false);\n        setAssetInFocus({} as Asset);\n    };\n\n    const sliceStart = () => {\n        return page === 0 ? 1 : (5 + (page - 1) * 8);\n    }\n\n    const sliceEnd = () => {\n        return page === 0 ? 5 : (5 + (page) * 8);\n    }\n    const makePlural = (length: number) => length > 1 ? \"s\" : \"\";\n\n    const photoStat = () => <>{assets.length} Photo{makePlural(assets.length)}</>\n\n    const virtualTourStat = () => <>\n        {virtualTourCount && virtualTourCount > 0 ? <>&nbsp;|&nbsp;{virtualTourCount} Virtual\n            Tour{makePlural(virtualTourCount)}</> : \"\"}\n    </>\n    const videoTourStat = () => <>\n        {videoTourCount && videoTourCount > 0 ? <>&nbsp;|&nbsp;{videoTourCount} Video\n            Tour{makePlural(videoTourCount)}</> : \"\"}\n    </>\n\n    return (\n        <div className=\"div-gallery\">\n            <GalleryModal assets={assets} assetInFocus={assetInFocus}\n                          setAssetInFocus={setAssetInFocus} showModal={showModal}\n                          assetIndex={assetIndex} setAssetIndex={setAssetIndex}\n                          modalCloseHandler={modalCloseHandler}/>\n            <div className=\"gallery-hero main\">\n\n                {isAvailableNow && page===0?\n                    <div className=\"badge--info\"><Badge variant=\"secondary\">Available Now</Badge></div> : <></>}\n                {assets.length > 5 ?\n                    <div className={page < 1 ? \"icon-left icon--disabled\" : \"icon-left\"}>\n                        <Icon name=\"chevron-left\" size=\"large\" weight={2}\n                              onClick={() => {\n                                  if (page > 0) {\n                                      setPage(page - 1);\n                                  }\n                              }}\n                        />\n                    </div> : <></>}\n\n                <div className=\"gallery-hero-two-columns\">\n                    {page === 0 ?\n                        <div className={assets.length < 2 ? \"gallery-hero-one\" : \"gallery-hero-column-one\"}>\n                            {\n                                assets.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                    {assets.length > 1 ?\n                        <div className={page === 0 ? \"gallery-hero-column-two\" : \"gallery-hero-column\"}>\n                            {\n                                assets.slice(sliceStart(), sliceEnd()).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                </div>\n                {assets.length > 5 ?\n                    <div className={page < totalPages - 1 ? \"icon-right\" : \"icon-right icon--disabled\"}>\n                        <Icon name=\"chevron-right\" size=\"large\" weight={2}\n                              onClick={() => {\n                                  if (page < totalPages - 1) {\n                                      setPage(page + 1);\n                                  }\n                              }}\n                        />\n                    </div> : <></>\n                }\n                <div className=\"badge--stats\"><Badge\n                    variant=\"tertiary\">{photoStat()}{virtualTourStat()}{videoTourStat()}</Badge></div>\n            </div>\n\n            <div className=\"gallery-hero mobile\">\n\n                {isAvailableNow && assetIndex === 0 ?\n                    <div className=\"badge--info\"><Badge variant=\"secondary\">Available Now</Badge></div> : <></>}\n                {assets.length > 1 ?\n                    <div className=\"icon-left\">\n                        <Icon name=\"chevron-left\" size=\"large\" weight={2}\n                              onClick={() => {\n                                  if (assetIndex < 1) {\n                                      setAssetIndex(assets.length - 1);\n                                  } else {\n                                      setAssetIndex(assetIndex - 1);\n                                  }\n                              }}\n                        />\n                    </div> : <></>}\n\n                <div className=\"gallery-hero-two-columns\">\n\n                    <div className=\"gallery-hero-column\">\n                        <img src={assetUrlFrom(assets[assetIndex].id)}\n                             alt={assets[assetIndex].name}\n                             key={assets[assetIndex].id}\n                             className=\"gallery-hero-mobile--image\"\n                             onClick={() => imageClickedHandler(assets[assetIndex])}\n                        />\n                    </div>\n                </div>\n                {assets.length > 1 ?\n                    <div className=\"icon-right\">\n                        <Icon name=\"chevron-right\" size=\"large\" weight={2}\n                              onClick={() => {\n                                  if (assetIndex > assets.length - 1) {\n                                      setAssetIndex(0);\n                                  } else {\n                                      setAssetIndex(assetIndex + 1);\n                                  }\n                              }}\n                        />\n                    </div> : <></>\n                }\n                <div className=\"badge--stats\"><Badge\n                    variant=\"tertiary\">{photoStat()}{virtualTourStat()}{videoTourStat()}</Badge></div>\n            </div>\n        </div>\n    );\n};\n\n\nexport interface GalleryHeroProps {\n    assets: Asset[];\n    virtualTourCount?: number;\n    videoTourCount?: number;\n    isAvailableNow?: boolean;\n\n}"],"mappings":";;;;;;;;;AAAA;;AACA;;AAEA;;AACA;;AACA;;;;;;;;;;;;;;;;;;AAEA,IAAMA,mBAAmB,GAAG,SAAtBA,mBAAsB,CAACC,MAAD,EAAqB;EAC7C,IAAIC,KAAK,GAAG,CAAZ;;EACA,IAAID,MAAM,CAACE,MAAP,GAAgB,CAApB,EAAuB;IACnBD,KAAK,GAAGA,KAAK,GAAI,CAACD,MAAM,CAACE,MAAP,GAAgB,CAAjB,IAAsB,CAA/B,GAAoC,CAA5C;IAEA,IAAMC,SAAS,GAAG,CAACH,MAAM,CAACE,MAAP,GAAgB,CAAjB,IAAsB,CAAxC;IACA,IAAIC,SAAS,GAAG,CAAhB,EACIF,KAAK,IAAI,CAAT;EAEP;;EACD,OAAOA,KAAP;AACH,CAXD;;AAYO,IAAMG,WAAuC,GAAG,SAA1CA,WAA0C,OACY;EAAA,IAA9DJ,MAA8D,QAA9DA,MAA8D;EAAA,IAAtDK,cAAsD,QAAtDA,cAAsD;EAAA,IAAtCC,gBAAsC,QAAtCA,gBAAsC;EAAA,IAApBC,cAAoB,QAApBA,cAAoB;;EAC/D,gBAAkC,IAAAC,eAAA,EAAS,KAAT,CAAlC;EAAA;EAAA,IAAOC,SAAP;EAAA,IAAkBC,YAAlB;;EACA,iBAAwC,IAAAF,eAAA,EAAgB,EAAhB,CAAxC;EAAA;EAAA,IAAOG,YAAP;EAAA,IAAqBC,eAArB;;EACA,iBAAoC,IAAAJ,eAAA,EAAS,CAAT,CAApC;EAAA;EAAA,IAAOK,UAAP;EAAA,IAAmBC,aAAnB;;EACA,iBAAwB,IAAAN,eAAA,EAAS,CAAT,CAAxB;EAAA;EAAA,IAAOO,IAAP;EAAA,IAAaC,OAAb;;EACA,IAAMC,UAAU,GAAGlB,mBAAmB,CAACC,MAAD,CAAtC;;EAEA,IAAMkB,mBAAmB,GAAG,SAAtBA,mBAAsB,CAACC,KAAD,EAAkB;IAC1CT,YAAY,CAAC,IAAD,CAAZ;IACAE,eAAe,CAACO,KAAD,CAAf;IACAL,aAAa,CAACd,MAAM,CAACoB,SAAP,CAAiB,UAAAC,KAAK;MAAA,OAAIA,KAAK,CAACC,EAAN,KAAaH,KAAK,CAACG,EAAvB;IAAA,CAAtB,CAAD,CAAb;EACH,CAJD;;EAKA,IAAMC,iBAAiB,GAAG,SAApBA,iBAAoB,GAAM;IAC5Bb,YAAY,CAAC,KAAD,CAAZ;IACAE,eAAe,CAAC,EAAD,CAAf;EACH,CAHD;;EAKA,IAAMY,UAAU,GAAG,SAAbA,UAAa,GAAM;IACrB,OAAOT,IAAI,KAAK,CAAT,GAAa,CAAb,GAAkB,IAAI,CAACA,IAAI,GAAG,CAAR,IAAa,CAA1C;EACH,CAFD;;EAIA,IAAMU,QAAQ,GAAG,SAAXA,QAAW,GAAM;IACnB,OAAOV,IAAI,KAAK,CAAT,GAAa,CAAb,GAAkB,IAAKA,IAAD,GAAS,CAAtC;EACH,CAFD;;EAGA,IAAMW,UAAU,GAAG,SAAbA,UAAa,CAACxB,MAAD;IAAA,OAAoBA,MAAM,GAAG,CAAT,GAAa,GAAb,GAAmB,EAAvC;EAAA,CAAnB;;EAEA,IAAMyB,SAAS,GAAG,SAAZA,SAAY;IAAA,oBAAM,4DAAG3B,MAAM,CAACE,MAAV,YAAwBwB,UAAU,CAAC1B,MAAM,CAACE,MAAR,CAAlC,CAAN;EAAA,CAAlB;;EAEA,IAAM0B,eAAe,GAAG,SAAlBA,eAAkB;IAAA,oBAAM,4DACzBtB,gBAAgB,IAAIA,gBAAgB,GAAG,CAAvC,gBAA2C,yEAAgBA,gBAAhB,mBACnCoB,UAAU,CAACpB,gBAAD,CADyB,CAA3C,GAC2C,EAFlB,CAAN;EAAA,CAAxB;;EAIA,IAAMuB,aAAa,GAAG,SAAhBA,aAAgB;IAAA,oBAAM,4DACvBxB,cAAc,IAAIA,cAAc,GAAG,CAAnC,gBAAuC,yEAAgBA,cAAhB,iBAC/BqB,UAAU,CAACrB,cAAD,CADqB,CAAvC,GACyC,EAFlB,CAAN;EAAA,CAAtB;;EAKA,oBACI;IAAK,SAAS,EAAC;EAAf,gBACI,6BAAC,0BAAD;IAAc,MAAM,EAAEL,MAAtB;IAA8B,YAAY,EAAEW,YAA5C;IACc,eAAe,EAAEC,eAD/B;IACgD,SAAS,EAAEH,SAD3D;IAEc,UAAU,EAAEI,UAF1B;IAEsC,aAAa,EAAEC,aAFrD;IAGc,iBAAiB,EAAES;EAHjC,EADJ,eAKI;IAAK,SAAS,EAAC;EAAf,GAEKhB,cAAc,IAAIQ,IAAI,KAAG,CAAzB,gBACG;IAAK,SAAS,EAAC;EAAf,gBAA6B,6BAAC,gBAAD;IAAO,OAAO,EAAC;EAAf,mBAA7B,CADH,gBACyF,2DAH9F,EAIKf,MAAM,CAACE,MAAP,GAAgB,CAAhB,gBACG;IAAK,SAAS,EAAEa,IAAI,GAAG,CAAP,GAAW,0BAAX,GAAwC;EAAxD,gBACI,6BAAC,eAAD;IAAM,IAAI,EAAC,cAAX;IAA0B,IAAI,EAAC,OAA/B;IAAuC,MAAM,EAAE,CAA/C;IACM,OAAO,EAAE,mBAAM;MACX,IAAIA,IAAI,GAAG,CAAX,EAAc;QACVC,OAAO,CAACD,IAAI,GAAG,CAAR,CAAP;MACH;IACJ;EALP,EADJ,CADH,gBASY,2DAbjB,eAeI;IAAK,SAAS,EAAC;EAAf,GACKA,IAAI,KAAK,CAAT,gBACG;IAAK,SAAS,EAAEf,MAAM,CAACE,MAAP,GAAgB,CAAhB,GAAoB,kBAApB,GAAyC;EAAzD,GAEQF,MAAM,CAAC8B,KAAP,CAAa,CAAb,EAAgB,CAAhB,EAAmBC,GAAnB,CAAuB,UAACC,KAAD;IAAA,oBACnB;MAAK,GAAG,EAAE,IAAAC,0BAAA,EAAaD,KAAK,CAACV,EAAnB,CAAV;MACK,GAAG,EAAEU,KAAK,CAACE,IADhB;MAEK,GAAG,EAAEF,KAAK,CAACV,EAFhB;MAGK,SAAS,EAAC,qBAHf;MAIK,OAAO,EAAE;QAAA,OAAMJ,mBAAmB,CAACc,KAAD,CAAzB;MAAA;IAJd,EADmB;EAAA,CAAvB,CAFR,CADH,gBAYY,2DAbjB,EAcKhC,MAAM,CAACE,MAAP,GAAgB,CAAhB,gBACG;IAAK,SAAS,EAAEa,IAAI,KAAK,CAAT,GAAa,yBAAb,GAAyC;EAAzD,GAEQf,MAAM,CAAC8B,KAAP,CAAaN,UAAU,EAAvB,EAA2BC,QAAQ,EAAnC,EAAuCM,GAAvC,CAA2C,UAACC,KAAD;IAAA,oBACvC;MAAK,GAAG,EAAE,IAAAC,0BAAA,EAAaD,KAAK,CAACV,EAAnB,CAAV;MACK,GAAG,EAAEU,KAAK,CAACE,IADhB;MAEK,GAAG,EAAEF,KAAK,CAACV,EAFhB;MAGK,SAAS,EAAC,qBAHf;MAIK,OAAO,EAAE;QAAA,OAAMJ,mBAAmB,CAACc,KAAD,CAAzB;MAAA;IAJd,EADuC;EAAA,CAA3C,CAFR,CADH,gBAYY,2DA1BjB,CAfJ,EA4CKhC,MAAM,CAACE,MAAP,GAAgB,CAAhB,gBACG;IAAK,SAAS,EAAEa,IAAI,GAAGE,UAAU,GAAG,CAApB,GAAwB,YAAxB,GAAuC;EAAvD,gBACI,6BAAC,eAAD;IAAM,IAAI,EAAC,eAAX;IAA2B,IAAI,EAAC,OAAhC;IAAwC,MAAM,EAAE,CAAhD;IACM,OAAO,EAAE,mBAAM;MACX,IAAIF,IAAI,GAAGE,UAAU,GAAG,CAAxB,EAA2B;QACvBD,OAAO,CAACD,IAAI,GAAG,CAAR,CAAP;MACH;IACJ;EALP,EADJ,CADH,gBASY,2DArDjB,eAuDI;IAAK,SAAS,EAAC;EAAf,gBAA8B,6BAAC,gBAAD;IAC1B,OAAO,EAAC;EADkB,GACNY,SAAS,EADH,EACOC,eAAe,EADtB,EAC0BC,aAAa,EADvC,CAA9B,CAvDJ,CALJ,eAgEI;IAAK,SAAS,EAAC;EAAf,GAEKtB,cAAc,IAAIM,UAAU,KAAK,CAAjC,gBACG;IAAK,SAAS,EAAC;EAAf,gBAA6B,6BAAC,gBAAD;IAAO,OAAO,EAAC;EAAf,mBAA7B,CADH,gBACyF,2DAH9F,EAIKb,MAAM,CAACE,MAAP,GAAgB,CAAhB,gBACG;IAAK,SAAS,EAAC;EAAf,gBACI,6BAAC,eAAD;IAAM,IAAI,EAAC,cAAX;IAA0B,IAAI,EAAC,OAA/B;IAAuC,MAAM,EAAE,CAA/C;IACM,OAAO,EAAE,mBAAM;MACX,IAAIW,UAAU,GAAG,CAAjB,EAAoB;QAChBC,aAAa,CAACd,MAAM,CAACE,MAAP,GAAgB,CAAjB,CAAb;MACH,CAFD,MAEO;QACHY,aAAa,CAACD,UAAU,GAAG,CAAd,CAAb;MACH;IACJ;EAPP,EADJ,CADH,gBAWY,2DAfjB,eAiBI;IAAK,SAAS,EAAC;EAAf,gBAEI;IAAK,SAAS,EAAC;EAAf,gBACI;IAAK,GAAG,EAAE,IAAAoB,0BAAA,EAAajC,MAAM,CAACa,UAAD,CAAN,CAAmBS,EAAhC,CAAV;IACK,GAAG,EAAEtB,MAAM,CAACa,UAAD,CAAN,CAAmBqB,IAD7B;IAEK,GAAG,EAAElC,MAAM,CAACa,UAAD,CAAN,CAAmBS,EAF7B;IAGK,SAAS,EAAC,4BAHf;IAIK,OAAO,EAAE;MAAA,OAAMJ,mBAAmB,CAAClB,MAAM,CAACa,UAAD,CAAP,CAAzB;IAAA;EAJd,EADJ,CAFJ,CAjBJ,EA4BKb,MAAM,CAACE,MAAP,GAAgB,CAAhB,gBACG;IAAK,SAAS,EAAC;EAAf,gBACI,6BAAC,eAAD;IAAM,IAAI,EAAC,eAAX;IAA2B,IAAI,EAAC,OAAhC;IAAwC,MAAM,EAAE,CAAhD;IACM,OAAO,EAAE,mBAAM;MACX,IAAIW,UAAU,GAAGb,MAAM,CAACE,MAAP,GAAgB,CAAjC,EAAoC;QAChCY,aAAa,CAAC,CAAD,CAAb;MACH,CAFD,MAEO;QACHA,aAAa,CAACD,UAAU,GAAG,CAAd,CAAb;MACH;IACJ;EAPP,EADJ,CADH,gBAWY,2DAvCjB,eAyCI;IAAK,SAAS,EAAC;EAAf,gBAA8B,6BAAC,gBAAD;IAC1B,OAAO,EAAC;EADkB,GACNc,SAAS,EADH,EACOC,eAAe,EADtB,EAC0BC,aAAa,EADvC,CAA9B,CAzCJ,CAhEJ,CADJ;AA+GH,CArJM"}
278
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["calculateTotalPages","assets","total","length","remainder","GalleryHero","videoTours","virtualTour","isAvailableNow","useState","showModal","setShowModal","assetInFocus","setAssetInFocus","assetIndex","setAssetIndex","page","setPage","totalPages","currentView","setCurrentView","imageClickedHandler","image","findIndex","value","id","modalCloseHandler","sliceStart","sliceEnd","makePlural","photoStat","virtualTourStat","videoTourStat","slice","map","asset","assetUrlFrom","name"],"sources":["../../src/gallery/GalleryHero.tsx"],"sourcesContent":["import React, {useState} from \"react\";\nimport './assets/GalleryHero.scss';\nimport {Asset} from \"../asset/data/Asset\";\nimport {assetUrlFrom} from \"../asset/service/AssetService\";\nimport {Badge, Button, Icon} from \"@contentmunch/muncher-ui\";\nimport {GalleryModal} from \"./GalleryModal\";\nimport {VirtualTour} from \"./VirtualTour\";\nimport {VideoTours} from \"./VideoTours\";\n\nconst calculateTotalPages = (assets: Asset[]) => {\n    let total = 0;\n    if (assets.length > 5) {\n        total = total + ((assets.length - 5) / 8) + 1;\n\n        const remainder = (assets.length - 5) % 8;\n        if (remainder > 0)\n            total += 1;\n\n    }\n    return total;\n}\nexport const GalleryHero: React.FC<GalleryHeroProps> = (\n    {assets, videoTours, virtualTour, isAvailableNow}) => {\n    const [showModal, setShowModal] = useState(false);\n    const [assetInFocus, setAssetInFocus] = useState<Asset>({} as Asset);\n    const [assetIndex, setAssetIndex] = useState(0);\n    const [page, setPage] = useState(0);\n    const totalPages = calculateTotalPages(assets);\n    const [currentView, setCurrentView] = useState<\"photo\" | \"virtual tour\" | \"video tour\">(\"photo\");\n    const imageClickedHandler = (image: Asset) => {\n        setShowModal(true);\n        setAssetInFocus(image);\n        setAssetIndex(assets.findIndex(value => value.id === image.id));\n    };\n    const modalCloseHandler = () => {\n        setShowModal(false);\n        setAssetInFocus({} as Asset);\n    };\n\n    const sliceStart = () => {\n        return page === 0 ? 1 : (5 + (page - 1) * 8);\n    }\n\n    const sliceEnd = () => {\n        return page === 0 ? 5 : (5 + (page) * 8);\n    }\n    const makePlural = (length: number) => length > 1 ? \"s\" : \"\";\n\n    const photoStat = () =>\n        <Button size=\"small\" variant=\"transparent\"\n                onClick={() => {\n                    setCurrentView(\"photo\");\n                }}><span className={currentView === \"photo\" ? \"selected\" : \"\"}>\n            {assets.length} Photo{makePlural(assets.length)}</span>\n        </Button>\n\n    const virtualTourStat = () => <>\n        {virtualTour ?\n            <Button size=\"small\" variant=\"transparent\"\n                    onClick={() => {\n                        setCurrentView(\"virtual tour\");\n                    }}>\n                &nbsp;|&nbsp;<span\n                className={currentView === \"virtual tour\" ? \"selected\" : \"\"}>1 Virtual Tour</span></Button> : \"\"}\n    </>\n    const videoTourStat = () => <>\n        {videoTours.length > 0 ?\n            <Button size=\"small\" variant=\"transparent\"\n                    onClick={() => {\n                        setCurrentView(\"video tour\");\n                    }}>\n                &nbsp;|&nbsp;<span className={currentView === \"video tour\" ? \"selected\" : \"\"}>{videoTours.length} Video Tour{makePlural(videoTours.length)}</span></Button> : \"\"}\n    </>\n\n    return (\n        <div className=\"div-gallery\">\n            <GalleryModal assets={assets} assetInFocus={assetInFocus}\n                          setAssetInFocus={setAssetInFocus} showModal={showModal}\n                          assetIndex={assetIndex} setAssetIndex={setAssetIndex}\n                          modalCloseHandler={modalCloseHandler}/>\n            <div className=\"gallery-hero main\">\n\n                {currentView === \"photo\" ?\n                    <div className=\"photo-view\">\n                        {isAvailableNow && page === 0 ?\n                            <div className=\"badge--info\"><Badge variant=\"secondary\">Available Now</Badge></div> : <></>}\n                        {assets.length > 5 ?\n                            <div className={page < 1 ? \"icon-left icon--disabled\" : \"icon-left\"}>\n                                <Icon name=\"chevron-left\" size=\"large\" weight={2}\n                                      onClick={() => {\n                                          if (page > 0) {\n                                              setPage(page - 1);\n                                          }\n                                      }}\n                                />\n                            </div> : <></>}\n\n                        <div className=\"gallery-hero-two-columns\">\n                            {page === 0 ?\n                                <div className={assets.length < 2 ? \"gallery-hero-one\" : \"gallery-hero-column-one\"}>\n                                    {\n                                        assets.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                            {assets.length > 1 ?\n                                <div className={page === 0 ? \"gallery-hero-column-two\" : \"gallery-hero-column\"}>\n                                    {\n                                        assets.slice(sliceStart(), sliceEnd()).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                        </div>\n                        {assets.length > 5 ?\n                            <div className={page < totalPages - 1 ? \"icon-right\" : \"icon-right icon--disabled\"}>\n                                <Icon name=\"chevron-right\" size=\"large\" weight={2}\n                                      onClick={() => {\n                                          if (page < totalPages - 1) {\n                                              setPage(page + 1);\n                                          }\n                                      }}\n                                />\n                            </div> : <></>\n                        }\n                    </div> : \"\"\n                }\n                {currentView === \"video tour\" ? <VideoTours videoTourUrls={videoTours}/> : \"\"}\n                {currentView === \"virtual tour\" ? <VirtualTour virtualTourUrl={virtualTour}/> : \"\"}\n\n                <div className=\"badge--stats\">\n                    <Badge variant=\"tertiary\">\n                        {photoStat()}{virtualTourStat()}{videoTourStat()}\n                    </Badge>\n                </div>\n            </div>\n\n            <div className=\"gallery-hero mobile\">\n                {currentView === \"photo\" ?\n                    <div className=\"photo-view\">\n                        {isAvailableNow && assetIndex === 0 ?\n                            <div className=\"badge--info\"><Badge variant=\"secondary\">Available Now</Badge></div> : <></>}\n                        {assets.length > 1 ?\n                            <div className=\"icon-left\">\n                                <Icon name=\"chevron-left\" size=\"large\" weight={2}\n                                      onClick={() => {\n                                          if (assetIndex < 1) {\n                                              setAssetIndex(assets.length - 1);\n                                          } else {\n                                              setAssetIndex(assetIndex - 1);\n                                          }\n                                      }}\n                                />\n                            </div> : <></>}\n\n                        <div className=\"gallery-hero-two-columns\">\n\n                            <div className=\"gallery-hero-column\">\n                                <img src={assetUrlFrom(assets[assetIndex].id)}\n                                     alt={assets[assetIndex].name}\n                                     key={assets[assetIndex].id}\n                                     className=\"gallery-hero-mobile--image\"\n                                     onClick={() => imageClickedHandler(assets[assetIndex])}\n                                />\n                            </div>\n                        </div>\n                        {assets.length > 1 ?\n                            <div className=\"icon-right\">\n                                <Icon name=\"chevron-right\" size=\"large\" weight={2}\n                                      onClick={() => {\n                                          if (assetIndex > assets.length - 1) {\n                                              setAssetIndex(0);\n                                          } else {\n                                              setAssetIndex(assetIndex + 1);\n                                          }\n                                      }}\n                                />\n                            </div> : <></>\n                        }\n                    </div> : \"\"\n                }\n                {currentView === \"video tour\" ? <VideoTours videoTourUrls={videoTours}/> : \"\"}\n                {currentView === \"virtual tour\" ? <VirtualTour virtualTourUrl={virtualTour}/> : \"\"}\n\n                <div className=\"badge--stats\"><Badge\n                    variant=\"tertiary\">{photoStat()}{virtualTourStat()}{videoTourStat()}</Badge></div>\n            </div>\n        </div>\n    );\n};\n\n\nexport interface GalleryHeroProps {\n    assets: Asset[];\n    virtualTour?: string;\n    videoTours: string[];\n    isAvailableNow?: boolean;\n\n}"],"mappings":"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"}
@@ -78,24 +78,24 @@ var GalleryModal = function GalleryModal(_ref) {
78
78
  }, /*#__PURE__*/_react.default.createElement(_muncherUi.Icon, {
79
79
  name: "close",
80
80
  size: "large"
81
- })), /*#__PURE__*/_react.default.createElement("div", {
81
+ })), assets.length > 1 ? /*#__PURE__*/_react.default.createElement("div", {
82
82
  className: "left",
83
83
  onClick: leftClickHandler
84
84
  }, /*#__PURE__*/_react.default.createElement(_muncherUi.Icon, {
85
85
  name: "arrow-left",
86
86
  size: "large"
87
- })), sliderImageLoaded ? "" : /*#__PURE__*/_react.default.createElement(_muncherUi.Spinner, null), showModal ? /*#__PURE__*/_react.default.createElement("img", {
87
+ })) : "", sliderImageLoaded ? "" : /*#__PURE__*/_react.default.createElement(_muncherUi.Spinner, null), showModal ? /*#__PURE__*/_react.default.createElement("img", {
88
88
  src: (0, _AssetService.assetUrlFrom)(assetInFocus.id),
89
89
  alt: assetInFocus.name,
90
90
  onLoad: imageLoaded
91
- }) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null), /*#__PURE__*/_react.default.createElement("div", {
91
+ }) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null), assets.length > 1 ? /*#__PURE__*/_react.default.createElement("div", {
92
92
  className: "right",
93
93
  onClick: rightClickHandler
94
94
  }, /*#__PURE__*/_react.default.createElement(_muncherUi.Icon, {
95
95
  name: "arrow-right",
96
96
  size: "large"
97
- })))));
97
+ })) : "")));
98
98
  };
99
99
 
100
100
  exports.GalleryModal = GalleryModal;
101
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJHYWxsZXJ5TW9kYWwiLCJhc3NldHMiLCJhc3NldEluZGV4Iiwic2V0QXNzZXRJbmRleCIsImFzc2V0SW5Gb2N1cyIsInNldEFzc2V0SW5Gb2N1cyIsInNob3dNb2RhbCIsIm1vZGFsQ2xvc2VIYW5kbGVyIiwidXNlU3RhdGUiLCJzbGlkZXJJbWFnZUxvYWRlZCIsInNldFNsaWRlckltYWdlTG9hZGVkIiwicmlnaHRDbGlja0hhbmRsZXIiLCJjdXJyZW50SW5kZXgiLCJsZW5ndGgiLCJsZWZ0Q2xpY2tIYW5kbGVyIiwiaW1hZ2VMb2FkZWQiLCJhc3NldFVybEZyb20iLCJpZCIsIm5hbWUiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvZ2FsbGVyeS9HYWxsZXJ5TW9kYWwudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCwge3VzZVN0YXRlfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCB7SWNvbiwgTW9kYWwsIFNwaW5uZXJ9IGZyb20gXCJAY29udGVudG11bmNoL211bmNoZXItdWlcIjtcbmltcG9ydCB7YXNzZXRVcmxGcm9tfSBmcm9tIFwiLi4vYXNzZXQvc2VydmljZS9Bc3NldFNlcnZpY2VcIjtcbmltcG9ydCB7QXNzZXR9IGZyb20gXCIuLi9hc3NldC9kYXRhL0Fzc2V0XCI7XG5pbXBvcnQgXCIuL2Fzc2V0cy9HYWxsZXJ5TW9kYWwuc2Nzc1wiO1xuXG5leHBvcnQgY29uc3QgR2FsbGVyeU1vZGFsOiBSZWFjdC5GQzxHYWxsZXJ5TW9kYWxQcm9wcz4gPSAoXG4gICAge2Fzc2V0cywgYXNzZXRJbmRleCwgc2V0QXNzZXRJbmRleCwgYXNzZXRJbkZvY3VzLCBzZXRBc3NldEluRm9jdXMsIHNob3dNb2RhbCwgbW9kYWxDbG9zZUhhbmRsZXJ9KSA9PiB7XG5cblxuICAgIGNvbnN0IFtzbGlkZXJJbWFnZUxvYWRlZCwgc2V0U2xpZGVySW1hZ2VMb2FkZWRdID0gdXNlU3RhdGUoZmFsc2UpO1xuXG4gICAgY29uc3QgcmlnaHRDbGlja0hhbmRsZXIgPSAoKSA9PiB7XG4gICAgICAgIHNldFNsaWRlckltYWdlTG9hZGVkKGZhbHNlKTtcbiAgICAgICAgbGV0IGN1cnJlbnRJbmRleCA9IGFzc2V0SW5kZXggKyAxO1xuICAgICAgICBjdXJyZW50SW5kZXggPSBjdXJyZW50SW5kZXggPj0gYXNzZXRzLmxlbmd0aCA/IDAgOiBjdXJyZW50SW5kZXg7XG4gICAgICAgIHNldEFzc2V0SW5kZXgoY3VycmVudEluZGV4KTtcbiAgICAgICAgc2V0QXNzZXRJbkZvY3VzKGFzc2V0c1tjdXJyZW50SW5kZXhdKTtcbiAgICB9O1xuICAgIGNvbnN0IGxlZnRDbGlja0hhbmRsZXIgPSAoKSA9PiB7XG4gICAgICAgIHNldFNsaWRlckltYWdlTG9hZGVkKGZhbHNlKTtcbiAgICAgICAgbGV0IGN1cnJlbnRJbmRleCA9IGFzc2V0SW5kZXggLSAxO1xuICAgICAgICBjdXJyZW50SW5kZXggPSBjdXJyZW50SW5kZXggPCAwID8gYXNzZXRzLmxlbmd0aCAtIDEgOiBjdXJyZW50SW5kZXg7XG4gICAgICAgIHNldEFzc2V0SW5kZXgoY3VycmVudEluZGV4KTtcbiAgICAgICAgc2V0QXNzZXRJbkZvY3VzKGFzc2V0c1tjdXJyZW50SW5kZXhdKTtcbiAgICB9O1xuXG5cbiAgICBjb25zdCBpbWFnZUxvYWRlZCA9ICgpID0+IHtcbiAgICAgICAgc2V0U2xpZGVySW1hZ2VMb2FkZWQodHJ1ZSk7XG4gICAgfTtcbiAgICByZXR1cm4gKFxuICAgICAgICA8ZGl2IGNsYXNzTmFtZT1cImdhbGxlcnktbW9kYWxcIj5cbiAgICAgICAgICAgIDxNb2RhbCBzaG93PXtzaG93TW9kYWx9IHNldFNob3c9e21vZGFsQ2xvc2VIYW5kbGVyfT5cbiAgICAgICAgICAgICAgICA8ZGl2IGNsYXNzTmFtZT1cImltYWdlLXNsaWRlclwiPlxuICAgICAgICAgICAgICAgICAgICA8ZGl2IGNsYXNzTmFtZT1cImNsb3NlXCIgb25DbGljaz17bW9kYWxDbG9zZUhhbmRsZXJ9PlxuICAgICAgICAgICAgICAgICAgICAgICAgPEljb24gbmFtZT1cImNsb3NlXCIgc2l6ZT1cImxhcmdlXCIvPlxuICAgICAgICAgICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgICAgICAgICAgPGRpdiBjbGFzc05hbWU9XCJsZWZ0XCIgb25DbGljaz17bGVmdENsaWNrSGFuZGxlcn0+XG4gICAgICAgICAgICAgICAgICAgICAgICA8SWNvbiBuYW1lPVwiYXJyb3ctbGVmdFwiIHNpemU9XCJsYXJnZVwiLz5cbiAgICAgICAgICAgICAgICAgICAgPC9kaXY+XG5cbiAgICAgICAgICAgICAgICAgICAge1xuICAgICAgICAgICAgICAgICAgICAgICAgc2xpZGVySW1hZ2VMb2FkZWQgPyBcIlwiIDogPFNwaW5uZXIvPlxuICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgIHtzaG93TW9kYWwgP1xuICAgICAgICAgICAgICAgICAgICAgICAgPGltZyBzcmM9e2Fzc2V0VXJsRnJvbShhc3NldEluRm9jdXMuaWQpfSBhbHQ9e2Fzc2V0SW5Gb2N1cy5uYW1lfSBvbkxvYWQ9e2ltYWdlTG9hZGVkfS8+IDogPD48Lz59XG4gICAgICAgICAgICAgICAgICAgIDxkaXYgY2xhc3NOYW1lPVwicmlnaHRcIiBvbkNsaWNrPXtyaWdodENsaWNrSGFuZGxlcn0+XG4gICAgICAgICAgICAgICAgICAgICAgICA8SWNvbiBuYW1lPVwiYXJyb3ctcmlnaHRcIiBzaXplPVwibGFyZ2VcIi8+XG4gICAgICAgICAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgPC9Nb2RhbD5cbiAgICAgICAgPC9kaXY+XG4gICAgKTtcbn07XG5cbmV4cG9ydCBpbnRlcmZhY2UgR2FsbGVyeU1vZGFsUHJvcHMge1xuICAgIGFzc2V0czogQXNzZXRbXTtcbiAgICBhc3NldEluRm9jdXM6IEFzc2V0O1xuICAgIGFzc2V0SW5kZXg6IG51bWJlcjtcbiAgICBzZXRBc3NldEluZGV4OiAoaW5kZXg6IG51bWJlcikgPT4gdm9pZDtcbiAgICBzZXRBc3NldEluRm9jdXM6IChhc3NldDogQXNzZXQpID0+IHZvaWQ7XG4gICAgc2hvd01vZGFsOiBib29sZWFuO1xuICAgIG1vZGFsQ2xvc2VIYW5kbGVyOiAoKSA9PiB2b2lkO1xufSJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7O0FBQUE7O0FBQ0E7O0FBQ0E7O0FBRUE7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUVPLElBQU1BLFlBQXlDLEdBQUcsU0FBNUNBLFlBQTRDLE9BQ2dEO0VBQUEsSUFBcEdDLE1BQW9HLFFBQXBHQSxNQUFvRztFQUFBLElBQTVGQyxVQUE0RixRQUE1RkEsVUFBNEY7RUFBQSxJQUFoRkMsYUFBZ0YsUUFBaEZBLGFBQWdGO0VBQUEsSUFBakVDLFlBQWlFLFFBQWpFQSxZQUFpRTtFQUFBLElBQW5EQyxlQUFtRCxRQUFuREEsZUFBbUQ7RUFBQSxJQUFsQ0MsU0FBa0MsUUFBbENBLFNBQWtDO0VBQUEsSUFBdkJDLGlCQUF1QixRQUF2QkEsaUJBQXVCOztFQUdyRyxnQkFBa0QsSUFBQUMsZUFBQSxFQUFTLEtBQVQsQ0FBbEQ7RUFBQTtFQUFBLElBQU9DLGlCQUFQO0VBQUEsSUFBMEJDLG9CQUExQjs7RUFFQSxJQUFNQyxpQkFBaUIsR0FBRyxTQUFwQkEsaUJBQW9CLEdBQU07SUFDNUJELG9CQUFvQixDQUFDLEtBQUQsQ0FBcEI7SUFDQSxJQUFJRSxZQUFZLEdBQUdWLFVBQVUsR0FBRyxDQUFoQztJQUNBVSxZQUFZLEdBQUdBLFlBQVksSUFBSVgsTUFBTSxDQUFDWSxNQUF2QixHQUFnQyxDQUFoQyxHQUFvQ0QsWUFBbkQ7SUFDQVQsYUFBYSxDQUFDUyxZQUFELENBQWI7SUFDQVAsZUFBZSxDQUFDSixNQUFNLENBQUNXLFlBQUQsQ0FBUCxDQUFmO0VBQ0gsQ0FORDs7RUFPQSxJQUFNRSxnQkFBZ0IsR0FBRyxTQUFuQkEsZ0JBQW1CLEdBQU07SUFDM0JKLG9CQUFvQixDQUFDLEtBQUQsQ0FBcEI7SUFDQSxJQUFJRSxZQUFZLEdBQUdWLFVBQVUsR0FBRyxDQUFoQztJQUNBVSxZQUFZLEdBQUdBLFlBQVksR0FBRyxDQUFmLEdBQW1CWCxNQUFNLENBQUNZLE1BQVAsR0FBZ0IsQ0FBbkMsR0FBdUNELFlBQXREO0lBQ0FULGFBQWEsQ0FBQ1MsWUFBRCxDQUFiO0lBQ0FQLGVBQWUsQ0FBQ0osTUFBTSxDQUFDVyxZQUFELENBQVAsQ0FBZjtFQUNILENBTkQ7O0VBU0EsSUFBTUcsV0FBVyxHQUFHLFNBQWRBLFdBQWMsR0FBTTtJQUN0Qkwsb0JBQW9CLENBQUMsSUFBRCxDQUFwQjtFQUNILENBRkQ7O0VBR0Esb0JBQ0k7SUFBSyxTQUFTLEVBQUM7RUFBZixnQkFDSSw2QkFBQyxnQkFBRDtJQUFPLElBQUksRUFBRUosU0FBYjtJQUF3QixPQUFPLEVBQUVDO0VBQWpDLGdCQUNJO0lBQUssU0FBUyxFQUFDO0VBQWYsZ0JBQ0k7SUFBSyxTQUFTLEVBQUMsT0FBZjtJQUF1QixPQUFPLEVBQUVBO0VBQWhDLGdCQUNJLDZCQUFDLGVBQUQ7SUFBTSxJQUFJLEVBQUMsT0FBWDtJQUFtQixJQUFJLEVBQUM7RUFBeEIsRUFESixDQURKLGVBSUk7SUFBSyxTQUFTLEVBQUMsTUFBZjtJQUFzQixPQUFPLEVBQUVPO0VBQS9CLGdCQUNJLDZCQUFDLGVBQUQ7SUFBTSxJQUFJLEVBQUMsWUFBWDtJQUF3QixJQUFJLEVBQUM7RUFBN0IsRUFESixDQUpKLEVBU1FMLGlCQUFpQixHQUFHLEVBQUgsZ0JBQVEsNkJBQUMsa0JBQUQsT0FUakMsRUFXS0gsU0FBUyxnQkFDTjtJQUFLLEdBQUcsRUFBRSxJQUFBVSwwQkFBQSxFQUFhWixZQUFZLENBQUNhLEVBQTFCLENBQVY7SUFBeUMsR0FBRyxFQUFFYixZQUFZLENBQUNjLElBQTNEO0lBQWlFLE1BQU0sRUFBRUg7RUFBekUsRUFETSxnQkFDb0YsMkRBWmxHLGVBYUk7SUFBSyxTQUFTLEVBQUMsT0FBZjtJQUF1QixPQUFPLEVBQUVKO0VBQWhDLGdCQUNJLDZCQUFDLGVBQUQ7SUFBTSxJQUFJLEVBQUMsYUFBWDtJQUF5QixJQUFJLEVBQUM7RUFBOUIsRUFESixDQWJKLENBREosQ0FESixDQURKO0FBdUJILENBaERNIn0=
101
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJHYWxsZXJ5TW9kYWwiLCJhc3NldHMiLCJhc3NldEluZGV4Iiwic2V0QXNzZXRJbmRleCIsImFzc2V0SW5Gb2N1cyIsInNldEFzc2V0SW5Gb2N1cyIsInNob3dNb2RhbCIsIm1vZGFsQ2xvc2VIYW5kbGVyIiwidXNlU3RhdGUiLCJzbGlkZXJJbWFnZUxvYWRlZCIsInNldFNsaWRlckltYWdlTG9hZGVkIiwicmlnaHRDbGlja0hhbmRsZXIiLCJjdXJyZW50SW5kZXgiLCJsZW5ndGgiLCJsZWZ0Q2xpY2tIYW5kbGVyIiwiaW1hZ2VMb2FkZWQiLCJhc3NldFVybEZyb20iLCJpZCIsIm5hbWUiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvZ2FsbGVyeS9HYWxsZXJ5TW9kYWwudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCwge3VzZVN0YXRlfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCB7SWNvbiwgTW9kYWwsIFNwaW5uZXJ9IGZyb20gXCJAY29udGVudG11bmNoL211bmNoZXItdWlcIjtcbmltcG9ydCB7YXNzZXRVcmxGcm9tfSBmcm9tIFwiLi4vYXNzZXQvc2VydmljZS9Bc3NldFNlcnZpY2VcIjtcbmltcG9ydCB7QXNzZXR9IGZyb20gXCIuLi9hc3NldC9kYXRhL0Fzc2V0XCI7XG5pbXBvcnQgXCIuL2Fzc2V0cy9HYWxsZXJ5TW9kYWwuc2Nzc1wiO1xuXG5leHBvcnQgY29uc3QgR2FsbGVyeU1vZGFsOiBSZWFjdC5GQzxHYWxsZXJ5TW9kYWxQcm9wcz4gPSAoXG4gICAge2Fzc2V0cywgYXNzZXRJbmRleCwgc2V0QXNzZXRJbmRleCwgYXNzZXRJbkZvY3VzLCBzZXRBc3NldEluRm9jdXMsIHNob3dNb2RhbCwgbW9kYWxDbG9zZUhhbmRsZXJ9KSA9PiB7XG5cblxuICAgIGNvbnN0IFtzbGlkZXJJbWFnZUxvYWRlZCwgc2V0U2xpZGVySW1hZ2VMb2FkZWRdID0gdXNlU3RhdGUoZmFsc2UpO1xuXG4gICAgY29uc3QgcmlnaHRDbGlja0hhbmRsZXIgPSAoKSA9PiB7XG4gICAgICAgIHNldFNsaWRlckltYWdlTG9hZGVkKGZhbHNlKTtcbiAgICAgICAgbGV0IGN1cnJlbnRJbmRleCA9IGFzc2V0SW5kZXggKyAxO1xuICAgICAgICBjdXJyZW50SW5kZXggPSBjdXJyZW50SW5kZXggPj0gYXNzZXRzLmxlbmd0aCA/IDAgOiBjdXJyZW50SW5kZXg7XG4gICAgICAgIHNldEFzc2V0SW5kZXgoY3VycmVudEluZGV4KTtcbiAgICAgICAgc2V0QXNzZXRJbkZvY3VzKGFzc2V0c1tjdXJyZW50SW5kZXhdKTtcbiAgICB9O1xuICAgIGNvbnN0IGxlZnRDbGlja0hhbmRsZXIgPSAoKSA9PiB7XG4gICAgICAgIHNldFNsaWRlckltYWdlTG9hZGVkKGZhbHNlKTtcbiAgICAgICAgbGV0IGN1cnJlbnRJbmRleCA9IGFzc2V0SW5kZXggLSAxO1xuICAgICAgICBjdXJyZW50SW5kZXggPSBjdXJyZW50SW5kZXggPCAwID8gYXNzZXRzLmxlbmd0aCAtIDEgOiBjdXJyZW50SW5kZXg7XG4gICAgICAgIHNldEFzc2V0SW5kZXgoY3VycmVudEluZGV4KTtcbiAgICAgICAgc2V0QXNzZXRJbkZvY3VzKGFzc2V0c1tjdXJyZW50SW5kZXhdKTtcbiAgICB9O1xuXG5cbiAgICBjb25zdCBpbWFnZUxvYWRlZCA9ICgpID0+IHtcbiAgICAgICAgc2V0U2xpZGVySW1hZ2VMb2FkZWQodHJ1ZSk7XG4gICAgfTtcbiAgICByZXR1cm4gKFxuICAgICAgICA8ZGl2IGNsYXNzTmFtZT1cImdhbGxlcnktbW9kYWxcIj5cbiAgICAgICAgICAgIDxNb2RhbCBzaG93PXtzaG93TW9kYWx9IHNldFNob3c9e21vZGFsQ2xvc2VIYW5kbGVyfT5cbiAgICAgICAgICAgICAgICA8ZGl2IGNsYXNzTmFtZT1cImltYWdlLXNsaWRlclwiPlxuICAgICAgICAgICAgICAgICAgICA8ZGl2IGNsYXNzTmFtZT1cImNsb3NlXCIgb25DbGljaz17bW9kYWxDbG9zZUhhbmRsZXJ9PlxuICAgICAgICAgICAgICAgICAgICAgICAgPEljb24gbmFtZT1cImNsb3NlXCIgc2l6ZT1cImxhcmdlXCIvPlxuICAgICAgICAgICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgICAgICAgICAge2Fzc2V0cy5sZW5ndGggPiAxID9cbiAgICAgICAgICAgICAgICAgICAgICAgIDxkaXYgY2xhc3NOYW1lPVwibGVmdFwiIG9uQ2xpY2s9e2xlZnRDbGlja0hhbmRsZXJ9PlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIDxJY29uIG5hbWU9XCJhcnJvdy1sZWZ0XCIgc2l6ZT1cImxhcmdlXCIvPlxuICAgICAgICAgICAgICAgICAgICAgICAgPC9kaXY+IDogXCJcIn1cblxuICAgICAgICAgICAgICAgICAgICB7XG4gICAgICAgICAgICAgICAgICAgICAgICBzbGlkZXJJbWFnZUxvYWRlZCA/IFwiXCIgOiA8U3Bpbm5lci8+XG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAge3Nob3dNb2RhbCA/XG4gICAgICAgICAgICAgICAgICAgICAgICA8aW1nIHNyYz17YXNzZXRVcmxGcm9tKGFzc2V0SW5Gb2N1cy5pZCl9IGFsdD17YXNzZXRJbkZvY3VzLm5hbWV9IG9uTG9hZD17aW1hZ2VMb2FkZWR9Lz4gOiA8PjwvPn1cblxuICAgICAgICAgICAgICAgICAgICB7YXNzZXRzLmxlbmd0aCA+IDEgP1xuICAgICAgICAgICAgICAgICAgICAgICAgPGRpdiBjbGFzc05hbWU9XCJyaWdodFwiIG9uQ2xpY2s9e3JpZ2h0Q2xpY2tIYW5kbGVyfT5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICA8SWNvbiBuYW1lPVwiYXJyb3ctcmlnaHRcIiBzaXplPVwibGFyZ2VcIi8+XG4gICAgICAgICAgICAgICAgICAgICAgICA8L2Rpdj4gOiBcIlwifVxuICAgICAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgPC9Nb2RhbD5cbiAgICAgICAgPC9kaXY+XG4gICAgKTtcbn07XG5cbmV4cG9ydCBpbnRlcmZhY2UgR2FsbGVyeU1vZGFsUHJvcHMge1xuICAgIGFzc2V0czogQXNzZXRbXTtcbiAgICBhc3NldEluRm9jdXM6IEFzc2V0O1xuICAgIGFzc2V0SW5kZXg6IG51bWJlcjtcbiAgICBzZXRBc3NldEluZGV4OiAoaW5kZXg6IG51bWJlcikgPT4gdm9pZDtcbiAgICBzZXRBc3NldEluRm9jdXM6IChhc3NldDogQXNzZXQpID0+IHZvaWQ7XG4gICAgc2hvd01vZGFsOiBib29sZWFuO1xuICAgIG1vZGFsQ2xvc2VIYW5kbGVyOiAoKSA9PiB2b2lkO1xufSJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7O0FBQUE7O0FBQ0E7O0FBQ0E7O0FBRUE7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUVPLElBQU1BLFlBQXlDLEdBQUcsU0FBNUNBLFlBQTRDLE9BQ2dEO0VBQUEsSUFBcEdDLE1BQW9HLFFBQXBHQSxNQUFvRztFQUFBLElBQTVGQyxVQUE0RixRQUE1RkEsVUFBNEY7RUFBQSxJQUFoRkMsYUFBZ0YsUUFBaEZBLGFBQWdGO0VBQUEsSUFBakVDLFlBQWlFLFFBQWpFQSxZQUFpRTtFQUFBLElBQW5EQyxlQUFtRCxRQUFuREEsZUFBbUQ7RUFBQSxJQUFsQ0MsU0FBa0MsUUFBbENBLFNBQWtDO0VBQUEsSUFBdkJDLGlCQUF1QixRQUF2QkEsaUJBQXVCOztFQUdyRyxnQkFBa0QsSUFBQUMsZUFBQSxFQUFTLEtBQVQsQ0FBbEQ7RUFBQTtFQUFBLElBQU9DLGlCQUFQO0VBQUEsSUFBMEJDLG9CQUExQjs7RUFFQSxJQUFNQyxpQkFBaUIsR0FBRyxTQUFwQkEsaUJBQW9CLEdBQU07SUFDNUJELG9CQUFvQixDQUFDLEtBQUQsQ0FBcEI7SUFDQSxJQUFJRSxZQUFZLEdBQUdWLFVBQVUsR0FBRyxDQUFoQztJQUNBVSxZQUFZLEdBQUdBLFlBQVksSUFBSVgsTUFBTSxDQUFDWSxNQUF2QixHQUFnQyxDQUFoQyxHQUFvQ0QsWUFBbkQ7SUFDQVQsYUFBYSxDQUFDUyxZQUFELENBQWI7SUFDQVAsZUFBZSxDQUFDSixNQUFNLENBQUNXLFlBQUQsQ0FBUCxDQUFmO0VBQ0gsQ0FORDs7RUFPQSxJQUFNRSxnQkFBZ0IsR0FBRyxTQUFuQkEsZ0JBQW1CLEdBQU07SUFDM0JKLG9CQUFvQixDQUFDLEtBQUQsQ0FBcEI7SUFDQSxJQUFJRSxZQUFZLEdBQUdWLFVBQVUsR0FBRyxDQUFoQztJQUNBVSxZQUFZLEdBQUdBLFlBQVksR0FBRyxDQUFmLEdBQW1CWCxNQUFNLENBQUNZLE1BQVAsR0FBZ0IsQ0FBbkMsR0FBdUNELFlBQXREO0lBQ0FULGFBQWEsQ0FBQ1MsWUFBRCxDQUFiO0lBQ0FQLGVBQWUsQ0FBQ0osTUFBTSxDQUFDVyxZQUFELENBQVAsQ0FBZjtFQUNILENBTkQ7O0VBU0EsSUFBTUcsV0FBVyxHQUFHLFNBQWRBLFdBQWMsR0FBTTtJQUN0Qkwsb0JBQW9CLENBQUMsSUFBRCxDQUFwQjtFQUNILENBRkQ7O0VBR0Esb0JBQ0k7SUFBSyxTQUFTLEVBQUM7RUFBZixnQkFDSSw2QkFBQyxnQkFBRDtJQUFPLElBQUksRUFBRUosU0FBYjtJQUF3QixPQUFPLEVBQUVDO0VBQWpDLGdCQUNJO0lBQUssU0FBUyxFQUFDO0VBQWYsZ0JBQ0k7SUFBSyxTQUFTLEVBQUMsT0FBZjtJQUF1QixPQUFPLEVBQUVBO0VBQWhDLGdCQUNJLDZCQUFDLGVBQUQ7SUFBTSxJQUFJLEVBQUMsT0FBWDtJQUFtQixJQUFJLEVBQUM7RUFBeEIsRUFESixDQURKLEVBSUtOLE1BQU0sQ0FBQ1ksTUFBUCxHQUFnQixDQUFoQixnQkFDRztJQUFLLFNBQVMsRUFBQyxNQUFmO0lBQXNCLE9BQU8sRUFBRUM7RUFBL0IsZ0JBQ0ksNkJBQUMsZUFBRDtJQUFNLElBQUksRUFBQyxZQUFYO0lBQXdCLElBQUksRUFBQztFQUE3QixFQURKLENBREgsR0FHWSxFQVBqQixFQVVRTCxpQkFBaUIsR0FBRyxFQUFILGdCQUFRLDZCQUFDLGtCQUFELE9BVmpDLEVBWUtILFNBQVMsZ0JBQ047SUFBSyxHQUFHLEVBQUUsSUFBQVUsMEJBQUEsRUFBYVosWUFBWSxDQUFDYSxFQUExQixDQUFWO0lBQXlDLEdBQUcsRUFBRWIsWUFBWSxDQUFDYyxJQUEzRDtJQUFpRSxNQUFNLEVBQUVIO0VBQXpFLEVBRE0sZ0JBQ29GLDJEQWJsRyxFQWVLZCxNQUFNLENBQUNZLE1BQVAsR0FBZ0IsQ0FBaEIsZ0JBQ0c7SUFBSyxTQUFTLEVBQUMsT0FBZjtJQUF1QixPQUFPLEVBQUVGO0VBQWhDLGdCQUNJLDZCQUFDLGVBQUQ7SUFBTSxJQUFJLEVBQUMsYUFBWDtJQUF5QixJQUFJLEVBQUM7RUFBOUIsRUFESixDQURILEdBR1ksRUFsQmpCLENBREosQ0FESixDQURKO0FBMEJILENBbkRNIn0=
@@ -0,0 +1,5 @@
1
+ import React from "react";
2
+ export declare const VideoTours: React.FC<VideoToursProps>;
3
+ export interface VideoToursProps {
4
+ videoTourUrls: string[];
5
+ }
@@ -0,0 +1,56 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.VideoTours = void 0;
7
+
8
+ var _react = _interopRequireDefault(require("react"));
9
+
10
+ var _Utils = require("../utils/Utils");
11
+
12
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
13
+
14
+ var VideoTours = function VideoTours(_ref) {
15
+ var videoTourUrls = _ref.videoTourUrls;
16
+ return /*#__PURE__*/_react.default.createElement("div", {
17
+ className: "video-tour-view"
18
+ }, videoTourUrls.length == 1 ? /*#__PURE__*/_react.default.createElement("div", {
19
+ className: "single-video-layout"
20
+ }, /*#__PURE__*/_react.default.createElement("iframe", {
21
+ src: (0, _Utils.youtubeUrlToEmbedUrl)(videoTourUrls[0]),
22
+ title: "YouTube video player",
23
+ frameBorder: "0",
24
+ allow: "accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture",
25
+ allowFullScreen: true
26
+ })) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("div", {
27
+ className: "mobile"
28
+ }, /*#__PURE__*/_react.default.createElement("div", {
29
+ className: "single-video-layout"
30
+ }, /*#__PURE__*/_react.default.createElement("iframe", {
31
+ src: (0, _Utils.youtubeUrlToEmbedUrl)(videoTourUrls[0]),
32
+ title: "YouTube video player",
33
+ frameBorder: "0",
34
+ allow: "accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture",
35
+ allowFullScreen: true
36
+ }))), /*#__PURE__*/_react.default.createElement("div", {
37
+ className: "main"
38
+ }, /*#__PURE__*/_react.default.createElement("div", {
39
+ className: "two-video-layout"
40
+ }, /*#__PURE__*/_react.default.createElement("iframe", {
41
+ src: (0, _Utils.youtubeUrlToEmbedUrl)(videoTourUrls[0]),
42
+ title: "YouTube video player",
43
+ frameBorder: "0",
44
+ allow: "accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture",
45
+ allowFullScreen: true
46
+ }), /*#__PURE__*/_react.default.createElement("iframe", {
47
+ src: (0, _Utils.youtubeUrlToEmbedUrl)(videoTourUrls[1]),
48
+ title: "YouTube video player",
49
+ frameBorder: "0",
50
+ allow: "accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture",
51
+ allowFullScreen: true
52
+ })))));
53
+ };
54
+
55
+ exports.VideoTours = VideoTours;
56
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJWaWRlb1RvdXJzIiwidmlkZW9Ub3VyVXJscyIsImxlbmd0aCIsInlvdXR1YmVVcmxUb0VtYmVkVXJsIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL2dhbGxlcnkvVmlkZW9Ub3Vycy50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHt5b3V0dWJlVXJsVG9FbWJlZFVybH0gZnJvbSBcIi4uL3V0aWxzL1V0aWxzXCI7XG5cbmV4cG9ydCBjb25zdCBWaWRlb1RvdXJzOiBSZWFjdC5GQzxWaWRlb1RvdXJzUHJvcHM+ID0gKHt2aWRlb1RvdXJVcmxzfSkgPT4ge1xuICAgIHJldHVybiAoXG4gICAgICAgIDxkaXYgY2xhc3NOYW1lPVwidmlkZW8tdG91ci12aWV3XCI+XG4gICAgICAgICAgICB7dmlkZW9Ub3VyVXJscy5sZW5ndGggPT0gMSA/XG4gICAgICAgICAgICAgICAgPGRpdiBjbGFzc05hbWU9XCJzaW5nbGUtdmlkZW8tbGF5b3V0XCI+XG4gICAgICAgICAgICAgICAgICAgIDxpZnJhbWUgc3JjPXt5b3V0dWJlVXJsVG9FbWJlZFVybCh2aWRlb1RvdXJVcmxzWzBdKX1cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICB0aXRsZT1cIllvdVR1YmUgdmlkZW8gcGxheWVyXCIgZnJhbWVCb3JkZXI9XCIwXCJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBhbGxvdz1cImFjY2VsZXJvbWV0ZXI7IGF1dG9wbGF5OyBjbGlwYm9hcmQtd3JpdGU7IGVuY3J5cHRlZC1tZWRpYTsgZ3lyb3Njb3BlOyBwaWN0dXJlLWluLXBpY3R1cmVcIlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIGFsbG93RnVsbFNjcmVlbi8+XG4gICAgICAgICAgICAgICAgPC9kaXY+IDpcbiAgICAgICAgICAgICAgICA8PlxuICAgICAgICAgICAgICAgICAgICA8ZGl2IGNsYXNzTmFtZT1cIm1vYmlsZVwiPlxuICAgICAgICAgICAgICAgICAgICAgICAgPGRpdiBjbGFzc05hbWU9XCJzaW5nbGUtdmlkZW8tbGF5b3V0XCI+XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgPGlmcmFtZSBzcmM9e3lvdXR1YmVVcmxUb0VtYmVkVXJsKHZpZGVvVG91clVybHNbMF0pfVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgdGl0bGU9XCJZb3VUdWJlIHZpZGVvIHBsYXllclwiIGZyYW1lQm9yZGVyPVwiMFwiXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBhbGxvdz1cImFjY2VsZXJvbWV0ZXI7IGF1dG9wbGF5OyBjbGlwYm9hcmQtd3JpdGU7IGVuY3J5cHRlZC1tZWRpYTsgZ3lyb3Njb3BlOyBwaWN0dXJlLWluLXBpY3R1cmVcIlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYWxsb3dGdWxsU2NyZWVuLz5cbiAgICAgICAgICAgICAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgICAgICAgICAgPGRpdiBjbGFzc05hbWU9XCJtYWluXCI+XG4gICAgICAgICAgICAgICAgICAgICAgICA8ZGl2IGNsYXNzTmFtZT1cInR3by12aWRlby1sYXlvdXRcIj5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICA8aWZyYW1lIHNyYz17eW91dHViZVVybFRvRW1iZWRVcmwodmlkZW9Ub3VyVXJsc1swXSl9XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB0aXRsZT1cIllvdVR1YmUgdmlkZW8gcGxheWVyXCIgZnJhbWVCb3JkZXI9XCIwXCJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGFsbG93PVwiYWNjZWxlcm9tZXRlcjsgYXV0b3BsYXk7IGNsaXBib2FyZC13cml0ZTsgZW5jcnlwdGVkLW1lZGlhOyBneXJvc2NvcGU7IHBpY3R1cmUtaW4tcGljdHVyZVwiXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBhbGxvd0Z1bGxTY3JlZW4vPlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIDxpZnJhbWUgc3JjPXt5b3V0dWJlVXJsVG9FbWJlZFVybCh2aWRlb1RvdXJVcmxzWzFdKX1cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHRpdGxlPVwiWW91VHViZSB2aWRlbyBwbGF5ZXJcIiBmcmFtZUJvcmRlcj1cIjBcIlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgYWxsb3c9XCJhY2NlbGVyb21ldGVyOyBhdXRvcGxheTsgY2xpcGJvYXJkLXdyaXRlOyBlbmNyeXB0ZWQtbWVkaWE7IGd5cm9zY29wZTsgcGljdHVyZS1pbi1waWN0dXJlXCJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGFsbG93RnVsbFNjcmVlbi8+XG5cbiAgICAgICAgICAgICAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgICAgICA8Lz5cbiAgICAgICAgICAgIH1cblxuICAgICAgICA8L2Rpdj5cbiAgICApO1xufTtcblxuZXhwb3J0IGludGVyZmFjZSBWaWRlb1RvdXJzUHJvcHMge1xuICAgIHZpZGVvVG91clVybHM6IHN0cmluZ1tdO1xufSJdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUFBOztBQUNBOzs7O0FBRU8sSUFBTUEsVUFBcUMsR0FBRyxTQUF4Q0EsVUFBd0MsT0FBcUI7RUFBQSxJQUFuQkMsYUFBbUIsUUFBbkJBLGFBQW1CO0VBQ3RFLG9CQUNJO0lBQUssU0FBUyxFQUFDO0VBQWYsR0FDS0EsYUFBYSxDQUFDQyxNQUFkLElBQXdCLENBQXhCLGdCQUNHO0lBQUssU0FBUyxFQUFDO0VBQWYsZ0JBQ0k7SUFBUSxHQUFHLEVBQUUsSUFBQUMsMkJBQUEsRUFBcUJGLGFBQWEsQ0FBQyxDQUFELENBQWxDLENBQWI7SUFDUSxLQUFLLEVBQUMsc0JBRGQ7SUFDcUMsV0FBVyxFQUFDLEdBRGpEO0lBRVEsS0FBSyxFQUFDLDBGQUZkO0lBR1EsZUFBZTtFQUh2QixFQURKLENBREgsZ0JBT0cseUVBQ0k7SUFBSyxTQUFTLEVBQUM7RUFBZixnQkFDSTtJQUFLLFNBQVMsRUFBQztFQUFmLGdCQUNJO0lBQVEsR0FBRyxFQUFFLElBQUFFLDJCQUFBLEVBQXFCRixhQUFhLENBQUMsQ0FBRCxDQUFsQyxDQUFiO0lBQ1EsS0FBSyxFQUFDLHNCQURkO0lBQ3FDLFdBQVcsRUFBQyxHQURqRDtJQUVRLEtBQUssRUFBQywwRkFGZDtJQUdRLGVBQWU7RUFIdkIsRUFESixDQURKLENBREosZUFTSTtJQUFLLFNBQVMsRUFBQztFQUFmLGdCQUNJO0lBQUssU0FBUyxFQUFDO0VBQWYsZ0JBQ0k7SUFBUSxHQUFHLEVBQUUsSUFBQUUsMkJBQUEsRUFBcUJGLGFBQWEsQ0FBQyxDQUFELENBQWxDLENBQWI7SUFDUSxLQUFLLEVBQUMsc0JBRGQ7SUFDcUMsV0FBVyxFQUFDLEdBRGpEO0lBRVEsS0FBSyxFQUFDLDBGQUZkO0lBR1EsZUFBZTtFQUh2QixFQURKLGVBS0k7SUFBUSxHQUFHLEVBQUUsSUFBQUUsMkJBQUEsRUFBcUJGLGFBQWEsQ0FBQyxDQUFELENBQWxDLENBQWI7SUFDUSxLQUFLLEVBQUMsc0JBRGQ7SUFDcUMsV0FBVyxFQUFDLEdBRGpEO0lBRVEsS0FBSyxFQUFDLDBGQUZkO0lBR1EsZUFBZTtFQUh2QixFQUxKLENBREosQ0FUSixDQVJSLENBREo7QUFvQ0gsQ0FyQ00ifQ==
@@ -0,0 +1,5 @@
1
+ import React from "react";
2
+ export declare const VirtualTour: React.FC<VirtualTourProps>;
3
+ export interface VirtualTourProps {
4
+ virtualTourUrl?: string;
5
+ }
@@ -0,0 +1,28 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.VirtualTour = void 0;
7
+
8
+ var _react = _interopRequireDefault(require("react"));
9
+
10
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
11
+
12
+ var VirtualTour = function VirtualTour(_ref) {
13
+ var virtualTourUrl = _ref.virtualTourUrl;
14
+ return /*#__PURE__*/_react.default.createElement("div", {
15
+ className: "virtual-tour-view"
16
+ }, /*#__PURE__*/_react.default.createElement("iframe", {
17
+ title: "virtual tour",
18
+ frameBorder: "0",
19
+ style: {
20
+ border: 0
21
+ },
22
+ src: virtualTourUrl,
23
+ allowFullScreen: true
24
+ }));
25
+ };
26
+
27
+ exports.VirtualTour = VirtualTour;
28
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJWaXJ0dWFsVG91ciIsInZpcnR1YWxUb3VyVXJsIiwiYm9yZGVyIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL2dhbGxlcnkvVmlydHVhbFRvdXIudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tIFwicmVhY3RcIjtcblxuZXhwb3J0IGNvbnN0IFZpcnR1YWxUb3VyOiBSZWFjdC5GQzxWaXJ0dWFsVG91clByb3BzPiA9ICh7dmlydHVhbFRvdXJVcmx9KSA9PiB7XG4gICAgcmV0dXJuIChcbiAgICAgICAgPGRpdiBjbGFzc05hbWU9XCJ2aXJ0dWFsLXRvdXItdmlld1wiPlxuICAgICAgICAgICAgPGlmcmFtZSB0aXRsZT1cInZpcnR1YWwgdG91clwiICBmcmFtZUJvcmRlcj1cIjBcIlxuICAgICAgICAgICAgICAgICAgICBzdHlsZT17e2JvcmRlcjogMH19XG4gICAgICAgICAgICAgICAgICAgIHNyYz17dmlydHVhbFRvdXJVcmx9XG4gICAgICAgICAgICAgICAgICAgIGFsbG93RnVsbFNjcmVlbi8+XG4gICAgICAgIDwvZGl2PlxuICAgICk7XG59O1xuXG5leHBvcnQgaW50ZXJmYWNlIFZpcnR1YWxUb3VyUHJvcHMge1xuICAgIHZpcnR1YWxUb3VyVXJsPzogc3RyaW5nO1xufSJdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUFBOzs7O0FBRU8sSUFBTUEsV0FBdUMsR0FBRyxTQUExQ0EsV0FBMEMsT0FBc0I7RUFBQSxJQUFwQkMsY0FBb0IsUUFBcEJBLGNBQW9CO0VBQ3pFLG9CQUNJO0lBQUssU0FBUyxFQUFDO0VBQWYsZ0JBQ0k7SUFBUSxLQUFLLEVBQUMsY0FBZDtJQUE4QixXQUFXLEVBQUMsR0FBMUM7SUFDUSxLQUFLLEVBQUU7TUFBQ0MsTUFBTSxFQUFFO0lBQVQsQ0FEZjtJQUVRLEdBQUcsRUFBRUQsY0FGYjtJQUdRLGVBQWU7RUFIdkIsRUFESixDQURKO0FBUUgsQ0FUTSJ9