@renaissancerentals/renaissance-component 10.0.10 → 10.0.13
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/asset/AssetModal.d.ts +10 -0
- package/lib/asset/AssetModal.js +84 -0
- package/lib/asset/assets/AssetModal.scss +37 -0
- package/lib/assets/_variables.scss +1 -0
- package/lib/floorplan/card/SimilarFloorplanCard.d.ts +7 -0
- package/lib/floorplan/card/SimilarFloorplanCard.js +117 -0
- package/lib/floorplan/card/TestimonialsCard.d.ts +7 -0
- package/lib/floorplan/card/TestimonialsCard.js +68 -0
- package/lib/floorplan/card/assets/SimilarFloorplanCard.scss +53 -0
- package/lib/floorplan/card/assets/TestimonialsCard.scss +65 -0
- package/lib/floorplan/data/Floorplan.d.ts +39 -1
- package/lib/floorplan/data/Floorplan.js +1 -1
- package/lib/floorplan/data/Unit.d.ts +2 -2
- package/lib/floorplan/data/Unit.js +2 -2
- package/lib/floorplan/section/FloorplanHero.d.ts +9 -0
- package/lib/floorplan/section/FloorplanHero.js +126 -0
- package/lib/floorplan/section/FloorplanSection.d.ts +13 -0
- package/lib/floorplan/section/FloorplanSection.js +187 -0
- package/lib/floorplan/section/assets/FloorplanHero.scss +75 -0
- package/lib/floorplan/section/assets/FloorplanSection.scss +88 -0
- package/lib/floorplan/service/FloorplanService.d.ts +11 -1
- package/lib/floorplan/service/FloorplanService.js +127 -2
- package/lib/gallery/GalleryHero.d.ts +2 -2
- package/lib/gallery/GalleryHero.js +53 -8
- package/lib/gallery/GalleryModal.js +5 -5
- package/lib/gallery/VideoTours.d.ts +5 -0
- package/lib/gallery/VideoTours.js +56 -0
- package/lib/gallery/VirtualTour.d.ts +5 -0
- package/lib/gallery/VirtualTour.js +28 -0
- package/lib/gallery/assets/GalleryHero.scss +64 -3
- package/lib/index.d.ts +5 -3
- package/lib/index.js +77 -1
- package/lib/utils/Utils.d.ts +3 -0
- package/lib/utils/Utils.js +16 -2
- package/package.json +2 -1
|
@@ -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":"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"}
|
|
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
|
-
|
|
8
|
-
|
|
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
|
-
|
|
51
|
-
|
|
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(
|
|
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,
|
|
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,
|
|
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(
|
|
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(
|
|
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":"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"}
|
|
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+
|
|
101
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJHYWxsZXJ5TW9kYWwiLCJhc3NldHMiLCJhc3NldEluZGV4Iiwic2V0QXNzZXRJbmRleCIsImFzc2V0SW5Gb2N1cyIsInNldEFzc2V0SW5Gb2N1cyIsInNob3dNb2RhbCIsIm1vZGFsQ2xvc2VIYW5kbGVyIiwidXNlU3RhdGUiLCJzbGlkZXJJbWFnZUxvYWRlZCIsInNldFNsaWRlckltYWdlTG9hZGVkIiwicmlnaHRDbGlja0hhbmRsZXIiLCJjdXJyZW50SW5kZXgiLCJsZW5ndGgiLCJsZWZ0Q2xpY2tIYW5kbGVyIiwiaW1hZ2VMb2FkZWQiLCJhc3NldFVybEZyb20iLCJpZCIsIm5hbWUiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvZ2FsbGVyeS9HYWxsZXJ5TW9kYWwudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCwge3VzZVN0YXRlfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCB7SWNvbiwgTW9kYWwsIFNwaW5uZXJ9IGZyb20gXCJAY29udGVudG11bmNoL211bmNoZXItdWlcIjtcbmltcG9ydCB7YXNzZXRVcmxGcm9tfSBmcm9tIFwiLi4vYXNzZXQvc2VydmljZS9Bc3NldFNlcnZpY2VcIjtcbmltcG9ydCB7QXNzZXR9IGZyb20gXCIuLi9hc3NldC9kYXRhL0Fzc2V0XCI7XG5pbXBvcnQgXCIuL2Fzc2V0cy9HYWxsZXJ5TW9kYWwuc2Nzc1wiO1xuXG5leHBvcnQgY29uc3QgR2FsbGVyeU1vZGFsOiBSZWFjdC5GQzxHYWxsZXJ5TW9kYWxQcm9wcz4gPSAoXG4gICAge2Fzc2V0cywgYXNzZXRJbmRleCwgc2V0QXNzZXRJbmRleCwgYXNzZXRJbkZvY3VzLCBzZXRBc3NldEluRm9jdXMsIHNob3dNb2RhbCwgbW9kYWxDbG9zZUhhbmRsZXJ9KSA9PiB7XG5cblxuICAgIGNvbnN0IFtzbGlkZXJJbWFnZUxvYWRlZCwgc2V0U2xpZGVySW1hZ2VMb2FkZWRdID0gdXNlU3RhdGUoZmFsc2UpO1xuXG4gICAgY29uc3QgcmlnaHRDbGlja0hhbmRsZXIgPSAoKSA9PiB7XG4gICAgICAgIHNldFNsaWRlckltYWdlTG9hZGVkKGZhbHNlKTtcbiAgICAgICAgbGV0IGN1cnJlbnRJbmRleCA9IGFzc2V0SW5kZXggKyAxO1xuICAgICAgICBjdXJyZW50SW5kZXggPSBjdXJyZW50SW5kZXggPj0gYXNzZXRzLmxlbmd0aCA/IDAgOiBjdXJyZW50SW5kZXg7XG4gICAgICAgIHNldEFzc2V0SW5kZXgoY3VycmVudEluZGV4KTtcbiAgICAgICAgc2V0QXNzZXRJbkZvY3VzKGFzc2V0c1tjdXJyZW50SW5kZXhdKTtcbiAgICB9O1xuICAgIGNvbnN0IGxlZnRDbGlja0hhbmRsZXIgPSAoKSA9PiB7XG4gICAgICAgIHNldFNsaWRlckltYWdlTG9hZGVkKGZhbHNlKTtcbiAgICAgICAgbGV0IGN1cnJlbnRJbmRleCA9IGFzc2V0SW5kZXggLSAxO1xuICAgICAgICBjdXJyZW50SW5kZXggPSBjdXJyZW50SW5kZXggPCAwID8gYXNzZXRzLmxlbmd0aCAtIDEgOiBjdXJyZW50SW5kZXg7XG4gICAgICAgIHNldEFzc2V0SW5kZXgoY3VycmVudEluZGV4KTtcbiAgICAgICAgc2V0QXNzZXRJbkZvY3VzKGFzc2V0c1tjdXJyZW50SW5kZXhdKTtcbiAgICB9O1xuXG5cbiAgICBjb25zdCBpbWFnZUxvYWRlZCA9ICgpID0+IHtcbiAgICAgICAgc2V0U2xpZGVySW1hZ2VMb2FkZWQodHJ1ZSk7XG4gICAgfTtcbiAgICByZXR1cm4gKFxuICAgICAgICA8ZGl2IGNsYXNzTmFtZT1cImdhbGxlcnktbW9kYWxcIj5cbiAgICAgICAgICAgIDxNb2RhbCBzaG93PXtzaG93TW9kYWx9IHNldFNob3c9e21vZGFsQ2xvc2VIYW5kbGVyfT5cbiAgICAgICAgICAgICAgICA8ZGl2IGNsYXNzTmFtZT1cImltYWdlLXNsaWRlclwiPlxuICAgICAgICAgICAgICAgICAgICA8ZGl2IGNsYXNzTmFtZT1cImNsb3NlXCIgb25DbGljaz17bW9kYWxDbG9zZUhhbmRsZXJ9PlxuICAgICAgICAgICAgICAgICAgICAgICAgPEljb24gbmFtZT1cImNsb3NlXCIgc2l6ZT1cImxhcmdlXCIvPlxuICAgICAgICAgICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgICAgICAgICAge2Fzc2V0cy5sZW5ndGggPiAxID9cbiAgICAgICAgICAgICAgICAgICAgICAgIDxkaXYgY2xhc3NOYW1lPVwibGVmdFwiIG9uQ2xpY2s9e2xlZnRDbGlja0hhbmRsZXJ9PlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIDxJY29uIG5hbWU9XCJhcnJvdy1sZWZ0XCIgc2l6ZT1cImxhcmdlXCIvPlxuICAgICAgICAgICAgICAgICAgICAgICAgPC9kaXY+IDogXCJcIn1cblxuICAgICAgICAgICAgICAgICAgICB7XG4gICAgICAgICAgICAgICAgICAgICAgICBzbGlkZXJJbWFnZUxvYWRlZCA/IFwiXCIgOiA8U3Bpbm5lci8+XG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAge3Nob3dNb2RhbCA/XG4gICAgICAgICAgICAgICAgICAgICAgICA8aW1nIHNyYz17YXNzZXRVcmxGcm9tKGFzc2V0SW5Gb2N1cy5pZCl9IGFsdD17YXNzZXRJbkZvY3VzLm5hbWV9IG9uTG9hZD17aW1hZ2VMb2FkZWR9Lz4gOiA8PjwvPn1cblxuICAgICAgICAgICAgICAgICAgICB7YXNzZXRzLmxlbmd0aCA+IDEgP1xuICAgICAgICAgICAgICAgICAgICAgICAgPGRpdiBjbGFzc05hbWU9XCJyaWdodFwiIG9uQ2xpY2s9e3JpZ2h0Q2xpY2tIYW5kbGVyfT5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICA8SWNvbiBuYW1lPVwiYXJyb3ctcmlnaHRcIiBzaXplPVwibGFyZ2VcIi8+XG4gICAgICAgICAgICAgICAgICAgICAgICA8L2Rpdj4gOiBcIlwifVxuICAgICAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgPC9Nb2RhbD5cbiAgICAgICAgPC9kaXY+XG4gICAgKTtcbn07XG5cbmV4cG9ydCBpbnRlcmZhY2UgR2FsbGVyeU1vZGFsUHJvcHMge1xuICAgIGFzc2V0czogQXNzZXRbXTtcbiAgICBhc3NldEluRm9jdXM6IEFzc2V0O1xuICAgIGFzc2V0SW5kZXg6IG51bWJlcjtcbiAgICBzZXRBc3NldEluZGV4OiAoaW5kZXg6IG51bWJlcikgPT4gdm9pZDtcbiAgICBzZXRBc3NldEluRm9jdXM6IChhc3NldDogQXNzZXQpID0+IHZvaWQ7XG4gICAgc2hvd01vZGFsOiBib29sZWFuO1xuICAgIG1vZGFsQ2xvc2VIYW5kbGVyOiAoKSA9PiB2b2lkO1xufSJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7O0FBQUE7O0FBQ0E7O0FBQ0E7O0FBRUE7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUVPLElBQU1BLFlBQXlDLEdBQUcsU0FBNUNBLFlBQTRDLE9BQ2dEO0VBQUEsSUFBcEdDLE1BQW9HLFFBQXBHQSxNQUFvRztFQUFBLElBQTVGQyxVQUE0RixRQUE1RkEsVUFBNEY7RUFBQSxJQUFoRkMsYUFBZ0YsUUFBaEZBLGFBQWdGO0VBQUEsSUFBakVDLFlBQWlFLFFBQWpFQSxZQUFpRTtFQUFBLElBQW5EQyxlQUFtRCxRQUFuREEsZUFBbUQ7RUFBQSxJQUFsQ0MsU0FBa0MsUUFBbENBLFNBQWtDO0VBQUEsSUFBdkJDLGlCQUF1QixRQUF2QkEsaUJBQXVCOztFQUdyRyxnQkFBa0QsSUFBQUMsZUFBQSxFQUFTLEtBQVQsQ0FBbEQ7RUFBQTtFQUFBLElBQU9DLGlCQUFQO0VBQUEsSUFBMEJDLG9CQUExQjs7RUFFQSxJQUFNQyxpQkFBaUIsR0FBRyxTQUFwQkEsaUJBQW9CLEdBQU07SUFDNUJELG9CQUFvQixDQUFDLEtBQUQsQ0FBcEI7SUFDQSxJQUFJRSxZQUFZLEdBQUdWLFVBQVUsR0FBRyxDQUFoQztJQUNBVSxZQUFZLEdBQUdBLFlBQVksSUFBSVgsTUFBTSxDQUFDWSxNQUF2QixHQUFnQyxDQUFoQyxHQUFvQ0QsWUFBbkQ7SUFDQVQsYUFBYSxDQUFDUyxZQUFELENBQWI7SUFDQVAsZUFBZSxDQUFDSixNQUFNLENBQUNXLFlBQUQsQ0FBUCxDQUFmO0VBQ0gsQ0FORDs7RUFPQSxJQUFNRSxnQkFBZ0IsR0FBRyxTQUFuQkEsZ0JBQW1CLEdBQU07SUFDM0JKLG9CQUFvQixDQUFDLEtBQUQsQ0FBcEI7SUFDQSxJQUFJRSxZQUFZLEdBQUdWLFVBQVUsR0FBRyxDQUFoQztJQUNBVSxZQUFZLEdBQUdBLFlBQVksR0FBRyxDQUFmLEdBQW1CWCxNQUFNLENBQUNZLE1BQVAsR0FBZ0IsQ0FBbkMsR0FBdUNELFlBQXREO0lBQ0FULGFBQWEsQ0FBQ1MsWUFBRCxDQUFiO0lBQ0FQLGVBQWUsQ0FBQ0osTUFBTSxDQUFDVyxZQUFELENBQVAsQ0FBZjtFQUNILENBTkQ7O0VBU0EsSUFBTUcsV0FBVyxHQUFHLFNBQWRBLFdBQWMsR0FBTTtJQUN0Qkwsb0JBQW9CLENBQUMsSUFBRCxDQUFwQjtFQUNILENBRkQ7O0VBR0Esb0JBQ0k7SUFBSyxTQUFTLEVBQUM7RUFBZixnQkFDSSw2QkFBQyxnQkFBRDtJQUFPLElBQUksRUFBRUosU0FBYjtJQUF3QixPQUFPLEVBQUVDO0VBQWpDLGdCQUNJO0lBQUssU0FBUyxFQUFDO0VBQWYsZ0JBQ0k7SUFBSyxTQUFTLEVBQUMsT0FBZjtJQUF1QixPQUFPLEVBQUVBO0VBQWhDLGdCQUNJLDZCQUFDLGVBQUQ7SUFBTSxJQUFJLEVBQUMsT0FBWDtJQUFtQixJQUFJLEVBQUM7RUFBeEIsRUFESixDQURKLEVBSUtOLE1BQU0sQ0FBQ1ksTUFBUCxHQUFnQixDQUFoQixnQkFDRztJQUFLLFNBQVMsRUFBQyxNQUFmO0lBQXNCLE9BQU8sRUFBRUM7RUFBL0IsZ0JBQ0ksNkJBQUMsZUFBRDtJQUFNLElBQUksRUFBQyxZQUFYO0lBQXdCLElBQUksRUFBQztFQUE3QixFQURKLENBREgsR0FHWSxFQVBqQixFQVVRTCxpQkFBaUIsR0FBRyxFQUFILGdCQUFRLDZCQUFDLGtCQUFELE9BVmpDLEVBWUtILFNBQVMsZ0JBQ047SUFBSyxHQUFHLEVBQUUsSUFBQVUsMEJBQUEsRUFBYVosWUFBWSxDQUFDYSxFQUExQixDQUFWO0lBQXlDLEdBQUcsRUFBRWIsWUFBWSxDQUFDYyxJQUEzRDtJQUFpRSxNQUFNLEVBQUVIO0VBQXpFLEVBRE0sZ0JBQ29GLDJEQWJsRyxFQWVLZCxNQUFNLENBQUNZLE1BQVAsR0FBZ0IsQ0FBaEIsZ0JBQ0c7SUFBSyxTQUFTLEVBQUMsT0FBZjtJQUF1QixPQUFPLEVBQUVGO0VBQWhDLGdCQUNJLDZCQUFDLGVBQUQ7SUFBTSxJQUFJLEVBQUMsYUFBWDtJQUF5QixJQUFJLEVBQUM7RUFBOUIsRUFESixDQURILEdBR1ksRUFsQmpCLENBREosQ0FESixDQURKO0FBMEJILENBbkRNIn0=
|
|
@@ -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,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
|