@renaissancerentals/renaissance-component 12.1.30 → 12.1.31

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.
@@ -112,10 +112,13 @@ const FloorplanCard = _ref => {
112
112
  }, /*#__PURE__*/_react.default.createElement("h3", {
113
113
  className: "truncate"
114
114
  }, floorplan.name), /*#__PURE__*/_react.default.createElement("p", null, /*#__PURE__*/_react.default.createElement(_FloorplanPrice.FloorplanPrice, {
115
- floorplan: floorplan
115
+ unitRents: floorplan.units,
116
+ specialRent: floorplan.specialRent,
117
+ specialRentEndDate: floorplan.specialRentEndDate,
118
+ specialRentStartDate: floorplan.specialRentStartDate
116
119
  }))), /*#__PURE__*/_react.default.createElement("div", {
117
120
  className: "right"
118
121
  }, /*#__PURE__*/_react.default.createElement("p", null, floorplan.bedroom, " bed, ", floorplan.bathroom, " bath"), /*#__PURE__*/_react.default.createElement("p", null, floorplan.units.length > 0 ? /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, (0, _Utils.rangeFrom)(floorplan.units, "squareFoot"), " sq. ft.") : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, "\xA0")))))));
119
122
  };
120
123
  exports.FloorplanCard = FloorplanCard;
121
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_icon","_interopRequireDefault","_videoIcon","_muncherUi","_AssetService","_AssetApi","_Utils","_FloorplanService","_FloorplanPrice","_SpecialOfferButton","obj","__esModule","default","_getRequireWildcardCache","e","WeakMap","r","t","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","prototype","hasOwnProperty","call","i","set","FloorplanCard","_ref","floorplan","size","videoClickHandler","propertyId","assets","setAssets","useState","isAssetLoading","setIsAssetLoading","isAssetLoaded","setIsAssetLoaded","showSpecialOffer","setShowSpecialOffer","loadAssets","photosFolderId","getAssetsFrom","then","data","catch","console","log","finally","createElement","className","length","ItemSlider","navButtonSize","sliderItems","map","asset","alt","src","assetUrlFrom","id","coverImage","getAssetUrl","DEFAULT_IMAGE_URL","NavigateButton","direction","onClick","Spinner","Fragment","featured","isFloorplanAvailable","Badge","webSpecials","SpecialOfferButton","onMouseEnter","onMouseLeave","virtualTourLink","Button","variant","url","type","tourIcon","height","videoTourLink","videoIcon","href","title","name","FloorplanPrice","bedroom","bathroom","units","rangeFrom","exports"],"sources":["../../../src/floorplan/card/FloorplanCard.tsx"],"sourcesContent":["import React, {useState} from \"react\";\nimport \"./assets/FloorplanCard.scss\";\nimport tourIcon from \"./assets/360-icon.png\";\nimport videoIcon from \"./assets/video-icon.png\";\nimport {Badge, Button, ItemSlider, NavigateButton, Spinner} from \"@contentmunch/muncher-ui\";\nimport {assetUrlFrom, getAssetsFrom, getAssetUrl} from \"../../asset/service/AssetService\";\nimport {FloorplanCardData} from \"../data/Floorplan\";\nimport {DEFAULT_IMAGE_URL} from \"../../service/AssetApi\";\nimport {rangeFrom} from \"../../utils/Utils\";\nimport {Asset, Video} from \"../../asset/data/Asset\";\nimport {isFloorplanAvailable} from \"../service/FloorplanService\";\nimport {FloorplanPrice} from \"./FloorplanPrice\";\nimport {SpecialOfferButton} from \"../../specialOffer/SpecialOfferButton\";\n\nexport const FloorplanCard: React.FC<FloorplanCardProps> = ({floorplan, size, videoClickHandler, propertyId}) => {\n    const [assets, setAssets] = useState<Asset[]>([]);\n    const [isAssetLoading, setIsAssetLoading] = useState(false);\n    const [isAssetLoaded, setIsAssetLoaded] = useState(false);\n    const [showSpecialOffer, setShowSpecialOffer] = useState(false);\n\n    const loadAssets = () => {\n\n        if (floorplan.photosFolderId) {\n            getAssetsFrom(floorplan.photosFolderId).then(data => {\n                setAssets(data);\n            }).catch(() => {\n                console.log(\"invalid folderId\");\n            }).finally(() => {\n                setIsAssetLoaded(true);\n                setIsAssetLoading(false);\n            });\n        } else {\n            setIsAssetLoaded(true);\n            setIsAssetLoading(false);\n        }\n    };\n\n\n    return (\n        <div className={size === \"small\" ? \"floorplan-card floorplan-card--small\" : \"floorplan-card\"}>\n\n            {isAssetLoaded && assets.length > 0 ?\n                <ItemSlider navButtonSize=\"medium\"\n                            sliderItems={assets.map(asset => <img\n                                className=\"card--image\"\n                                alt=\"card\"\n                                src={assetUrlFrom(asset.id, propertyId)}/>)}/> :\n                <img className=\"card--image\" alt=\"cover\"\n                     src={floorplan.coverImage ? getAssetUrl(floorplan.coverImage, propertyId) : DEFAULT_IMAGE_URL}/>}\n            {isAssetLoaded ? \"\" : <NavigateButton direction=\"right\" onClick={loadAssets} size=\"medium\"/>}\n\n\n            {isAssetLoading ? <Spinner size=\"medium\"/> : <></>}\n            <div className=\"badges--right\">\n                {\n                    floorplan.featured ? (isFloorplanAvailable(floorplan) ? <Badge>Featured & Available Now</Badge> :\n                        <Badge>Featured</Badge>) : isFloorplanAvailable(floorplan) ? <Badge>Available Now</Badge> : ''\n                }\n                {\n                    floorplan.webSpecials.length > 0 ?\n                        <SpecialOfferButton onMouseEnter={() => setShowSpecialOffer(true)}\n                                            onMouseLeave={() => setShowSpecialOffer(false)}/> : <></>\n                }\n            </div>\n            <div className=\"badges--left\">\n                {floorplan.virtualTourLink ?\n                    <div className=\"icon-tour\">\n                        <Button variant=\"transparent\" size=\"small\"\n                                onClick={() => videoClickHandler({\n                                    url: floorplan.virtualTourLink,\n                                    type: \"virtual\"\n                                })}>\n                            <img src={tourIcon} alt=\"tour icon\" height={30}/>\n                        </Button>\n\n                    </div>\n                    : ''}\n                {floorplan.videoTourLink ?\n                    <div className=\"icon-video\">\n                        <Button variant=\"transparent\" size=\"small\"\n                                onClick={() => videoClickHandler({url: floorplan.videoTourLink, type: \"video\"})}>\n                            <img src={videoIcon} alt=\"video icon\" height={20}/>\n                        </Button>\n                    </div>\n                    : ''}\n            </div>\n\n\n            <a href={\"/floorplans/\" + floorplan.id}\n               title={floorplan.name}>\n                <div className=\"floorplan-card-content\">\n                    <div className=\"floorplan-card-content--special\">\n                        {showSpecialOffer && floorplan.webSpecials.length > 0 ?\n                            <div className=\"content--special\">\n                                <p>{floorplan.webSpecials[0]}</p>\n                            </div> : <></>}\n                    </div>\n                    <div className=\"floorplan-card-footer\">\n                        <div className=\"left\">\n                            <h3 className=\"truncate\">\n                                {floorplan.name}\n                            </h3>\n                            <p>\n                                <FloorplanPrice floorplan={floorplan}/>\n                            </p>\n                        </div>\n                        <div className=\"right\">\n                            <p>{floorplan.bedroom} bed, {floorplan.bathroom} bath</p>\n                            <p>{floorplan.units.length > 0 ? <>{rangeFrom(floorplan.units, \"squareFoot\")} sq.\n                                ft.</> : <>&nbsp;</>}</p>\n                        </div>\n                    </div>\n                </div>\n\n            </a>\n        </div>\n    );\n}\n\nexport interface FloorplanCardProps {\n    floorplan: FloorplanCardData;\n    size?: \"small\" | \"large\"\n    videoClickHandler: (video: Video) => void;\n    propertyId: string;\n}\n\n"],"mappings":";;;;;;AAAA,IAAAA,MAAA,GAAAC,uBAAA,CAAAC,OAAA;AACAA,OAAA;AACA,IAAAC,KAAA,GAAAC,sBAAA,CAAAF,OAAA;AACA,IAAAG,UAAA,GAAAD,sBAAA,CAAAF,OAAA;AACA,IAAAI,UAAA,GAAAJ,OAAA;AACA,IAAAK,aAAA,GAAAL,OAAA;AAEA,IAAAM,SAAA,GAAAN,OAAA;AACA,IAAAO,MAAA,GAAAP,OAAA;AAEA,IAAAQ,iBAAA,GAAAR,OAAA;AACA,IAAAS,eAAA,GAAAT,OAAA;AACA,IAAAU,mBAAA,GAAAV,OAAA;AAAyE,SAAAE,uBAAAS,GAAA,WAAAA,GAAA,IAAAA,GAAA,CAAAC,UAAA,GAAAD,GAAA,KAAAE,OAAA,EAAAF,GAAA;AAAA,SAAAG,yBAAAC,CAAA,6BAAAC,OAAA,mBAAAC,CAAA,OAAAD,OAAA,IAAAE,CAAA,OAAAF,OAAA,YAAAF,wBAAA,YAAAA,CAAAC,CAAA,WAAAA,CAAA,GAAAG,CAAA,GAAAD,CAAA,KAAAF,CAAA;AAAA,SAAAhB,wBAAAgB,CAAA,EAAAE,CAAA,SAAAA,CAAA,IAAAF,CAAA,IAAAA,CAAA,CAAAH,UAAA,SAAAG,CAAA,eAAAA,CAAA,uBAAAA,CAAA,yBAAAA,CAAA,WAAAF,OAAA,EAAAE,CAAA,QAAAG,CAAA,GAAAJ,wBAAA,CAAAG,CAAA,OAAAC,CAAA,IAAAA,CAAA,CAAAC,GAAA,CAAAJ,CAAA,UAAAG,CAAA,CAAAE,GAAA,CAAAL,CAAA,OAAAM,CAAA,KAAAC,SAAA,UAAAC,CAAA,GAAAC,MAAA,CAAAC,cAAA,IAAAD,MAAA,CAAAE,wBAAA,WAAAC,CAAA,IAAAZ,CAAA,oBAAAY,CAAA,IAAAH,MAAA,CAAAI,SAAA,CAAAC,cAAA,CAAAC,IAAA,CAAAf,CAAA,EAAAY,CAAA,SAAAI,CAAA,GAAAR,CAAA,GAAAC,MAAA,CAAAE,wBAAA,CAAAX,CAAA,EAAAY,CAAA,UAAAI,CAAA,KAAAA,CAAA,CAAAX,GAAA,IAAAW,CAAA,CAAAC,GAAA,IAAAR,MAAA,CAAAC,cAAA,CAAAJ,CAAA,EAAAM,CAAA,EAAAI,CAAA,IAAAV,CAAA,CAAAM,CAAA,IAAAZ,CAAA,CAAAY,CAAA,YAAAN,CAAA,CAAAR,OAAA,GAAAE,CAAA,EAAAG,CAAA,IAAAA,CAAA,CAAAc,GAAA,CAAAjB,CAAA,EAAAM,CAAA,GAAAA,CAAA;AAElE,MAAMY,aAA2C,GAAGC,IAAA,IAAsD;EAAA,IAArD;IAACC,SAAS;IAAEC,IAAI;IAAEC,iBAAiB;IAAEC;EAAU,CAAC,GAAAJ,IAAA;EACxG,MAAM,CAACK,MAAM,EAAEC,SAAS,CAAC,GAAG,IAAAC,eAAQ,EAAU,EAAE,CAAC;EACjD,MAAM,CAACC,cAAc,EAAEC,iBAAiB,CAAC,GAAG,IAAAF,eAAQ,EAAC,KAAK,CAAC;EAC3D,MAAM,CAACG,aAAa,EAAEC,gBAAgB,CAAC,GAAG,IAAAJ,eAAQ,EAAC,KAAK,CAAC;EACzD,MAAM,CAACK,gBAAgB,EAAEC,mBAAmB,CAAC,GAAG,IAAAN,eAAQ,EAAC,KAAK,CAAC;EAE/D,MAAMO,UAAU,GAAGA,CAAA,KAAM;IAErB,IAAIb,SAAS,CAACc,cAAc,EAAE;MAC1B,IAAAC,2BAAa,EAACf,SAAS,CAACc,cAAc,CAAC,CAACE,IAAI,CAACC,IAAI,IAAI;QACjDZ,SAAS,CAACY,IAAI,CAAC;MACnB,CAAC,CAAC,CAACC,KAAK,CAAC,MAAM;QACXC,OAAO,CAACC,GAAG,CAAC,kBAAkB,CAAC;MACnC,CAAC,CAAC,CAACC,OAAO,CAAC,MAAM;QACbX,gBAAgB,CAAC,IAAI,CAAC;QACtBF,iBAAiB,CAAC,KAAK,CAAC;MAC5B,CAAC,CAAC;IACN,CAAC,MAAM;MACHE,gBAAgB,CAAC,IAAI,CAAC;MACtBF,iBAAiB,CAAC,KAAK,CAAC;IAC5B;EACJ,CAAC;EAGD,oBACI7C,MAAA,CAAAe,OAAA,CAAA4C,aAAA;IAAKC,SAAS,EAAEtB,IAAI,KAAK,OAAO,GAAG,sCAAsC,GAAG;EAAiB,GAExFQ,aAAa,IAAIL,MAAM,CAACoB,MAAM,GAAG,CAAC,gBAC/B7D,MAAA,CAAAe,OAAA,CAAA4C,aAAA,CAACrD,UAAA,CAAAwD,UAAU;IAACC,aAAa,EAAC,QAAQ;IACtBC,WAAW,EAAEvB,MAAM,CAACwB,GAAG,CAACC,KAAK,iBAAIlE,MAAA,CAAAe,OAAA,CAAA4C,aAAA;MAC7BC,SAAS,EAAC,aAAa;MACvBO,GAAG,EAAC,MAAM;MACVC,GAAG,EAAE,IAAAC,0BAAY,EAACH,KAAK,CAACI,EAAE,EAAE9B,UAAU;IAAE,CAAC,CAAC;EAAE,CAAC,CAAC,gBAC9DxC,MAAA,CAAAe,OAAA,CAAA4C,aAAA;IAAKC,SAAS,EAAC,aAAa;IAACO,GAAG,EAAC,OAAO;IACnCC,GAAG,EAAE/B,SAAS,CAACkC,UAAU,GAAG,IAAAC,yBAAW,EAACnC,SAAS,CAACkC,UAAU,EAAE/B,UAAU,CAAC,GAAGiC;EAAkB,CAAC,CAAC,EACxG3B,aAAa,GAAG,EAAE,gBAAG9C,MAAA,CAAAe,OAAA,CAAA4C,aAAA,CAACrD,UAAA,CAAAoE,cAAc;IAACC,SAAS,EAAC,OAAO;IAACC,OAAO,EAAE1B,UAAW;IAACZ,IAAI,EAAC;EAAQ,CAAC,CAAC,EAG3FM,cAAc,gBAAG5C,MAAA,CAAAe,OAAA,CAAA4C,aAAA,CAACrD,UAAA,CAAAuE,OAAO;IAACvC,IAAI,EAAC;EAAQ,CAAC,CAAC,gBAAGtC,MAAA,CAAAe,OAAA,CAAA4C,aAAA,CAAA3D,MAAA,CAAAe,OAAA,CAAA+D,QAAA,MAAI,CAAC,eAClD9E,MAAA,CAAAe,OAAA,CAAA4C,aAAA;IAAKC,SAAS,EAAC;EAAe,GAEtBvB,SAAS,CAAC0C,QAAQ,GAAI,IAAAC,sCAAoB,EAAC3C,SAAS,CAAC,gBAAGrC,MAAA,CAAAe,OAAA,CAAA4C,aAAA,CAACrD,UAAA,CAAA2E,KAAK,QAAC,0BAA+B,CAAC,gBAC3FjF,MAAA,CAAAe,OAAA,CAAA4C,aAAA,CAACrD,UAAA,CAAA2E,KAAK,QAAC,UAAe,CAAC,GAAI,IAAAD,sCAAoB,EAAC3C,SAAS,CAAC,gBAAGrC,MAAA,CAAAe,OAAA,CAAA4C,aAAA,CAACrD,UAAA,CAAA2E,KAAK,QAAC,eAAoB,CAAC,GAAG,EAAE,EAGlG5C,SAAS,CAAC6C,WAAW,CAACrB,MAAM,GAAG,CAAC,gBAC5B7D,MAAA,CAAAe,OAAA,CAAA4C,aAAA,CAAC/C,mBAAA,CAAAuE,kBAAkB;IAACC,YAAY,EAAEA,CAAA,KAAMnC,mBAAmB,CAAC,IAAI,CAAE;IAC9CoC,YAAY,EAAEA,CAAA,KAAMpC,mBAAmB,CAAC,KAAK;EAAE,CAAC,CAAC,gBAAGjD,MAAA,CAAAe,OAAA,CAAA4C,aAAA,CAAA3D,MAAA,CAAAe,OAAA,CAAA+D,QAAA,MAAI,CAEnF,CAAC,eACN9E,MAAA,CAAAe,OAAA,CAAA4C,aAAA;IAAKC,SAAS,EAAC;EAAc,GACxBvB,SAAS,CAACiD,eAAe,gBACtBtF,MAAA,CAAAe,OAAA,CAAA4C,aAAA;IAAKC,SAAS,EAAC;EAAW,gBACtB5D,MAAA,CAAAe,OAAA,CAAA4C,aAAA,CAACrD,UAAA,CAAAiF,MAAM;IAACC,OAAO,EAAC,aAAa;IAAClD,IAAI,EAAC,OAAO;IAClCsC,OAAO,EAAEA,CAAA,KAAMrC,iBAAiB,CAAC;MAC7BkD,GAAG,EAAEpD,SAAS,CAACiD,eAAe;MAC9BI,IAAI,EAAE;IACV,CAAC;EAAE,gBACP1F,MAAA,CAAAe,OAAA,CAAA4C,aAAA;IAAKS,GAAG,EAAEuB,aAAS;IAACxB,GAAG,EAAC,WAAW;IAACyB,MAAM,EAAE;EAAG,CAAC,CAC5C,CAEP,CAAC,GACJ,EAAE,EACPvD,SAAS,CAACwD,aAAa,gBACpB7F,MAAA,CAAAe,OAAA,CAAA4C,aAAA;IAAKC,SAAS,EAAC;EAAY,gBACvB5D,MAAA,CAAAe,OAAA,CAAA4C,aAAA,CAACrD,UAAA,CAAAiF,MAAM;IAACC,OAAO,EAAC,aAAa;IAAClD,IAAI,EAAC,OAAO;IAClCsC,OAAO,EAAEA,CAAA,KAAMrC,iBAAiB,CAAC;MAACkD,GAAG,EAAEpD,SAAS,CAACwD,aAAa;MAAEH,IAAI,EAAE;IAAO,CAAC;EAAE,gBACpF1F,MAAA,CAAAe,OAAA,CAAA4C,aAAA;IAAKS,GAAG,EAAE0B,kBAAU;IAAC3B,GAAG,EAAC,YAAY;IAACyB,MAAM,EAAE;EAAG,CAAC,CAC9C,CACP,CAAC,GACJ,EACL,CAAC,eAGN5F,MAAA,CAAAe,OAAA,CAAA4C,aAAA;IAAGoC,IAAI,EAAE,cAAc,GAAG1D,SAAS,CAACiC,EAAG;IACpC0B,KAAK,EAAE3D,SAAS,CAAC4D;EAAK,gBACrBjG,MAAA,CAAAe,OAAA,CAAA4C,aAAA;IAAKC,SAAS,EAAC;EAAwB,gBACnC5D,MAAA,CAAAe,OAAA,CAAA4C,aAAA;IAAKC,SAAS,EAAC;EAAiC,GAC3CZ,gBAAgB,IAAIX,SAAS,CAAC6C,WAAW,CAACrB,MAAM,GAAG,CAAC,gBACjD7D,MAAA,CAAAe,OAAA,CAAA4C,aAAA;IAAKC,SAAS,EAAC;EAAkB,gBAC7B5D,MAAA,CAAAe,OAAA,CAAA4C,aAAA,YAAItB,SAAS,CAAC6C,WAAW,CAAC,CAAC,CAAK,CAC/B,CAAC,gBAAGlF,MAAA,CAAAe,OAAA,CAAA4C,aAAA,CAAA3D,MAAA,CAAAe,OAAA,CAAA+D,QAAA,MAAI,CAChB,CAAC,eACN9E,MAAA,CAAAe,OAAA,CAAA4C,aAAA;IAAKC,SAAS,EAAC;EAAuB,gBAClC5D,MAAA,CAAAe,OAAA,CAAA4C,aAAA;IAAKC,SAAS,EAAC;EAAM,gBACjB5D,MAAA,CAAAe,OAAA,CAAA4C,aAAA;IAAIC,SAAS,EAAC;EAAU,GACnBvB,SAAS,CAAC4D,IACX,CAAC,eACLjG,MAAA,CAAAe,OAAA,CAAA4C,aAAA,yBACI3D,MAAA,CAAAe,OAAA,CAAA4C,aAAA,CAAChD,eAAA,CAAAuF,cAAc;IAAC7D,SAAS,EAAEA;EAAU,CAAC,CACvC,CACF,CAAC,eACNrC,MAAA,CAAAe,OAAA,CAAA4C,aAAA;IAAKC,SAAS,EAAC;EAAO,gBAClB5D,MAAA,CAAAe,OAAA,CAAA4C,aAAA,YAAItB,SAAS,CAAC8D,OAAO,EAAC,QAAM,EAAC9D,SAAS,CAAC+D,QAAQ,EAAC,OAAQ,CAAC,eACzDpG,MAAA,CAAAe,OAAA,CAAA4C,aAAA,YAAItB,SAAS,CAACgE,KAAK,CAACxC,MAAM,GAAG,CAAC,gBAAG7D,MAAA,CAAAe,OAAA,CAAA4C,aAAA,CAAA3D,MAAA,CAAAe,OAAA,CAAA+D,QAAA,QAAG,IAAAwB,gBAAS,EAACjE,SAAS,CAACgE,KAAK,EAAE,YAAY,CAAC,EAAC,UACpE,CAAC,gBAAGrG,MAAA,CAAAe,OAAA,CAAA4C,aAAA,CAAA3D,MAAA,CAAAe,OAAA,CAAA+D,QAAA,QAAE,MAAQ,CAAK,CAC3B,CACJ,CACJ,CAEN,CACF,CAAC;AAEd,CAAC;AAAAyB,OAAA,CAAApE,aAAA,GAAAA,aAAA"}
124
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_icon","_interopRequireDefault","_videoIcon","_muncherUi","_AssetService","_AssetApi","_Utils","_FloorplanService","_FloorplanPrice","_SpecialOfferButton","obj","__esModule","default","_getRequireWildcardCache","e","WeakMap","r","t","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","prototype","hasOwnProperty","call","i","set","FloorplanCard","_ref","floorplan","size","videoClickHandler","propertyId","assets","setAssets","useState","isAssetLoading","setIsAssetLoading","isAssetLoaded","setIsAssetLoaded","showSpecialOffer","setShowSpecialOffer","loadAssets","photosFolderId","getAssetsFrom","then","data","catch","console","log","finally","createElement","className","length","ItemSlider","navButtonSize","sliderItems","map","asset","alt","src","assetUrlFrom","id","coverImage","getAssetUrl","DEFAULT_IMAGE_URL","NavigateButton","direction","onClick","Spinner","Fragment","featured","isFloorplanAvailable","Badge","webSpecials","SpecialOfferButton","onMouseEnter","onMouseLeave","virtualTourLink","Button","variant","url","type","tourIcon","height","videoTourLink","videoIcon","href","title","name","FloorplanPrice","unitRents","units","specialRent","specialRentEndDate","specialRentStartDate","bedroom","bathroom","rangeFrom","exports"],"sources":["../../../src/floorplan/card/FloorplanCard.tsx"],"sourcesContent":["import React, {useState} from \"react\";\nimport \"./assets/FloorplanCard.scss\";\nimport tourIcon from \"./assets/360-icon.png\";\nimport videoIcon from \"./assets/video-icon.png\";\nimport {Badge, Button, ItemSlider, NavigateButton, Spinner} from \"@contentmunch/muncher-ui\";\nimport {assetUrlFrom, getAssetsFrom, getAssetUrl} from \"../../asset/service/AssetService\";\nimport {FloorplanCardData} from \"../data/Floorplan\";\nimport {DEFAULT_IMAGE_URL} from \"../../service/AssetApi\";\nimport {rangeFrom} from \"../../utils/Utils\";\nimport {Asset, Video} from \"../../asset/data/Asset\";\nimport {isFloorplanAvailable} from \"../service/FloorplanService\";\nimport {FloorplanPrice} from \"./FloorplanPrice\";\nimport {SpecialOfferButton} from \"../../specialOffer/SpecialOfferButton\";\n\nexport const FloorplanCard: React.FC<FloorplanCardProps> = ({floorplan, size, videoClickHandler, propertyId}) => {\n    const [assets, setAssets] = useState<Asset[]>([]);\n    const [isAssetLoading, setIsAssetLoading] = useState(false);\n    const [isAssetLoaded, setIsAssetLoaded] = useState(false);\n    const [showSpecialOffer, setShowSpecialOffer] = useState(false);\n\n    const loadAssets = () => {\n\n        if (floorplan.photosFolderId) {\n            getAssetsFrom(floorplan.photosFolderId).then(data => {\n                setAssets(data);\n            }).catch(() => {\n                console.log(\"invalid folderId\");\n            }).finally(() => {\n                setIsAssetLoaded(true);\n                setIsAssetLoading(false);\n            });\n        } else {\n            setIsAssetLoaded(true);\n            setIsAssetLoading(false);\n        }\n    };\n\n\n    return (\n        <div className={size === \"small\" ? \"floorplan-card floorplan-card--small\" : \"floorplan-card\"}>\n\n            {isAssetLoaded && assets.length > 0 ?\n                <ItemSlider navButtonSize=\"medium\"\n                            sliderItems={assets.map(asset => <img\n                                className=\"card--image\"\n                                alt=\"card\"\n                                src={assetUrlFrom(asset.id, propertyId)}/>)}/> :\n                <img className=\"card--image\" alt=\"cover\"\n                     src={floorplan.coverImage ? getAssetUrl(floorplan.coverImage, propertyId) : DEFAULT_IMAGE_URL}/>}\n            {isAssetLoaded ? \"\" : <NavigateButton direction=\"right\" onClick={loadAssets} size=\"medium\"/>}\n\n\n            {isAssetLoading ? <Spinner size=\"medium\"/> : <></>}\n            <div className=\"badges--right\">\n                {\n                    floorplan.featured ? (isFloorplanAvailable(floorplan) ? <Badge>Featured & Available Now</Badge> :\n                        <Badge>Featured</Badge>) : isFloorplanAvailable(floorplan) ? <Badge>Available Now</Badge> : ''\n                }\n                {\n                    floorplan.webSpecials.length > 0 ?\n                        <SpecialOfferButton onMouseEnter={() => setShowSpecialOffer(true)}\n                                            onMouseLeave={() => setShowSpecialOffer(false)}/> : <></>\n                }\n            </div>\n            <div className=\"badges--left\">\n                {floorplan.virtualTourLink ?\n                    <div className=\"icon-tour\">\n                        <Button variant=\"transparent\" size=\"small\"\n                                onClick={() => videoClickHandler({\n                                    url: floorplan.virtualTourLink,\n                                    type: \"virtual\"\n                                })}>\n                            <img src={tourIcon} alt=\"tour icon\" height={30}/>\n                        </Button>\n\n                    </div>\n                    : ''}\n                {floorplan.videoTourLink ?\n                    <div className=\"icon-video\">\n                        <Button variant=\"transparent\" size=\"small\"\n                                onClick={() => videoClickHandler({url: floorplan.videoTourLink, type: \"video\"})}>\n                            <img src={videoIcon} alt=\"video icon\" height={20}/>\n                        </Button>\n                    </div>\n                    : ''}\n            </div>\n\n\n            <a href={\"/floorplans/\" + floorplan.id}\n               title={floorplan.name}>\n                <div className=\"floorplan-card-content\">\n                    <div className=\"floorplan-card-content--special\">\n                        {showSpecialOffer && floorplan.webSpecials.length > 0 ?\n                            <div className=\"content--special\">\n                                <p>{floorplan.webSpecials[0]}</p>\n                            </div> : <></>}\n                    </div>\n                    <div className=\"floorplan-card-footer\">\n                        <div className=\"left\">\n                            <h3 className=\"truncate\">\n                                {floorplan.name}\n                            </h3>\n                            <p>\n                                <FloorplanPrice unitRents={floorplan.units} specialRent={floorplan.specialRent}\n                                                specialRentEndDate={floorplan.specialRentEndDate}\n                                                specialRentStartDate={floorplan.specialRentStartDate}/>\n                            </p>\n                        </div>\n                        <div className=\"right\">\n                            <p>{floorplan.bedroom} bed, {floorplan.bathroom} bath</p>\n                            <p>{floorplan.units.length > 0 ? <>{rangeFrom(floorplan.units, \"squareFoot\")} sq.\n                                ft.</> : <>&nbsp;</>}</p>\n                        </div>\n                    </div>\n                </div>\n\n            </a>\n        </div>\n    );\n}\n\nexport interface FloorplanCardProps {\n    floorplan: FloorplanCardData;\n    size?: \"small\" | \"large\"\n    videoClickHandler: (video: Video) => void;\n    propertyId: string;\n}\n\n"],"mappings":"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"}
@@ -1,7 +1,12 @@
1
1
  import React from "react";
2
- import { FloorplanCardData } from "../data/Floorplan";
3
2
  import "./assets/FloorplanPrice.scss";
4
3
  export declare const FloorplanPrice: React.FC<FloorplanPriceProps>;
5
4
  export interface FloorplanPriceProps {
6
- floorplan: FloorplanCardData;
5
+ unitRents: {
6
+ rent: number;
7
+ }[];
8
+ specialRent?: number;
9
+ specialRentStartDate?: string;
10
+ specialRentEndDate?: string;
11
+ invertColor?: boolean;
7
12
  }
@@ -11,16 +11,20 @@ require("./assets/FloorplanPrice.scss");
11
11
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
12
12
  const FloorplanPrice = _ref => {
13
13
  let {
14
- floorplan
14
+ unitRents,
15
+ specialRent,
16
+ specialRentStartDate,
17
+ specialRentEndDate,
18
+ invertColor
15
19
  } = _ref;
16
20
  const hasSpecialRent = () => {
17
21
  const currentDate = (0, _moment.default)();
18
- if (!floorplan.specialRent || floorplan.specialRent < 1 || !floorplan.specialRentStartDate || !floorplan.specialRentEndDate) return false;
19
- const startDate = (0, _Utils.dateToMoment)(floorplan.specialRentStartDate);
20
- const endDate = (0, _Utils.dateToMoment)(floorplan.specialRentEndDate);
22
+ if (!specialRent || specialRent < 1 || !specialRentStartDate || !specialRentEndDate) return false;
23
+ const startDate = (0, _Utils.dateToMoment)(specialRentStartDate);
24
+ const endDate = (0, _Utils.dateToMoment)(specialRentEndDate);
21
25
  return currentDate.isBetween(startDate, endDate);
22
26
  };
23
- const minMaxRent = (0, _Utils.minimumMaximum)(floorplan.units, "rent");
27
+ const minMaxRent = (0, _Utils.minimumMaximum)(unitRents, "rent");
24
28
  const getRentClass = () => hasSpecialRent() ? "strike-through" : "";
25
29
  const priceForSingleUnit = () => /*#__PURE__*/_react.default.createElement("span", {
26
30
  className: getRentClass()
@@ -34,10 +38,12 @@ const FloorplanPrice = _ref => {
34
38
  }, (0, _Utils.toUSD)(minMaxRent.min))), " - ", (0, _Utils.toUSD)(minMaxRent.max));
35
39
  const priceForSpecialRent = () => hasSpecialRent() ? /*#__PURE__*/_react.default.createElement("span", {
36
40
  className: "special"
37
- }, "Now starting at ", (0, _Utils.toUSD)(floorplan.specialRent), "/mo") : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null);
38
- return floorplan.units && floorplan.units.length > 0 ? /*#__PURE__*/_react.default.createElement("span", {
39
- className: "floorplan-price"
40
- }, minMaxRent.min === minMaxRent.max ? priceForSingleUnit() : priceForMultipleUnits(), priceForSpecialRent()) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, "-");
41
+ }, "Now starting at ", (0, _Utils.toUSD)(specialRent), "/mo") : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null);
42
+ return unitRents.length > 0 ? /*#__PURE__*/_react.default.createElement("span", {
43
+ className: invertColor ? "floorplan-price floorplan-price-inverted" : "floorplan-price"
44
+ }, minMaxRent.min === minMaxRent.max ? priceForSingleUnit() : priceForMultipleUnits(), /*#__PURE__*/_react.default.createElement("span", {
45
+ className: "floorplan-special-price"
46
+ }, priceForSpecialRent())) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, "-");
41
47
  };
42
48
  exports.FloorplanPrice = FloorplanPrice;
43
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIl9VdGlscyIsIl9tb21lbnQiLCJvYmoiLCJfX2VzTW9kdWxlIiwiZGVmYXVsdCIsIkZsb29ycGxhblByaWNlIiwiX3JlZiIsImZsb29ycGxhbiIsImhhc1NwZWNpYWxSZW50IiwiY3VycmVudERhdGUiLCJtb21lbnQiLCJzcGVjaWFsUmVudCIsInNwZWNpYWxSZW50U3RhcnREYXRlIiwic3BlY2lhbFJlbnRFbmREYXRlIiwic3RhcnREYXRlIiwiZGF0ZVRvTW9tZW50IiwiZW5kRGF0ZSIsImlzQmV0d2VlbiIsIm1pbk1heFJlbnQiLCJtaW5pbXVtTWF4aW11bSIsInVuaXRzIiwiZ2V0UmVudENsYXNzIiwicHJpY2VGb3JTaW5nbGVVbml0IiwiY3JlYXRlRWxlbWVudCIsImNsYXNzTmFtZSIsInRvVVNEIiwibWluIiwicHJpY2VGb3JNdWx0aXBsZVVuaXRzIiwiRnJhZ21lbnQiLCJtYXgiLCJwcmljZUZvclNwZWNpYWxSZW50IiwibGVuZ3RoIiwiZXhwb3J0cyJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9mbG9vcnBsYW4vY2FyZC9GbG9vcnBsYW5QcmljZS50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHtkYXRlVG9Nb21lbnQsIG1pbmltdW1NYXhpbXVtLCB0b1VTRH0gZnJvbSBcIi4uLy4uL3V0aWxzL1V0aWxzXCI7XG5pbXBvcnQgbW9tZW50IGZyb20gXCJtb21lbnQvbW9tZW50XCI7XG5pbXBvcnQge0Zsb29ycGxhbkNhcmREYXRhfSBmcm9tIFwiLi4vZGF0YS9GbG9vcnBsYW5cIjtcbmltcG9ydCBcIi4vYXNzZXRzL0Zsb29ycGxhblByaWNlLnNjc3NcIjtcblxuZXhwb3J0IGNvbnN0IEZsb29ycGxhblByaWNlOiBSZWFjdC5GQzxGbG9vcnBsYW5QcmljZVByb3BzPiA9ICh7Zmxvb3JwbGFufSkgPT4ge1xuXG4gICAgY29uc3QgaGFzU3BlY2lhbFJlbnQgPSAoKSA9PiB7XG4gICAgICAgIGNvbnN0IGN1cnJlbnREYXRlID0gbW9tZW50KCk7XG5cbiAgICAgICAgaWYgKCFmbG9vcnBsYW4uc3BlY2lhbFJlbnQgfHwgZmxvb3JwbGFuLnNwZWNpYWxSZW50IDwgMSB8fCAhZmxvb3JwbGFuLnNwZWNpYWxSZW50U3RhcnREYXRlIHx8ICFmbG9vcnBsYW4uc3BlY2lhbFJlbnRFbmREYXRlKVxuICAgICAgICAgICAgcmV0dXJuIGZhbHNlXG5cbiAgICAgICAgY29uc3Qgc3RhcnREYXRlID0gZGF0ZVRvTW9tZW50KGZsb29ycGxhbi5zcGVjaWFsUmVudFN0YXJ0RGF0ZSk7XG4gICAgICAgIGNvbnN0IGVuZERhdGUgPSBkYXRlVG9Nb21lbnQoZmxvb3JwbGFuLnNwZWNpYWxSZW50RW5kRGF0ZSk7XG5cbiAgICAgICAgcmV0dXJuIGN1cnJlbnREYXRlLmlzQmV0d2VlbihzdGFydERhdGUsIGVuZERhdGUpO1xuXG4gICAgfVxuXG4gICAgY29uc3QgbWluTWF4UmVudCA9IG1pbmltdW1NYXhpbXVtKGZsb29ycGxhbi51bml0cywgXCJyZW50XCIpO1xuXG4gICAgY29uc3QgZ2V0UmVudENsYXNzID0gKCkgPT4gaGFzU3BlY2lhbFJlbnQoKSA/IFwic3RyaWtlLXRocm91Z2hcIiA6IFwiXCI7XG5cbiAgICBjb25zdCBwcmljZUZvclNpbmdsZVVuaXQgPSAoKSA9PlxuICAgICAgICA8c3BhbiBjbGFzc05hbWU9e2dldFJlbnRDbGFzcygpfT48c3BhbiBjbGFzc05hbWU9XCJyZW50XCI+e3RvVVNEKG1pbk1heFJlbnQubWluKX08L3NwYW4+PC9zcGFuPlxuICAgIGNvbnN0IHByaWNlRm9yTXVsdGlwbGVVbml0cyA9ICgpID0+XG4gICAgICAgIDw+PHNwYW4gY2xhc3NOYW1lPXtnZXRSZW50Q2xhc3MoKX0+PHNwYW4gY2xhc3NOYW1lPVwicmVudFwiPnt0b1VTRChtaW5NYXhSZW50Lm1pbil9PC9zcGFuPjwvc3Bhbj4gLSB7dG9VU0QobWluTWF4UmVudC5tYXgpfTwvPlxuXG4gICAgY29uc3QgcHJpY2VGb3JTcGVjaWFsUmVudCA9ICgpID0+IGhhc1NwZWNpYWxSZW50KCkgPyA8c3BhblxuICAgICAgICBjbGFzc05hbWU9XCJzcGVjaWFsXCI+Tm93IHN0YXJ0aW5nIGF0IHt0b1VTRChmbG9vcnBsYW4uc3BlY2lhbFJlbnQpfS9tbzwvc3Bhbj4gOiA8PjwvPlxuICAgIHJldHVybiAoXG4gICAgICAgIGZsb29ycGxhbi51bml0cyAmJiBmbG9vcnBsYW4udW5pdHMubGVuZ3RoID4gMCA/XG4gICAgICAgICAgICA8c3BhbiBjbGFzc05hbWU9XCJmbG9vcnBsYW4tcHJpY2VcIj5cbiAgICAgICAgICAgICAgICB7bWluTWF4UmVudC5taW4gPT09IG1pbk1heFJlbnQubWF4ID8gcHJpY2VGb3JTaW5nbGVVbml0KCkgOiBwcmljZUZvck11bHRpcGxlVW5pdHMoKX1cbiAgICAgICAgICAgICAgICB7cHJpY2VGb3JTcGVjaWFsUmVudCgpfVxuICAgICAgICAgICAgPC9zcGFuPlxuICAgICAgICAgICAgOiA8Pi08Lz5cbiAgICApO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEZsb29ycGxhblByaWNlUHJvcHMge1xuICAgIGZsb29ycGxhbjogRmxvb3JwbGFuQ2FyZERhdGE7XG59XG4iXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLElBQUFBLE1BQUEsR0FBQUMsc0JBQUEsQ0FBQUMsT0FBQTtBQUNBLElBQUFDLE1BQUEsR0FBQUQsT0FBQTtBQUNBLElBQUFFLE9BQUEsR0FBQUgsc0JBQUEsQ0FBQUMsT0FBQTtBQUVBQSxPQUFBO0FBQXNDLFNBQUFELHVCQUFBSSxHQUFBLFdBQUFBLEdBQUEsSUFBQUEsR0FBQSxDQUFBQyxVQUFBLEdBQUFELEdBQUEsS0FBQUUsT0FBQSxFQUFBRixHQUFBO0FBRS9CLE1BQU1HLGNBQTZDLEdBQUdDLElBQUEsSUFBaUI7RUFBQSxJQUFoQjtJQUFDQztFQUFTLENBQUMsR0FBQUQsSUFBQTtFQUVyRSxNQUFNRSxjQUFj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
49
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIl9VdGlscyIsIl9tb21lbnQiLCJvYmoiLCJfX2VzTW9kdWxlIiwiZGVmYXVsdCIsIkZsb29ycGxhblByaWNlIiwiX3JlZiIsInVuaXRSZW50cyIsInNwZWNpYWxSZW50Iiwic3BlY2lhbFJlbnRTdGFydERhdGUiLCJzcGVjaWFsUmVudEVuZERhdGUiLCJpbnZlcnRDb2xvciIsImhhc1NwZWNpYWxSZW50IiwiY3VycmVudERhdGUiLCJtb21lbnQiLCJzdGFydERhdGUiLCJkYXRlVG9Nb21lbnQiLCJlbmREYXRlIiwiaXNCZXR3ZWVuIiwibWluTWF4UmVudCIsIm1pbmltdW1NYXhpbXVtIiwiZ2V0UmVudENsYXNzIiwicHJpY2VGb3JTaW5nbGVVbml0IiwiY3JlYXRlRWxlbWVudCIsImNsYXNzTmFtZSIsInRvVVNEIiwibWluIiwicHJpY2VGb3JNdWx0aXBsZVVuaXRzIiwiRnJhZ21lbnQiLCJtYXgiLCJwcmljZUZvclNwZWNpYWxSZW50IiwibGVuZ3RoIiwiZXhwb3J0cyJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9mbG9vcnBsYW4vY2FyZC9GbG9vcnBsYW5QcmljZS50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHtkYXRlVG9Nb21lbnQsIG1pbmltdW1NYXhpbXVtLCB0b1VTRH0gZnJvbSBcIi4uLy4uL3V0aWxzL1V0aWxzXCI7XG5pbXBvcnQgbW9tZW50IGZyb20gXCJtb21lbnQvbW9tZW50XCI7XG5pbXBvcnQgXCIuL2Fzc2V0cy9GbG9vcnBsYW5QcmljZS5zY3NzXCI7XG5cbmV4cG9ydCBjb25zdCBGbG9vcnBsYW5QcmljZTogUmVhY3QuRkM8Rmxvb3JwbGFuUHJpY2VQcm9wcz4gPSAoXG4gICAge1xuICAgICAgICB1bml0UmVudHMsXG4gICAgICAgIHNwZWNpYWxSZW50LFxuICAgICAgICBzcGVjaWFsUmVudFN0YXJ0RGF0ZSxcbiAgICAgICAgc3BlY2lhbFJlbnRFbmREYXRlLFxuICAgICAgICBpbnZlcnRDb2xvclxuICAgIH0pID0+IHtcblxuICAgIGNvbnN0IGhhc1NwZWNpYWxSZW50ID0gKCkgPT4ge1xuICAgICAgICBjb25zdCBjdXJyZW50RGF0ZSA9IG1vbWVudCgpO1xuXG4gICAgICAgIGlmICghc3BlY2lhbFJlbnQgfHwgc3BlY2lhbFJlbnQgPCAxIHx8ICFzcGVjaWFsUmVudFN0YXJ0RGF0ZSB8fCAhc3BlY2lhbFJlbnRFbmREYXRlKVxuICAgICAgICAgICAgcmV0dXJuIGZhbHNlXG5cbiAgICAgICAgY29uc3Qgc3RhcnREYXRlID0gZGF0ZVRvTW9tZW50KHNwZWNpYWxSZW50U3RhcnREYXRlKTtcbiAgICAgICAgY29uc3QgZW5kRGF0ZSA9IGRhdGVUb01vbWVudChzcGVjaWFsUmVudEVuZERhdGUpO1xuXG4gICAgICAgIHJldHVybiBjdXJyZW50RGF0ZS5pc0JldHdlZW4oc3RhcnREYXRlLCBlbmREYXRlKTtcblxuICAgIH1cblxuICAgIGNvbnN0IG1pbk1heFJlbnQgPSBtaW5pbXVtTWF4aW11bSh1bml0UmVudHMsIFwicmVudFwiKTtcblxuICAgIGNvbnN0IGdldFJlbnRDbGFzcyA9ICgpID0+IGhhc1NwZWNpYWxSZW50KCkgPyBcInN0cmlrZS10aHJvdWdoXCIgOiBcIlwiO1xuXG4gICAgY29uc3QgcHJpY2VGb3JTaW5nbGVVbml0ID0gKCkgPT5cbiAgICAgICAgPHNwYW4gY2xhc3NOYW1lPXtnZXRSZW50Q2xhc3MoKX0+PHNwYW4gY2xhc3NOYW1lPVwicmVudFwiPnt0b1VTRChtaW5NYXhSZW50Lm1pbil9PC9zcGFuPjwvc3Bhbj5cbiAgICBjb25zdCBwcmljZUZvck11bHRpcGxlVW5pdHMgPSAoKSA9PlxuICAgICAgICA8PjxzcGFuIGNsYXNzTmFtZT17Z2V0UmVudENsYXNzKCl9PjxzcGFuXG4gICAgICAgICAgICBjbGFzc05hbWU9XCJyZW50XCI+e3RvVVNEKG1pbk1heFJlbnQubWluKX08L3NwYW4+PC9zcGFuPiAtIHt0b1VTRChtaW5NYXhSZW50Lm1heCl9PC8+XG5cbiAgICBjb25zdCBwcmljZUZvclNwZWNpYWxSZW50ID0gKCkgPT4gaGFzU3BlY2lhbFJlbnQoKSA/IDxzcGFuXG4gICAgICAgIGNsYXNzTmFtZT1cInNwZWNpYWxcIj5Ob3cgc3RhcnRpbmcgYXQge3RvVVNEKHNwZWNpYWxSZW50ISEpfS9tbzwvc3Bhbj4gOiA8PjwvPlxuICAgIHJldHVybiAoXG4gICAgICAgIHVuaXRSZW50cy5sZW5ndGggPiAwID9cbiAgICAgICAgICAgIDxzcGFuIGNsYXNzTmFtZT17aW52ZXJ0Q29sb3IgPyBcImZsb29ycGxhbi1wcmljZSBmbG9vcnBsYW4tcHJpY2UtaW52ZXJ0ZWRcIiA6IFwiZmxvb3JwbGFuLXByaWNlXCJ9PlxuICAgICAgICAgICAgICAgIHttaW5NYXhSZW50Lm1pbiA9PT0gbWluTWF4UmVudC5tYXggPyBwcmljZUZvclNpbmdsZVVuaXQoKSA6IHByaWNlRm9yTXVsdGlwbGVVbml0cygpfVxuICAgICAgICAgICAgICAgIDxzcGFuIGNsYXNzTmFtZT1cImZsb29ycGxhbi1zcGVjaWFsLXByaWNlXCI+e3ByaWNlRm9yU3BlY2lhbFJlbnQoKX08L3NwYW4+XG4gICAgICAgICAgICA8L3NwYW4+XG4gICAgICAgICAgICA6IDw+LTwvPlxuICAgICk7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRmxvb3JwbGFuUHJpY2VQcm9wcyB7XG4gICAgdW5pdFJlbnRzOiB7IHJlbnQ6IG51bWJlciB9W10sXG4gICAgc3BlY2lhbFJlbnQ/OiBudW1iZXIsXG4gICAgc3BlY2lhbFJlbnRTdGFydERhdGU/OiBzdHJpbmcsXG4gICAgc3BlY2lhbFJlbnRFbmREYXRlPzogc3RyaW5nLFxuICAgIGludmVydENvbG9yPzogYm9vbGVhblxufVxuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQSxJQUFBQSxNQUFBLEdBQUFDLHNCQUFBLENBQUFDLE9BQUE7QUFDQSxJQUFBQyxNQUFBLEdBQUFELE9BQUE7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
@@ -1,18 +1,22 @@
1
1
  @import "src/assets/variables";
2
2
 
3
- $floorplan-card-color: $primary-background-color !default;
3
+ $floorplan-price-color: $primary-background-color !default;
4
+ $floorplan-price-color-inverted: $primary-color !default;
4
5
  $floorplan-price-special-color: $special-offer-color !default;
5
6
  .floorplan-price {
6
7
  .strike-through {
7
8
  text-decoration: line-through;
8
- text-decoration-thickness: .3rem;
9
+ text-decoration-thickness: .25rem;
9
10
  color: $floorplan-price-special-color;
10
11
  }
11
12
 
12
13
  .rent {
13
- color: $floorplan-card-color;
14
+ color: $floorplan-price-color;
14
15
  }
15
16
 
17
+ .floorplan-special-price{
18
+ color: $floorplan-price-color;
19
+ }
16
20
  .special {
17
21
  padding-left: 1rem;
18
22
  -webkit-text-stroke: .2rem $floorplan-price-special-color;
@@ -22,3 +26,9 @@ $floorplan-price-special-color: $special-offer-color !default;
22
26
  font-style: italic;
23
27
  }
24
28
  }
29
+
30
+ .floorplan-price-inverted{
31
+ .rent {
32
+ color: $floorplan-price-color-inverted;
33
+ }
34
+ }
@@ -42,9 +42,9 @@ export interface FloorplanDetails {
42
42
  bedroom: number;
43
43
  bathroom: number;
44
44
  style: FloorplanStyle;
45
- specialRent: 0;
46
- specialRentStartDate: "";
47
- specialRentEndDate: "";
45
+ specialRent: number;
46
+ specialRentStartDate: string;
47
+ specialRentEndDate: string;
48
48
  featured: boolean;
49
49
  greenCertified: boolean;
50
50
  videoTourLink: string | null;
@@ -68,9 +68,9 @@ export interface FloorplanCardData {
68
68
  coverImage: string;
69
69
  featured: boolean;
70
70
  style: FloorplanStyle;
71
- specialRent: 0;
72
- specialRentStartDate: "";
73
- specialRentEndDate: "";
71
+ specialRent: number;
72
+ specialRentStartDate: string;
73
+ specialRentEndDate: string;
74
74
  virtualTourLink: string;
75
75
  videoTourLink: string;
76
76
  photosFolderId: string;
@@ -97,9 +97,9 @@ export interface Floorplan {
97
97
  zipcode: string;
98
98
  description: string;
99
99
  vanityLink: string;
100
- specialRent: 0;
101
- specialRentStartDate: "";
102
- specialRentEndDate: "";
100
+ specialRent: number;
101
+ specialRentStartDate: string;
102
+ specialRentEndDate: string;
103
103
  htmlTitle: string;
104
104
  metaDescription: string;
105
105
  conversionTrackingId1: string;
@@ -112,6 +112,7 @@ export interface Floorplan {
112
112
  lastModifiedBy: string;
113
113
  lastModifiedDate: string;
114
114
  active: boolean;
115
+ webSpecials: WebSpecialDetails[];
115
116
  }
116
117
  export interface FloorplanSpotlight {
117
118
  id: string;
@@ -31,4 +31,4 @@ let UtilityType = exports.UtilityType = /*#__PURE__*/function (UtilityType) {
31
31
  UtilityType["INCLUDED_UTILITY"] = "INCLUDED_UTILITY";
32
32
  return UtilityType;
33
33
  }({});
34
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJNSU5fUkVOVCIsImV4cG9ydHMiLCJNQVhfUkVOVCIsIkZsb29ycGxhblN0eWxlIiwiQW1lbml0eVR5cGUiLCJVdGlsaXR5VHlwZSJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9mbG9vcnBsYW4vZGF0YS9GbG9vcnBsYW4udHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtVbml0LCBVbml0Q2FyZERhdGEsIFVuaXREZXRhaWxzfSBmcm9tIFwiLi9Vbml0XCI7XG5pbXBvcnQge0xlYXNlVHlwZSwgUHJvcGVydHlCdXNSb3V0ZX0gZnJvbSBcIi4uLy4uL3Byb3BlcnR5L2RhdGEvUHJvcGVydHlcIjtcblxuZXhwb3J0IGNvbnN0IE1JTl9SRU5UID0gMDtcbmV4cG9ydCBjb25zdCBNQVhfUkVOVCA9IDQwMDA7XG5cbmV4cG9ydCBlbnVtIEZsb29ycGxhblN0eWxlIHtcbiAgICBTVFVESU8gPSBcIlNUVURJT1wiLFxuICAgIEFQQVJUTUVOVCA9IFwiQVBBUlRNRU5UXCIsXG4gICAgREVMVVhFX0FQQVJUTUVOVCA9IFwiREVMVVhFX0FQQVJUTUVOVFwiLFxuICAgIFRPV05fSE9NRSA9IFwiVE9XTl9IT01FXCIsXG4gICAgU0lOR0xFX0ZBTUlMWSA9IFwiU0lOR0xFX0ZBTUlMWVwiLFxuICAgIEdBUkFHRSA9IFwiR0FSQUdFXCJcbn1cblxuZXhwb3J0IGVudW0gQW1lbml0eVR5cGUge1xuICAgIEtJVENIRU4gPSBcIktJVENIRU5cIixcbiAgICBMSVZJTkdfQU5EX0JFRFJPT00gPSBcIkxJVklOR19BTkRfQkVEUk9PTVwiLFxuICAgIEJBVEhST09NID0gXCJCQVRIUk9PTVwiLFxuICAgIE9VVERPT1IgPSBcIk9VVERPT1JcIixcbiAgICBIRUFUSU5HX0NPT0xJTkdfQU5EX1dJUklORyA9IFwiSEVBVElOR19DT09MSU5HX0FORF9XSVJJTkdcIixcbiAgICBTTUFSVF9MSVZJTkcgPSBcIlNNQVJUX0xJVklOR1wiLFxuICAgIFBBUktJTkcgPSBcIlBBUktJTkdcIixcbiAgICBOT1RfQVBQTElDQUJMRSA9IFwiTk9UX0FQUExJQ0FCTEVcIlxufVxuXG5leHBvcnQgaW50ZXJmYWNlIEFtZW5pdHlOYW1lIHtcbiAgICBpZDogc3RyaW5nO1xuICAgIG5hbWU6IHN0cmluZztcbiAgICBmZWF0dXJlZDogYm9vbGVhbjtcbiAgICB0eXBlOiBBbWVuaXR5VHlwZTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBVdGlsaXR5TmFtZSB7XG4gICAgaWQ6IG51bWJlcjtcbiAgICBuYW1lOiBzdHJpbmc7XG4gICAgdHlwZTogVXRpbGl0eVR5cGU7XG4gICAgYXZlcmFnZU1vbnRobHlCaWxsOiBudW1iZXI7XG59XG5cbmV4cG9ydCBlbnVtIFV0aWxpdHlUeXBlIHtcbiAgICBSRVNJREVOVF9VVElMSVRZID0gXCJSRVNJREVOVF9VVElMSVRZXCIsIElOQ0xVREVEX1VUSUxJVFkgPSBcIklOQ0xVREVEX1VUSUxJVFlcIlxufVxuXG5leHBvcnQgaW50ZXJmYWNlIEZsb29ycGxhbkRldGFpbHMge1xuICAgIGlkOiBzdHJpbmc7XG4gICAgbmFtZTogc3RyaW5nO1xuICAgIGJlZHJvb206IG51bWJlcjtcbiAgICBiYXRocm9vbTogbnVtYmVyO1xuICAgIHN0eWxlOiBGbG9vcnBsYW5TdHlsZTtcbiAgICBzcGVjaWFsUmVudDogMCxcbiAgICBzcGVjaWFsUmVudFN0YXJ0RGF0ZTogXCJcIixcbiAgICBzcGVjaWFsUmVudEVuZERhdGU6IFwiXCIsXG4gICAgZmVhdHVyZWQ6IGJvb2xlYW47XG4gICAgZ3JlZW5DZXJ0aWZpZWQ6IGJvb2xlYW47XG4gICAgdmlkZW9Ub3VyTGluazogc3RyaW5nIHwgbnVsbDtcbiAgICB0aHJlZVNpeHR5VmlkZW9Ub3VyTGluazogc3RyaW5nIHwgbnVsbDtcbiAgICB2aXJ0dWFsVG91ckxpbms6IHN0cmluZyB8IG51bGw7XG4gICAgcGhvdG86IHN0cmluZyxcbiAgICBjb3ZlckltYWdlOiBzdHJpbmcsXG4gICAgZmxvb3JQbGFuRm9sZGVySWQ6IHN0cmluZztcbiAgICBwaG90b3NGb2xkZXJJZDogc3RyaW5nO1xuICAgIGFtZW5pdGllczogQW1lbml0eU5hbWVbXTtcbiAgICB1bml0czogVW5pdERldGFpbHNbXTtcbiAgICBhY3RpdmU6IGJvb2xlYW47XG4gICAgd2ViU3BlY2lhbHM6IFdlYlNwZWNpYWxEZXRhaWxzW107XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRmxvb3JwbGFuQ2FyZERhdGEge1xuICAgIGlkOiBzdHJpbmc7XG4gICAgbmFtZTogc3RyaW5nO1xuICAgIGFjdGl2ZTogYm9vbGVhbjtcbiAgICBiZWRyb29tOiBudW1iZXI7XG4gICAgYmF0aHJvb206IG51bWJlcjtcbiAgICBjb3ZlckltYWdlOiBzdHJpbmc7XG4gICAgZmVhdHVyZWQ6IGJvb2xlYW47XG4gICAgc3R5bGU6IEZsb29ycGxhblN0eWxlO1xuICAgIHNwZWNpYWxSZW50OiAwLFxuICAgIHNwZWNpYWxSZW50U3RhcnREYXRlOiBcIlwiLFxuICAgIHNwZWNpYWxSZW50RW5kRGF0ZTogXCJcIixcbiAgICB2aXJ0dWFsVG91ckxpbms6IHN0cmluZztcbiAgICB2aWRlb1RvdXJMaW5rOiBzdHJpbmc7XG4gICAgcGhvdG9zRm9sZGVySWQ6IHN0cmluZztcbiAgICB1bml0czogVW5pdENhcmREYXRhW107XG4gICAgd2ViU3BlY2lhbHM6IHN0cmluZyBbXTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBGbG9vcnBsYW4ge1xuICAgIGlkOiBzdHJpbmc7XG4gICAgbmFtZTogc3RyaW5nO1xuICAgIGJlZHJvb206IG51bWJlcjtcbiAgICBiYXRocm9vbTogbnVtYmVyO1xuICAgIHN0eWxlOiBGbG9vcnBsYW5TdHlsZTtcbiAgICBmZWF0dXJlZDogYm9vbGVhbjtcbiAgICBwYXRpb0luY2x1ZGVkOiBib29sZWFuO1xuICAgIGdyZWVuQ2VydGlmaWVkOiBib29sZWFuO1xuICAgIHZpZGVvVG91ckxpbms6IHN0cmluZztcbiAgICB0aHJlZVNpeHR5VmlkZW9Ub3VyTGluazogc3RyaW5nO1xuICAgIHZpcnR1YWxUb3VyTGluazogc3RyaW5nO1xuICAgIHBob3RvOiBzdHJpbmcgfCBudWxsLFxuICAgIGNvdmVySW1hZ2U6IHN0cmluZyB8IG51bGwsXG4gICAgZmxvb3JQbGFuRm9sZGVySWQ6IHN0cmluZztcbiAgICBwaG90b3NGb2xkZXJJZDogc3RyaW5nO1xuICAgIGFkZHJlc3M6IHN0cmluZztcbiAgICB6aXBjb2RlOiBzdHJpbmc7XG4gICAgZGVzY3JpcHRpb246IHN0cmluZztcbiAgICB2YW5pdHlMaW5rOiBzdHJpbmc7XG4gICAgc3BlY2lhbFJlbnQ6IDAsXG4gICAgc3BlY2lhbFJlbnRTdGFydERhdGU6IFwiXCIsXG4gICAgc3BlY2lhbFJlbnRFbmREYXRlOiBcIlwiLFxuICAgIGh0bWxUaXRsZTogc3RyaW5nO1xuICAgIG1ldGFEZXNjcmlwdGlvbjogc3RyaW5nO1xuICAgIGNvbnZlcnNpb25UcmFja2luZ0lkMTogc3RyaW5nO1xuICAgIGNvbnZlcnNpb25UcmFja2luZ0lkMjogc3RyaW5nO1xuICAgIGN1c3RvbUNvZGU6IHN0cmluZztcbiAgICB1dGlsaXRpZXM6IFV0aWxpdHlOYW1lW107XG4gICAgYW1lbml0aWVzOiBBbWVuaXR5TmFtZVtdO1xuICAgIHByb3BlcnR5OiBQcm9wZXJ0eU5hbWU7XG4gICAgdW5pdHM6IFVuaXRbXTtcbiAgICBsYXN0TW9kaWZpZWRCeTogc3RyaW5nO1xuICAgIGxhc3RNb2RpZmllZERhdGU6IHN0cmluZztcbiAgICBhY3RpdmU6IGJvb2xlYW47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRmxvb3JwbGFuU3BvdGxpZ2h0IHtcbiAgICBpZDogc3RyaW5nO1xuICAgIG5hbWU6IHN0cmluZztcbiAgICBtZXRhRGVzY3JpcHRpb246IHN0cmluZztcbiAgICBiZWRyb29tOiBudW1iZXI7XG4gICAgYmF0aHJvb206IG51bWJlcjtcbiAgICBzdHlsZTogRmxvb3JwbGFuU3R5bGU7XG4gICAgZmVhdHVyZWQ6IGJvb2xlYW47XG4gICAgY292ZXJJbWFnZTogc3RyaW5nO1xuICAgIHVuaXRzOiBVbml0U3BvdGxpZ2h0W107XG4gICAgYWN0aXZlOiBib29sZWFuO1xuICAgIHByb3BlcnR5OiBQcm9wZXJ0eU5hbWU7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVW5pdFNwb3RsaWdodCB7XG4gICAgaWQ6IHN0cmluZztcbiAgICBzcXVhcmVGb290OiBudW1iZXI7XG4gICAgcmVudDogbnVtYmVyO1xuICAgIGFjdGl2ZTogYm9vbGVhbjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBQcm9wZXJ0eU5hbWUge1xuICAgIG5hbWU6IHN0cmluZztcbiAgICBpZDogc3RyaW5nO1xuICAgIGFjdGl2ZTogYm9vbGVhbjtcbiAgICBlbWFpbDogc3RyaW5nO1xuICAgIHBob25lOiBzdHJpbmc7XG4gICAgYWRkcmVzczogc3RyaW5nO1xuICAgIHppcGNvZGU6IHN0cmluZztcbiAgICBidXNSb3V0ZXM6IFByb3BlcnR5QnVzUm91dGVbXTtcbiAgICBsZWFzZVR5cGU6IExlYXNlVHlwZTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBGbG9vcnBsYW5OYW1lIHtcbiAgICBuYW1lOiBzdHJpbmc7XG4gICAgaWQ6IHN0cmluZztcbiAgICBhY3RpdmU6IGJvb2xlYW47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgU2ltaWxhckZsb29ycGxhbiB7XG4gICAgc2ltaWxhclRvOiBGbG9vcnBsYW5OYW1lO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEZsb29ycGxhblZhcmlhdGlvbiB7XG4gICAgdmFyaWF0aW9uOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVGVzdGltb25pYWwge1xuICAgIHRlc3RpbW9uaWFsOiBzdHJpbmc7XG4gICAgdGVuYW50OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgV2ViU3BlY2lhbCB7XG4gICAgZGVzY3JpcHRpb246IHN0cmluZztcbiAgICBzdGFydERhdGU6IHN0cmluZztcbiAgICBlbmREYXRlOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgV2ViU3BlY2lhbERldGFpbHMgZXh0ZW5kcyBXZWJTcGVjaWFsIHtcbiAgICBpZDogc3RyaW5nO1xufVxuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFHTyxNQUFNQSxRQUFRLEdBQUFDLE9BQUEsQ0FBQUQsUUFBQSxHQUFHLENBQUM7QUFDbEIsTUFBTUUsUUFBUSxHQUFBRCxPQUFBLENBQUFDLFFBQUEsR0FBRyxJQUFJO0FBQUMsSUFFakJDLGNBQWMsR0FBQUYsT0FBQSxDQUFBRSxjQUFBLDBCQUFkQSxjQUFjO0VBQWRBLGNBQWM7RUFBZEEsY0FBYztFQUFkQSxjQUFjO0VBQWRBLGNBQWM7RUFBZEEsY0FBYztFQUFkQSxjQUFjO0VBQUEsT0FBZEEsY0FBYztBQUFBO0FBQUEsSUFTZEMsV0FBVyxHQUFBSCxPQUFBLENBQUFHLFdBQUEsMEJBQVhBLFdBQVc7RUFBWEEsV0FBVztFQUFYQSxXQUFXO0VBQVhBLFdBQVc7RUFBWEEsV0FBVztFQUFYQSxXQUFXO0VBQVhBLFdBQVc7RUFBWEEsV0FBVztFQUFYQSxXQUFXO0VBQUEsT0FBWEEsV0FBVztBQUFBO0FBQUEsSUF5QlhDLFdBQVcsR0FBQUosT0FBQSxDQUFBSSxXQUFBLDBCQUFYQSxXQUFXO0VBQVhBLFdBQVc7RUFBWEEsV0FBVztFQUFBLE9BQVhBLFdBQVc7QUFBQSJ9
34
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJNSU5fUkVOVCIsImV4cG9ydHMiLCJNQVhfUkVOVCIsIkZsb29ycGxhblN0eWxlIiwiQW1lbml0eVR5cGUiLCJVdGlsaXR5VHlwZSJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9mbG9vcnBsYW4vZGF0YS9GbG9vcnBsYW4udHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtVbml0LCBVbml0Q2FyZERhdGEsIFVuaXREZXRhaWxzfSBmcm9tIFwiLi9Vbml0XCI7XG5pbXBvcnQge0xlYXNlVHlwZSwgUHJvcGVydHlCdXNSb3V0ZX0gZnJvbSBcIi4uLy4uL3Byb3BlcnR5L2RhdGEvUHJvcGVydHlcIjtcblxuZXhwb3J0IGNvbnN0IE1JTl9SRU5UID0gMDtcbmV4cG9ydCBjb25zdCBNQVhfUkVOVCA9IDQwMDA7XG5cbmV4cG9ydCBlbnVtIEZsb29ycGxhblN0eWxlIHtcbiAgICBTVFVESU8gPSBcIlNUVURJT1wiLFxuICAgIEFQQVJUTUVOVCA9IFwiQVBBUlRNRU5UXCIsXG4gICAgREVMVVhFX0FQQVJUTUVOVCA9IFwiREVMVVhFX0FQQVJUTUVOVFwiLFxuICAgIFRPV05fSE9NRSA9IFwiVE9XTl9IT01FXCIsXG4gICAgU0lOR0xFX0ZBTUlMWSA9IFwiU0lOR0xFX0ZBTUlMWVwiLFxuICAgIEdBUkFHRSA9IFwiR0FSQUdFXCJcbn1cblxuZXhwb3J0IGVudW0gQW1lbml0eVR5cGUge1xuICAgIEtJVENIRU4gPSBcIktJVENIRU5cIixcbiAgICBMSVZJTkdfQU5EX0JFRFJPT00gPSBcIkxJVklOR19BTkRfQkVEUk9PTVwiLFxuICAgIEJBVEhST09NID0gXCJCQVRIUk9PTVwiLFxuICAgIE9VVERPT1IgPSBcIk9VVERPT1JcIixcbiAgICBIRUFUSU5HX0NPT0xJTkdfQU5EX1dJUklORyA9IFwiSEVBVElOR19DT09MSU5HX0FORF9XSVJJTkdcIixcbiAgICBTTUFSVF9MSVZJTkcgPSBcIlNNQVJUX0xJVklOR1wiLFxuICAgIFBBUktJTkcgPSBcIlBBUktJTkdcIixcbiAgICBOT1RfQVBQTElDQUJMRSA9IFwiTk9UX0FQUExJQ0FCTEVcIlxufVxuXG5leHBvcnQgaW50ZXJmYWNlIEFtZW5pdHlOYW1lIHtcbiAgICBpZDogc3RyaW5nO1xuICAgIG5hbWU6IHN0cmluZztcbiAgICBmZWF0dXJlZDogYm9vbGVhbjtcbiAgICB0eXBlOiBBbWVuaXR5VHlwZTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBVdGlsaXR5TmFtZSB7XG4gICAgaWQ6IG51bWJlcjtcbiAgICBuYW1lOiBzdHJpbmc7XG4gICAgdHlwZTogVXRpbGl0eVR5cGU7XG4gICAgYXZlcmFnZU1vbnRobHlCaWxsOiBudW1iZXI7XG59XG5cbmV4cG9ydCBlbnVtIFV0aWxpdHlUeXBlIHtcbiAgICBSRVNJREVOVF9VVElMSVRZID0gXCJSRVNJREVOVF9VVElMSVRZXCIsIElOQ0xVREVEX1VUSUxJVFkgPSBcIklOQ0xVREVEX1VUSUxJVFlcIlxufVxuXG5leHBvcnQgaW50ZXJmYWNlIEZsb29ycGxhbkRldGFpbHMge1xuICAgIGlkOiBzdHJpbmc7XG4gICAgbmFtZTogc3RyaW5nO1xuICAgIGJlZHJvb206IG51bWJlcjtcbiAgICBiYXRocm9vbTogbnVtYmVyO1xuICAgIHN0eWxlOiBGbG9vcnBsYW5TdHlsZTtcbiAgICBzcGVjaWFsUmVudDogbnVtYmVyLFxuICAgIHNwZWNpYWxSZW50U3RhcnREYXRlOiBzdHJpbmcsXG4gICAgc3BlY2lhbFJlbnRFbmREYXRlOiBzdHJpbmcsXG4gICAgZmVhdHVyZWQ6IGJvb2xlYW47XG4gICAgZ3JlZW5DZXJ0aWZpZWQ6IGJvb2xlYW47XG4gICAgdmlkZW9Ub3VyTGluazogc3RyaW5nIHwgbnVsbDtcbiAgICB0aHJlZVNpeHR5VmlkZW9Ub3VyTGluazogc3RyaW5nIHwgbnVsbDtcbiAgICB2aXJ0dWFsVG91ckxpbms6IHN0cmluZyB8IG51bGw7XG4gICAgcGhvdG86IHN0cmluZyxcbiAgICBjb3ZlckltYWdlOiBzdHJpbmcsXG4gICAgZmxvb3JQbGFuRm9sZGVySWQ6IHN0cmluZztcbiAgICBwaG90b3NGb2xkZXJJZDogc3RyaW5nO1xuICAgIGFtZW5pdGllczogQW1lbml0eU5hbWVbXTtcbiAgICB1bml0czogVW5pdERldGFpbHNbXTtcbiAgICBhY3RpdmU6IGJvb2xlYW47XG4gICAgd2ViU3BlY2lhbHM6IFdlYlNwZWNpYWxEZXRhaWxzW107XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRmxvb3JwbGFuQ2FyZERhdGEge1xuICAgIGlkOiBzdHJpbmc7XG4gICAgbmFtZTogc3RyaW5nO1xuICAgIGFjdGl2ZTogYm9vbGVhbjtcbiAgICBiZWRyb29tOiBudW1iZXI7XG4gICAgYmF0aHJvb206IG51bWJlcjtcbiAgICBjb3ZlckltYWdlOiBzdHJpbmc7XG4gICAgZmVhdHVyZWQ6IGJvb2xlYW47XG4gICAgc3R5bGU6IEZsb29ycGxhblN0eWxlO1xuICAgIHNwZWNpYWxSZW50OiBudW1iZXIsXG4gICAgc3BlY2lhbFJlbnRTdGFydERhdGU6IHN0cmluZyxcbiAgICBzcGVjaWFsUmVudEVuZERhdGU6IHN0cmluZyxcbiAgICB2aXJ0dWFsVG91ckxpbms6IHN0cmluZztcbiAgICB2aWRlb1RvdXJMaW5rOiBzdHJpbmc7XG4gICAgcGhvdG9zRm9sZGVySWQ6IHN0cmluZztcbiAgICB1bml0czogVW5pdENhcmREYXRhW107XG4gICAgd2ViU3BlY2lhbHM6IHN0cmluZyBbXTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBGbG9vcnBsYW4ge1xuICAgIGlkOiBzdHJpbmc7XG4gICAgbmFtZTogc3RyaW5nO1xuICAgIGJlZHJvb206IG51bWJlcjtcbiAgICBiYXRocm9vbTogbnVtYmVyO1xuICAgIHN0eWxlOiBGbG9vcnBsYW5TdHlsZTtcbiAgICBmZWF0dXJlZDogYm9vbGVhbjtcbiAgICBwYXRpb0luY2x1ZGVkOiBib29sZWFuO1xuICAgIGdyZWVuQ2VydGlmaWVkOiBib29sZWFuO1xuICAgIHZpZGVvVG91ckxpbms6IHN0cmluZztcbiAgICB0aHJlZVNpeHR5VmlkZW9Ub3VyTGluazogc3RyaW5nO1xuICAgIHZpcnR1YWxUb3VyTGluazogc3RyaW5nO1xuICAgIHBob3RvOiBzdHJpbmcgfCBudWxsLFxuICAgIGNvdmVySW1hZ2U6IHN0cmluZyB8IG51bGwsXG4gICAgZmxvb3JQbGFuRm9sZGVySWQ6IHN0cmluZztcbiAgICBwaG90b3NGb2xkZXJJZDogc3RyaW5nO1xuICAgIGFkZHJlc3M6IHN0cmluZztcbiAgICB6aXBjb2RlOiBzdHJpbmc7XG4gICAgZGVzY3JpcHRpb246IHN0cmluZztcbiAgICB2YW5pdHlMaW5rOiBzdHJpbmc7XG4gICAgc3BlY2lhbFJlbnQ6IG51bWJlcixcbiAgICBzcGVjaWFsUmVudFN0YXJ0RGF0ZTogc3RyaW5nLFxuICAgIHNwZWNpYWxSZW50RW5kRGF0ZTogc3RyaW5nLFxuICAgIGh0bWxUaXRsZTogc3RyaW5nO1xuICAgIG1ldGFEZXNjcmlwdGlvbjogc3RyaW5nO1xuICAgIGNvbnZlcnNpb25UcmFja2luZ0lkMTogc3RyaW5nO1xuICAgIGNvbnZlcnNpb25UcmFja2luZ0lkMjogc3RyaW5nO1xuICAgIGN1c3RvbUNvZGU6IHN0cmluZztcbiAgICB1dGlsaXRpZXM6IFV0aWxpdHlOYW1lW107XG4gICAgYW1lbml0aWVzOiBBbWVuaXR5TmFtZVtdO1xuICAgIHByb3BlcnR5OiBQcm9wZXJ0eU5hbWU7XG4gICAgdW5pdHM6IFVuaXRbXTtcbiAgICBsYXN0TW9kaWZpZWRCeTogc3RyaW5nO1xuICAgIGxhc3RNb2RpZmllZERhdGU6IHN0cmluZztcbiAgICBhY3RpdmU6IGJvb2xlYW47XG4gICAgd2ViU3BlY2lhbHM6IFdlYlNwZWNpYWxEZXRhaWxzW107XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRmxvb3JwbGFuU3BvdGxpZ2h0IHtcbiAgICBpZDogc3RyaW5nO1xuICAgIG5hbWU6IHN0cmluZztcbiAgICBtZXRhRGVzY3JpcHRpb246IHN0cmluZztcbiAgICBiZWRyb29tOiBudW1iZXI7XG4gICAgYmF0aHJvb206IG51bWJlcjtcbiAgICBzdHlsZTogRmxvb3JwbGFuU3R5bGU7XG4gICAgZmVhdHVyZWQ6IGJvb2xlYW47XG4gICAgY292ZXJJbWFnZTogc3RyaW5nO1xuICAgIHVuaXRzOiBVbml0U3BvdGxpZ2h0W107XG4gICAgYWN0aXZlOiBib29sZWFuO1xuICAgIHByb3BlcnR5OiBQcm9wZXJ0eU5hbWU7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVW5pdFNwb3RsaWdodCB7XG4gICAgaWQ6IHN0cmluZztcbiAgICBzcXVhcmVGb290OiBudW1iZXI7XG4gICAgcmVudDogbnVtYmVyO1xuICAgIGFjdGl2ZTogYm9vbGVhbjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBQcm9wZXJ0eU5hbWUge1xuICAgIG5hbWU6IHN0cmluZztcbiAgICBpZDogc3RyaW5nO1xuICAgIGFjdGl2ZTogYm9vbGVhbjtcbiAgICBlbWFpbDogc3RyaW5nO1xuICAgIHBob25lOiBzdHJpbmc7XG4gICAgYWRkcmVzczogc3RyaW5nO1xuICAgIHppcGNvZGU6IHN0cmluZztcbiAgICBidXNSb3V0ZXM6IFByb3BlcnR5QnVzUm91dGVbXTtcbiAgICBsZWFzZVR5cGU6IExlYXNlVHlwZTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBGbG9vcnBsYW5OYW1lIHtcbiAgICBuYW1lOiBzdHJpbmc7XG4gICAgaWQ6IHN0cmluZztcbiAgICBhY3RpdmU6IGJvb2xlYW47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgU2ltaWxhckZsb29ycGxhbiB7XG4gICAgc2ltaWxhclRvOiBGbG9vcnBsYW5OYW1lO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEZsb29ycGxhblZhcmlhdGlvbiB7XG4gICAgdmFyaWF0aW9uOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVGVzdGltb25pYWwge1xuICAgIHRlc3RpbW9uaWFsOiBzdHJpbmc7XG4gICAgdGVuYW50OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgV2ViU3BlY2lhbCB7XG4gICAgZGVzY3JpcHRpb246IHN0cmluZztcbiAgICBzdGFydERhdGU6IHN0cmluZztcbiAgICBlbmREYXRlOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgV2ViU3BlY2lhbERldGFpbHMgZXh0ZW5kcyBXZWJTcGVjaWFsIHtcbiAgICBpZDogc3RyaW5nO1xufVxuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFHTyxNQUFNQSxRQUFRLEdBQUFDLE9BQUEsQ0FBQUQsUUFBQSxHQUFHLENBQUM7QUFDbEIsTUFBTUUsUUFBUSxHQUFBRCxPQUFBLENBQUFDLFFBQUEsR0FBRyxJQUFJO0FBQUMsSUFFakJDLGNBQWMsR0FBQUYsT0FBQSxDQUFBRSxjQUFBLDBCQUFkQSxjQUFjO0VBQWRBLGNBQWM7RUFBZEEsY0FBYztFQUFkQSxjQUFjO0VBQWRBLGNBQWM7RUFBZEEsY0FBYztFQUFkQSxjQUFjO0VBQUEsT0FBZEEsY0FBYztBQUFBO0FBQUEsSUFTZEMsV0FBVyxHQUFBSCxPQUFBLENBQUFHLFdBQUEsMEJBQVhBLFdBQVc7RUFBWEEsV0FBVztFQUFYQSxXQUFXO0VBQVhBLFdBQVc7RUFBWEEsV0FBVztFQUFYQSxXQUFXO0VBQVhBLFdBQVc7RUFBWEEsV0FBVztFQUFYQSxXQUFXO0VBQUEsT0FBWEEsV0FBVztBQUFBO0FBQUEsSUF5QlhDLFdBQVcsR0FBQUosT0FBQSxDQUFBSSxXQUFBLDBCQUFYQSxXQUFXO0VBQVhBLFdBQVc7RUFBWEEsV0FBVztFQUFBLE9BQVhBLFdBQVc7QUFBQSJ9
@@ -18,6 +18,7 @@ var _VirtualTour = require("../../gallery/VirtualTour");
18
18
  var _GalleryModal = require("../../gallery/GalleryModal");
19
19
  var _GalleryHeroMobile = require("../../gallery/GalleryHeroMobile");
20
20
  var _HeroBadgeStats = require("./HeroBadgeStats");
21
+ var _FloorplanPrice = require("../card/FloorplanPrice");
21
22
  function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
22
23
  function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
23
24
  const FloorplanHero = _ref => {
@@ -156,9 +157,15 @@ const FloorplanHero = _ref => {
156
157
  className: "floorplan--two-columns"
157
158
  }, /*#__PURE__*/_react.default.createElement("div", {
158
159
  className: "floorplan-column-left"
159
- }, /*#__PURE__*/_react.default.createElement("h3", null, floorplan.name), floorplan.units.length > 0 ? /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("h4", null, "$", (0, _Utils.rangeFrom)(floorplan.units, "rent"), "/mo"), /*#__PURE__*/_react.default.createElement("p", {
160
+ }, /*#__PURE__*/_react.default.createElement("h3", null, floorplan.name), /*#__PURE__*/_react.default.createElement("h4", null, /*#__PURE__*/_react.default.createElement(_FloorplanPrice.FloorplanPrice, {
161
+ unitRents: floorplan.units,
162
+ specialRent: floorplan.specialRent,
163
+ specialRentStartDate: floorplan.specialRentStartDate,
164
+ specialRentEndDate: floorplan.specialRentEndDate,
165
+ invertColor: true
166
+ })), /*#__PURE__*/_react.default.createElement("p", {
160
167
  className: "floorplan--description"
161
- }, printFloorplanAddress())) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null), /*#__PURE__*/_react.default.createElement("div", {
168
+ }, printFloorplanAddress()), /*#__PURE__*/_react.default.createElement("div", {
162
169
  className: "floorplan--featured"
163
170
  }, /*#__PURE__*/_react.default.createElement(_muncherUi.Button, {
164
171
  size: "small",
@@ -196,4 +203,4 @@ const FloorplanHero = _ref => {
196
203
  }))))));
197
204
  };
198
205
  exports.FloorplanHero = FloorplanHero;
199
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_muncherUi","_AssetService","_GalleryHeroSkeleton","_GalleryHeroMain","_Utils","_AssetModal","_FloorplanService","_VideoTours","_VirtualTour","_GalleryModal","_GalleryHeroMobile","_HeroBadgeStats","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","prototype","hasOwnProperty","call","i","set","FloorplanHero","_ref","floorplan","contactClickHandler","applyClickHandler","handleRefToMap","webSpecials","assets","setAssets","useState","isAssetsLoading","setIsAssetsLoading","videoTours","setVideoTours","virtualTour","setVirtualTour","undefined","showFloorplanModal","setShowFloorplanModal","totalPages","setTotalPages","toursCount","setToursCount","currentView","setCurrentView","assetInFocus","setAssetInFocus","assetIndex","setAssetIndex","showModal","setShowModal","FIRST_PAGE_ASSET_COUNT","GRID_SIZE","imageClickedHandler","image","findIndex","value","id","modalCloseHandler","useEffect","virtualTourLink","tourLinks","videoTourLink","push","threeSixtyVideoTourLink","otherAssetCounts","length","images","extractIdFrom","coverImage","name","photosFolderId","getAssetsFrom","then","galleryAssets","totalAssets","pages","Math","trunc","finally","console","log","isFirstSliderPage","slideIndex","imageCountForFirstPage","getImagesForFirstSliderPage","slice","assetsToShow","startIndex","endIndex","printFloorplanAddress","address","floorplanAddress","city","state","zipcode","createElement","className","GalleryHeroSkeleton","Fragment","GalleryModal","propertyId","property","ItemSlider","sliderItems","Array","map","x","GalleryHeroMain","isAvailableNow","isFloorplanAvailable","isFirst","GalleryHeroMobile","VideoTours","videoTourUrls","VirtualTour","virtualTourUrl","HeroBadgeStats","AssetModal","assetUrl","photo","assetTitle","units","rangeFrom","Button","size","onClick","Icon","orientation","busRoutes","busRoute","index","key","href","busRouteLink","target","rel","variant","ShareButton","title","exports"],"sources":["../../../src/floorplan/section/FloorplanHero.tsx"],"sourcesContent":["import React, {useEffect, useState} from \"react\";\nimport \"./assets/FloorplanHero.scss\";\nimport {Button, Icon, ItemSlider, ShareButton} from \"@contentmunch/muncher-ui\";\nimport {Asset} from \"../../asset/data/Asset\";\nimport {getAssetsFrom} from \"../../asset/service/AssetService\";\nimport {GalleryHeroSkeleton} from \"../../gallery/GalleryHeroSkeleton\";\nimport {GalleryHeroMain} from \"../../gallery/GalleryHeroMain\";\nimport {extractIdFrom, rangeFrom} from \"../../utils/Utils\";\nimport {Floorplan, WebSpecial} from \"../data/Floorplan\";\nimport {AssetModal} from \"../../asset/AssetModal\";\nimport {floorplanAddress, isFloorplanAvailable} from \"../service/FloorplanService\";\nimport {VideoTours} from \"../../gallery/VideoTours\";\nimport {VirtualTour} from \"../../gallery/VirtualTour\";\nimport {GalleryModal} from \"../../gallery/GalleryModal\";\nimport {GalleryHeroMobile} from \"../../gallery/GalleryHeroMobile\";\nimport {HeroBadgeStats} from \"./HeroBadgeStats\";\n\nexport const FloorplanHero: React.FC<FloorplanProps> = (\n    {floorplan, contactClickHandler, applyClickHandler, handleRefToMap, webSpecials}) => {\n    const [assets, setAssets] = useState<Asset[]>([]);\n    const [isAssetsLoading, setIsAssetsLoading] = useState(true);\n    const [videoTours, setVideoTours] = useState<string[]>([]);\n    const [virtualTour, setVirtualTour] = useState<string | undefined>(undefined);\n    const [showFloorplanModal, setShowFloorplanModal] = useState(false);\n    const [totalPages, setTotalPages] = useState(1);\n    const [toursCount, setToursCount] = useState(0);\n    const [currentView, setCurrentView] = useState<\"photo\" | \"virtual tour\" | \"video tour\">(\"photo\");\n    const [assetInFocus, setAssetInFocus] = useState<Asset>({} as Asset);\n    const [assetIndex, setAssetIndex] = useState(0);\n    const [showModal, setShowModal] = useState(false);\n\n    const FIRST_PAGE_ASSET_COUNT = 5;\n    const GRID_SIZE = 8;\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    useEffect(() => {\n        if (floorplan.virtualTourLink)\n            setVirtualTour(floorplan.virtualTourLink);\n        const tourLinks = [];\n        if (floorplan.videoTourLink)\n            tourLinks.push(floorplan.videoTourLink);\n        if (floorplan.threeSixtyVideoTourLink)\n            tourLinks.push(floorplan.threeSixtyVideoTourLink);\n        setVideoTours(tourLinks);\n\n        let otherAssetCounts = (tourLinks.length > 0 ? 1 : 0) + (floorplan.virtualTourLink ? 1 : 0);\n        setToursCount(otherAssetCounts);\n        const images: Asset[] = [];\n        images.push({id: extractIdFrom(floorplan.coverImage), name: \"cover image\"} as Asset);\n\n        if (floorplan.photosFolderId) {\n            getAssetsFrom(floorplan.photosFolderId).then(galleryAssets => {\n                images.push(...galleryAssets);\n\n                let totalAssets = images.length + otherAssetCounts;\n\n                if (totalAssets > FIRST_PAGE_ASSET_COUNT) {\n\n                    let pages = Math.trunc(((totalAssets - FIRST_PAGE_ASSET_COUNT) / 8) + 1);\n\n                    if ((totalAssets - FIRST_PAGE_ASSET_COUNT) % 8 === 0) {\n                        setTotalPages(pages);\n                    } else\n                        setTotalPages(pages + 1);\n                }\n\n            }).finally(() => {\n                setAssets(images);\n                setIsAssetsLoading(false);\n            });\n        } else {\n            setAssets(images);\n            console.log(images)\n            setIsAssetsLoading(false);\n        }\n\n    }, [floorplan])\n\n    const isFirstSliderPage = (slideIndex: number) => slideIndex === 0;\n    const imageCountForFirstPage = () => FIRST_PAGE_ASSET_COUNT - toursCount;\n\n    const getImagesForFirstSliderPage = assets.slice(0, assets.length >= imageCountForFirstPage() ? imageCountForFirstPage() : assets.length);\n    const assetsToShow = (slideIndex: number) => {\n\n        if (isFirstSliderPage(slideIndex))\n            return getImagesForFirstSliderPage;\n\n        const startIndex = imageCountForFirstPage() + (slideIndex - 1) * 8;\n        const endIndex = startIndex + GRID_SIZE;\n\n        return assets.slice(startIndex, endIndex);\n    };\n\n    const printFloorplanAddress = () => {\n        const address = floorplanAddress(floorplan);\n        return address.address + \", \" + address.city + \", \" + address.state + \" \" + address.zipcode;\n    }\n    return (\n        <section className=\"section-floorplan--hero\">\n            {isAssetsLoading ? <GalleryHeroSkeleton/> :\n                <>\n                    <div className=\"gallery-hero\">\n                        <GalleryModal assets={assets} assetInFocus={assetInFocus}\n                                      setAssetInFocus={setAssetInFocus} showModal={showModal}\n                                      assetIndex={assetIndex} setAssetIndex={setAssetIndex}\n                                      modalCloseHandler={modalCloseHandler} propertyId={floorplan.property.id}/>\n                        {currentView === \"photo\" ?\n                            <>\n                                <div className=\"photo-view main\">\n                                    <ItemSlider\n                                        sliderItems={[...Array(totalPages)].map((x, i) =>\n                                            <GalleryHeroMain isAvailableNow={isFloorplanAvailable(floorplan)}\n                                                             virtualTour={virtualTour} isFirst={i === 0}\n                                                             toursCount={toursCount}\n                                                             webSpecials={webSpecials}\n                                                             setCurrentView={setCurrentView}\n                                                             imageClickedHandler={imageClickedHandler}\n                                                             assetsToShow={assetsToShow(i)}\n                                                             propertyId={floorplan.property.id}/>\n                                        )}/>\n                                </div>\n                                <div className=\"photo-view mobile\">\n                                    <GalleryHeroMobile assets={assets} toursCount={toursCount}\n                                                       virtualTour={virtualTour}\n                                                       setCurrentView={setCurrentView}\n                                                       imageClickedHandler={imageClickedHandler}\n                                                       webSpecials={webSpecials}\n                                                       isAvailableNow={isFloorplanAvailable(floorplan)}\n                                                       propertyId={floorplan.property.id}/>\n                                </div>\n                            </> : \"\"\n                        }\n\n                        {currentView === \"video tour\" ? <VideoTours videoTourUrls={videoTours}/> : \"\"}\n                        {currentView === \"virtual tour\" ? <VirtualTour virtualTourUrl={virtualTour}/> : \"\"}\n                        <HeroBadgeStats currentView={currentView} setCurrentView={setCurrentView}\n                                        totalAssets={assets?.length} videoTours={videoTours} virtualTour={virtualTour}/>\n\n                    </div>\n                </>\n\n            }\n            <AssetModal assetUrl={floorplan.photo} assetTitle=\"Floorplan image\" showModal={showFloorplanModal}\n                        setShowModal={setShowFloorplanModal} propertyId={floorplan.property.id}/>\n            <div className=\"container\">\n                <div className=\"floorplan--two-columns\">\n                    <div className=\"floorplan-column-left\">\n                        <h3>{floorplan.name}</h3>\n                        {\n                            floorplan.units.length > 0 ?\n                                <>\n                                    <h4>${rangeFrom(floorplan.units, \"rent\")}/mo</h4>\n                                    <p className=\"floorplan--description\">{printFloorplanAddress()}</p>\n                                </> : <></>\n                        }\n                        <div className=\"floorplan--featured\">\n                            <Button size=\"small\" onClick={() => setShowFloorplanModal(true)}>\n                                <Icon name=\"max\" orientation=\"right\">ViewFloorplan</Icon>\n                            </Button>\n                            |&nbsp;&nbsp;\n                            <Button size=\"small\" onClick={() => handleRefToMap()}>\n                                <Icon orientation=\"right\" name=\"map\">View on Map</Icon>\n                            </Button>\n                            {floorplan.property.busRoutes.length > 0 ?\n                                <p>Bus Routes:&nbsp;\n                                    {floorplan.property.busRoutes.map((busRoute, index) =>\n                                        <span key={\"bus-route-\" + index}>\n                                            <a href={busRoute.busRouteLink} target=\"_blank\"\n                                               rel=\"noreferrer\">{busRoute.busRoute}</a>\n                                            {index < floorplan.property.busRoutes.length - 1 ? \", \" : \"\"}\n                                        </span>\n                                    )}\n                                </p>\n                                : \"\"}\n                        </div>\n                    </div>\n                    <div className=\"main\">\n                        <div className=\" floorplan-column-right\">\n                            <Button variant=\"primary\" size=\"medium\" onClick={contactClickHandler}>contact us</Button>\n                            <Button variant=\"tertiary\" size=\"medium\" onClick={applyClickHandler}>apply</Button>\n                            <ShareButton title=\"Check out this apartment\" size=\"large\"/>\n                        </div>\n                    </div>\n                </div>\n            </div>\n        </section>\n    );\n};\n\nexport interface FloorplanProps {\n    floorplan: Floorplan;\n    webSpecials: WebSpecial[];\n    contactClickHandler: () => void;\n    applyClickHandler: () => void;\n    handleRefToMap: () => void;\n}\n"],"mappings":"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"}
206
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_muncherUi","_AssetService","_GalleryHeroSkeleton","_GalleryHeroMain","_Utils","_AssetModal","_FloorplanService","_VideoTours","_VirtualTour","_GalleryModal","_GalleryHeroMobile","_HeroBadgeStats","_FloorplanPrice","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","prototype","hasOwnProperty","call","i","set","FloorplanHero","_ref","floorplan","contactClickHandler","applyClickHandler","handleRefToMap","webSpecials","assets","setAssets","useState","isAssetsLoading","setIsAssetsLoading","videoTours","setVideoTours","virtualTour","setVirtualTour","undefined","showFloorplanModal","setShowFloorplanModal","totalPages","setTotalPages","toursCount","setToursCount","currentView","setCurrentView","assetInFocus","setAssetInFocus","assetIndex","setAssetIndex","showModal","setShowModal","FIRST_PAGE_ASSET_COUNT","GRID_SIZE","imageClickedHandler","image","findIndex","value","id","modalCloseHandler","useEffect","virtualTourLink","tourLinks","videoTourLink","push","threeSixtyVideoTourLink","otherAssetCounts","length","images","extractIdFrom","coverImage","name","photosFolderId","getAssetsFrom","then","galleryAssets","totalAssets","pages","Math","trunc","finally","console","log","isFirstSliderPage","slideIndex","imageCountForFirstPage","getImagesForFirstSliderPage","slice","assetsToShow","startIndex","endIndex","printFloorplanAddress","address","floorplanAddress","city","state","zipcode","createElement","className","GalleryHeroSkeleton","Fragment","GalleryModal","propertyId","property","ItemSlider","sliderItems","Array","map","x","GalleryHeroMain","isAvailableNow","isFloorplanAvailable","isFirst","GalleryHeroMobile","VideoTours","videoTourUrls","VirtualTour","virtualTourUrl","HeroBadgeStats","AssetModal","assetUrl","photo","assetTitle","FloorplanPrice","unitRents","units","specialRent","specialRentStartDate","specialRentEndDate","invertColor","Button","size","onClick","Icon","orientation","busRoutes","busRoute","index","key","href","busRouteLink","target","rel","variant","ShareButton","title","exports"],"sources":["../../../src/floorplan/section/FloorplanHero.tsx"],"sourcesContent":["import React, {useEffect, useState} from \"react\";\nimport \"./assets/FloorplanHero.scss\";\nimport {Button, Icon, ItemSlider, ShareButton} from \"@contentmunch/muncher-ui\";\nimport {Asset} from \"../../asset/data/Asset\";\nimport {getAssetsFrom} from \"../../asset/service/AssetService\";\nimport {GalleryHeroSkeleton} from \"../../gallery/GalleryHeroSkeleton\";\nimport {GalleryHeroMain} from \"../../gallery/GalleryHeroMain\";\nimport {extractIdFrom} from \"../../utils/Utils\";\nimport {Floorplan, WebSpecial} from \"../data/Floorplan\";\nimport {AssetModal} from \"../../asset/AssetModal\";\nimport {floorplanAddress, isFloorplanAvailable} from \"../service/FloorplanService\";\nimport {VideoTours} from \"../../gallery/VideoTours\";\nimport {VirtualTour} from \"../../gallery/VirtualTour\";\nimport {GalleryModal} from \"../../gallery/GalleryModal\";\nimport {GalleryHeroMobile} from \"../../gallery/GalleryHeroMobile\";\nimport {HeroBadgeStats} from \"./HeroBadgeStats\";\nimport {FloorplanPrice} from \"../card/FloorplanPrice\";\n\nexport const FloorplanHero: React.FC<FloorplanProps> = (\n    {floorplan, contactClickHandler, applyClickHandler, handleRefToMap, webSpecials}) => {\n    const [assets, setAssets] = useState<Asset[]>([]);\n    const [isAssetsLoading, setIsAssetsLoading] = useState(true);\n    const [videoTours, setVideoTours] = useState<string[]>([]);\n    const [virtualTour, setVirtualTour] = useState<string | undefined>(undefined);\n    const [showFloorplanModal, setShowFloorplanModal] = useState(false);\n    const [totalPages, setTotalPages] = useState(1);\n    const [toursCount, setToursCount] = useState(0);\n    const [currentView, setCurrentView] = useState<\"photo\" | \"virtual tour\" | \"video tour\">(\"photo\");\n    const [assetInFocus, setAssetInFocus] = useState<Asset>({} as Asset);\n    const [assetIndex, setAssetIndex] = useState(0);\n    const [showModal, setShowModal] = useState(false);\n\n    const FIRST_PAGE_ASSET_COUNT = 5;\n    const GRID_SIZE = 8;\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    useEffect(() => {\n        if (floorplan.virtualTourLink)\n            setVirtualTour(floorplan.virtualTourLink);\n        const tourLinks = [];\n        if (floorplan.videoTourLink)\n            tourLinks.push(floorplan.videoTourLink);\n        if (floorplan.threeSixtyVideoTourLink)\n            tourLinks.push(floorplan.threeSixtyVideoTourLink);\n        setVideoTours(tourLinks);\n\n        let otherAssetCounts = (tourLinks.length > 0 ? 1 : 0) + (floorplan.virtualTourLink ? 1 : 0);\n        setToursCount(otherAssetCounts);\n        const images: Asset[] = [];\n        images.push({id: extractIdFrom(floorplan.coverImage), name: \"cover image\"} as Asset);\n\n        if (floorplan.photosFolderId) {\n            getAssetsFrom(floorplan.photosFolderId).then(galleryAssets => {\n                images.push(...galleryAssets);\n\n                let totalAssets = images.length + otherAssetCounts;\n\n                if (totalAssets > FIRST_PAGE_ASSET_COUNT) {\n\n                    let pages = Math.trunc(((totalAssets - FIRST_PAGE_ASSET_COUNT) / 8) + 1);\n\n                    if ((totalAssets - FIRST_PAGE_ASSET_COUNT) % 8 === 0) {\n                        setTotalPages(pages);\n                    } else\n                        setTotalPages(pages + 1);\n                }\n\n            }).finally(() => {\n                setAssets(images);\n                setIsAssetsLoading(false);\n            });\n        } else {\n            setAssets(images);\n            console.log(images)\n            setIsAssetsLoading(false);\n        }\n\n    }, [floorplan])\n\n    const isFirstSliderPage = (slideIndex: number) => slideIndex === 0;\n    const imageCountForFirstPage = () => FIRST_PAGE_ASSET_COUNT - toursCount;\n\n    const getImagesForFirstSliderPage = assets.slice(0, assets.length >= imageCountForFirstPage() ? imageCountForFirstPage() : assets.length);\n    const assetsToShow = (slideIndex: number) => {\n\n        if (isFirstSliderPage(slideIndex))\n            return getImagesForFirstSliderPage;\n\n        const startIndex = imageCountForFirstPage() + (slideIndex - 1) * 8;\n        const endIndex = startIndex + GRID_SIZE;\n\n        return assets.slice(startIndex, endIndex);\n    };\n\n    const printFloorplanAddress = () => {\n        const address = floorplanAddress(floorplan);\n        return address.address + \", \" + address.city + \", \" + address.state + \" \" + address.zipcode;\n    }\n    return (\n        <section className=\"section-floorplan--hero\">\n            {isAssetsLoading ? <GalleryHeroSkeleton/> :\n                <>\n                    <div className=\"gallery-hero\">\n                        <GalleryModal assets={assets} assetInFocus={assetInFocus}\n                                      setAssetInFocus={setAssetInFocus} showModal={showModal}\n                                      assetIndex={assetIndex} setAssetIndex={setAssetIndex}\n                                      modalCloseHandler={modalCloseHandler} propertyId={floorplan.property.id}/>\n                        {currentView === \"photo\" ?\n                            <>\n                                <div className=\"photo-view main\">\n                                    <ItemSlider\n                                        sliderItems={[...Array(totalPages)].map((x, i) =>\n                                            <GalleryHeroMain isAvailableNow={isFloorplanAvailable(floorplan)}\n                                                             virtualTour={virtualTour} isFirst={i === 0}\n                                                             toursCount={toursCount}\n                                                             webSpecials={webSpecials}\n                                                             setCurrentView={setCurrentView}\n                                                             imageClickedHandler={imageClickedHandler}\n                                                             assetsToShow={assetsToShow(i)}\n                                                             propertyId={floorplan.property.id}/>\n                                        )}/>\n                                </div>\n                                <div className=\"photo-view mobile\">\n                                    <GalleryHeroMobile assets={assets} toursCount={toursCount}\n                                                       virtualTour={virtualTour}\n                                                       setCurrentView={setCurrentView}\n                                                       imageClickedHandler={imageClickedHandler}\n                                                       webSpecials={webSpecials}\n                                                       isAvailableNow={isFloorplanAvailable(floorplan)}\n                                                       propertyId={floorplan.property.id}/>\n                                </div>\n                            </> : \"\"\n                        }\n\n                        {currentView === \"video tour\" ? <VideoTours videoTourUrls={videoTours}/> : \"\"}\n                        {currentView === \"virtual tour\" ? <VirtualTour virtualTourUrl={virtualTour}/> : \"\"}\n                        <HeroBadgeStats currentView={currentView} setCurrentView={setCurrentView}\n                                        totalAssets={assets?.length} videoTours={videoTours} virtualTour={virtualTour}/>\n\n                    </div>\n                </>\n\n            }\n            <AssetModal assetUrl={floorplan.photo} assetTitle=\"Floorplan image\" showModal={showFloorplanModal}\n                        setShowModal={setShowFloorplanModal} propertyId={floorplan.property.id}/>\n            <div className=\"container\">\n                <div className=\"floorplan--two-columns\">\n                    <div className=\"floorplan-column-left\">\n                        <h3>{floorplan.name}</h3>\n                        <h4><FloorplanPrice unitRents={floorplan.units} specialRent={floorplan.specialRent}\n                                            specialRentStartDate={floorplan.specialRentStartDate}\n                                            specialRentEndDate={floorplan.specialRentEndDate}\n                                            invertColor={true}\n                        />\n                        </h4>\n                        <p className=\"floorplan--description\">{printFloorplanAddress()}</p>\n\n                        <div className=\"floorplan--featured\">\n                            <Button size=\"small\" onClick={() => setShowFloorplanModal(true)}>\n                                <Icon name=\"max\" orientation=\"right\">ViewFloorplan</Icon>\n                            </Button>\n                            |&nbsp;&nbsp;\n                            <Button size=\"small\" onClick={() => handleRefToMap()}>\n                                <Icon orientation=\"right\" name=\"map\">View on Map</Icon>\n                            </Button>\n                            {floorplan.property.busRoutes.length > 0 ?\n                                <p>Bus Routes:&nbsp;\n                                    {floorplan.property.busRoutes.map((busRoute, index) =>\n                                        <span key={\"bus-route-\" + index}>\n                                            <a href={busRoute.busRouteLink} target=\"_blank\"\n                                               rel=\"noreferrer\">{busRoute.busRoute}</a>\n                                            {index < floorplan.property.busRoutes.length - 1 ? \", \" : \"\"}\n                                        </span>\n                                    )}\n                                </p>\n                                : \"\"}\n                        </div>\n                    </div>\n                    <div className=\"main\">\n                        <div className=\" floorplan-column-right\">\n                            <Button variant=\"primary\" size=\"medium\" onClick={contactClickHandler}>contact us</Button>\n                            <Button variant=\"tertiary\" size=\"medium\" onClick={applyClickHandler}>apply</Button>\n                            <ShareButton title=\"Check out this apartment\" size=\"large\"/>\n                        </div>\n                    </div>\n                </div>\n            </div>\n        </section>\n    );\n};\n\nexport interface FloorplanProps {\n    floorplan: Floorplan;\n    webSpecials: WebSpecial[];\n    contactClickHandler: () => void;\n    applyClickHandler: () => void;\n    handleRefToMap: () => void;\n}\n"],"mappings":"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"}
@@ -11,6 +11,7 @@ var _muncherUi = require("@contentmunch/muncher-ui");
11
11
  var _HeroImageCard = require("./HeroImageCard");
12
12
  var _icon = _interopRequireDefault(require("../floorplan/card/assets/360-icon.png"));
13
13
  var _videoIcon = _interopRequireDefault(require("../floorplan/card/assets/video-icon.png"));
14
+ var _SpecialOfferBadge = require("../specialOffer/SpecialOfferBadge");
14
15
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
15
16
  const GalleryHeroMain = _ref => {
16
17
  let {
@@ -35,15 +36,13 @@ const GalleryHeroMain = _ref => {
35
36
  }), /*#__PURE__*/_react.default.createElement("p", null, "Video Tour"));
36
37
  return /*#__PURE__*/_react.default.createElement("div", {
37
38
  className: "div-gallery"
38
- }, isFirst && isAvailableNow ? /*#__PURE__*/_react.default.createElement("div", {
39
+ }, /*#__PURE__*/_react.default.createElement("div", {
39
40
  className: "badge--info"
40
- }, /*#__PURE__*/_react.default.createElement(_muncherUi.Badge, {
41
+ }, isFirst && isAvailableNow ? /*#__PURE__*/_react.default.createElement(_muncherUi.Badge, {
41
42
  variant: "secondary"
42
- }, "Available Now")) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null), isFirst && webSpecials.length > 0 ? /*#__PURE__*/_react.default.createElement("div", {
43
+ }, "Available Now") : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null), isFirst && webSpecials.length > 0 ? /*#__PURE__*/_react.default.createElement(_SpecialOfferBadge.SpecialOfferBadge, null) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null)), isFirst && webSpecials.length > 0 ? /*#__PURE__*/_react.default.createElement("div", {
43
44
  className: "gallery--information"
44
- }, /*#__PURE__*/_react.default.createElement(_muncherUi.Badge, {
45
- variant: "secondary"
46
- }, /*#__PURE__*/_react.default.createElement("p", null, webSpecials[0].description))) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null), /*#__PURE__*/_react.default.createElement("div", {
45
+ }, /*#__PURE__*/_react.default.createElement("p", null, webSpecials[0].description)) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null), /*#__PURE__*/_react.default.createElement("div", {
47
46
  className: "gallery-hero-two-columns"
48
47
  }, isFirst ? /*#__PURE__*/_react.default.createElement("div", {
49
48
  className: assetsToShow.length < 2 ? "gallery-hero-one" : "gallery-hero-column-one"
@@ -70,4 +69,4 @@ const GalleryHeroMain = _ref => {
70
69
  }))) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null)));
71
70
  };
72
71
  exports.GalleryHeroMain = GalleryHeroMain;
73
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_AssetService","_muncherUi","_HeroImageCard","_icon","_videoIcon","obj","__esModule","default","GalleryHeroMain","_ref","virtualTour","setCurrentView","isAvailableNow","webSpecials","assetsToShow","isFirst","toursCount","imageClickedHandler","propertyId","cardImageIcon","i","createElement","Fragment","src","tourIcon","alt","height","videoIcon","className","Badge","variant","length","description","slice","map","asset","assetUrlFrom","id","name","key","onClick","Array","x","HeroImageCard","backgroundImage","exports"],"sources":["../../src/gallery/GalleryHeroMain.tsx"],"sourcesContent":["import React from \"react\";\nimport './assets/GalleryHero.scss';\nimport {Asset} from \"../asset/data/Asset\";\nimport {assetUrlFrom} from \"../asset/service/AssetService\";\nimport {Badge} from \"@contentmunch/muncher-ui\";\nimport {HeroImageCard} from \"./HeroImageCard\";\nimport tourIcon from \"../floorplan/card/assets/360-icon.png\";\nimport videoIcon from \"../floorplan/card/assets/video-icon.png\";\nimport {WebSpecial} from \"../floorplan/data/Floorplan\";\n\nexport const GalleryHeroMain: React.FC<GalleryHeroProps> = (\n    {\n        virtualTour, setCurrentView, isAvailableNow, webSpecials,\n        assetsToShow, isFirst, toursCount, imageClickedHandler, propertyId\n    }) => {\n\n    const cardImageIcon = (i: number) => virtualTour && i === 0 ?\n        <>\n            <img src={tourIcon} alt=\"tour icon\" height={50}/>\n            <p>Virtual Tour</p>\n        </> :\n        <>\n            <img src={videoIcon} alt=\"video icon\" height={40}/>\n            <p>Video Tour</p>\n        </>\n\n    return (\n        <div className=\"div-gallery\">\n            {isFirst && isAvailableNow ?\n                <div className=\"badge--info\"><Badge variant=\"secondary\">Available Now</Badge></div> : <></>}\n\n            {\n                isFirst && webSpecials.length > 0 ?\n                    <div className=\"gallery--information\"><Badge variant=\"secondary\"><p>{webSpecials[0].description}</p></Badge></div> : <></>\n            }\n            <div className=\"gallery-hero-two-columns\">\n                {isFirst ?\n                    <div\n                        className={assetsToShow.length < 2 ? \"gallery-hero-one\" : \"gallery-hero-column-one\"}>\n                        {\n                            assetsToShow.slice(0, 1).map((asset) =>\n                                <img src={assetUrlFrom(asset.id, propertyId)}\n                                     alt={asset.name}\n                                     key={asset.id}\n                                     className=\"gallery-hero--image\"\n                                     onClick={() => imageClickedHandler(asset)}\n                                />\n                            )\n                        }\n                    </div> : <></>}\n                {assetsToShow.length > 1 ?\n                    <div className={isFirst ? \"gallery-hero-column-two\" : \"gallery-hero-column\"}>\n                        {isFirst ?\n                            [...Array(toursCount)].map((x, i) =>\n\n                                <HeroImageCard backgroundImage={assetUrlFrom(assetsToShow[i].id, propertyId)}\n                                               key={\"tour\" + i}\n                                               onClick={() => {\n                                                   virtualTour && i === 0 ? setCurrentView(\"virtual tour\") : setCurrentView(\"video tour\");\n                                               }}>\n                                    {cardImageIcon(i)}\n                                </HeroImageCard>\n                            ) : <></>\n                        }\n                        {\n\n                            assetsToShow.slice(isFirst ? 1 : 0, assetsToShow.length).map((asset) =>\n                                <img src={assetUrlFrom(asset.id, propertyId)}\n                                     alt={asset.name}\n                                     key={asset.id}\n                                     className=\"gallery-hero--image\"\n                                     onClick={() => imageClickedHandler(asset)}\n                                />\n                            )\n                        }\n                    </div> : <></>\n                }\n\n            </div>\n        </div>\n    );\n};\n\n\nexport interface GalleryHeroProps {\n\n    assetsToShow: Asset[];\n    virtualTour?: string;\n    isAvailableNow?: boolean;\n    isFirst: boolean;\n    toursCount: number;\n    webSpecials: WebSpecial[];\n    setCurrentView: (view: \"photo\" | \"virtual tour\" | \"video tour\") => void;\n    imageClickedHandler: (image: Asset) => void;\n    propertyId: string;\n\n}\n"],"mappings":"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"}
72
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_AssetService","_muncherUi","_HeroImageCard","_icon","_videoIcon","_SpecialOfferBadge","obj","__esModule","default","GalleryHeroMain","_ref","virtualTour","setCurrentView","isAvailableNow","webSpecials","assetsToShow","isFirst","toursCount","imageClickedHandler","propertyId","cardImageIcon","i","createElement","Fragment","src","tourIcon","alt","height","videoIcon","className","Badge","variant","length","SpecialOfferBadge","description","slice","map","asset","assetUrlFrom","id","name","key","onClick","Array","x","HeroImageCard","backgroundImage","exports"],"sources":["../../src/gallery/GalleryHeroMain.tsx"],"sourcesContent":["import React from \"react\";\nimport './assets/GalleryHero.scss';\nimport {Asset} from \"../asset/data/Asset\";\nimport {assetUrlFrom} from \"../asset/service/AssetService\";\nimport {Badge} from \"@contentmunch/muncher-ui\";\nimport {HeroImageCard} from \"./HeroImageCard\";\nimport tourIcon from \"../floorplan/card/assets/360-icon.png\";\nimport videoIcon from \"../floorplan/card/assets/video-icon.png\";\nimport {WebSpecial} from \"../floorplan/data/Floorplan\";\nimport {SpecialOfferBadge} from \"../specialOffer/SpecialOfferBadge\";\n\nexport const GalleryHeroMain: React.FC<GalleryHeroProps> = (\n    {\n        virtualTour, setCurrentView, isAvailableNow, webSpecials,\n        assetsToShow, isFirst, toursCount, imageClickedHandler, propertyId\n    }) => {\n\n    const cardImageIcon = (i: number) => virtualTour && i === 0 ?\n        <>\n            <img src={tourIcon} alt=\"tour icon\" height={50}/>\n            <p>Virtual Tour</p>\n        </> :\n        <>\n            <img src={videoIcon} alt=\"video icon\" height={40}/>\n            <p>Video Tour</p>\n        </>\n\n    return (\n        <div className=\"div-gallery\">\n            <div className=\"badge--info\">\n                {isFirst && isAvailableNow ?\n                    <Badge variant=\"secondary\">Available Now</Badge>\n                    : <></>\n                }\n                {isFirst && webSpecials.length > 0 ?\n                    <SpecialOfferBadge/> : <></>\n                }\n            </div>\n            {isFirst && webSpecials.length > 0 ?\n                <div className=\"gallery--information\"><p>{webSpecials[0].description}</p></div> : <></>\n            }\n\n            <div className=\"gallery-hero-two-columns\">\n                {isFirst ?\n                    <div\n                        className={assetsToShow.length < 2 ? \"gallery-hero-one\" : \"gallery-hero-column-one\"}>\n                        {\n                            assetsToShow.slice(0, 1).map((asset) =>\n                                <img src={assetUrlFrom(asset.id, propertyId)}\n                                     alt={asset.name}\n                                     key={asset.id}\n                                     className=\"gallery-hero--image\"\n                                     onClick={() => imageClickedHandler(asset)}\n                                />\n                            )\n                        }\n                    </div> : <></>}\n                {assetsToShow.length > 1 ?\n                    <div className={isFirst ? \"gallery-hero-column-two\" : \"gallery-hero-column\"}>\n                        {isFirst ?\n                            [...Array(toursCount)].map((x, i) =>\n\n                                <HeroImageCard backgroundImage={assetUrlFrom(assetsToShow[i].id, propertyId)}\n                                               key={\"tour\" + i}\n                                               onClick={() => {\n                                                   virtualTour && i === 0 ? setCurrentView(\"virtual tour\") : setCurrentView(\"video tour\");\n                                               }}>\n                                    {cardImageIcon(i)}\n                                </HeroImageCard>\n                            ) : <></>\n                        }\n                        {\n\n                            assetsToShow.slice(isFirst ? 1 : 0, assetsToShow.length).map((asset) =>\n                                <img src={assetUrlFrom(asset.id, propertyId)}\n                                     alt={asset.name}\n                                     key={asset.id}\n                                     className=\"gallery-hero--image\"\n                                     onClick={() => imageClickedHandler(asset)}\n                                />\n                            )\n                        }\n                    </div> : <></>\n                }\n\n            </div>\n        </div>\n    );\n};\n\n\nexport interface GalleryHeroProps {\n\n    assetsToShow: Asset[];\n    virtualTour?: string;\n    isAvailableNow?: boolean;\n    isFirst: boolean;\n    toursCount: number;\n    webSpecials: WebSpecial[];\n    setCurrentView: (view: \"photo\" | \"virtual tour\" | \"video tour\") => void;\n    imageClickedHandler: (image: Asset) => void;\n    propertyId: string;\n\n}\n"],"mappings":"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"}
@@ -4,14 +4,17 @@ Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
6
  exports.GalleryHeroMobile = void 0;
7
- var _react = _interopRequireDefault(require("react"));
7
+ var _react = _interopRequireWildcard(require("react"));
8
8
  require("./assets/GalleryHero.scss");
9
9
  var _AssetService = require("../asset/service/AssetService");
10
10
  var _muncherUi = require("@contentmunch/muncher-ui");
11
11
  var _HeroImageCard = require("./HeroImageCard");
12
12
  var _icon = _interopRequireDefault(require("../floorplan/card/assets/360-icon.png"));
13
13
  var _videoIcon = _interopRequireDefault(require("../floorplan/card/assets/video-icon.png"));
14
+ var _SpecialOfferButton = require("../specialOffer/SpecialOfferButton");
14
15
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
16
+ function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
17
+ function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
15
18
  const GalleryHeroMobile = _ref => {
16
19
  let {
17
20
  assets,
@@ -23,15 +26,17 @@ const GalleryHeroMobile = _ref => {
23
26
  propertyId,
24
27
  webSpecials
25
28
  } = _ref;
26
- const createImageItem = (asset, index) => /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, index === 0 ? /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, isAvailableNow ? /*#__PURE__*/_react.default.createElement("div", {
29
+ const [showSpecialOffer, setShowSpecialOffer] = (0, _react.useState)(false);
30
+ const createImageItem = (asset, index) => /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, index === 0 ? /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("div", {
27
31
  className: "badge--info"
28
- }, /*#__PURE__*/_react.default.createElement(_muncherUi.Badge, {
32
+ }, isAvailableNow ? /*#__PURE__*/_react.default.createElement(_muncherUi.Badge, {
29
33
  variant: "secondary"
30
- }, "Available Now")) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null), webSpecials.length > 0 ? /*#__PURE__*/_react.default.createElement("div", {
34
+ }, "Available Now") : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null), webSpecials.length > 0 ? /*#__PURE__*/_react.default.createElement(_SpecialOfferButton.SpecialOfferButton, {
35
+ onMouseEnter: () => setShowSpecialOffer(true),
36
+ onMouseLeave: () => setShowSpecialOffer(false)
37
+ }) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null)), showSpecialOffer ? /*#__PURE__*/_react.default.createElement("div", {
31
38
  className: "gallery--information"
32
- }, /*#__PURE__*/_react.default.createElement(_muncherUi.Badge, {
33
- variant: "secondary"
34
- }, /*#__PURE__*/_react.default.createElement("p", null, webSpecials[0].description))) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null)) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null), /*#__PURE__*/_react.default.createElement("img", {
39
+ }, /*#__PURE__*/_react.default.createElement("p", null, webSpecials[0].description)) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null)) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null), /*#__PURE__*/_react.default.createElement("img", {
35
40
  src: (0, _AssetService.assetUrlFrom)(asset.id, propertyId),
36
41
  alt: asset.name,
37
42
  key: asset.id,
@@ -76,4 +81,4 @@ const GalleryHeroMobile = _ref => {
76
81
  }))));
77
82
  };
78
83
  exports.GalleryHeroMobile = GalleryHeroMobile;
79
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_AssetService","_muncherUi","_HeroImageCard","_icon","_videoIcon","obj","__esModule","default","GalleryHeroMobile","_ref","assets","virtualTour","setCurrentView","toursCount","imageClickedHandler","isAvailableNow","propertyId","webSpecials","createImageItem","asset","index","createElement","Fragment","className","Badge","variant","length","description","src","assetUrlFrom","id","alt","name","key","onClick","sliderItems","cardImageIcon","i","tourIcon","height","videoIcon","items","push","Array","forEach","x","HeroImageCard","backgroundImage","isForMobile","slice","ItemSlider","exports"],"sources":["../../src/gallery/GalleryHeroMobile.tsx"],"sourcesContent":["import React, {ReactElement} from \"react\";\nimport './assets/GalleryHero.scss';\nimport {Asset} from \"../asset/data/Asset\";\nimport {assetUrlFrom} from \"../asset/service/AssetService\";\nimport {Badge, ItemSlider} from \"@contentmunch/muncher-ui\";\nimport {HeroImageCard} from \"./HeroImageCard\";\nimport tourIcon from \"../floorplan/card/assets/360-icon.png\";\nimport videoIcon from \"../floorplan/card/assets/video-icon.png\";\nimport {WebSpecial} from \"../floorplan/data/Floorplan\";\n\nexport const GalleryHeroMobile: React.FC<GalleryHeroMobileProps> = (\n    {\n        assets, virtualTour, setCurrentView, toursCount,\n        imageClickedHandler, isAvailableNow, propertyId, webSpecials,\n    }) => {\n\n    const createImageItem = (asset: Asset, index: number) =>\n\n        <>\n            {index === 0 ?\n                <>\n                    {isAvailableNow ?\n                        <div className=\"badge--info\"><Badge variant=\"secondary\">Available Now</Badge></div> : <></>}\n                    {webSpecials.length > 0 ?\n                        <div className=\"gallery--information\"><Badge variant=\"secondary\">\n                            <p>{webSpecials[0].description}</p>\n                        </Badge></div> : <></>}\n                </> : <></>\n            }\n            <img src={assetUrlFrom(asset.id, propertyId)}\n                 alt={asset.name}\n                 key={asset.id}\n                 className=\"gallery-hero-mobile--image\"\n                 onClick={() => imageClickedHandler(asset)}/>\n        </>;\n\n    const sliderItems = () => {\n        const cardImageIcon = (i: number) => virtualTour && i === 0 ?\n            <>\n                <img src={tourIcon} alt=\"tour icon\" height={40}/>\n                <p>Virtual Tour</p>\n            </> :\n            <>\n                <img src={videoIcon} alt=\"video icon\" height={30}/>\n                <p>Video Tour</p>\n            </>\n        const items: ReactElement[] = [];\n        items.push(createImageItem(assets[0], 0));\n        [...Array(toursCount)].forEach((x, i) => {\n                items.push(\n                    <HeroImageCard backgroundImage={assetUrlFrom(assets[i].id, propertyId)}\n                                   isForMobile={true}\n                                   key={\"tour\" + i}\n                                   onClick={() => {\n                                       virtualTour && i === 0 ? setCurrentView(\"virtual tour\") : setCurrentView(\"video tour\");\n                                   }}\n                    >\n                        {cardImageIcon(i)}\n                    </HeroImageCard>\n                )\n            }\n        );\n        assets.slice(1, assets.length).forEach((asset, index) => {\n            items.push(createImageItem(asset, index+1));\n        });\n\n        return items;\n    };\n\n\n    return (\n        <div className=\"div-gallery\">\n            <div className=\"gallery-hero-two-columns\">\n                <div className=\"gallery-hero-column\">\n                    <ItemSlider sliderItems={sliderItems()}/>\n\n                </div>\n            </div>\n\n\n        </div>\n    );\n};\n\nexport interface GalleryHeroMobileProps {\n    assets: Asset[];\n    virtualTour?: string;\n    toursCount: number;\n    webSpecials: WebSpecial[];\n    setCurrentView: (view: \"photo\" | \"virtual tour\" | \"video tour\") => void;\n    imageClickedHandler: (image: Asset) => void;\n    propertyId: string;\n    isAvailableNow: boolean;\n}\n"],"mappings":"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"}
84
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_AssetService","_muncherUi","_HeroImageCard","_icon","_interopRequireDefault","_videoIcon","_SpecialOfferButton","obj","__esModule","default","_getRequireWildcardCache","e","WeakMap","r","t","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","prototype","hasOwnProperty","call","i","set","GalleryHeroMobile","_ref","assets","virtualTour","setCurrentView","toursCount","imageClickedHandler","isAvailableNow","propertyId","webSpecials","showSpecialOffer","setShowSpecialOffer","useState","createImageItem","asset","index","createElement","Fragment","className","Badge","variant","length","SpecialOfferButton","onMouseEnter","onMouseLeave","description","src","assetUrlFrom","id","alt","name","key","onClick","sliderItems","cardImageIcon","tourIcon","height","videoIcon","items","push","Array","forEach","x","HeroImageCard","backgroundImage","isForMobile","slice","ItemSlider","exports"],"sources":["../../src/gallery/GalleryHeroMobile.tsx"],"sourcesContent":["import React, {ReactElement, useState} from \"react\";\nimport './assets/GalleryHero.scss';\nimport {Asset} from \"../asset/data/Asset\";\nimport {assetUrlFrom} from \"../asset/service/AssetService\";\nimport {Badge, ItemSlider} from \"@contentmunch/muncher-ui\";\nimport {HeroImageCard} from \"./HeroImageCard\";\nimport tourIcon from \"../floorplan/card/assets/360-icon.png\";\nimport videoIcon from \"../floorplan/card/assets/video-icon.png\";\nimport {WebSpecial} from \"../floorplan/data/Floorplan\";\nimport {SpecialOfferButton} from \"../specialOffer/SpecialOfferButton\";\n\nexport const GalleryHeroMobile: React.FC<GalleryHeroMobileProps> = (\n    {\n        assets, virtualTour, setCurrentView, toursCount,\n        imageClickedHandler, isAvailableNow, propertyId, webSpecials,\n    }) => {\n    const [showSpecialOffer, setShowSpecialOffer] = useState(false);\n\n    const createImageItem = (asset: Asset, index: number) =>\n\n        <>\n            {index === 0 ?\n                <>\n                    <div className=\"badge--info\">\n                        {isAvailableNow ?\n                            <Badge variant=\"secondary\">Available Now</Badge> : <></>}\n                        {webSpecials.length > 0 ? <SpecialOfferButton onMouseEnter={() => setShowSpecialOffer(true)}\n                                                                      onMouseLeave={() => setShowSpecialOffer(false)}/> : <></>}\n                    </div>\n                    {showSpecialOffer ?\n                        <div className=\"gallery--information\"><p>{webSpecials[0].description}</p></div> : <></>}\n                </> : <></>\n            }\n            <img src={assetUrlFrom(asset.id, propertyId)}\n                 alt={asset.name}\n                 key={asset.id}\n                 className=\"gallery-hero-mobile--image\"\n                 onClick={() => imageClickedHandler(asset)}/>\n        </>;\n\n    const sliderItems = () => {\n        const cardImageIcon = (i: number) => virtualTour && i === 0 ?\n            <>\n                <img src={tourIcon} alt=\"tour icon\" height={40}/>\n                <p>Virtual Tour</p>\n            </> :\n            <>\n                <img src={videoIcon} alt=\"video icon\" height={30}/>\n                <p>Video Tour</p>\n            </>\n        const items: ReactElement[] = [];\n        items.push(createImageItem(assets[0], 0));\n        [...Array(toursCount)].forEach((x, i) => {\n                items.push(\n                    <HeroImageCard backgroundImage={assetUrlFrom(assets[i].id, propertyId)}\n                                   isForMobile={true}\n                                   key={\"tour\" + i}\n                                   onClick={() => {\n                                       virtualTour && i === 0 ? setCurrentView(\"virtual tour\") : setCurrentView(\"video tour\");\n                                   }}\n                    >\n                        {cardImageIcon(i)}\n                    </HeroImageCard>\n                )\n            }\n        );\n        assets.slice(1, assets.length).forEach((asset, index) => {\n            items.push(createImageItem(asset, index + 1));\n        });\n\n        return items;\n    };\n\n\n    return (\n        <div className=\"div-gallery\">\n            <div className=\"gallery-hero-two-columns\">\n                <div className=\"gallery-hero-column\">\n                    <ItemSlider sliderItems={sliderItems()}/>\n\n                </div>\n            </div>\n\n\n        </div>\n    );\n};\n\nexport interface GalleryHeroMobileProps {\n    assets: Asset[];\n    virtualTour?: string;\n    toursCount: number;\n    webSpecials: WebSpecial[];\n    setCurrentView: (view: \"photo\" | \"virtual tour\" | \"video tour\") => void;\n    imageClickedHandler: (image: Asset) => void;\n    propertyId: string;\n    isAvailableNow: boolean;\n}\n"],"mappings":";;;;;;AAAA,IAAAA,MAAA,GAAAC,uBAAA,CAAAC,OAAA;AACAA,OAAA;AAEA,IAAAC,aAAA,GAAAD,OAAA;AACA,IAAAE,UAAA,GAAAF,OAAA;AACA,IAAAG,cAAA,GAAAH,OAAA;AACA,IAAAI,KAAA,GAAAC,sBAAA,CAAAL,OAAA;AACA,IAAAM,UAAA,GAAAD,sBAAA,CAAAL,OAAA;AAEA,IAAAO,mBAAA,GAAAP,OAAA;AAAsE,SAAAK,uBAAAG,GAAA,WAAAA,GAAA,IAAAA,GAAA,CAAAC,UAAA,GAAAD,GAAA,KAAAE,OAAA,EAAAF,GAAA;AAAA,SAAAG,yBAAAC,CAAA,6BAAAC,OAAA,mBAAAC,CAAA,OAAAD,OAAA,IAAAE,CAAA,OAAAF,OAAA,YAAAF,wBAAA,YAAAA,CAAAC,CAAA,WAAAA,CAAA,GAAAG,CAAA,GAAAD,CAAA,KAAAF,CAAA;AAAA,SAAAb,wBAAAa,CAAA,EAAAE,CAAA,SAAAA,CAAA,IAAAF,CAAA,IAAAA,CAAA,CAAAH,UAAA,SAAAG,CAAA,eAAAA,CAAA,uBAAAA,CAAA,yBAAAA,CAAA,WAAAF,OAAA,EAAAE,CAAA,QAAAG,CAAA,GAAAJ,wBAAA,CAAAG,CAAA,OAAAC,CAAA,IAAAA,CAAA,CAAAC,GAAA,CAAAJ,CAAA,UAAAG,CAAA,CAAAE,GAAA,CAAAL,CAAA,OAAAM,CAAA,KAAAC,SAAA,UAAAC,CAAA,GAAAC,MAAA,CAAAC,cAAA,IAAAD,MAAA,CAAAE,wBAAA,WAAAC,CAAA,IAAAZ,CAAA,oBAAAY,CAAA,IAAAH,MAAA,CAAAI,SAAA,CAAAC,cAAA,CAAAC,IAAA,CAAAf,CAAA,EAAAY,CAAA,SAAAI,CAAA,GAAAR,CAAA,GAAAC,MAAA,CAAAE,wBAAA,CAAAX,CAAA,EAAAY,CAAA,UAAAI,CAAA,KAAAA,CAAA,CAAAX,GAAA,IAAAW,CAAA,CAAAC,GAAA,IAAAR,MAAA,CAAAC,cAAA,CAAAJ,CAAA,EAAAM,CAAA,EAAAI,CAAA,IAAAV,CAAA,CAAAM,CAAA,IAAAZ,CAAA,CAAAY,CAAA,YAAAN,CAAA,CAAAR,OAAA,GAAAE,CAAA,EAAAG,CAAA,IAAAA,CAAA,CAAAc,GAAA,CAAAjB,CAAA,EAAAM,CAAA,GAAAA,CAAA;AAE/D,MAAMY,iBAAmD,GAAGC,IAAA,IAIzD;EAAA,IAHN;IACIC,MAAM;IAAEC,WAAW;IAAEC,cAAc;IAAEC,UAAU;IAC/CC,mBAAmB;IAAEC,cAAc;IAAEC,UAAU;IAAEC;EACrD,CAAC,GAAAR,IAAA;EACD,MAAM,CAACS,gBAAgB,EAAEC,mBAAmB,CAAC,GAAG,IAAAC,eAAQ,EAAC,KAAK,CAAC;EAE/D,MAAMC,eAAe,GAAGA,CAACC,KAAY,EAAEC,KAAa,kBAEhD/C,MAAA,CAAAY,OAAA,CAAAoC,aAAA,CAAAhD,MAAA,CAAAY,OAAA,CAAAqC,QAAA,QACKF,KAAK,KAAK,CAAC,gBACR/C,MAAA,CAAAY,OAAA,CAAAoC,aAAA,CAAAhD,MAAA,CAAAY,OAAA,CAAAqC,QAAA,qBACIjD,MAAA,CAAAY,OAAA,CAAAoC,aAAA;IAAKE,SAAS,EAAC;EAAa,GACvBX,cAAc,gBACXvC,MAAA,CAAAY,OAAA,CAAAoC,aAAA,CAAC5C,UAAA,CAAA+C,KAAK;IAACC,OAAO,EAAC;EAAW,GAAC,eAAoB,CAAC,gBAAGpD,MAAA,CAAAY,OAAA,CAAAoC,aAAA,CAAAhD,MAAA,CAAAY,OAAA,CAAAqC,QAAA,MAAI,CAAC,EAC3DR,WAAW,CAACY,MAAM,GAAG,CAAC,gBAAGrD,MAAA,CAAAY,OAAA,CAAAoC,aAAA,CAACvC,mBAAA,CAAA6C,kBAAkB;IAACC,YAAY,EAAEA,CAAA,KAAMZ,mBAAmB,CAAC,IAAI,CAAE;IAC9Ca,YAAY,EAAEA,CAAA,KAAMb,mBAAmB,CAAC,KAAK;EAAE,CAAC,CAAC,gBAAG3C,MAAA,CAAAY,OAAA,CAAAoC,aAAA,CAAAhD,MAAA,CAAAY,OAAA,CAAAqC,QAAA,MAAI,CACrG,CAAC,EACLP,gBAAgB,gBACb1C,MAAA,CAAAY,OAAA,CAAAoC,aAAA;IAAKE,SAAS,EAAC;EAAsB,gBAAClD,MAAA,CAAAY,OAAA,CAAAoC,aAAA,YAAIP,WAAW,CAAC,CAAC,CAAC,CAACgB,WAAe,CAAM,CAAC,gBAAGzD,MAAA,CAAAY,OAAA,CAAAoC,aAAA,CAAAhD,MAAA,CAAAY,OAAA,CAAAqC,QAAA,MAAI,CAC5F,CAAC,gBAAGjD,MAAA,CAAAY,OAAA,CAAAoC,aAAA,CAAAhD,MAAA,CAAAY,OAAA,CAAAqC,QAAA,MAAI,CAAC,eAEfjD,MAAA,CAAAY,OAAA,CAAAoC,aAAA;IAAKU,GAAG,EAAE,IAAAC,0BAAY,EAACb,KAAK,CAACc,EAAE,EAAEpB,UAAU,CAAE;IACxCqB,GAAG,EAAEf,KAAK,CAACgB,IAAK;IAChBC,GAAG,EAAEjB,KAAK,CAACc,EAAG;IACdV,SAAS,EAAC,4BAA4B;IACtCc,OAAO,EAAEA,CAAA,KAAM1B,mBAAmB,CAACQ,KAAK;EAAE,CAAC,CAClD,CAAC;EAEP,MAAMmB,WAAW,GAAGA,CAAA,KAAM;IACtB,MAAMC,aAAa,GAAIpC,CAAS,IAAKK,WAAW,IAAIL,CAAC,KAAK,CAAC,gBACvD9B,MAAA,CAAAY,OAAA,CAAAoC,aAAA,CAAAhD,MAAA,CAAAY,OAAA,CAAAqC,QAAA,qBACIjD,MAAA,CAAAY,OAAA,CAAAoC,aAAA;MAAKU,GAAG,EAAES,aAAS;MAACN,GAAG,EAAC,WAAW;MAACO,MAAM,EAAE;IAAG,CAAC,CAAC,eACjDpE,MAAA,CAAAY,OAAA,CAAAoC,aAAA,YAAG,cAAe,CACpB,CAAC,gBACHhD,MAAA,CAAAY,OAAA,CAAAoC,aAAA,CAAAhD,MAAA,CAAAY,OAAA,CAAAqC,QAAA,qBACIjD,MAAA,CAAAY,OAAA,CAAAoC,aAAA;MAAKU,GAAG,EAAEW,kBAAU;MAACR,GAAG,EAAC,YAAY;MAACO,MAAM,EAAE;IAAG,CAAC,CAAC,eACnDpE,MAAA,CAAAY,OAAA,CAAAoC,aAAA,YAAG,YAAa,CAClB,CAAC;IACP,MAAMsB,KAAqB,GAAG,EAAE;IAChCA,KAAK,CAACC,IAAI,CAAC1B,eAAe,CAACX,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IACzC,CAAC,GAAGsC,KAAK,CAACnC,UAAU,CAAC,CAAC,CAACoC,OAAO,CAAC,CAACC,CAAC,EAAE5C,CAAC,KAAK;MACjCwC,KAAK,CAACC,IAAI,eACNvE,MAAA,CAAAY,OAAA,CAAAoC,aAAA,CAAC3C,cAAA,CAAAsE,aAAa;QAACC,eAAe,EAAE,IAAAjB,0BAAY,EAACzB,MAAM,CAACJ,CAAC,CAAC,CAAC8B,EAAE,EAAEpB,UAAU,CAAE;QACxDqC,WAAW,EAAE,IAAK;QAClBd,GAAG,EAAE,MAAM,GAAGjC,CAAE;QAChBkC,OAAO,EAAEA,CAAA,KAAM;UACX7B,WAAW,IAAIL,CAAC,KAAK,CAAC,GAAGM,cAAc,CAAC,cAAc,CAAC,GAAGA,cAAc,CAAC,YAAY,CAAC;QAC1F;MAAE,GAEZ8B,aAAa,CAACpC,CAAC,CACL,CACnB,CAAC;IACL,CACJ,CAAC;IACDI,MAAM,CAAC4C,KAAK,CAAC,CAAC,EAAE5C,MAAM,CAACmB,MAAM,CAAC,CAACoB,OAAO,CAAC,CAAC3B,KAAK,EAAEC,KAAK,KAAK;MACrDuB,KAAK,CAACC,IAAI,CAAC1B,eAAe,CAACC,KAAK,EAAEC,KAAK,GAAG,CAAC,CAAC,CAAC;IACjD,CAAC,CAAC;IAEF,OAAOuB,KAAK;EAChB,CAAC;EAGD,oBACItE,MAAA,CAAAY,OAAA,CAAAoC,aAAA;IAAKE,SAAS,EAAC;EAAa,gBACxBlD,MAAA,CAAAY,OAAA,CAAAoC,aAAA;IAAKE,SAAS,EAAC;EAA0B,gBACrClD,MAAA,CAAAY,OAAA,CAAAoC,aAAA;IAAKE,SAAS,EAAC;EAAqB,gBAChClD,MAAA,CAAAY,OAAA,CAAAoC,aAAA,CAAC5C,UAAA,CAAA2E,UAAU;IAACd,WAAW,EAAEA,WAAW,CAAC;EAAE,CAAC,CAEvC,CACJ,CAGJ,CAAC;AAEd,CAAC;AAACe,OAAA,CAAAhD,iBAAA,GAAAA,iBAAA"}
@@ -78,26 +78,27 @@
78
78
  position: absolute;
79
79
  top: 1.5rem;
80
80
  left: 1rem;
81
- }
82
-
83
- .gallery--information {
81
+ display: flex;
82
+ align-items: center;
83
+ justify-content: center;
84
84
  .muncher-badge {
85
- border-radius: 0;
86
- padding: 1rem;
87
- text-align: center;
88
- background-color: rgba(234, 233, 227, 0.6);
85
+ margin-right: .5rem;
89
86
  }
87
+ }
90
88
 
89
+ .gallery--information {
90
+ text-align: center;
91
+ color: $primary-background-color;
92
+ background-color: $special-offer-color;
93
+ padding: 0 1rem;
91
94
  position: absolute;
92
- top: 4.5rem;
93
- width: 70vw;
95
+ top: 5rem;
96
+ width: 50vw;
94
97
  left: 0;
95
98
  font-size: .8rem;
96
- //font-weight: bold;
97
- @media (min-width: $medium-size) {
98
- width: 30vw;
99
- font-size: 1rem;
99
+ @media (min-width: $large-size) {
100
+ font-size: 1.1rem;
101
+ width: 16rem;
100
102
  }
101
-
102
103
  }
103
104
  }
@@ -0,0 +1,3 @@
1
+ import React from "react";
2
+ import "./assets/SpecialOfferBadge.scss";
3
+ export declare const SpecialOfferBadge: React.FC;
@@ -0,0 +1,24 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.SpecialOfferBadge = void 0;
7
+ var _react = _interopRequireDefault(require("react"));
8
+ require("./assets/SpecialOfferBadge.scss");
9
+ var _muncherUi = require("@contentmunch/muncher-ui");
10
+ var _ConcaveStar = _interopRequireDefault(require("./assets/ConcaveStar.png"));
11
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
12
+ const SpecialOfferBadge = () => {
13
+ return /*#__PURE__*/_react.default.createElement("span", {
14
+ className: "special-offer-badge"
15
+ }, /*#__PURE__*/_react.default.createElement(_muncherUi.Badge, {
16
+ variant: "primary"
17
+ }, /*#__PURE__*/_react.default.createElement("img", {
18
+ className: "star-icon",
19
+ src: _ConcaveStar.default,
20
+ alt: "star icon"
21
+ }), "Special Offer"));
22
+ };
23
+ exports.SpecialOfferBadge = SpecialOfferBadge;
24
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIl9tdW5jaGVyVWkiLCJfQ29uY2F2ZVN0YXIiLCJvYmoiLCJfX2VzTW9kdWxlIiwiZGVmYXVsdCIsIlNwZWNpYWxPZmZlckJhZGdlIiwiY3JlYXRlRWxlbWVudCIsImNsYXNzTmFtZSIsIkJhZGdlIiwidmFyaWFudCIsInNyYyIsInN0YXJ0SWNvbiIsImFsdCIsImV4cG9ydHMiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvc3BlY2lhbE9mZmVyL1NwZWNpYWxPZmZlckJhZGdlLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgXCIuL2Fzc2V0cy9TcGVjaWFsT2ZmZXJCYWRnZS5zY3NzXCI7XG5pbXBvcnQge0JhZGdlfSBmcm9tIFwiQGNvbnRlbnRtdW5jaC9tdW5jaGVyLXVpXCI7XG5pbXBvcnQgc3RhcnRJY29uIGZyb20gXCIuL2Fzc2V0cy9Db25jYXZlU3Rhci5wbmdcIjtcblxuZXhwb3J0IGNvbnN0IFNwZWNpYWxPZmZlckJhZGdlOiBSZWFjdC5GQyA9ICgpID0+IHtcbiAgICByZXR1cm4gKFxuICAgICAgICA8c3BhbiBjbGFzc05hbWU9XCJzcGVjaWFsLW9mZmVyLWJhZGdlXCI+XG4gICAgICAgICAgICA8QmFkZ2UgdmFyaWFudD1cInByaW1hcnlcIj48aW1nIGNsYXNzTmFtZT1cInN0YXItaWNvblwiIHNyYz17c3RhcnRJY29ufSBhbHQ9XCJzdGFyIGljb25cIi8+U3BlY2lhbCBPZmZlcjwvQmFkZ2U+XG4gICAgICAgIDwvc3Bhbj5cbiAgICApXG59XG4iXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLElBQUFBLE1BQUEsR0FBQUMsc0JBQUEsQ0FBQUMsT0FBQTtBQUNBQSxPQUFBO0FBQ0EsSUFBQUMsVUFBQSxHQUFBRCxPQUFBO0FBQ0EsSUFBQUUsWUFBQSxHQUFBSCxzQkFBQSxDQUFBQyxPQUFBO0FBQWlELFNBQUFELHVCQUFBSSxHQUFBLFdBQUFBLEdBQUEsSUFBQUEsR0FBQSxDQUFBQyxVQUFBLEdBQUFELEdBQUEsS0FBQUUsT0FBQSxFQUFBRixHQUFBO0FBRTFDLE1BQU1HLGlCQUEyQixHQUFHQSxDQUFBLEtBQU07RUFDN0Msb0JBQ0lSLE1BQUEsQ0FBQU8sT0FBQSxDQUFBRSxhQUFBO0lBQU1DLFNBQVMsRUFBQztFQUFxQixnQkFDakNWLE1BQUEsQ0FBQU8sT0FBQSxDQUFBRSxhQUFBLENBQUNOLFVBQUEsQ0FBQVEsS0FBSztJQUFDQyxPQUFPLEVBQUM7RUFBUyxnQkFBQ1osTUFBQSxDQUFBTyxPQUFBLENBQUFFLGFBQUE7SUFBS0MsU0FBUyxFQUFDLFdBQVc7SUFBQ0csR0FBRyxFQUFFQyxvQkFBVTtJQUFDQyxHQUFHLEVBQUM7RUFBVyxDQUFDLENBQUMsaUJBQW9CLENBQ3ZHLENBQUM7QUFFZixDQUFDO0FBQUFDLE9BQUEsQ0FBQVIsaUJBQUEsR0FBQUEsaUJBQUEifQ==
@@ -0,0 +1,19 @@
1
+ @import "src/assets/variables";
2
+
3
+ .special-offer-badge {
4
+ .muncher-badge {
5
+ border-radius: .5rem;
6
+ background-color: $special-offer-color;
7
+ text-transform: none;
8
+ font-family: $serif-font;
9
+ font-weight: normal;
10
+ //font-size: .8rem;
11
+ padding: .3rem .5rem;
12
+ display: inline-flex;
13
+ align-items: center;
14
+ justify-content: center;
15
+ .star-icon {
16
+ width: 1.6rem;
17
+ }
18
+ }
19
+ }
@@ -21,6 +21,7 @@ export interface MinMax {
21
21
  export declare const minimumMaximum: (arr: any[], field: string) => MinMax;
22
22
  export declare const rangeFrom: (arr: any[], field: string) => string;
23
23
  export declare const dateToMoment: (date: string) => Moment;
24
+ export declare const momentToDate: (date: Moment) => string;
24
25
  export declare const decode: (content: string) => string;
25
26
  export declare const formatDate: (date: string) => string;
26
27
  export declare const isZipcodeValid: (zipcode?: string) => boolean;
@@ -3,7 +3,7 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
- exports.youtubeUrlToEmbedUrl = exports.toUSD = exports.toDate = exports.rangeFrom = exports.minimumMaximum = exports.isZipcodeValid = exports.isGoogleDriveImage = exports.isEmpty = exports.formatPhoneNumber = exports.formatDate = exports.floorplanAddressToGoogleMap = exports.extractIdFrom = exports.enumToString = exports.decode = exports.dateToMoment = exports.capitalizeFirstLetter = exports.addressToGoogleMapLink = exports.addressToGoogleMap = exports.MIN_VALUE = exports.MAX_VALUE = void 0;
6
+ exports.youtubeUrlToEmbedUrl = exports.toUSD = exports.toDate = exports.rangeFrom = exports.momentToDate = exports.minimumMaximum = exports.isZipcodeValid = exports.isGoogleDriveImage = exports.isEmpty = exports.formatPhoneNumber = exports.formatDate = exports.floorplanAddressToGoogleMap = exports.extractIdFrom = exports.enumToString = exports.decode = exports.dateToMoment = exports.capitalizeFirstLetter = exports.addressToGoogleMapLink = exports.addressToGoogleMap = exports.MIN_VALUE = exports.MAX_VALUE = void 0;
7
7
  var _lodash = _interopRequireDefault(require("lodash"));
8
8
  var _moment = _interopRequireDefault(require("moment"));
9
9
  var _htmlEntities = require("html-entities");
@@ -86,6 +86,8 @@ const rangeFrom = (arr, field) => {
86
86
  exports.rangeFrom = rangeFrom;
87
87
  const dateToMoment = date => (0, _moment.default)(date, "YYYY-MM-DD");
88
88
  exports.dateToMoment = dateToMoment;
89
+ const momentToDate = date => date.format("YYYY-MM-DD");
90
+ exports.momentToDate = momentToDate;
89
91
  const decode = content => {
90
92
  return (0, _htmlEntities.decodeEntity)(content);
91
93
  };
@@ -100,4 +102,4 @@ const isZipcodeValid = zipcode => {
100
102
  return zipcodePattern.test(zipcode);
101
103
  };
102
104
  exports.isZipcodeValid = isZipcodeValid;
103
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_lodash","_interopRequireDefault","require","_moment","_htmlEntities","obj","__esModule","default","MIN_VALUE","exports","MAX_VALUE","isEmpty","object","_","formatPhoneNumber","phone","match","toString","cleanAddressForGoogle","address","replace","addressToGoogleMapLink","zipcode","addressToGoogleMap","floorplanAddressToGoogleMap","floorplanAddress","city","state","enumToString","value","replaceAll","toLowerCase","capitalizeFirstLetter","lowerCased","charAt","toUpperCase","slice","toUSD","num","Intl","NumberFormat","style","currency","minimumFractionDigits","format","toDate","date","Date","toLocaleString","youtubeUrlToEmbedUrl","youtubeUrl","split","pop","isGoogleDriveImage","imageUrl","includes","extractIdFrom","paramString","queryString","URLSearchParams","id","get","minimumMaximum","arr","field","sorted","filter","active","sort","a","b","min","max","length","e","rangeFrom","minMax","dateToMoment","moment","decode","content","decodeEntity","formatDate","isZipcodeValid","zipcodePattern","test"],"sources":["../../src/utils/Utils.ts"],"sourcesContent":["import _ from \"lodash\";\nimport moment, {Moment} from \"moment\";\nimport {decodeEntity} from \"html-entities\";\nimport {FloorplanAddress} from \"../floorplan/service/FloorplanService\";\n\nexport const MIN_VALUE = 0;\nexport const MAX_VALUE = 4000;\nexport const isEmpty = (object: any): boolean => {\n    return !object || _.isEmpty(object);\n}\nexport const formatPhoneNumber = (phone?: string): string => {\n    if (!phone) return \"\";\n    const match = phone.toString().match(/^(\\d{3})(\\d{3})(\\d{4})$/);\n    return match ? \"(\" + match[1] + \")-\" + match[2] + \"-\" + match[3] : phone;\n}\n\nconst cleanAddressForGoogle = (address?: string): string => address ? address.replace(/apt. /gi, \"\") : \"\";\nexport const addressToGoogleMapLink = (address?: string, zipcode?: string) => \"https://maps.google.com/?q=\" + cleanAddressForGoogle(address) + \",\" + zipcode;\nexport const addressToGoogleMap = (address?: string, zipcode?: string) => \"https://www.google.com/maps?output=embed&q=\" + cleanAddressForGoogle(address) + \",\" + zipcode;\n\nexport const floorplanAddressToGoogleMap = (floorplanAddress: FloorplanAddress) =>\n    \"https://www.google.com/maps?output=embed&q=\" + cleanAddressForGoogle(floorplanAddress.address) + \", \" + floorplanAddress.city + \", \" + floorplanAddress.state + \" \" + floorplanAddress.zipcode;\nexport const enumToString = (value?: string): string => {\n\n    return value && !isEmpty(value) ? value.replaceAll(\"_\", \" \").toLowerCase() : \"\";\n};\n\nexport const capitalizeFirstLetter = (value: string): string => {\n    if (value) {\n        let lowerCased = value.toLowerCase();\n        return lowerCased.charAt(0).toUpperCase() + lowerCased.slice(1);\n    }\n    return value;\n}\nexport const toUSD = (num: number) => new Intl.NumberFormat('en-US', {\n    style: 'currency',\n    currency: 'USD',\n    minimumFractionDigits: 0\n}).format(num);\nexport const toDate = (date: string) => new Date(date).toLocaleString('en-US');\nexport const youtubeUrlToEmbedUrl = (youtubeUrl: string) => \"https://www.youtube.com/embed/\" + youtubeUrl.split(\"/\").pop() + \"?rel=0\";\n\n\nexport const isGoogleDriveImage = (imageUrl: string) => imageUrl && true && imageUrl.includes(\"drive.google.com\");\nexport const extractIdFrom = (imageUrl: string | null): string => {\n    if (imageUrl) {\n        const paramString = imageUrl.split('?')[1];\n        const queryString = new URLSearchParams(paramString);\n        const id = queryString.get(\"id\");\n        return id === null ? \"\" : id;\n    } else\n        return \"\";\n};\n\nexport interface MinMax {\n    min: number;\n    max: number;\n}\n\nexport const minimumMaximum = (arr: any[], field: string): MinMax => {\n    try {\n        const sorted = arr.filter(value => value.active ? value.active : true).sort((a, b) =>\n            a[field] && b[field] ? a[field] - b[field] : 0\n        );\n\n        return {\n            min: sorted[0][field],\n            max: sorted[sorted.length - 1][field]\n        }\n    } catch (e: any) {\n        return {\n            min: MIN_VALUE,\n            max: MIN_VALUE\n        }\n    }\n}\nexport const rangeFrom = (arr: any[], field: string): string => {\n    if (arr && arr.length > 0) {\n        const minMax = minimumMaximum(arr, field);\n\n        return (minMax.min === minMax.max) ? minMax.min.toString() : minMax.min + \" - \" + minMax.max;\n    } else {\n        return \"-\";\n    }\n}\n\nexport const dateToMoment = (date: string): Moment => moment(date, \"YYYY-MM-DD\");\n\nexport const decode = (content: string) => {\n    return decodeEntity(content);\n};\n\nexport const formatDate = (date: string): string => {\n    return moment(date, \"YYYY-MM-DD\").format('MMM DD, YYYY');\n};\n\nexport const isZipcodeValid = (zipcode?: string): boolean => {\n    if (!zipcode)\n        return true;\n    const zipcodePattern = /^\\d{5}$/;\n    return zipcodePattern.test(zipcode);\n};\n"],"mappings":"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"}
105
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_lodash","_interopRequireDefault","require","_moment","_htmlEntities","obj","__esModule","default","MIN_VALUE","exports","MAX_VALUE","isEmpty","object","_","formatPhoneNumber","phone","match","toString","cleanAddressForGoogle","address","replace","addressToGoogleMapLink","zipcode","addressToGoogleMap","floorplanAddressToGoogleMap","floorplanAddress","city","state","enumToString","value","replaceAll","toLowerCase","capitalizeFirstLetter","lowerCased","charAt","toUpperCase","slice","toUSD","num","Intl","NumberFormat","style","currency","minimumFractionDigits","format","toDate","date","Date","toLocaleString","youtubeUrlToEmbedUrl","youtubeUrl","split","pop","isGoogleDriveImage","imageUrl","includes","extractIdFrom","paramString","queryString","URLSearchParams","id","get","minimumMaximum","arr","field","sorted","filter","active","sort","a","b","min","max","length","e","rangeFrom","minMax","dateToMoment","moment","momentToDate","decode","content","decodeEntity","formatDate","isZipcodeValid","zipcodePattern","test"],"sources":["../../src/utils/Utils.ts"],"sourcesContent":["import _ from \"lodash\";\nimport moment, {Moment} from \"moment\";\nimport {decodeEntity} from \"html-entities\";\nimport {FloorplanAddress} from \"../floorplan/service/FloorplanService\";\n\nexport const MIN_VALUE = 0;\nexport const MAX_VALUE = 4000;\nexport const isEmpty = (object: any): boolean => {\n    return !object || _.isEmpty(object);\n}\nexport const formatPhoneNumber = (phone?: string): string => {\n    if (!phone) return \"\";\n    const match = phone.toString().match(/^(\\d{3})(\\d{3})(\\d{4})$/);\n    return match ? \"(\" + match[1] + \")-\" + match[2] + \"-\" + match[3] : phone;\n}\n\nconst cleanAddressForGoogle = (address?: string): string => address ? address.replace(/apt. /gi, \"\") : \"\";\nexport const addressToGoogleMapLink = (address?: string, zipcode?: string) => \"https://maps.google.com/?q=\" + cleanAddressForGoogle(address) + \",\" + zipcode;\nexport const addressToGoogleMap = (address?: string, zipcode?: string) => \"https://www.google.com/maps?output=embed&q=\" + cleanAddressForGoogle(address) + \",\" + zipcode;\n\nexport const floorplanAddressToGoogleMap = (floorplanAddress: FloorplanAddress) =>\n    \"https://www.google.com/maps?output=embed&q=\" + cleanAddressForGoogle(floorplanAddress.address) + \", \" + floorplanAddress.city + \", \" + floorplanAddress.state + \" \" + floorplanAddress.zipcode;\nexport const enumToString = (value?: string): string => {\n\n    return value && !isEmpty(value) ? value.replaceAll(\"_\", \" \").toLowerCase() : \"\";\n};\n\nexport const capitalizeFirstLetter = (value: string): string => {\n    if (value) {\n        let lowerCased = value.toLowerCase();\n        return lowerCased.charAt(0).toUpperCase() + lowerCased.slice(1);\n    }\n    return value;\n}\nexport const toUSD = (num: number) => new Intl.NumberFormat('en-US', {\n    style: 'currency',\n    currency: 'USD',\n    minimumFractionDigits: 0\n}).format(num);\nexport const toDate = (date: string) => new Date(date).toLocaleString('en-US');\nexport const youtubeUrlToEmbedUrl = (youtubeUrl: string) => \"https://www.youtube.com/embed/\" + youtubeUrl.split(\"/\").pop() + \"?rel=0\";\n\n\nexport const isGoogleDriveImage = (imageUrl: string) => imageUrl && true && imageUrl.includes(\"drive.google.com\");\nexport const extractIdFrom = (imageUrl: string | null): string => {\n    if (imageUrl) {\n        const paramString = imageUrl.split('?')[1];\n        const queryString = new URLSearchParams(paramString);\n        const id = queryString.get(\"id\");\n        return id === null ? \"\" : id;\n    } else\n        return \"\";\n};\n\nexport interface MinMax {\n    min: number;\n    max: number;\n}\n\nexport const minimumMaximum = (arr: any[], field: string): MinMax => {\n    try {\n        const sorted = arr.filter(value => value.active ? value.active : true).sort((a, b) =>\n            a[field] && b[field] ? a[field] - b[field] : 0\n        );\n\n        return {\n            min: sorted[0][field],\n            max: sorted[sorted.length - 1][field]\n        }\n    } catch (e: any) {\n        return {\n            min: MIN_VALUE,\n            max: MIN_VALUE\n        }\n    }\n}\nexport const rangeFrom = (arr: any[], field: string): string => {\n    if (arr && arr.length > 0) {\n        const minMax = minimumMaximum(arr, field);\n\n        return (minMax.min === minMax.max) ? minMax.min.toString() : minMax.min + \" - \" + minMax.max;\n    } else {\n        return \"-\";\n    }\n}\n\nexport const dateToMoment = (date: string): Moment => moment(date, \"YYYY-MM-DD\");\n\nexport const momentToDate = (date: Moment): string => date.format(\"YYYY-MM-DD\");\n\nexport const decode = (content: string) => {\n    return decodeEntity(content);\n};\n\nexport const formatDate = (date: string): string => {\n    return moment(date, \"YYYY-MM-DD\").format('MMM DD, YYYY');\n};\n\nexport const isZipcodeValid = (zipcode?: string): boolean => {\n    if (!zipcode)\n        return true;\n    const zipcodePattern = /^\\d{5}$/;\n    return zipcodePattern.test(zipcode);\n};\n"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@renaissancerentals/renaissance-component",
3
- "version": "12.1.30",
3
+ "version": "12.1.31",
4
4
  "description": "Renaissance rentals UI component library",
5
5
  "author": "asikpradhan",
6
6
  "license": "MIT",