@renaissancerentals/renaissance-component 10.0.12 → 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.
Files changed (33) 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/SimilarFloorplanCard.d.ts +7 -0
  6. package/lib/floorplan/card/SimilarFloorplanCard.js +117 -0
  7. package/lib/floorplan/card/TestimonialsCard.d.ts +7 -0
  8. package/lib/floorplan/card/TestimonialsCard.js +68 -0
  9. package/lib/floorplan/card/assets/SimilarFloorplanCard.scss +53 -0
  10. package/lib/floorplan/card/assets/TestimonialsCard.scss +65 -0
  11. package/lib/floorplan/data/Floorplan.d.ts +39 -1
  12. package/lib/floorplan/data/Floorplan.js +1 -1
  13. package/lib/floorplan/section/FloorplanHero.d.ts +9 -0
  14. package/lib/floorplan/section/FloorplanHero.js +126 -0
  15. package/lib/floorplan/section/FloorplanSection.d.ts +13 -0
  16. package/lib/floorplan/section/FloorplanSection.js +187 -0
  17. package/lib/floorplan/section/assets/FloorplanHero.scss +75 -0
  18. package/lib/floorplan/section/assets/FloorplanSection.scss +88 -0
  19. package/lib/floorplan/service/FloorplanService.d.ts +11 -1
  20. package/lib/floorplan/service/FloorplanService.js +127 -2
  21. package/lib/gallery/GalleryHero.d.ts +2 -2
  22. package/lib/gallery/GalleryHero.js +53 -8
  23. package/lib/gallery/GalleryModal.js +5 -5
  24. package/lib/gallery/VideoTours.d.ts +5 -0
  25. package/lib/gallery/VideoTours.js +56 -0
  26. package/lib/gallery/VirtualTour.d.ts +5 -0
  27. package/lib/gallery/VirtualTour.js +28 -0
  28. package/lib/gallery/assets/GalleryHero.scss +64 -3
  29. package/lib/index.d.ts +4 -2
  30. package/lib/index.js +77 -1
  31. package/lib/utils/Utils.d.ts +3 -0
  32. package/lib/utils/Utils.js +16 -2
  33. package/package.json +2 -1
@@ -0,0 +1,10 @@
1
+ import React from "react";
2
+ import "./assets/AssetModal.scss";
3
+ import { Size, Variant } from "@contentmunch/muncher-ui/lib/button/Button";
4
+ export declare const AssetModal: React.FC<AssetModalProps>;
5
+ export interface AssetModalProps {
6
+ assetUrl: string | null;
7
+ assetTitle: string;
8
+ variant?: Variant;
9
+ size?: Size;
10
+ }
@@ -0,0 +1,84 @@
1
+ "use strict";
2
+
3
+ function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
4
+
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.AssetModal = void 0;
9
+
10
+ var _react = _interopRequireWildcard(require("react"));
11
+
12
+ var _muncherUi = require("@contentmunch/muncher-ui");
13
+
14
+ var _AssetService = require("./service/AssetService");
15
+
16
+ require("./assets/AssetModal.scss");
17
+
18
+ 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); }
19
+
20
+ 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; }
21
+
22
+ function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
23
+
24
+ function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
25
+
26
+ function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
27
+
28
+ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
29
+
30
+ function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
31
+
32
+ function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
33
+
34
+ var AssetModal = function AssetModal(_ref) {
35
+ var assetUrl = _ref.assetUrl,
36
+ variant = _ref.variant,
37
+ size = _ref.size,
38
+ assetTitle = _ref.assetTitle,
39
+ children = _ref.children;
40
+
41
+ var _useState = (0, _react.useState)(false),
42
+ _useState2 = _slicedToArray(_useState, 2),
43
+ showModal = _useState2[0],
44
+ setShowModal = _useState2[1];
45
+
46
+ var _useState3 = (0, _react.useState)(false),
47
+ _useState4 = _slicedToArray(_useState3, 2),
48
+ assetLoaded = _useState4[0],
49
+ setAssetLoaded = _useState4[1];
50
+
51
+ return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("div", {
52
+ className: "asset-modal"
53
+ }, /*#__PURE__*/_react.default.createElement(_muncherUi.Modal, {
54
+ show: showModal,
55
+ setShow: function setShow() {
56
+ return setShowModal(false);
57
+ }
58
+ }, /*#__PURE__*/_react.default.createElement("div", {
59
+ className: "asset"
60
+ }, /*#__PURE__*/_react.default.createElement("div", {
61
+ className: "close",
62
+ onClick: function onClick() {
63
+ return setShowModal(false);
64
+ }
65
+ }, /*#__PURE__*/_react.default.createElement(_muncherUi.Icon, {
66
+ name: "close",
67
+ size: "large"
68
+ })), assetLoaded ? "" : /*#__PURE__*/_react.default.createElement(_muncherUi.Spinner, null), showModal && assetUrl ? /*#__PURE__*/_react.default.createElement("img", {
69
+ src: (0, _AssetService.getAssetUrl)(assetUrl),
70
+ alt: assetTitle,
71
+ onLoad: function onLoad() {
72
+ return setAssetLoaded(true);
73
+ }
74
+ }) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null)))), /*#__PURE__*/_react.default.createElement(_muncherUi.Button, {
75
+ variant: variant,
76
+ size: size,
77
+ onClick: function onClick() {
78
+ setShowModal(true);
79
+ }
80
+ }, children));
81
+ };
82
+
83
+ exports.AssetModal = AssetModal;
84
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJBc3NldE1vZGFsIiwiYXNzZXRVcmwiLCJ2YXJpYW50Iiwic2l6ZSIsImFzc2V0VGl0bGUiLCJjaGlsZHJlbiIsInVzZVN0YXRlIiwic2hvd01vZGFsIiwic2V0U2hvd01vZGFsIiwiYXNzZXRMb2FkZWQiLCJzZXRBc3NldExvYWRlZCIsImdldEFzc2V0VXJsIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL2Fzc2V0L0Fzc2V0TW9kYWwudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCwge3VzZVN0YXRlfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCB7QnV0dG9uLCBJY29uLCBNb2RhbCwgU3Bpbm5lcn0gZnJvbSBcIkBjb250ZW50bXVuY2gvbXVuY2hlci11aVwiO1xuaW1wb3J0IHtnZXRBc3NldFVybH0gZnJvbSBcIi4vc2VydmljZS9Bc3NldFNlcnZpY2VcIjtcbmltcG9ydCBcIi4vYXNzZXRzL0Fzc2V0TW9kYWwuc2Nzc1wiO1xuaW1wb3J0IHtTaXplLCBWYXJpYW50fSBmcm9tIFwiQGNvbnRlbnRtdW5jaC9tdW5jaGVyLXVpL2xpYi9idXR0b24vQnV0dG9uXCI7XG5cbmV4cG9ydCBjb25zdCBBc3NldE1vZGFsOiBSZWFjdC5GQzxBc3NldE1vZGFsUHJvcHM+ID0gKFxuICAgIHthc3NldFVybCwgdmFyaWFudCwgc2l6ZSwgYXNzZXRUaXRsZSwgY2hpbGRyZW59KSA9PiB7XG4gICAgY29uc3QgW3Nob3dNb2RhbCwgc2V0U2hvd01vZGFsXSA9IHVzZVN0YXRlKGZhbHNlKTtcbiAgICBjb25zdCBbYXNzZXRMb2FkZWQsIHNldEFzc2V0TG9hZGVkXSA9IHVzZVN0YXRlKGZhbHNlKTtcblxuXG4gICAgcmV0dXJuIChcbiAgICAgICAgPD5cbiAgICAgICAgICAgIDxkaXYgY2xhc3NOYW1lPVwiYXNzZXQtbW9kYWxcIj5cbiAgICAgICAgICAgICAgICA8TW9kYWwgc2hvdz17c2hvd01vZGFsfSBzZXRTaG93PXsoKSA9PiBzZXRTaG93TW9kYWwoZmFsc2UpfT5cbiAgICAgICAgICAgICAgICAgICAgPGRpdiBjbGFzc05hbWU9XCJhc3NldFwiPlxuICAgICAgICAgICAgICAgICAgICAgICAgPGRpdiBjbGFzc05hbWU9XCJjbG9zZVwiIG9uQ2xpY2s9eygpID0+IHNldFNob3dNb2RhbChmYWxzZSl9PlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIDxJY29uIG5hbWU9XCJjbG9zZVwiIHNpemU9XCJsYXJnZVwiLz5cbiAgICAgICAgICAgICAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgICAgICAgICAgICAge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIGFzc2V0TG9hZGVkID8gXCJcIiA6IDxTcGlubmVyLz5cbiAgICAgICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgICAgIHtzaG93TW9kYWwgJiYgYXNzZXRVcmwgP1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIDxpbWcgc3JjPXtnZXRBc3NldFVybChhc3NldFVybCl9IGFsdD17YXNzZXRUaXRsZX1cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIG9uTG9hZD17KCkgPT4gc2V0QXNzZXRMb2FkZWQodHJ1ZSl9Lz4gOiA8PjwvPlxuICAgICAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgICAgICA8L01vZGFsPlxuICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICA8QnV0dG9uIHZhcmlhbnQ9e3ZhcmlhbnR9IHNpemU9e3NpemV9IG9uQ2xpY2s9eygpID0+IHtcbiAgICAgICAgICAgICAgICBzZXRTaG93TW9kYWwodHJ1ZSk7XG4gICAgICAgICAgICB9fT57Y2hpbGRyZW59PC9CdXR0b24+XG5cbiAgICAgICAgPC8+XG4gICAgKTtcbn07XG5cbmV4cG9ydCBpbnRlcmZhY2UgQXNzZXRNb2RhbFByb3BzIHtcbiAgICBhc3NldFVybDogc3RyaW5nIHwgbnVsbDtcbiAgICBhc3NldFRpdGxlOiBzdHJpbmc7XG4gICAgdmFyaWFudD86IFZhcmlhbnQ7XG4gICAgc2l6ZT86IFNpemU7XG59Il0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7QUFBQTs7QUFDQTs7QUFDQTs7QUFDQTs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBR08sSUFBTUEsVUFBcUMsR0FBRyxTQUF4Q0EsVUFBd0MsT0FDRztFQUFBLElBQW5EQyxRQUFtRCxRQUFuREEsUUFBbUQ7RUFBQSxJQUF6Q0MsT0FBeUMsUUFBekNBLE9BQXlDO0VBQUEsSUFBaENDLElBQWdDLFFBQWhDQSxJQUFnQztFQUFBLElBQTFCQyxVQUEwQixRQUExQkEsVUFBMEI7RUFBQSxJQUFkQyxRQUFjLFFBQWRBLFFBQWM7O0VBQ3BELGdCQUFrQyxJQUFBQyxlQUFBLEVBQVMsS0FBVCxDQUFsQztFQUFBO0VBQUEsSUFBT0MsU0FBUDtFQUFBLElBQWtCQyxZQUFsQjs7RUFDQSxpQkFBc0MsSUFBQUYsZUFBQSxFQUFTLEtBQVQsQ0FBdEM7RUFBQTtFQUFBLElBQU9HLFdBQVA7RUFBQSxJQUFvQkMsY0FBcEI7O0VBR0Esb0JBQ0kseUVBQ0k7SUFBSyxTQUFTLEVBQUM7RUFBZixnQkFDSSw2QkFBQyxnQkFBRDtJQUFPLElBQUksRUFBRUgsU0FBYjtJQUF3QixPQUFPLEVBQUU7TUFBQSxPQUFNQyxZQUFZLENBQUMsS0FBRCxDQUFsQjtJQUFBO0VBQWpDLGdCQUNJO0lBQUssU0FBUyxFQUFDO0VBQWYsZ0JBQ0k7SUFBSyxTQUFTLEVBQUMsT0FBZjtJQUF1QixPQUFPLEVBQUU7TUFBQSxPQUFNQSxZQUFZLENBQUMsS0FBRCxDQUFsQjtJQUFBO0VBQWhDLGdCQUNJLDZCQUFDLGVBQUQ7SUFBTSxJQUFJLEVBQUMsT0FBWDtJQUFtQixJQUFJLEVBQUM7RUFBeEIsRUFESixDQURKLEVBS1FDLFdBQVcsR0FBRyxFQUFILGdCQUFRLDZCQUFDLGtCQUFELE9BTDNCLEVBT0tGLFNBQVMsSUFBSU4sUUFBYixnQkFDRztJQUFLLEdBQUcsRUFBRSxJQUFBVSx5QkFBQSxFQUFZVixRQUFaLENBQVY7SUFBaUMsR0FBRyxFQUFFRyxVQUF0QztJQUNLLE1BQU0sRUFBRTtNQUFBLE9BQU1NLGNBQWMsQ0FBQyxJQUFELENBQXBCO0lBQUE7RUFEYixFQURILGdCQUVnRCwyREFUckQsQ0FESixDQURKLENBREosZUFpQkksNkJBQUMsaUJBQUQ7SUFBUSxPQUFPLEVBQUVSLE9BQWpCO0lBQTBCLElBQUksRUFBRUMsSUFBaEM7SUFBc0MsT0FBTyxFQUFFLG1CQUFNO01BQ2pESyxZQUFZLENBQUMsSUFBRCxDQUFaO0lBQ0g7RUFGRCxHQUVJSCxRQUZKLENBakJKLENBREo7QUF3QkgsQ0E5Qk0ifQ==
@@ -0,0 +1,37 @@
1
+ @import "src/assets/variables";
2
+
3
+ .asset-modal {
4
+
5
+ .muncher-modal {
6
+ color: $primary-background-color;
7
+ text-align: center;
8
+ top: 3vh;
9
+
10
+ .asset {
11
+ img {
12
+ width: 80vw;
13
+ height: 80vh;
14
+ object-fit: contain;
15
+ }
16
+
17
+ .close {
18
+ top: .1rem;
19
+ right: .2rem;
20
+ position: fixed;
21
+ padding: .4rem;
22
+ cursor: pointer;
23
+ }
24
+
25
+ .close:hover {
26
+ opacity: .6;
27
+ }
28
+
29
+ .muncher-spinner {
30
+ position: fixed;
31
+ left: 45%;
32
+ top: 45%;
33
+ }
34
+ }
35
+ }
36
+
37
+ }
@@ -1,6 +1,7 @@
1
1
  //overrides from muncher-ui
2
2
  $primary-color: #40606f !default;
3
3
  $secondary-color: #4b4f54 !default;
4
+ $tertiary-color: #f7f7f7 !default;
4
5
  $primary-background-color: white !default;
5
6
  $secondary-background-color: #eae9e3 !default;
6
7
  $tertiary-background-color: #91a9b3 !default;
@@ -0,0 +1,7 @@
1
+ import React from "react";
2
+ import { SimilarFloorplan } from "../data/Floorplan";
3
+ import "./assets/SimilarFloorplanCard.scss";
4
+ export declare const SimilarFloorplanCard: React.FC<SimilarFloorplanCardProps>;
5
+ export interface SimilarFloorplanCardProps {
6
+ similarFloorplans: SimilarFloorplan[];
7
+ }
@@ -0,0 +1,117 @@
1
+ "use strict";
2
+
3
+ function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
4
+
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.SimilarFloorplanCard = void 0;
9
+
10
+ var _react = _interopRequireWildcard(require("react"));
11
+
12
+ var _AssetService = require("../../asset/service/AssetService");
13
+
14
+ var _Api = require("../../service/Api");
15
+
16
+ var _Card = require("../../card/Card");
17
+
18
+ var _muncherUi = require("@contentmunch/muncher-ui");
19
+
20
+ var _Utils = require("../../utils/Utils");
21
+
22
+ require("./assets/SimilarFloorplanCard.scss");
23
+
24
+ var _FloorplanService = require("../service/FloorplanService");
25
+
26
+ 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); }
27
+
28
+ 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; }
29
+
30
+ function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
31
+
32
+ function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
33
+
34
+ function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
35
+
36
+ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
37
+
38
+ function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
39
+
40
+ function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
41
+
42
+ var SimilarFloorplanCard = function SimilarFloorplanCard(_ref) {
43
+ var _floorplans$current, _floorplans$current$u;
44
+
45
+ var similarFloorplans = _ref.similarFloorplans;
46
+
47
+ var _useState = (0, _react.useState)([]),
48
+ _useState2 = _slicedToArray(_useState, 2),
49
+ floorplans = _useState2[0],
50
+ setFloorplans = _useState2[1];
51
+
52
+ var _useState3 = (0, _react.useState)(0),
53
+ _useState4 = _slicedToArray(_useState3, 2),
54
+ current = _useState4[0],
55
+ setCurrent = _useState4[1];
56
+
57
+ var _useState5 = (0, _react.useState)(true),
58
+ _useState6 = _slicedToArray(_useState5, 2),
59
+ isLoading = _useState6[0],
60
+ setIsLoading = _useState6[1];
61
+
62
+ (0, _react.useEffect)(function () {
63
+ var promises = [];
64
+ similarFloorplans.map(function (similarFloorplan) {
65
+ promises.push((0, _FloorplanService.getFloorplan)(similarFloorplan.similarTo.id));
66
+ });
67
+ Promise.all(promises).then(function (data) {
68
+ setFloorplans(data);
69
+ }).finally(function () {
70
+ return setIsLoading(false);
71
+ });
72
+ }, [similarFloorplans]);
73
+
74
+ var imageUrl = function imageUrl(floorplan) {
75
+ if (floorplan && floorplan.coverImage) return (0, _AssetService.getAssetUrl)(floorplan.coverImage);else return _Api.DEFAULT_IMAGE_URL;
76
+ };
77
+
78
+ return /*#__PURE__*/_react.default.createElement("div", {
79
+ className: "similar-floorplan-card"
80
+ }, /*#__PURE__*/_react.default.createElement(_Card.Card, {
81
+ title: "You Might Also Like"
82
+ }, isLoading ? /*#__PURE__*/_react.default.createElement(_muncherUi.Spinner, {
83
+ size: "medium"
84
+ }) : /*#__PURE__*/_react.default.createElement("div", {
85
+ className: "similar-floorplan-card"
86
+ }, /*#__PURE__*/_react.default.createElement("div", {
87
+ className: "card-slider-body",
88
+ style: {
89
+ backgroundImage: "url(".concat(imageUrl(floorplans[current]), ")")
90
+ }
91
+ }, floorplans.length > 1 ? /*#__PURE__*/_react.default.createElement("div", {
92
+ className: "icon-left"
93
+ }, /*#__PURE__*/_react.default.createElement(_muncherUi.Icon, {
94
+ name: "chevron-left",
95
+ size: "large",
96
+ weight: 2,
97
+ onClick: function onClick() {
98
+ setCurrent(current < 1 ? floorplans.length - 1 : current - 1);
99
+ }
100
+ })) : "", floorplans.length > 1 ? /*#__PURE__*/_react.default.createElement("div", {
101
+ className: "icon-right"
102
+ }, /*#__PURE__*/_react.default.createElement(_muncherUi.Icon, {
103
+ name: "chevron-right",
104
+ size: "large",
105
+ weight: 2,
106
+ onClick: function onClick() {
107
+ setCurrent(current === floorplans.length - 1 ? 0 : current + 1);
108
+ }
109
+ })) : ""), /*#__PURE__*/_react.default.createElement("div", {
110
+ className: "card-slider-footer"
111
+ }, /*#__PURE__*/_react.default.createElement("h3", null, /*#__PURE__*/_react.default.createElement("a", {
112
+ href: "/floorplans/" + floorplans[current].id
113
+ }, floorplans[current].name)), /*#__PURE__*/_react.default.createElement("p", null, (_floorplans$current = floorplans[current]) === null || _floorplans$current === void 0 ? void 0 : (_floorplans$current$u = _floorplans$current.units[0]) === null || _floorplans$current$u === void 0 ? void 0 : _floorplans$current$u.address), /*#__PURE__*/_react.default.createElement("p", null, " ", floorplans[current].bedroom, " Bedroom $", (0, _Utils.rangeFrom)(floorplans[current].units, "rent"), "/mo")))));
114
+ };
115
+
116
+ exports.SimilarFloorplanCard = SimilarFloorplanCard;
117
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["SimilarFloorplanCard","similarFloorplans","useState","floorplans","setFloorplans","current","setCurrent","isLoading","setIsLoading","useEffect","promises","map","similarFloorplan","push","getFloorplan","similarTo","id","Promise","all","then","data","finally","imageUrl","floorplan","coverImage","getAssetUrl","DEFAULT_IMAGE_URL","backgroundImage","length","name","units","address","bedroom","rangeFrom"],"sources":["../../../src/floorplan/card/SimilarFloorplanCard.tsx"],"sourcesContent":["import React, {useEffect, useState} from \"react\";\nimport {Floorplan, SimilarFloorplan} from \"../data/Floorplan\";\nimport {getAssetUrl} from \"../../asset/service/AssetService\";\nimport {DEFAULT_IMAGE_URL} from \"../../service/Api\";\nimport {Card} from \"../../card/Card\";\nimport {Icon, Spinner} from \"@contentmunch/muncher-ui\";\nimport {rangeFrom} from \"../../utils/Utils\";\nimport \"./assets/SimilarFloorplanCard.scss\"\nimport {getFloorplan} from \"../service/FloorplanService\";\n\nexport const SimilarFloorplanCard: React.FC<SimilarFloorplanCardProps> = ({similarFloorplans}) => {\n    const [floorplans, setFloorplans] = useState<Floorplan[]>([]);\n    const [current, setCurrent] = useState(0);\n    const [isLoading, setIsLoading] = useState(true);\n\n    useEffect(() => {\n        const promises: Promise<Floorplan>[] = [];\n        similarFloorplans.map(similarFloorplan => {\n            promises.push(getFloorplan(similarFloorplan.similarTo.id));\n        });\n        Promise.all(promises).then(data => {\n            setFloorplans(data);\n        }).finally(() => setIsLoading(false));\n\n    }, [similarFloorplans]);\n\n    const imageUrl = (floorplan: Floorplan): string => {\n        if (floorplan && floorplan.coverImage)\n            return getAssetUrl(floorplan.coverImage);\n        else\n            return DEFAULT_IMAGE_URL;\n\n    };\n    return (\n\n        <div className=\"similar-floorplan-card\">\n            <Card title=\"You Might Also Like\">\n                {isLoading ? <Spinner size=\"medium\"/> :\n                    <div className=\"similar-floorplan-card\">\n                        <div className=\"card-slider-body\"\n                             style={{backgroundImage: `url(${imageUrl(floorplans[current])})`}}>\n                            {floorplans.length > 1 ?\n                                <div className=\"icon-left\">\n                                    <Icon name=\"chevron-left\" size=\"large\" weight={2} onClick={\n                                        () => {\n                                            setCurrent(current < 1 ? floorplans.length - 1 : current - 1)\n                                        }}/>\n                                </div>\n                                : \"\"}\n                            {floorplans.length > 1 ?\n                                <div className=\"icon-right\">\n                                    <Icon name=\"chevron-right\" size=\"large\" weight={2} onClick={\n                                        () => {\n                                            setCurrent(current === (floorplans.length - 1) ? 0 : current + 1)\n                                        }}/>\n                                </div>\n                                : \"\"}\n                        </div>\n                        <div className=\"card-slider-footer\">\n                            <h3><a href={\"/floorplans/\" + floorplans[current].id}>{floorplans[current].name}</a></h3>\n                            <p>{floorplans[current]?.units[0]?.address}</p>\n                            <p> {floorplans[current].bedroom} Bedroom\n                                ${rangeFrom(floorplans[current].units, \"rent\")}/mo</p>\n                        </div>\n                    </div>\n                }\n            </Card>\n        </div>\n    );\n};\n\nexport interface SimilarFloorplanCardProps {\n    similarFloorplans: SimilarFloorplan[];\n}"],"mappings":"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"}
@@ -0,0 +1,7 @@
1
+ import React from "react";
2
+ import "./assets/TestimonialsCard.scss";
3
+ import { Testimonial } from "../data/Floorplan";
4
+ export declare const TestimonialsCard: React.FC<TestimonialsCardProps>;
5
+ export interface TestimonialsCardProps {
6
+ testimonials: Testimonial[];
7
+ }
@@ -0,0 +1,68 @@
1
+ "use strict";
2
+
3
+ function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
4
+
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.TestimonialsCard = void 0;
9
+
10
+ var _react = _interopRequireWildcard(require("react"));
11
+
12
+ var _muncherUi = require("@contentmunch/muncher-ui");
13
+
14
+ require("./assets/TestimonialsCard.scss");
15
+
16
+ var _Card = require("../../card/Card");
17
+
18
+ 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); }
19
+
20
+ 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; }
21
+
22
+ function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
23
+
24
+ function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
25
+
26
+ function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
27
+
28
+ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
29
+
30
+ function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
31
+
32
+ function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
33
+
34
+ var TestimonialsCard = function TestimonialsCard(_ref) {
35
+ var testimonials = _ref.testimonials;
36
+
37
+ var _useState = (0, _react.useState)(0),
38
+ _useState2 = _slicedToArray(_useState, 2),
39
+ current = _useState2[0],
40
+ setCurrent = _useState2[1];
41
+
42
+ return /*#__PURE__*/_react.default.createElement("div", {
43
+ className: "testimonials-card"
44
+ }, /*#__PURE__*/_react.default.createElement(_Card.Card, {
45
+ featured: true
46
+ }, testimonials.length > 1 ? /*#__PURE__*/_react.default.createElement("div", {
47
+ className: "icon-left"
48
+ }, /*#__PURE__*/_react.default.createElement(_muncherUi.Icon, {
49
+ name: "chevron-left",
50
+ size: "large",
51
+ weight: 2,
52
+ onClick: function onClick() {
53
+ setCurrent(current < 1 ? testimonials.length - 1 : current - 1);
54
+ }
55
+ })) : "", /*#__PURE__*/_react.default.createElement("blockquote", null, testimonials[current].testimonial), /*#__PURE__*/_react.default.createElement("i", null, "- ", testimonials[current].tenant, ", former tenant"), testimonials.length > 1 ? /*#__PURE__*/_react.default.createElement("div", {
56
+ className: "icon-right"
57
+ }, /*#__PURE__*/_react.default.createElement(_muncherUi.Icon, {
58
+ name: "chevron-right",
59
+ size: "large",
60
+ weight: 2,
61
+ onClick: function onClick() {
62
+ setCurrent(current === testimonials.length - 1 ? 0 : current + 1);
63
+ }
64
+ })) : ""));
65
+ };
66
+
67
+ exports.TestimonialsCard = TestimonialsCard;
68
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJUZXN0aW1vbmlhbHNDYXJkIiwidGVzdGltb25pYWxzIiwidXNlU3RhdGUiLCJjdXJyZW50Iiwic2V0Q3VycmVudCIsImxlbmd0aCIsInRlc3RpbW9uaWFsIiwidGVuYW50Il0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2Zsb29ycGxhbi9jYXJkL1Rlc3RpbW9uaWFsc0NhcmQudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCwge3VzZVN0YXRlfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCB7SWNvbn0gZnJvbSBcIkBjb250ZW50bXVuY2gvbXVuY2hlci11aVwiO1xuaW1wb3J0IFwiLi9hc3NldHMvVGVzdGltb25pYWxzQ2FyZC5zY3NzXCJcbmltcG9ydCB7Q2FyZH0gZnJvbSBcIi4uLy4uL2NhcmQvQ2FyZFwiO1xuaW1wb3J0IHtUZXN0aW1vbmlhbH0gZnJvbSBcIi4uL2RhdGEvRmxvb3JwbGFuXCI7XG5cbmV4cG9ydCBjb25zdCBUZXN0aW1vbmlhbHNDYXJkOiBSZWFjdC5GQzxUZXN0aW1vbmlhbHNDYXJkUHJvcHM+ID0gKHt0ZXN0aW1vbmlhbHN9KSA9PiB7XG4gICAgY29uc3QgW2N1cnJlbnQsIHNldEN1cnJlbnRdID0gdXNlU3RhdGUoMCk7XG5cbiAgICByZXR1cm4gKFxuICAgICAgICA8ZGl2IGNsYXNzTmFtZT1cInRlc3RpbW9uaWFscy1jYXJkXCI+XG4gICAgICAgICAgICA8Q2FyZCBmZWF0dXJlZD17dHJ1ZX0+XG4gICAgICAgICAgICAgICAge3Rlc3RpbW9uaWFscy5sZW5ndGggPiAxID9cbiAgICAgICAgICAgICAgICAgICAgPGRpdiBjbGFzc05hbWU9XCJpY29uLWxlZnRcIj5cbiAgICAgICAgICAgICAgICAgICAgICAgIDxJY29uIG5hbWU9XCJjaGV2cm9uLWxlZnRcIiBzaXplPVwibGFyZ2VcIiB3ZWlnaHQ9ezJ9IG9uQ2xpY2s9e1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgICgpID0+IHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgc2V0Q3VycmVudChjdXJyZW50IDwgMSA/IHRlc3RpbW9uaWFscy5sZW5ndGggLSAxIDogY3VycmVudCAtIDEpXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgfX0vPlxuICAgICAgICAgICAgICAgICAgICA8L2Rpdj4gOiBcIlwiXG4gICAgICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICAgICAgPGJsb2NrcXVvdGU+XG4gICAgICAgICAgICAgICAgICAgIHt0ZXN0aW1vbmlhbHNbY3VycmVudF0udGVzdGltb25pYWx9XG4gICAgICAgICAgICAgICAgPC9ibG9ja3F1b3RlPlxuICAgICAgICAgICAgICAgIDxpPi0ge3Rlc3RpbW9uaWFsc1tjdXJyZW50XS50ZW5hbnR9LCBmb3JtZXIgdGVuYW50PC9pPlxuICAgICAgICAgICAgICAgIHt0ZXN0aW1vbmlhbHMubGVuZ3RoID4gMSA/XG4gICAgICAgICAgICAgICAgICAgIDxkaXYgY2xhc3NOYW1lPVwiaWNvbi1yaWdodFwiPlxuICAgICAgICAgICAgICAgICAgICAgICAgPEljb24gbmFtZT1cImNoZXZyb24tcmlnaHRcIiBzaXplPVwibGFyZ2VcIiB3ZWlnaHQ9ezJ9IG9uQ2xpY2s9e1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgICgpID0+IHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgc2V0Q3VycmVudChjdXJyZW50ID09PSAodGVzdGltb25pYWxzLmxlbmd0aCAtIDEpID8gMCA6IGN1cnJlbnQgKyAxKVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIH19Lz5cbiAgICAgICAgICAgICAgICAgICAgPC9kaXY+IDogXCJcIlxuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIDwvQ2FyZD5cbiAgICAgICAgPC9kaXY+XG4gICAgKTtcbn07XG5cbmV4cG9ydCBpbnRlcmZhY2UgVGVzdGltb25pYWxzQ2FyZFByb3BzIHtcbiAgICB0ZXN0aW1vbmlhbHM6IFRlc3RpbW9uaWFsW107XG59Il0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7QUFBQTs7QUFDQTs7QUFDQTs7QUFDQTs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBR08sSUFBTUEsZ0JBQWlELEdBQUcsU0FBcERBLGdCQUFvRCxPQUFvQjtFQUFBLElBQWxCQyxZQUFrQixRQUFsQkEsWUFBa0I7O0VBQ2pGLGdCQUE4QixJQUFBQyxlQUFBLEVBQVMsQ0FBVCxDQUE5QjtFQUFBO0VBQUEsSUFBT0MsT0FBUDtFQUFBLElBQWdCQyxVQUFoQjs7RUFFQSxvQkFDSTtJQUFLLFNBQVMsRUFBQztFQUFmLGdCQUNJLDZCQUFDLFVBQUQ7SUFBTSxRQUFRLEVBQUU7RUFBaEIsR0FDS0gsWUFBWSxDQUFDSSxNQUFiLEdBQXNCLENBQXRCLGdCQUNHO0lBQUssU0FBUyxFQUFDO0VBQWYsZ0JBQ0ksNkJBQUMsZUFBRDtJQUFNLElBQUksRUFBQyxjQUFYO0lBQTBCLElBQUksRUFBQyxPQUEvQjtJQUF1QyxNQUFNLEVBQUUsQ0FBL0M7SUFBa0QsT0FBTyxFQUNyRCxtQkFBTTtNQUNGRCxVQUFVLENBQUNELE9BQU8sR0FBRyxDQUFWLEdBQWNGLFlBQVksQ0FBQ0ksTUFBYixHQUFzQixDQUFwQyxHQUF3Q0YsT0FBTyxHQUFHLENBQW5ELENBQVY7SUFDSDtFQUhMLEVBREosQ0FESCxHQU1ZLEVBUGpCLGVBVUksaURBQ0tGLFlBQVksQ0FBQ0UsT0FBRCxDQUFaLENBQXNCRyxXQUQzQixDQVZKLGVBYUksOENBQU1MLFlBQVksQ0FBQ0UsT0FBRCxDQUFaLENBQXNCSSxNQUE1QixvQkFiSixFQWNLTixZQUFZLENBQUNJLE1BQWIsR0FBc0IsQ0FBdEIsZ0JBQ0c7SUFBSyxTQUFTLEVBQUM7RUFBZixnQkFDSSw2QkFBQyxlQUFEO0lBQU0sSUFBSSxFQUFDLGVBQVg7SUFBMkIsSUFBSSxFQUFDLE9BQWhDO0lBQXdDLE1BQU0sRUFBRSxDQUFoRDtJQUFtRCxPQUFPLEVBQ3RELG1CQUFNO01BQ0ZELFVBQVUsQ0FBQ0QsT0FBTyxLQUFNRixZQUFZLENBQUNJLE1BQWIsR0FBc0IsQ0FBbkMsR0FBd0MsQ0FBeEMsR0FBNENGLE9BQU8sR0FBRyxDQUF2RCxDQUFWO0lBQ0g7RUFITCxFQURKLENBREgsR0FNWSxFQXBCakIsQ0FESixDQURKO0FBMkJILENBOUJNIn0=
@@ -0,0 +1,53 @@
1
+ @import 'src/assets/variables';
2
+
3
+ .similar-floorplan-card {
4
+ .card-body {
5
+ padding: 0;
6
+
7
+ }
8
+
9
+ .card-slider-body {
10
+ height: 15rem;
11
+ position: relative;
12
+ background-repeat: no-repeat;
13
+ background-position: center;
14
+ background-size: cover;
15
+
16
+ .icon-left, .icon-right {
17
+ position: absolute;
18
+ top: 40%;
19
+ cursor: pointer;
20
+ color: $primary-background-color;
21
+ }
22
+
23
+ .icon-left:hover, .icon-right:hover {
24
+ opacity: .6;
25
+ }
26
+
27
+ .icon-left {
28
+ left: .1rem;
29
+ }
30
+
31
+ .icon-right {
32
+ right: .1rem;
33
+ }
34
+ }
35
+
36
+ .card-slider-footer {
37
+ padding: 0 2rem 1rem;
38
+ h3 {
39
+ font-size: 1.3rem;
40
+ font-family: $sans-serif-font;
41
+ letter-spacing: .04rem;
42
+ line-height: 2rem;
43
+ font-weight: 400;
44
+ text-transform: capitalize;
45
+ text-align: left;
46
+ }
47
+ p{
48
+ line-height: 1rem;
49
+ }
50
+
51
+ }
52
+
53
+ }
@@ -0,0 +1,65 @@
1
+ @import 'src/assets/variables';
2
+
3
+ .testimonials-card {
4
+ position: relative;
5
+
6
+ .icon-left, .icon-right {
7
+ position: absolute;
8
+ top: 40%;
9
+ cursor: pointer;
10
+ color: $primary-background-color;
11
+ }
12
+
13
+ .icon-left:hover, .icon-right:hover {
14
+ opacity: .6;
15
+ }
16
+
17
+ .icon-left {
18
+ left: 1vw;
19
+ @media (min-width: $large-size) {
20
+ left: .1rem;
21
+ }
22
+ }
23
+
24
+ .icon-right {
25
+ right: 1vw;
26
+ @media (min-width: $large-size) {
27
+ right: .1rem;
28
+ }
29
+ }
30
+
31
+ .card-body--featured {
32
+ text-align: center;
33
+ }
34
+
35
+ .section-card {
36
+ blockquote {
37
+ margin: 2rem;
38
+ font-size: 1.6rem;
39
+ font-style: italic;
40
+ font-family: $serif-font;
41
+ letter-spacing: .04rem;
42
+ line-height: 2rem;
43
+ font-weight: 400;
44
+ }
45
+
46
+ blockquote:before {
47
+ content: open-quote;
48
+
49
+ }
50
+
51
+ blockquote:after {
52
+ content: close-quote;
53
+ }
54
+
55
+ i {
56
+ font-size: 1.2rem;
57
+ font-family: $serif-font;
58
+ letter-spacing: .04rem;
59
+ line-height: 2rem;
60
+ text-align: center;
61
+ font-weight: 300;
62
+ }
63
+ }
64
+
65
+ }
@@ -1,5 +1,4 @@
1
1
  import { Unit, UnitDetails } from "./Unit";
2
- import { PropertyName } from "../../property/data/Property";
3
2
  export declare const defaultMinRent = 100;
4
3
  export declare const defaultMaxRent = 4000;
5
4
  export declare enum FloorplanStyle {
@@ -85,3 +84,42 @@ export interface Floorplan {
85
84
  lastModifiedDate: string;
86
85
  active: boolean;
87
86
  }
87
+ export interface FloorplanSpotlight {
88
+ id: string;
89
+ name: string;
90
+ metaDescription: string;
91
+ bedroom: number;
92
+ bathroom: number;
93
+ style: FloorplanStyle;
94
+ featured: boolean;
95
+ coverImage: string;
96
+ units: UnitSpotlight[];
97
+ active: boolean;
98
+ property: PropertyName;
99
+ }
100
+ export interface UnitSpotlight {
101
+ id: string;
102
+ squareFoot: number;
103
+ rent: number;
104
+ active: boolean;
105
+ }
106
+ export interface PropertyName {
107
+ name: string;
108
+ id: string;
109
+ active: boolean;
110
+ }
111
+ export interface FloorplanName {
112
+ name: string;
113
+ id: string;
114
+ active: boolean;
115
+ }
116
+ export interface SimilarFloorplan {
117
+ similarTo: FloorplanName;
118
+ }
119
+ export interface FloorplanVariation {
120
+ variation: string;
121
+ }
122
+ export interface Testimonial {
123
+ testimonial: string;
124
+ tenant: string;
125
+ }
@@ -40,4 +40,4 @@ exports.UtilityType = UtilityType;
40
40
  UtilityType["RESIDENT_UTILITY"] = "RESIDENT_UTILITY";
41
41
  UtilityType["INCLUDED_UTILITY"] = "INCLUDED_UTILITY";
42
42
  })(UtilityType || (exports.UtilityType = UtilityType = {}));
43
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJkZWZhdWx0TWluUmVudCIsImRlZmF1bHRNYXhSZW50IiwiRmxvb3JwbGFuU3R5bGUiLCJBbWVuaXR5VHlwZSIsIlV0aWxpdHlUeXBlIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2Zsb29ycGxhbi9kYXRhL0Zsb29ycGxhbi50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1VuaXQsIFVuaXREZXRhaWxzfSBmcm9tIFwiLi9Vbml0XCI7XG5pbXBvcnQge1Byb3BlcnR5TmFtZX0gZnJvbSBcIi4uLy4uL3Byb3BlcnR5L2RhdGEvUHJvcGVydHlcIjtcblxuZXhwb3J0IGNvbnN0IGRlZmF1bHRNaW5SZW50ID0gMTAwO1xuZXhwb3J0IGNvbnN0IGRlZmF1bHRNYXhSZW50ID0gNDAwMDtcblxuZXhwb3J0IGVudW0gRmxvb3JwbGFuU3R5bGUge1xuICAgIFNUVURJTyA9IFwiU1RVRElPXCIsXG4gICAgQVBBUlRNRU5UID0gXCJBUEFSVE1FTlRcIixcbiAgICBUT1dOX0hPTUUgPSBcIlRPV05fSE9NRVwiLFxuICAgIFNJTkdMRV9GQU1JTFkgPSBcIlNJTkdMRV9GQU1JTFlcIixcbiAgICBHQVJBR0UgPSBcIkdBUkFHRVwiXG59XG5cbmV4cG9ydCBlbnVtIEFtZW5pdHlUeXBlIHtcbiAgICBLSVRDSEVOID0gXCJLSVRDSEVOXCIsXG4gICAgTElWSU5HX0FORF9CRURST09NID0gXCJMSVZJTkdfQU5EX0JFRFJPT01cIixcbiAgICBCQVRIUk9PTSA9IFwiQkFUSFJPT01cIixcbiAgICBPVVRET09SID0gXCJPVVRET09SXCIsXG4gICAgSEVBVElOR19DT09MSU5HX0FORF9XSVJJTkcgPSBcIkhFQVRJTkdfQ09PTElOR19BTkRfV0lSSU5HXCIsXG4gICAgU01BUlRfTElWSU5HID0gXCJTTUFSVF9MSVZJTkdcIixcbiAgICBQQVJLSU5HID0gXCJQQVJLSU5HXCIsXG4gICAgTk9UX0FQUExJQ0FCTEUgPSBcIk5PVF9BUFBMSUNBQkxFXCJcbn1cblxuZXhwb3J0IGludGVyZmFjZSBBbWVuaXR5TmFtZSB7XG4gICAgaWQ6IHN0cmluZztcbiAgICBuYW1lOiBzdHJpbmc7XG4gICAgZmVhdHVyZWQ6IGJvb2xlYW47XG4gICAgdHlwZTogQW1lbml0eVR5cGU7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVXRpbGl0eU5hbWUge1xuICAgIGlkOiBudW1iZXI7XG4gICAgbmFtZTogc3RyaW5nO1xuICAgIHR5cGU6IFV0aWxpdHlUeXBlO1xuICAgIGF2ZXJhZ2VNb250aGx5QmlsbDogbnVtYmVyO1xufVxuXG5leHBvcnQgZW51bSBVdGlsaXR5VHlwZSB7XG4gICAgUkVTSURFTlRfVVRJTElUWSA9IFwiUkVTSURFTlRfVVRJTElUWVwiLCBJTkNMVURFRF9VVElMSVRZID0gXCJJTkNMVURFRF9VVElMSVRZXCJcbn1cblxuZXhwb3J0IGludGVyZmFjZSBGbG9vcnBsYW5EZXRhaWxzIHtcbiAgICBpZDogc3RyaW5nO1xuICAgIG5hbWU6IHN0cmluZztcbiAgICBiZWRyb29tOiBudW1iZXI7XG4gICAgYmF0aHJvb206IG51bWJlcjtcbiAgICBzdHlsZTogRmxvb3JwbGFuU3R5bGU7XG4gICAgZmVhdHVyZWQ6IGJvb2xlYW47XG4gICAgZ3JlZW5DZXJ0aWZpZWQ6IGJvb2xlYW47XG4gICAgdmlkZW9Ub3VyTGluazogc3RyaW5nIHwgbnVsbDtcbiAgICB0aHJlZVNpeHR5VmlkZW9Ub3VyTGluazogc3RyaW5nIHwgbnVsbDtcbiAgICB2aXJ0dWFsVG91ckxpbms6IHN0cmluZyB8IG51bGw7XG4gICAgcGhvdG86IHN0cmluZyxcbiAgICBjb3ZlckltYWdlOiBzdHJpbmcsXG4gICAgZmxvb3JQbGFuRm9sZGVySWQ6IHN0cmluZztcbiAgICBwaG90b3NGb2xkZXJJZDogc3RyaW5nO1xuICAgIGFtZW5pdGllczogQW1lbml0eU5hbWVbXTtcbiAgICB1bml0czogVW5pdERldGFpbHNbXTtcbiAgICBhY3RpdmU6IGJvb2xlYW47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRmxvb3JwbGFuIHtcbiAgICBpZDogc3RyaW5nO1xuICAgIG5hbWU6IHN0cmluZztcbiAgICBiZWRyb29tOiBudW1iZXI7XG4gICAgYmF0aHJvb206IG51bWJlcjtcbiAgICBzdHlsZTogRmxvb3JwbGFuU3R5bGU7XG4gICAgZmVhdHVyZWQ6IGJvb2xlYW47XG4gICAgcGF0aW9JbmNsdWRlZDogYm9vbGVhbjtcbiAgICBncmVlbkNlcnRpZmllZDogYm9vbGVhbjtcbiAgICB2aWRlb1RvdXJMaW5rOiBzdHJpbmc7XG4gICAgdGhyZWVTaXh0eVZpZGVvVG91ckxpbms6IHN0cmluZztcbiAgICB2aXJ0dWFsVG91ckxpbms6IHN0cmluZztcbiAgICBwaG90bzogc3RyaW5nIHwgbnVsbCxcbiAgICBjb3ZlckltYWdlOiBzdHJpbmcgfCBudWxsLFxuICAgIGZsb29yUGxhbkZvbGRlcklkOiBzdHJpbmc7XG4gICAgcGhvdG9zRm9sZGVySWQ6IHN0cmluZztcbiAgICBkZXNjcmlwdGlvbjogc3RyaW5nO1xuICAgIHZhbml0eUxpbms6IHN0cmluZztcbiAgICBodG1sVGl0bGU6IHN0cmluZztcbiAgICBtZXRhRGVzY3JpcHRpb246IHN0cmluZztcbiAgICBjb252ZXJzaW9uVHJhY2tpbmdJZDE6IHN0cmluZztcbiAgICBjb252ZXJzaW9uVHJhY2tpbmdJZDI6IHN0cmluZztcbiAgICBjdXN0b21Db2RlOiBzdHJpbmc7XG4gICAgdXRpbGl0aWVzOiBVdGlsaXR5TmFtZVtdO1xuICAgIGFtZW5pdGllczogQW1lbml0eU5hbWVbXTtcbiAgICBwcm9wZXJ0eTogUHJvcGVydHlOYW1lO1xuICAgIHVuaXRzOiBVbml0W107XG4gICAgbGFzdE1vZGlmaWVkQnk6IHN0cmluZztcbiAgICBsYXN0TW9kaWZpZWREYXRlOiBzdHJpbmc7XG4gICAgYWN0aXZlOiBib29sZWFuO1xufVxuXG5cbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBR08sSUFBTUEsY0FBYyxHQUFHLEdBQXZCOztBQUNBLElBQU1DLGNBQWMsR0FBRyxJQUF2Qjs7SUFFS0MsYzs7O1dBQUFBLGM7RUFBQUEsYztFQUFBQSxjO0VBQUFBLGM7RUFBQUEsYztFQUFBQSxjO0dBQUFBLGMsOEJBQUFBLGM7O0lBUUFDLFc7OztXQUFBQSxXO0VBQUFBLFc7RUFBQUEsVztFQUFBQSxXO0VBQUFBLFc7RUFBQUEsVztFQUFBQSxXO0VBQUFBLFc7RUFBQUEsVztHQUFBQSxXLDJCQUFBQSxXOztJQXlCQUMsVzs7O1dBQUFBLFc7RUFBQUEsVztFQUFBQSxXO0dBQUFBLFcsMkJBQUFBLFcifQ==
43
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJkZWZhdWx0TWluUmVudCIsImRlZmF1bHRNYXhSZW50IiwiRmxvb3JwbGFuU3R5bGUiLCJBbWVuaXR5VHlwZSIsIlV0aWxpdHlUeXBlIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2Zsb29ycGxhbi9kYXRhL0Zsb29ycGxhbi50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1VuaXQsIFVuaXREZXRhaWxzfSBmcm9tIFwiLi9Vbml0XCI7XG5cbmV4cG9ydCBjb25zdCBkZWZhdWx0TWluUmVudCA9IDEwMDtcbmV4cG9ydCBjb25zdCBkZWZhdWx0TWF4UmVudCA9IDQwMDA7XG5cbmV4cG9ydCBlbnVtIEZsb29ycGxhblN0eWxlIHtcbiAgICBTVFVESU8gPSBcIlNUVURJT1wiLFxuICAgIEFQQVJUTUVOVCA9IFwiQVBBUlRNRU5UXCIsXG4gICAgVE9XTl9IT01FID0gXCJUT1dOX0hPTUVcIixcbiAgICBTSU5HTEVfRkFNSUxZID0gXCJTSU5HTEVfRkFNSUxZXCIsXG4gICAgR0FSQUdFID0gXCJHQVJBR0VcIlxufVxuXG5leHBvcnQgZW51bSBBbWVuaXR5VHlwZSB7XG4gICAgS0lUQ0hFTiA9IFwiS0lUQ0hFTlwiLFxuICAgIExJVklOR19BTkRfQkVEUk9PTSA9IFwiTElWSU5HX0FORF9CRURST09NXCIsXG4gICAgQkFUSFJPT00gPSBcIkJBVEhST09NXCIsXG4gICAgT1VURE9PUiA9IFwiT1VURE9PUlwiLFxuICAgIEhFQVRJTkdfQ09PTElOR19BTkRfV0lSSU5HID0gXCJIRUFUSU5HX0NPT0xJTkdfQU5EX1dJUklOR1wiLFxuICAgIFNNQVJUX0xJVklORyA9IFwiU01BUlRfTElWSU5HXCIsXG4gICAgUEFSS0lORyA9IFwiUEFSS0lOR1wiLFxuICAgIE5PVF9BUFBMSUNBQkxFID0gXCJOT1RfQVBQTElDQUJMRVwiXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQW1lbml0eU5hbWUge1xuICAgIGlkOiBzdHJpbmc7XG4gICAgbmFtZTogc3RyaW5nO1xuICAgIGZlYXR1cmVkOiBib29sZWFuO1xuICAgIHR5cGU6IEFtZW5pdHlUeXBlO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFV0aWxpdHlOYW1lIHtcbiAgICBpZDogbnVtYmVyO1xuICAgIG5hbWU6IHN0cmluZztcbiAgICB0eXBlOiBVdGlsaXR5VHlwZTtcbiAgICBhdmVyYWdlTW9udGhseUJpbGw6IG51bWJlcjtcbn1cblxuZXhwb3J0IGVudW0gVXRpbGl0eVR5cGUge1xuICAgIFJFU0lERU5UX1VUSUxJVFkgPSBcIlJFU0lERU5UX1VUSUxJVFlcIiwgSU5DTFVERURfVVRJTElUWSA9IFwiSU5DTFVERURfVVRJTElUWVwiXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRmxvb3JwbGFuRGV0YWlscyB7XG4gICAgaWQ6IHN0cmluZztcbiAgICBuYW1lOiBzdHJpbmc7XG4gICAgYmVkcm9vbTogbnVtYmVyO1xuICAgIGJhdGhyb29tOiBudW1iZXI7XG4gICAgc3R5bGU6IEZsb29ycGxhblN0eWxlO1xuICAgIGZlYXR1cmVkOiBib29sZWFuO1xuICAgIGdyZWVuQ2VydGlmaWVkOiBib29sZWFuO1xuICAgIHZpZGVvVG91ckxpbms6IHN0cmluZyB8IG51bGw7XG4gICAgdGhyZWVTaXh0eVZpZGVvVG91ckxpbms6IHN0cmluZyB8IG51bGw7XG4gICAgdmlydHVhbFRvdXJMaW5rOiBzdHJpbmcgfCBudWxsO1xuICAgIHBob3RvOiBzdHJpbmcsXG4gICAgY292ZXJJbWFnZTogc3RyaW5nLFxuICAgIGZsb29yUGxhbkZvbGRlcklkOiBzdHJpbmc7XG4gICAgcGhvdG9zRm9sZGVySWQ6IHN0cmluZztcbiAgICBhbWVuaXRpZXM6IEFtZW5pdHlOYW1lW107XG4gICAgdW5pdHM6IFVuaXREZXRhaWxzW107XG4gICAgYWN0aXZlOiBib29sZWFuO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEZsb29ycGxhbiB7XG4gICAgaWQ6IHN0cmluZztcbiAgICBuYW1lOiBzdHJpbmc7XG4gICAgYmVkcm9vbTogbnVtYmVyO1xuICAgIGJhdGhyb29tOiBudW1iZXI7XG4gICAgc3R5bGU6IEZsb29ycGxhblN0eWxlO1xuICAgIGZlYXR1cmVkOiBib29sZWFuO1xuICAgIHBhdGlvSW5jbHVkZWQ6IGJvb2xlYW47XG4gICAgZ3JlZW5DZXJ0aWZpZWQ6IGJvb2xlYW47XG4gICAgdmlkZW9Ub3VyTGluazogc3RyaW5nO1xuICAgIHRocmVlU2l4dHlWaWRlb1RvdXJMaW5rOiBzdHJpbmc7XG4gICAgdmlydHVhbFRvdXJMaW5rOiBzdHJpbmc7XG4gICAgcGhvdG86IHN0cmluZyB8IG51bGwsXG4gICAgY292ZXJJbWFnZTogc3RyaW5nIHwgbnVsbCxcbiAgICBmbG9vclBsYW5Gb2xkZXJJZDogc3RyaW5nO1xuICAgIHBob3Rvc0ZvbGRlcklkOiBzdHJpbmc7XG4gICAgZGVzY3JpcHRpb246IHN0cmluZztcbiAgICB2YW5pdHlMaW5rOiBzdHJpbmc7XG4gICAgaHRtbFRpdGxlOiBzdHJpbmc7XG4gICAgbWV0YURlc2NyaXB0aW9uOiBzdHJpbmc7XG4gICAgY29udmVyc2lvblRyYWNraW5nSWQxOiBzdHJpbmc7XG4gICAgY29udmVyc2lvblRyYWNraW5nSWQyOiBzdHJpbmc7XG4gICAgY3VzdG9tQ29kZTogc3RyaW5nO1xuICAgIHV0aWxpdGllczogVXRpbGl0eU5hbWVbXTtcbiAgICBhbWVuaXRpZXM6IEFtZW5pdHlOYW1lW107XG4gICAgcHJvcGVydHk6IFByb3BlcnR5TmFtZTtcbiAgICB1bml0czogVW5pdFtdO1xuICAgIGxhc3RNb2RpZmllZEJ5OiBzdHJpbmc7XG4gICAgbGFzdE1vZGlmaWVkRGF0ZTogc3RyaW5nO1xuICAgIGFjdGl2ZTogYm9vbGVhbjtcbn1cblxuXG5leHBvcnQgaW50ZXJmYWNlIEZsb29ycGxhblNwb3RsaWdodCB7XG4gICAgaWQ6IHN0cmluZztcbiAgICBuYW1lOiBzdHJpbmc7XG4gICAgbWV0YURlc2NyaXB0aW9uOiBzdHJpbmc7XG4gICAgYmVkcm9vbTogbnVtYmVyO1xuICAgIGJhdGhyb29tOiBudW1iZXI7XG4gICAgc3R5bGU6IEZsb29ycGxhblN0eWxlO1xuICAgIGZlYXR1cmVkOiBib29sZWFuO1xuICAgIGNvdmVySW1hZ2U6IHN0cmluZztcbiAgICB1bml0czogVW5pdFNwb3RsaWdodFtdO1xuICAgIGFjdGl2ZTogYm9vbGVhbjtcbiAgICBwcm9wZXJ0eTogUHJvcGVydHlOYW1lO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFVuaXRTcG90bGlnaHQge1xuICAgIGlkOiBzdHJpbmc7XG4gICAgc3F1YXJlRm9vdDogbnVtYmVyO1xuICAgIHJlbnQ6IG51bWJlcjtcbiAgICBhY3RpdmU6IGJvb2xlYW47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgUHJvcGVydHlOYW1lIHtcbiAgICBuYW1lOiBzdHJpbmc7XG4gICAgaWQ6IHN0cmluZztcbiAgICBhY3RpdmU6IGJvb2xlYW47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRmxvb3JwbGFuTmFtZSB7XG4gICAgbmFtZTogc3RyaW5nO1xuICAgIGlkOiBzdHJpbmc7XG4gICAgYWN0aXZlOiBib29sZWFuO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFNpbWlsYXJGbG9vcnBsYW4ge1xuICAgIHNpbWlsYXJUbzogRmxvb3JwbGFuTmFtZTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBGbG9vcnBsYW5WYXJpYXRpb24ge1xuICAgIHZhcmlhdGlvbjogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFRlc3RpbW9uaWFsIHtcbiAgICB0ZXN0aW1vbmlhbDogc3RyaW5nO1xuICAgIHRlbmFudDogc3RyaW5nO1xufSJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBRU8sSUFBTUEsY0FBYyxHQUFHLEdBQXZCOztBQUNBLElBQU1DLGNBQWMsR0FBRyxJQUF2Qjs7SUFFS0MsYzs7O1dBQUFBLGM7RUFBQUEsYztFQUFBQSxjO0VBQUFBLGM7RUFBQUEsYztFQUFBQSxjO0dBQUFBLGMsOEJBQUFBLGM7O0lBUUFDLFc7OztXQUFBQSxXO0VBQUFBLFc7RUFBQUEsVztFQUFBQSxXO0VBQUFBLFc7RUFBQUEsVztFQUFBQSxXO0VBQUFBLFc7RUFBQUEsVztHQUFBQSxXLDJCQUFBQSxXOztJQXlCQUMsVzs7O1dBQUFBLFc7RUFBQUEsVztFQUFBQSxXO0dBQUFBLFcsMkJBQUFBLFcifQ==
@@ -0,0 +1,9 @@
1
+ import React from "react";
2
+ import "./assets/FloorplanHero.scss";
3
+ import { Floorplan } from "../data/Floorplan";
4
+ export declare const FloorplanHero: React.FC<FloorplanProps>;
5
+ export interface FloorplanProps {
6
+ floorplan: Floorplan;
7
+ contactClickHandler: () => void;
8
+ applyClickHandler: () => void;
9
+ }