Changeset 3063353
- Timestamp:
- 04/03/2024 07:29:54 AM (23 months ago)
- Location:
- loymaxapp/trunk
- Files:
-
- 3 edited
-
public/app.min.js (modified) (5 diffs)
-
public/css/style.min.css (modified) (2 diffs)
-
readme.txt (modified) (1 diff)
Legend:
- Unmodified
- Added
- Removed
-
loymaxapp/trunk/public/app.min.js
r2868514 r3063353 1 1 /** 2 * Loymax v 2.2.20230221(http://loymax.ru)3 * Copyright 2011-202 3Loymax, Inc.2 * Loymax v3.4.20240403-.9 (http://loymax.ru) 3 * Copyright 2011-2024 Loymax, Inc. 4 4 * License: MIT 5 5 * … … 9073 9073 "use strict";!function(n){n.module("lmxApp").service("couponsService",["$http","configurationService","LIMITS",function(n,t,e){function o(t){return n.get(u,{params:{count:e.INT32_MAX,onlyActive:t}}).then(function(n){return n.data})}function r(t){return n.get(u+t).then(function(n){return n.data})}var u=t.host+"api/coupons/";return{getUserCoupons:o,getUserCoupon:r}}])}(angular); 9074 9074 "use strict";!function(e){e.module("lmxApp").controller("couponViewModalController",["$scope","$uibModalInstance","coupon",function(e,t,o){e.coupon=o;var n=new Date;if(e.coupon.expiryDate){var a=e.coupon.expiryDate-e.coupon.activationDate,r=e.coupon.expiryDate.toUTCDate()-new Date;e.expiryTimePercent=Math.trunc(100*r/a)}e.offerProceed=function(e){return n>=e.toUTCDate()},e.offerStartedToday=function(e){return e.toUTCDate()<n&&e.toUTCDate().getDate()===n.getDate()},e.lessThanWeek=function(t){var o=86400,n=604800;if((t.toUTCDate()-new Date)/1e3<n){var a=(t.toUTCDate()-new Date)/1e3;e.leftDays=Math.trunc(a/o),e.leftHours=Math.trunc(a%o/3600)}return(t.toUTCDate()-new Date)/1e3<n},e.cancel=function(){t.dismiss()}}])}(angular); 9075 "use strict";!function(t){t.module("lmxApp").directive("lmxCustomUserStatus",["$rootScope","configurationService","translatePluralService","$http","$sce","lmxCustomUserStatusService",function(t,e,r,s,a,u){return{restrict:"E",replace:!0,scope:{cardsInfo:"<"},templateUrl:"app/directives/customStatus/customUserStatus.html",link:function(n){function c(){n.counterStatus=t.userStatus.find(function(t){return t.logicalName===m}),n.counterStatus.currentValue<=0&&(n.counterStatus.currentValue=0);var e=n.counterStatus.currentValue;n.currentIndex=n.purchases.findIndex(function(t,r){return e>=t&&!n.purchases[r+1]?n.purchases.length-1:e>=t&&e<n.purchases[r+1]})}function o(){n.currentStatusSystem=t.userStatus.find(function(t){return t.logicalName===h}),u.modifyStatusSystem(n.currentStatusSystem),n.currentStatusSystem.nextStatusValue&&(n.needPurchases=(n.currentStatusSystem.nextStatusValue-n.currentStatusSystem.currentValue).toFixed(2)),n.currentStatusIndex=n.currentStatusSystem.statuses.map(function(t){return t.name}).indexOf(n.currentStatusSystem.currentStatus.name),n.UAZcircleHTML=i(n.currentStatusSystem.statuses[n.currentStatusIndex]),n.showStatus=!0}function i(t){var e=t.threshold/100;n.purchasesLeft=t.threshold-n.currentStatusSystem.currentValue;var r,s=(t.threshold-n.purchasesLeft)/e,c=v/100*s,o="0 0 ".concat(c," ").concat(v),i='transform="rotate(-90) translate(-64)"',S=u.drawSector(y,o,i),l="".concat(n.currentStatusSystem.currentValue),m="";null===t.threshold&&(r="из ".concat(n.currentStatusSystem.statuses[3].threshold)),n.currentStatusSystem.currentValue<=t.threshold&&(m='<circle cx="32" cy="32" r="30" stroke="'.concat(p,'" stroke-width="4px" fill="transparent" />'),r="из ".concat(t.threshold));var d=u.getSvgTextUAZ(l,r,y),f="".concat(S).concat(d),h=a.trustAsHtml('<svg viewBox="0 0 68 68" class="pie">'.concat(m).concat(f,"</svg>"));return h}n.statusLoader=!1,n.showStatus=!1,n.purchases=[5,10,15,20,25],n.couponPreference=[50,60,70,80,100],n.nameCases={genitive:"покупки",nominative:"покупку",plural:"покупок"},n.showHint=!1,n.purchasesLeft=0;var S=n.cardsInfo,l=["Балаково","Вольск"],m="StatusSystem3",d="StatusSystem2",f="StatusSystem4",h="StatusSystem5",y="#F6822F",p="#D6DFEA",v=2*Math.PI*30;n.isUAZstatusSystem=!1,c(),S.find(function(t){return"Карта УАЗ"===t.cardCategory.logicalName})?(n.isUAZstatusSystem=!0,o()):(n.statusLoader=!0,s.get(e.host+"api/User?payload=Attributes.City").then(function(e){n.showStatus=l.includes(e.data.attributes.city.stringValue);var r=e.data.id,s=S.find(function(t){return t.cardOwnerInfo.id===r}),a=s.cardCategory.logicalName;"VIP"===a||"Employee_card"===a?n.currentStatusSystem=t.userStatus.find(function(t){return t.logicalName===f}):n.currentStatusSystem=t.userStatus.find(function(t){return t.logicalName===d}),n.currentStatusIndex=n.currentStatusSystem.statuses.map(function(t){return t.name}).indexOf(n.currentStatusSystem.currentStatus.name),u.modifyStatusSystem(n.currentStatusSystem)})["finally"](function(){n.statusLoader=!1})),n.toggleHint=function(){n.showHint=!n.showHint},n.getCurrencyNameCase=function(t){switch(r.getTranslationKey(t)){case"one":return"nominative";case"few":return"genitive";default:return"plural"}},n.getRound=function(t){var e=u.getSvgText(t,y);if(n.counterStatus.currentValue>=t){var r=u.drawGrayCircle(y),s="".concat(r).concat(e),c=a.trustAsHtml('<svg viewBox="0 0 68 68" class="pie">'.concat(s,"</svg>"));return c}var o=u.drawGrayCircle(p);if(t===n.purchases[n.currentIndex+1]){n.purchasesLeft=t-n.counterStatus.currentValue;var i=t-(n.purchases[n.currentIndex]||0),S=100*(i-n.purchasesLeft)/i,l=v/100*S,m="0 0 ".concat(l," ").concat(v),d='transform="rotate(-90) translate(-64, 64) scale(1,-1)"',f="".concat(u.drawSector(y,m,d)).concat(e),h=a.trustAsHtml('<svg viewBox="0 0 68 68" class="pie">'.concat(o).concat(f,"</svg>"));return h}e=u.getSvgText(t,p);var g="".concat(o).concat(e),x=a.trustAsHtml('<svg viewBox="0 0 68 68" class="pie">'.concat(g,"</svg>"));return x}}}}])}(angular); 9076 "use strict";!function(t){t.module("lmxApp").factory("lmxCustomUserStatusService",function(){function t(t){t.statuses.forEach(function(t){if(!Array.isArray(t.description)){var n=t.description.split("\n");t.description=[],n.forEach(function(n){t.description.push({text:n.split("-")[0].replace("• ",""),value:n.split("-")[1],additional:n.split("-")[2]||null})})}})}function n(t){return'<circle cx="32" cy="32" r="30" stroke="'.concat(t,'" stroke-width="4px" />')}function e(t,n){return'<text x="50%" y="50%" text-anchor="middle" fill="'.concat(n,'" stroke-width="2px" font-size="23px" dy=".2em" dx="-.1em">').concat(t,"</text>")}function r(t,n,e){return'<circle cx="32" cy="32" r="30" stroke="'.concat(t,'" stroke-width="4px" stroke-dasharray="').concat(n,'" ').concat(e,' stroke-linecap="round" fill="transparent"/>')}function c(t,n,e){return'<text text-anchor="middle" fill="'.concat(e,'" stroke-width="2px" font-size="10px" dy=".2em" dx="-.1em">\n <tspan x="50%" y="38%">\n ').concat(t,'\n </tspan>\n <tspan x="50%" y="58%">\n ').concat(n,"\n </tspan>\n </text>")}return{modifyStatusSystem:t,drawGrayCircle:n,drawSector:r,getSvgText:e,getSvgTextUAZ:c}})}(angular); 9075 9077 "use strict";!function(e){e.module("lmxApp").directive("datePicker",["$locale",function(t){return{restrict:"E",require:"ngModel",scope:{initDate:"=?",timezone:"@",inputClass:"@"},replace:!0,link:{pre:function(t,i,a){var n=e.element(i[0].children[0]);for(var r in a.$attr)a.$attr.hasOwnProperty(r)&&n.attr(a.$attr[r],a[r]);var o=new Date;t.modelOptions={allowInvalid:!0},t.modelOptions.timezone=t.timezone||o.getTimezoneOffset()*-1,t.initDate=t.initDate||o},post:function(t,i,a,n){function r(t){return e.isDefined(a.asUtc)&&e.isDefined(t)&&t instanceof Date}var o={ru:"dd.MM.yyyy"};t.dateFormat=o.ru,t.options={showWeeks:!1,initDate:t.initDate,formatMonth:"LLLL",formatDayTitle:"LLLL yyyy"},t.isOpen=!1,t.toggleCalendar=function(i,a){t.isOpen=e.isDefined(a)?a:!t.isOpen,t.isOpen||(t.$$childHead.showPicker="date")},t.$watch("model",function(i,a){!e.isDefined(a)&&e.isDefined(i)&&n.$setValidity("date",!0),r(i)&&(i=i.toUTCDate(!0)),n.$setViewValue(i),t.validateModel()}),t.validateModel=function(e){var i=!e||!e.target.value.length||t.model instanceof Date;n.$setValidity("date",i),n.$validators.hasOwnProperty("required")&&n.$$attr.required&&n.$setValidity("required",e&&e.target.value.length||!!t.model)},n.$render=function(){var e=n.$viewValue;r(e)&&(e=e.toUTCDate()),t.model=e},i.on("$destroy",function(){t.isOpen&&e.element("body").children("ul[date-picker-wrap].datetime-picker-dropdown").remove()})}},templateUrl:"app/directives/datePicker/datePickerView.html"}}])}(angular); 9076 9078 "use strict";!function(e){e.module("lmxApp").directive("dateTimePicker",["$locale","$translate","datePickerDirective",function(t,i,a){function r(e){i(["datePicker.date","datePicker.time"]).then(function(t){var i={ru:"dd.MM.yyyy HH:mm"};e.dateFormat=i.ru,e.timepickerOptions={showMeridian:e.dateFormat.match(/h/)},e.buttonsOptions={show:!0,date:{show:!0,text:t["datePicker.date"]},time:{show:!0,text:t["datePicker.time"]},now:{show:!1},today:{show:!1},clear:{show:!1},close:{show:!1}}})}return r.$inject=["$scope"],e.extend({},a[0],{templateUrl:"app/directives/dateTimePicker/dateTimePickerView.html",controller:r})}])}(angular); … … 9143 9145 "use strict";!function(e){e.module("lmxApp").factory("reCaptchaService",["$log","$q","$rootScope","$timeout",function(e,r,t,n){function o(){a.value=!1,c.value=null}function u(u){c.value=u;var i=r.defer();return n(function(){a.value=!0}),t.$on("reCaptchaSuccess",function(e,r){o(),i.resolve(r)}),t.$on("reCaptchaError",function(){e.error("reCaptcha error. See the badge in left-bottom corner for more information.\r\nCurrent siteKey is `"+c.value+"`"),i.reject()}),i.promise}var a={value:!1},c={value:null};return{reCaptchaCheckingInProgress:a,siteKey:c,execute:u}}])}(angular); 9144 9146 "use strict";!function(t){t.module("lmxApp").directive("cardAssignment",function(){return{restrict:"E",replace:!0,templateUrl:"app/directives/registration/cardAssignment.html"}})}(angular); 9145 "use strict";!function(e){e.module("lmxApp").directive("lmxRegistration",["$q","$rootScope","$log","$http","authService","cardsService","configurationService","globalService","emailConfirmationCheckerService","localStorageService","notification","registrationService","resetPasswordService","routingService","shareAuthLoginToRegistration","$translate","userAlertService","translateFilter","userService","resendService",function(t,r,n,i,o,s,a,c,u,f,g,d,l,p,m,h,S,R,v,C){return{restrict:"E",replace:!0,scope:!0,templateUrl:"app/directives/registration/registration.html",link:function(n){function i(){V=!0}function A(){V=!1}function T(){n.inProgressFinishRegistration=!0,d.tryFinishRegistration().then(function(e){B=e,n.authorizeOnRegistrationComplete=a.components.registration.authorizeOnRegistrationComplete,n.registrationCompleted=!0})["finally"](function(){n.inProgressFinishRegistration=!1})}function k(){o.loadAuth();var e= "";return e=a.apiVersion<"21.1"?d.getActions():d.getRegistrationActions(),n.inProgress=!0,e.then(function(e){var t;if(_=e.actions,!_.length)return o.clearAuthData(),window.location.reload();if(a.apiVersion>="21.1"){var r=_.find(function(e){return"AcceptSubscriptionsConfirm"===e.userActionType});r&&(n.shouldHideSubscriptionInput=!1,n.shouldRequireSubscriptionInput="Required"===r.actionState)}x=n.emailSkippable&&!f.get("forceEmailStepSkipped")&&!f.get("forceEmailStepHasCode");for(var i=0;i<_.length;i++)if(!_[i].isDone&&"AcceptSubscriptionsConfirm"!==_[i].userActionType){t="Questions"===_[i].userActionType&&x?"ChangeEmail":_[i].userActionType;break}n.currentStep=t,n.currentStep||T()})["catch"](function(){n.currentStep=null})["finally"](function(){n.inProgress=!1})}function O(){var e={tenderOffer:d.getTenderOffer(!n.acceptTenderOfferByCheck),agreement:d.getAgreementPdf()};n.inProgress=!0,t.allSettled(e).then(function(e){e.tenderOffer.success?n.tenderOfferFile=e.tenderOffer.value:200!==e.tenderOffer.error.status?g.addCritical(R("registration.tenderOfferStep.alerts.offerFileError"),q):e.tenderOffer.error.incorrectFormat&&g.addCritical(R("registration.tenderOfferStep.alerts.offerFileFormatError"),q),e.agreement.success||200===e.agreement.error.status||g.addCritical(R("registration.tenderOfferStep.alerts.opdFileError"),q),n.isOfferAndAgreementLoaded=e.tenderOffer.success&&e.agreement.success})["finally"](function(){n.ignoreDocsFetchingErrors&&(n.isOfferAndAgreementLoaded=!0),n.inProgress=!1})}function y(){n.isRegistrationStarted=!1,n.currentStep=null,f.remove("isRegistrationToken"),f.remove("authorizationToken"),f.remove("refreshToken")}function P(){return d.getRegisterAnonym().then(function(e){f.set("anonymTokenExpireTime",e.authResult.expires_in),f.set("anonymAccessToken",e.authToken),f.set("anonymRefreshToken",e.authResult.refresh_token),n.isOfferAndAgreementLoaded||O(),o.setRegistrationToken(e.authToken,e.authResult.refresh_token),y()})}function I(){k().then(function(){"AcceptTenderOffer"===n.currentStep?O():"AssignCard"===n.currentStep&&(n.inProgress=!0,s.getVirtualCardInfo().then(function(e){n.isVirtualCardEmissionAllowed=e.isVirtualCardEmissionAllowed,n.ext_assignCardStep()})["finally"](function(){n.inProgress=!1}))})}function b(){a.common.requestUserStatus&&c.getUserStatus().then(function(e){r.userStatus=e})}function E(){n.registrationData={password:""},n.model={identifier:a.identifiers.registration[0]},(a.components.authentication.shareAuthLoginToRegistration||a.components.registration.forceRegistrationStartOnLoginAttempt&&n.acceptTenderOfferByCheck)&&m.loginAuth&&(n.model.identifier=m.identifier,n.registrationData.login=m.loginAuth,m.clearLogin())}function F(){n.isRegistrationStarted=!0,I(),n.passwordRequired=!1}function w(){var e;return n.acceptTenderOfferByCheck&&(e=n.acceptTenderOffer()),t.when(e).then(function(){F()})}function D(){var e;return n.referralRegistration&&n.referrerCardNumber.value&&(e=d.getReferrerInfo().then(function(){return h("registration.referrerCodeMessage").then(function(e){return S(e,"info")})})["catch"](function(){return d.sendReferrerCardNumber(n.referrerCardNumber.value)})),t.when(e).then(w)["catch"](function(){o.removeRegistrationToken(),o.clearAuthData()})}function $(){var e=f.get("refreshTokenForSocialRegistration");o.setRegistrationToken(n.tokenForSocialRegistration,e)}function L(t){n.authInProgress=!0;var r=a.oAuthClientId&&!f.get("authorizationToken")?o.getOAuthClientTokens():Promise.resolve();r.then(function(){return d.beginRegistration(e.copy(n.registrationData)).then(function(e){return o.clearAuthData(),o.setRegistrationToken(e.authResult.access_token,e.authResult.refresh_token),d.setIdentifier(n.model.identifier),a.apiVersion>="21.1"&&!n.shouldHideSubscriptionInput&&(n.isAgreeOnSubscribe.isAgree?v.confirmAllSubscription():v.rejectAllSubscriptions()),C.setTimer(C.requestEnums.sendConfirmCodePhone),D()},function(e){"PasswordRequired"===e.data.data.state&&(n.passwordRequired=!0,t.$submitted=!1)})["finally"](function(){n.authInProgress=!1})})}var q="registration";d.setArea(q),s.setArea(q),n.agreementEcheque={value:!1};var V=!0;document.addEventListener("mouseover",i),document.addEventListener("mouseleave",A),n.apiHost=a.host,n.opdAgreementFileId=a.components.registration.opdAgreementFileId,n.isRegistrationStarted=o.isRegistrationStarted(),n.acceptTenderOfferByCheck=a.components.registration.acceptTenderOfferByCheck,n.ignoreDocsFetchingErrors=a.components.registration.ignoreDocsFetchingErrors,n.offerPdfFileId=a.components.registration.offerPdfFileId,n.referralRegistration=a.components.registration.referralRegistration,n.registrationSmsCodeAsPassword=a.components.registration.setRegistrationSmsCodeAsPassword,n.isOfferAndAgreementLoaded=void 0,n.referrerCardNumber={value:""},n.registrationCompleted=!1,n.loader={cities:!1,streets:!1,houses:!1},n.emailSkippable=a.components.registration.forceEmailStep,n.tokenForSocialRegistration=f.get("tokenForSocialRegistration"),n.shouldRequireSubscriptionInput=!1,n.shouldHideSubscriptionInput=!0,n.isAgreeOnSubscribe={isAgree:!0};var _={},x=!1,B={},z=(new Date).getTime(),H=f.get("anonymTokenExpireTime");f.get("isRegistrationToken")||a.apiVersion<"21.1"?(y(),n.isRegistrationStarted?I():n.acceptTenderOfferByCheck&&O()):H>=z||!H?P().then(function(){k()}):(H<=z||!H)&&(o.setRegistrationToken(f.get("anonymAccessToken"),f.get("anonymRefreshToken")),n.isRegistrationStarted?(I(),y()):(O(),k().then(function(){y()}))),n["continue"]=function(){o.removeRegistrationToken(),a.components.registration.authorizeOnRegistrationComplete?o.setAuth(B.access_token,B.refresh_token):o.clearAuthData();var e=a.components.registration.redirectUrlOnRegistrationComplete;"#registration"===e&&(a.components.registration.authorizeOnRegistrationComplete?e=a.components.authentication.redirectUrlOnLogin:(n.registrationCompleted=!1,n.isRegistrationStarted=!1,n.acceptTenderOfferByCheck&&O())),o.loggedIn()&&b(),p.redirectTo(e)},n.acceptTenderOffer=function(){return n.stepInProgress=!0,d.acceptTenderOffer().then(function(){k()})["finally"](function(){n.stepInProgress=!1})},n.cancel=function(){n.currentStep=null,o.clearAuthData(),p.goToLogin()},n.cardModel={cardNumber:""},n.cvcCodeCardsRegistration=a.components.cards.cvcCodeCardsRegistration,n.cvcCodeCardsRegistration&&(n.cardModel.cvcCode=""),n.assignCard=function(){n.stepInProgress=!0,s.setCard(n.cardModel).then(function(){k()})["finally"](function(){n.stepInProgress=!1})},n.emitVirtualCard=function(){n.stepInProgress=!0,s.emitVirtualCard()["finally"](function(){k(),n.stepInProgress=!1})},n.$on("resetRegistration",function(){o.clearAuthData(),n.currentStep=null,n.isRegistrationStarted=!1}),n.$on("questionnaireIsSet",I),n.$on("emailIsSet",I),n.$on("phoneIsSet",I),n.$on("passwordIsSet",I);var M=r.$on("$locationChangeStart",function(e,t){var r=new RegExp("#/"+u.confirmationKeys.email+"?").test(t);!n.isRegistrationStarted||V||r||(window.stop(),n.registrationCompleted=!1,n.isRegistrationStarted=!1,n.currentStep=null,o.removeRegistrationToken(),o.clearAuthData(),p.goToLogin())});n.$on("$destroy",function(){document.removeEventListener("mouseover",i),document.removeEventListener("mouseleave",A),M()}),E(),n.registration=function(e){f.set("agreementEcheque",n.agreementEcheque.value),n.tokenForSocialRegistration?($(),D()):L(e)},n.resetPassword=function(){l.setResetPasswordConfirmationData({data:n.registrationData.login,identifier:n.model.identifier}),p.goTo("reset-password")},n.resetFormModels=function(e){n.registrationData.login="",e.$submitted=!1},!n.tokenForSocialRegistration||n.referralRegistration||n.acceptTenderOfferByCheck||($(),F()),n.ext_assignCardStep=function(){return null}}}}])}(angular);9147 "use strict";!function(e){e.module("lmxApp").directive("lmxRegistration",["$q","$rootScope","$log","$http","authService","cardsService","configurationService","globalService","emailConfirmationCheckerService","localStorageService","notification","registrationService","resetPasswordService","routingService","shareAuthLoginToRegistration","$translate","userAlertService","translateFilter","userService","resendService",function(t,r,n,i,o,s,a,c,u,f,g,d,l,p,m,h,S,R,v,C){return{restrict:"E",replace:!0,scope:!0,templateUrl:"app/directives/registration/registration.html",link:function(n){function i(){V=!0}function A(){V=!1}function T(){n.inProgressFinishRegistration=!0,d.tryFinishRegistration().then(function(e){B=e,n.authorizeOnRegistrationComplete=a.components.registration.authorizeOnRegistrationComplete,n.registrationCompleted=!0})["finally"](function(){n.inProgressFinishRegistration=!1})}function k(){o.loadAuth();var e=a.apiVersion<"21.1"?d.getActions():d.getRegistrationActions();return n.inProgress=!0,e.then(function(e){var t;if(_=e.actions,!_.length)return o.clearAuthData(),window.location.reload();if(a.apiVersion>="21.1"){var r=_.find(function(e){return"AcceptSubscriptionsConfirm"===e.userActionType});r&&(n.shouldHideSubscriptionInput=!1,n.shouldRequireSubscriptionInput="Required"===r.actionState)}x=n.emailSkippable&&!f.get("forceEmailStepSkipped")&&!f.get("forceEmailStepHasCode");for(var i=0;i<_.length;i++)if(!_[i].isDone&&"AcceptSubscriptionsConfirm"!==_[i].userActionType){t="Questions"===_[i].userActionType&&x?"ChangeEmail":_[i].userActionType;break}n.currentStep=t,n.currentStep||T()})["catch"](function(){n.currentStep=null})["finally"](function(){n.inProgress=!1})}function O(){var e={tenderOffer:d.getTenderOffer(!n.acceptTenderOfferByCheck),agreement:d.getAgreementPdf()};n.inProgress=!0,t.allSettled(e).then(function(e){e.tenderOffer.success?n.tenderOfferFile=e.tenderOffer.value:200!==e.tenderOffer.error.status?g.addCritical(R("registration.tenderOfferStep.alerts.offerFileError"),q):e.tenderOffer.error.incorrectFormat&&g.addCritical(R("registration.tenderOfferStep.alerts.offerFileFormatError"),q),e.agreement.success||200===e.agreement.error.status||g.addCritical(R("registration.tenderOfferStep.alerts.opdFileError"),q),n.isOfferAndAgreementLoaded=e.tenderOffer.success&&e.agreement.success})["finally"](function(){n.ignoreDocsFetchingErrors&&(n.isOfferAndAgreementLoaded=!0),n.inProgress=!1})}function y(){n.isRegistrationStarted=!1,n.currentStep=null,f.remove("isRegistrationToken"),f.remove("authorizationToken"),f.remove("refreshToken")}function P(){return d.getRegisterAnonym().then(function(e){f.set("anonymTokenExpireTime",e.authResult.expires_in),f.set("anonymAccessToken",e.authToken),f.set("anonymRefreshToken",e.authResult.refresh_token),n.isOfferAndAgreementLoaded||O(),o.setRegistrationToken(e.authToken,e.authResult.refresh_token),y()})}function I(){k().then(function(){"AcceptTenderOffer"===n.currentStep?O():"AssignCard"===n.currentStep&&(n.inProgress=!0,s.getVirtualCardInfo().then(function(e){n.isVirtualCardEmissionAllowed=e.isVirtualCardEmissionAllowed,n.ext_assignCardStep()})["finally"](function(){n.inProgress=!1}))})}function b(){a.common.requestUserStatus&&c.getUserStatus().then(function(e){r.userStatus=e})}function E(){n.registrationData={password:""},n.model={identifier:a.identifiers.registration[0]},(a.components.authentication.shareAuthLoginToRegistration||a.components.registration.forceRegistrationStartOnLoginAttempt&&n.acceptTenderOfferByCheck)&&m.loginAuth&&(n.model.identifier=m.identifier,n.registrationData.login=m.loginAuth,m.clearLogin())}function F(){n.isRegistrationStarted=!0,I(),n.passwordRequired=!1}function w(){var e;return n.acceptTenderOfferByCheck&&(e=n.acceptTenderOffer()),t.when(e).then(function(){F()})}function D(){var e;return n.referralRegistration&&n.referrerCardNumber.value&&(e=d.getReferrerInfo().then(function(){return h("registration.referrerCodeMessage").then(function(e){return S(e,"info")})})["catch"](function(){return d.sendReferrerCardNumber(n.referrerCardNumber.value)})),t.when(e).then(w)["catch"](function(){o.removeRegistrationToken(),o.clearAuthData()})}function $(){var e=f.get("refreshTokenForSocialRegistration");o.setRegistrationToken(n.tokenForSocialRegistration,e)}function L(t){n.authInProgress=!0;var r=a.oAuthClientId&&!f.get("authorizationToken")?o.getOAuthClientTokens():Promise.resolve();r.then(function(){return d.beginRegistration(e.copy(n.registrationData)).then(function(e){return o.clearAuthData(),o.setRegistrationToken(e.authResult.access_token,e.authResult.refresh_token),d.setIdentifier(n.model.identifier),a.apiVersion>="21.1"&&!n.shouldHideSubscriptionInput&&(n.isAgreeOnSubscribe.isAgree?v.confirmAllSubscription():v.rejectAllSubscriptions()),C.setTimer(C.requestEnums.sendConfirmCodePhone),D()},function(e){"PasswordRequired"===e.data.data.state&&(n.passwordRequired=!0,t.$submitted=!1)})["finally"](function(){n.authInProgress=!1})})}var q="registration";d.setArea(q),s.setArea(q),n.agreementEcheque={value:!1};var V=!0;document.addEventListener("mouseover",i),document.addEventListener("mouseleave",A),n.apiHost=a.host,n.opdAgreementFileId=a.components.registration.opdAgreementFileId,n.isRegistrationStarted=o.isRegistrationStarted(),n.acceptTenderOfferByCheck=a.components.registration.acceptTenderOfferByCheck,n.ignoreDocsFetchingErrors=a.components.registration.ignoreDocsFetchingErrors,n.offerPdfFileId=a.components.registration.offerPdfFileId,n.referralRegistration=a.components.registration.referralRegistration,n.registrationSmsCodeAsPassword=a.components.registration.setRegistrationSmsCodeAsPassword,n.isOfferAndAgreementLoaded=void 0,n.referrerCardNumber={value:""},n.registrationCompleted=!1,n.loader={cities:!1,streets:!1,houses:!1},n.emailSkippable=a.components.registration.forceEmailStep,n.tokenForSocialRegistration=f.get("tokenForSocialRegistration"),n.shouldRequireSubscriptionInput=!1,n.shouldHideSubscriptionInput=!0,n.isAgreeOnSubscribe={isAgree:!0};var _={},x=!1,B={},z=(new Date).getTime(),H=f.get("anonymTokenExpireTime");f.get("isRegistrationToken")||a.apiVersion<"21.1"?(y(),n.isRegistrationStarted?I():n.acceptTenderOfferByCheck&&O()):H>=z||!H?P().then(function(){k()}):(H<=z||!H)&&(o.setRegistrationToken(f.get("anonymAccessToken"),f.get("anonymRefreshToken")),n.isRegistrationStarted?(I(),y()):(O(),k().then(function(){y()}))),n["continue"]=function(){o.removeRegistrationToken(),a.components.registration.authorizeOnRegistrationComplete?o.setAuth(B.access_token,B.refresh_token):o.clearAuthData();var e=a.components.registration.redirectUrlOnRegistrationComplete;"#registration"===e&&(a.components.registration.authorizeOnRegistrationComplete?e=a.components.authentication.redirectUrlOnLogin:(n.registrationCompleted=!1,n.isRegistrationStarted=!1,n.acceptTenderOfferByCheck&&O())),o.loggedIn()&&b(),p.redirectTo(e)},n.acceptTenderOffer=function(){return n.stepInProgress=!0,d.acceptTenderOffer().then(function(){k()})["finally"](function(){n.stepInProgress=!1})},n.cancel=function(){n.currentStep=null,o.clearAuthData(),p.goToLogin()},n.cardModel={cardNumber:""},n.cvcCodeCardsRegistration=a.components.cards.cvcCodeCardsRegistration,n.cvcCodeCardsRegistration&&(n.cardModel.cvcCode=""),n.assignCard=function(){n.stepInProgress=!0,s.setCard(n.cardModel).then(function(){k()})["finally"](function(){n.stepInProgress=!1})},n.emitVirtualCard=function(){n.stepInProgress=!0,s.emitVirtualCard()["finally"](function(){k(),n.stepInProgress=!1})},n.$on("resetRegistration",function(){o.clearAuthData(),n.currentStep=null,n.isRegistrationStarted=!1}),n.$on("questionnaireIsSet",I),n.$on("emailIsSet",I),n.$on("phoneIsSet",I),n.$on("passwordIsSet",I);var M=r.$on("$locationChangeStart",function(e,t){var r=new RegExp("#/"+u.confirmationKeys.email+"?").test(t);!n.isRegistrationStarted||V||r||(window.stop(),n.registrationCompleted=!1,n.isRegistrationStarted=!1,n.currentStep=null,o.removeRegistrationToken(),o.clearAuthData(),p.goToLogin())});n.$on("$destroy",function(){document.removeEventListener("mouseover",i),document.removeEventListener("mouseleave",A),M()}),E(),n.registration=function(e){f.set("agreementEcheque",n.agreementEcheque.value),n.tokenForSocialRegistration?($(),D()):L(e)},n.resetPassword=function(){l.setResetPasswordConfirmationData({data:n.registrationData.login,identifier:n.model.identifier}),p.goTo("reset-password")},n.resetFormModels=function(e){n.registrationData.login="",e.$submitted=!1},!n.tokenForSocialRegistration||n.referralRegistration||n.acceptTenderOfferByCheck||($(),F()),n.ext_assignCardStep=function(){return null}}}}])}(angular); 9146 9148 "use strict";!function(i){i.module("lmxApp").directive("registrationFinish",function(){return{restrict:"E",replace:!0,templateUrl:"app/directives/registration/registrationFinish.html"}})}(angular); 9147 9149 "use strict";!function(e){e.module("lmxApp").factory("registrationService",["$http","$q","authService","backendEnumsService","configurationService","localStorageService","guidService",function(e,r,t,n,i,o,a){function s(e){y=e}function u(){var r=a.getGuid(),t={password:r};return e.post(F+"v1.2/Registration/RegisterAnonym",t).then(function(e){return e.data})}function c(r){var t={area:y};return e.post(F+"v1.2/Registration/BeginRegistration",r,t).then(function(e){return e.data})}function f(){return e.post(F+"v1.1/Registration/TryFinishRegistration",null,{area:y}).then(function(e){return e.data})}function g(){return e.get(F+"api/user/actions",{area:y}).then(function(e){return e.data})}function d(){return e.get(F+"v1.2/User/RegistrationActions",{area:y}).then(function(e){return e.data})}function p(){return e.post(F+"api/User/AcceptTenderOffer",null,{area:y})}function l(r){var t={answers:r};return e.post(F+"api/User/Answers",t,{area:y})}function m(t){if(t&&!i.components.registration.offerHtmlFileId.length||!t&&!i.components.registration.offerPdfFileId.length)return r.reject({error:"Error"});var n=t?i.components.registration.offerHtmlFileId:i.components.registration.offerPdfFileId;return e.get(F+"api/files/"+n,{area:y}).then(function(e){return t&&!e.headers("content-type").contains("html")?r.reject({incorrectFormat:!0}):e.data})}function h(){return i.components.registration.opdAgreementFileId.length?e.get(F+"api/files/"+i.components.registration.opdAgreementFileId,{area:y}).then(function(e){return e.data}):r.reject({error:"Error"})}function v(){return e.get(F+"api/User/Referrer",{area:y}).then(function(e){return e.data})}function R(r){var t={type:n.enums.referrerCodeType.cardNumber,code:r};return e.put(F+"api/User/Referrer",t,{area:y})}function A(e){e?o.set(S,e):o.remove(S)}function I(){return o.get(S)}var y,F=i.host,S=t.registrationIdentifierStorageKey;return{setArea:s,acceptTenderOffer:p,beginRegistration:c,getActions:g,getTenderOffer:m,sendQuestions:l,tryFinishRegistration:f,getAgreementPdf:h,getReferrerInfo:v,sendReferrerCardNumber:R,setIdentifier:A,getIdentifier:I,getRegisterAnonym:u,getRegistrationActions:d}}])}(angular); … … 9179 9181 "use strict";!function(n){n.module("lmxApp").config(["$compileProvider",function(n){n.debugInfoEnabled(!1)}])}(angular); 9180 9182 "use strict";!function(n){n.unNormalizeDirective=function(n){var r=/[A-Z]/g;return n.replace(r,function(n,r){return(r?"-":"")+n.toLowerCase()})},n.flipObject=function(n){var r={};for(var t in n)n.hasOwnProperty(t)&&(r[n[t]]=t);return r},n.isDate=function(n){return"[object Date]"===Object.prototype.toString.call(n)},n.copyObjectFields=function(n){for(var r,t={},e=1;e<arguments.length;e++)r=arguments[e],t[r]=n[r];return t},n.isNullOrUndefined=function(r){return n.isUndefined(r)||null===r}}(angular); 9181 "use strict";!function(e){e.module("lmxApp").factory("authService",["$http","$injector","$q","$rootScope","configurationService","localStorageService","notification","routingService","userService","shareAuthLoginToRegistration","backendEnumsService",function(e,t,n,o,r,i,a,s,u,c,f){function l(e){ L=e}function d(e){z.token=e}function h(){i.remove("isRegistrationToken","forceEmailStepHasCode","forceEmailStepSkipped","refreshToken","tokenForSocialRegistration","refreshTokenForSocialRegistration",x),z.isRegistrationToken=null}function g(){i.remove("isAnonymousToken","refreshToken"),z.isAnonymousToken=null}function k(){i.remove("authorizationToken"),i.remove("refreshToken"),h(),g(),z.token=null,z.permissions=null}function p(){return u.getUserInfo().then(function(e){return o.userInfo=e,r.common.requestUserAttributes?u.getAttributes().then(function(e){o.userInfo.attributes=e,o.$broadcast("loadUserInfo")}):void o.$broadcast("loadUserInfo")})}function m(e,t,n){return i.set("authorizationToken",e),i.set("refreshToken",t),d(e),n?null:p()}function T(e,t){m(e,t,!0),g(),z.isRegistrationToken=!0,i.set("isRegistrationToken",!0),i.set("refreshToken",t)}function v(e,t){m(e,t,!0),h(),z.isAnonymousToken=!0,i.set("isAnonymousToken",!0),i.set("refreshToken",t)}function A(){return null!==z.token&&!(z.isRegistrationToken||z.isAnonymousToken)}function R(e,t,n){var o={headers:{"Content-Type":"application/x-www-form-urlencoded"},data:"grant_type=password"};return(n||!n&&t)&&(o.data+="&password="+encodeURIComponent(e.password)),t?o.headers["X-Loymax-2FA"]=$:($=null,o.data+="&username="+e.login),o}function y(){r.apiVersion>="21.1"&&(j.path=j.path.replace("publicapi","authorizationService"))}function S(i,l,d){function h(){return p.beginRegistration(i).then(function(e){k(),T(e.authResult.access_token,e.authResult.refresh_token),s.goTo("registration")})}function g(e){k(),T(e.data.access_token,e.data.refresh_token),s.goTo("registration")}k();var p=t.get("registrationService");p.setArea("login");var v=R(i,l,d);return y(),e.post(j.path,v.data,{headers:v.headers,area:L}).then(function(e){return u.getUser(e).then(function(t){return t.state?t.state===f.enums.userStatus.registered?(a.clearNotifications(L),k(),m(e.data.access_token,e.data.refresh_token).then(function(){o.$broadcast("login")})):n.when(g(e)):h()["catch"](function(t){return"RegistrationAlreadyCompleted"===t.data.data.state?(a.clearNotifications(L),k(),m(e.data.access_token,e.data.refresh_token).then(function(){o.$broadcast("login")})):n.reject(t)})})})["catch"](function(e){if("RegistrationRequired"!==e.data.error||!r.components.registration.forceRegistrationStartOnLoginAttempt){var t=e.headers("X-Loymax-2FA");return t&&($=t),n.reject(e)}return delete i.password,r.components.registration.acceptTenderOfferByCheck||r.components.registration.referralRegistration?(c.loginAuth=i.login,void s.goTo("registration")):(c.clearLogin(),h())})}function _(e){k(),u.removeUserData(),o.wasLogout=!0,e||s.redirectTo(r.components.authentication.redirectUrlOnLogout)}function w(){return z.token&&z.isRegistrationToken}function C(){var e;if(A())e=p();else{var t=n.defer();t.reject(),e=t.promise}return e}function b(){var t=r.host;return r.apiVersion>="21.1"&&(t=t.replace("publicapi","authorizationService")),e.post(t+"v1.2/auth/SendConfirmationCode",null,{headers:{"X-Loymax-2FA":$},area:L})}function I(){var t=i.get("refreshToken");if(!t)return Promise.reject();y();var n={method:"POST",url:j.path,data:"grant_type=refresh_token&refresh_token=".concat(t,"&area=users"),headers:{"Content-Type":"application/x-www-form-urlencoded"}};return e(n).then(function(e){var t=e.data;m(t.access_token,t.refresh_token,!0)})}function U(){y();var t={method:"POST",url:j.path,data:"grant_type=anonymous",params:{client_id:r.oAuthClientId},headers:{"Content-Type":"application/x-www-form-urlencoded"}};return e(t).then(function(e){var t=e.data;v(t.access_token,t.refresh_token)})}var L,$,x="registrationIdentifier",z={token:i.get("isAnonymousToken")?i.get("authorizationToken"):null,isRegistrationToken:i.get("isRegistrationToken")||null,isAnonymousToken:i.get("isAnonymousToken")||null,permissions:null},O=i.get("authorizationToken");O&&d(O);var j={path:r.host+"token"};return y(),{login:S,logout:_,authentication:z,loadAuth:C,setAuth:m,setToken:d,loggedIn:A,isRegistrationStarted:w,removeRegistrationToken:h,setArea:l,setRegistrationToken:T,setAnonymousToken:v,clearAuthData:k,registrationIdentifierStorageKey:x,resendCode:b,refreshTokenRequest:I,getOAuthClientTokens:U,tokenUrl:j}}])}(angular);9183 "use strict";!function(e){e.module("lmxApp").factory("authService",["$http","$injector","$q","$rootScope","configurationService","localStorageService","notification","routingService","userService","shareAuthLoginToRegistration","backendEnumsService",function(e,t,n,o,r,i,a,s,u,c,f){function l(e){U=e}function d(e){O.token=e}function g(){i.remove("isRegistrationToken","forceEmailStepHasCode","forceEmailStepSkipped","refreshToken","tokenForSocialRegistration","refreshTokenForSocialRegistration",$),O.isRegistrationToken=null}function h(){i.remove("isAnonymousToken","refreshToken"),O.isAnonymousToken=null}function k(){i.remove("authorizationToken"),i.remove("refreshToken"),g(),h(),O.token=null,O.permissions=null}function p(){return u.getUserInfo().then(function(e){return o.userInfo=e,r.common.requestUserAttributes?u.getAttributes().then(function(e){o.userInfo.attributes=e,o.$broadcast("loadUserInfo")}):void o.$broadcast("loadUserInfo")})}function m(e,t,n){return i.set("authorizationToken",e),i.set("refreshToken",t),d(e),n?null:p()}function T(e,t){m(e,t,!0),h(),O.isRegistrationToken=!0,i.set("isRegistrationToken",!0),i.set("refreshToken",t)}function v(e,t){m(e,t,!0),g(),O.isAnonymousToken=!0,i.set("isAnonymousToken",!0),i.set("refreshToken",t)}function A(){return null!==O.token&&!(O.isRegistrationToken||O.isAnonymousToken)}function R(e,t,n){var o={headers:{"Content-Type":"application/x-www-form-urlencoded"},data:"grant_type=password"};return(n||!n&&t)&&(o.data+="&password="+encodeURIComponent(e.password)),t?o.headers["X-Loymax-2FA"]=L:(L=null,o.data+="&username="+e.login),o}function y(i,l,d){function g(){return p.beginRegistration(i).then(function(e){k(),T(e.authResult.access_token,e.authResult.refresh_token),s.goTo("registration")})}function h(e){k(),T(e.data.access_token,e.data.refresh_token),s.goTo("registration")}k();var p=t.get("registrationService");p.setArea("login");var v=R(i,l,d);return e.post(q.path,v.data,{headers:v.headers,area:U}).then(function(e){return u.getUser(e).then(function(t){return t.state?t.state===f.enums.userStatus.registered?(a.clearNotifications(U),k(),m(e.data.access_token,e.data.refresh_token).then(function(){o.$broadcast("login")})):n.when(h(e)):g()["catch"](function(t){return"RegistrationAlreadyCompleted"===t.data.data.state?(a.clearNotifications(U),k(),m(e.data.access_token,e.data.refresh_token).then(function(){o.$broadcast("login")})):n.reject(t)})})})["catch"](function(e){if("RegistrationRequired"!==e.data.error||!r.components.registration.forceRegistrationStartOnLoginAttempt){var t=e.headers("X-Loymax-2FA");return t&&(L=t),n.reject(e)}return delete i.password,r.components.registration.acceptTenderOfferByCheck||r.components.registration.referralRegistration?(c.loginAuth=i.login,void s.goTo("registration")):(c.clearLogin(),g())})}function S(t){function n(){k(),u.removeUserData(),o.wasLogout=!0,t||s.redirectTo(r.components.authentication.redirectUrlOnLogout)}r.apiVersion>="22.2"?(o.allRequestsCompleted=!1,e.post(x+"v1.2/auth/logout")["finally"](function(){n()})):n()}function _(){return O.token&&O.isRegistrationToken}function w(){var e;if(A())e=p();else{var t=n.defer();t.reject(),e=t.promise}return e}function C(){return e.post(x+"v1.2/auth/SendConfirmationCode",null,{headers:{"X-Loymax-2FA":L},area:U})}function b(){var t=i.get("refreshToken");if(!t)return Promise.reject();var n={method:"POST",url:q.path,data:"grant_type=refresh_token&refresh_token=".concat(t,"&area=users"),headers:{"Content-Type":"application/x-www-form-urlencoded"}};return e(n).then(function(e){var t=e.data;m(t.access_token,t.refresh_token,!0)})}function I(){var t={method:"POST",url:q.path,data:"grant_type=anonymous",params:{client_id:r.oAuthClientId},headers:{"Content-Type":"application/x-www-form-urlencoded"}};return e(t).then(function(e){var t=e.data;v(t.access_token,t.refresh_token)})}var U,L,$="registrationIdentifier",x=r.apiVersion>="21.1"?r.host.replace("publicapi","authorizationService"):r.host,O={token:i.get("isAnonymousToken")?i.get("authorizationToken"):null,isRegistrationToken:i.get("isRegistrationToken")||null,isAnonymousToken:i.get("isAnonymousToken")||null,permissions:null},j=i.get("authorizationToken");j&&d(j);var q={path:x+"token"};return{login:y,logout:S,authentication:O,loadAuth:w,setAuth:m,setToken:d,loggedIn:A,isRegistrationStarted:_,removeRegistrationToken:g,setArea:l,setRegistrationToken:T,setAnonymousToken:v,clearAuthData:k,registrationIdentifierStorageKey:$,resendCode:C,refreshTokenRequest:b,getOAuthClientTokens:I,tokenUrl:q}}])}(angular); 9182 9184 "use strict";!function(e){e.module("lmxApp").service("backendEnumsService",function(){this.enums={permissionValue:{authorized:"Authorized",partner:"Partner",siteAdmin:"SiteAdmin",admin:"Admin",activateCard:"ActivateCard",cardEmission:"CardEmission",cardPacking:"CardPacking",manageUserPermissions:"ManageUserPermissions",bankPayment:"BankPayment",offerRead:"OfferRead",offerEdit:"OfferEdit",offerManage:"OfferManage",answerManage:"AnswerManage",partnerCatalogEdit:"PartnerCatalogEdit",answersLoad:"AnswersLoad",mailingEdit:"MailingEdit",depositToCard:"DepositToCard",targetGroupEdit:"TargetGroupEdit",viewDepositsToCard:"ViewDepositsToCard",sendCardPassword:"SendCardPassword",blockAccount:"BlockAccount",getHistoryAudit:"GetHistoryAudit",getPurchaseHistory:"GetPurchaseHistory",getCards:"GetCards",getSmses:"GetSmses",deleteCard:"DeleteCard",recoverCard:"RecoverCard",attachCard:"AttachCard",getQuestions:"GetQuestions",startMailingTask:"StartMailingTask",cancelMailingTask:"CancelMailingTask",changePhone:"ChangePhone",browseHistoryAuditCodes:"BrowseHistoryAuditCodes",viewReport:"ViewReport",deviceEmulation:"DeviceEmulation",cardIssuance:"CardIssuance",replaceExternalCard:"ReplaceExternalCard",blockCard:"BlockCard",defaultOfferEdit:"DefaultOfferEdit",defaultOfferManage:"DefaultOfferManage",subscriptionsManage:"SubscriptionsManage",managerPortalAuthorized:"ManagerPortalAuthorized",partnerCatalogRead:"PartnerCatalogRead",targetGroupRead:"TargetGroupRead",partnerCatalogDecline:"PartnerCatalogDecline",mailingRead:"MailingRead",targetGroupCalculation:"TargetGroupCalculation",operationConfirmCancel:"OperationConfirmCancel",editReadonlyQuestions:"EditReadonlyQuestions",editReadonlyAnswers:"EditReadonlyAnswers",viewActiveOffersForCard:"ViewActiveOffersForCard",announcementSpacesEdit:"AnnouncementSpacesEdit",viewAnnouncements:"ViewAnnouncements",editAnnouncements:"EditAnnouncements",publishAnnouncements:"PublishAnnouncements",registration:"Registration",registerUsers:"RegisterUsers",limitRulesView:"LimitRulesView",limitRulesEdit:"LimitRulesEdit",couponEmissionEdit:"CouponEmissionEdit",couponEmissionView:"CouponEmissionView",oAuthApplication:"OAuthApplication",communicationOfferView:"CommunicationOfferView",communicationOfferEdit:"CommunicationOfferEdit",manageLifeTimeDefinitions:"ManageLifeTimeDefinitions",getEMails:"GetEMails",getPushes:"GetPushes",partnerView:"PartnerView",partnerEdit:"PartnerEdit",manageGateways:"ManageGateways",userAttributeView:"UserAttributeView",userAttributeEdit:"UserAttributeEdit",manageLocations:"ManageLocations",showcaseCategoryEdit:"ShowcaseCategoryEdit",showcaseCategoryView:"ShowcaseCategoryView",socialNetworkEdit:"SocialNetworkEdit",socialNetworkView:"SocialNetworkView",showcaseCouponTypeEdit:"ShowcaseCouponTypeEdit",showcaseCouponTypeView:"ShowcaseCouponTypeView",showcasePartnerEdit:"ShowcasePartnerEdit",showcasePartnerView:"ShowcasePartnerView",couponEdit:"CouponEdit",couponView:"CouponView",announcementSpacesView:"AnnouncementSpacesView",goodsGroupsView:"GoodsGroupsView",goodsGroupsEdit:"GoodsGroupsEdit",registrationCustomer:"RegistrationCustomer",showcaseCouponView:"ShowcaseCouponView",marketingCampaignsView:"MarketingCampaignsView",marketingCampaignsEdit:"MarketingCampaignsEdit",applicationUserAuthorize:"ApplicationUserAuthorize",applicationProcessing:"ApplicationProcessing",partnerPlanView:"PartnerPlanView",partnerPlanEdit:"PartnerPlanEdit",getPushableDevices:"GetPushableDevices",getSocialAccounts:"GetSocialAccounts",purchaseView:"PurchaseView",marketingCampaignPlanView:"MarketingCampaignPlanView",marketingCampaignPlanEdit:"MarketingCampaignPlanEdit"},templateFieldType:{string:"String",dateTime:"DateTime",radioButton:"RadioButton",radioButtonString:"RadioButtonString",checkbox:"Checkbox",int32:"Int32"},questionModelType:{"int":"Int","double":"Double","boolean":"Boolean",string:"String",date:"Date",select:"Select"},autoCompleteType:{city:"City",street:"Street",house:"House"},offerState:{active:"Active",commingSoon:"CommingSoon"},communicationOfferTypeEnum:{original:"Original",personalGoods:"PersonalGoods",personalOffer:"PersonalOffer"},referrerCodeType:{cardNumber:"CardNumber"},platformType:{ios:"Ios",android:"Android",windowsPhone:"WindowsPhone",unknown:"Unknown"},questionnaireItemModelType:{question:"Question",questionGroup:"QuestionGroup",questionFixedAnswer:"QuestionFixedAnswer",questionMultipleGroup:"QuestionMultipleGroup"},userStatus:{anonymous:"Anonymous",deleted:"Deleted",normal:"Normal",registered:"Registered"}}})}(angular); 9183 9185 "use strict";!function(o){o.module("lmxApp").service("backendTypesService",function(){this.enums={rewardThumbnail:{imageWithText:"Loymax.Mobile.Contract.Models.Offer.ImageWithText, Loymax.Mobile.Contract",oldNewPrice:"Loymax.Mobile.Contract.Models.Offer.OldNewPrice, Loymax.Mobile.Contract",twoLineText:"Loymax.Mobile.Contract.Models.Offer.TwoLineText, Loymax.Mobile.Contract"},supportMessages:{attachments:"Loymax.Support.Contract.Models.SupportMessageAttachmentCreateModel, Loymax.Support.Contract",comment:"Loymax.Support.Contract.Models.SupportMessageCommentCreateModel, Loymax.Support.Contract"},support:{attachment:"Loymax.Support.Contract.Models.SupportMessageAttachmentItem, Loymax.Support.Contract"},personalOfferDiscount:{amount:"Loymax.Mobile.Contract.Models.Offer.PersonalOffer.Discount.PersonalOfferAmountDiscountViewModel, Loymax.Mobile.Contract",amountPerMeasure:"Loymax.Mobile.Contract.Models.Offer.PersonalOffer.Discount.PersonalOfferAmountPerMeasureDiscountViewModel, Loymax.Mobile.Contract",amountPerUnit:"Loymax.Mobile.Contract.Models.Offer.PersonalOffer.Discount.PersonalOfferAmountPerUnitDiscountViewModel, Loymax.Mobile.Contract",percent:"Loymax.Mobile.Contract.Models.Offer.PersonalOffer.Discount.PersonalOfferPercentDiscountViewModel, Loymax.Mobile.Contract",price:"Loymax.Mobile.Contract.Models.Offer.PersonalOffer.Discount.PersonalOfferPriceDiscountViewModel, Loymax.Mobile.Contract",pricePerUnit:"Loymax.Mobile.Contract.Models.Offer.PersonalOffer.Discount.PersonalOfferPricePerUnitDiscountViewModel, Loymax.Mobile.Contract"},goodsCatalog:{node:"Loymax.Common.WebApi.Models.GoodsCatalog.GoodsCatalogNodeViewModel, Loymax.Common.WebApi",leaf:"Loymax.Common.WebApi.Models.GoodsCatalog.GoodsCatalogLeafViewModel, Loymax.Common.WebApi"}}})}(angular); 9184 9186 "use strict";!function(e){e.module("lmxApp").factory("componentStateService",["$q","$rootScope","messageService","configurationService","offerService","authService","backendEnumsService",function(e,n,o,t,r,s,f){function a(){return o.getUnreadNotificationCount().then(function(e){n.hasMessages=e.unReadCount>0})}function c(){return n.noPersonalOffers=!1,r.getOffers({offerState:p.active,offerType:m.personalOffer,existenceCheck:!0}).then(function(e){n.noPersonalOffers=0===e.$allCount})}function u(){return n.noPersonalGoods=!1,r.getOffers({offerState:p.active,offerType:m.personalGoods,existenceCheck:!0}).then(function(e){if(0===e.$allCount)return r.getOffers({offerState:p.commingSoon,offerType:m.personalGoods}).then(function(e){n.noPersonalGoods=0===e.$allCount})})}function i(){t.components.message.requestUnreadMessage&&a(),t.components.personalOffers.requestPersonalOffers&&c(),t.components.personalGoods.requestPersonalGoods&&u()}function l(){s.loggedIn()&&i()}var p=f.enums.offerState,m=f.enums.communicationOfferTypeEnum;return{populateComponentStates:l,hasUnReadMessages:a}}])}(angular); 9185 "use strict";function ownKeys(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);t&&(o=o.filter(function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable})),n.push.apply(n,o)}return n}function _objectSpread(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?ownKeys(Object(n),!0).forEach(function(t){_defineProperty(e,t,n[t])}):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):ownKeys(Object(n)).forEach(function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))})}return e}function _defineProperty(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}!function(e){e.module("lmxApp").service("configurationService",["$log","$rootScope","$window","localStorageService","backendEnumsService","optionsService","DEFAULT_CONFIG","IDENTIFIERS","REGISTRATION_IDENTIFIERS","RESET_PASSWORD_IDENTIFIERS",function(t,n,o,r,i,s,a,c,p,m){function l(e){var n=e.config,o=Object.values(e["const"]),r=[];if(n.length){for(var i=n.split(","),s=0;s<i.length;++s){var a=i[s];e["const"][a]?r.push(a):t.warn('"'+a+'" - недопустимое значение для опции "'+e.name+'Identifiers". Допустимые следующие значения: '+o.join(", "))}r.length||r.push(o[0])}else t.warn("В опциях должно быть задано не пустое значение "+e.name+'Identifiers, содержащее массив идентификаторов, например: "phone" или "'+o.join(", ")+'".'),r.push(o[0]);f.identifiers[e.name]=r}o.lmxConfig=lmxLodash.merge({},a,o.lmxConfig);var u=o.lmxConfig,f=this;f.showcase=s.get("showcaseHost")||u.showcase&&u.showcase.replace(/\/?$/,"/"),f.host=s.get("host")||u.host&&u.host.replace(/\/?$/,"/"),f.components=s.getComponents(),f.common=s.getCommon(),f.locales=s.get("locales")||u.locales,f.templatesPath=u.templatesPath?u.templatesPath.replace(/\/?$/,"/"):"",f.customTemplates=u.customTemplates,f.reCaptchaSiteKey=s.get("reCaptchaSiteKey")||o.lmxConfig.reCaptchaSiteKey,f.apiVersion= u.common.apiVersion,f.oAuthClientId=s.get("oAuthClientId")||u.common.oAuthClientId,f.imagesPath=u.imagesPath.replace(/\/?$/,"/"),f.customTemplates&&!e.isArray(f.customTemplates)&&t.warn('Configuration "customTemplates" must be an array'),f.enums=i.enums,f.userPortalDescriptionType="user_portal",r.get("e2e")&&n.$watch("$root.newOptions",function(e,t){e&&e!==t&&(f.components=_objectSpread({},f.components,{},"string"==typeof e?JSON.parse(e):e))}),r.get("newOptions")&&(f.components=_objectSpread({},f.components,{},r.get("newOptions")),f.common=_objectSpread({},f.common,{},r.get("newOptions")));var g={authentication:{name:"authentication",config:f.components.authentication.authenticationIdentifiers,"const":c},registration:{name:"registration",config:f.components.registration.registrationIdentifiers,"const":p},resetPassword:{name:"resetPassword",config:f.components.authentication.resetPasswordIdentifiers,"const":m}};f.identifiers={},f.loadIdentifiers=function(){l(g.authentication),l(g.registration),l(g.resetPassword)},f.loadIdentifiers()}])}(angular);9187 "use strict";function ownKeys(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);t&&(o=o.filter(function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable})),n.push.apply(n,o)}return n}function _objectSpread(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?ownKeys(Object(n),!0).forEach(function(t){_defineProperty(e,t,n[t])}):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):ownKeys(Object(n)).forEach(function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))})}return e}function _defineProperty(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}!function(e){e.module("lmxApp").service("configurationService",["$log","$rootScope","$window","localStorageService","backendEnumsService","optionsService","DEFAULT_CONFIG","IDENTIFIERS","REGISTRATION_IDENTIFIERS","RESET_PASSWORD_IDENTIFIERS",function(t,n,o,r,i,s,a,c,p,m){function l(e){var n=e.config,o=Object.values(e["const"]),r=[];if(n.length){for(var i=n.split(","),s=0;s<i.length;++s){var a=i[s];e["const"][a]?r.push(a):t.warn('"'+a+'" - недопустимое значение для опции "'+e.name+'Identifiers". Допустимые следующие значения: '+o.join(", "))}r.length||r.push(o[0])}else t.warn("В опциях должно быть задано не пустое значение "+e.name+'Identifiers, содержащее массив идентификаторов, например: "phone" или "'+o.join(", ")+'".'),r.push(o[0]);f.identifiers[e.name]=r}o.lmxConfig=lmxLodash.merge({},a,o.lmxConfig);var u=o.lmxConfig,f=this;f.showcase=s.get("showcaseHost")||u.showcase&&u.showcase.replace(/\/?$/,"/"),f.host=s.get("host")||u.host&&u.host.replace(/\/?$/,"/"),f.components=s.getComponents(),f.common=s.getCommon(),f.locales=s.get("locales")||u.locales,f.templatesPath=u.templatesPath?u.templatesPath.replace(/\/?$/,"/"):"",f.customTemplates=u.customTemplates,f.reCaptchaSiteKey=s.get("reCaptchaSiteKey")||o.lmxConfig.reCaptchaSiteKey,f.apiVersion=f.common.apiVersion,f.oAuthClientId=s.get("oAuthClientId")||u.common.oAuthClientId,f.imagesPath=u.imagesPath.replace(/\/?$/,"/"),f.customTemplates&&!e.isArray(f.customTemplates)&&t.warn('Configuration "customTemplates" must be an array'),f.enums=i.enums,f.userPortalDescriptionType="user_portal",r.get("e2e")&&n.$watch("$root.newOptions",function(e,t){e&&e!==t&&(f.components=_objectSpread({},f.components,{},"string"==typeof e?JSON.parse(e):e))}),r.get("newOptions")&&(f.components=_objectSpread({},f.components,{},r.get("newOptions")),f.common=_objectSpread({},f.common,{},r.get("newOptions")));var g={authentication:{name:"authentication",config:f.components.authentication.authenticationIdentifiers,"const":c},registration:{name:"registration",config:f.components.registration.registrationIdentifiers,"const":p},resetPassword:{name:"resetPassword",config:f.components.authentication.resetPasswordIdentifiers,"const":m}};f.identifiers={},f.loadIdentifiers=function(){l(g.authentication),l(g.registration),l(g.resetPassword)},f.loadIdentifiers()}])}(angular); 9186 9188 "use strict";!function(i){i.module("lmxApp").service("shareAuthLoginToRegistration",["configurationService",function(i){this.loginAuth="",this.identifier=i.identifiers.registration[0],this.setIdentifier=function(t){t&&i.identifiers.registration.includes(t)?this.identifier=t:this.identifier=i.identifiers.registration[0]},this.clearLogin=function(){this.loginAuth="",this.identifier=i.identifiers.registration[0]}}])}(angular); 9187 9189 "use strict";!function(e){var a={captchaResponseRequired:"CaptchaResponseRequired"};e.module("lmxApp").constant("API_RESPONSE_CODE",a)}(angular); 9188 "use strict";!function(e){var o={host:"https://demo.loymax.tech/publicapi/",locales:"ru",templatesPath:"",customTemplates:[],imagesPath:"https://cdn.loymax.tech/js/v2.1/assets/images/",localesPath:"assets/locale/",reCaptchaSiteKey:"",isWP:"false",pages:{authentication:"#login",resetPassword:"#reset-password",registration:"#registration",offers:"#offers",feedback:"#feedback",anonymousFeedback:"#anonymous-feedback",message:"#message",showcase:"#showcase",coupons:"#coupons",cards:"#cards",favoriteGoods:"#favorite-goods",balance:"#balance",history:"#history",brands:"#brands",merchant:"#merchant",userStatus:"#user-status",social:"#social-binding",announcement:"#announcement",contacts:"#contacts",questionnaire:"#questionnaire",options:"#options",personalOffers:"#personal-offers",personalGoods:"#personal-goods"},components:{authentication:{redirectUrlOnLogin:"#history",redirectUrlOnLogout:"#home",shareAuthLoginToRegistration:!0,authenticationIdentifiers:"phone",resetPasswordIdentifiers:"phone"},registration:{acceptTenderOfferByCheck:!0,authorizeOnRegistrationComplete:!0,forceRegistrationStartOnLoginAttempt:!0,ignoreDocsFetchingErrors:!1,redirectUrlOnRegistrationComplete:"#home",offerHtmlFileId:"",offerPdfFileId:"",opdAgreementFileId:"",referralRegistration:!1,setRegistrationSmsCodeAsPassword:!0,forceEmailStep:!1,registrationIdentifiers:"phone"},cards:{enableAppleWalletCards:!1,enableGoogleWalletCards:!1,cardNumberGraphicalCode:"bar,qr",cvcCodeCardsRegistration:!1},personalOffers:{requestPersonalOffers:!1},personalGoods:{requestPersonalGoods:!1,personalGoodsApprovalMessage:""},favoriteGoods:{favoriteGoodsImagesUrl:""},history:{loadMoreButton:!1,balanceChangeHistory:!1,isBalanceChangeHistoryForCurrentUser:!1,userBalanceHistoryAttributeName:""},support:{supportEmail:"[email protected]"},merchant:{filterByRegion:!1},message:{requestUnreadMessage:!1},announcement:{space:"offerSpace"}},common:{requestUserAttributes:!1,locales:"ru",requestUserStatus:!1,turnOnOfferModal:!0,echequeLogicalName:"",modalShowTimeout:2,modalShowInterval:1,maxPopupNumber:5,popupText:"Подпишись на нашу рассылку и получи **200** бонусных рублей",userStatusAttributeName:"",userPurchasesAmountAttributeName:"",obsoleteBrowserDetection:!0,subscriptionTypes:"Advertisement",notificationTypes:"smsNotification,emailNotification",map:{},resendTimer:0,oAuthClientId:"",authWithPassword:!0,apiVersion:"22.1"},version:" 2.2"};e.module("lmxApp").constant("DEFAULT_CONFIG",o)}(angular);9190 "use strict";!function(e){var o={host:"https://demo.loymax.tech/publicapi/",locales:"ru",templatesPath:"",customTemplates:[],imagesPath:"https://cdn.loymax.tech/js/v2.1/assets/images/",localesPath:"assets/locale/",reCaptchaSiteKey:"",isWP:"false",pages:{authentication:"#login",resetPassword:"#reset-password",registration:"#registration",offers:"#offers",feedback:"#feedback",anonymousFeedback:"#anonymous-feedback",message:"#message",showcase:"#showcase",coupons:"#coupons",cards:"#cards",favoriteGoods:"#favorite-goods",balance:"#balance",history:"#history",brands:"#brands",merchant:"#merchant",userStatus:"#user-status",social:"#social-binding",announcement:"#announcement",contacts:"#contacts",questionnaire:"#questionnaire",options:"#options",personalOffers:"#personal-offers",personalGoods:"#personal-goods"},components:{authentication:{redirectUrlOnLogin:"#history",redirectUrlOnLogout:"#home",shareAuthLoginToRegistration:!0,authenticationIdentifiers:"phone",resetPasswordIdentifiers:"phone"},registration:{acceptTenderOfferByCheck:!0,authorizeOnRegistrationComplete:!0,forceRegistrationStartOnLoginAttempt:!0,ignoreDocsFetchingErrors:!1,redirectUrlOnRegistrationComplete:"#home",offerHtmlFileId:"",offerPdfFileId:"",opdAgreementFileId:"",referralRegistration:!1,setRegistrationSmsCodeAsPassword:!0,forceEmailStep:!1,registrationIdentifiers:"phone"},cards:{enableAppleWalletCards:!1,enableGoogleWalletCards:!1,cardNumberGraphicalCode:"bar,qr",cvcCodeCardsRegistration:!1},personalOffers:{requestPersonalOffers:!1},personalGoods:{requestPersonalGoods:!1,personalGoodsApprovalMessage:""},favoriteGoods:{favoriteGoodsImagesUrl:""},history:{loadMoreButton:!1,balanceChangeHistory:!1,isBalanceChangeHistoryForCurrentUser:!1,userBalanceHistoryAttributeName:""},support:{supportEmail:"[email protected]"},merchant:{filterByRegion:!1},message:{requestUnreadMessage:!1},announcement:{space:"offerSpace"}},common:{requestUserAttributes:!1,locales:"ru",requestUserStatus:!1,turnOnOfferModal:!0,echequeLogicalName:"",modalShowTimeout:2,modalShowInterval:1,maxPopupNumber:5,popupText:"Подпишись на нашу рассылку и получи **200** бонусных рублей",userStatusAttributeName:"",userPurchasesAmountAttributeName:"",obsoleteBrowserDetection:!0,subscriptionTypes:"Advertisement",notificationTypes:"smsNotification,emailNotification",map:{},resendTimer:0,oAuthClientId:"",authWithPassword:!0,apiVersion:"22.1"},version:"3.4.9"};e.module("lmxApp").constant("DEFAULT_CONFIG",o)}(angular); 9189 9191 "use strict";!function(n){var a={phone:"phone",email:"email",card:"card"},e={phone:"phone",card:"card"},o={phone:"phone",email:"email"};n.module("lmxApp").constant("IDENTIFIERS",a),n.module("lmxApp").constant("REGISTRATION_IDENTIFIERS",e),n.module("lmxApp").constant("RESET_PASSWORD_IDENTIFIERS",o)}(angular); 9190 9192 "use strict";!function(n){var t={INT32_MAX:2147483647};n.module("lmxApp").constant("LIMITS",t)}(angular); … … 9248 9250 "use strict";!function(t){t.module("lmxApp").service("userService",["$http","$q","$rootScope","configurationService","backendEnumsService","localStorageService",function(n,e,r,a,u,o){function i(){var t={userInfo:c(),userBalance:f()};return e.all(t).then(function(t){var n=t.userInfo;return n.balanceAccounts=t.userBalance,n.baseBalanceAccount=n.balanceAccounts[0],n})}function c(t){if(m)return e.when(m);var r={};return t&&(r.headers={Authorization:t.data.token_type+" "+t.data.access_token}),n.get(B,r).then(function(t){return t.data.state&&t.data.state===u.enums.userStatus.registered&&(m=t.data),t.data})}function s(){m=null}function f(){return n.get(A+"Balance").then(function(t){return t.data})}function l(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{state:null};return n.get(B+"DetailedBalance",{params:{state:t.state}}).then(function(t){return t.data})}function p(t,e,r,u,o,i,c){var s=[];u&&s.push("BonusActivation"),o&&s.push("BonusExpiration");var f={"filter.fromDate":e?e.toUTCDate(!0):null,"filter.toDate":r?r.toUTCDate(!0):null,"filter.changeTypes":s};return a.apiVersion>="21.1"?(f.from=i,f.count=c):(f["filter.from"]=i,f["filter.count"]=c),n.get(B+"DetailedBalance/"+"".concat(t,"/Operations"),{params:f}).then(function(t){return t.data})}function d(){return n.get(B+"Attributes").then(function(n){var e={};return t.forEach(n.data,function(t){e[t.info.logicalName]=t}),e})}function h(t){return n.get(B+"Subscriptions",{params:{subscriptionExternalIds:t}}).then(function(t){return t.data})}function g(){return n.post(a.host+"/v1.2/User/Subscriptions/Reject",{}).then(function(t){return t.data})}function v(){return n.post(a.host+"/v1.2/User/Subscriptions/Confirm",{}).then(function(t){return t.data})}function S(t){return n.post(B+"Subscriptions",t).then(function(t){return t})}function b(){return n.get(B+"Status").then(function(t){return t.data})}var m,B=a.host+"api/User/",A=a.host+"v1.1/User/";return{getUserInfo:i,getDetailedBalance:l,getCurrencyDetailedBalance:p,getBalance:f,getAttributes:d,getSubscriptions:h,setSubscriptions:S,getUserStatus:b,getUser:c,removeUserData:s,rejectAllSubscriptions:g,confirmAllSubscription:v}}])}(angular); 9249 9251 angular.module("templateCache").run(["$templateCache",function(n){n.put("app/directives/announcement/modal/announcementModal.html",'<div>\r\n <div class="modal-header">\r\n <div class="lmx-modal-closer" ng-click="close()"></div>\r\n <h2>{{:: announcement.attributes.OfferTitle.value}}</h2>\r\n </div>\r\n\r\n <div class="modal-content-wrapper">\r\n <div class="modal-body">\r\n <div class="lmx-image">\r\n <img ng-src="{{:: getAnnouncementImagePath(announcement.attributes.OfferImage.value)}}" fallback-image="" fallback-title="{{\'imageNotFound\' | translate}}" alt="">\r\n </div>\r\n <div class="lmx-description">{{:: announcement.attributes.OfferDescription.value}}</div>\r\n </div>\r\n <div class="modal-footer lmx-btn-container">\r\n <button type="button" ng-click="close()">{{\'buttons.close\' | translate}}</button>\r\n </div>\r\n </div>\r\n</div>\r\n'),n.put("app/directives/announcement/modal/authAnnouncementModal.html",'<div>\r\n <div class="lmx-modal-closer" ng-click="close()"></div>\r\n <div loader="inProgress">\r\n <div ng-if="!inProgress" class="modal-content-wrapper">\r\n <div class="modal-body">\r\n <a href="#/offers">\r\n <div class="lmx-image">\r\n <img ng-src="{{:: getAnnouncementImagePath(announcement.attributesDictionary.OfferImage.value)}}" fallback-image="" fallback-title="{{\'imageNotFound\' | translate}}" alt="" ng-click="openOffer()">\r\n </div>\r\n </a>\r\n </div>\r\n <div class="modal-footer lmx-btn-container">\r\n <button type="button" ng-click="close()">{{\'buttons.close\' | translate}}</button>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n'),n.put("app/directives/announcement/offerSpace.html",'<div class="lmx-container lmx-announcements">\r\n <section>\r\n <h2>{{\'announcement.title\' | translate}}</h2>\r\n <div loader="isProgress" class="lmx-announcements-list">\r\n <article ng-repeat="announcement in announcements track by announcement.id" ng-click="openAnnouncementModal(announcement)" class="lmx-announcement lmx-card">\r\n <div class="lmx-card-image">\r\n <img ng-src="{{:: getAnnouncementImagePath(announcement.attributes.OfferImage.value)}}" fallback-image="" fallback-title="{{\'imageNotFound\' | translate}}" alt="">\r\n </div>\r\n <div class="lmx-card-content">\r\n <div class="lmx-card-title" title="{{:: announcement.attributes.OfferTitle.value}}">\r\n {{:: announcement.attributes.OfferTitle.value}}\r\n </div>\r\n <div class="lmx-card-description">\r\n {{:: announcement.attributes.OfferDescription.value}}\r\n </div>\r\n </div>\r\n </article>\r\n </div>\r\n </section>\r\n</div>\r\n'),n.put("app/directives/anonymousFeedback/anonymousFeedback.html",'<div class="lmx-container lmx-anonymous-feedback">\r\n <section>\r\n <h2>{{\'anonymousFeedback.title\' | translate}}:</h2>\r\n <div class="lmx-hint">\r\n <p ng-bind-html="\'anonymousFeedback.hint\' | translate"></p>\r\n </div>\r\n <form novalidate="" name="anonFeedbackForm" ng-submit="anonFeedbackForm.$valid && sendMail(anonFeedbackForm)">\r\n <form-group label-text="{{\'anonymousFeedback.theme\' | translate}}">\r\n <input type="text" id="lmx-subject" ng-model="messageModel.subject" name="subject" required="">\r\n </form-group>\r\n <form-group label-text="{{\'anonymousFeedback.message\' | translate}}">\r\n <textarea id="lmx-msg-textarea" ng-model="messageModel.message" name="msg-textarea" ng-trim="false" required="">\r\n </textarea>\r\n </form-group>\r\n <div class="lmx-btn-container">\r\n <button type="submit" class="lmx-right">{{\'buttons.send\' | translate}}</button>\r\n </div>\r\n </form>\r\n </section>\r\n</div>\r\n'),n.put("app/directives/authentication/authentication.html",'<div class="lmx-container lmx-auth">\r\n <h2>{{\'authentication.title\' | translate}}</h2>\r\n <lmx-notifications area="login"></lmx-notifications>\r\n\r\n <identifiers ng-if=":: identifiers.arr !== undefined" ng-hide="cvcRequired" identifiers="identifiers.arr" ng-model="model.identifier" ng-change="resetFormModels()"></identifiers>\r\n\r\n <form novalidate="" method="post" name="loginForm" ng-submit="loginForm.$valid && login()" id="lmx-loginForm">\r\n <div ng-if="cvcRequired">\r\n <p>{{cvcMessage}}</p>\r\n <form-group label-text="{{\'authentication.code\' | translate}}">\r\n <input type="text" ng-model="model.cvcData.password" id="lmx-cvc" name="cvc" ng-disabled="authInProgress" required="">\r\n </form-group>\r\n <div>\r\n <a id="lmx-confirm-code-repeated" ng-click="!resendTimer.time && resendCode()" ng-hide="authInProgress" href="">\r\n {{\'resetPassword.resendCode\' | translate}}\r\n <span ng-if="resendTimer.time">({{resendTimer.time}})</span>\r\n </a>\r\n </div>\r\n </div>\r\n <div ng-if="!cvcRequired">\r\n <form-group ng-if="model.identifier === IDENTIFIERS.phone" label-text="{{\'identifiers.\' + model.identifier | translate}}">\r\n <phone-mask></phone-mask>\r\n <phone-input ng-model="model.loginData.login" id="lmx-login_{{model.identifier}}" name="login" ng-disabled="authInProgress" required="" autofocus=""></phone-input>\r\n </form-group>\r\n <form-group ng-if="model.identifier === IDENTIFIERS.email" label-text="{{\'identifiers.\' + model.identifier | translate}}">\r\n <input type="email" ng-model="model.loginData.login" id="lmx-login_{{model.identifier}}" name="login" placeholder="[email protected]" required="">\r\n </form-group>\r\n <form-group ng-if="model.identifier === IDENTIFIERS.card" label-text="{{\'identifiers.\' + model.identifier | translate}}">\r\n <input type="text" ng-model="model.loginData.login" id="lmx-login_{{model.identifier}}" name="login" ng-disabled="authInProgress" placeholder="0000 0000 0000 0000" mask="9999 9999 9999 9999" clean="true" validate="false" restrict="reject" required="">\r\n </form-group>\r\n <form-group label-text="{{\'authentication.password\' | translate}}" ng-if="authWithPassword">\r\n <input type="password" ng-model="model.loginData.password" id="lmx-password" name="password" ng-disabled="authInProgress" required="">\r\n </form-group>\r\n <div ng-if="!cvcRequired" class="lmx-auth-links lmx-row" ng-class="{\'lmx-invisible\': authInProgress}">\r\n <div>\r\n <a ng-click="resetPassword()" href="">{{\'authentication.forgotPassword\' | translate}}</a>\r\n </div>\r\n <div>\r\n <a href="{{:: registrationUrl}}">{{\'authentication.register\' | translate}}</a>\r\n </div>\r\n </div>\r\n </div>\r\n <div class="lmx-btn-container">\r\n <button type="reset" ng-hide="authInProgress" ng-if="cvcRequired" ng-click="cancelCvcConfirmation()">\r\n {{\'buttons.cancel\' | translate}}\r\n </button>\r\n <button type="submit" ng-hide="authInProgress">\r\n {{\'authentication.login\' | translate}}\r\n </button>\r\n\r\n <inline-loader line="">authInProgress</inline-loader>\r\n </div>\r\n <lmx-social ng-if="!cvcRequired" ng-hide="authInProgress"></lmx-social>\r\n </form>\r\n</div>\r\n'),n.put("app/directives/balance/balance.html",'<div class="lmx-container lmx-balance">\r\n <section>\r\n <h2>{{\'balance.title\' | translate}}</h2>\r\n <div loader="inProgress">\r\n <div ng-if="!inProgress" ng-switch="!!balanceAccounts.length">\r\n <div ng-switch-when="true" class="lmx-balance-block">\r\n <lmx-tabs list="balanceAccounts" ng-model="selectedAccount" view-field="title">\r\n </lmx-tabs>\r\n <balance-info ng-if="selectedAccount.currency"></balance-info>\r\n <div class="lmx-balance-accordion-wrap">\r\n <uib-accordion class="lmx-balance-accordion">\r\n <uib-accordion-group ng-repeat="selectedAccount in balanceAccounts" class="lmx-balance-accordion-group" ng-click="selectAccordion(selectedAccount)">\r\n <uib-accordion-heading class="lmx-balance-header">\r\n <span>{{::selectedAccount.title}}</span>\r\n <span class="glyphicon glyphicon-chevron-down"></span>\r\n <span class="glyphicon glyphicon-chevron-up"></span>\r\n </uib-accordion-heading>\r\n <balance-info ng-if="selectedAccount.currency.id === selectedCurrency.id"></balance-info>\r\n </uib-accordion-group>\r\n </uib-accordion>\r\n </div>\r\n </div>\r\n <div ng-switch-when="false" class="lmx-no-balance-block">\r\n {{\'balance.infoNotFound\' | translate}}\r\n </div>\r\n </div>\r\n </div>\r\n </section>\r\n</div>\r\n'),n.put("app/directives/balance/balanceInfo.html",'<div class="lmx-balance-tab-content">\r\n <h3>{{selectedAccount.currency.name}}</h3>\r\n <div class="lmx-account-description">{{selectedAccount.currency.description}}</div>\r\n <div class="lmx-account-details">\r\n <div>\r\n <b>{{\'balance.amount\' | translate}}</b>: {{selectedAccount.amount | number: 2}}\r\n {{selectedAccount.currency.nameCases[getCurrencyNameCase(selectedAccount.amount)]}}\r\n </div>\r\n <div>\r\n <b>{{\'balance.notActivatedAmount\' | translate}}</b>:\r\n {{selectedAccount.notActivatedAmount | number: 2}}\r\n {{selectedAccount.currency.nameCases[getCurrencyNameCase(selectedAccount.notActivatedAmount)]}}\r\n </div>\r\n\r\n <div ng-if="selectedAccount.lifeTimesByTime.length">\r\n <b>\r\n {{\'balance.lastWeekChanges\' | translate}}:\r\n </b>\r\n <div class="lmx-lifeTime-amount">\r\n {{ \'history.gift.rewardData\' | translate }} - {{ weekRewardAmount |\r\n number:2 }}\r\n {{selectedAccount.currency.nameCases[getCurrencyNameCase(weekRewardAmount)]}}\r\n <br>\r\n {{ \'history.gift.withdrawData\' | translate }} - {{ (weekWithdrawAmount *\r\n -1) | number:2 }}\r\n {{selectedAccount.currency.nameCases[getCurrencyNameCase(weekWithdrawAmount)]}}\r\n </div>\r\n </div>\r\n\r\n <div ng-if="selectedAccount.lifeTimesByPeriod.length">\r\n <div ng-repeat="lifeTime in selectedAccount.lifeTimesByPeriod track by $index">\r\n <b>\r\n {{ (\'balance.lifeTimePeriod.\' + (lifeTime.period | lowerCamelCase)) |\r\n translate}}:\r\n </b>\r\n <div class="lmx-lifeTime-amount">\r\n {{ \'history.gift.rewardData\' | translate }} - {{\r\n lifeTime.activationAmount | number: 2}}\r\n {{selectedAccount.currency.nameCases[getCurrencyNameCase(lifeTime.activationAmount)]}}\r\n <br>\r\n {{ \'history.gift.withdrawData\' | translate }} - {{\r\n (lifeTime.expirationAmount * -1) | number: 2 }} {{\r\n selectedAccount.currency.nameCases[getCurrencyNameCase(lifeTime.expirationAmount)]\r\n }}\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div class="lmx-currency-info" loader="inProgress">\r\n <h3>{{ \'history.balanceChanges\' | translate }}</h3>\r\n <div class="date-filters">\r\n <div class="date-filter lmx-since-date-filter">\r\n <span class="lmx-pretext">{{\'history.fromDate\' | translate}}</span>\r\n <date-picker ng-model="fromDate" ng-change="getCurrencyInfo()"> </date-picker>\r\n </div>\r\n \r\n <div class="date-filter lmx-to-date-filter">\r\n <span class="lmx-pretext">{{\'history.toDate\' | translate}}</span>\r\n <date-picker ng-model="toDate" ng-change="getCurrencyInfo()"> </date-picker>\r\n </div>\r\n </div>\r\n <input type="checkbox" id="lmx-activation" name="activation" ng-model="activation" ng-click="getCurrencyInfo()">\r\n <label for="lmx-activation">\r\n {{:: \'history.gift.rewardData\' | translate }}\r\n </label>\r\n\r\n <input type="checkbox" id="lmx-expiration" name="expiration" ng-model="expiration" ng-click="getCurrencyInfo()">\r\n <label for="lmx-expiration">\r\n {{:: \'history.gift.withdrawData\' | translate }}\r\n </label>\r\n\r\n <uib-pagination ng-show="operations[selectedAccount.currency.id].$allCount > onPage" total-items="operations[selectedAccount.currency.id].$allCount" ng-model="currentPage" max-size="4" items-per-page="{{:: onPage}}" class="lmx-pagination" boundary-links="true" boundary-link-numbers="true" direction-links="false" force-ellipses="true" first-text="<<" last-text=">>" ng-change="getCurrencyInfo()"></uib-pagination>\r\n\r\n <div class="lmx-history-not-found" ng-if="!operations[selectedAccount.currency.id].$allCount && !inProgress">\r\n {{ \'history.notFound\' | translate}}\r\n </div>\r\n\r\n <table ng-if="operations[selectedAccount.currency.id].$allCount && !inProgress">\r\n <tr>\r\n <th>{{ \'history.operations\' | translate}}</th>\r\n <th>{{ \'balanceChanges.amount\' | translate }}</th>\r\n <th>{{ \'balance.date\' | translate }}</th>\r\n </tr>\r\n <tr ng-repeat="operation in operations[selectedAccount.currency.id] track by $index">\r\n <td>\r\n {{ (operation.amount < 0 ? \'history.gift.withdrawData\' :\r\n \'history.gift.rewardData\' ) | translate }}\r\n </td>\r\n <td ng-class="{\'lmx-activation\': operation.amount > 0,\'lmx-expiration\': operation.amount < 0}">\r\n {{ operation.amount }} {{\r\n selectedAccount.currency.nameCases[getCurrencyNameCase(operation.amount)]}}\r\n </td>\r\n <td>\r\n {{ operation.date | toUTC | shortDateTime }}\r\n </td>\r\n </tr>\r\n </table>\r\n </div>\r\n</div>\r\n'),n.put("app/directives/balanceChanges/balanceChanges.html",'<div class="lmx-container lmx-balance-changes">\r\n <div class="lmx-balance-changes-table">\r\n <div class="lmx-balance-changes-operations-list lmx-margin-bottom" loader="inProgress">\r\n <div>\r\n <table>\r\n <tbody>\r\n <tr class="lmx-purchase-amount-row">\r\n <td class="lmx-identity">\r\n {{\'balanceChanges.purchaseAmount\' | translate}}:\r\n </td>\r\n <td class="lmx-amount" ng-switch="model.aggregateWithdrawRewardPurchase.purchaseAmount.length" colspan="2">\r\n <p class="lmx-amount-text" ng-switch-when="0">0</p>\r\n <p ng-repeat="item in model.aggregateWithdrawRewardPurchase.purchaseAmount" class="lmx-amount-text" ng-switch-default="">\r\n {{:: item.amount.amount}} {{:: item.amount.currency}}\r\n </p>\r\n </td>\r\n </tr>\r\n <tr class="lmx-rewards-row">\r\n <td class="lmx-identity">{{\'balanceChanges.rewards\' | translate}}:</td>\r\n <td class="lmx-amount" ng-switch="model.aggregateWithdrawRewardPurchase.rewards.length" colspan="2">\r\n <p class="lmx-amount-text" ng-switch-when="0">0</p>\r\n <p ng-switch-default="" ng-repeat="reward in model.aggregateWithdrawRewardPurchase.rewards" class="lmx-amount-text">\r\n {{:: reward.amount.amount}} {{:: reward.amount.currency}}\r\n </p>\r\n </td>\r\n </tr>\r\n <tr class="lmx-withdraws-row">\r\n <td class="lmx-identity">{{\'balanceChanges.withdraws\' | translate}}:</td>\r\n <td class="lmx-amount" colspan="2" ng-switch="model.aggregateWithdrawRewardPurchase.withdraws.length">\r\n <p class="lmx-amount-text" ng-switch-when="0">0</p>\r\n <p ng-repeat="withdraw in model.aggregateWithdrawRewardPurchase.withdraws" class="lmx-amount-text" ng-switch-default="">\r\n {{:: withdraw.amount.amount}} {{:: withdraw.amount.currency}}\r\n </p>\r\n </td>\r\n </tr>\r\n <tr ng-if="model.percentageOfBonuses.length" class="lmx-operation-info" class-toggle-click="percent-opened" ng-class="::{\'lmx-only-one-element\': model.percentageOfBonuses.length === 1}" ng-click="changeLimit()">\r\n <td class="lmx-identity">{{\'balanceChanges.percent\' | translate}}:</td>\r\n <td class="date-range">\r\n <p class="lmx-amount-text lmx-percent-info" ng-repeat="item in model.percentageOfBonuses | limitTo: limit">\r\n <span class="lmx-operation-info-date">\r\n {{item.createDateTime | toUTC | dateRange:\r\n (item.changeDateTime | toUTC):true | capitalize}}\r\n </span>\r\n <span class="lmx-operation-info-value">\r\n {{item.attributeValue}}\r\n </span>\r\n </p>\r\n </td>\r\n <td class="lmx-percent-info-expander"></td>\r\n </tr>\r\n <tr ng-if="!model.percentageOfBonuses.length" class="lmx-not-found-row">\r\n <td class="lmx-identity">{{\'balanceChanges.percent\' | translate}}:</td>\r\n <td class="lmx-amount" colspan="2">\r\n {{\'balanceChanges.notFound\' | translate}}\r\n </td>\r\n </tr>\r\n </tbody>\r\n </table>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n'),n.put("app/directives/birthdayPicker/birthdayPicker.html",'<div class="lmx-birthday-picker">\r\n <div class="lmx-birthday-picker-wrapper lmx-day">\r\n <div lmx-custom-select="" ng-model="date" repeat="dates" placeholder="{{\'datePicker.day\' | translate}}" options="d for d in dates track by d" is-disabled="disabled"></div>\r\n </div>\r\n <div class="lmx-birthday-picker-wrapper lmx-month">\r\n <div lmx-custom-select="" ng-model="month" repeat="months" placeholder="{{\'datePicker.month\' | translate}}" options="m.value as m.name for m in months" is-disabled="disabled"></div>\r\n </div>\r\n <div class="lmx-birthday-picker-wrapper lmx-year">\r\n <div lmx-custom-select="" ng-model="year" repeat="years" placeholder="{{\'datePicker.year\' | translate}}" options="y for y in years" is-disabled="disabled"></div>\r\n </div>\r\n</div>\r\n'),n.put("app/directives/brand/brand.html",'<div class="lmx-container lmx-brand">\r\n <section>\r\n <h2>{{::brand.name}}</h2>\r\n <p>{{::brand.description}}</p>\r\n <div class="lmx-content">\r\n <div class="lmx-image">\r\n <img ng-src="{{:: brand.imgUrl}}" fallback-image="" fallback-title="{{\'imageNotFound\' | translate}}" alt="">\r\n </div>\r\n <a ng-href="{{::brand.url}}">{{\'brands.site\' | translate}}</a>\r\n <div ng-if="merchants.length">\r\n <p>{{\'brands.locations\' | translate}}:</p>\r\n <div ng-repeat="merchant in merchants track by merchant.id">\r\n <span>{{::merchant.location.description}}</span>\r\n </div>\r\n <lmx-map class="lmx-map" data="merchants" options="{\r\n markerImg: brand.markerUrl,\r\n markerSize: [29, 32]\r\n }">\r\n </lmx-map>\r\n </div>\r\n </div>\r\n </section>\r\n</div>\r\n'),n.put("app/directives/brands/brands.html",'<div>\r\n <div class="lmx-container lmx-brands" ng-if="!appLocationParts[1]">\r\n <section>\r\n <h2>{{\'brands.title\' | translate}}</h2>\r\n <div loader="inProgress">\r\n <!-- TODO width: 400px; height: 400px; -->\r\n <div class="lmx-card" style="width: 400px; height: 400px;" ng-repeat="brand in brands track by brand.id" ng-click="changeLocation(\'brands/\' + brand.id)">\r\n <div>\r\n <img ng-src="{{:: brand.imgUrl}}" fallback-image="" fallback-title="{{\'imageNotFound\' | translate}}" alt="" style="height: 250px; padding: 10px">\r\n </div>\r\n <div class="lmx-card-content">\r\n <span class="lmx-card-title">{{:: brand.name}}</span>\r\n <div class="lmx-description">{{::brand.description}}</div>\r\n </div>\r\n </div>\r\n </div>\r\n </section>\r\n </div>\r\n <brand ng-if="appLocationParts[1]" brand-id="appLocationParts[1]"></brand>\r\n</div>\r\n'),n.put("app/directives/brandsNames/brandsNames.html",'<div class="lmx-brands-names" ng-class="{\'lmx-one-brand\': brands.length === 1}">\r\n <div ng-if="brands.length > 1">\r\n <span ng-repeat="brand in brands track by brand.id">\r\n {{::brand.name | nbspSpaces}}<span ng-show="!$last">, </span>\r\n </span>\r\n </div>\r\n <div ng-if="brands.length === 1" ng-switch=":: !!brands[0].imgUrl && brands[0].imgUrl !== \'undefined\'">\r\n <span ng-switch-when="false">{{:: brands[0].name | nbspSpaces}}</span>\r\n <img ng-switch-when="true" class="lmx-brand-img" ng-src="{{:: brands[0].imgUrl}}" fallback-image="" alt="" title="{{:: brands[0].name}}">\r\n </div>\r\n</div>\r\n'),n.put("app/directives/cards/card/card.html",'<div>\r\n <div class="lmx-card-item__image" ng-class="{\'lmx-blocked\': card.block}">\r\n <img ng-src="{{ card.imageUrl}}" fallback-image="" fallback-title="{{\'imageNotFound\' | translate}}" alt="">\r\n </div>\r\n <div class="lmx-card-item__info" ng-switch=":: !!cardNumberGraphicalCodes.length && !card.isInGroup">\r\n <div ng-switch-when="true">\r\n <!-- Пробел после :: в {{::cardNumberGraphicalCodes.join(\' \')}} сводит префиксер с ума -->\r\n <div class="lmx-card-number lmx-card-code lmx-{{::cardNumberGraphicalCodes.join(\' lmx-\')}}" ng-click="displayCodes(card)">\r\n <a class="lmx-pseudolink">{{:: card.number | charsDivide: 4}}</a>\r\n </div>\r\n </div>\r\n <div ng-switch-when="false" class="lmx-card-number">{{:: card.number | charsDivide: 4}}</div>\r\n\r\n <div class="lmx-card-category" ng-hide="::card.cardCategory.title.toLowerCase() === \'стандартная\'">\r\n {{:: card.cardCategory.title}}\r\n </div>\r\n <div class="lmx-card-blocked-state-info" ng-if="::card.block">\r\n {{\'cards.info.blocked\' | translate}}\r\n </div>\r\n\r\n <dl class="lmx-card-owner" ng-if="::card.cardOwnerInfo.firstName || card.cardOwnerInfo.lastName || card.patronymicName">\r\n <dt>{{\'cards.info.owner\' | translate}}:</dt>\r\n <dd>\r\n <span>{{:: card.cardOwnerInfo.lastName}}</span>\r\n <span>{{:: card.cardOwnerInfo.firstName}}</span>\r\n <span>{{:: card.cardOwnerInfo.patronymicName}}</span>\r\n </dd>\r\n </dl>\r\n <dl class="lmx-card-paid">\r\n <dt>{{\'cards.info.paid\' | translate}}:</dt>\r\n <dd>\r\n <span>{{:: card.paid.amount | number: 2}}</span>\r\n <span>{{:: card.paid.currencyInfo.nameCases.abbreviation}}</span>\r\n </dd>\r\n </dl>\r\n <div ng-if=":: !card.isInGroup" class="lmx-card-actions">\r\n <button ng-class="card.block ? \'lmx-card-action__unblock\' : \'lmx-card-action__block\'" class="lmx-block-btn" ng-if="card.cardActionAccessInfo.canBlock" ng-click="blockStateChange(card)" type="button">\r\n {{card.block ? \'cards.actions.unblock\' : \'cards.actions.block\' | translate}}\r\n </button>\r\n <button ng-if="card.cardActionAccessInfo.canReplace" ng-click="replaceCard(card)" type="button" class="lmx-replace-btn">\r\n {{\'cards.actions.replace\' | translate}}\r\n </button>\r\n <a ng-if="card.walletUrl && !card.block && platfotm.currentPlatform" ng-href="{{::card.walletUrl}}" target="_blank" class="lmx-wallet-btn lmx-{{::platfotm.currentPlatform}}-wallet-btn"></a>\r\n </div>\r\n </div>\r\n</div>\r\n'),n.put("app/directives/cards/cards.html",'<div class="lmx-container lmx-cards">\r\n <section>\r\n <h2>{{\'cards.title\' | translate}}</h2>\r\n <div loader="inProgress">\r\n <div ng-if="!inProgress">\r\n <lmx-tabs ng-if="isAttachCardAvailable" list="tabs" ng-model="selectedTab.value" view-field="name">\r\n </lmx-tabs>\r\n <div ng-show="selectedTab.value === tabs.personalCards" ng-class="::{\'lmx-no-add-card-button\': !maxCountOfMainCardsForUserNotReached}" class="lmx-personal-cards">\r\n <p ng-bind-html="\'cards.replaceHint\' | translate"></p>\r\n\r\n <div class="lmx-card-item-wrap" ng-repeat="card in cards.personal track by card.id">\r\n <card card="card" class="lmx-card-item"></card>\r\n </div>\r\n <div class="lmx-add-card-buttons" ng-if="maxCountOfMainCardsForUserNotReached">\r\n <button ng-click="setCard()" type="button" class="lmx-set-card-btn">\r\n {{\'cards.actions.set\' | translate}}\r\n </button>\r\n </div>\r\n </div>\r\n\r\n <div ng-show="selectedTab.value === tabs.accountCards" class="lmx-account-cards">\r\n <div ng-repeat="card in cards.group track by card.id">\r\n <card card="card" class="lmx-card-item" in-group=""></card>\r\n </div>\r\n <div class="lmx-add-card-buttons">\r\n <button ng-click="attachCard()" type="button" class="lmx-attach-btn">\r\n {{\'cards.actions.attach\' | translate}}\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </section>\r\n</div>\r\n'),n.put("app/directives/cards/modal/modalAttachCard.html",'<div class="lmx-attach-card-modal">\r\n <div class="modal-header">\r\n <h2>{{\'cards.attachCardModal.title\' | translate}}</h2>\r\n </div>\r\n\r\n <lmx-notifications area="cardModal"></lmx-notifications>\r\n <div loader="confirmForm === undefined">\r\n <div ng-hide="confirmForm === undefined" class="lmx-hint lmx-modal-description lmx-row">\r\n <div>{{\'cards.attachCardModal.separationImpossible\' | translate}}</div>\r\n <div ng-if="confirmForm" ng-bind-html="\'cards.attachCardModal.confirmCode\' | translate"></div>\r\n </div>\r\n <form novalidate="" ng-if="confirmForm === false" name="attachCardForm" ng-submit="attachCardForm.$valid && startAttachCard()">\r\n <div class="modal-content-wrapper">\r\n <div class="modal-body">\r\n <form-group label-text="{{\'cards.attachCardModal.cardNumber\' | translate}}">\r\n <input type="text" ng-model="model.cardNumber" ng-disabled="inProgress" id="lmx-cardnumber" name="cardnumber" required="" autofocus="">\r\n </form-group>\r\n <form-group label-text="{{\'cards.attachCardModal.password\' | translate}}">\r\n <input type="password" ng-model="model.password" ng-disabled="inProgress" id="lmx-password" name="password" autocomplete="off" required="">\r\n </form-group>\r\n </div>\r\n <div class="modal-footer lmx-btn-container">\r\n <div ng-hide="inProgress">\r\n <button class="lmx-btn-cancel" type="button" ng-click="cancel()">\r\n {{\'buttons.cancel\' | translate}}\r\n </button>\r\n <button type="submit">{{\'buttons.next\' | translate}}</button>\r\n </div>\r\n <inline-loader>inProgress</inline-loader>\r\n </div>\r\n </div>\r\n </form>\r\n\r\n <form novalidate="" ng-if="confirmForm" name="attachCardConfirmForm" ng-submit="attachCardConfirmForm.$valid && confirm()">\r\n <div class="modal-content-wrapper">\r\n <div class="modal-body">\r\n <form-group label-text="{{\'cards.attachCardModal.code\' | translate}}">\r\n <input type="text" ng-model="model.confirmCode" ng-disabled="inProgress" id="lmx-confirmCode" name="confirmCode" required="" autofocus="">\r\n </form-group>\r\n <div ng-hide="inProgress">\r\n <a ng-click="!resendTimer.time && sendConfirmCode()" href="">\r\n {{\'cards.attachCardModal.resendConfirmCode\' | translate}}\r\n <span ng-if="resendTimer.time">({{resendTimer.time}})</span>\r\n </a>\r\n </div>\r\n </div>\r\n <div class="modal-footer lmx-btn-container">\r\n <div ng-hide="inProgress">\r\n <button class="lmx-btn-cancel" ng-click="cancelAttachCard()" type="button">\r\n {{\'buttons.cancel\' | translate}}\r\n </button>\r\n <button type="submit">{{\'cards.actions.attach\' | translate}}</button>\r\n </div>\r\n <inline-loader>inProgress</inline-loader>\r\n </div>\r\n </div>\r\n </form>\r\n </div>\r\n</div>\r\n'), 9250 n.put("app/directives/cards/modal/modalBlockStateChange.html",'<div class="lmx-block-state-change-modal">\r\n <div class="modal-header">\r\n <h2>\r\n {{\'cards.blockCardModal.\' + (isBlocked ? \'unblockTitle\' : \'blockTitle\') | translate}}\r\n </h2>\r\n </div>\r\n <lmx-notifications area="cardModal"></lmx-notifications>\r\n <form novalidate="" name="blockCardForm" ng-submit="blockCardForm.$valid && blockStateChange()">\r\n <div class="modal-content-wrapper">\r\n <div class="modal-body">\r\n <form-group label-text="{{\'cards.blockCardModal.password\' | translate}}">\r\n <input type="password" ng-model="model.password" ng-disabled="inProgress" id="lmx-userPassword" name="userPassword" autocomplete="off" required="" autofocus="">\r\n </form-group>\r\n </div>\r\n <div class="modal-footer lmx-btn-container">\r\n <div ng-hide="inProgress">\r\n <button class="lmx-btn-cancel" ng-click="cancel()" type="button">\r\n {{\'buttons.cancel\' | translate}}\r\n </button>\r\n <button type="submit">\r\n {{isBlocked ? \'cards.actions.unblock\' : \'cards.actions.block\' | translate}}\r\n </button>\r\n </div>\r\n <inline-loader>inProgress</inline-loader>\r\n </div>\r\n </div>\r\n </form>\r\n</div>\r\n'),n.put("app/directives/cards/modal/modalGraphicalCodes.html",'<div class="lmx-card-codes-modal">\r\n <div class="modal-body">\r\n <section ng-if=":: displayBarCode" class="lmx-bar-code lmx-margin-bottom">\r\n <h2>{{\'cards.graphicalCodesModal.barCode\' | translate}}</h2>\r\n <angular-barcode ng-model="card.barCode" bc-type="svg"></angular-barcode>\r\n </section>\r\n\r\n <section ng-if=":: displayQrCode" class="lmx-qr-code">\r\n <h2>{{\'cards.graphicalCodesModal.qrCode\' | translate}}</h2>\r\n <qrcode data="{{:: card.number}}" size="222"></qrcode>\r\n </section>\r\n </div>\r\n\r\n <div class="modal-footer lmx-btn-container">\r\n <button type="button" ng-click="close()">{{\'buttons.close\' | translate}}</button>\r\n </div>\r\n</div>\r\n'),n.put("app/directives/cards/modal/modalReplaceCard.html",'<div class="lmx-replace-card-modal">\r\n <div class="modal-header">\r\n <h2>{{\'cards.replaceCardModal.title\' | translate}}</h2>\r\n </div>\r\n <lmx-notifications area="cardModal"></lmx-notifications>\r\n <form novalidate="" name="replaceCardForm" ng-submit="replaceCardForm.$valid && replaceCard()">\r\n <div class="modal-content-wrapper">\r\n <div class="modal-body">\r\n <form-group label-text="{{\'cards.replaceCardModal.cardNumber\' | translate}}">\r\n <input type="text" ng-model="model.cardNumber" ng-disabled="inProgress" id="lmx-cardNumber" name="cardNumber" required="" autofocus="">\r\n </form-group>\r\n <form-group ng-if="cvcCodeCardsRegistration" label-text="{{\'cards.replaceCardModal.cvcCode\' | translate}}">\r\n <input type="number" ng-model="model.cvcCode" ng-disabled="inProgress" id="lmx-cvcCode" name="cvcCode">\r\n </form-group>\r\n <form-group label-text="{{\'cards.replaceCardModal.password\' | translate}}">\r\n <input type="password" ng-model="model.password" ng-disabled="inProgress" id="lmx-password" name="password" autocomplete="off" required="">\r\n </form-group>\r\n </div>\r\n <div class="modal-footer lmx-btn-container">\r\n <div ng-hide="inProgress">\r\n <button class="lmx-btn-cancel" ng-click="cancel()" type="button">\r\n {{\'buttons.cancel\' | translate}}\r\n </button>\r\n <button type="submit">\r\n {{\'cards.actions.replace\' | translate}}\r\n </button>\r\n </div>\r\n <inline-loader>inProgress</inline-loader>\r\n </div>\r\n </div>\r\n </form>\r\n</div>\r\n'),n.put("app/directives/cards/modal/modalSetCard.html",'<div class="lmx-set-card-modal">\r\n <div class="modal-header">\r\n <h2>{{\'cards.setCardModal.title\' | translate}}</h2>\r\n </div>\r\n\r\n <lmx-notifications area="cardModal"></lmx-notifications>\r\n\r\n <form novalidate="" name="setCardForm" ng-submit="setCardForm.$valid && setCard()">\r\n <div class="modal-content-wrapper">\r\n <div class="modal-body">\r\n <form-group label-text="{{\'cards.setCardModal.cardNumber\' | translate}}">\r\n <input type="text" ng-model="model.cardNumber" ng-disabled="inProgress" id="lmx-cardNumber" name="cardNumber" required="" autofocus="">\r\n </form-group>\r\n <form-group ng-if="cvcCodeCardsRegistration" label-text="{{\'registration.cardStep.cvcCode\' | translate}}">\r\n <input type="number" ng-model="model.cvcCode" ng-disabled="inProgress" id="lmx-cvcCode" name="cvcCode">\r\n </form-group>\r\n </div>\r\n <div class="modal-footer lmx-btn-container">\r\n <div ng-hide="inProgress">\r\n <button class="lmx-btn-cancel" ng-click="cancel()" type="button">\r\n {{\'buttons.cancel\' | translate}}\r\n </button>\r\n <button type="submit">\r\n {{\'cards.actions.set\' | translate}}\r\n </button>\r\n </div>\r\n <inline-loader>inProgress</inline-loader>\r\n </div>\r\n </div>\r\n </form>\r\n</div>\r\n'),n.put("app/directives/coupon/coupon.html",'<div class="lmx-card" style="width: 400px; height: 400px;">\r\n <div class="lmx-card-image">\r\n <img ng-src="{{::coupon.imageUri || \'undefined\'}}" fallback-image="" fallback-title="{{\'coupons.imageNotFound\' | translate}}" alt="" style="height: 250px; padding: 10px">\r\n </div>\r\n <div class="lmx-card-content">\r\n <span class="lmx-card-title">{{coupon.name}}</span>\r\n <span><b>{{\'coupons.price\' | translate}}:</b> {{coupon.price}} RUB</span>\r\n </div>\r\n <div class="lmx-card-reveal">\r\n <span class="lmx-card-title"><span class="glyphicon glyphicon-remove"></span>{{coupon.name}}</span>\r\n <p>\r\n <span><b>{{\'coupons.description\' | translate}}:</b>{{:: couponInfo.description ||\r\n (\'coupons.noDescription\' | translate)}}</span>\r\n </p>\r\n <button ng-if=":: loggedIn" type="button" ng-click="openBuyCouponModal(coupon)">\r\n <div>\r\n {{\'coupons.buy\' | translate}}\r\n <span class="lmx-price">{{ coupon.price | zeroFill: 2 }}</span>\r\n </div>\r\n </button>\r\n <button ng-if=":: !loggedIn" type="button" ng-click="goToLogin()">\r\n <div>{{\'coupons.login\' | translate}}</div>\r\n </button>\r\n </div>\r\n</div>\r\n'),n.put("app/directives/coupons/coupons.html",'<div class="lmx-container lmx-coupons">\r\n <h2>{{\'coupons.title\' | translate}}</h2>\r\n <div loader="inProgress">\r\n <div class="lmx-coupon lmx-card" ng-repeat="coupon in coupons track by coupon.id" ng-click="openCouponInfo(coupon)">\r\n <div class="lmx-card-code">\r\n <div class="lmx-image-block">\r\n <img ng-src="data:{{::coupon.imageFile.mimeType}};charset=utf-8;base64, {{::coupon.imageFile.content}}" fallback-image="" fallback-title="{{\'imageNotFound\' | translate}}" alt="" style="height: 100px; padding: 10px">\r\n </div>\r\n </div>\r\n <div class="lmx-card-content">\r\n <div class="lmx-coupon-details">\r\n <div class="lmx-coupon-title">\r\n <h2>{{ coupon.emissionTitle }}</h2>\r\n </div>\r\n <div class="lmx-coupon-description">{{ coupon.shortDescription}}</div>\r\n <div class="lmx-coupon-content">\r\n <div class="lmx-coupon-code">\r\n <qrcode data="{{:: coupon.code }}" size="100"></qrcode>\r\n </div>\r\n <div class="lmx-coupon-period">\r\n <span>Номер купона: {{ coupon.code }}</span>\r\n\r\n <div ng-if="coupon.expiryDate && offerProceed(coupon.activationDate) && !lessThanWeek(coupon.expiryDate)" class="lmx-rating-container">\r\n <span ng-if="offerStartedToday(coupon.activationDate)">\r\n {{ \'coupons.expirationDate\' | translate}}: {{:: coupon.expiryDate | toUTC | shortDate }}\r\n </span>\r\n <span ng-if="!offerStartedToday(coupon.activationDate)">\r\n {{ \'coupons.offerStartFrom\' | translate }} {{:: coupon.activationDate | toUTC | shortDateTime }}\r\n {{ \'dateRange.to\' | translate }}\r\n {{:: coupon.expiryDate | toUTC | shortDate }}\r\n </span>\r\n </div>\r\n\r\n <div ng-if="coupon.expiryDate && lessThanWeek(coupon.expiryDate) && offerProceed(coupon.activationDate)">\r\n {{ \'coupons.offerPeriod.left\' | translate }}:\r\n {{ leftDays }} {{\'coupons.offerPeriod.leftDays\' | translate }}\r\n {{ leftHours }} {{\'coupons.offerPeriod.leftHours\' | translate }}\r\n </div>\r\n\r\n <div ng-if="coupon.expiryDate && !offerProceed(coupon.activationDate)">\r\n {{ \'coupons.offerStartFrom\' | translate }}\r\n {{ coupon.activationDate | toUTC | shortDate }}\r\n {{ \'dateRange.to\' | translate }}\r\n {{ coupon.expiryDate | toUTC | shortDate }}\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n'),n.put("app/directives/coupons/modal/couponViewModal.html",'<div class="lmx-coupon-modal">\r\n <div class="modal-header">\r\n <div class="lmx-modal-closer" ng-click="cancel()"></div>\r\n <h2>{{:: coupon.emissionTitle }}</h2>\r\n </div>\r\n\r\n <div class="modal-content-wrapper">\r\n <div class="lmx-coupon-modal">\r\n <div class="modal-body">\r\n <qrcode data="{{:: coupon.code }}" href="{{ coupon.qrContent }}" size="200"></qrcode>\r\n\r\n <div ng-if="coupon.expiryDate && offerProceed(coupon.activationDate) && !lessThanWeek(coupon.expiryDate)" class="lmx-rating-container">\r\n <span ng-if="offerStartedToday(coupon.activationDate)">\r\n {{ \'coupons.expirationDate\' | translate}}: {{:: coupon.expiryDate | toUTC | shortDate }}\r\n </span>\r\n <span ng-if="!offerStartedToday(coupon.activationDate)">\r\n {{ \'coupons.offerStartFrom\' | translate }} {{:: coupon.activationDate | toUTC | shortDateTime }}\r\n {{ \'dateRange.to\' | translate }}\r\n {{:: coupon.expiryDate | toUTC | shortDate }}\r\n </span>\r\n </div>\r\n\r\n <div ng-if="coupon.expiryDate && lessThanWeek(coupon.expiryDate) && offerProceed(coupon.activationDate)">\r\n {{ \'coupons.offerPeriod.left\' | translate }}:\r\n {{ leftDays }} {{\'coupons.offerPeriod.leftDays\' | translate}}\r\n {{ leftHours }} {{\'coupons.offerPeriod.leftHours\' | translate}}\r\n <div class="lmx-bar">\r\n <span class="lmx-left-time" ng-style="{ width: expiryTimePercent + \'%\'}"></span>\r\n </div>\r\n </div>\r\n\r\n <div ng-if="coupon.expiryDate && !offerProceed(coupon.activationDate)">\r\n {{ \'coupons.offerStartFrom\' | translate }}\r\n {{ coupon.activationDate | toUTC | shortDate }}\r\n {{ \'dateRange.to\' | translate }}\r\n {{ coupon.expiryDate | toUTC | shortDate }}\r\n </div>\r\n\r\n <div class="lmx-coupon-description">\r\n {{ coupon.description }}\r\n </div>\r\n\r\n <div class="lmx-coupon-hint">\r\n {{ \'coupons.hint\' | translate }}\r\n </div>\r\n </div>\r\n <div class="modal-footer lmx-btn-container">\r\n <button type="button" ng-click="cancel()">{{\'buttons.close\' | translate}}</button>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n'),n.put("app/directives/ datePicker/datePickerView.html",'<span class="date-picker-wrap" outside-click="toggleCalendar($event, false)">\r\n <div class="toggler" ng-click="toggleCalendar($event)">\r\n <span class="glyphicon glyphicon-calendar"></span>\r\n </div>\r\n\r\n <input type="text" ng-class="\'lmx-\'+inputClass" datetime-picker="{{dateFormat}}" ng-model="model" ng-keyup="validateModel($event)" ng-model-options="modelOptions" datepicker-options="options" button-bar="{show:false}" is-open="isOpen" enable-time="false">\r\n</span>\r\n'),n.put("app/directives/dateTimePicker/datetimePickerView.html",'<span class="date-picker-wrap" outside-click="toggleCalendar($event, false)">\r\n <div class="toggler glyphicon glyphicon-calendar" ng-click="toggleCalendar($event)"></div>\r\n\r\n <input type="text" ng-if=":: timepickerOptions" ng-class="\'lmx-\'+inputClass" datetime-picker="{{dateFormat}}" ng-model="model" ng-keyup="checkModel($event)" ng-model-options="modelOptions" button-bar="buttonsOptions" initial-picker="date" re-open-default="date" datepicker-options="{showWeeks:false}" timepicker-options="timepickerOptions" is-open="isOpen">\r\n</span>\r\n'),n.put("app/directives/favoriteGoods/favoriteGood/favoriteGood.html",'<div class="lmx-favorite-goods-item">\r\n <div class="lmx-favorite-goods-item__image">\r\n <img ng-src="{{:: favoriteGoodsImagesUrl}}{{:: favoriteGood.good ? favoriteGood.good.codeGood : \'undefined\'}}.png" fallback-image="" fallback-title="Изображение отсутствует" alt="">\r\n </div>\r\n <p ng-if=":: !favoriteGood.good || favoriteGood.good.id === 0">\r\n {{\'favoriteGoods.noFavoriteGood\' | translate}}\r\n </p>\r\n <p ng-if=":: favoriteGood.good && favoriteGood.good.id !== 0">{{:: favoriteGood.good.name}}</p>\r\n <button class="lmx-btn lmx-change-favorite-good-btn" ng-click="changeGood(favoriteGood)" ng-if=":: favoriteGood.allowChange" type="button">\r\n {{\'favoriteGoods.actions.edit\' | translate}}\r\n </button>\r\n <small>\r\n <p class="lmx-favorite-goods-already-changed" ng-if=":: !favoriteGood.allowChange">\r\n {{\'favoriteGoods.alreadyChanged\' | translate}}\r\n </p>\r\n </small>\r\n</div>\r\n'),n.put("app/directives/favoriteGoods/favoriteGoods.html",'<div class="lmx-container lmx-favorite-goods" ng-class="{\'lmx-empty\': !inProgress && !favoriteGoods}">\r\n <section>\r\n <h2>{{\'favoriteGoods.title\' | translate}}</h2>\r\n <div loader="inProgress">\r\n <div ng-if="!inProgress">\r\n <div>\r\n <p>{{\'favoriteGoods.info.description\' | translate}}.</p>\r\n <p>\r\n {{\'favoriteGoods.info.limitation.part1\' | translate}}\r\n <a href="#offers">{{\'favoriteGoods.info.limitation.part2\' | translate}}</a>.\r\n </p>\r\n </div>\r\n <div class="lmx-favorite-goods-list">\r\n <p ng-if="!(favoriteGoods && favoriteGoods.goods && favoriteGoods.goods.length)">\r\n {{\'favoriteGoods.favoriteGoodsEmpty\' | translate}}\r\n </p>\r\n <favorite-good favorite-good="favoriteGoodsItem" change-good="changeGood" ng-repeat="favoriteGoodsItem in favoriteGoods.goods" loader="goodsInProgres_{{:: favoriteGoodsItem.position}}"></favorite-good>\r\n </div>\r\n </div>\r\n </div>\r\n </section>\r\n</div>\r\n'),n.put("app/directives/favoriteGoods/modal/goodsOrCategory/goodsOrCategory.html",'<ul class="lmx-goods-or-category-item">\r\n <li ng-if=":: isCategory" class="lmx-category-item-li">\r\n <div>\r\n <div class="lmx-category-item">\r\n <p class="material-icons">folder</p>\r\n <p class="lmx-category-item-name" ng-click="changeVisibilityCategoryList()">\r\n {{:: goodsOrCategory.name}}\r\n </p>\r\n </div>\r\n <div ng-if=":: !inProgress">\r\n <goods-or-category ng-show="isShow" goods-group-id="goodsGroupId" goods-or-category="item" ng-repeat="item in nodeItems track by item.id"></goods-or-category>\r\n </div>\r\n <inline-loader>inProgress</inline-loader>\r\n </div>\r\n </li>\r\n <li ng-if=":: !isCategory" class="lmx-good-item-li">\r\n <p ng-click="selectNewFavoriteGood()" class="lmx-good-item">\r\n {{:: goodsOrCategory.name}}\r\n </p>\r\n </li>\r\n</ul>\r\n'),n.put("app/directives/favoriteGoods/modal/modalSelectNewFavoriteGood.html",'<div class="modal-content-favorite-goods">\r\n <div class="lmx-modal-closer" ng-click="cancel()"></div>\r\n <div loader="inProgress" class="lmx-modal-favorite-goods-container">\r\n <div ng-if="!inProgress" class="lmx-modal-favorite-goods-content">\r\n <div class="modal-header">\r\n <h2>{{\'favoriteGoods.modal.selectGood\' | translate}}</h2>\r\n </div>\r\n <div class="lmx-content lmx-select-new-favorite-good">\r\n <div class="lmx-categories-list">\r\n <goods-or-category goods-group-id="goodsGroupId" goods-or-category="goodsOrCategory" ng-repeat="goodsOrCategory in categories track by goodsOrCategory.id"></goods-or-category>\r\n </div>\r\n <button class="lmx-btn lmx-close-modal-btn" ng-click="cancel()" type="button">\r\n {{\'favoriteGoods.modal.close\' | translate}}\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n'),n.put("app/directives/feedback/feedback.html",'<div class="lmx-container lmx-feedback">\r\n <section>\r\n <h2>{{\'feedback.title\' | translate}}</h2>\r\n <lmx-notifications area="feedback"></lmx-notifications>\r\n\r\n <div loader="inProgress && messages === undefined">\r\n <div ng-show="!inProgress || messages !== undefined">\r\n <div class="lmx-hint">\r\n <p>{{\'feedback.askQuestion\' | translate}}:</p>\r\n </div>\r\n\r\n <form novalidate="" name="feedbackForm" ng-submit="feedbackForm.$valid && send(feedbackForm)">\r\n <form-group>\r\n <textarea ng-disabled="sendInProgress" id="lmx-msgTextarea" name="msgTextarea" ng-model="messageModel.text" placeholder="{{\'feedback.typeText\' | translate}}" required="">\r\n </textarea>\r\n </form-group>\r\n\r\n <inline-loader line="">sendInProgress</inline-loader>\r\n\r\n <div class="lmx-file-input-and-submitter lmx-clearfix lmx-margin-bottom" ng-if="!sendInProgress">\r\n <file-input ng-model="messageModel.attachment" class="lmx-left"></file-input>\r\n <button type="submit" class="lmx-right lmx-row">\r\n {{\'buttons.send\' | translate}}\r\n </button>\r\n </div>\r\n </form>\r\n\r\n <div class="lmx-message-history" loader="sendInProgress || inProgress">\r\n <lmx-scroller>\r\n <div class="lmx-chat-message-line lmx-clearfix" ng-repeat="item in messages track by item.message.id">\r\n <div ng-class="{\'lmx-outcoming\': item.isUserMessage}" class="lmx-chat-message">\r\n <div class="lmx-from">\r\n {{\'feedback.\' + (item.isUserMessage ? \'you\' : \'operator\') |\r\n translate}}\r\n </div>\r\n <div class="lmx-text">{{::item.message.message}}</div>\r\n <div class="lmx-file-name" ng-if="item.message.fileName">\r\n {{\'feedback.file\' | translate}}: {{::item.message.fileName}}\r\n </div>\r\n <div class="date">\r\n {{::item.message.dateTime | toUTC | shortDateTime}}\r\n </div>\r\n </div>\r\n </div>\r\n </lmx-scroller>\r\n </div>\r\n </div>\r\n </div>\r\n </section>\r\n</div>\r\n'),n.put("app/directives/fileInput/fileInput.html",'<div class="lmx-file-input">\r\n <form-group>\r\n <inline-loader>loader</inline-loader>\r\n <input type="file" ng-model="attachment.fileInfo" id="lmx-file-input" ng-attr-name="{{inputName}}" base-sixty-four-input="" maxsize="5120" do-not-parse-if-oversize="" onloadstart="onFileLoadStart" onerror="onFileLoadError" onload="onFileLoadSuccess">\r\n <label for="lmx-file-input" ng-switch="loadError.value" ng-hide="loader" ng-click="clearAttachment(); loadError.value = false;">\r\n <a>{{\'buttons.attachFile\' | translate}}</a>\r\n <span class="lmx-file-input-span"></span>\r\n <span ng-switch-when="false" ng-if="attachment.fileInfo" class="lmx-attachment">\r\n <span class="lmx-attachment-name" ng-attr-title="{{attachment.fileInfo.filename}}">{{attachment.fileInfo.filename}}</span>\r\n <span ng-click="clearAttachment($event)" class="lmx-attachment-remove glyphicon glyphicon-remove"></span>\r\n </span>\r\n <span ng-switch-when="true" class="lmx-attachment-error">{{loadError.text || (\'file.error\' | translate)}}</span>\r\n </label>\r\n </form-group>\r\n</div>\r\n'),n.put("app/directives/formGroup/formGroupTemplate.html",'<div class="lmx-form-group lmx-clearfix lmx-row" ng-class="{\'lmx-has-error\': form.$submitted && model.$invalid}">\r\n <div ng-if="labelText !== undefined" class="lmx-label-container">\r\n <label class="lmx-form-group-label lmx-{{:: lmx-labelAlign+\'align\'}}" for="{{itemId}}">{{labelText}}</label>\r\n </div>\r\n <div class="lmx-input-container">\r\n <div><ng-transclude></ng-transclude></div>\r\n <div class="lmx-help-block" ng-if="form.$submitted">\r\n <div class="lmx-help-block__error" ng-if="model.$error.validationErrors" ng-repeat="error in model.$error.validationErrors">\r\n <div>{{error}}</div>\r\n </div>\r\n <div class="lmx-help-block__error" ng-if="!model.$error.validationErrors" ng-repeat="(error, value) in model.$error">\r\n <div>{{errorMessage(error, model.$viewValue)}}</div>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n'),n.put("app/directives/history/history.html",'<div class="lmx-container lmx-history">\r\n <section>\r\n <h2 ng-if=":: !isPreview">{{\'history.title\' | translate}}</h2>\r\n <div loader="history === undefined">\r\n <div ng-show=":: history">\r\n <div ng-show=":: !isPreview" class="lmx-history-filters lmx-clearfix lmx-margin-bottom">\r\n <div class="date-filters">\r\n <div class="date-filter lmx-since-date-filter">\r\n <span class="lmx-pretext">{{\'history.fromDate\' | translate}}</span>\r\n <date-picker ng-model="fromDate" ng-change="reloadHistory()">\r\n </date-picker>\r\n </div>\r\n <div class="date-filter lmx-to-date-filter">\r\n <span class="lmx-pretext">{{\'history.toDate\' | translate}}</span>\r\n <date-picker ng-model="toDate" ng-change="reloadHistory()">\r\n </date-picker>\r\n </div>\r\n </div>\r\n <div class="lmx-card-filter">\r\n <inline-loader>cardsInProgress</inline-loader>\r\n <div ng-hide="cardsInProgress">\r\n <select ng-model="selectedCard" ng-change="reloadHistory()" id="lmx-cardFilter" name="cardFilter">\r\n <option ng-value="0">{{\'history.allCards\' | translate}}</option>\r\n <option ng-repeat="card in cards" ng-value="card.id">{{:: card.number | charsDivide: 4}}</option>\r\n </select>\r\n </div>\r\n </div>\r\n <div class="lmx-reset-filters">\r\n <a ng-click="resetFilters()" class="lmx-pseudolink" href="">{{\'history.resetFilters\' | translate}}</a>\r\n </div>\r\n </div>\r\n <lmx-tabs ng-if="balanceChangeHistory" list="tabs" ng-model="selectedTab.value" view-field="name">\r\n </lmx-tabs>\r\n <div ng-show="!balanceChangeHistory || selectedTab.value === tabs.operations">\r\n <div class="lmx-history-table" ng-show="history.allCount || inProgress">\r\n <div class="lmx-operations-list lmx-margin-bottom" loader="inProgress && (isPaginated || isReload)">\r\n <div ng-class="{\'lmx-loading\': inProgress}" ng-hide="inProgress && isReload">\r\n <table ng-if="history.rows.length">\r\n <thead>\r\n <tr>\r\n <th>{{\'history.date\' | translate}}</th>\r\n <th>{{\'history.cardNumber\' | translate}}</th>\r\n <th>{{\'history.description\' | translate}}</th>\r\n <th>{{\'history.operation\' | translate}}</th>\r\n <th>{{\'history.amount\' | translate}}</th>\r\n <th></th>\r\n </tr>\r\n </thead>\r\n <tbody ng-repeat="item in history.rows track by item.id" class-toggle-click="cheque-opened" ng-class="::{\'lmx-empty-cheque\': !item.data.chequeItems.length && !item.data.chequeAdditionalAttributes.length}">\r\n <tr class="lmx-operation-info">\r\n <td class="date-time" ng-attr-title="{{:: item.dateTime | toUTCTemporarySolution | shortDateTime}}">\r\n {{:: item.dateTime | toUTCTemporarySolution |\r\n shortDateTime}}\r\n </td>\r\n <td class="lmx-identity" ng-attr-title="{{:: item.identity ? (\'**** \' + (item.identity | lastCount: 4)) : undefined}}">\r\n <span ng-if="::item.identity">****\r\n <b>{{:: item.identity | lastCount: 4 }}</b></span>\r\n </td>\r\n <td class="lmx-description" ng-attr-title="{{:: item.description}}">\r\n <img ng-if=":: item.logoSquareUrl" ng-src="{{:: item.logoSquareUrl}}" class="lmx-logo-square" fallback-image="" fallback-title="{{\'imageNotFound\' | translate}}" alt="">\r\n <span class="lmx-description-text">{{:: item.description}}</span>\r\n </td>\r\n <td class="lmx-withdraws lmx-text">\r\n <div ng-if=":: item.data.withdraws.length" ng-repeat="wdrw in item.data.withdraws" ng-attr-title="{{\'history.gift\' + (item.data.isRefund ? \'Refund\' : \'\' ) + \'.withdraw\' | translate}}" class="lmx-text-overflow-ellipsis">\r\n {{\'history.gift\' + (item.data.isRefund ?\r\n \'Refund\' : \'\' ) + \'.withdraw\' | translate}}\r\n </div>\r\n <div ng-if=":: item.data.rewards.length" ng-repeat="(type, values) in item.rewardsResult">\r\n <div ng-repeat="(currency, value) in values" ng-attr-title="{{\'history.gift\' + (item.data.isRefund ? \'Refund.\' : \'.\') + (type | lowerCamelCase) | translate}}" class="lmx-text-overflow-ellipsis">\r\n {{\'history.gift\' + (item.data.isRefund ?\r\n \'Refund.\' : \'.\') + (type | lowerCamelCase) |\r\n translate}}\r\n </div>\r\n </div>\r\n <div ng-if=":: item.type == \'RewardData\'" ng-attr-title="{{\'history.rewardData.\' + (item.data.rewardType | lowerCamelCase) | translate}}" class="lmx-text-overflow-ellipsis">\r\n {{\'history.rewardData.\' + (item.data.rewardType\r\n | lowerCamelCase) | translate}}\r\n </div>\r\n <div ng-if=":: item.type == \'WithdrawData\'" ng-attr-title="{{\'history.withdrawData.\' + (item.data.withdrawType | lowerCamelCase) | translate}}" class="lmx-text-overflow-ellipsis">\r\n {{\'history.withdrawData.\' +\r\n (item.data.withdrawType | lowerCamelCase) |\r\n translate}}\r\n </div>\r\n </td>\r\n <td class="lmx-withdraws lmx-amount">\r\n <div ng-if=":: item.data.withdraws.length" ng-repeat="wdrw in item.data.withdraws" ng-attr-title="{{:: (item.data.isRefund ? wdrw.amount.amount * -1 : wdrw.amount.amount) | number: 2}} {{:: wdrw.amount.currency }}" class="lmx-text-overflow-ellipsis">\r\n {{:: (item.data.isRefund ? wdrw.amount.amount *\r\n -1 : wdrw.amount.amount) | number: 2}} {{::\r\n wdrw.amount.currency }}\r\n </div>\r\n <div ng-if=":: item.data.rewards.length" ng-repeat="(type, values) in item.rewardsResult">\r\n <div ng-repeat="(currency, value) in values" ng-attr-title="{{:: (item.data.isRefund ? value * -1 : value) | number: 2}} {{:: currency }}" class="lmx-text-overflow-ellipsis">\r\n {{:: (item.data.isRefund ? value * -1 :\r\n value) | number: 2}} {{:: currency }}\r\n </div>\r\n </div>\r\n <div ng-if=":: item.type == \'RewardData\' || item.type == \'WithdrawData\'" ng-attr-title="{{:: (item.data.isRefund ? item.data.amount.amount * -1 : item.data.amount.amount) | number: 2}} {{:: item.data.amount.currency }}" class="lmx-text-overflow-ellipsis">\r\n {{:: (item.data.isRefund ?\r\n item.data.amount.amount * -1 :\r\n item.data.amount.amount) | number: 2}} {{::\r\n item.data.amount.currency }}\r\n </div>\r\n </td>\r\n <td class="lmx-cheque-expander"></td>\r\n </tr>\r\n <tr class="lmx-cheque-info" ng-if="item.data.chequeItems.length">\r\n <td colspan="6">\r\n <div class="lmx-cheque-content">\r\n <div class="lmx-cheque-line" ng-repeat="chequeItem in item.data.chequeItems">\r\n <span class="lmx-cheque-item">{{::chequeItem.description |\r\n nbspSpaces}}</span>\r\n <span class="lmx-cheque-count">{{::chequeItem.count}}\r\n <span ng-if=":: chequeItem.unit" class="lmx-cheque-unit">{{:: chequeItem.unit}}</span></span>\r\n </div>\r\n <div class="lmx-cheque-total">\r\n {{::item.data.amount.amount | number: 2}}\r\n {{:: item.data.amount.currency }}\r\n </div>\r\n </div>\r\n </td>\r\n </tr>\r\n <tr class="lmx-cheque-info" ng-if="item.data.chequeAdditionalAttributes && item.data.chequeAdditionalAttributes.length">\r\n <td colspan="6" class="lmx-cheque-content">\r\n <h4>{{ \'history.eCheque\' | translate }}:</h4>\r\n <div ng-repeat="attribute in item.data.chequeAdditionalAttributes">\r\n <a ng-href="{{ attribute.value }}" target="_blank">\r\n {{ attribute.stringValue}}\r\n </a>\r\n </div>\r\n </td>\r\n </tr>\r\n </tbody>\r\n </table>\r\n </div>\r\n </div>\r\n <div ng-show=":: !isPreview" ng-switch=":: !!isPaginated">\r\n <uib-pagination ng-switch-when="true" ng-show="!isReload && history.allCount > onPage" total-items="history.allCount" ng-model="$parent.currentPage" max-size="4" items-per-page="{{:: onPage}}" class="lmx-pagination" boundary-links="true" boundary-link-numbers="true" direction-links="false" force-ellipses="true" first-text="<<" last-text=">>" ng-change="paginationChange()"></uib-pagination>\r\n <div ng-switch-when="false">\r\n <a class="lmx-pseudolink lmx-right" ng-if="!inProgress && (from + onPage < history.allCount)" ng-click="increaseFrom()" href="">{{\'history.showMore\' | translate}}</a>\r\n <inline-loader line="">inProgress && !isReload</inline-loader>\r\n </div>\r\n </div>\r\n <a ng-if=":: isPreview" href="{{:: historyUrl}}" class="lmx-pseudolink">{{\'history.goToFullHistory\' | translate}}</a>\r\n </div>\r\n <div class="lmx-history-not-found" ng-if="!history.allCount && !inProgress">\r\n {{\'history.notFound\' | translate}}\r\n </div>\r\n <a ng-if="balanceChangeHistory && !history.allCount && !inProgress && !balanceChangesIsEmpty" href="" ng-click="changeTab(tabs.balanceChanges)">{{\'history.showBalanceChange\' | translate}}</a>\r\n </div>\r\n <div ng-if="balanceChangeHistory" ng-show="selectedTab.value === tabs.balanceChanges">\r\n <lmx-balance-changes from-date="fromDate" to-date="toDate" card-id="selectedCard"></lmx-balance-changes>\r\n <a ng-if="balanceChangeHistory && history.allCount && !inProgress && balanceChangesIsEmpty" href="" ng-click="changeTab(tabs.operations)">{{\'history.showOperations\' | translate}}</a>\r\n </div>\r\n </div>\r\n </div>\r\n </section>\r\n</div>\r\n'),9252 n.put("app/directives/cards/modal/modalBlockStateChange.html",'<div class="lmx-block-state-change-modal">\r\n <div class="modal-header">\r\n <h2>\r\n {{\'cards.blockCardModal.\' + (isBlocked ? \'unblockTitle\' : \'blockTitle\') | translate}}\r\n </h2>\r\n </div>\r\n <lmx-notifications area="cardModal"></lmx-notifications>\r\n <form novalidate="" name="blockCardForm" ng-submit="blockCardForm.$valid && blockStateChange()">\r\n <div class="modal-content-wrapper">\r\n <div class="modal-body">\r\n <form-group label-text="{{\'cards.blockCardModal.password\' | translate}}">\r\n <input type="password" ng-model="model.password" ng-disabled="inProgress" id="lmx-userPassword" name="userPassword" autocomplete="off" required="" autofocus="">\r\n </form-group>\r\n </div>\r\n <div class="modal-footer lmx-btn-container">\r\n <div ng-hide="inProgress">\r\n <button class="lmx-btn-cancel" ng-click="cancel()" type="button">\r\n {{\'buttons.cancel\' | translate}}\r\n </button>\r\n <button type="submit">\r\n {{isBlocked ? \'cards.actions.unblock\' : \'cards.actions.block\' | translate}}\r\n </button>\r\n </div>\r\n <inline-loader>inProgress</inline-loader>\r\n </div>\r\n </div>\r\n </form>\r\n</div>\r\n'),n.put("app/directives/cards/modal/modalGraphicalCodes.html",'<div class="lmx-card-codes-modal">\r\n <div class="modal-body">\r\n <section ng-if=":: displayBarCode" class="lmx-bar-code lmx-margin-bottom">\r\n <h2>{{\'cards.graphicalCodesModal.barCode\' | translate}}</h2>\r\n <angular-barcode ng-model="card.barCode" bc-type="svg"></angular-barcode>\r\n </section>\r\n\r\n <section ng-if=":: displayQrCode" class="lmx-qr-code">\r\n <h2>{{\'cards.graphicalCodesModal.qrCode\' | translate}}</h2>\r\n <qrcode data="{{:: card.number}}" size="222"></qrcode>\r\n </section>\r\n </div>\r\n\r\n <div class="modal-footer lmx-btn-container">\r\n <button type="button" ng-click="close()">{{\'buttons.close\' | translate}}</button>\r\n </div>\r\n</div>\r\n'),n.put("app/directives/cards/modal/modalReplaceCard.html",'<div class="lmx-replace-card-modal">\r\n <div class="modal-header">\r\n <h2>{{\'cards.replaceCardModal.title\' | translate}}</h2>\r\n </div>\r\n <lmx-notifications area="cardModal"></lmx-notifications>\r\n <form novalidate="" name="replaceCardForm" ng-submit="replaceCardForm.$valid && replaceCard()">\r\n <div class="modal-content-wrapper">\r\n <div class="modal-body">\r\n <form-group label-text="{{\'cards.replaceCardModal.cardNumber\' | translate}}">\r\n <input type="text" ng-model="model.cardNumber" ng-disabled="inProgress" id="lmx-cardNumber" name="cardNumber" required="" autofocus="">\r\n </form-group>\r\n <form-group ng-if="cvcCodeCardsRegistration" label-text="{{\'cards.replaceCardModal.cvcCode\' | translate}}">\r\n <input type="number" ng-model="model.cvcCode" ng-disabled="inProgress" id="lmx-cvcCode" name="cvcCode">\r\n </form-group>\r\n <form-group label-text="{{\'cards.replaceCardModal.password\' | translate}}">\r\n <input type="password" ng-model="model.password" ng-disabled="inProgress" id="lmx-password" name="password" autocomplete="off" required="">\r\n </form-group>\r\n </div>\r\n <div class="modal-footer lmx-btn-container">\r\n <div ng-hide="inProgress">\r\n <button class="lmx-btn-cancel" ng-click="cancel()" type="button">\r\n {{\'buttons.cancel\' | translate}}\r\n </button>\r\n <button type="submit">\r\n {{\'cards.actions.replace\' | translate}}\r\n </button>\r\n </div>\r\n <inline-loader>inProgress</inline-loader>\r\n </div>\r\n </div>\r\n </form>\r\n</div>\r\n'),n.put("app/directives/cards/modal/modalSetCard.html",'<div class="lmx-set-card-modal">\r\n <div class="modal-header">\r\n <h2>{{\'cards.setCardModal.title\' | translate}}</h2>\r\n </div>\r\n\r\n <lmx-notifications area="cardModal"></lmx-notifications>\r\n\r\n <form novalidate="" name="setCardForm" ng-submit="setCardForm.$valid && setCard()">\r\n <div class="modal-content-wrapper">\r\n <div class="modal-body">\r\n <form-group label-text="{{\'cards.setCardModal.cardNumber\' | translate}}">\r\n <input type="text" ng-model="model.cardNumber" ng-disabled="inProgress" id="lmx-cardNumber" name="cardNumber" required="" autofocus="">\r\n </form-group>\r\n <form-group ng-if="cvcCodeCardsRegistration" label-text="{{\'registration.cardStep.cvcCode\' | translate}}">\r\n <input type="number" ng-model="model.cvcCode" ng-disabled="inProgress" id="lmx-cvcCode" name="cvcCode">\r\n </form-group>\r\n </div>\r\n <div class="modal-footer lmx-btn-container">\r\n <div ng-hide="inProgress">\r\n <button class="lmx-btn-cancel" ng-click="cancel()" type="button">\r\n {{\'buttons.cancel\' | translate}}\r\n </button>\r\n <button type="submit">\r\n {{\'cards.actions.set\' | translate}}\r\n </button>\r\n </div>\r\n <inline-loader>inProgress</inline-loader>\r\n </div>\r\n </div>\r\n </form>\r\n</div>\r\n'),n.put("app/directives/coupon/coupon.html",'<div class="lmx-card" style="width: 400px; height: 400px;">\r\n <div class="lmx-card-image">\r\n <img ng-src="{{::coupon.imageUri || \'undefined\'}}" fallback-image="" fallback-title="{{\'coupons.imageNotFound\' | translate}}" alt="" style="height: 250px; padding: 10px">\r\n </div>\r\n <div class="lmx-card-content">\r\n <span class="lmx-card-title">{{coupon.name}}</span>\r\n <span><b>{{\'coupons.price\' | translate}}:</b> {{coupon.price}} RUB</span>\r\n </div>\r\n <div class="lmx-card-reveal">\r\n <span class="lmx-card-title"><span class="glyphicon glyphicon-remove"></span>{{coupon.name}}</span>\r\n <p>\r\n <span><b>{{\'coupons.description\' | translate}}:</b>{{:: couponInfo.description ||\r\n (\'coupons.noDescription\' | translate)}}</span>\r\n </p>\r\n <button ng-if=":: loggedIn" type="button" ng-click="openBuyCouponModal(coupon)">\r\n <div>\r\n {{\'coupons.buy\' | translate}}\r\n <span class="lmx-price">{{ coupon.price | zeroFill: 2 }}</span>\r\n </div>\r\n </button>\r\n <button ng-if=":: !loggedIn" type="button" ng-click="goToLogin()">\r\n <div>{{\'coupons.login\' | translate}}</div>\r\n </button>\r\n </div>\r\n</div>\r\n'),n.put("app/directives/coupons/coupons.html",'<div class="lmx-container lmx-coupons">\r\n <h2>{{\'coupons.title\' | translate}}</h2>\r\n <div loader="inProgress">\r\n <div class="lmx-coupon lmx-card" ng-repeat="coupon in coupons track by coupon.id" ng-click="openCouponInfo(coupon)">\r\n <div class="lmx-card-code">\r\n <div class="lmx-image-block">\r\n <img ng-src="data:{{::coupon.imageFile.mimeType}};charset=utf-8;base64, {{::coupon.imageFile.content}}" fallback-image="" fallback-title="{{\'imageNotFound\' | translate}}" alt="" style="height: 100px; padding: 10px">\r\n </div>\r\n </div>\r\n <div class="lmx-card-content">\r\n <div class="lmx-coupon-details">\r\n <div class="lmx-coupon-title">\r\n <h2>{{ coupon.emissionTitle }}</h2>\r\n </div>\r\n <div class="lmx-coupon-description">{{ coupon.shortDescription}}</div>\r\n <div class="lmx-coupon-content">\r\n <div class="lmx-coupon-code">\r\n <qrcode data="{{:: coupon.code }}" size="100"></qrcode>\r\n </div>\r\n <div class="lmx-coupon-period">\r\n <span>Номер купона: {{ coupon.code }}</span>\r\n\r\n <div ng-if="coupon.expiryDate && offerProceed(coupon.activationDate) && !lessThanWeek(coupon.expiryDate)" class="lmx-rating-container">\r\n <span ng-if="offerStartedToday(coupon.activationDate)">\r\n {{ \'coupons.expirationDate\' | translate}}: {{:: coupon.expiryDate | toUTC | shortDate }}\r\n </span>\r\n <span ng-if="!offerStartedToday(coupon.activationDate)">\r\n {{ \'coupons.offerStartFrom\' | translate }} {{:: coupon.activationDate | toUTC | shortDateTime }}\r\n {{ \'dateRange.to\' | translate }}\r\n {{:: coupon.expiryDate | toUTC | shortDate }}\r\n </span>\r\n </div>\r\n\r\n <div ng-if="coupon.expiryDate && lessThanWeek(coupon.expiryDate) && offerProceed(coupon.activationDate)">\r\n {{ \'coupons.offerPeriod.left\' | translate }}:\r\n {{ leftDays }} {{\'coupons.offerPeriod.leftDays\' | translate }}\r\n {{ leftHours }} {{\'coupons.offerPeriod.leftHours\' | translate }}\r\n </div>\r\n\r\n <div ng-if="coupon.expiryDate && !offerProceed(coupon.activationDate)">\r\n {{ \'coupons.offerStartFrom\' | translate }}\r\n {{ coupon.activationDate | toUTC | shortDate }}\r\n {{ \'dateRange.to\' | translate }}\r\n {{ coupon.expiryDate | toUTC | shortDate }}\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n'),n.put("app/directives/coupons/modal/couponViewModal.html",'<div class="lmx-coupon-modal">\r\n <div class="modal-header">\r\n <div class="lmx-modal-closer" ng-click="cancel()"></div>\r\n <h2>{{:: coupon.emissionTitle }}</h2>\r\n </div>\r\n\r\n <div class="modal-content-wrapper">\r\n <div class="lmx-coupon-modal">\r\n <div class="modal-body">\r\n <qrcode data="{{:: coupon.code }}" href="{{ coupon.qrContent }}" size="200"></qrcode>\r\n\r\n <div ng-if="coupon.expiryDate && offerProceed(coupon.activationDate) && !lessThanWeek(coupon.expiryDate)" class="lmx-rating-container">\r\n <span ng-if="offerStartedToday(coupon.activationDate)">\r\n {{ \'coupons.expirationDate\' | translate}}: {{:: coupon.expiryDate | toUTC | shortDate }}\r\n </span>\r\n <span ng-if="!offerStartedToday(coupon.activationDate)">\r\n {{ \'coupons.offerStartFrom\' | translate }} {{:: coupon.activationDate | toUTC | shortDateTime }}\r\n {{ \'dateRange.to\' | translate }}\r\n {{:: coupon.expiryDate | toUTC | shortDate }}\r\n </span>\r\n </div>\r\n\r\n <div ng-if="coupon.expiryDate && lessThanWeek(coupon.expiryDate) && offerProceed(coupon.activationDate)">\r\n {{ \'coupons.offerPeriod.left\' | translate }}:\r\n {{ leftDays }} {{\'coupons.offerPeriod.leftDays\' | translate}}\r\n {{ leftHours }} {{\'coupons.offerPeriod.leftHours\' | translate}}\r\n <div class="lmx-bar">\r\n <span class="lmx-left-time" ng-style="{ width: expiryTimePercent + \'%\'}"></span>\r\n </div>\r\n </div>\r\n\r\n <div ng-if="coupon.expiryDate && !offerProceed(coupon.activationDate)">\r\n {{ \'coupons.offerStartFrom\' | translate }}\r\n {{ coupon.activationDate | toUTC | shortDate }}\r\n {{ \'dateRange.to\' | translate }}\r\n {{ coupon.expiryDate | toUTC | shortDate }}\r\n </div>\r\n\r\n <div class="lmx-coupon-description">\r\n {{ coupon.description }}\r\n </div>\r\n\r\n <div class="lmx-coupon-hint">\r\n {{ \'coupons.hint\' | translate }}\r\n </div>\r\n </div>\r\n <div class="modal-footer lmx-btn-container">\r\n <button type="button" ng-click="cancel()">{{\'buttons.close\' | translate}}</button>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n'),n.put("app/directives/customStatus/customUserStatus.html",'<div class="lmx-lmx-b-statuses" loader="statusLoader" style="margin-top: 20px">\r\n <div ng-if="!statusLoader && showStatus && !isUAZstatusSystem">\r\n <h3 class="lmx-lmx-b-statuses__header">Мои достижения</h3>\r\n <div class="lmx-lmx-b-statuses__container">\r\n <div class="lmx-lmx-b-status-block" ng-repeat="status in currentStatusSystem.statuses track by $index">\r\n <div class="lmx-lmx-b-status" ng-class="{\'lmx-lmx-b-status--active\': $index === currentStatusIndex}">\r\n <h3 class="lmx-lmx-b-status__head">Уровень <span>{{ $index + 1 }}</span></h3>\r\n <div class="lmx-lmx-b-status__block">\r\n <div class="lmx-lmx-b-status-info">\r\n <p class="lmx-lmx-b-status-info__text">\r\n {{ status.description[0].text }}\r\n <span class="lmx-lmx-b-status-info__value">{{ status.description[0].value }}</span>\r\n </p>\r\n <p class="lmx-lmx-b-status-info__text">\r\n {{ status.description[1].text }}\r\n <span class="lmx-lmx-b-status-info__value">{{ status.description[1].value }}</span>\r\n </p>\r\n </div>\r\n <div class="lmx-lmx-b-status-info">\r\n <div class="lmx-lmx-b-status-info__text">\r\n <div>\r\n <h4>{{ status.description[2].text }}</h4>\r\n </div>\r\n <span class="lmx-lmx-b-status-info__value">{{ status.description[2].value }}</span>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div class="lmx-lmx-b-days" ng-if="!statusLoader && !isUAZstatusSystem">\r\n <div class="lmx-lmx-b-days__info">\r\n <div class="lmx-lmx-b-days__hint" ng-class="{\'lmx-lmx-b-days__hint--show\': showHint}">\r\n <h4>\r\n Покупай чаще в супермаркетах "Гулливер" - получай больше выгоды! За каждый 5\r\n день с покупкой в текущем месяце получай купон на сумму от 50 до 100 руб на\r\n следующую покупку!\r\n </h4>\r\n </div>\r\n <h4 style="color: #757F8C" ng-mouseover="toggleHint()" ng-mouseleave="toggleHint()">\r\n Акция "Дни с Гулливером"\r\n </h4>\r\n <div class="lmx-lmx-b-days__text" ng-if="counterStatus.currentValue >= purchases[purchases.length - 1]">\r\n Поздравляем! Вы получили максимальный купон! Так держать!\r\n </div>\r\n <div class="lmx-lmx-b-days__text" ng-if="counterStatus.currentValue < purchases[purchases.length - 1] && counterStatus.currentValue > 0">\r\n Совершите еще\r\n <span style="color: #F6822F">{{ purchasesLeft }} {{ nameCases[getCurrencyNameCase(purchasesLeft)]}}</span>\r\n в разные дни для получения купона на скидку {{ couponPreference[currentIndex + 1]\r\n }}₽\r\n </div>\r\n <!-- <div class="b-days__text" ng-if="counterStatus.currentValue <= 0">\r\n Необходимо совершить покупку\r\n </div> -->\r\n </div>\r\n <div class="lmx-lmx-b-rounds">\r\n <div class="lmx-lmx-b-rounds__round" ng-repeat="round in purchases track by $index">\r\n <div ng-bind-html="getRound(round)"></div>\r\n <!-- TODO: проверить смену цвета -->\r\n <div class="lmx-lmx-b-rounds__coupon" ng-class="::{\'lmx-lmx-b-rounds__coupon--active\': $index <= currentIndex + 1}">\r\n {{ couponPreference[$index] }}₽\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- UAZ status -->\r\n <!-- TODO: выпилить инлайн стили -->\r\n <div class="lmx-lmx-b-uaz-status" ng-if="isUAZstatusSystem && !statusLoader" style="display: flex; flex-direction: row;">\r\n <div ng-bind-html="UAZcircleHTML" style="width: 20%"></div>\r\n\r\n <div class="lmx-lmx-b-uaz-status__info lmx-lmx-b-status-info">\r\n <h3 class="lmx-lmx-b-status-info__head">{{ currentStatusSystem.currentStatus.name }}</h3>\r\n <div class="lmx-lmx-b-status-info__text" ng-repeat="prefer in currentStatusSystem.statuses[currentStatusIndex].description track by $index">\r\n <p>\r\n {{ prefer.text }}\r\n <span class="lmx-lmx-b-status-info__value">{{ prefer.value }}</span>\r\n </p>\r\n </div>\r\n\r\n <div class="lmx-lmx-b-status-info__result" ng-if="currentStatusIndex + 1 < currentStatusSystem.statuses.length">\r\n До статуса {{ currentStatusSystem.statuses[currentStatusIndex + 1].name }}: {{\r\n needPurchases }}P\r\n </div>\r\n\r\n <div class="lmx-lmx-b-status-info__result" ng-if="currentStatusIndex + 1 === currentStatusSystem.statuses.length">\r\n Поздравляем! Вы достигли максимального уровня! Продолжайте совершать покупки, чтобы\r\n сохранить 5 уровень в следующем месяце\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n'),n.put("app/directives/datePicker/datePickerView.html",'<span class="date-picker-wrap" outside-click="toggleCalendar($event, false)">\r\n <div class="toggler" ng-click="toggleCalendar($event)">\r\n <span class="glyphicon glyphicon-calendar"></span>\r\n </div>\r\n\r\n <input type="text" ng-class="\'lmx-\'+inputClass" datetime-picker="{{dateFormat}}" ng-model="model" ng-keyup="validateModel($event)" ng-model-options="modelOptions" datepicker-options="options" button-bar="{show:false}" is-open="isOpen" enable-time="false">\r\n</span>\r\n'),n.put("app/directives/dateTimePicker/datetimePickerView.html",'<span class="date-picker-wrap" outside-click="toggleCalendar($event, false)">\r\n <div class="toggler glyphicon glyphicon-calendar" ng-click="toggleCalendar($event)"></div>\r\n\r\n <input type="text" ng-if=":: timepickerOptions" ng-class="\'lmx-\'+inputClass" datetime-picker="{{dateFormat}}" ng-model="model" ng-keyup="checkModel($event)" ng-model-options="modelOptions" button-bar="buttonsOptions" initial-picker="date" re-open-default="date" datepicker-options="{showWeeks:false}" timepicker-options="timepickerOptions" is-open="isOpen">\r\n</span>\r\n'),n.put("app/directives/favoriteGoods/favoriteGood/favoriteGood.html",'<div class="lmx-favorite-goods-item">\r\n <div class="lmx-favorite-goods-item__image">\r\n <img ng-src="{{:: favoriteGoodsImagesUrl}}{{:: favoriteGood.good ? favoriteGood.good.codeGood : \'undefined\'}}.png" fallback-image="" fallback-title="Изображение отсутствует" alt="">\r\n </div>\r\n <p ng-if=":: !favoriteGood.good || favoriteGood.good.id === 0">\r\n {{\'favoriteGoods.noFavoriteGood\' | translate}}\r\n </p>\r\n <p ng-if=":: favoriteGood.good && favoriteGood.good.id !== 0">{{:: favoriteGood.good.name}}</p>\r\n <button class="lmx-btn lmx-change-favorite-good-btn" ng-click="changeGood(favoriteGood)" ng-if=":: favoriteGood.allowChange" type="button">\r\n {{\'favoriteGoods.actions.edit\' | translate}}\r\n </button>\r\n <small>\r\n <p class="lmx-favorite-goods-already-changed" ng-if=":: !favoriteGood.allowChange">\r\n {{\'favoriteGoods.alreadyChanged\' | translate}}\r\n </p>\r\n </small>\r\n</div>\r\n'),n.put("app/directives/favoriteGoods/favoriteGoods.html",'<div class="lmx-container lmx-favorite-goods" ng-class="{\'lmx-empty\': !inProgress && !favoriteGoods}">\r\n <section>\r\n <h2>{{\'favoriteGoods.title\' | translate}}</h2>\r\n <div loader="inProgress">\r\n <div ng-if="!inProgress">\r\n <div>\r\n <p>{{\'favoriteGoods.info.description\' | translate}}.</p>\r\n <p>\r\n {{\'favoriteGoods.info.limitation.part1\' | translate}}\r\n <a href="#offers">{{\'favoriteGoods.info.limitation.part2\' | translate}}</a>.\r\n </p>\r\n </div>\r\n <div class="lmx-favorite-goods-list">\r\n <p ng-if="!(favoriteGoods && favoriteGoods.goods && favoriteGoods.goods.length)">\r\n {{\'favoriteGoods.favoriteGoodsEmpty\' | translate}}\r\n </p>\r\n <favorite-good favorite-good="favoriteGoodsItem" change-good="changeGood" ng-repeat="favoriteGoodsItem in favoriteGoods.goods" loader="goodsInProgres_{{:: favoriteGoodsItem.position}}"></favorite-good>\r\n </div>\r\n </div>\r\n </div>\r\n </section>\r\n</div>\r\n'),n.put("app/directives/favoriteGoods/modal/goodsOrCategory/goodsOrCategory.html",'<ul class="lmx-goods-or-category-item">\r\n <li ng-if=":: isCategory" class="lmx-category-item-li">\r\n <div>\r\n <div class="lmx-category-item">\r\n <p class="material-icons">folder</p>\r\n <p class="lmx-category-item-name" ng-click="changeVisibilityCategoryList()">\r\n {{:: goodsOrCategory.name}}\r\n </p>\r\n </div>\r\n <div ng-if=":: !inProgress">\r\n <goods-or-category ng-show="isShow" goods-group-id="goodsGroupId" goods-or-category="item" ng-repeat="item in nodeItems track by item.id"></goods-or-category>\r\n </div>\r\n <inline-loader>inProgress</inline-loader>\r\n </div>\r\n </li>\r\n <li ng-if=":: !isCategory" class="lmx-good-item-li">\r\n <p ng-click="selectNewFavoriteGood()" class="lmx-good-item">\r\n {{:: goodsOrCategory.name}}\r\n </p>\r\n </li>\r\n</ul>\r\n'),n.put("app/directives/favoriteGoods/modal/modalSelectNewFavoriteGood.html",'<div class="modal-content-favorite-goods">\r\n <div class="lmx-modal-closer" ng-click="cancel()"></div>\r\n <div loader="inProgress" class="lmx-modal-favorite-goods-container">\r\n <div ng-if="!inProgress" class="lmx-modal-favorite-goods-content">\r\n <div class="modal-header">\r\n <h2>{{\'favoriteGoods.modal.selectGood\' | translate}}</h2>\r\n </div>\r\n <div class="lmx-content lmx-select-new-favorite-good">\r\n <div class="lmx-categories-list">\r\n <goods-or-category goods-group-id="goodsGroupId" goods-or-category="goodsOrCategory" ng-repeat="goodsOrCategory in categories track by goodsOrCategory.id"></goods-or-category>\r\n </div>\r\n <button class="lmx-btn lmx-close-modal-btn" ng-click="cancel()" type="button">\r\n {{\'favoriteGoods.modal.close\' | translate}}\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n'),n.put("app/directives/feedback/feedback.html",'<div class="lmx-container lmx-feedback">\r\n <section>\r\n <h2>{{\'feedback.title\' | translate}}</h2>\r\n <lmx-notifications area="feedback"></lmx-notifications>\r\n\r\n <div loader="inProgress && messages === undefined">\r\n <div ng-show="!inProgress || messages !== undefined">\r\n <div class="lmx-hint">\r\n <p>{{\'feedback.askQuestion\' | translate}}:</p>\r\n </div>\r\n\r\n <form novalidate="" name="feedbackForm" ng-submit="feedbackForm.$valid && send(feedbackForm)">\r\n <form-group>\r\n <textarea ng-disabled="sendInProgress" id="lmx-msgTextarea" name="msgTextarea" ng-model="messageModel.text" placeholder="{{\'feedback.typeText\' | translate}}" required="">\r\n </textarea>\r\n </form-group>\r\n\r\n <inline-loader line="">sendInProgress</inline-loader>\r\n\r\n <div class="lmx-file-input-and-submitter lmx-clearfix lmx-margin-bottom" ng-if="!sendInProgress">\r\n <file-input ng-model="messageModel.attachment" class="lmx-left"></file-input>\r\n <button type="submit" class="lmx-right lmx-row">\r\n {{\'buttons.send\' | translate}}\r\n </button>\r\n </div>\r\n </form>\r\n\r\n <div class="lmx-message-history" loader="sendInProgress || inProgress">\r\n <lmx-scroller>\r\n <div class="lmx-chat-message-line lmx-clearfix" ng-repeat="item in messages track by item.message.id">\r\n <div ng-class="{\'lmx-outcoming\': item.isUserMessage}" class="lmx-chat-message">\r\n <div class="lmx-from">\r\n {{\'feedback.\' + (item.isUserMessage ? \'you\' : \'operator\') |\r\n translate}}\r\n </div>\r\n <div class="lmx-text">{{::item.message.message}}</div>\r\n <div class="lmx-file-name" ng-if="item.message.fileName">\r\n {{\'feedback.file\' | translate}}: {{::item.message.fileName}}\r\n </div>\r\n <div class="date">\r\n {{::item.message.dateTime | toUTC | shortDateTime}}\r\n </div>\r\n </div>\r\n </div>\r\n </lmx-scroller>\r\n </div>\r\n </div>\r\n </div>\r\n </section>\r\n</div>\r\n'),n.put("app/directives/fileInput/fileInput.html",'<div class="lmx-file-input">\r\n <form-group>\r\n <inline-loader>loader</inline-loader>\r\n <input type="file" ng-model="attachment.fileInfo" id="lmx-file-input" ng-attr-name="{{inputName}}" base-sixty-four-input="" maxsize="5120" do-not-parse-if-oversize="" onloadstart="onFileLoadStart" onerror="onFileLoadError" onload="onFileLoadSuccess">\r\n <label for="lmx-file-input" ng-switch="loadError.value" ng-hide="loader" ng-click="clearAttachment(); loadError.value = false;">\r\n <a>{{\'buttons.attachFile\' | translate}}</a>\r\n <span class="lmx-file-input-span"></span>\r\n <span ng-switch-when="false" ng-if="attachment.fileInfo" class="lmx-attachment">\r\n <span class="lmx-attachment-name" ng-attr-title="{{attachment.fileInfo.filename}}">{{attachment.fileInfo.filename}}</span>\r\n <span ng-click="clearAttachment($event)" class="lmx-attachment-remove glyphicon glyphicon-remove"></span>\r\n </span>\r\n <span ng-switch-when="true" class="lmx-attachment-error">{{loadError.text || (\'file.error\' | translate)}}</span>\r\n </label>\r\n </form-group>\r\n</div>\r\n'),n.put("app/directives/formGroup/formGroupTemplate.html",'<div class="lmx-form-group lmx-clearfix lmx-row" ng-class="{\'lmx-has-error\': form.$submitted && model.$invalid}">\r\n <div ng-if="labelText !== undefined" class="lmx-label-container">\r\n <label class="lmx-form-group-label lmx-{{:: lmx-labelAlign+\'align\'}}" for="{{itemId}}">{{labelText}}</label>\r\n </div>\r\n <div class="lmx-input-container">\r\n <div><ng-transclude></ng-transclude></div>\r\n <div class="lmx-help-block" ng-if="form.$submitted">\r\n <div class="lmx-help-block__error" ng-if="model.$error.validationErrors" ng-repeat="error in model.$error.validationErrors">\r\n <div>{{error}}</div>\r\n </div>\r\n <div class="lmx-help-block__error" ng-if="!model.$error.validationErrors" ng-repeat="(error, value) in model.$error">\r\n <div>{{errorMessage(error, model.$viewValue)}}</div>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n'),n.put("app/directives/history/history.html",'<div class="lmx-container lmx-history">\r\n <section>\r\n <h2 ng-if=":: !isPreview">{{\'history.title\' | translate}}</h2>\r\n <div loader="history === undefined">\r\n <div ng-show=":: history">\r\n <div ng-show=":: !isPreview" class="lmx-history-filters lmx-clearfix lmx-margin-bottom">\r\n <div class="date-filters">\r\n <div class="date-filter lmx-since-date-filter">\r\n <span class="lmx-pretext">{{\'history.fromDate\' | translate}}</span>\r\n <date-picker ng-model="fromDate" ng-change="reloadHistory()">\r\n </date-picker>\r\n </div>\r\n <div class="date-filter lmx-to-date-filter">\r\n <span class="lmx-pretext">{{\'history.toDate\' | translate}}</span>\r\n <date-picker ng-model="toDate" ng-change="reloadHistory()">\r\n </date-picker>\r\n </div>\r\n </div>\r\n <div class="lmx-card-filter">\r\n <inline-loader>cardsInProgress</inline-loader>\r\n <div ng-hide="cardsInProgress">\r\n <select ng-model="selectedCard" ng-change="reloadHistory()" id="lmx-cardFilter" name="cardFilter">\r\n <option ng-value="0">{{\'history.allCards\' | translate}}</option>\r\n <option ng-repeat="card in cards" ng-value="card.id">{{:: card.number | charsDivide: 4}}</option>\r\n </select>\r\n </div>\r\n </div>\r\n <div class="lmx-reset-filters">\r\n <a ng-click="resetFilters()" class="lmx-pseudolink" href="">{{\'history.resetFilters\' | translate}}</a>\r\n </div>\r\n </div>\r\n <lmx-tabs ng-if="balanceChangeHistory" list="tabs" ng-model="selectedTab.value" view-field="name">\r\n </lmx-tabs>\r\n <div ng-show="!balanceChangeHistory || selectedTab.value === tabs.operations">\r\n <div class="lmx-history-table" ng-show="history.allCount || inProgress">\r\n <div class="lmx-operations-list lmx-margin-bottom" loader="inProgress && (isPaginated || isReload)">\r\n <div ng-class="{\'lmx-loading\': inProgress}" ng-hide="inProgress && isReload">\r\n <table ng-if="history.rows.length">\r\n <thead>\r\n <tr>\r\n <th>{{\'history.date\' | translate}}</th>\r\n <th>{{\'history.cardNumber\' | translate}}</th>\r\n <th>{{\'history.description\' | translate}}</th>\r\n <th>{{\'history.operation\' | translate}}</th>\r\n <th>{{\'history.amount\' | translate}}</th>\r\n <th></th>\r\n </tr>\r\n </thead>\r\n <tbody ng-repeat="item in history.rows track by item.id" class-toggle-click="cheque-opened" ng-class="::{\'lmx-empty-cheque\': !item.data.chequeItems.length && !item.data.chequeAdditionalAttributes.length}">\r\n <tr class="lmx-operation-info">\r\n <td class="date-time" ng-attr-title="{{:: item.dateTime | toUTCTemporarySolution | shortDateTime}}">\r\n {{:: item.dateTime | toUTCTemporarySolution |\r\n shortDateTime}}\r\n </td>\r\n <td class="lmx-identity" ng-attr-title="{{:: item.identity ? (\'**** \' + (item.identity | lastCount: 4)) : undefined}}">\r\n <span ng-if="::item.identity">****\r\n <b>{{:: item.identity | lastCount: 4 }}</b></span>\r\n </td>\r\n <td class="lmx-description" ng-attr-title="{{:: item.description}}">\r\n <img ng-if=":: item.logoSquareUrl" ng-src="{{:: item.logoSquareUrl}}" class="lmx-logo-square" fallback-image="" fallback-title="{{\'imageNotFound\' | translate}}" alt="">\r\n <span class="lmx-description-text">{{:: item.description}}</span>\r\n </td>\r\n <td class="lmx-withdraws lmx-text">\r\n <div ng-if=":: item.data.withdraws.length" ng-repeat="wdrw in item.data.withdraws" ng-attr-title="{{\'history.gift\' + (item.data.isRefund ? \'Refund\' : \'\' ) + \'.withdraw\' | translate}}" class="lmx-text-overflow-ellipsis">\r\n {{\'history.gift\' + (item.data.isRefund ?\r\n \'Refund\' : \'\' ) + \'.withdraw\' | translate}}\r\n </div>\r\n <div ng-if=":: item.data.rewards.length" ng-repeat="(type, values) in item.rewardsResult">\r\n <div ng-repeat="(currency, value) in values" ng-attr-title="{{\'history.gift\' + (item.data.isRefund ? \'Refund.\' : \'.\') + (type | lowerCamelCase) | translate}}" class="lmx-text-overflow-ellipsis">\r\n {{\'history.gift\' + (item.data.isRefund ?\r\n \'Refund.\' : \'.\') + (type | lowerCamelCase) |\r\n translate}}\r\n </div>\r\n </div>\r\n <div ng-if=":: item.type == \'RewardData\'" ng-attr-title="{{\'history.rewardData.\' + (item.data.rewardType | lowerCamelCase) | translate}}" class="lmx-text-overflow-ellipsis">\r\n {{\'history.rewardData.\' + (item.data.rewardType\r\n | lowerCamelCase) | translate}}\r\n </div>\r\n <div ng-if=":: item.type == \'WithdrawData\'" ng-attr-title="{{\'history.withdrawData.\' + (item.data.withdrawType | lowerCamelCase) | translate}}" class="lmx-text-overflow-ellipsis">\r\n {{\'history.withdrawData.\' +\r\n (item.data.withdrawType | lowerCamelCase) |\r\n translate}}\r\n </div>\r\n </td>\r\n <td class="lmx-withdraws lmx-amount">\r\n <div ng-if=":: item.data.withdraws.length" ng-repeat="wdrw in item.data.withdraws" ng-attr-title="{{:: (item.data.isRefund ? wdrw.amount.amount * -1 : wdrw.amount.amount) | number: 2}} {{:: wdrw.amount.currency }}" class="lmx-text-overflow-ellipsis">\r\n {{:: (item.data.isRefund ? wdrw.amount.amount *\r\n -1 : wdrw.amount.amount) | number: 2}} {{::\r\n wdrw.amount.currency }}\r\n </div>\r\n <div ng-if=":: item.data.rewards.length" ng-repeat="(type, values) in item.rewardsResult">\r\n <div ng-repeat="(currency, value) in values" ng-attr-title="{{:: (item.data.isRefund ? value * -1 : value) | number: 2}} {{:: currency }}" class="lmx-text-overflow-ellipsis">\r\n {{:: (item.data.isRefund ? value * -1 :\r\n value) | number: 2}} {{:: currency }}\r\n </div>\r\n </div>\r\n <div ng-if=":: item.type == \'RewardData\' || item.type == \'WithdrawData\'" ng-attr-title="{{:: (item.data.isRefund ? item.data.amount.amount * -1 : item.data.amount.amount) | number: 2}} {{:: item.data.amount.currency }}" class="lmx-text-overflow-ellipsis">\r\n {{:: (item.data.isRefund ?\r\n item.data.amount.amount * -1 :\r\n item.data.amount.amount) | number: 2}} {{::\r\n item.data.amount.currency }}\r\n </div>\r\n </td>\r\n <td class="lmx-cheque-expander"></td>\r\n </tr>\r\n <tr class="lmx-cheque-info" ng-if="item.data.chequeItems.length">\r\n <td colspan="6">\r\n <div class="lmx-cheque-content">\r\n <div class="lmx-cheque-line" ng-repeat="chequeItem in item.data.chequeItems">\r\n <span class="lmx-cheque-item">{{::chequeItem.description |\r\n nbspSpaces}}</span>\r\n <span class="lmx-cheque-count">{{::chequeItem.count}}\r\n <span ng-if=":: chequeItem.unit" class="lmx-cheque-unit">{{:: chequeItem.unit}}</span></span>\r\n </div>\r\n <div class="lmx-cheque-total">\r\n {{::item.data.amount.amount | number: 2}}\r\n {{:: item.data.amount.currency }}\r\n </div>\r\n </div>\r\n </td>\r\n </tr>\r\n <tr class="lmx-cheque-info" ng-if="item.data.chequeAdditionalAttributes && item.data.chequeAdditionalAttributes.length">\r\n <td colspan="6" class="lmx-cheque-content">\r\n <h4>{{ \'history.eCheque\' | translate }}:</h4>\r\n <div ng-repeat="attribute in item.data.chequeAdditionalAttributes">\r\n <a ng-href="{{ attribute.value }}" target="_blank">\r\n {{ attribute.stringValue}}\r\n </a>\r\n </div>\r\n </td>\r\n </tr>\r\n </tbody>\r\n </table>\r\n </div>\r\n </div>\r\n <div ng-show=":: !isPreview" ng-switch=":: !!isPaginated">\r\n <uib-pagination ng-switch-when="true" ng-show="!isReload && history.allCount > onPage" total-items="history.allCount" ng-model="$parent.currentPage" max-size="4" items-per-page="{{:: onPage}}" class="lmx-pagination" boundary-links="true" boundary-link-numbers="true" direction-links="false" force-ellipses="true" first-text="<<" last-text=">>" ng-change="paginationChange()"></uib-pagination>\r\n <div ng-switch-when="false">\r\n <a class="lmx-pseudolink lmx-right" ng-if="!inProgress && (from + onPage < history.allCount)" ng-click="increaseFrom()" href="">{{\'history.showMore\' | translate}}</a>\r\n <inline-loader line="">inProgress && !isReload</inline-loader>\r\n </div>\r\n </div>\r\n <a ng-if=":: isPreview" href="{{:: historyUrl}}" class="lmx-pseudolink">{{\'history.goToFullHistory\' | translate}}</a>\r\n </div>\r\n <div class="lmx-history-not-found" ng-if="!history.allCount && !inProgress">\r\n {{\'history.notFound\' | translate}}\r\n </div>\r\n <a ng-if="balanceChangeHistory && !history.allCount && !inProgress && !balanceChangesIsEmpty" href="" ng-click="changeTab(tabs.balanceChanges)">{{\'history.showBalanceChange\' | translate}}</a>\r\n </div>\r\n <div ng-if="balanceChangeHistory" ng-show="selectedTab.value === tabs.balanceChanges">\r\n <lmx-balance-changes from-date="fromDate" to-date="toDate" card-id="selectedCard"></lmx-balance-changes>\r\n <a ng-if="balanceChangeHistory && history.allCount && !inProgress && balanceChangesIsEmpty" href="" ng-click="changeTab(tabs.operations)">{{\'history.showOperations\' | translate}}</a>\r\n </div>\r\n </div>\r\n </div>\r\n </section>\r\n</div>\r\n'), 9251 9253 n.put("app/directives/identifiers/identifiers.html",'<div>\r\n <div class="lmx-identifier-types lmx-row" ng-if=":: identifiers.length > 1">\r\n <div class="lmx-identifier-type-radio" ng-repeat="identifier in identifiers track by $index">\r\n <input type="radio" ng-model="model.currentIdentifier" value="{{identifier}}" id="lmx-{{identifier}}" ng-disabled="authInProgress" name="{{identifier}}">\r\n <label for="lmx-{{identifier}}">{{\'identifiers.\' + identifier | translate}}</label>\r\n </div>\r\n </div>\r\n</div>\r\n'),n.put("app/directives/limiters/repeatLimitDirective.html",'<ul ng-if="::items.length > 0" class="lmx-repeat-limit">\r\n <li ng-repeat="item in items | limitTo: limit track by $index" class="lmx-repeat-limit-item">\r\n <span ng-if="!textLimit">{{::item}}</span>\r\n <text-limit ng-if="textLimit" limit="{{textLimit}}" text="item"></text-limit>\r\n <span ng-if="::delimiter " class="lmx-repeat-limit-item-delimiter" ng-class="{\'lmx-hide\': $index === items.length - 1}">{{::delimiter}} </span>\r\n </li>\r\n <li class="lmx-toggle-limit-btn" ng-click="toggleLimit()" ng-if="items.length > limit">\r\n {{ limit ? \'showAll\' : \'hide\' | translate | lowercase }}\r\n <span ng-if="limit"> ({{:: items.length}})</span>\r\n </li>\r\n</ul>\r\n<span ng-if="::items.length === 0 && defaultMessage">{{:: defaultMessage}}</span>\r\n'),n.put("app/directives/limiters/textLimitDirective.html",'<span>\r\n {{:: framing}}{{ text | limitTo: limit }}\r\n <span ng-if="::framing && text.length < limit">{{:: framing}}</span>\r\n <span ng-if="::framing && text.length > limit">{{limit ? \'\' : framing}}</span>\r\n</span>\r\n<span ng-click="toggleLimit()" ng-if="text.length > limit" class="lmx-toggle-limit-btn">\r\n <span ng-if="limit">\r\n ...\r\n <span ng-if="::framing">{{limit ? framing : \'\'}}</span>\r\n </span>\r\n {{ limit ? \'show\' : \'hide\' | translate | lowercase}}\r\n</span>\r\n'),n.put("app/directives/lmxApp/lmxApp.html",'<div class="loymax-container">\r\n <div class="lmx-body-loader" ng-hide="allRequestsCompleted"></div>\r\n <div class="lmx-main-block lmx-embedded-user-info lmx-clearfix">\r\n <lmx-user-info></lmx-user-info>\r\n </div>\r\n <nav class="lmx-main-block lmx-embedded-menu lmx-base-menu" ng-if="allRequestsCompleted">\r\n <ul class="lmx-side-nav">\r\n <li class="lmx-hide-when-authed">\r\n <a href="#login"><i class="material-icons">input</i>{{\'menu.authentication\' | translate}}</a>\r\n </li>\r\n <li class="lmx-hide-when-authed">\r\n <a href="#registration"><i class="material-icons">person_add</i>{{\'menu.registration\' | translate}}</a>\r\n </li>\r\n <li class="lmx-show-when-authed">\r\n <a href="#contacts"><i class="material-icons">settings</i>{{\'menu.settings\' | translate}}</a>\r\n </li>\r\n <li class="lmx-show-when-authed">\r\n <a href="#balance"><i class="material-icons">account_balance_wallet</i>{{\'menu.balance\' |\r\n translate}}</a>\r\n </li>\r\n <li class="lmx-show-when-authed">\r\n <a href="#cards"><i class="material-icons">card_membership</i>{{\'menu.cards\' | translate}}</a>\r\n </li>\r\n <li class="lmx-show-when-authed">\r\n <a href="#coupons"><i class="material-icons">card_giftcard</i>{{\'menu.coupons\' | translate}}</a>\r\n </li>\r\n <li class="lmx-show-when-authed">\r\n <a href="#history"><i class="material-icons">card_membership</i>{{\'menu.history\' | translate}}</a>\r\n </li>\r\n <li class="lmx-show-when-authed">\r\n <a href="#personal"><i class="material-icons">question_answer</i>{{\'menu.personalData\' |\r\n translate}}</a>\r\n </li>\r\n <li class="lmx-show-when-authed">\r\n <a href="#personal-offers" style="{{noPersonalOffers ? \'color:gray\' : \'\'}}"><i class="material-icons">shopping_cart</i>{{\'menu.personalOffers\' |\r\n translate}}</a>\r\n </li>\r\n <li class="lmx-show-when-authed">\r\n <a href="#personal-goods" style="{{noPersonalGoods ? \'color:gray\' : \'\'}}"><i class="material-icons">add_shopping_cart</i>{{\'menu.personalGoods\' |\r\n translate}}</a>\r\n </li>\r\n <li class="lmx-show-when-authed">\r\n <a href="#favorite-goods"><i class="material-icons">shopping_cart</i>{{\'menu.favoriteGoods\' |\r\n translate}}</a>\r\n </li>\r\n <li class="lmx-show-when-authed">\r\n <a href="#accounts"><i class="material-icons">people</i>{{\'menu.socials\' | translate}}</a>\r\n </li>\r\n <li class="lmx-show-when-authed">\r\n <a href="#message"><i class="material-icons" style="{{hasMessages ? \'color:red\' : \'\'}}">notifications</i>{{\'menu.messages\' | translate}}</a>\r\n </li>\r\n <li class="lmx-show-when-authed">\r\n <a href="#feedback"><i class="material-icons">feedback</i>{{\'menu.feedback\' | translate}}</a>\r\n </li>\r\n <li class="lmx-show-when-authed">\r\n <a href="#user-status"><i class="material-icons">shopping_cart</i>{{\'menu.status\' | translate}}</a>\r\n </li>\r\n <li class="lmx-show-when-authed">\r\n <a href="#user-info"><i class="material-icons">shopping_cart</i>{{\'menu.userInfo\' | translate}}</a>\r\n </li>\r\n <li>\r\n <a href="#anonymous-feedback"><i class="material-icons">feedback</i>{{\'menu.anonymousFeedback\' |\r\n translate}}</a>\r\n </li>\r\n <li>\r\n <a href="#offers"><i class="material-icons">local_offer</i>{{\'menu.offers\' | translate}}</a>\r\n </li>\r\n <li>\r\n <a href="#brands"><i class="material-icons">thumb_up</i>{{\'menu.brands\' | translate}}</a>\r\n </li>\r\n <li>\r\n <a href="#announcement"><i class="material-icons">loyalty</i>{{\'menu.announcement\' | translate}}</a>\r\n </li>\r\n <li>\r\n <a href="#merchants"><i class="material-icons">store</i>{{\'menu.merchants\' | translate}}</a>\r\n </li>\r\n <li>\r\n <a href="#options"><i class="material-icons">settings</i>Опции сайта</a>\r\n </li>\r\n </ul>\r\n </nav>\r\n <div class="lmx-main-block lmx-section" ng-cloak="" ng-if="allRequestsCompleted">\r\n <div ng-switch="appLocationParts[0]">\r\n <lmx-user-email-modal></lmx-user-email-modal>\r\n <lmx-authentication ng-switch-when="login"></lmx-authentication>\r\n <lmx-reset-password ng-switch-when="reset-password"></lmx-reset-password>\r\n <lmx-registration ng-switch-when="registration"></lmx-registration>\r\n <lmx-offers ng-switch-when="offers"></lmx-offers>\r\n <lmx-feedback ng-switch-when="feedback"></lmx-feedback>\r\n <lmx-anonymous-feedback ng-switch-when="anonymous-feedback"></lmx-anonymous-feedback>\r\n <lmx-message ng-switch-when="message"></lmx-message>\r\n <lmx-user-status ng-switch-when="user-status"></lmx-user-status>\r\n <lmx-cards ng-switch-when="cards" card-number-graphical-code="bar,qr"></lmx-cards>\r\n <lmx-coupons ng-switch-when="coupons"></lmx-coupons>\r\n <lmx-favorite-goods ng-switch-when="favorite-goods"></lmx-favorite-goods>\r\n <lmx-balance ng-switch-when="balance"></lmx-balance>\r\n <lmx-history ng-switch-when="history"></lmx-history>\r\n <lmx-merchant filter-by-region="" ng-switch-when="merchants"></lmx-merchant>\r\n <lmx-user-info ng-switch-when="user-info"></lmx-user-info>\r\n <lmx-announcement ng-switch-when="announcement" space="offerSpace"></lmx-announcement>\r\n\r\n <div class="lmx-settings" ng-if="[\'personal\', \'contacts\', \'accounts\'].contains(currentLocation)">\r\n <nav class="lmx-menu grid lmx-clearfix lmx-margin-bottom">\r\n <a class="lmx-col4" ng-class="{\'active\': currentLocation == \'personal\'}" ng-click="changeLocation(\'personal\')" href="">{{\'menu.personalData\' | translate}}</a>\r\n <a class="lmx-col4" ng-class="{\'active\': currentLocation == \'contacts\'}" ng-click="changeLocation(\'contacts\')" href="">{{\'contacts.title\' | translate}}</a>\r\n <a class="lmx-col4" ng-class="{\'active\': currentLocation == \'accounts\'}" ng-click="changeLocation(\'accounts\')" href="">{{\'settings.accountsTitle\' | translate}}</a>\r\n </nav>\r\n </div>\r\n\r\n <div ng-switch-when="contacts">\r\n <div class="lmx-container lmx-contacts">\r\n <lmx-user-phone></lmx-user-phone>\r\n <lmx-user-email></lmx-user-email>\r\n <lmx-subscriptions subscription-types="Advertisement" notification-types="smsNotification,emailNotification"></lmx-subscriptions>\r\n </div>\r\n </div>\r\n <div ng-switch-when="accounts">\r\n <div class="lmx-container lmx-accounts">\r\n <lmx-user-password></lmx-user-password>\r\n <lmx-social is-binding=""></lmx-social>\r\n <lmx-unregistration></lmx-unregistration>\r\n </div>\r\n </div>\r\n <div ng-switch-when="personal">\r\n <div class="lmx-container lmx-personal">\r\n <h2>{{\'questionnaire.title\' | translate}}</h2>\r\n <lmx-questionnaire registration="false"></lmx-questionnaire>\r\n </div>\r\n </div>\r\n <lmx-options ng-switch-when="options"></lmx-options>\r\n\r\n <lmx-brands ng-switch-when="brands"></lmx-brands>\r\n <lmx-personal-offers ng-switch-when="personal-offers"></lmx-personal-offers>\r\n <lmx-personal-goods ng-switch-when="personal-goods"></lmx-personal-goods>\r\n\r\n <div ng-switch-when="logout" ng-init="logout()"></div>\r\n\r\n <div ng-switch-default="" ng-init="goToDefaultPage()"></div>\r\n </div>\r\n </div>\r\n <lmx-notifications></lmx-notifications>\r\n <re-captcha></re-captcha>\r\n</div>\r\n'),n.put("app/directives/lmxAppMenu/lmxAppMenu.html",'<div class="lmx-loymax-menu-container">\r\n <nav ng-if="allRequestsCompleted" class="lmx-base-menu">\r\n <ul class="lmx-side-nav">\r\n <li class="lmx-hide-when-authed">\r\n <a href="#login"><i class="material-icons">input</i>Вход</a>\r\n </li>\r\n <li class="lmx-hide-when-authed">\r\n <a href="#registration"><i class="material-icons">person_add</i>Регистрация</a>\r\n </li>\r\n <li class="lmx-show-when-authed">\r\n <a href="#personal"><i class="material-icons">settings</i>Настройки</a>\r\n </li>\r\n <li class="lmx-show-when-authed">\r\n <a href="#balance"><i class="material-icons">account_balance_wallet</i>Детальный баланс</a>\r\n </li>\r\n <li class="lmx-show-when-authed">\r\n <a href="#cards"><i class="material-icons">card_membership</i>Карты</a>\r\n </li>\r\n <li class="lmx-show-when-authed">\r\n <a href="#coupons"><i class="material-icons">card_giftcard</i>{{\'menu.coupons\' | translate}}</a>\r\n </li>\r\n <li class="lmx-show-when-authed">\r\n <a href="#history"><i class="material-icons">card_membership</i>История операций</a>\r\n </li>\r\n <li class="lmx-show-when-authed">\r\n <a href="#history-load-more-button"><i class="material-icons">card_membership</i>История операций (подгрузка)</a>\r\n </li>\r\n <li class="lmx-show-when-authed">\r\n <a href="#personal"><i class="material-icons">question_answer</i>Анкета</a>\r\n </li>\r\n <li class="lmx-show-when-authed">\r\n <a href="#personal-offers" style="{{noPersonalOffers ? \'color:gray\' : \'\'}}"><i class="material-icons">shopping_cart</i>Персональные предложения</a>\r\n </li>\r\n <li class="lmx-show-when-authed">\r\n <a href="#personal-goods" style="{{noPersonalGoods ? \'color:gray\' : \'\'}}"><i class="material-icons">add_shopping_cart</i>Персональные товары</a>\r\n </li>\r\n <li class="lmx-show-when-authed">\r\n <a href="#favorite-goods"><i class="material-icons">shopping_cart</i>Любимые вкусы</a>\r\n </li>\r\n <li class="lmx-show-when-authed">\r\n <a href="#social-binding"><i class="material-icons">people</i>Привязка соц-сетей</a>\r\n </li>\r\n <li class="lmx-show-when-authed">\r\n <a href="#message"><i class="material-icons" style="{{hasMessages ? \'color:red\' : \'\'}}">notifications</i>Уведомления</a>\r\n </li>\r\n <li class="lmx-show-when-authed">\r\n <a href="#feedback"><i class="material-icons">feedback</i>Обратная связь</a>\r\n </li>\r\n <li ng-if="userStatus" class="lmx-show-when-authed">\r\n <a href="#user-status"><i class="material-icons">shopping_cart</i>Статус пользователя</a>\r\n </li>\r\n <li class="lmx-show-when-authed">\r\n <a href="#user-info"><i class="material-icons">shopping_cart</i>User Info</a>\r\n </li>\r\n <li>\r\n <a href="#anonymous-feedback"><i class="material-icons">feedback</i>Бесплатная обратная связь</a>\r\n </li>\r\n <li>\r\n <a href="#offers"><i class="material-icons">local_offer</i>Рекламные материалы</a>\r\n </li>\r\n <li>\r\n <a href="#showcase"><i class="material-icons">shopping_basket</i>Витрина</a>\r\n </li>\r\n <li>\r\n <a href="#brands"><i class="material-icons">thumb_up</i>Бренды</a>\r\n </li>\r\n <li>\r\n <a href="#announcement"><i class="material-icons">loyalty</i>Реклама</a>\r\n </li>\r\n <li>\r\n <a href="#merchants"><i class="material-icons">store</i>Магазины</a>\r\n </li>\r\n <li>\r\n <a href="#merchants-filter-by-region"><i class="material-icons">store</i>Магазины по регионам</a>\r\n </li>\r\n </ul>\r\n </nav>\r\n</div>\r\n'),n.put("app/directives/lmxScroller/lmxScroller.html",'<div class="scroller-wrapper">\r\n <div class="scroller">\r\n <div ng-transclude=""></div>\r\n </div>\r\n <div class="scroller-track">\r\n <div class="scroller-bar"></div>\r\n </div>\r\n</div>\r\n'),n.put("app/directives/lmxTabs/lmxTabs.html",'<ul class="lmx-tabs-container">\r\n <!-- TODO ng-class \'active\' не срабатывает на внешние события (изменения URL, например) !-->\r\n <!-- После исправления - обновить page.html в плагине (меню в разделе "Настройки" -> на эти табы) !-->\r\n <li ng-repeat="item in list track by $index" ng-click="selectItem(item)" ng-class="{\'active\': selectedItem === item}">\r\n {{viewField ? item[viewField] : item}}\r\n </li>\r\n</ul>\r\n'),n.put("app/directives/localeSwitcher/localeSwitcher.html",'<div class="lmx-locale-switcher">\r\n <div ng-repeat="locale in ::availableLanguages track by $index" ng-class="{\'active\': isCurrentLocale(locale)}" ng-click="!isCurrentLocale(locale) && switchLocale(locale)">\r\n <span ng-class="::\'lmx-\'+locale + \'-locale\'">{{:: locale}}</span>\r\n </div>\r\n</div>\r\n'),n.put("app/directives/merchant/merchant.html",'<div class="lmx-container lmx-merchants">\r\n <section>\r\n <h2>{{\'merchants.title\' | translate}}</h2>\r\n\r\n <div loader="loaders.inProgress">\r\n <div ng-if="!loaders.inProgress" ng-switch="!!merchants.length" class="lmx-merchants-by-regions__wrapper">\r\n <div ng-if=":: filterByRegion" class="lmx-row lmx-merchants-by-regions__filterByRegion">\r\n <div class="lmx-merchant-filter" ng-if=":: regions.length">\r\n <div lmx-custom-select="" ng-model="region.id" repeat="regions" placeholder="{{\'merchants.chooseRegion\' | translate}}" options="r.id as r.name for r in regions"></div>\r\n <div lmx-custom-select="" ng-model="city.id" repeat="cities" placeholder="{{\'merchants.chooseCity\' | translate}}" options="c.id as c.name for c in cities" loader="loaders.cities"></div>\r\n </div>\r\n <div ng-if="!regions.length">{{\'merchants.noRegionInfo\' | translate}}</div>\r\n </div>\r\n\r\n <div ng-switch-when="true" class="lmx-merchants-map-row" ng-class="{\'lmx-list-tab-selected\': selectedTab.value === tabs.asList}" loader="loaders.brands || loaders.ymaps || loaders.merchantsList">\r\n <lmx-tabs ng-hide="loaders.merchantsList" list="tabs" ng-model="selectedTab.value" view-field="name">\r\n </lmx-tabs>\r\n\r\n <div class="lmx-merchant-list">\r\n <lmx-scroller ng-hide="loaders.merchantsList">\r\n <ul>\r\n <li ng-repeat="merchant in merchants | limitTo: merchantsLimit track by merchant.id" ng-init="isUnclickable = !merchant.location" ng-class="::{\'lmx-unclickable\': isUnclickable}" ng-click="!isUnclickable && showMerchantOnMap($index)">\r\n <p>\r\n {{:: merchant.title}}{{:: merchant.location ? (\', \' +\r\n merchant.location.description) : \'\'}}\r\n </p>\r\n </li>\r\n </ul>\r\n\r\n <a class="lmx-pseudolink" ng-if="merchants.length > merchantsLimit" ng-click="changeListExpansionState(true)" href="">\r\n <span ng-if="merchantsCountText">{{\'merchants.showAll\' | translate}}\r\n <span ng-bind-html="merchantsCountText"></span></span>\r\n </a>\r\n <a class="lmx-pseudolink" ng-if="merchantsLimit === merchants.length" ng-click="changeListExpansionState()" href="">\r\n {{\'merchants.hide\' | translate}}\r\n </a>\r\n </lmx-scroller>\r\n </div>\r\n\r\n <lmx-map class="lmx-map" data="merchants" ng-if="merchants.length && !loaders.brands"></lmx-map>\r\n\r\n <script type="text/javascript">\r\n document.addEventListener("lmxMapReady", function() {\r\n var map = window.lmxMap;\r\n map.balloon.events.add("open", function() {\r\n $(".ymaps-2-1-74-panel-pane").addClass("panel-opened");\r\n $(".ymaps-2-1-74-panel-pane").removeClass("panel-closed");\r\n $(".ymaps-2-1-74-copyrights-pane").addClass("copyrights-hidden");\r\n });\r\n map.balloon.events.add("close", function() {\r\n $(".ymaps-2-1-74-panel-pane").addClass("panel-closed");\r\n $(".ymaps-2-1-74-panel-pane").removeClass("panel-opened");\r\n $(".ymaps-2-1-74-copyrights-pane").removeClass("copyrights-hidden");\r\n });\r\n });\r\n </script>\r\n <style>\r\n @media (max-width: 450px) {\r\n .ymaps-2-1-74-panel-pane.panel-opened,\r\n .ymaps-2-1-74-panel-pane.panel-opened\r\n .ymaps-2-1-74-balloon-panel\r\n .ymaps-2-1-74-balloon {\r\n top: 10px;\r\n left: 10px;\r\n right: 10px;\r\n bottom: 10px;\r\n }\r\n .ymaps-2-1-74-panel-pane.panel-opened\r\n .ymaps-2-1-74-balloon-panel\r\n .ymaps-2-1-74-balloon__content\r\n ymaps {\r\n overflow-y: visible !important;\r\n height: 100% !important;\r\n }\r\n .ymaps-2-1-74-copyrights-pane.copyrights-hidden {\r\n z-index: -1 !important;\r\n }\r\n }\r\n </style>\r\n </div>\r\n <div ng-if="!merchants.length && !loaders.merchantsList">\r\n {{\'merchants.\' + (filterByRegion ? \'filteredNotFound\' : \'notFound\') |\r\n translate}}\r\n </div>\r\n\r\n <div class="lmx-offers lmx-row" ng-if="offers.length" loader="loaders.offers">\r\n <h3>\r\n {{\'merchants.offers\' | translate}} «{{titleOfMerchantOffers}}»\r\n </h3>\r\n <offers-list offers="offers"></offers-list>\r\n </div>\r\n </div>\r\n </div>\r\n </section>\r\n</div>\r\n'),n.put("app/directives/message/message.html",'<div class="lmx-container lmx-message">\r\n <section>\r\n <h2>{{\'messages.title\' | translate}}</h2>\r\n\r\n <div ng-if="messages.length || state.isProgress" loader="isProgress" class="lmx-messages-container">\r\n <article ng-repeat="message in messages">\r\n <div class="date">{{:: message.creationDate | shortDate }}</div>\r\n\r\n <div class="lmx-remove" ng-click="remove(message);">\r\n {{\'buttons.delete\' | translate | lowercase}}\r\n </div>\r\n\r\n <h4 class="lmx-title" ng-class="{\'lmx-notRead\': !message.isReaded}">\r\n <span ng-click="toggleView(message);">{{:: message.title }}</span>\r\n </h4>\r\n\r\n <div class="lmx-text" ng-if="message._isShowText">\r\n <p>{{:: message.body }}</p>\r\n </div>\r\n </article>\r\n </div>\r\n\r\n <p ng-if="!messages.length && !isProgress">{{\'messages.notFound\' | translate}}</p>\r\n </section>\r\n</div>\r\n'),n.put("app/directives/notifications/notificationsView.html",'<div class="lmx-notifications">\r\n <div ng-repeat="(text, type) in notifications.value">\r\n <div class="lmx-alert" ng-class="::{\'lmx-alert-info\': type == notificationTypes.message,\'lmx-alert-warning\': type == notificationTypes.error,\'lmx-alert-danger\': type == notificationTypes.critical}">\r\n <span class="lmx-close-btn" ng-click="clearNotifications(area)" ng-if="!notificationsAreEmpty()">×</span>\r\n <span ng-bind-html=":: text"></span>\r\n </div>\r\n </div>\r\n</div>\r\n'),n.put("app/directives/offers/modal/offerModal.html",'<div>\r\n <div class="lmx-modal-closer" ng-click="cancel()"></div>\r\n <div loader="inProgress">\r\n <div ng-if="!inProgress">\r\n <div class="modal-header">\r\n <h2>{{:: offer.title}}</h2>\r\n </div>\r\n\r\n <div class="modal-body">\r\n <div class="lmx-image">\r\n <img ng-src="{{::offer.imgUrl}}" fallback-image="" fallback-title="{{\'imageNotFound\' | translate}}" alt="">\r\n\r\n <div class="lmx-reward-thumbnail" ng-if=":: offer.rewardThumbnail" ng-switch="rewardThumbnailTypes[offer.rewardThumbnail.$type]">\r\n <div class="lmx-thumbnail lmx-two-line-text" ng-switch-when="twoLineText">\r\n <div title="{{::offer.rewardThumbnail.firstLine}}" class="lmx-first-line">\r\n {{::offer.rewardThumbnail.firstLine}}\r\n </div>\r\n <div title="{{::offer.rewardThumbnail.secondLine}}" class="lmx-second-line">\r\n {{::offer.rewardThumbnail.secondLine}}\r\n </div>\r\n </div>\r\n <div class="lmx-thumbnail lmx-image-with-text" ng-switch-when="imageWithText">\r\n <div title="{{::offer.rewardThumbnail.header}}">\r\n {{::offer.rewardThumbnail.header}}\r\n </div>\r\n <div class="lmx-reward-image">\r\n <img ng-src="{{::offer.rewardThumbnail.imgUrl || \'undefined\'}}" fallback-image="" fallback-title="{{\'imageNotFound\' | translate}}" alt="">\r\n </div>\r\n <div title="{{::offer.rewardThumbnail.footer}}">\r\n {{::offer.rewardThumbnail.footer}}\r\n </div>\r\n </div>\r\n <div class="lmx-thumbnail lmx-old-new-price" ng-switch-when="oldNewPrice">\r\n <div title="{{::offer.rewardThumbnail.oldPrice}}" class="lmx-old-price">\r\n {{::offer.rewardThumbnail.oldPrice}}\r\n </div>\r\n <div title="{{::offer.rewardThumbnail.newPrice}}" class="lmx-new-price">\r\n {{::offer.rewardThumbnail.newPrice}}\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n <div class="lmx-details">\r\n <div>\r\n <div class="lmx-offer-title">{{\'offers.date\' | translate}}:</div>\r\n <div>{{:: (offer.begin | toUTC) | timeRange: (offer.end | toUTC)}}</div>\r\n </div>\r\n\r\n <section ng-if=":: offer.description">\r\n <div class="lmx-offer-title">{{\'offers.description\' | translate}}:</div>\r\n <div ng-bind-html="offer.description | markdown"></div>\r\n </section>\r\n\r\n <section ng-if=":: offer.instructions.length">\r\n <div class="lmx-offer-title">{{\'offers.instructions\' | translate}}:</div>\r\n <ol>\r\n <li ng-repeat="item in offer.instructions track by $index">\r\n {{::item }}\r\n </li>\r\n </ol>\r\n </section>\r\n\r\n <section ng-if=":: offer.merchants.length" ng-init="merchantsLimit = (offer.merchants.length === 4 ? 4 : 3)">\r\n <div class="lmx-offer-title">{{\'offers.merchants\' | translate}}:</div>\r\n <ul>\r\n <li ng-repeat="merchant in offer.merchants | limitTo: merchantsLimit track by merchant.id">\r\n {{:: merchant.title}}{{:: merchant.location ? (\', \' +\r\n merchant.location.description) : \'\'}}\r\n </li>\r\n </ul>\r\n <a class="lmx-pseudolink" ng-if="merchantsLimit !== offer.merchants.length && offer.merchants.length > 4" ng-click="$parent.merchantsLimit = offer.merchants.length" href="">\r\n <span ng-if="merchantsCountText">{{\'offers.showAllMerchants\' | translate}}\r\n <span ng-bind-html="merchantsCountText"></span></span>\r\n </a>\r\n <a class="lmx-pseudolink" ng-if="merchantsLimit === offer.merchants.length && offer.merchants.length > 4" ng-click="$parent.merchantsLimit = 3" href="">\r\n {{\'offers.hideMerchants\' | translate}}\r\n </a>\r\n </section>\r\n </div>\r\n </div>\r\n\r\n <div class="modal-footer lmx-btn-container">\r\n <button type="button" ng-click="cancel()">{{\'buttons.close\' | translate}}</button>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n'),n.put("app/directives/offers/offers.html",'<div class="lmx-container lmx-offers">\r\n <section>\r\n <h2>{{\'offers.title\' | translate}}</h2>\r\n <div loader="inProgress">\r\n <div ng-if="!inProgress" class="lmx-offers-list">\r\n <offers-list offers="offers"></offers-list>\r\n </div>\r\n </div>\r\n </section>\r\n</div>\r\n'),n.put("app/directives/offers/offersList.html",'<div class="lmx-offers-list">\r\n <div ng-repeat="offer in offers track by offer.id" ng-click="openCommunicationOfferModal(offer)" class="lmx-offer lmx-card">\r\n <div class="lmx-card-image">\r\n <img ng-src="{{::offer.imgUrl}}" fallback-image="" fallback-title="{{\'imageNotFound\' | translate}}" alt="">\r\n </div>\r\n <div class="lmx-content">\r\n <div class="lmx-reward-thumbnail" ng-if=":: offer.rewardThumbnail" ng-switch="rewardThumbnailTypes[offer.rewardThumbnail.$type]">\r\n <div class="lmx-two-line-text" ng-switch-when="twoLineText">\r\n <div title="{{::offer.rewardThumbnail.firstLine}}" class="lmx-first-line">\r\n {{::offer.rewardThumbnail.firstLine}}\r\n </div>\r\n <div title="{{::offer.rewardThumbnail.secondLine}}" class="lmx-second-line">\r\n {{::offer.rewardThumbnail.secondLine}}\r\n </div>\r\n </div>\r\n <div class="lmx-image-with-text" ng-switch-when="imageWithText">\r\n <div title="{{::offer.rewardThumbnail.header}}">\r\n {{::offer.rewardThumbnail.header}}\r\n </div>\r\n <div class="lmx-reward-image">\r\n <img ng-src="{{::offer.rewardThumbnail.imgUrl}}" fallback-image="" fallback-title="{{\'imageNotFound\' | translate}}" alt="">\r\n </div>\r\n <div title="{{::offer.rewardThumbnail.footer}}">\r\n {{::offer.rewardThumbnail.footer}}\r\n </div>\r\n </div>\r\n <div class="lmx-old-new-price" ng-switch-when="oldNewPrice">\r\n <div title="{{::offer.rewardThumbnail.oldPrice}}" class="lmx-old-price">\r\n {{::offer.rewardThumbnail.oldPrice}}\r\n </div>\r\n <div title="{{::offer.rewardThumbnail.newPrice}}" class="lmx-new-price">\r\n {{::offer.rewardThumbnail.newPrice}}\r\n </div>\r\n </div>\r\n </div>\r\n <div class="lmx-card-content">\r\n <div class="lmx-card-title" title="{{::offer.title}}">{{::offer.title}}</div>\r\n <div class="lmx-card-description">{{:: offer.shortDescription}}</div>\r\n </div>\r\n </div>\r\n </div>\r\n <div ng-if="!offers.length">\r\n {{\'offers.\' + (offerState === states.active ? \'noActiveOffers\' : \'noFutureOffers\') |\r\n translate}}\r\n </div>\r\n</div>\r\n'), 9252 9254 n.put("app/directives/options/options.html",'<div class="lmx-container lmx-options">\r\n <section>\r\n <h2>Параметры сайта</h2>\r\n\r\n <table>\r\n <tr>\r\n <td>\r\n <input type="text" id="lmx-api" ng-model="api">\r\n <label for="lmx-api">API</label>\r\n </td>\r\n <td>\r\n <button type="button" ng-click="saveConfiguration(\'host\', api)">\r\n {{\'buttons.save\' | translate}}\r\n </button>\r\n </td>\r\n </tr>\r\n <tr>\r\n <td>\r\n <input type="text" id="lmx-showcaseApi" ng-model="showcaseApi">\r\n <label for="lmx-showcaseApi">ShowcaseAPI</label>\r\n </td>\r\n <td>\r\n <button type="button" ng-click="saveConfiguration(\'showcaseHost\', showcaseApi)">\r\n {{\'buttons.save\' | translate}}\r\n </button>\r\n </td>\r\n </tr>\r\n <tr>\r\n <td>\r\n <input type="text" id="lmx-locales" ng-model="locales" required="">\r\n <label for="lmx-locales">Локализации</label>\r\n </td>\r\n <td>\r\n <button type="button" ng-click="saveConfiguration(\'locales\', locales)">\r\n {{\'buttons.save\' | translate}}\r\n </button>\r\n </td>\r\n </tr>\r\n <tr>\r\n <td>\r\n <input type="text" id="lmx-reCaptchaSiteKey" ng-model="reCaptchaSiteKey">\r\n <label for="lmx-reCaptchaSiteKey">reCaptchaSiteKey</label>\r\n </td>\r\n <td>\r\n <button type="button" ng-click="saveConfiguration(\'reCaptchaSiteKey\', reCaptchaSiteKey)">\r\n {{\'buttons.save\' | translate}}\r\n </button>\r\n </td>\r\n </tr>\r\n <tr>\r\n <td>\r\n <input type="text" id="lmx-oAuthClientId" ng-model="oAuthClientId">\r\n <label ng-class="{\'active\': oAuthClientId}" for="lmx-oAuthClientId">oAuthClientId</label>\r\n </td>\r\n <td>\r\n <button type="button" ng-click="saveConfiguration(\'oAuthClientId\', oAuthClientId)">\r\n {{\'buttons.save\' | translate}}\r\n </button>\r\n </td>\r\n </tr>\r\n </table>\r\n\r\n <h2>Опции компонент</h2>\r\n <div class="lmx-components-option">\r\n <table ng-repeat="(key, value) in components">\r\n <thead>\r\n <th>{{optionsNames[key]}}</th>\r\n </thead>\r\n\r\n <tbody>\r\n <tr ng-repeat="(compKey, compValue) in value">\r\n <td>{{compKey}}</td>\r\n <td ng-init="inputType = getType(compValue)" ng-switch="inputType" class="lmx-option-value">\r\n <textarea ng-switch-when="textarea" ng-attr-id="{{compKey}}" readonly="">\r\n {{value[compKey] | json}}\r\n </textarea>\r\n <input ng-switch-default="" ng-attr-id="{{compKey}}" ng-attr-type="{{inputType}}" ng-class="\'lmx-\'+getClass(compValue)" ng-model="value[compKey]">\r\n <label ng-attr-for="{{compKey}}"></label>\r\n </td>\r\n <td class="lmx-option-description">{{optionsNames[compKey]}}</td>\r\n </tr>\r\n </tbody>\r\n </table>\r\n\r\n <button type="button" ng-click="saveComponentsOptions()">\r\n {{\'buttons.save\' | translate}}\r\n </button>\r\n </div>\r\n\r\n <h2>Общие опции</h2>\r\n <div class="lmx-components-option">\r\n <table>\r\n <tbody>\r\n <tr ng-repeat="(key, value) in common">\r\n <td>{{key}}</td>\r\n <td ng-init="inputType = getType(value)" ng-switch="inputType" class="lmx-option-value">\r\n <textarea ng-switch-when="textarea" ng-attr-id="{{key}}" readonly="">\r\n {{common[key] | json}}\r\n </textarea>\r\n <input ng-switch-default="" ng-attr-id="{{key}}" ng-attr-type="{{inputType}}" ng-class="\'lmx-\'+getClass(value)" ng-model="common[key]">\r\n <label ng-attr-for="{{key}}"></label>\r\n </td>\r\n <td class="lmx-option-description">{{optionsNames[key]}}</td>\r\n </tr>\r\n </tbody>\r\n </table>\r\n\r\n <button type="button" ng-click="saveCommonOptions()">\r\n {{\'buttons.save\' | translate}}\r\n </button>\r\n </div>\r\n </section>\r\n</div>\r\n'),n.put("app/directives/personalGoods/personalGoods.html",'<div>\r\n <div class="lmx-container lmx-personal-goods" ng-if="!appLocationParts[1]">\r\n <h2>{{\'personalGoods.title\' | translate}}</h2>\r\n\r\n <div loader="inProgress">\r\n <div ng-show="!inProgress">\r\n <section class="lmx-my-goods lmx-margin-bottom" ng-if="approvedPersonalOffers.length">\r\n <h3>{{\'personalGoods.myGoodsOffers\' | translate}}:</h3>\r\n <personal-goods-offer-info ng-repeat="offer in approvedPersonalOffers track by offer.id" offer="offer" goods-preview=""></personal-goods-offer-info>\r\n </section>\r\n\r\n <section class="lmx-current-goods lmx-margin-bottom">\r\n <h3>{{\'personalGoods.activeOffers\' | translate}}:</h3>\r\n <div ng-if="activePersonalOffers.length">\r\n <personal-goods-offer-info ng-repeat="offer in activePersonalOffers track by offer.id" offer="offer"></personal-goods-offer-info>\r\n </div>\r\n <div ng-if="!activePersonalOffers.length">\r\n {{\'personalGoods.noActiveOffers\' | translate}}\r\n </div>\r\n </section>\r\n\r\n <section class="lmx-future-goods lmx-margin-bottom" ng-if="futurePersonalOffers.length">\r\n <h3>{{\'personalGoods.futureOffers\' | translate}}:</h3>\r\n <personal-goods-offer-info ng-repeat="offer in futurePersonalOffers track by offer.id" offer="offer"></personal-goods-offer-info>\r\n </section>\r\n </div>\r\n </div>\r\n </div>\r\n <personal-goods-offer ng-if="appLocationParts[1]" offer-id="appLocationParts[1]" show-full-description="true"></personal-goods-offer>\r\n</div>\r\n'),n.put("app/directives/personalGoods/personalGoodsOffer/personalGoodsOffer.html",'<div class="lmx-container lmx-personal-goods-offer" loader="inProgress">\r\n <div class="lmx-margin-bottom" ng-show="!inProgress">\r\n <div class="lmx-margin-bottom">\r\n <a href="{{:: personalGoodsUrl}}">← {{\'buttons.backToList\' | translate}}</a>\r\n </div>\r\n\r\n <personal-goods-offer-info offer="offer" class="lmx-margin-bottom" show-full-description="showFullDescription"></personal-goods-offer-info>\r\n\r\n <div class="lmx-personal-goods-offer__goods-list lmx-card" ng-class="{\'lmx-unselectable\': !selectableGoodsCount,\'lmx-readonly\': !offer.canSelectGoods,\'lmx-many-goods\': offerGoods.length > 9}" loader="offerDetailsInProgress">\r\n <div class="lmx-approve lmx-card-action">\r\n <div class="lmx-available-amount-hint">\r\n {{selectableGoodsCount ? (\'personalGoods.availableGoodsCount\' | translate:\r\n {availableCount: selectableGoodsCount || 0, maxGoodsCount:\r\n offer.attribute.maxGoodsCount}) : (\'personalGoods.maxGoodsCount\' | translate)}}\r\n </div>\r\n <button type="button" ng-if="availableGoodsCount" ng-click="approveSelectedGoods()" ng-disabled="!selectedGoods.length">\r\n {{\'buttons.approve\' | translate}}\r\n </button>\r\n </div>\r\n <div class="lmx-card-content">\r\n <div ng-repeat="goods in offerGoods track by goods.id" ng-click="changeSelectedGoods(goods)" ng-class="{\'lmx-approved\': goods.selected,\'lmx-selected\': selectedGoods.contains(goods)}" class="lmx-goods">\r\n <div class="lmx-img-wrapper">\r\n <img ng-src="{{:: goods.imgUrl}}" fallback-image="" fallback-title="{{\'imageNotFound\' | translate}}" alt="">\r\n </div>\r\n <div class="lmx-goods__title" title="{{:: goods.title}}">{{:: goods.title}}</div>\r\n <div ng-if="goods.typeRewardThumbnail" ng-switch="goods.typeRewardThumbnail">\r\n <div ng-switch-when="oldNewPrice" class="lmx-old-new-price">\r\n <span class="lmx-new-price">{{:: goods.rewardThumbnail.newPrice}}</span>\r\n <span class="lmx-old-price">{{:: goods.rewardThumbnail.oldPrice}}</span>\r\n </div>\r\n <div ng-switch-when="imageWithText" class="lmx-image-with-text">\r\n <div title="{{::goods.rewardThumbnail.header}}">\r\n {{::goods.rewardThumbnail.header}}\r\n </div>\r\n <div class="lmx-reward-image">\r\n <img ng-src="{{::goods.rewardThumbnail.imgUrl}}" fallback-image="" fallback-title="{{\'imageNotFound\' | translate}}" alt="">\r\n </div>\r\n <div title="{{::goods.rewardThumbnail.footer}}">\r\n {{::goods.rewardThumbnail.footer}}\r\n </div>\r\n </div>\r\n <div ng-switch-when="twoLineText" class="lmx-two-line-text">\r\n <div title="{{:: goods.rewardThumbnail.firstLine}}" class="lmx-first-line">\r\n {{:: goods.rewardThumbnail.firstLine}}\r\n </div>\r\n <div title="{{:: goods.rewardThumbnail.secondLine}}" class="lmx-second-line">\r\n {{:: goods.rewardThumbnail.secondLine}}\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n <div ng-if="availableGoodsCount" class="lmx-approve lmx-card-action lmx-approve-footer-duplicate lmx-clearfix">\r\n <button type="button" ng-click="approveSelectedGoods()" ng-disabled="!selectedGoods.length">\r\n {{\'buttons.approve\' | translate}}\r\n </button>\r\n </div>\r\n <div class="lmx-goods-list-overlayer">\r\n <p ng-bind-html="(\'personalGoods.editingNotAvailable\' | translate) + \': \' + ((offer.attribute.startFillDate | toUTC | timeRange: (offer.attribute.endFillDate | toUTC)) | nbspSpaces)"></p>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n'),n.put("app/directives/personalGoods/personalGoodsOfferInfo/personalGoodsOfferInfo.html",'<div class="lmx-personal-goods-offer__info" ng-class="::{\'lmx-card\': isPreview}">\r\n <div class="lmx-card-content lmx-clearfix">\r\n <div ng-if=":: goodsPreview" class="lmx-goods-preview">\r\n <div class="lmx-selected-count">\r\n {{(\'personalGoods.goodsSelected\' | translate: {approvedCount:\r\n offer.approvedGoodsCount, maxGoodsCount: offer.attribute.maxGoodsCount})}}\r\n </div>\r\n <div ng-repeat="goods in offer.approvedGoods track by goods.id" class="lmx-goods">\r\n <img ng-src="{{:: goods.imgUrl}}" fallback-image="" alt="" title="{{:: goods.title}}">\r\n </div>\r\n </div>\r\n\r\n <brands-names brands="offer.brands"></brands-names>\r\n\r\n <div class="lmx-title-wrap" ng-switch=":: isPreview">\r\n <h2 ng-switch-when="false" class="lmx-title">{{:: offer.title}}</h2>\r\n <h4 ng-switch-when="true" class="lmx-title">{{:: offer.title}}</h4>\r\n </div>\r\n\r\n <div ng-if="showFullDescription" class="lmx-description lmx-row" ng-bind-html="offer.description | markdown"></div>\r\n <div ng-if="!showFullDescription" class="lmx-description lmx-row">\r\n {{:: offer.shortDescription}}\r\n </div>\r\n <div class="lmx-duration lmx-row">\r\n <b>{{\'personalGoods.offerPeriod\' | translate}}:</b>\r\n <div>{{:: offer.begin | toUTC | timeRange: (offer.end | toUTC) | capitalize}}</div>\r\n </div>\r\n <div class="lmx-edit-duration lmx-row">\r\n <b ng-bind-html="(\'personalGoods.editingNotAvailable\' | translate) + \':\'"></b>\r\n <div>\r\n {{:: offer.attribute.startFillDate | toUTC | timeRange: (offer.attribute.endFillDate\r\n | toUTC) | capitalize}}\r\n </div>\r\n </div>\r\n </div>\r\n <div class="lmx-card-action lmx-clearfix">\r\n <button type="button" ng-click=":: changeLocation(\'personal-goods/\' + offer.id)">\r\n {{\'buttons.viewMore\' | translate}}\r\n </button>\r\n </div>\r\n</div>\r\n'),n.put("app/directives/personalOffers/personalOffer/modal/personalOfferMapModal.html",'<div class="lmx-personal-offers-map">\r\n <div loader="inProgress" class="modal-body">\r\n <lmx-map ng-if="merchants.length" class="lmx-map" data="merchants"> </lmx-map>\r\n </div>\r\n <div class="modal-footer lmx-btn-container">\r\n <button type="button" ng-click="cancel()">{{\'buttons.close\' | translate}}</button>\r\n </div>\r\n</div>\r\n'),n.put("app/directives/personalOffers/personalOffer/personalOffer.html",'<div class="lmx-container lmx-personal-offer" loader="inProgress">\r\n <div ng-if="!inProgress">\r\n <div class="lmx-margin-bottom">\r\n <a href="{{:: personalOffersUrl}}" class="lmx-go-back-link">← {{\'buttons.backToList\' | translate}}</a>\r\n </div>\r\n\r\n <personal-offer-content class="lmx-margin-bottom" personal-offer="personalOffer" show-full-description="true"></personal-offer-content>\r\n\r\n <div ng-if=":: offerDetails.length" class="lmx-offer-details-container lmx-margin-bottom">\r\n <uib-accordion class="lmx-offer-details-accordion">\r\n <uib-accordion-group ng-repeat="offerDetail in offerDetails" class="lmx-offer-details-accordion-group">\r\n <uib-accordion-heading class="lmx-offer-details-header">\r\n <span>{{::offerDetail.title}}</span>\r\n <span class="glyphicon glyphicon-chevron-down"></span>\r\n <span class="glyphicon glyphicon-chevron-up"></span>\r\n </uib-accordion-heading>\r\n <dl class="lmx-offer-details-list">\r\n <dt class="lmx-offer-detail__title">{{\'personalOffers.offer\' | translate}}:</dt>\r\n <dd class="lmx-offer-detail__description">{{::offerDetail.description}}</dd>\r\n\r\n <dt class="lmx-offer-detail__title">\r\n {{\'personalOffers.details\' | translate}}:\r\n </dt>\r\n <dd class="lmx-offer-detail__values">\r\n <personal-offer-discount-view ng-if="offerDetail.discount" value="offerDetail.discount.value" type="offerDetail.discount.$type" measure-amount="offerDetail.discount.measureAmount" discount-type="offerDetail.discount.discountType"></personal-offer-discount-view>\r\n <div>{{::offerDetail.annotation}}</div>\r\n </dd>\r\n\r\n <dt class="lmx-offer-detail__title lmx-_interval" ng-if="offerDetail.detailBeginLocalDate || offerDetail.detailEndLocalDate">\r\n {{\'personalOffers.detailPeriodTitle\' | translate}}:\r\n </dt>\r\n <dd class="lmx-offer-detail__dates" ng-if="offerDetail.detailBeginLocalDate || offerDetail.detailEndLocalDate">\r\n <span ng-if="offerDetail.detailBeginLocalDate && !offerDetail.detailEndLocalDate">\r\n {{(\'personalOffers.detailPeriod\' | translate: {offerBeginning:\r\n (offerDetail.detailBeginLocalDate | toUTC | shortDate), offerEnd:\r\n (\'personalOffers.offerEnd\' | translate)})}}\r\n </span>\r\n <span ng-if="!offerDetail.detailBeginLocalDate && offerDetail.detailEndLocalDate">\r\n {{(\'personalOffers.detailPeriod\' | translate: {offerBeginning:\r\n (\'personalOffers.offerBeginning\' | translate), offerEnd:\r\n (offerDetail.detailEndLocalDate | toUTC | shortDate)})}}\r\n </span>\r\n <span ng-if="offerDetail.detailBeginLocalDate && offerDetail.detailEndLocalDate">\r\n {{(\'personalOffers.detailPeriod\' | translate: {offerBeginning:\r\n (offerDetail.detailBeginLocalDate | toUTC | shortDate), offerEnd:\r\n (offerDetail.detailEndLocalDate | toUTC | shortDate)})}}\r\n </span>\r\n </dd>\r\n\r\n <dt class="lmx-offer-detail__title">\r\n {{\'personalOffers.goodsCode\' | translate}}:\r\n </dt>\r\n <dd class="lmx-offer-detail__codes">\r\n <repeat-limit list="offerDetail.codes" delimiter="," limit="3" field="value"></repeat-limit>\r\n </dd>\r\n </dl>\r\n <div class="lmx-btn-container lmx-offer-details-map">\r\n <button type="button" ng-show="offerDetail.hasMerchants" ng-click="openPersonalOfferMapModal(offerDetail.id)">\r\n {{\'personalOffers.viewOnMap\' | translate}}\r\n </button>\r\n </div>\r\n </uib-accordion-group>\r\n </uib-accordion>\r\n </div>\r\n </div>\r\n</div>\r\n'),n.put("app/directives/personalOffers/personalOfferContentView/personalOfferContent.html",'<div class="lmx-offer-content-container lmx-card-content lmx-clearfix">\r\n <brands-names brands="personalOffer.brands"></brands-names>\r\n\r\n <div class="lmx-personal-offer__title-container" ng-switch=":: isPreview">\r\n <h2 ng-switch-when="false" class="lmx-personal-offer__title">{{:: personalOffer.title}}</h2>\r\n <h4 ng-switch-when="true" class="lmx-card-title lmx-personal-offer__title">\r\n {{:: personalOffer.title}}\r\n </h4>\r\n </div>\r\n\r\n <div class="lmx-personal-offer__map-link">\r\n <a ng-click="openPersonalOfferMapModal()" class="lmx-pseudolink" href="">{{\'personalOffers.showOnMap\' | translate}}</a>\r\n </div>\r\n <div ng-if=":: showFullDescription" class="lmx-personal-offer__description lmx-row" ng-bind-html="personalOffer.description | markdown"></div>\r\n <div ng-if=":: !showFullDescription" class="lmx-personal-offer__description lmx-row">\r\n {{:: personalOffer.shortDescription}}\r\n </div>\r\n <div class="lmx-personal-offer__duration lmx-row">\r\n <b>{{\'personalOffers.offerPeriod\' | translate}}:</b>\r\n <div>\r\n {{:: personalOffer.begin | toUTC | timeRange: (personalOffer.end | toUTC) | capitalize}}\r\n </div>\r\n </div>\r\n</div>\r\n'),n.put("app/directives/personalOffers/personalOfferDiscountView/personalOfferDiscountView.html",'<div class="lmx-discount-view" ng-switch=":: discountEnums[type]">\r\n <span ng-switch-default="">{{:: discountView}}</span>\r\n <div ng-switch-when="pricePerUnit">\r\n <span>{{::discountView}}</span>\r\n <span class="lmx-tooltip glyphicon glyphicon-question-sign" uib-tooltip="{{\'personalOffers.pricePerUnitDiscountHint.\' + (discountType | lowerCamelCase) | translate }}" tooltip-placement="right"></span>\r\n </div>\r\n</div>\r\n'),n.put("app/directives/personalOffers/personalOffers.html",'<div>\r\n <div class="lmx-container lmx-personal-offers" ng-if="!appLocationParts[1]">\r\n <h2>{{\'personalOffers.title\' | translate}}</h2>\r\n <div loader="inProgress">\r\n <div class="lmx-margin-bottom" ng-if="!inProgress">\r\n <div ng-repeat="personalOffer in personalOffers track by personalOffer.id" class="lmx-card">\r\n <personal-offer-content personal-offer="personalOffer"></personal-offer-content>\r\n <div class="lmx-card-action lmx-clearfix">\r\n <button type="button" ng-click="openOffer(personalOffer.id)">\r\n {{\'buttons.viewMore\' | translate}}\r\n </button>\r\n </div>\r\n </div>\r\n <div ng-if=":: !personalOffers.length">\r\n {{\'personalOffers.noActiveOffers\' | translate}}\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n <personal-offer ng-if="appLocationParts[1]" offer-id="appLocationParts[1]"></personal-offer>\r\n</div>\r\n'),n.put("app/directives/phoneInput/phoneInput.html",'<input ng-class="{\'lmx-multipleMasksNumber\': multipleMasks}" ng-transclude="" ng-keypress="keyPress($event)" ng-paste="paste($event)" type="text" mask="{{phoneSettings.prefix}} {{phoneSettings.mask}}" clean="true" validate="false" restrict="reject" is-phone="" is-phone-message="{{ \'validationMessages.isPhone\' | translate: {prefix: phoneSettings.prefix, number: phoneLength } }}" placeholder="{{phoneSettings.prefix}} {{phoneSettings.mask}}">\r\n'),n.put("app/directives/phoneMask/phoneMask.html",'<div class="lmx-multipleMasksSelector" outside-click="outsideClick()" ng-if="phoneSettingsList">\r\n <span class="lmx-selected-phoneSettings" ng-click="expandList.state = !expandList.state">\r\n <div class="lmx-flag" ng-style="{ \'background-image\': \'url(data:image/svg+xml;base64,\'+ selectedType.country.image.content +\')\'}"></div>\r\n </span>\r\n\r\n <ul class="lmx-phone-types-list" ng-show="expandList.state" ng-click="expandList.state = !expandList.state">\r\n <li ng-repeat="phoneSettings in phoneSettingsList" ng-click="setPhoneSettings(phoneSettings)">\r\n <div class="lmx-flag" ng-style="{ \'background-image\': \'url(data:image/svg+xml;base64,\'+ phoneSettings.country.image.content +\')\'}"></div>\r\n <span class="lmx-country-name"> {{ phoneSettings.country.name}} </span>\r\n <span>+ {{ phoneSettings.prefix}}</span>\r\n <input type="radio" ng-model="selectedType" ng-value="phoneSettings">\r\n </li>\r\n </ul>\r\n</div>\r\n'),n.put("app/directives/questionnaire/questionCancel.html",'<div class="lmx-cancel-link">\r\n <a ng-click="cancelForm()" href="">{{\'buttons.cancel\' | translate}}</a>\r\n</div>\r\n'),n.put("app/directives/questionnaire/questionEdit.html",'<div>\r\n <a ng-click="openForm()" href="">{{\'buttons.change\'|translate}}</a>\r\n</div>\r\n'),n.put("app/directives/questionnaire/questionErrors.html",'<div class="lmx-questionnaire-error" ng-repeat="message in errors">\r\n <span>{{::message}}</span>\r\n</div>\r\n'),n.put("app/directives/questionnaire/questionnaire.html",'<div>\r\n <div ng-if=":: registration">\r\n <h2>{{\'personal.title\' | translate}}</h2>\r\n </div>\r\n <div class="lmx-questionnaire" loader="loader.templatesInProgress" ng-class="::{\'lmx-questionnaire-edit\': !registration}">\r\n <div ng-hide="loader.templatesInProgress">\r\n <div ng-repeat="questionnaireBlock in questionnaire track by $index">\r\n <div ng-if="questionnaireBlock.type === questionnaireItemTypes.question">\r\n <questionnaire-item question="questionnaireBlock" registration="registration"></questionnaire-item>\r\n </div>\r\n <div ng-if="questionnaireBlock.type === questionnaireItemTypes.questionGroup">\r\n <questionnaire-group group="questionnaireBlock" class="lmx-questionnaire-column" registration="registration"></questionnaire-group>\r\n </div>\r\n <div ng-if="questionnaireBlock.type === questionnaireItemTypes.questionMultipleGroup">\r\n <questionnaire-block block="questionnaireBlock" class="lmx-questionnaire-column"></questionnaire-block>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <lmx-notifications ng-if=":: registration" area="registration"></lmx-notifications>\r\n <lmx-notifications area="questionnaire"></lmx-notifications>\r\n <div ng-if="!loader.templatesInProgress">\r\n <div class="lmx-btn-container">\r\n <div ng-hide="loader.saveInProgress">\r\n <button type="button" ng-if=":: registration" class="lmx-btn-cancel" ng-click="cancelForm()" id="lmx-registration-questionnaire__cancel">\r\n {{\'buttons.cancel\' | translate}}\r\n </button>\r\n <button type="button" ng-click="saveQuestionnaire()" ng-disabled="saveButtonDisabled" id="lmx-registration-questionnaire__submit" ng-class="::{\'lmx-right\': !registration}">\r\n {{(registration ? \'buttons.next\' : \'buttons.save\') |translate}}\r\n </button>\r\n </div>\r\n <inline-loader>loader.saveInProgress</inline-loader>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n'),n.put("app/directives/questionnaire/questionnaireBlock.html",'<div>\r\n <h3>{{::block.name}}</h3>\r\n <div class="lmx-add-block-button">\r\n <button ng-click="addBlock()" ng-disabled="block.answers.length === block.maxAnswersCount">\r\n {{:: \'buttons.add\' | translate }}\r\n </button>\r\n </div>\r\n\r\n <div>\r\n <span ng-if="block.answers.length === 0">{{:: \'questionnaire.noQuestionBlocks\' | translate }}</span>\r\n <span ng-if="block.answers.length > 0">{{:: \'questionnaire.repliesAdded\' | translate }}</span>\r\n ({{ block.answers.length }}/{{ block.maxAnswersCount }})\r\n </div>\r\n\r\n <div ng-repeat="row in block.answers track by row.number" class="lmx-questions-row">\r\n <div class="lmx-remove-block-button">\r\n <button ng-click="removeBlock(row)">{{:: \'buttons.delete\' | translate }}</button>\r\n </div>\r\n <div ng-repeat="question in block.questions | orderBy: \'order\' track by question.id">\r\n <questionnaire-item question="question" question-block="block" question-id="block.id" answer="row.answers.getObjectByField(\'questionId\', question.id)"></questionnaire-item>\r\n </div>\r\n </div>\r\n</div>\r\n'),n.put("app/directives/questionnaire/questionnaireGroup.html",'<div>\r\n <h3>{{::group.name}}</h3>\r\n <div ng-repeat="question in group.questions | orderBy: \'order\' track by question.id">\r\n <questionnaire-item question="question" question-id="group.id" registration="registration"></questionnaire-item>\r\n </div>\r\n</div>\r\n'),n.put("app/directives/questionnaire/questionSave.html",'<div>\r\n <inline-loader line="">inProgress</inline-loader>\r\n <button type="submit" ng-hide="inProgress">{{\'buttons.save\'|translate}}</button>\r\n</div>\r\n'),n.put("app/directives/questionnaire/questionTypes/Boolean.html",'<div class="lmx-question-boolean">\r\n <form novalidate="" name="questionnaireForm" ng-submit="questionnaireForm.$valid && save()">\r\n <form-group ng-init="registerForm(questionnaireForm)" ng-class="::{\'lmx-required\': question.isRequired}">\r\n <input type="checkbox" ng-attr-id="{{::question.logicalName + answer.number}}" name="{{::question.logicalName}}" ng-model="answer.value" ng-disabled="question.isReadOnly || disabled">\r\n <label ng-attr-for="{{::question.logicalName + answer.number}}" class="lmx-checkbox-item-label">\r\n {{::question.name}}\r\n </label>\r\n <question-errors></question-errors>\r\n </form-group>\r\n </form>\r\n</div>\r\n'),n.put("app/directives/questionnaire/questionTypes/Date.html",'<div class="lmx-question-date">\r\n <form novalidate="" name="questionnaireForm" ng-submit="questionnaireForm.$valid && save()">\r\n <form-group label-text="{{::question.name}}" ng-init="registerForm(questionnaireForm)" ng-class="::{\'lmx-required\': question.isRequired}">\r\n <birthday-picker ng-attr-id="{{:: question.logicalName}}" ng-attr-name="{{:: question.logicalName}}" ng-model="answer.value" ng-required="::question.isRequired" is-disabled="question.isReadOnly || disabled" ng-class="{\'disabled\': question.isReadOnly || disabled}"></birthday-picker>\r\n\r\n <question-errors></question-errors>\r\n </form-group>\r\n </form>\r\n</div>\r\n'),n.put("app/directives/questionnaire/questionTypes/Double.html",'<div class="lmx-question-double">\r\n <form novalidate="" name="questionnaireForm" ng-submit="questionnaireForm.$valid && save()">\r\n <form-group ng-init="registerForm(questionnaireForm)" ng-class="::{\'lmx-required\': question.isRequired}" ng-attr-title="{{:: question.name.length > 30 ? question.name : \'\'}}" label-text="{{::question.name}}">\r\n <input type="number" ng-model="answer.value" name="{{::question.logicalName}}" id="lmx-{{::question.logicalName}}" ng-disabled="question.isReadOnly || disabled" ng-required="::question.isRequired" ng-pattern=":: question.regexp" ng-pattern-message="{{:: question.regexpErrorMessage}}">\r\n <question-errors></question-errors>\r\n </form-group>\r\n </form>\r\n</div>\r\n'),n.put("app/directives/questionnaire/questionTypes/Echeque.html",'<div class="lmx-question-boolean" ng-hide="registration && !showEchequeQuestion">\r\n <form novalidate="" name="questionnaireForm" ng-submit="questionnaireForm.$valid && save()">\r\n <form-group ng-init="registerForm(questionnaireForm)" ng-class="::{\'lmx-required\': question.isRequired}">\r\n <input type="checkbox" ng-attr-id="{{::question.logicalName + answer.number}}" ng-click="changeEchequeState()" name="{{::question.logicalName}}" ng-model="answer.value" ng-disabled="question.isReadOnly || disabled">\r\n <label ng-attr-for="{{::question.logicalName + answer.number}}" class="lmx-checkbox-item-label" ng-click="changeEchequeState()">\r\n {{::question.name}}\r\n </label>\r\n <div class="lmx-echeque-hint">\r\n {{ \'questionnaire.echequeAdress\' | translate }}\r\n </div>\r\n <lmx-user-email ng-if="answer.value && !registration" questionnaire="true"></lmx-user-email>\r\n <question-errors></question-errors>\r\n </form-group>\r\n </form>\r\n</div>\r\n'), -
loymaxapp/trunk/public/css/style.min.css
r2868514 r3063353 1 1 /** 2 * Loymax v 2.2.20230221(http://loymax.ru)3 * Copyright 2011-202 3Loymax, Inc.2 * Loymax v3.4.20240403-.9 (http://loymax.ru) 3 * Copyright 2011-2024 Loymax, Inc. 4 4 * License: MIT 5 5 * … … 46 46 .loymax-container ul.lmx-tabs-container{border-bottom:1px solid #ccc;margin-top:15px}.loymax-container ul.lmx-tabs-container~div{background-color:#fff;padding:15px;border:1px solid #ccc;border-top:none;overflow:auto}.loymax-container ul.lmx-tabs-container li{display:inline-block;min-width:120px;height:50px;border:1px solid #ccc;border-bottom:none;text-align:center;line-height:50px;cursor:pointer;background-color:#f0f0f0;border-top-right-radius:2px;border-top-left-radius:2px;padding:0 10px}.loymax-container ul.lmx-tabs-container li:not(:last-of-type){margin-right:5px!important}.loymax-container ul.lmx-tabs-container li.active{box-shadow:0 2px 0 -1px #fff;background-color:#fff} 47 47 .loymax-container .lmx-locale-switcher>div{display:inline}.loymax-container .lmx-locale-switcher>div:not(:last-child):after{content:" / "}.loymax-container .lmx-locale-switcher>div.active span{cursor:default}.loymax-container .lmx-locale-switcher>div:not(.active) span{text-decoration:underline;cursor:pointer} 48 @font-face{font-family:Material Icons;font-style:normal;font-weight:400;src:url(https://fonts.gstatic.com/s/materialicons/v1 39/flUhRq6tzZclQEJ-Vdg-IuiaDsNZ.ttf) format("truetype")}.material-icons{font-family:Material Icons;font-weight:400;font-style:normal;font-size:24px;line-height:1;letter-spacing:normal;text-transform:none;display:inline-block;white-space:nowrap;word-wrap:normal;direction:ltr}body.lmx-authorised .lmx-hide-when-authed,body .lmx-hidden,body.lmx-unauthorised .lmx-show-when-authed{display:none!important}body:not(.lmx-bootstrapped).modal-open{overflow:hidden}body:not(.lmx-bootstrapped) .loymax-modal{overflow:hidden;position:fixed;top:0;left:0;height:100%;width:100%;background-color:hsla(0,0%,55%,.6);text-align:center;z-index:100;max-height:none}body:not(.lmx-bootstrapped) .loymax-modal.lmx-wide .modal-content{width:710px;padding:24px}body:not(.lmx-bootstrapped) .loymax-modal.lmx-localeError-modal{background-color:#8c8c8c}body:not(.lmx-bootstrapped) .loymax-modal.lmx-userAlert-modal.lmx-centered-modal .modal-content{top:50%;transform:translateY(-50%);width:430px}body:not(.lmx-bootstrapped) .loymax-modal.lmx-modal-sm .modal-content{margin-left:-150px;width:300px}body:not(.lmx-bootstrapped) .loymax-modal.lmx-modal-lg .modal-content{margin-left:-400px;width:800px;max-height:90%;overflow-y:auto;overflow-x:hidden}body:not(.lmx-bootstrapped) .loymax-modal .lmx-modal-closer{position:absolute;top:16px;right:16px;cursor:pointer;width:16px;height:16px;background:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyNCIgaGVpZ2h0PSIyNCIgdmlld0JveD0iMCAwIDI0IDI0Ij48cGF0aCBmaWxsPSJub25lIiBkPSJNMCAwaDI0djI0SDBWMHoiLz48cGF0aCBkPSJNMTkgNi40MUwxNy41OSA1IDEyIDEwLjU5IDYuNDEgNSA1IDYuNDEgMTAuNTkgMTIgNSAxNy41OSA2LjQxIDE5IDEyIDEzLjQxIDE3LjU5IDE5IDE5IDE3LjU5IDEzLjQxIDEyIDE5IDYuNDF6Ii8+PC9zdmc+) no-repeat 50% transparent}body:not(.lmx-bootstrapped) .loymax-modal .modal-content{left:50%;margin-left:-250px;position:absolute;width:500px;padding:24px;text-align:left;top:5%;background-color:#fff;overflow-y:auto;max-height:90%}body:not(.lmx-bootstrapped) .loymax-modal .modal-content .modal-footer,body:not(.lmx-bootstrapped) .loymax-modal .modal-content .modal-header{text-align:center}body:not(.lmx-bootstrapped) .loymax-modal .modal-content .modal-body{margin-bottom:20px}.lmx-embedded-menu,.lmx-embedded-user-info{display:none}.loymax-modal .lmx-form-group input{width:100%}.loymax-container{box-sizing:border-box;margin:0}.loymax-container *,.loymax-container :after,.loymax-container :before{box-sizing:border-box!important}.loymax-container *{outline:0!important}.loymax-container ul{list-style:none!important;padding:0!important;margin:0!important}.loymax-container ul li{margin:0!important}.loymax-container table{border-collapse:collapse;border-spacing:0;width:100%}.loymax-container pre{display:block;padding:9.5px;margin:0 0 10px;font-size:13px;line-height:1.43;overflow-wrap:break-word;word-wrap:break-word;color:#333;background-color:#f5f5f5;border:1px solid #ccc;border-radius:4px}.loymax-container .lmx-row{margin:20px 0}.loymax-container input[type=number]{-moz-appearance:textfield}.loymax-container input[type=number]::-webkit-inner-spin-button,.loymax-container input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.loymax-container .lmx-relative{position:relative}.loymax-container .lmx-left{float:left}.loymax-container .lmx-right{float:right}.loymax-container .lmx-hidden{display:none}.loymax-container .lmx-invisible{visibility:hidden}.loymax-container ul.lmx-topbar{text-align:right}.loymax-container ul.lmx-topbar li{display:inline-block;margin-left:15px}.loymax-container .menu-item{display:inline-block}.loymax-container .menu-item.current-menu-item a,.loymax-container .menu-item:not(.current-menu-item) span{display:none!important}.loymax-container .lmx-alert-message{padding-top:10px;padding-bottom:10px;font-size:18px;text-align:center}.loymax-container .lmx-loader-container{min-height:50px;min-width:50px}.loymax-container .lmx-loading{opacity:.2;cursor:default!important;pointer-events:none!important}.loymax-container .lmx-body-loader,.loymax-container .lmx-loader{position:absolute;top:0;left:0;right:0;bottom:0;min-height:50px}.loymax-container .lmx-body-loader:after,.loymax-container .lmx-loader:after{background:no-repeat 50%;content:"";position:absolute;top:50%;left:50%;background-image:url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiIHN0YW5kYWxvbmU9Im5vIj8+DQo8c3ZnIHhtbG5zOnN2Zz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHZlcnNpb249IjEuMCIgd2lkdGg9IjEwMCUiIGhlaWdodD0iMTAwJSIgdmlld0JveD0iMCAwIDEyOCAxMjgiIHhtbDpzcGFjZT0icHJlc2VydmUiPg0KICAgIDxnPg0KICAgICAgPHBhdGggZD0iTTk3LjYzIDguMjNhNy4zOCA3LjM4IDAgMCAxIDIuNyAxMC4wN0w4OS4yIDM3LjU3YTcuMzggNy4zOCAwIDEgMS0xMi43Ny03LjM3bDExLjEyLTE5LjI3YTcuMzggNy4zOCAwIDAgMSAxMC4wOC0yLjd6IiBmaWxsPSIjNzU3NTc1IiBmaWxsLW9wYWNpdHk9IjEiLz4NCiAgICAgIDxwYXRoIGQ9Ik05Ny42MyA4LjIzYTcuMzggNy4zOCAwIDAgMSAyLjcgMTAuMDdMODkuMiAzNy41N2E3LjM4IDcuMzggMCAxIDEtMTIuNzctNy4zN2wxMS4xMi0xOS4yN2E3LjM4IDcuMzggMCAwIDEgMTAuMDgtMi43eiIgZmlsbD0iIzc1NzU3NSIgZmlsbC1vcGFjaXR5PSIwLjEiIHRyYW5zZm9ybT0icm90YXRlKDMwIDY0IDY0KSIvPg0KICAgICAgPHBhdGggZD0iTTk3LjYzIDguMjNhNy4zOCA3LjM4IDAgMCAxIDIuNyAxMC4wN0w4OS4yIDM3LjU3YTcuMzggNy4zOCAwIDEgMS0xMi43Ny03LjM3bDExLjEyLTE5LjI3YTcuMzggNy4zOCAwIDAgMSAxMC4wOC0yLjd6IiBmaWxsPSIjNzU3NTc1IiBmaWxsLW9wYWNpdHk9IjAuMSIgdHJhbnNmb3JtPSJyb3RhdGUoNjAgNjQgNjQpIi8+DQogICAgICA8cGF0aCBkPSJNOTcuNjMgOC4yM2E3LjM4IDcuMzggMCAwIDEgMi43IDEwLjA3TDg5LjIgMzcuNTdhNy4zOCA3LjM4IDAgMSAxLTEyLjc3LTcuMzdsMTEuMTItMTkuMjdhNy4zOCA3LjM4IDAgMCAxIDEwLjA4LTIuN3oiIGZpbGw9IiM3NTc1NzUiIGZpbGwtb3BhY2l0eT0iMC4xIiB0cmFuc2Zvcm09InJvdGF0ZSg5MCA2NCA2NCkiLz4NCiAgICAgIDxwYXRoIGQ9Ik05Ny42MyA4LjIzYTcuMzggNy4zOCAwIDAgMSAyLjcgMTAuMDdMODkuMiAzNy41N2E3LjM4IDcuMzggMCAxIDEtMTIuNzctNy4zN2wxMS4xMi0xOS4yN2E3LjM4IDcuMzggMCAwIDEgMTAuMDgtMi43eiIgZmlsbD0iIzc1NzU3NSIgZmlsbC1vcGFjaXR5PSIwLjE5IiB0cmFuc2Zvcm09InJvdGF0ZSgxMjAgNjQgNjQpIi8+DQogICAgICA8cGF0aCBkPSJNOTcuNjMgOC4yM2E3LjM4IDcuMzggMCAwIDEgMi43IDEwLjA3TDg5LjIgMzcuNTdhNy4zOCA3LjM4IDAgMSAxLTEyLjc3LTcuMzdsMTEuMTItMTkuMjdhNy4zOCA3LjM4IDAgMCAxIDEwLjA4LTIuN3oiIGZpbGw9IiM3NTc1NzUiIGZpbGwtb3BhY2l0eT0iMC4yOCIgdHJhbnNmb3JtPSJyb3RhdGUoMTUwIDY0IDY0KSIvPg0KICAgICAgPHBhdGggZD0iTTk3LjYzIDguMjNhNy4zOCA3LjM4IDAgMCAxIDIuNyAxMC4wN0w4OS4yIDM3LjU3YTcuMzggNy4zOCAwIDEgMS0xMi43Ny03LjM3bDExLjEyLTE5LjI3YTcuMzggNy4zOCAwIDAgMSAxMC4wOC0yLjd6IiBmaWxsPSIjNzU3NTc1IiBmaWxsLW9wYWNpdHk9IjAuMzgiIHRyYW5zZm9ybT0icm90YXRlKDE4MCA2NCA2NCkiLz4NCiAgICAgIDxwYXRoIGQ9Ik05Ny42MyA4LjIzYTcuMzggNy4zOCAwIDAgMSAyLjcgMTAuMDdMODkuMiAzNy41N2E3LjM4IDcuMzggMCAxIDEtMTIuNzctNy4zN2wxMS4xMi0xOS4yN2E3LjM4IDcuMzggMCAwIDEgMTAuMDgtMi43eiIgZmlsbD0iIzc1NzU3NSIgZmlsbC1vcGFjaXR5PSIwLjQ2IiB0cmFuc2Zvcm09InJvdGF0ZSgyMTAgNjQgNjQpIi8+DQogICAgICA8cGF0aCBkPSJNOTcuNjMgOC4yM2E3LjM4IDcuMzggMCAwIDEgMi43IDEwLjA3TDg5LjIgMzcuNTdhNy4zOCA3LjM4IDAgMSAxLTEyLjc3LTcuMzdsMTEuMTItMTkuMjdhNy4zOCA3LjM4IDAgMCAxIDEwLjA4LTIuN3oiIGZpbGw9IiM3NTc1NzUiIGZpbGwtb3BhY2l0eT0iMC41NSIgdHJhbnNmb3JtPSJyb3RhdGUoMjQwIDY0IDY0KSIvPg0KICAgICAgPHBhdGggZD0iTTk3LjYzIDguMjNhNy4zOCA3LjM4IDAgMCAxIDIuNyAxMC4wN0w4OS4yIDM3LjU3YTcuMzggNy4zOCAwIDEgMS0xMi43Ny03LjM3bDExLjEyLTE5LjI3YTcuMzggNy4zOCAwIDAgMSAxMC4wOC0yLjd6IiBmaWxsPSIjNzU3NTc1IiBmaWxsLW9wYWNpdHk9IjAuNjQiIHRyYW5zZm9ybT0icm90YXRlKDI3MCA2NCA2NCkiLz4NCiAgICAgIDxwYXRoIGQ9Ik05Ny42MyA4LjIzYTcuMzggNy4zOCAwIDAgMSAyLjcgMTAuMDdMODkuMiAzNy41N2E3LjM4IDcuMzggMCAxIDEtMTIuNzctNy4zN2wxMS4xMi0xOS4yN2E3LjM4IDcuMzggMCAwIDEgMTAuMDgtMi43eiIgZmlsbD0iIzc1NzU3NSIgZmlsbC1vcGFjaXR5PSIwLjczIiB0cmFuc2Zvcm09InJvdGF0ZSgzMDAgNjQgNjQpIi8+DQogICAgICA8cGF0aCBkPSJNOTcuNjMgOC4yM2E3LjM4IDcuMzggMCAwIDEgMi43IDEwLjA3TDg5LjIgMzcuNTdhNy4zOCA3LjM4IDAgMSAxLTEyLjc3LTcuMzdsMTEuMTItMTkuMjdhNy4zOCA3LjM4IDAgMCAxIDEwLjA4LTIuN3oiIGZpbGw9IiM3NTc1NzUiIGZpbGwtb3BhY2l0eT0iMC44MiIgdHJhbnNmb3JtPSJyb3RhdGUoMzMwIDY0IDY0KSIvPg0KICAgIDwvZz4NCjwvc3ZnPg0K);animation-name:lmx-rotation;animation-duration:.84s;animation-timing-function:steps(12);animation-iteration-count:infinite;transform-origin:center}.loymax-container .lmx-loader{z-index:100}.loymax-container .lmx-loader:after{width:50px;height:50px;background-color:transparent;background-size:50px}.loymax-container .lmx-body-loader{background-color:#fff;z-index:999}.loymax-container .lmx-body-loader:after{width:100px;height:100px}.loymax-container .lmx-inline-loader{position:relative;display:inline-block;width:30px;height:30px}.loymax-container .lmx-inline-loader:after{width:24px;height:24px;background:transparent no-repeat 50%/contain;content:"";position:absolute;top:50%;left:50%;background-image:url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiIHN0YW5kYWxvbmU9Im5vIj8+DQo8c3ZnIHhtbG5zOnN2Zz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHZlcnNpb249IjEuMCIgd2lkdGg9IjEwMCUiIGhlaWdodD0iMTAwJSIgdmlld0JveD0iMCAwIDEyOCAxMjgiIHhtbDpzcGFjZT0icHJlc2VydmUiPg0KICAgIDxnPg0KICAgICAgPHBhdGggZD0iTTk3LjYzIDguMjNhNy4zOCA3LjM4IDAgMCAxIDIuNyAxMC4wN0w4OS4yIDM3LjU3YTcuMzggNy4zOCAwIDEgMS0xMi43Ny03LjM3bDExLjEyLTE5LjI3YTcuMzggNy4zOCAwIDAgMSAxMC4wOC0yLjd6IiBmaWxsPSIjNzU3NTc1IiBmaWxsLW9wYWNpdHk9IjEiLz4NCiAgICAgIDxwYXRoIGQ9Ik05Ny42MyA4LjIzYTcuMzggNy4zOCAwIDAgMSAyLjcgMTAuMDdMODkuMiAzNy41N2E3LjM4IDcuMzggMCAxIDEtMTIuNzctNy4zN2wxMS4xMi0xOS4yN2E3LjM4IDcuMzggMCAwIDEgMTAuMDgtMi43eiIgZmlsbD0iIzc1NzU3NSIgZmlsbC1vcGFjaXR5PSIwLjEiIHRyYW5zZm9ybT0icm90YXRlKDMwIDY0IDY0KSIvPg0KICAgICAgPHBhdGggZD0iTTk3LjYzIDguMjNhNy4zOCA3LjM4IDAgMCAxIDIuNyAxMC4wN0w4OS4yIDM3LjU3YTcuMzggNy4zOCAwIDEgMS0xMi43Ny03LjM3bDExLjEyLTE5LjI3YTcuMzggNy4zOCAwIDAgMSAxMC4wOC0yLjd6IiBmaWxsPSIjNzU3NTc1IiBmaWxsLW9wYWNpdHk9IjAuMSIgdHJhbnNmb3JtPSJyb3RhdGUoNjAgNjQgNjQpIi8+DQogICAgICA8cGF0aCBkPSJNOTcuNjMgOC4yM2E3LjM4IDcuMzggMCAwIDEgMi43IDEwLjA3TDg5LjIgMzcuNTdhNy4zOCA3LjM4IDAgMSAxLTEyLjc3LTcuMzdsMTEuMTItMTkuMjdhNy4zOCA3LjM4IDAgMCAxIDEwLjA4LTIuN3oiIGZpbGw9IiM3NTc1NzUiIGZpbGwtb3BhY2l0eT0iMC4xIiB0cmFuc2Zvcm09InJvdGF0ZSg5MCA2NCA2NCkiLz4NCiAgICAgIDxwYXRoIGQ9Ik05Ny42MyA4LjIzYTcuMzggNy4zOCAwIDAgMSAyLjcgMTAuMDdMODkuMiAzNy41N2E3LjM4IDcuMzggMCAxIDEtMTIuNzctNy4zN2wxMS4xMi0xOS4yN2E3LjM4IDcuMzggMCAwIDEgMTAuMDgtMi43eiIgZmlsbD0iIzc1NzU3NSIgZmlsbC1vcGFjaXR5PSIwLjE5IiB0cmFuc2Zvcm09InJvdGF0ZSgxMjAgNjQgNjQpIi8+DQogICAgICA8cGF0aCBkPSJNOTcuNjMgOC4yM2E3LjM4IDcuMzggMCAwIDEgMi43IDEwLjA3TDg5LjIgMzcuNTdhNy4zOCA3LjM4IDAgMSAxLTEyLjc3LTcuMzdsMTEuMTItMTkuMjdhNy4zOCA3LjM4IDAgMCAxIDEwLjA4LTIuN3oiIGZpbGw9IiM3NTc1NzUiIGZpbGwtb3BhY2l0eT0iMC4yOCIgdHJhbnNmb3JtPSJyb3RhdGUoMTUwIDY0IDY0KSIvPg0KICAgICAgPHBhdGggZD0iTTk3LjYzIDguMjNhNy4zOCA3LjM4IDAgMCAxIDIuNyAxMC4wN0w4OS4yIDM3LjU3YTcuMzggNy4zOCAwIDEgMS0xMi43Ny03LjM3bDExLjEyLTE5LjI3YTcuMzggNy4zOCAwIDAgMSAxMC4wOC0yLjd6IiBmaWxsPSIjNzU3NTc1IiBmaWxsLW9wYWNpdHk9IjAuMzgiIHRyYW5zZm9ybT0icm90YXRlKDE4MCA2NCA2NCkiLz4NCiAgICAgIDxwYXRoIGQ9Ik05Ny42MyA4LjIzYTcuMzggNy4zOCAwIDAgMSAyLjcgMTAuMDdMODkuMiAzNy41N2E3LjM4IDcuMzggMCAxIDEtMTIuNzctNy4zN2wxMS4xMi0xOS4yN2E3LjM4IDcuMzggMCAwIDEgMTAuMDgtMi43eiIgZmlsbD0iIzc1NzU3NSIgZmlsbC1vcGFjaXR5PSIwLjQ2IiB0cmFuc2Zvcm09InJvdGF0ZSgyMTAgNjQgNjQpIi8+DQogICAgICA8cGF0aCBkPSJNOTcuNjMgOC4yM2E3LjM4IDcuMzggMCAwIDEgMi43IDEwLjA3TDg5LjIgMzcuNTdhNy4zOCA3LjM4IDAgMSAxLTEyLjc3LTcuMzdsMTEuMTItMTkuMjdhNy4zOCA3LjM4IDAgMCAxIDEwLjA4LTIuN3oiIGZpbGw9IiM3NTc1NzUiIGZpbGwtb3BhY2l0eT0iMC41NSIgdHJhbnNmb3JtPSJyb3RhdGUoMjQwIDY0IDY0KSIvPg0KICAgICAgPHBhdGggZD0iTTk3LjYzIDguMjNhNy4zOCA3LjM4IDAgMCAxIDIuNyAxMC4wN0w4OS4yIDM3LjU3YTcuMzggNy4zOCAwIDEgMS0xMi43Ny03LjM3bDExLjEyLTE5LjI3YTcuMzggNy4zOCAwIDAgMSAxMC4wOC0yLjd6IiBmaWxsPSIjNzU3NTc1IiBmaWxsLW9wYWNpdHk9IjAuNjQiIHRyYW5zZm9ybT0icm90YXRlKDI3MCA2NCA2NCkiLz4NCiAgICAgIDxwYXRoIGQ9Ik05Ny42MyA4LjIzYTcuMzggNy4zOCAwIDAgMSAyLjcgMTAuMDdMODkuMiAzNy41N2E3LjM4IDcuMzggMCAxIDEtMTIuNzctNy4zN2wxMS4xMi0xOS4yN2E3LjM4IDcuMzggMCAwIDEgMTAuMDgtMi43eiIgZmlsbD0iIzc1NzU3NSIgZmlsbC1vcGFjaXR5PSIwLjczIiB0cmFuc2Zvcm09InJvdGF0ZSgzMDAgNjQgNjQpIi8+DQogICAgICA8cGF0aCBkPSJNOTcuNjMgOC4yM2E3LjM4IDcuMzggMCAwIDEgMi43IDEwLjA3TDg5LjIgMzcuNTdhNy4zOCA3LjM4IDAgMSAxLTEyLjc3LTcuMzdsMTEuMTItMTkuMjdhNy4zOCA3LjM4IDAgMCAxIDEwLjA4LTIuN3oiIGZpbGw9IiM3NTc1NzUiIGZpbGwtb3BhY2l0eT0iMC44MiIgdHJhbnNmb3JtPSJyb3RhdGUoMzMwIDY0IDY0KSIvPg0KICAgIDwvZz4NCjwvc3ZnPg0K);animation-name:lmx-rotation;animation-duration:.84s;animation-timing-function:steps(12);animation-iteration-count:infinite;transform-origin:center}.loymax-container .lmx-inline-loader.lmx-line{width:100%}.loymax-container .lmx-grecaptcha-badge{z-index:1}.loymax-container .lmx-settings .lmx-menu>*{margin-right:10px}.loymax-container .lmx-accounts,.loymax-container .lmx-contacts,.loymax-container .lmx-personal{max-width:400px}.loymax-container .lmx-accounts .lmx-social ul{display:flex;flex-direction:column}@keyframes lmx-rotation{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media (max-width:960px){.lmx-base-menu{width:300px;position:fixed;background-color:#fff;z-index:100;padding:10px;box-shadow:3px 3px 5px #ccc}}.lmx-loymax-menu-item.current-menu-item a{font-weight:700!important}48 @font-face{font-family:Material Icons;font-style:normal;font-weight:400;src:url(https://fonts.gstatic.com/s/materialicons/v141/flUhRq6tzZclQEJ-Vdg-IuiaDsNZ.ttf) format("truetype")}.material-icons{font-family:Material Icons;font-weight:400;font-style:normal;font-size:24px;line-height:1;letter-spacing:normal;text-transform:none;display:inline-block;white-space:nowrap;word-wrap:normal;direction:ltr}body.lmx-authorised .lmx-hide-when-authed,body .lmx-hidden,body.lmx-unauthorised .lmx-show-when-authed{display:none!important}body:not(.lmx-bootstrapped).modal-open{overflow:hidden}body:not(.lmx-bootstrapped) .loymax-modal{overflow:hidden;position:fixed;top:0;left:0;height:100%;width:100%;background-color:hsla(0,0%,55%,.6);text-align:center;z-index:100;max-height:none}body:not(.lmx-bootstrapped) .loymax-modal.lmx-wide .modal-content{width:710px;padding:24px}body:not(.lmx-bootstrapped) .loymax-modal.lmx-localeError-modal{background-color:#8c8c8c}body:not(.lmx-bootstrapped) .loymax-modal.lmx-userAlert-modal.lmx-centered-modal .modal-content{top:50%;transform:translateY(-50%);width:430px}body:not(.lmx-bootstrapped) .loymax-modal.lmx-modal-sm .modal-content{margin-left:-150px;width:300px}body:not(.lmx-bootstrapped) .loymax-modal.lmx-modal-lg .modal-content{margin-left:-400px;width:800px;max-height:90%;overflow-y:auto;overflow-x:hidden}body:not(.lmx-bootstrapped) .loymax-modal .lmx-modal-closer{position:absolute;top:16px;right:16px;cursor:pointer;width:16px;height:16px;background:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyNCIgaGVpZ2h0PSIyNCIgdmlld0JveD0iMCAwIDI0IDI0Ij48cGF0aCBmaWxsPSJub25lIiBkPSJNMCAwaDI0djI0SDBWMHoiLz48cGF0aCBkPSJNMTkgNi40MUwxNy41OSA1IDEyIDEwLjU5IDYuNDEgNSA1IDYuNDEgMTAuNTkgMTIgNSAxNy41OSA2LjQxIDE5IDEyIDEzLjQxIDE3LjU5IDE5IDE5IDE3LjU5IDEzLjQxIDEyIDE5IDYuNDF6Ii8+PC9zdmc+) no-repeat 50% transparent}body:not(.lmx-bootstrapped) .loymax-modal .modal-content{left:50%;margin-left:-250px;position:absolute;width:500px;padding:24px;text-align:left;top:5%;background-color:#fff;overflow-y:auto;max-height:90%}body:not(.lmx-bootstrapped) .loymax-modal .modal-content .modal-footer,body:not(.lmx-bootstrapped) .loymax-modal .modal-content .modal-header{text-align:center}body:not(.lmx-bootstrapped) .loymax-modal .modal-content .modal-body{margin-bottom:20px}.lmx-embedded-menu,.lmx-embedded-user-info{display:none}.loymax-modal .lmx-form-group input{width:100%}.loymax-container{box-sizing:border-box;margin:0}.loymax-container *,.loymax-container :after,.loymax-container :before{box-sizing:border-box!important}.loymax-container *{outline:0!important}.loymax-container ul{list-style:none!important;padding:0!important;margin:0!important}.loymax-container ul li{margin:0!important}.loymax-container table{border-collapse:collapse;border-spacing:0;width:100%}.loymax-container pre{display:block;padding:9.5px;margin:0 0 10px;font-size:13px;line-height:1.43;overflow-wrap:break-word;word-wrap:break-word;color:#333;background-color:#f5f5f5;border:1px solid #ccc;border-radius:4px}.loymax-container .lmx-row{margin:20px 0}.loymax-container input[type=number]{-moz-appearance:textfield}.loymax-container input[type=number]::-webkit-inner-spin-button,.loymax-container input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.loymax-container .lmx-relative{position:relative}.loymax-container .lmx-left{float:left}.loymax-container .lmx-right{float:right}.loymax-container .lmx-hidden{display:none}.loymax-container .lmx-invisible{visibility:hidden}.loymax-container ul.lmx-topbar{text-align:right}.loymax-container ul.lmx-topbar li{display:inline-block;margin-left:15px}.loymax-container .menu-item{display:inline-block}.loymax-container .menu-item.current-menu-item a,.loymax-container .menu-item:not(.current-menu-item) span{display:none!important}.loymax-container .lmx-alert-message{padding-top:10px;padding-bottom:10px;font-size:18px;text-align:center}.loymax-container .lmx-loader-container{min-height:50px;min-width:50px}.loymax-container .lmx-loading{opacity:.2;cursor:default!important;pointer-events:none!important}.loymax-container .lmx-body-loader,.loymax-container .lmx-loader{position:absolute;top:0;left:0;right:0;bottom:0;min-height:50px}.loymax-container .lmx-body-loader:after,.loymax-container .lmx-loader:after{background:no-repeat 50%;content:"";position:absolute;top:50%;left:50%;background-image:url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiIHN0YW5kYWxvbmU9Im5vIj8+DQo8c3ZnIHhtbG5zOnN2Zz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHZlcnNpb249IjEuMCIgd2lkdGg9IjEwMCUiIGhlaWdodD0iMTAwJSIgdmlld0JveD0iMCAwIDEyOCAxMjgiIHhtbDpzcGFjZT0icHJlc2VydmUiPg0KICAgIDxnPg0KICAgICAgPHBhdGggZD0iTTk3LjYzIDguMjNhNy4zOCA3LjM4IDAgMCAxIDIuNyAxMC4wN0w4OS4yIDM3LjU3YTcuMzggNy4zOCAwIDEgMS0xMi43Ny03LjM3bDExLjEyLTE5LjI3YTcuMzggNy4zOCAwIDAgMSAxMC4wOC0yLjd6IiBmaWxsPSIjNzU3NTc1IiBmaWxsLW9wYWNpdHk9IjEiLz4NCiAgICAgIDxwYXRoIGQ9Ik05Ny42MyA4LjIzYTcuMzggNy4zOCAwIDAgMSAyLjcgMTAuMDdMODkuMiAzNy41N2E3LjM4IDcuMzggMCAxIDEtMTIuNzctNy4zN2wxMS4xMi0xOS4yN2E3LjM4IDcuMzggMCAwIDEgMTAuMDgtMi43eiIgZmlsbD0iIzc1NzU3NSIgZmlsbC1vcGFjaXR5PSIwLjEiIHRyYW5zZm9ybT0icm90YXRlKDMwIDY0IDY0KSIvPg0KICAgICAgPHBhdGggZD0iTTk3LjYzIDguMjNhNy4zOCA3LjM4IDAgMCAxIDIuNyAxMC4wN0w4OS4yIDM3LjU3YTcuMzggNy4zOCAwIDEgMS0xMi43Ny03LjM3bDExLjEyLTE5LjI3YTcuMzggNy4zOCAwIDAgMSAxMC4wOC0yLjd6IiBmaWxsPSIjNzU3NTc1IiBmaWxsLW9wYWNpdHk9IjAuMSIgdHJhbnNmb3JtPSJyb3RhdGUoNjAgNjQgNjQpIi8+DQogICAgICA8cGF0aCBkPSJNOTcuNjMgOC4yM2E3LjM4IDcuMzggMCAwIDEgMi43IDEwLjA3TDg5LjIgMzcuNTdhNy4zOCA3LjM4IDAgMSAxLTEyLjc3LTcuMzdsMTEuMTItMTkuMjdhNy4zOCA3LjM4IDAgMCAxIDEwLjA4LTIuN3oiIGZpbGw9IiM3NTc1NzUiIGZpbGwtb3BhY2l0eT0iMC4xIiB0cmFuc2Zvcm09InJvdGF0ZSg5MCA2NCA2NCkiLz4NCiAgICAgIDxwYXRoIGQ9Ik05Ny42MyA4LjIzYTcuMzggNy4zOCAwIDAgMSAyLjcgMTAuMDdMODkuMiAzNy41N2E3LjM4IDcuMzggMCAxIDEtMTIuNzctNy4zN2wxMS4xMi0xOS4yN2E3LjM4IDcuMzggMCAwIDEgMTAuMDgtMi43eiIgZmlsbD0iIzc1NzU3NSIgZmlsbC1vcGFjaXR5PSIwLjE5IiB0cmFuc2Zvcm09InJvdGF0ZSgxMjAgNjQgNjQpIi8+DQogICAgICA8cGF0aCBkPSJNOTcuNjMgOC4yM2E3LjM4IDcuMzggMCAwIDEgMi43IDEwLjA3TDg5LjIgMzcuNTdhNy4zOCA3LjM4IDAgMSAxLTEyLjc3LTcuMzdsMTEuMTItMTkuMjdhNy4zOCA3LjM4IDAgMCAxIDEwLjA4LTIuN3oiIGZpbGw9IiM3NTc1NzUiIGZpbGwtb3BhY2l0eT0iMC4yOCIgdHJhbnNmb3JtPSJyb3RhdGUoMTUwIDY0IDY0KSIvPg0KICAgICAgPHBhdGggZD0iTTk3LjYzIDguMjNhNy4zOCA3LjM4IDAgMCAxIDIuNyAxMC4wN0w4OS4yIDM3LjU3YTcuMzggNy4zOCAwIDEgMS0xMi43Ny03LjM3bDExLjEyLTE5LjI3YTcuMzggNy4zOCAwIDAgMSAxMC4wOC0yLjd6IiBmaWxsPSIjNzU3NTc1IiBmaWxsLW9wYWNpdHk9IjAuMzgiIHRyYW5zZm9ybT0icm90YXRlKDE4MCA2NCA2NCkiLz4NCiAgICAgIDxwYXRoIGQ9Ik05Ny42MyA4LjIzYTcuMzggNy4zOCAwIDAgMSAyLjcgMTAuMDdMODkuMiAzNy41N2E3LjM4IDcuMzggMCAxIDEtMTIuNzctNy4zN2wxMS4xMi0xOS4yN2E3LjM4IDcuMzggMCAwIDEgMTAuMDgtMi43eiIgZmlsbD0iIzc1NzU3NSIgZmlsbC1vcGFjaXR5PSIwLjQ2IiB0cmFuc2Zvcm09InJvdGF0ZSgyMTAgNjQgNjQpIi8+DQogICAgICA8cGF0aCBkPSJNOTcuNjMgOC4yM2E3LjM4IDcuMzggMCAwIDEgMi43IDEwLjA3TDg5LjIgMzcuNTdhNy4zOCA3LjM4IDAgMSAxLTEyLjc3LTcuMzdsMTEuMTItMTkuMjdhNy4zOCA3LjM4IDAgMCAxIDEwLjA4LTIuN3oiIGZpbGw9IiM3NTc1NzUiIGZpbGwtb3BhY2l0eT0iMC41NSIgdHJhbnNmb3JtPSJyb3RhdGUoMjQwIDY0IDY0KSIvPg0KICAgICAgPHBhdGggZD0iTTk3LjYzIDguMjNhNy4zOCA3LjM4IDAgMCAxIDIuNyAxMC4wN0w4OS4yIDM3LjU3YTcuMzggNy4zOCAwIDEgMS0xMi43Ny03LjM3bDExLjEyLTE5LjI3YTcuMzggNy4zOCAwIDAgMSAxMC4wOC0yLjd6IiBmaWxsPSIjNzU3NTc1IiBmaWxsLW9wYWNpdHk9IjAuNjQiIHRyYW5zZm9ybT0icm90YXRlKDI3MCA2NCA2NCkiLz4NCiAgICAgIDxwYXRoIGQ9Ik05Ny42MyA4LjIzYTcuMzggNy4zOCAwIDAgMSAyLjcgMTAuMDdMODkuMiAzNy41N2E3LjM4IDcuMzggMCAxIDEtMTIuNzctNy4zN2wxMS4xMi0xOS4yN2E3LjM4IDcuMzggMCAwIDEgMTAuMDgtMi43eiIgZmlsbD0iIzc1NzU3NSIgZmlsbC1vcGFjaXR5PSIwLjczIiB0cmFuc2Zvcm09InJvdGF0ZSgzMDAgNjQgNjQpIi8+DQogICAgICA8cGF0aCBkPSJNOTcuNjMgOC4yM2E3LjM4IDcuMzggMCAwIDEgMi43IDEwLjA3TDg5LjIgMzcuNTdhNy4zOCA3LjM4IDAgMSAxLTEyLjc3LTcuMzdsMTEuMTItMTkuMjdhNy4zOCA3LjM4IDAgMCAxIDEwLjA4LTIuN3oiIGZpbGw9IiM3NTc1NzUiIGZpbGwtb3BhY2l0eT0iMC44MiIgdHJhbnNmb3JtPSJyb3RhdGUoMzMwIDY0IDY0KSIvPg0KICAgIDwvZz4NCjwvc3ZnPg0K);animation-name:lmx-rotation;animation-duration:.84s;animation-timing-function:steps(12);animation-iteration-count:infinite;transform-origin:center}.loymax-container .lmx-loader{z-index:100}.loymax-container .lmx-loader:after{width:50px;height:50px;background-color:transparent;background-size:50px}.loymax-container .lmx-body-loader{background-color:#fff;z-index:999}.loymax-container .lmx-body-loader:after{width:100px;height:100px}.loymax-container .lmx-inline-loader{position:relative;display:inline-block;width:30px;height:30px}.loymax-container .lmx-inline-loader:after{width:24px;height:24px;background:transparent no-repeat 50%/contain;content:"";position:absolute;top:50%;left:50%;background-image:url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiIHN0YW5kYWxvbmU9Im5vIj8+DQo8c3ZnIHhtbG5zOnN2Zz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHZlcnNpb249IjEuMCIgd2lkdGg9IjEwMCUiIGhlaWdodD0iMTAwJSIgdmlld0JveD0iMCAwIDEyOCAxMjgiIHhtbDpzcGFjZT0icHJlc2VydmUiPg0KICAgIDxnPg0KICAgICAgPHBhdGggZD0iTTk3LjYzIDguMjNhNy4zOCA3LjM4IDAgMCAxIDIuNyAxMC4wN0w4OS4yIDM3LjU3YTcuMzggNy4zOCAwIDEgMS0xMi43Ny03LjM3bDExLjEyLTE5LjI3YTcuMzggNy4zOCAwIDAgMSAxMC4wOC0yLjd6IiBmaWxsPSIjNzU3NTc1IiBmaWxsLW9wYWNpdHk9IjEiLz4NCiAgICAgIDxwYXRoIGQ9Ik05Ny42MyA4LjIzYTcuMzggNy4zOCAwIDAgMSAyLjcgMTAuMDdMODkuMiAzNy41N2E3LjM4IDcuMzggMCAxIDEtMTIuNzctNy4zN2wxMS4xMi0xOS4yN2E3LjM4IDcuMzggMCAwIDEgMTAuMDgtMi43eiIgZmlsbD0iIzc1NzU3NSIgZmlsbC1vcGFjaXR5PSIwLjEiIHRyYW5zZm9ybT0icm90YXRlKDMwIDY0IDY0KSIvPg0KICAgICAgPHBhdGggZD0iTTk3LjYzIDguMjNhNy4zOCA3LjM4IDAgMCAxIDIuNyAxMC4wN0w4OS4yIDM3LjU3YTcuMzggNy4zOCAwIDEgMS0xMi43Ny03LjM3bDExLjEyLTE5LjI3YTcuMzggNy4zOCAwIDAgMSAxMC4wOC0yLjd6IiBmaWxsPSIjNzU3NTc1IiBmaWxsLW9wYWNpdHk9IjAuMSIgdHJhbnNmb3JtPSJyb3RhdGUoNjAgNjQgNjQpIi8+DQogICAgICA8cGF0aCBkPSJNOTcuNjMgOC4yM2E3LjM4IDcuMzggMCAwIDEgMi43IDEwLjA3TDg5LjIgMzcuNTdhNy4zOCA3LjM4IDAgMSAxLTEyLjc3LTcuMzdsMTEuMTItMTkuMjdhNy4zOCA3LjM4IDAgMCAxIDEwLjA4LTIuN3oiIGZpbGw9IiM3NTc1NzUiIGZpbGwtb3BhY2l0eT0iMC4xIiB0cmFuc2Zvcm09InJvdGF0ZSg5MCA2NCA2NCkiLz4NCiAgICAgIDxwYXRoIGQ9Ik05Ny42MyA4LjIzYTcuMzggNy4zOCAwIDAgMSAyLjcgMTAuMDdMODkuMiAzNy41N2E3LjM4IDcuMzggMCAxIDEtMTIuNzctNy4zN2wxMS4xMi0xOS4yN2E3LjM4IDcuMzggMCAwIDEgMTAuMDgtMi43eiIgZmlsbD0iIzc1NzU3NSIgZmlsbC1vcGFjaXR5PSIwLjE5IiB0cmFuc2Zvcm09InJvdGF0ZSgxMjAgNjQgNjQpIi8+DQogICAgICA8cGF0aCBkPSJNOTcuNjMgOC4yM2E3LjM4IDcuMzggMCAwIDEgMi43IDEwLjA3TDg5LjIgMzcuNTdhNy4zOCA3LjM4IDAgMSAxLTEyLjc3LTcuMzdsMTEuMTItMTkuMjdhNy4zOCA3LjM4IDAgMCAxIDEwLjA4LTIuN3oiIGZpbGw9IiM3NTc1NzUiIGZpbGwtb3BhY2l0eT0iMC4yOCIgdHJhbnNmb3JtPSJyb3RhdGUoMTUwIDY0IDY0KSIvPg0KICAgICAgPHBhdGggZD0iTTk3LjYzIDguMjNhNy4zOCA3LjM4IDAgMCAxIDIuNyAxMC4wN0w4OS4yIDM3LjU3YTcuMzggNy4zOCAwIDEgMS0xMi43Ny03LjM3bDExLjEyLTE5LjI3YTcuMzggNy4zOCAwIDAgMSAxMC4wOC0yLjd6IiBmaWxsPSIjNzU3NTc1IiBmaWxsLW9wYWNpdHk9IjAuMzgiIHRyYW5zZm9ybT0icm90YXRlKDE4MCA2NCA2NCkiLz4NCiAgICAgIDxwYXRoIGQ9Ik05Ny42MyA4LjIzYTcuMzggNy4zOCAwIDAgMSAyLjcgMTAuMDdMODkuMiAzNy41N2E3LjM4IDcuMzggMCAxIDEtMTIuNzctNy4zN2wxMS4xMi0xOS4yN2E3LjM4IDcuMzggMCAwIDEgMTAuMDgtMi43eiIgZmlsbD0iIzc1NzU3NSIgZmlsbC1vcGFjaXR5PSIwLjQ2IiB0cmFuc2Zvcm09InJvdGF0ZSgyMTAgNjQgNjQpIi8+DQogICAgICA8cGF0aCBkPSJNOTcuNjMgOC4yM2E3LjM4IDcuMzggMCAwIDEgMi43IDEwLjA3TDg5LjIgMzcuNTdhNy4zOCA3LjM4IDAgMSAxLTEyLjc3LTcuMzdsMTEuMTItMTkuMjdhNy4zOCA3LjM4IDAgMCAxIDEwLjA4LTIuN3oiIGZpbGw9IiM3NTc1NzUiIGZpbGwtb3BhY2l0eT0iMC41NSIgdHJhbnNmb3JtPSJyb3RhdGUoMjQwIDY0IDY0KSIvPg0KICAgICAgPHBhdGggZD0iTTk3LjYzIDguMjNhNy4zOCA3LjM4IDAgMCAxIDIuNyAxMC4wN0w4OS4yIDM3LjU3YTcuMzggNy4zOCAwIDEgMS0xMi43Ny03LjM3bDExLjEyLTE5LjI3YTcuMzggNy4zOCAwIDAgMSAxMC4wOC0yLjd6IiBmaWxsPSIjNzU3NTc1IiBmaWxsLW9wYWNpdHk9IjAuNjQiIHRyYW5zZm9ybT0icm90YXRlKDI3MCA2NCA2NCkiLz4NCiAgICAgIDxwYXRoIGQ9Ik05Ny42MyA4LjIzYTcuMzggNy4zOCAwIDAgMSAyLjcgMTAuMDdMODkuMiAzNy41N2E3LjM4IDcuMzggMCAxIDEtMTIuNzctNy4zN2wxMS4xMi0xOS4yN2E3LjM4IDcuMzggMCAwIDEgMTAuMDgtMi43eiIgZmlsbD0iIzc1NzU3NSIgZmlsbC1vcGFjaXR5PSIwLjczIiB0cmFuc2Zvcm09InJvdGF0ZSgzMDAgNjQgNjQpIi8+DQogICAgICA8cGF0aCBkPSJNOTcuNjMgOC4yM2E3LjM4IDcuMzggMCAwIDEgMi43IDEwLjA3TDg5LjIgMzcuNTdhNy4zOCA3LjM4IDAgMSAxLTEyLjc3LTcuMzdsMTEuMTItMTkuMjdhNy4zOCA3LjM4IDAgMCAxIDEwLjA4LTIuN3oiIGZpbGw9IiM3NTc1NzUiIGZpbGwtb3BhY2l0eT0iMC44MiIgdHJhbnNmb3JtPSJyb3RhdGUoMzMwIDY0IDY0KSIvPg0KICAgIDwvZz4NCjwvc3ZnPg0K);animation-name:lmx-rotation;animation-duration:.84s;animation-timing-function:steps(12);animation-iteration-count:infinite;transform-origin:center}.loymax-container .lmx-inline-loader.lmx-line{width:100%}.loymax-container .lmx-grecaptcha-badge{z-index:1}.loymax-container .lmx-settings .lmx-menu>*{margin-right:10px}.loymax-container .lmx-accounts,.loymax-container .lmx-contacts,.loymax-container .lmx-personal{max-width:400px}.loymax-container .lmx-accounts .lmx-social ul{display:flex;flex-direction:column}@keyframes lmx-rotation{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media (max-width:960px){.lmx-base-menu{width:300px;position:fixed;background-color:#fff;z-index:100;padding:10px;box-shadow:3px 3px 5px #ccc}}.lmx-loymax-menu-item.current-menu-item a{font-weight:700!important} 49 49 .loymax-container .lmx-map{height:450px;overflow:hidden}.loymax-container .lmx-map .lmx-balloon{background-color:#fafad2;width:250px;position:relative}.loymax-container .lmx-map .lmx-title{color:red;font-size:20px;margin:0}.loymax-container .lmx-map .lmx-close{position:absolute;right:5px;top:5px;width:16px;height:16px;cursor:pointer}.loymax-container .lmx-map .lmx-map-balloon-wrapper{width:200px}.loymax-container .lmx-map .lmx-map-balloon-wrapper .lmx-map-balloon-brand-logo-container{height:200px;position:relative;width:200px}.loymax-container .lmx-map .lmx-map-balloon-wrapper .lmx-map-balloon-brand-logo-container img{display:block;position:relative;height:auto;width:auto;padding:0;max-width:100%;max-height:100%;margin:0 auto;top:50%;transform:translateY(-50%)}.loymax-container .lmx-map .lmx-map-balloon-wrapper .lmx-map-balloon-merchant-title{-webkit-margin-before:0;margin-block-start:0;-webkit-margin-after:0;margin-block-end:0;padding:3px 0}.loymax-container .lmx-map .lmx-map-balloon-wrapper .lmx-map-balloon-merchant-schedule .lmx-map-balloon-schedule{position:relative}.loymax-container .lmx-map .lmx-map-balloon-wrapper .lmx-map-balloon-merchant-schedule .lmx-map-balloon-schedule:before{content:"";display:inline-block;position:relative;width:.6em;height:.6em;border-radius:50%;vertical-align:baseline;margin-right:5px}.loymax-container .lmx-map .lmx-map-balloon-wrapper .lmx-map-balloon-merchant-schedule .lmx-map-balloon-schedule._open:before{background:green}.loymax-container .lmx-map .lmx-map-balloon-wrapper .lmx-map-balloon-merchant-schedule .lmx-map-balloon-schedule._close:before{background:red} 50 50 .loymax-container .lmx-merchants-map-row{display:flex}.loymax-container .lmx-merchants-map-row .lmx-tabs-container{display:none}.loymax-container .lmx-merchants-map-row .lmx-tabs-container li{width:49%}.loymax-container .lmx-merchants-map-row .lmx-tabs-container li:first-child{margin-right:2%!important}.loymax-container .lmx-merchants-map-row .lmx-tabs-container~div{border:0}.loymax-container .lmx-merchants-map-row .lmx-map,.loymax-container .lmx-merchants-map-row .lmx-merchant-list{padding:0}.loymax-container .lmx-merchants-map-row .lmx-merchant-list{width:30%;max-width:30%;margin-right:40px;position:relative;z-index:1}.loymax-container .lmx-merchants-map-row .lmx-merchant-list ul>li{overflow-wrap:break-word;word-wrap:break-word;word-break:break-word;-webkit-hyphens:auto;-ms-hyphens:auto;hyphens:auto;cursor:pointer;padding-right:15px}.loymax-container .lmx-merchants-map-row .lmx-merchant-list ul>li.lmx-unclickable{cursor:default}.loymax-container .lmx-merchants-map-row .lmx-merchant-list ul>li:first-of-type p{margin-top:0}.loymax-container .lmx-merchants-map-row .lmx-merchant-list .scroller-wrapper{height:450px;max-height:450px}.loymax-container .lmx-merchants-map-row .lmx-map{flex-grow:1}.loymax-container .lmx-merchant-filter{display:flex;flex-wrap:wrap;justify-content:space-between;width:calc(70% - 40px);margin-left:auto}.loymax-container .lmx-merchant-filter button{flex-shrink:0}.loymax-container .lmx-merchant-filter .customSelect{flex-shrink:0;width:48%;margin-bottom:5px;min-height:inherit}.loymax-container .lmx-merchant-filter .customSelect>.lmx-loader{background-size:contain;min-height:inherit;background-color:hsla(0,0%,100%,.6)}.loymax-container .lmx-merchant-filter .customSelect-item{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;padding:0 10px;text-align:left} -
loymaxapp/trunk/readme.txt
r2864117 r3063353 37 37 38 38 == Changelog == 39 = 3.4.9 = 40 * Фиксация logout 39 41 = 3.4.6 = 40 42 * Отображена опция запроса атрибутов клиента
Note: See TracChangeset
for help on using the changeset viewer.