{"version":3,"sources":["webpack:///./src/services/modules/property.ts","webpack:///./src/views/PropertyPhotoTour.vue?6146","webpack:///./src/components/PropertyPhotoSlideShow.vue?bd50","webpack:///./src/components/PropertyPhotoSlideShow.vue","webpack:///./src/components/PropertyPhotoSlideShow.vue?92f2","webpack:///./src/components/PropertyPhotoSlideShow.vue?b0cb","webpack:///./src/views/PropertyPhotoTour.vue","webpack:///./src/views/PropertyPhotoTour.vue?e165","webpack:///./src/views/PropertyPhotoTour.vue?ad0f","webpack:///./src/composition/currency.ts","webpack:///./src/services/modules/exchangeRate.ts","webpack:///./src/composition/exchangeRate.ts","webpack:///./src/composition/service.ts"],"names":["controller","createPropertyService","client","data","config","post","action","propertyService","base","PropertyCategoryId","render","_vm","this","_h","$createElement","_c","_self","staticClass","attrs","closeRouteTo","_v","_s","estateProperty","title","typeViewModel","categoryViewModel","cityViewModel","name","stateViewModel","price","price2","class","toneViewModel","propertyPrice","_e","isRental","propertyPrice2","_l","image","index","key","imageId","propertyImageListCount","getImageId","imageKey","getPropertyPhotoSlideShowRouteTo","description","staticRenderFns","ref","swiperOptions","scopedSlots","_u","fn","proxy","propertyImage","previousPropertyImageRouteTo","nextPropertyImageRouteTo","props","type","Object","required","Number","propertyImageIndex","imageIndex","propertyImageList","findIndex","value","undefined","length","currency","currencyViewModel","categoryId","Rentals","swiper","observer","observeParents","navigation","nextEl","prevEl","component","components","PropertyPhotoSlideShow","default","scrollToImageKey","photoEl","document","getElementById","scrollIntoView","handler","evt","target","includes","nodeName","router","push","exchangeKey","pesosExchangeRateAmount","amount","isDisplayMxCurrency","Boolean","locale","convertFromUsdToMxn","Math","ceil","convertFromMxnToUsd","getUsdPrice","useCurrency","computedLocale","values","find","language","currencyCode","code","shouldConvertToMexicanPeso","parseFloat","currencySuffix","toLocaleString","minimumFractionDigits","maximumFractionDigits","createExchangeRateService","params","get","model","exchangeRateService","PESOS_EXCHANGE_KEY","useExchangeRate","request","useService","getKey","fetcher","isLoading","error","async","getFn","response","Array","isArray","e","retry","deep","immediate"],"mappings":"yHAEA,gGAgBA,MAAMA,EAAa,eAAW,YAE9B,SAASC,EAAsBC,GAC7B,MAAO,CACL,IAAIC,EAAqBC,GACvB,OAAOF,EAAOG,KACZL,EAAWM,OAAO,OAClBH,EACAC,IAIJ,OAAOD,GACL,OAAOD,EAAOG,KAAwBL,EAAWM,OAAO,UAAWH,IAGrE,OAAOA,GACL,OAAOD,EAAOG,KAAwBL,EAAWM,OAAO,UAAWH,KAKlE,MAAMI,EAAkBN,EAAsB,OAAIO,MAgIzD,IAAYC,GAAZ,SAAYA,GACV,oDACA,qDAFF,CAAYA,MAAkB,M,2CCxK9B,IAAIC,EAAS,WAAa,IAAIC,EAAIC,KAASC,EAAGF,EAAIG,eAAmBC,EAAGJ,EAAIK,MAAMD,IAAIF,EAAG,OAAOE,EAAG,UAAU,CAACE,YAAY,yDAAyD,CAACF,EAAG,WAAW,CAACE,YAAY,2HAA2HC,MAAM,CAAC,GAAKP,EAAIQ,gBAAgBJ,EAAG,UAAU,CAACE,YAAY,mCAAmC,CAACF,EAAG,UAAU,CAACE,YAAY,sDAAsD,CAACF,EAAG,UAAU,CAACE,YAAY,OAAO,CAACF,EAAG,UAAU,CAACE,YAAY,iCAAiCC,MAAM,CAAC,IAAM,WAAW,CAACH,EAAG,UAAU,CAACE,YAAY,+KAA+K,CAACF,EAAG,UAAU,CAACE,YAAY,wBAAwB,CAACF,EAAG,cAAc,CAACE,YAAY,qCAAqCC,MAAM,CAAC,MAAQ,IAAI,CAACP,EAAIS,GAAG,IAAIT,EAAIU,GAAGV,EAAIW,eAAeC,OAAO,OAAOR,EAAG,WAAW,CAACE,YAAY,cAAc,CAACN,EAAIS,GAAG,IAAIT,EAAIU,GAAGV,EAAIW,eAAeE,cAAcD,OAAO,MAAMZ,EAAIU,GAAGV,EAAIW,eAAeG,kBAAkBF,OAAO,MAAMZ,EAAIU,GAAGV,EAAIW,eAAeI,cAAcC,MAAM,KAAKhB,EAAIU,GAAGV,EAAIW,eAAeM,eAAeD,MAAM,QAAQ,GAAIhB,EAAIW,eAAeO,OAASlB,EAAIW,eAAeQ,OAAQf,EAAG,UAAU,CAACgB,MAAM,CACl0C,kEAEA,YADApB,EAAIW,eAAeG,kBAAkBO,cAAcL,KAE/C,kCACA,wCAAyC,CAAEhB,EAAIW,eAAoB,MAAEP,EAAG,UAAU,CAACA,EAAG,WAAW,CAACE,YAAY,iBAAiB,CAACN,EAAIS,GAAG,IAAIT,EAAIU,GAAGV,EAAIsB,eAAe,OAAQtB,EAAY,SAAE,CAACI,EAAG,WAAW,CAACA,EAAG,OAAO,CAACG,MAAM,CAAC,KAAM,EAAM,KAAO,eAAe,IAAIP,EAAIuB,MAAM,GAAGvB,EAAIuB,KACtRvB,EAAIwB,UAAYxB,EAAIW,eAAeO,OAASlB,EAAIW,eAAeQ,OAC/Df,EAAG,UAAU,CAACE,YAAY,2CAA2CN,EAAIuB,KAAMvB,EAAIwB,UAAYxB,EAAIW,eAAeQ,OAAQf,EAAG,UAAU,CAACA,EAAG,WAAW,CAACE,YAAY,iBAAiB,CAACN,EAAIS,GAAG,IAAIT,EAAIU,GAAGV,EAAIyB,gBAAgB,OAAOrB,EAAG,WAAW,CAACA,EAAG,OAAO,CAACG,MAAM,CAAC,KAAM,EAAM,KAAO,eAAe,IAAI,GAAGP,EAAIuB,MAAM,GAAGvB,EAAIuB,MAAM,GAAGnB,EAAG,UAAU,CAACA,EAAG,WAAW,CAACE,YAAY,mBAAmBC,MAAM,CAAC,GAAKP,EAAIQ,eAAe,CAACJ,EAAG,WAAW,CAACE,YAAY,WAAW,CAACF,EAAG,OAAO,CAACG,MAAM,CAAC,KAAM,EAAM,KAAO,YAAY,GAAGH,EAAG,WAAW,CAACG,MAAM,CAAC,KAAO,cAAc,OAAS,aAAa,IAAI,IAAI,IAAI,GAAGH,EAAG,UAAU,CAACE,YAAY,kCAAkC,CAACF,EAAG,UAAU,CAACE,YAAY,gJAAgJC,MAAM,CAAC,cAAc,CAC/0B,IACA,SACA,SACA,UACA,UACA,UACA,WACA,cAAeP,EAAI0B,GAAI1B,EAAIW,eAAgC,mBAAE,SAASgB,EAAMC,GAAO,OAAOxB,EAAG,WAAW,CAACyB,IAAIF,EAAMG,QAAQV,MAAM,CAC/H,wFACAQ,EAAQ,EAAI,GAAK,gBACjBA,EAAQ,IAAM,GAAKA,IAAU5B,EAAI+B,uBAAyB,EACtD,gBACA,IAAKxB,MAAM,CAAC,GAAKP,EAAIgC,WAAWL,EAAMM,UAAU,GAAKjC,EAAIkC,iCAAiCP,KAAS,CAACvB,EAAG,UAAU,CAACG,MAAM,CAAC,cAAc,CAACqB,EAAQ,EAAI,OAAS,WAAW,CAACxB,EAAG,YAAY,CAACE,YAAY,sCAAsCC,MAAM,CAAC,IAAQoB,EAAU,KAAI,IAAOA,EAAU,KAAG,IAAMA,EAAMQ,aAAe,GAAG,QAAU,OAAO,SAAW,YAAY,IAAI,MAAK,IAAI,GAAInC,EAAY,SAAEI,EAAG,SAAS,CAACG,MAAM,CAAC,GAAK,oCAAoC,CAACH,EAAG,yBAAyB,CAACG,MAAM,CAAC,kBAAkBP,EAAIW,eAAe,YAAYX,EAAIiC,aAAa,GAAGjC,EAAIuB,MAAM,IAAI,IAAI,IACxkBa,EAAkB,G,oCCrBlB,EAAS,WAAa,IAAIpC,EAAIC,KAASC,EAAGF,EAAIG,eAAmBC,EAAGJ,EAAIK,MAAMD,IAAIF,EAAG,OAAOE,EAAG,UAAU,CAACE,YAAY,yDAAyD,CAACF,EAAG,UAAU,CAACE,YAAY,+CAA+CF,EAAG,UAAU,CAACE,YAAY,+JAA+J,CAACF,EAAG,UAAU,CAACE,YAAY,wBAAwB,CAACF,EAAG,UAAU,CAACE,YAAY,OAAO,CAACF,EAAG,UAAU,CAACE,YAAY,iCAAiCC,MAAM,CAAC,IAAM,WAAW,CAACH,EAAG,UAAU,CAACE,YAAY,+KAA+K,CAACF,EAAG,UAAU,CAACE,YAAY,wBAAwB,CAACF,EAAG,cAAc,CAACE,YAAY,gDAAgDC,MAAM,CAAC,MAAQ,IAAI,CAACP,EAAIS,GAAG,IAAIT,EAAIU,GAAGV,EAAIW,eAAeC,OAAO,OAAOR,EAAG,WAAW,CAACE,YAAY,yBAAyB,CAACN,EAAIS,GAAG,IAAIT,EAAIU,GAAGV,EAAIW,eAAeE,cAAcD,OAAO,MAAMZ,EAAIU,GAAGV,EAAIW,eAAeG,kBAAkBF,OAAO,MAAMZ,EAAIU,GAAGV,EAAIW,eAAeI,cAAcC,MAAM,KAAKhB,EAAIU,GAAGV,EAAIW,eAAeM,eAAeD,MAAM,QAAQ,GAAIhB,EAAIW,eAAeO,OAASlB,EAAIW,eAAeQ,OAAQf,EAAG,UAAU,CAACgB,MAAM,CACz0C,kEAEA,YADApB,EAAIW,eAAeG,kBAAkBO,cAAcL,KAE/C,kCACA,wCAAyC,CAAEhB,EAAIW,eAAoB,MAAEP,EAAG,UAAU,CAACA,EAAG,WAAW,CAACE,YAAY,iBAAiB,CAACN,EAAIS,GAAG,IAAIT,EAAIU,GAAGV,EAAIsB,eAAe,OAAQtB,EAAY,SAAE,CAACI,EAAG,WAAW,CAACA,EAAG,OAAO,CAACG,MAAM,CAAC,KAAM,EAAM,KAAO,eAAe,IAAIP,EAAIuB,MAAM,GAAGvB,EAAIuB,KACtRvB,EAAIwB,UAAYxB,EAAIW,eAAeO,OAASlB,EAAIW,eAAeQ,OAC/Df,EAAG,UAAU,CAACE,YAAY,2CAA2CN,EAAIuB,KAAMvB,EAAIwB,UAAYxB,EAAIW,eAAeQ,OAAQf,EAAG,UAAU,CAACA,EAAG,WAAW,CAACE,YAAY,iBAAiB,CAACN,EAAIS,GAAG,IAAIT,EAAIU,GAAGV,EAAIyB,gBAAgB,OAAOrB,EAAG,WAAW,CAACA,EAAG,OAAO,CAACG,MAAM,CAAC,KAAM,EAAM,KAAO,eAAe,IAAI,GAAGP,EAAIuB,MAAM,GAAGvB,EAAIuB,MAAM,GAAGnB,EAAG,UAAU,CAACA,EAAG,WAAW,CAACE,YAAY,8BAA8BC,MAAM,CAAC,GAAKP,EAAIQ,eAAe,CAACJ,EAAG,WAAW,CAACE,YAAY,WAAW,CAACF,EAAG,OAAO,CAACG,MAAM,CAAC,KAAM,EAAM,KAAO,YAAY,GAAGH,EAAG,WAAW,CAACG,MAAM,CAAC,KAAO,cAAc,OAAS,aAAa,IAAI,IAAI,IAAI,GAAGH,EAAG,UAAU,CAACE,YAAY,oBAAoB,CAACF,EAAG,UAAU,CAACE,YAAY,oCAAoC,CAACF,EAAG,SAAS,CAACiC,IAAI,SAAS9B,MAAM,CAAC,QAAUP,EAAIsC,eAAeC,YAAYvC,EAAIwC,GAAG,CAAC,CAACX,IAAI,UAAUY,GAAG,WAAW,OAAOzC,EAAI0B,GAAI1B,EAAIW,eAAgC,mBAAE,SAASgB,GAAO,OAAOvB,EAAG,cAAc,CAACyB,IAAIF,EAAMG,SAAS,CAAC1B,EAAG,UAAU,CAACE,YAAY,kBAAkBC,MAAM,CAAC,cAAc,CACt+B,IACA,SACA,SACA,UACA,UACA,UACA,WACA,cAAe,CAACH,EAAG,YAAY,CAACE,YAAY,wCAAwCC,MAAM,CAAC,IAAQoB,EAAU,KAAI,IAAOA,EAAU,KAAG,IAAMA,EAAMQ,aAAe,GAAG,QAAU,OAAO,SAAW,YAAY,IAAI,OAAMO,OAAM,GAAM,CAACb,IAAI,cAAcY,GAAG,WAAW,MAAO,CAACrC,EAAG,UAAU,CAACE,YAAY,6CAA6CoC,OAAM,GAAM,CAACb,IAAI,cAAcY,GAAG,WAAW,MAAO,CAACrC,EAAG,UAAU,CAACE,YAAY,6CAA6CoC,OAAM,QAAW,GAAGtC,EAAG,UAAU,CAACE,YAAY,kCAAkCC,MAAM,CAAC,cAAc,CAC1jB,IACA,SACA,SACA,UACA,UACA,UACA,WACA,cAAe,CAACH,EAAG,aAAa,CAACG,MAAM,CAAC,qBAAqB,wBAAwB,cAAc,YAAY,iBAAiB,cAAc,qBAAqB,uBAAuB,cAAc,cAAc,iBAAiB,cAAc,CAACH,EAAG,YAAY,CAACyB,IAAI7B,EAAIiC,SAAS3B,YAAY,wCAAwCC,MAAM,CAAC,IAAQP,EAAI2C,cAAkB,KAAI,IAAO3C,EAAI2C,cAAkB,KAAG,IAAM3C,EAAI2C,cAAcR,aAAe,GAAG,QAAU,OAAO,SAAW,YAAY,GAAG/B,EAAG,UAAU,CAACE,YAAY,mPAAmP,CAACF,EAAG,UAAU,CAACE,YAAY,uBAAuB,CAAEN,EAAgC,6BAAEI,EAAG,WAAW,CAACE,YAAY,qCAAqCC,MAAM,CAAC,GAAKP,EAAI4C,+BAA+B,CAACxC,EAAG,WAAW,CAACE,YAAY,WAAW,CAACF,EAAG,OAAO,CAACG,MAAM,CAAC,KAAM,EAAM,KAAO,eAAe,GAAGH,EAAG,WAAW,CAACG,MAAM,CAAC,KAAO,SAAS,OAAS,aAAa,GAAGP,EAAIuB,MAAM,GAAGnB,EAAG,UAAU,CAACE,YAAY,uBAAuB,CAAEN,EAA4B,yBAAEI,EAAG,WAAW,CAACE,YAAY,qCAAqCC,MAAM,CAAC,GAAKP,EAAI6C,2BAA2B,CAACzC,EAAG,WAAW,CAACE,YAAY,WAAW,CAACF,EAAG,OAAO,CAACG,MAAM,CAAC,KAAM,EAAM,KAAO,WAAW,GAAGH,EAAG,WAAW,CAACG,MAAM,CAAC,KAAO,UAAU,OAAS,aAAa,GAAGP,EAAIuB,MAAM,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IACv+C,EAAkB,G,YC4LP,iBAAgB,CAC7BP,KAAM,yBAEN8B,MAAO,CACLnC,eAAgB,CACdoC,KAAMC,OACNC,UAAU,GAGZhB,SAAU,CACRc,KAAMG,OACND,UAAU,IAId,MAAMH,GACJ,MAAMK,EAAqB,eAAS,KAClC,MAAMC,EAAaN,EAAMnC,eAAe0C,kBAAkBC,UACvD3B,GAAUA,EAAMM,WAAaa,EAAMb,UAEtC,OAAuB,IAAhBmB,EAAoB,EAAIA,IAG3BT,EAAgB,eACpB,IAAMG,EAAMnC,eAAe0C,kBAAkBF,EAAmBI,QAG5DX,EAA+B,eAAS,IACf,IAA7BO,EAAmBI,WACfC,EACA,eACEV,EAAMnC,eAAe0C,kBAAkBF,EAAmBI,MAAQ,KAIpEV,EAA2B,eAAS,IACxCM,EAAmBI,QACnBT,EAAMnC,eAAe0C,kBAAkBI,OAAS,OAC5CD,EACA,eACEV,EAAMnC,eAAe0C,kBAAkBF,EAAmBI,MAAQ,KAIpEjC,EAAgB,eACpB,IACE,eAAY,CACViC,MAAOT,EAAMnC,eAAeO,MAC5BwC,SAAUZ,EAAMnC,eAAegD,oBAC9BJ,OAGD9B,EAAiB,eACrB,IACE,eAAY,CACV8B,MAAOT,EAAMnC,eAAeQ,OAC5BuC,SAAUZ,EAAMnC,eAAegD,oBAC9BJ,OAGD/B,EAAW,eACf,IACEsB,EAAMnC,eAAeG,kBAAkB8C,aACvC,OAAmBC,SAGjBrD,EAAe,eAAS,IAC5B,eAAmBsC,EAAMnC,iBAGrBmD,EAAS,eAAwC,MAEjDxB,EAAgB,eAAS,KAAM,CACnCyB,UAAU,EACVC,gBAAgB,EAChBC,WAAY,CACVC,OAAQ,sBACRC,OAAQ,0BAIZ,MAAO,CACLxB,gBACArB,gBACAG,iBACAD,WACAoB,+BACAC,2BACArC,eACAsD,SACAxB,oBC9S2Y,I,YCO7Y8B,EAAY,eACd,EACA,EACA,GACA,EACA,KACA,KACA,MAIa,EAAAA,E,gCC+IA,iBAAgB,CAC7BpD,KAAM,oBAENqD,WAAY,CACVC,0BAGFxB,MAAO,CACLnC,eAAgB,CACdoC,KAAMC,OACNC,UAAU,GAGZhB,SAAU,CACRc,KAAMG,OACNqB,QAAS,MAGXC,iBAAkB,CAChBzB,KAAMG,OACNqB,QAAS,OAIb,MAAMzB,GACJ,MAAMf,EAAyB,eAC7B,IAAMe,EAAMnC,eAAe0C,kBAAkBI,QAGzCnC,EAAgB,eACpB,IACE,eAAY,CACViC,MAAOT,EAAMnC,eAAeO,MAC5BwC,SAAUZ,EAAMnC,eAAegD,oBAC9BJ,OAGD9B,EAAiB,eACrB,IACE,eAAY,CACV8B,MAAOT,EAAMnC,eAAeQ,OAC5BuC,SAAUZ,EAAMnC,eAAegD,oBAC9BJ,OAGD/B,EAAW,eACf,IACEsB,EAAMnC,eAAeG,kBAAkB8C,aACvC,OAAmBC,SAevB,SAAS7B,EAAWC,GAClB,MAAO,SAASA,EAblB,eAAU,KACR,GAAIa,EAAM0B,iBAAkB,CAC1B,MAAMC,EAAUC,SAASC,eACvB3C,EAAWc,EAAM0B,mBAGfC,GACFA,EAAQG,oBASd,MAAMpE,EAAe,eAAS,IAC5B,eAAmBsC,EAAMnC,iBAiB3B,OAdA,eAA0B,CACxBkB,IAAK,SACLgD,QAAUC,IAENA,GACAA,EAAIC,QACJ,CAAC,QAAS,YAAYC,SAAUF,EAAIC,OAAuBE,WAI7DC,EAAA,KAAOC,KAAK3E,EAAa+C,UAItB,CACLxB,yBACAT,gBACAG,iBACAD,WACAQ,aACAE,iCAAA,OACA1B,mBC7PsY,ICOxY,EAAY,eACd,EACAT,EACAqC,GACA,EACA,KACA,KACA,MAIa,e,6CClBf,oIAOA,MAAM,KAAE5C,GAAS,eAAgB,CAAE4F,YAAa,SAEnCC,EAA0B,eAAS,4BAAM7F,EAAK+D,MAAM,UAAjB,aAAM,EAAe+B,SAExDC,EAAsB,eAAS,IAC1CC,QAAQ,OAAKC,SAAW,OAAKA,QAAUJ,EAAwB9B,QAG3D,SAAUmC,EAAoBnC,GAClC,OAAOoC,KAAKC,KAAKrC,EAAQ8B,EAAwB9B,OAG7C,SAAUsC,EAAoBtC,GAClC,OAAOoC,KAAKC,KAAKrC,EAAQ8B,EAAwB9B,OAO7C,SAAUuC,EAAYvC,GAC1B,OAAOgC,EAAoBhC,OAASA,EAAQsC,EAAoBtC,GAASA,EASrE,SAAUwC,GAAY,MAC1BxC,EAD0B,OAE1BkC,EAAS,OAAKA,OAFY,SAG1B/B,IAEA,OAAO,eAAS,KAAK,QACnB,MAAMsC,EAAiBtC,GAAQ,oBAC3BV,OAAOiD,OAAO,QAAWC,KACtBC,GAAaA,EAASC,gBAAT,OAA0B1C,QAA1B,IAA0BA,OAA1B,EAA0BA,EAAU2C,cAFzB,aAC3B,EAEGZ,cAHwB,QAI3BA,EACEa,GACH5C,GACD8B,QAAQC,IAAW,OAAKA,QAAUJ,EAAwB9B,OAC5D,IAAI+B,EAA0B,kBAAV/B,EAAqBL,OAAOqD,WAAWhD,GAASA,EACpE,MAAMiD,EAAiBF,EACnB,OACQ,OAAR5C,QAAQ,IAARA,OAAA,EAAAA,EAAU2C,OAAQ,MAMtB,OAJIC,IACFhB,EAASI,EAAoBJ,IAGxB,IAAIA,EAAOmB,eAAeT,EAAgB,CAC/CU,sBAAuB,EACvBC,sBAAuB,OACnBH,Q,kCC9DV,gGAGA,MAAMnH,EAAa,eAAW,YAE9B,SAASuH,EAA0BrH,GACjC,MAAO,CACL,IAAIsH,GACF,OAAOtH,EAAOuH,IAAyBzH,EAAWM,OAAO,OAAQ,CAC/DkH,YAIJ,OAAOE,GACL,OAAOxH,EAAOG,KAAcL,EAAWM,OAAO,UAAWoH,KAKxD,MAAMC,EAAsBJ,EAA0B,OAAI/G,MAoBpDoH,EAAqB,G,kCCxClC,0EAOM,SAAUC,EAAgBH,GAC9B,MAAMI,EAAU,eAAwB,KAAM,IACzCJ,KAGL,OAAO,eAAWI,EAAS,IAAM,OAAoBL,IAAIK,EAAQ5D,U,kCCZnE,kDAGM,SAAU6D,EACdC,EACAC,GAEA,MAAM9H,EAAO,eAAI,IACX+H,EAAY,gBAAI,GAChBC,EAAQ,eAAoB,MAOlCC,eAAeC,IACb,IACEH,EAAUhE,OAAQ,EAClB,MAAMoE,QAAiBL,IACvB9H,EAAK+D,MAAQqE,MAAMC,QAAQF,EAASnI,MAChCmI,EAASnI,KACT,CAACmI,EAASnI,MACd,MAAOsI,GACPN,EAAMjE,MAAQuE,EAPhB,QASEP,EAAUhE,OAAQ,GAItBkE,eAAeM,UACPL,IAGR,OAvBA,eAAML,EAAQK,EAAO,CACnBM,MAAM,EACNC,WAAW,IAqBN,CACLzI,OACA+H,YACAC,QACAO","file":"js/PropertyPhotoTour.vue.c2da5326.js","sourcesContent":["import { Color } from '@/design/system/helpers'\nimport { AxiosInstance, AxiosRequestConfig } from 'axios'\nimport { api } from '../client'\nimport {\n GuidIdTableType,\n IdReturnViewModel,\n IntIdTableType,\n PaginationList,\n PaginationSelectModel,\n serviceUrl,\n} from '../utils'\nimport { AgentViewModel } from './agent'\nimport { AreaViewModel } from './area'\nimport { CategoryViewModel } from './category'\nimport { TagViewModel } from './tag'\nimport { TypeViewModel } from './type'\nimport { CurrencyViewModel } from './currency'\n\nconst controller = serviceUrl('property')\n\nfunction createPropertyService(client: AxiosInstance) {\n return {\n get(data: PropertyModel, config?: AxiosRequestConfig) {\n return client.post(\n controller.action('get'),\n data,\n config\n )\n },\n\n insert(data: PropertyInsertModel) {\n return client.post(controller.action('insert'), data)\n },\n\n update(data: PropertyUpdateModel) {\n return client.post(controller.action('update'), data)\n },\n }\n}\n\nexport const propertyService = createPropertyService(api.base)\n\nexport type PropertyGetViewModel = PaginationList\n\nexport interface PropertyModel extends PaginationSelectModel {\n languageId?: string\n isRecommendation?: boolean\n isFeatureListing?: boolean\n isDeleted?: boolean\n bottomLatitude?: string\n topLatitude?: string\n leftLongitude?: string\n rightLongitude?: string\n propertyKey?: number\n categoryId?: string\n agentKey?: number\n bathroom?: number\n bedroom?: number\n minPrice?: number\n minPrice2?: number\n maxPrice?: number\n maxPrice2?: number\n orderBy?: string\n excludePropertyKey?: number\n propertyTypeList?: GuidIdTableType[]\n propertyAreaList?: GuidIdTableType[]\n propertyKeyList?: IntIdTableType[]\n AvailableRentalStartingDate?: Date\n AvailableRentalEndingDate?: Date\n}\n\nexport interface PropertyViewModel {\n propertyId: string\n propertyKey: number\n mlsPropertyId: string\n price: number\n price2: number\n cleaningFee: number\n bathroom: number\n bedroom: number\n isRecommendation: boolean\n isFeatureListing: boolean\n isDeleted: boolean\n virtualTour: string\n displayOrder: number\n title: string\n description: string\n addressViewModel: AddressViewModel\n areaViewModel: AreaViewModel\n cityViewModel: CityViewModel\n stateViewModel: StateViewModel\n countryViewModel: CountryViewModel\n agentViewModel: AgentViewModel\n typeViewModel: TypeViewModel\n categoryViewModel: CategoryViewModel\n tagViewModel: TagViewModel | null\n currencyViewModel: CurrencyViewModel\n propertyImageList: PropertyImageViewModel[]\n propertyGroupList: PropertyGroupViewModel[]\n calendarList: CalendarViewModel[]\n}\n\nexport interface AddressViewModel {\n addressId: string\n addressKey: number\n name: string\n lineOne: string\n lineTwo: string\n postalCode: string\n latitude: string\n longitude: string\n}\n\nexport interface CityViewModel {\n cityId: string\n cityKey: number\n name: string\n}\n\nexport interface StateViewModel {\n stateId: string\n stateKey: number\n name: string\n}\n\nexport interface CountryViewModel {\n countryId: string\n countryKey: number\n name: string\n}\n\nexport interface ToneViewModel {\n toneId: string\n toneKey: number\n name: Color\n}\n\nexport interface PropertyImageViewModel {\n imageId: string\n imageKey: number\n propertyId: string\n name: string\n description: string | null\n path: string\n displayOrder: number\n}\n\nexport interface PropertyGroupViewModel {\n groupId: string\n groupKey: number\n name: string\n title: string\n description: string\n detailList: PropertyDetailViewModel[]\n}\n\nexport interface PropertyDetailViewModel {\n detailId: string\n detailKey: number\n name: string\n description: string\n propertyDetailTitle: string\n propertyDetailDescription: string\n value: string\n groupId: string\n propertyId: string\n}\n\nexport enum PropertyCategoryId {\n ForSale = '74e39077-4d67-eb11-9ffe-00155e010303',\n Rentals = '75e39077-4d67-eb11-9ffe-00155e010303',\n}\n\nexport interface PropertyInsertModel {\n areaId?: string\n agentId?: string\n typeId?: string\n categoryId?: string\n tagId?: string\n currencyId?: string\n addressName: string\n addressLineOne: string\n addressLineTwo: string\n addressPostalCode: string\n addressLatitude: string\n addressLongitude: string\n mlsPropertyId: string\n price?: number\n price2?: number\n cleaningFee?: number\n bathroom?: number\n bedroom?: number\n isRecommendation?: boolean\n isFeatureListing?: boolean\n isDeleted?: boolean\n virtualTour: string\n displayOrder?: number\n detailValueTableType: DetailValueTableType[]\n propertyTextTableType: PropertyTextTableType[]\n calendarTableType: CalendarTableType[]\n fileTableType: FileTableType[]\n}\n\nexport interface PropertyUpdateModel {\n propertyId: string\n areaId?: string\n agentId?: string\n typeId?: string\n categoryId?: string\n tagId?: string\n currencyId?: string\n addressId?: string\n addressName: string\n addressLineOne: string\n addressLineTwo: string\n addressPostalCode: string\n addressLatitude: string\n addressLongitude: string\n mlsPropertyId: string\n price?: number\n price2?: number\n cleaningFee?: number\n bathroom?: number\n bedroom?: number\n isRecommendation?: boolean\n isFeatureListing?: boolean\n isDeleted?: boolean\n virtualTour: string\n displayOrder?: number\n detailValueTableType: DetailValueTableType[]\n propertyTextTableType: PropertyTextTableType[]\n calendarTableType: CalendarTableType[]\n fileTableType: FileTableType[]\n fileListToDelete: FileTableType[]\n}\n\nexport interface DetailValueTableType {\n detailId: string\n languageId: string\n value: string\n}\n\nexport interface PropertyTextTableType {\n propertyId: string\n languageId: string\n title: string\n description: string\n}\n\nexport interface FileTableType {\n dataUrl: string\n name: string\n description: string\n extension: string\n path: string\n displayOrder: number\n}\n\nexport interface CalendarTableType {\n startingDate: Date\n endingDate: Date\n}\n\nexport interface CalendarViewModel {\n propertyId: string\n startingDate: string\n endingDate: string\n}\n","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('BaseBox',{staticClass:\"relative flex justify-center h-full lg:py-12 xl:py-20\"},[_c('BaseLink',{staticClass:\"\\n bg-gray-900 bg-opacity-50\\n absolute\\n inset-0\\n w-full\\n h-full\\n cursor-default\\n \",attrs:{\"to\":_vm.closeRouteTo}}),_c('BaseBox',{staticClass:\"relative max-w-screen-lg w-full\"},[_c('BaseBox',{staticClass:\"bg-white flex flex-col h-full lg:shadow lg:rounded\"},[_c('BaseBox',{staticClass:\"p-6\"},[_c('BaseBox',{staticClass:\"flex space-x-6 xl:items-center\",attrs:{\"tag\":\"header\"}},[_c('BaseBox',{staticClass:\"\\n flex-1 flex flex-col\\n space-y-4\\n items-start\\n xl:flex-row xl:space-y-0 xl:space-x-4 xl:items-center\\n \"},[_c('BaseBox',{staticClass:\"grid gap-2 xl:flex-1\"},[_c('BaseHeading',{staticClass:\"text-2xl xl:text-3xl font-semibold\",attrs:{\"level\":1}},[_vm._v(\" \"+_vm._s(_vm.estateProperty.title)+\" \")]),_c('BaseText',{staticClass:\"xl:text-lg\"},[_vm._v(\" \"+_vm._s(_vm.estateProperty.typeViewModel.title)+\" · \"+_vm._s(_vm.estateProperty.categoryViewModel.title)+\" · \"+_vm._s(_vm.estateProperty.cityViewModel.name)+\", \"+_vm._s(_vm.estateProperty.stateViewModel.name)+\" \")])],1),(_vm.estateProperty.price || _vm.estateProperty.price2)?_c('BaseBox',{class:[\n 'grid gap-2 rounded-md py-3 px-6 text-xl xl:text-3xl text-center',\n _vm.estateProperty.categoryViewModel.toneViewModel.name ===\n 'primary'\n ? 'bg-primary text-primary-inverse'\n : 'bg-secondary text-secondary-inverse' ]},[(_vm.estateProperty.price)?_c('BaseBox',[_c('BaseText',{staticClass:\"font-semibold\"},[_vm._v(\" \"+_vm._s(_vm.propertyPrice)+\" \")]),(_vm.isRental)?[_c('BaseText',[_c('i18n',{attrs:{\"tag\":false,\"path\":\"perNight\"}})],1)]:_vm._e()],2):_vm._e(),(\n _vm.isRental && _vm.estateProperty.price && _vm.estateProperty.price2\n )?_c('BaseBox',{staticClass:\"border border-secondary-700 rounded-md\"}):_vm._e(),(_vm.isRental && _vm.estateProperty.price2)?_c('BaseBox',[_c('BaseText',{staticClass:\"font-semibold\"},[_vm._v(\" \"+_vm._s(_vm.propertyPrice2)+\" \")]),_c('BaseText',[_c('i18n',{attrs:{\"tag\":false,\"path\":\"perMonth\"}})],1)],1):_vm._e()],1):_vm._e()],1),_c('BaseBox',[_c('BaseLink',{staticClass:\"hover:opacity-75\",attrs:{\"to\":_vm.closeRouteTo}},[_c('BaseText',{staticClass:\"sr-only\"},[_c('i18n',{attrs:{\"tag\":false,\"path\":\"close\"}})],1),_c('BaseIcon',{attrs:{\"name\":\"close-small\",\"source\":\"custom\"}})],1)],1)],1)],1),_c('BaseBox',{staticClass:\"flex-1 overflow-auto px-6 pb-6\"},[_c('BaseBox',{staticClass:\"\\n grid grid-cols-2\\n gap-6\\n rounded-lg\\n overflow-hidden\\n transform-gpu\\n \",attrs:{\"width-ratio\":[\n 375,\n 'xs:639',\n 'sm:767',\n 'md:1023',\n 'lg:1279',\n 'xl:1535',\n '2xl:2047',\n '3xl:2048' ]}},_vm._l((_vm.estateProperty.propertyImageList),function(image,index){return _c('BaseLink',{key:image.imageId,class:[\n 'relative bg-gray-200 aspect-w-16 aspect-h-9 filter transition-all hover:brightness-75',\n index % 3 ? '' : 'col-span-full',\n index % 3 === 1 && index === _vm.propertyImageListCount - 1\n ? 'col-span-full'\n : '' ],attrs:{\"id\":_vm.getImageId(image.imageKey),\"to\":_vm.getPropertyPhotoSlideShowRouteTo(image)}},[_c('BaseBox',{attrs:{\"width-ratio\":[index % 3 ? '6/12' : '12/12']}},[_c('BaseImage',{staticClass:\"absolute w-full h-full object-cover\",attrs:{\"src\":((image.path) + \"/\" + (image.name)),\"alt\":image.description || '',\"loading\":\"lazy\",\"decoding\":\"async\"}})],1)],1)}),1)],1),(_vm.imageKey)?_c('Portal',{attrs:{\"to\":\"route-secondary-modal-container\"}},[_c('PropertyPhotoSlideShow',{attrs:{\"estate-property\":_vm.estateProperty,\"image-key\":_vm.imageKey}})],1):_vm._e()],1)],1)],1)}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('BaseBox',{staticClass:\"relative flex justify-center h-full lg:py-12 xl:py-20\"},[_c('BaseBox',{staticClass:\"bg-gray-900 absolute inset-0 w-full h-full\"}),_c('BaseBox',{staticClass:\"\\n relative\\n max-w-screen-lg\\n xl:max-w-screen-xl\\n 2xl:max-w-screen-2xl\\n 3xl:max-w-screen-3xl\\n w-full\\n h-full\\n \"},[_c('BaseBox',{staticClass:\"flex flex-col h-full\"},[_c('BaseBox',{staticClass:\"p-6\"},[_c('BaseBox',{staticClass:\"flex space-x-6 xl:items-center\",attrs:{\"tag\":\"header\"}},[_c('BaseBox',{staticClass:\"\\n flex-1 flex flex-col\\n space-y-4\\n items-start\\n xl:flex-row xl:space-y-0 xl:space-x-4 xl:items-center\\n \"},[_c('BaseBox',{staticClass:\"grid gap-2 xl:flex-1\"},[_c('BaseHeading',{staticClass:\"text-white text-2xl xl:text-3xl font-semibold\",attrs:{\"level\":1}},[_vm._v(\" \"+_vm._s(_vm.estateProperty.title)+\" \")]),_c('BaseText',{staticClass:\"text-white xl:text-lg\"},[_vm._v(\" \"+_vm._s(_vm.estateProperty.typeViewModel.title)+\" · \"+_vm._s(_vm.estateProperty.categoryViewModel.title)+\" · \"+_vm._s(_vm.estateProperty.cityViewModel.name)+\", \"+_vm._s(_vm.estateProperty.stateViewModel.name)+\" \")])],1),(_vm.estateProperty.price || _vm.estateProperty.price2)?_c('BaseBox',{class:[\n 'grid gap-2 rounded-md py-3 px-6 text-xl xl:text-3xl text-center',\n _vm.estateProperty.categoryViewModel.toneViewModel.name ===\n 'primary'\n ? 'bg-primary text-primary-inverse'\n : 'bg-secondary text-secondary-inverse' ]},[(_vm.estateProperty.price)?_c('BaseBox',[_c('BaseText',{staticClass:\"font-semibold\"},[_vm._v(\" \"+_vm._s(_vm.propertyPrice)+\" \")]),(_vm.isRental)?[_c('BaseText',[_c('i18n',{attrs:{\"tag\":false,\"path\":\"perNight\"}})],1)]:_vm._e()],2):_vm._e(),(\n _vm.isRental && _vm.estateProperty.price && _vm.estateProperty.price2\n )?_c('BaseBox',{staticClass:\"border border-secondary-700 rounded-md\"}):_vm._e(),(_vm.isRental && _vm.estateProperty.price2)?_c('BaseBox',[_c('BaseText',{staticClass:\"font-semibold\"},[_vm._v(\" \"+_vm._s(_vm.propertyPrice2)+\" \")]),_c('BaseText',[_c('i18n',{attrs:{\"tag\":false,\"path\":\"perMonth\"}})],1)],1):_vm._e()],1):_vm._e()],1),_c('BaseBox',[_c('BaseLink',{staticClass:\"text-white hover:opacity-75\",attrs:{\"to\":_vm.closeRouteTo}},[_c('BaseText',{staticClass:\"sr-only\"},[_c('i18n',{attrs:{\"tag\":false,\"path\":\"close\"}})],1),_c('BaseIcon',{attrs:{\"name\":\"close-small\",\"source\":\"custom\"}})],1)],1)],1)],1),_c('BaseBox',{staticClass:\"flex-1 px-6 pb-6\"},[_c('BaseBox',{staticClass:\"xl:hidden aspect-w-16 aspect-h-9\"},[_c('Swiper',{ref:\"swiper\",attrs:{\"options\":_vm.swiperOptions},scopedSlots:_vm._u([{key:\"default\",fn:function(){return _vm._l((_vm.estateProperty.propertyImageList),function(image){return _c('SwiperSlide',{key:image.imageId},[_c('BaseBox',{staticClass:\"relative h-full\",attrs:{\"width-ratio\":[\n 375,\n 'xs:639',\n 'sm:767',\n 'md:1023',\n 'lg:1279',\n 'xl:1535',\n '2xl:2047',\n '3xl:2048' ]}},[_c('BaseImage',{staticClass:\"absolute w-full h-full object-contain\",attrs:{\"src\":((image.path) + \"/\" + (image.name)),\"alt\":image.description || '',\"loading\":\"lazy\",\"decoding\":\"async\"}})],1)],1)})},proxy:true},{key:\"button-prev\",fn:function(){return [_c('BaseBox',{staticClass:\"swiper-button-prev swiper-button-white\"})]},proxy:true},{key:\"button-next\",fn:function(){return [_c('BaseBox',{staticClass:\"swiper-button-next swiper-button-white\"})]},proxy:true}])})],1),_c('BaseBox',{staticClass:\"hidden xl:block relative h-full\",attrs:{\"width-ratio\":[\n 375,\n 'xs:639',\n 'sm:767',\n 'md:1023',\n 'lg:1279',\n 'xl:1535',\n '2xl:2047',\n '3xl:2048' ]}},[_c('Transition',{attrs:{\"enter-active-class\":\"duration-200 ease-out\",\"enter-class\":\"opacity-0\",\"enter-to-class\":\"opacity-100\",\"leave-active-class\":\"duration-100 ease-in\",\"leave-class\":\"opacity-100\",\"leave-to-class\":\"opacity-0\"}},[_c('BaseImage',{key:_vm.imageKey,staticClass:\"absolute w-full h-full object-contain\",attrs:{\"src\":((_vm.propertyImage.path) + \"/\" + (_vm.propertyImage.name)),\"alt\":_vm.propertyImage.description || '',\"loading\":\"lazy\",\"decoding\":\"async\"}})],1),_c('BaseBox',{staticClass:\"\\n absolute\\n inset-0\\n w-full\\n h-full\\n pointer-events-none\\n flex\\n justify-between\\n items-center\\n px-4\\n \"},[_c('BaseBox',{staticClass:\"pointer-events-auto\"},[(_vm.previousPropertyImageRouteTo)?_c('BaseLink',{staticClass:\"text-white text-4xl cursor-pointer\",attrs:{\"to\":_vm.previousPropertyImageRouteTo}},[_c('BaseText',{staticClass:\"sr-only\"},[_c('i18n',{attrs:{\"tag\":false,\"path\":\"previous\"}})],1),_c('BaseIcon',{attrs:{\"name\":\"left-c\",\"source\":\"custom\"}})],1):_vm._e()],1),_c('BaseBox',{staticClass:\"pointer-events-auto\"},[(_vm.nextPropertyImageRouteTo)?_c('BaseLink',{staticClass:\"text-white text-4xl cursor-pointer\",attrs:{\"to\":_vm.nextPropertyImageRouteTo}},[_c('BaseText',{staticClass:\"sr-only\"},[_c('i18n',{attrs:{\"tag\":false,\"path\":\"next\"}})],1),_c('BaseIcon',{attrs:{\"name\":\"right-c\",\"source\":\"custom\"}})],1):_vm._e()],1)],1)],1)],1)],1)],1)],1)}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\nimport { useCurrency } from '@/composition/currency'\nimport {\n PropertyCategoryId,\n PropertyViewModel,\n} from '@/services/modules/property'\nimport {\n getPropertyRouteTo,\n getPropertyPhotoSlideShowRouteTo,\n} from '@/utils/property'\nimport { Swiper } from 'vue-awesome-swiper'\nimport { computed, defineComponent, PropType, ref } from '@vue/composition-api'\n\nexport default defineComponent({\n name: 'PropertyPhotoSlideShow',\n\n props: {\n estateProperty: {\n type: Object as PropType,\n required: true,\n },\n\n imageKey: {\n type: Number,\n required: true,\n },\n },\n\n setup(props) {\n const propertyImageIndex = computed(() => {\n const imageIndex = props.estateProperty.propertyImageList.findIndex(\n (image) => image.imageKey === props.imageKey\n )\n return imageIndex === -1 ? 0 : imageIndex\n })\n\n const propertyImage = computed(\n () => props.estateProperty.propertyImageList[propertyImageIndex.value]\n )\n\n const previousPropertyImageRouteTo = computed(() =>\n propertyImageIndex.value === 0\n ? undefined\n : getPropertyPhotoSlideShowRouteTo(\n props.estateProperty.propertyImageList[propertyImageIndex.value - 1]\n )\n )\n\n const nextPropertyImageRouteTo = computed(() =>\n propertyImageIndex.value ===\n props.estateProperty.propertyImageList.length - 1\n ? undefined\n : getPropertyPhotoSlideShowRouteTo(\n props.estateProperty.propertyImageList[propertyImageIndex.value + 1]\n )\n )\n\n const propertyPrice = computed(\n () =>\n useCurrency({\n value: props.estateProperty.price,\n currency: props.estateProperty.currencyViewModel,\n }).value\n )\n\n const propertyPrice2 = computed(\n () =>\n useCurrency({\n value: props.estateProperty.price2,\n currency: props.estateProperty.currencyViewModel,\n }).value\n )\n\n const isRental = computed(\n () =>\n props.estateProperty.categoryViewModel.categoryId ===\n PropertyCategoryId.Rentals\n )\n\n const closeRouteTo = computed(() =>\n getPropertyRouteTo(props.estateProperty)\n )\n\n const swiper = ref | null>(null)\n\n const swiperOptions = computed(() => ({\n observer: true,\n observeParents: true,\n navigation: {\n nextEl: '.swiper-button-next',\n prevEl: '.swiper-button-prev',\n },\n }))\n\n return {\n propertyImage,\n propertyPrice,\n propertyPrice2,\n isRental,\n previousPropertyImageRouteTo,\n nextPropertyImageRouteTo,\n closeRouteTo,\n swiper,\n swiperOptions,\n }\n },\n})\n","import mod from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--14-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/ts-loader/index.js??ref--14-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./PropertyPhotoSlideShow.vue?vue&type=script&lang=ts&\"; export default mod; export * from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--14-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/ts-loader/index.js??ref--14-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./PropertyPhotoSlideShow.vue?vue&type=script&lang=ts&\"","import { render, staticRenderFns } from \"./PropertyPhotoSlideShow.vue?vue&type=template&id=0041e76b&\"\nimport script from \"./PropertyPhotoSlideShow.vue?vue&type=script&lang=ts&\"\nexport * from \"./PropertyPhotoSlideShow.vue?vue&type=script&lang=ts&\"\n\n\n/* normalize component */\nimport normalizer from \"!../../node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n null,\n null\n \n)\n\nexport default component.exports","\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\nimport { useCurrency } from '@/composition/currency'\nimport {\n PropertyCategoryId,\n PropertyViewModel,\n} from '@/services/modules/property'\nimport {\n getPropertyRouteTo,\n getPropertyPhotoSlideShowRouteTo,\n} from '@/utils/property'\nimport PropertyPhotoSlideShow from '@/components/PropertyPhotoSlideShow.vue'\nimport { useWindowKeyboardListener } from '@/composition/windowKeyboardListener'\nimport router from '@/router'\nimport {\n computed,\n defineComponent,\n onMounted,\n PropType,\n} from '@vue/composition-api'\n\nexport default defineComponent({\n name: 'PropertyPhotoTour',\n\n components: {\n PropertyPhotoSlideShow,\n },\n\n props: {\n estateProperty: {\n type: Object as PropType,\n required: true,\n },\n\n imageKey: {\n type: Number as PropType,\n default: null,\n },\n\n scrollToImageKey: {\n type: Number as PropType,\n default: null,\n },\n },\n\n setup(props) {\n const propertyImageListCount = computed(\n () => props.estateProperty.propertyImageList.length\n )\n\n const propertyPrice = computed(\n () =>\n useCurrency({\n value: props.estateProperty.price,\n currency: props.estateProperty.currencyViewModel,\n }).value\n )\n\n const propertyPrice2 = computed(\n () =>\n useCurrency({\n value: props.estateProperty.price2,\n currency: props.estateProperty.currencyViewModel,\n }).value\n )\n\n const isRental = computed(\n () =>\n props.estateProperty.categoryViewModel.categoryId ===\n PropertyCategoryId.Rentals\n )\n\n onMounted(() => {\n if (props.scrollToImageKey) {\n const photoEl = document.getElementById(\n getImageId(props.scrollToImageKey)\n )\n\n if (photoEl) {\n photoEl.scrollIntoView()\n }\n }\n })\n\n function getImageId(imageKey: number) {\n return `photo-${imageKey}`\n }\n\n const closeRouteTo = computed(() =>\n getPropertyRouteTo(props.estateProperty)\n )\n\n useWindowKeyboardListener({\n key: 'Escape',\n handler: (evt) => {\n if (\n evt &&\n evt.target &&\n ['INPUT', 'TEXTAREA'].includes((evt.target as HTMLElement).nodeName)\n )\n return\n\n router.push(closeRouteTo.value)\n },\n })\n\n return {\n propertyImageListCount,\n propertyPrice,\n propertyPrice2,\n isRental,\n getImageId,\n getPropertyPhotoSlideShowRouteTo,\n closeRouteTo,\n }\n },\n})\n","import mod from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--14-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/ts-loader/index.js??ref--14-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./PropertyPhotoTour.vue?vue&type=script&lang=ts&\"; export default mod; export * from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--14-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/ts-loader/index.js??ref--14-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./PropertyPhotoTour.vue?vue&type=script&lang=ts&\"","import { render, staticRenderFns } from \"./PropertyPhotoTour.vue?vue&type=template&id=22742dd4&\"\nimport script from \"./PropertyPhotoTour.vue?vue&type=script&lang=ts&\"\nexport * from \"./PropertyPhotoTour.vue?vue&type=script&lang=ts&\"\n\n\n/* normalize component */\nimport normalizer from \"!../../node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n null,\n null\n \n)\n\nexport default component.exports","import { PESOS_EXCHANGE_KEY } from '@/services/modules/exchangeRate'\nimport i18n from '@/setup/i18n'\nimport { esMx, languages } from '@/utils/language'\nimport { computed } from '@vue/composition-api'\nimport { useExchangeRate } from './exchangeRate'\nimport { CurrencyViewModel } from '@/services/modules/currency'\n\nconst { data } = useExchangeRate({ exchangeKey: PESOS_EXCHANGE_KEY })\n\nexport const pesosExchangeRateAmount = computed(() => data.value[0]?.amount)\n\nexport const isDisplayMxCurrency = computed(() =>\n Boolean(i18n.locale === esMx.locale && pesosExchangeRateAmount.value)\n)\n\nexport function convertFromUsdToMxn(value: number) {\n return Math.ceil(value * pesosExchangeRateAmount.value)\n}\n\nexport function convertFromMxnToUsd(value: number) {\n return Math.ceil(value / pesosExchangeRateAmount.value)\n}\n\nexport function getLocalizedPrice(value: number | undefined) {\n return isDisplayMxCurrency.value && value ? convertFromUsdToMxn(value) : value\n}\n\nexport function getUsdPrice(value: number | undefined) {\n return isDisplayMxCurrency.value && value ? convertFromMxnToUsd(value) : value\n}\n\nexport interface UseCurrencyOptions {\n value: number | string\n locale?: string\n currency?: CurrencyViewModel\n}\n\nexport function useCurrency({\n value,\n locale = i18n.locale,\n currency,\n}: UseCurrencyOptions) {\n return computed(() => {\n const computedLocale = currency\n ? Object.values(languages).find(\n (language) => language.currencyCode === currency?.code\n )?.locale ?? locale\n : locale\n const shouldConvertToMexicanPeso =\n !currency &&\n Boolean(locale === esMx.locale && pesosExchangeRateAmount.value)\n let amount = typeof value === 'string' ? Number.parseFloat(value) : value\n const currencySuffix = shouldConvertToMexicanPeso\n ? 'MXN'\n : currency?.code || 'USD'\n\n if (shouldConvertToMexicanPeso) {\n amount = convertFromUsdToMxn(amount)\n }\n\n return `$${amount.toLocaleString(computedLocale, {\n minimumFractionDigits: 0,\n maximumFractionDigits: 2,\n })} ${currencySuffix}`\n })\n}\n","import { AxiosInstance } from 'axios'\nimport { api } from '../client'\nimport { Audit, serviceUrl } from '../utils'\n\nconst controller = serviceUrl('exchange')\n\nfunction createExchangeRateService(client: AxiosInstance) {\n return {\n get(params: ExchangeModel) {\n return client.get(controller.action('get'), {\n params,\n })\n },\n\n update(model: ExchangeUpdateModel) {\n return client.post(controller.action('update'), model)\n },\n }\n}\n\nexport const exchangeRateService = createExchangeRateService(api.base)\n\nexport interface ExchangeModel {\n exchangeKey?: number\n}\n\nexport interface ExchangeUpdateModel {\n exchangeId: string\n amount: number\n}\n\nexport interface ExchangeViewModel extends Audit {\n exchangeId: string\n exchangeKey: number\n name: string\n abbreviation: string\n amount: number\n isDeleted: boolean\n}\n\nexport const PESOS_EXCHANGE_KEY = 1\n","import {\n ExchangeModel,\n exchangeRateService,\n} from '@/services/modules/exchangeRate'\nimport { computed } from '@vue/composition-api'\nimport { useService } from './service'\n\nexport function useExchangeRate(model?: ExchangeModel) {\n const request = computed(() => ({\n ...model,\n }))\n\n return useService(request, () => exchangeRateService.get(request.value))\n}\n","import { Ref, ref, watch, WatchSource } from '@vue/composition-api'\nimport { AxiosResponse } from 'axios'\n\nexport function useService(\n getKey: WatchSource,\n fetcher: (...args: any) => Promise>\n) {\n const data = ref([]) as Ref\n const isLoading = ref(false)\n const error = ref(null)\n\n watch(getKey, getFn, {\n deep: true,\n immediate: true,\n })\n\n async function getFn() {\n try {\n isLoading.value = true\n const response = await fetcher()\n data.value = Array.isArray(response.data)\n ? response.data\n : [response.data]\n } catch (e) {\n error.value = e\n } finally {\n isLoading.value = false\n }\n }\n\n async function retry() {\n await getFn()\n }\n\n return {\n data,\n isLoading,\n error,\n retry,\n }\n}\n"],"sourceRoot":""}