").parent(), e.$slideTrack.css("opacity", 0), !0 !== e.options.centerMode && !0 !== e.options.swipeToSlide || (e.options.slidesToScroll = 1), i("img[data-lazy]", e.$slider).not("[src]").addClass("slick-loading"), e.setupInfinite(), e.buildArrows(), e.buildDots(), e.updateDots(), e.setSlideClasses("number" == typeof e.currentSlide ? e.currentSlide : 0), !0 === e.options.draggable && e.$list.addClass("draggable"); }, e.prototype.buildRows = function () { var i, e, t, o, s, n, r, l = this; if (o = document.createDocumentFragment(), n = l.$slider.children(), l.options.rows > 1) { for (r = l.options.slidesPerRow * l.options.rows, s = Math.ceil(n.length / r), i = 0; i < s; i++) { var d = document.createElement("div"); for (e = 0; e < l.options.rows; e++) { var a = document.createElement("div"); for (t = 0; t < l.options.slidesPerRow; t++) { var c = i * r + (e * l.options.slidesPerRow + t); n.get(c) && a.appendChild(n.get(c)); } d.appendChild(a); } o.appendChild(d); } l.$slider.empty().append(o), l.$slider.children().children().children().css({width: 100 / l.options.slidesPerRow + "%", display: "inline-block"}); } }, e.prototype.checkResponsive = function (e, t) { var o, s, n, r = this, l = !1, d = r.$slider.width(), a = window.innerWidth || i(window).width(); if ("window" === r.respondTo ? n = a : "slider" === r.respondTo ? n = d : "min" === r.respondTo && (n = Math.min(a, d)), r.options.responsive && r.options.responsive.length && null !== r.options.responsive) { s = null; for (o in r.breakpoints) { r.breakpoints.hasOwnProperty(o) && (!1 === r.originalSettings.mobileFirst ? n < r.breakpoints[o] && (s = r.breakpoints[o]) : n > r.breakpoints[o] && (s = r.breakpoints[o])); } null !== s ? null !== r.activeBreakpoint ? (s !== r.activeBreakpoint || t) && (r.activeBreakpoint = s, "unslick" === r.breakpointSettings[s] ? r.unslick(s) : (r.options = i.extend({}, r.originalSettings, r.breakpointSettings[s]), !0 === e && (r.currentSlide = r.options.initialSlide), r.refresh(e)), l = s) : (r.activeBreakpoint = s, "unslick" === r.breakpointSettings[s] ? r.unslick(s) : (r.options = i.extend({}, r.originalSettings, r.breakpointSettings[s]), !0 === e && (r.currentSlide = r.options.initialSlide), r.refresh(e)), l = s) : null !== r.activeBreakpoint && (r.activeBreakpoint = null, r.options = r.originalSettings, !0 === e && (r.currentSlide = r.options.initialSlide), r.refresh(e), l = s), e || !1 === l || r.$slider.trigger("breakpoint", [r, l]); } }, e.prototype.changeSlide = function (e, t) { var o, s, n, r = this, l = i(e.currentTarget); switch (l.is("a") && e.preventDefault(), l.is("li") || (l = l.closest("li")), n = r.slideCount % r.options.slidesToScroll != 0, o = n ? 0 : (r.slideCount - r.currentSlide) % r.options.slidesToScroll, e.data.message) { case "previous": s = 0 === o ? r.options.slidesToScroll : r.options.slidesToShow - o, r.slideCount > r.options.slidesToShow && r.slideHandler(r.currentSlide - s, !1, t); break; case "next": s = 0 === o ? r.options.slidesToScroll : o, r.slideCount > r.options.slidesToShow && r.slideHandler(r.currentSlide + s, !1, t); break; case "index": var d = 0 === e.data.index ? 0 : e.data.index || (l.index() - 1) * r.options.slidesToScroll; r.slideHandler(r.checkNavigable(d), !1, t), l.children().trigger("focus"); break; default: return; } }, e.prototype.checkNavigable = function (i) { var e, t; if (e = this.getNavigableIndexes(), t = 0, i > e[e.length - 1]) { i = e[e.length - 1]; } else { for (var o in e) { if (i < e[o]) { i = t; break; } t = e[o]; } } return i; }, e.prototype.cleanUpEvents = function () { var e = this; e.options.dots && null !== e.$dots && (i("li", e.$dots).off("click.slick", e.changeSlide).off("mouseenter.slick", i.proxy(e.interrupt, e, !0)).off("mouseleave.slick", i.proxy(e.interrupt, e, !1)), !0 === e.options.accessibility && e.$dots.off("keydown.slick", e.keyHandler)), e.$slider.off("focus.slick blur.slick"), !0 === e.options.arrows && e.slideCount > e.options.slidesToShow && (e.$prevArrow && e.$prevArrow.off("click.slick", e.changeSlide), e.$nextArrow && e.$nextArrow.off("click.slick", e.changeSlide), !0 === e.options.accessibility && (e.$prevArrow && e.$prevArrow.off("keydown.slick", e.keyHandler), e.$nextArrow && e.$nextArrow.off("keydown.slick", e.keyHandler))), e.$list.off("touchstart.slick mousedown.slick", e.swipeHandler), e.$list.off("touchmove.slick mousemove.slick", e.swipeHandler), e.$list.off("touchend.slick mouseup.slick", e.swipeHandler), e.$list.off("touchcancel.slick mouseleave.slick", e.swipeHandler), e.$list.off("click.slick", e.clickHandler), i(document).off(e.visibilityChange, e.visibility), e.cleanUpSlideEvents(), !0 === e.options.accessibility && e.$list.off("keydown.slick", e.keyHandler), !0 === e.options.focusOnSelect && i(e.$slideTrack).children().off("click.slick", e.selectHandler), i(window).off("orientationchange.slick.slick-" + e.instanceUid, e.orientationChange), i(window).off("resize.slick.slick-" + e.instanceUid, e.resize), i("[draggable!=true]", e.$slideTrack).off("dragstart", e.preventDefault), i(window).off("load.slick.slick-" + e.instanceUid, e.setPosition); }, e.prototype.cleanUpSlideEvents = function () { var e = this; e.$list.off("mouseenter.slick", i.proxy(e.interrupt, e, !0)), e.$list.off("mouseleave.slick", i.proxy(e.interrupt, e, !1)); }, e.prototype.cleanUpRows = function () { var i, e = this; e.options.rows > 1 && ((i = e.$slides.children().children()).removeAttr("style"), e.$slider.empty().append(i)); }, e.prototype.clickHandler = function (i) { !1 === this.shouldClick && (i.stopImmediatePropagation(), i.stopPropagation(), i.preventDefault()); }, e.prototype.destroy = function (e) { var t = this; t.autoPlayClear(), t.touchObject = {}, t.cleanUpEvents(), i(".slick-cloned", t.$slider).detach(), t.$dots && t.$dots.remove(), t.$prevArrow && t.$prevArrow.length && (t.$prevArrow.removeClass("slick-disabled slick-arrow slick-hidden").removeAttr("aria-hidden aria-disabled tabindex").css("display", ""), t.htmlExpr.test(t.options.prevArrow) && t.$prevArrow.remove()), t.$nextArrow && t.$nextArrow.length && (t.$nextArrow.removeClass("slick-disabled slick-arrow slick-hidden").removeAttr("aria-hidden aria-disabled tabindex").css("display", ""), t.htmlExpr.test(t.options.nextArrow) && t.$nextArrow.remove()), t.$slides && (t.$slides.removeClass("slick-slide slick-active slick-center slick-visible slick-current").removeAttr("aria-hidden").removeAttr("data-slick-index").each(function () { i(this).attr("style", i(this).data("originalStyling")); }), t.$slideTrack.children(this.options.slide).detach(), t.$slideTrack.detach(), t.$list.detach(), t.$slider.append(t.$slides)), t.cleanUpRows(), t.$slider.removeClass("slick-slider"), t.$slider.removeClass("slick-initialized"), t.$slider.removeClass("slick-dotted"), t.unslicked = !0, e || t.$slider.trigger("destroy", [t]); }, e.prototype.disableTransition = function (i) { var e = this, t = {}; t[e.transitionType] = "", !1 === e.options.fade ? e.$slideTrack.css(t) : e.$slides.eq(i).css(t); }, e.prototype.fadeSlide = function (i, e) { var t = this; !1 === t.cssTransitions ? (t.$slides.eq(i).css({zIndex: t.options.zIndex}), t.$slides.eq(i).animate({opacity: 1}, t.options.speed, t.options.easing, e)) : (t.applyTransition(i), t.$slides.eq(i).css({opacity: 1, zIndex: t.options.zIndex}), e && setTimeout(function () { t.disableTransition(i), e.call(); }, t.options.speed)); }, e.prototype.fadeSlideOut = function (i) { var e = this; !1 === e.cssTransitions ? e.$slides.eq(i).animate({opacity: 0, zIndex: e.options.zIndex - 2}, e.options.speed, e.options.easing) : (e.applyTransition(i), e.$slides.eq(i).css({opacity: 0, zIndex: e.options.zIndex - 2})); }, e.prototype.filterSlides = e.prototype.slickFilter = function (i) { var e = this; null !== i && (e.$slidesCache = e.$slides, e.unload(), e.$slideTrack.children(this.options.slide).detach(), e.$slidesCache.filter(i).appendTo(e.$slideTrack), e.reinit()); }, e.prototype.focusHandler = function () { var e = this; e.$slider.off("focus.slick blur.slick").on("focus.slick blur.slick", "*", function (t) { t.stopImmediatePropagation(); var o = i(this); setTimeout(function () { e.options.pauseOnFocus && (e.focussed = o.is(":focus"), e.autoPlay()); }, 0); }); }, e.prototype.getCurrent = e.prototype.slickCurrentSlide = function () { return this.currentSlide; }, e.prototype.getDotCount = function () { var i = this, e = 0, t = 0, o = 0; if (!0 === i.options.infinite) { if (i.slideCount <= i.options.slidesToShow) { ++o; } else { for (; e < i.slideCount; ) { ++o, e = t + i.options.slidesToScroll, t += i.options.slidesToScroll <= i.options.slidesToShow ? i.options.slidesToScroll : i.options.slidesToShow; } } } else { if (!0 === i.options.centerMode) { o = i.slideCount; } else { if (i.options.asNavFor) { for (; e < i.slideCount; ) { ++o, e = t + i.options.slidesToScroll, t += i.options.slidesToScroll <= i.options.slidesToShow ? i.options.slidesToScroll : i.options.slidesToShow; } } else { o = 1 + Math.ceil((i.slideCount - i.options.slidesToShow) / i.options.slidesToScroll); } } } return o - 1; }, e.prototype.getLeft = function (i) { var e, t, o, s, n = this, r = 0; return n.slideOffset = 0, t = n.$slides.first().outerHeight(!0), !0 === n.options.infinite ? (n.slideCount > n.options.slidesToShow && (n.slideOffset = n.slideWidth * n.options.slidesToShow * -1, s = -1, !0 === n.options.vertical && !0 === n.options.centerMode && (2 === n.options.slidesToShow ? s = -1.5 : 1 === n.options.slidesToShow && (s = -2)), r = t * n.options.slidesToShow * s), n.slideCount % n.options.slidesToScroll != 0 && i + n.options.slidesToScroll > n.slideCount && n.slideCount > n.options.slidesToShow && (i > n.slideCount ? (n.slideOffset = (n.options.slidesToShow - (i - n.slideCount)) * n.slideWidth * -1, r = (n.options.slidesToShow - (i - n.slideCount)) * t * -1) : (n.slideOffset = n.slideCount % n.options.slidesToScroll * n.slideWidth * -1, r = n.slideCount % n.options.slidesToScroll * t * -1))) : i + n.options.slidesToShow > n.slideCount && (n.slideOffset = (i + n.options.slidesToShow - n.slideCount) * n.slideWidth, r = (i + n.options.slidesToShow - n.slideCount) * t), n.slideCount <= n.options.slidesToShow && (n.slideOffset = 0, r = 0), !0 === n.options.centerMode && n.slideCount <= n.options.slidesToShow ? n.slideOffset = n.slideWidth * Math.floor(n.options.slidesToShow) / 2 - n.slideWidth * n.slideCount / 2 : !0 === n.options.centerMode && !0 === n.options.infinite ? n.slideOffset += n.slideWidth * Math.floor(n.options.slidesToShow / 2) - n.slideWidth : !0 === n.options.centerMode && (n.slideOffset = 0, n.slideOffset += n.slideWidth * Math.floor(n.options.slidesToShow / 2)), e = !1 === n.options.vertical ? i * n.slideWidth * -1 + n.slideOffset : i * t * -1 + r, !0 === n.options.variableWidth && (o = n.slideCount <= n.options.slidesToShow || !1 === n.options.infinite ? n.$slideTrack.children(".slick-slide").eq(i) : n.$slideTrack.children(".slick-slide").eq(i + n.options.slidesToShow), e = !0 === n.options.rtl ? o[0] ? -1 * (n.$slideTrack.width() - o[0].offsetLeft - o.width()) : 0 : o[0] ? -1 * o[0].offsetLeft : 0, !0 === n.options.centerMode && (o = n.slideCount <= n.options.slidesToShow || !1 === n.options.infinite ? n.$slideTrack.children(".slick-slide").eq(i) : n.$slideTrack.children(".slick-slide").eq(i + n.options.slidesToShow + 1), e = !0 === n.options.rtl ? o[0] ? -1 * (n.$slideTrack.width() - o[0].offsetLeft - o.width()) : 0 : o[0] ? -1 * o[0].offsetLeft : 0, e += (n.$list.width() - o.outerWidth()) / 2)), e; }, e.prototype.getOption = e.prototype.slickGetOption = function (i) { return this.options[i]; }, e.prototype.getNavigableIndexes = function () { var i, e = this, t = 0, o = 0, s = []; for (!1 === e.options.infinite ? i = e.slideCount : (t = -1 * e.options.slidesToScroll, o = -1 * e.options.slidesToScroll, i = 2 * e.slideCount); t < i; ) { s.push(t), t = o + e.options.slidesToScroll, o += e.options.slidesToScroll <= e.options.slidesToShow ? e.options.slidesToScroll : e.options.slidesToShow; } return s; }, e.prototype.getSlick = function () { return this; }, e.prototype.getSlideCount = function () { var e, t, o = this; return t = !0 === o.options.centerMode ? o.slideWidth * Math.floor(o.options.slidesToShow / 2) : 0, !0 === o.options.swipeToSlide ? (o.$slideTrack.find(".slick-slide").each(function (s, n) { if (n.offsetLeft - t + i(n).outerWidth() / 2 > -1 * o.swipeLeft) { return e = n, !1; } }), Math.abs(i(e).attr("data-slick-index") - o.currentSlide) || 1) : o.options.slidesToScroll; }, e.prototype.goTo = e.prototype.slickGoTo = function (i, e) { this.changeSlide({data: {message: "index", index: parseInt(i)}}, e); }, e.prototype.init = function (e) { var t = this; i(t.$slider).hasClass("slick-initialized") || (i(t.$slider).addClass("slick-initialized"), t.buildRows(), t.buildOut(), t.setProps(), t.startLoad(), t.loadSlider(), t.initializeEvents(), t.updateArrows(), t.updateDots(), t.checkResponsive(!0), t.focusHandler()), e && t.$slider.trigger("init", [t]), !0 === t.options.accessibility && t.initADA(), t.options.autoplay && (t.paused = !1, t.autoPlay()); }, e.prototype.initADA = function () { var e = this, t = Math.ceil(e.slideCount / e.options.slidesToShow), o = e.getNavigableIndexes().filter(function (i) { return i >= 0 && i < e.slideCount; }); e.$slides.add(e.$slideTrack.find(".slick-cloned")).attr({"aria-hidden": "true", tabindex: "-1"}).find("a, input, button, select").attr({tabindex: "-1"}), null !== e.$dots && (e.$slides.not(e.$slideTrack.find(".slick-cloned")).each(function (t) { var s = o.indexOf(t); i(this).attr({role: "tabpanel", id: "slick-slide" + e.instanceUid + t, tabindex: -1}), -1 !== s && i(this).attr({"aria-describedby": "slick-slide-control" + e.instanceUid + s}); }), e.$dots.attr("role", "tablist").find("li").each(function (s) { var n = o[s]; i(this).attr({role: "presentation"}), i(this).find("button").first().attr({role: "tab", id: "slick-slide-control" + e.instanceUid + s, "aria-controls": "slick-slide" + e.instanceUid + n, "aria-label": s + 1 + " of " + t, "aria-selected": null, tabindex: "-1"}); }).eq(e.currentSlide).find("button").attr({"aria-selected": "true", tabindex: "0"}).end()); for (var s = e.currentSlide, n = s + e.options.slidesToShow; s < n; s++) { e.$slides.eq(s).attr("tabindex", 0); } e.activateADA(); }, e.prototype.initArrowEvents = function () { var i = this; !0 === i.options.arrows && i.slideCount > i.options.slidesToShow && (i.$prevArrow.off("click.slick").on("click.slick", {message: "previous"}, i.changeSlide), i.$nextArrow.off("click.slick").on("click.slick", {message: "next"}, i.changeSlide), !0 === i.options.accessibility && (i.$prevArrow.on("keydown.slick", i.keyHandler), i.$nextArrow.on("keydown.slick", i.keyHandler))); }, e.prototype.initDotEvents = function () { var e = this; !0 === e.options.dots && (i("li", e.$dots).on("click.slick", {message: "index"}, e.changeSlide), !0 === e.options.accessibility && e.$dots.on("keydown.slick", e.keyHandler)), !0 === e.options.dots && !0 === e.options.pauseOnDotsHover && i("li", e.$dots).on("mouseenter.slick", i.proxy(e.interrupt, e, !0)).on("mouseleave.slick", i.proxy(e.interrupt, e, !1)); }, e.prototype.initSlideEvents = function () { var e = this; e.options.pauseOnHover && (e.$list.on("mouseenter.slick", i.proxy(e.interrupt, e, !0)), e.$list.on("mouseleave.slick", i.proxy(e.interrupt, e, !1))); }, e.prototype.initializeEvents = function () { var e = this; e.initArrowEvents(), e.initDotEvents(), e.initSlideEvents(), e.$list.on("touchstart.slick mousedown.slick", {action: "start"}, e.swipeHandler), e.$list.on("touchmove.slick mousemove.slick", {action: "move"}, e.swipeHandler), e.$list.on("touchend.slick mouseup.slick", {action: "end"}, e.swipeHandler), e.$list.on("touchcancel.slick mouseleave.slick", {action: "end"}, e.swipeHandler), e.$list.on("click.slick", e.clickHandler), i(document).on(e.visibilityChange, i.proxy(e.visibility, e)), !0 === e.options.accessibility && e.$list.on("keydown.slick", e.keyHandler), !0 === e.options.focusOnSelect && i(e.$slideTrack).children().on("click.slick", e.selectHandler), i(window).on("orientationchange.slick.slick-" + e.instanceUid, i.proxy(e.orientationChange, e)), i(window).on("resize.slick.slick-" + e.instanceUid, i.proxy(e.resize, e)), i("[draggable!=true]", e.$slideTrack).on("dragstart", e.preventDefault), i(window).on("load.slick.slick-" + e.instanceUid, e.setPosition), i(e.setPosition); }, e.prototype.initUI = function () { var i = this; !0 === i.options.arrows && i.slideCount > i.options.slidesToShow && (i.$prevArrow.show(), i.$nextArrow.show()), !0 === i.options.dots && i.slideCount > i.options.slidesToShow && i.$dots.show(); }, e.prototype.keyHandler = function (i) { var e = this; i.target.tagName.match("TEXTAREA|INPUT|SELECT") || (37 === i.keyCode && !0 === e.options.accessibility ? e.changeSlide({data: {message: !0 === e.options.rtl ? "next" : "previous"}}) : 39 === i.keyCode && !0 === e.options.accessibility && e.changeSlide({data: {message: !0 === e.options.rtl ? "previous" : "next"}})); }, e.prototype.lazyLoad = function () { function e(e) { i("img[data-lazy]", e).each(function () { var e = i(this), t = i(this).attr("data-lazy"), o = i(this).attr("data-srcset"), s = i(this).attr("data-sizes") || n.$slider.attr("data-sizes"), r = document.createElement("img"); r.onload = function () { e.animate({opacity: 0}, 100, function () { o && (e.attr("srcset", o), s && e.attr("sizes", s)), e.attr("src", t).animate({opacity: 1}, 200, function () { e.removeAttr("data-lazy data-srcset data-sizes").removeClass("slick-loading"); }), n.$slider.trigger("lazyLoaded", [n, e, t]); }); }, r.onerror = function () { e.removeAttr("data-lazy").removeClass("slick-loading").addClass("slick-lazyload-error"), n.$slider.trigger("lazyLoadError", [n, e, t]); }, r.src = t; }); } var t, o, s, n = this; if (!0 === n.options.centerMode ? !0 === n.options.infinite ? s = (o = n.currentSlide + (n.options.slidesToShow / 2 + 1)) + n.options.slidesToShow + 2 : (o = Math.max(0, n.currentSlide - (n.options.slidesToShow / 2 + 1)), s = n.options.slidesToShow / 2 + 1 + 2 + n.currentSlide) : (o = n.options.infinite ? n.options.slidesToShow + n.currentSlide : n.currentSlide, s = Math.ceil(o + n.options.slidesToShow), !0 === n.options.fade && (o > 0 && o--, s <= n.slideCount && s++)), t = n.$slider.find(".slick-slide").slice(o, s), "anticipated" === n.options.lazyLoad) { for (var r = o - 1, l = s, d = n.$slider.find(".slick-slide"), a = 0; a < n.options.slidesToScroll; a++) { r < 0 && (r = n.slideCount - 1), t = (t = t.add(d.eq(r))).add(d.eq(l)), r--, l++; } } e(t), n.slideCount <= n.options.slidesToShow ? e(n.$slider.find(".slick-slide")) : n.currentSlide >= n.slideCount - n.options.slidesToShow ? e(n.$slider.find(".slick-cloned").slice(0, n.options.slidesToShow)) : 0 === n.currentSlide && e(n.$slider.find(".slick-cloned").slice(-1 * n.options.slidesToShow)); }, e.prototype.loadSlider = function () { var i = this; i.setPosition(), i.$slideTrack.css({opacity: 1}), i.$slider.removeClass("slick-loading"), i.initUI(), "progressive" === i.options.lazyLoad && i.progressiveLazyLoad(); }, e.prototype.next = e.prototype.slickNext = function () { this.changeSlide({data: {message: "next"}}); }, e.prototype.orientationChange = function () { var i = this; i.checkResponsive(), i.setPosition(); }, e.prototype.pause = e.prototype.slickPause = function () { var i = this; i.autoPlayClear(), i.paused = !0; }, e.prototype.play = e.prototype.slickPlay = function () { var i = this; i.autoPlay(), i.options.autoplay = !0, i.paused = !1, i.focussed = !1, i.interrupted = !1; }, e.prototype.postSlide = function (e) { var t = this; t.unslicked || (t.$slider.trigger("afterChange", [t, e]), t.animating = !1, t.slideCount > t.options.slidesToShow && t.setPosition(), t.swipeLeft = null, t.options.autoplay && t.autoPlay(), !0 === t.options.accessibility && (t.initADA(), t.options.focusOnChange && i(t.$slides.get(t.currentSlide)).attr("tabindex", 0).focus())); }, e.prototype.prev = e.prototype.slickPrev = function () { this.changeSlide({data: {message: "previous"}}); }, e.prototype.preventDefault = function (i) { i.preventDefault(); }, e.prototype.progressiveLazyLoad = function (e) { e = e || 1; var t, o, s, n, r, l = this, d = i("img[data-lazy]", l.$slider); d.length ? (t = d.first(), o = t.attr("data-lazy"), s = t.attr("data-srcset"), n = t.attr("data-sizes") || l.$slider.attr("data-sizes"), (r = document.createElement("img")).onload = function () { s && (t.attr("srcset", s), n && t.attr("sizes", n)), t.attr("src", o).removeAttr("data-lazy data-srcset data-sizes").removeClass("slick-loading"), !0 === l.options.adaptiveHeight && l.setPosition(), l.$slider.trigger("lazyLoaded", [l, t, o]), l.progressiveLazyLoad(); }, r.onerror = function () { e < 3 ? setTimeout(function () { l.progressiveLazyLoad(e + 1); }, 500) : (t.removeAttr("data-lazy").removeClass("slick-loading").addClass("slick-lazyload-error"), l.$slider.trigger("lazyLoadError", [l, t, o]), l.progressiveLazyLoad()); }, r.src = o) : l.$slider.trigger("allImagesLoaded", [l]); }, e.prototype.refresh = function (e) { var t, o, s = this; o = s.slideCount - s.options.slidesToShow, !s.options.infinite && s.currentSlide > o && (s.currentSlide = o), s.slideCount <= s.options.slidesToShow && (s.currentSlide = 0), t = s.currentSlide, s.destroy(!0), i.extend(s, s.initials, {currentSlide: t}), s.init(), e || s.changeSlide({data: {message: "index", index: t}}, !1); }, e.prototype.registerBreakpoints = function () { var e, t, o, s = this, n = s.options.responsive || null; if ("array" === i.type(n) && n.length) { s.respondTo = s.options.respondTo || "window"; for (e in n) { if (o = s.breakpoints.length - 1, n.hasOwnProperty(e)) { for (t = n[e].breakpoint; o >= 0; ) { s.breakpoints[o] && s.breakpoints[o] === t && s.breakpoints.splice(o, 1), o--; } s.breakpoints.push(t), s.breakpointSettings[t] = n[e].settings; } } s.breakpoints.sort(function (i, e) { return s.options.mobileFirst ? i - e : e - i; }); } }, e.prototype.reinit = function () { var e = this; e.$slides = e.$slideTrack.children(e.options.slide).addClass("slick-slide"), e.slideCount = e.$slides.length, e.currentSlide >= e.slideCount && 0 !== e.currentSlide && (e.currentSlide = e.currentSlide - e.options.slidesToScroll), e.slideCount <= e.options.slidesToShow && (e.currentSlide = 0), e.registerBreakpoints(), e.setProps(), e.setupInfinite(), e.buildArrows(), e.updateArrows(), e.initArrowEvents(), e.buildDots(), e.updateDots(), e.initDotEvents(), e.cleanUpSlideEvents(), e.initSlideEvents(), e.checkResponsive(!1, !0), !0 === e.options.focusOnSelect && i(e.$slideTrack).children().on("click.slick", e.selectHandler), e.setSlideClasses("number" == typeof e.currentSlide ? e.currentSlide : 0), e.setPosition(), e.focusHandler(), e.paused = !e.options.autoplay, e.autoPlay(), e.$slider.trigger("reInit", [e]); }, e.prototype.resize = function () { var e = this; i(window).width() !== e.windowWidth && (clearTimeout(e.windowDelay), e.windowDelay = window.setTimeout(function () { e.windowWidth = i(window).width(), e.checkResponsive(), e.unslicked || e.setPosition(); }, 50)); }, e.prototype.removeSlide = e.prototype.slickRemove = function (i, e, t) { var o = this; if (i = "boolean" == typeof i ? !0 === (e = i) ? 0 : o.slideCount - 1 : !0 === e ? --i : i, o.slideCount < 1 || i < 0 || i > o.slideCount - 1) { return !1; } o.unload(), !0 === t ? o.$slideTrack.children().remove() : o.$slideTrack.children(this.options.slide).eq(i).remove(), o.$slides = o.$slideTrack.children(this.options.slide), o.$slideTrack.children(this.options.slide).detach(), o.$slideTrack.append(o.$slides), o.$slidesCache = o.$slides, o.reinit(); }, e.prototype.setCSS = function (i) { var e, t, o = this, s = {}; !0 === o.options.rtl && (i = -i), e = "left" == o.positionProp ? Math.ceil(i) + "px" : "0px", t = "top" == o.positionProp ? Math.ceil(i) + "px" : "0px", s[o.positionProp] = i, !1 === o.transformsEnabled ? o.$slideTrack.css(s) : (s = {}, !1 === o.cssTransitions ? (s[o.animType] = "translate(" + e + ", " + t + ")", o.$slideTrack.css(s)) : (s[o.animType] = "translate3d(" + e + ", " + t + ", 0px)", o.$slideTrack.css(s))); }, e.prototype.setDimensions = function () { var i = this; !1 === i.options.vertical ? !0 === i.options.centerMode && i.$list.css({padding: "0px " + i.options.centerPadding}) : (i.$list.height(i.$slides.first().outerHeight(!0) * i.options.slidesToShow), !0 === i.options.centerMode && i.$list.css({padding: i.options.centerPadding + " 0px"})), i.listWidth = i.$list.width(), i.listHeight = i.$list.height(), !1 === i.options.vertical && !1 === i.options.variableWidth ? (i.slideWidth = Math.ceil(i.listWidth / i.options.slidesToShow), i.$slideTrack.width(Math.ceil(i.slideWidth * i.$slideTrack.children(".slick-slide").length))) : !0 === i.options.variableWidth ? i.$slideTrack.width(5000 * i.slideCount) : (i.slideWidth = Math.ceil(i.listWidth), i.$slideTrack.height(Math.ceil(i.$slides.first().outerHeight(!0) * i.$slideTrack.children(".slick-slide").length))); var e = i.$slides.first().outerWidth(!0) - i.$slides.first().width(); !1 === i.options.variableWidth && i.$slideTrack.children(".slick-slide").width(i.slideWidth - e); }, e.prototype.setFade = function () { var e, t = this; t.$slides.each(function (o, s) { e = t.slideWidth * o * -1, !0 === t.options.rtl ? i(s).css({position: "relative", right: e, top: 0, zIndex: t.options.zIndex - 2, opacity: 0}) : i(s).css({position: "relative", left: e, top: 0, zIndex: t.options.zIndex - 2, opacity: 0}); }), t.$slides.eq(t.currentSlide).css({zIndex: t.options.zIndex - 1, opacity: 1}); }, e.prototype.setHeight = function () { var i = this; if (1 === i.options.slidesToShow && !0 === i.options.adaptiveHeight && !1 === i.options.vertical) { var e = i.$slides.eq(i.currentSlide).outerHeight(!0); i.$list.css("height", e); } }, e.prototype.setOption = e.prototype.slickSetOption = function () { var e, t, o, s, n, r = this, l = !1; if ("object" === i.type(arguments[0]) ? (o = arguments[0], l = arguments[1], n = "multiple") : "string" === i.type(arguments[0]) && (o = arguments[0], s = arguments[1], l = arguments[2], "responsive" === arguments[0] && "array" === i.type(arguments[1]) ? n = "responsive" : void 0 !== arguments[1] && (n = "single")), "single" === n) { r.options[o] = s; } else { if ("multiple" === n) { i.each(o, function (i, e) { r.options[i] = e; }); } else { if ("responsive" === n) { for (t in s) { if ("array" !== i.type(r.options.responsive)) { r.options.responsive = [s[t]]; } else { for (e = r.options.responsive.length - 1; e >= 0; ) { r.options.responsive[e].breakpoint === s[t].breakpoint && r.options.responsive.splice(e, 1), e--; } r.options.responsive.push(s[t]); } } } } } l && (r.unload(), r.reinit()); }, e.prototype.setPosition = function () { var i = this; i.setDimensions(), i.setHeight(), !1 === i.options.fade ? i.setCSS(i.getLeft(i.currentSlide)) : i.setFade(), i.$slider.trigger("setPosition", [i]); }, e.prototype.setProps = function () { var i = this, e = document.body.style; i.positionProp = !0 === i.options.vertical ? "top" : "left", "top" === i.positionProp ? i.$slider.addClass("slick-vertical") : i.$slider.removeClass("slick-vertical"), void 0 === e.WebkitTransition && void 0 === e.MozTransition && void 0 === e.msTransition || !0 === i.options.useCSS && (i.cssTransitions = !0), i.options.fade && ("number" == typeof i.options.zIndex ? i.options.zIndex < 3 && (i.options.zIndex = 3) : i.options.zIndex = i.defaults.zIndex), void 0 !== e.OTransform && (i.animType = "OTransform", i.transformType = "-o-transform", i.transitionType = "OTransition", void 0 === e.perspectiveProperty && void 0 === e.webkitPerspective && (i.animType = !1)), void 0 !== e.MozTransform && (i.animType = "MozTransform", i.transformType = "-moz-transform", i.transitionType = "MozTransition", void 0 === e.perspectiveProperty && void 0 === e.MozPerspective && (i.animType = !1)), void 0 !== e.webkitTransform && (i.animType = "webkitTransform", i.transformType = "-webkit-transform", i.transitionType = "webkitTransition", void 0 === e.perspectiveProperty && void 0 === e.webkitPerspective && (i.animType = !1)), void 0 !== e.msTransform && (i.animType = "msTransform", i.transformType = "-ms-transform", i.transitionType = "msTransition", void 0 === e.msTransform && (i.animType = !1)), void 0 !== e.transform && !1 !== i.animType && (i.animType = "transform", i.transformType = "transform", i.transitionType = "transition"), i.transformsEnabled = i.options.useTransform && null !== i.animType && !1 !== i.animType; }, e.prototype.setSlideClasses = function (i) { var e, t, o, s, n = this; if (t = n.$slider.find(".slick-slide").removeClass("slick-active slick-center slick-current").attr("aria-hidden", "true"), n.$slides.eq(i).addClass("slick-current"), !0 === n.options.centerMode) { var r = n.options.slidesToShow % 2 == 0 ? 1 : 0; e = Math.floor(n.options.slidesToShow / 2), !0 === n.options.infinite && (i >= e && i <= n.slideCount - 1 - e ? n.$slides.slice(i - e + r, i + e + 1).addClass("slick-active").attr("aria-hidden", "false") : (o = n.options.slidesToShow + i, t.slice(o - e + 1 + r, o + e + 2).addClass("slick-active").attr("aria-hidden", "false")), 0 === i ? t.eq(t.length - 1 - n.options.slidesToShow).addClass("slick-center") : i === n.slideCount - 1 && t.eq(n.options.slidesToShow).addClass("slick-center")), n.$slides.eq(i).addClass("slick-center"); } else { i >= 0 && i <= n.slideCount - n.options.slidesToShow ? n.$slides.slice(i, i + n.options.slidesToShow).addClass("slick-active").attr("aria-hidden", "false") : t.length <= n.options.slidesToShow ? t.addClass("slick-active").attr("aria-hidden", "false") : (s = n.slideCount % n.options.slidesToShow, o = !0 === n.options.infinite ? n.options.slidesToShow + i : i, n.options.slidesToShow == n.options.slidesToScroll && n.slideCount - i < n.options.slidesToShow ? t.slice(o - (n.options.slidesToShow - s), o + s).addClass("slick-active").attr("aria-hidden", "false") : t.slice(o, o + n.options.slidesToShow).addClass("slick-active").attr("aria-hidden", "false")); } "ondemand" !== n.options.lazyLoad && "anticipated" !== n.options.lazyLoad || n.lazyLoad(); }, e.prototype.setupInfinite = function () { var e, t, o, s = this; if (!0 === s.options.fade && (s.options.centerMode = !1), !0 === s.options.infinite && !1 === s.options.fade && (t = null, s.slideCount > s.options.slidesToShow)) { for (o = !0 === s.options.centerMode ? s.options.slidesToShow + 1 : s.options.slidesToShow, e = s.slideCount; e > s.slideCount - o; e -= 1) { t = e - 1, i(s.$slides[t]).clone(!0).attr("id", "").attr("data-slick-index", t - s.slideCount).prependTo(s.$slideTrack).addClass("slick-cloned"); } for (e = 0; e < o + s.slideCount; e += 1) { t = e, i(s.$slides[t]).clone(!0).attr("id", "").attr("data-slick-index", t + s.slideCount).appendTo(s.$slideTrack).addClass("slick-cloned"); } s.$slideTrack.find(".slick-cloned").find("[id]").each(function () { i(this).attr("id", ""); }); } }, e.prototype.interrupt = function (i) { var e = this; i || e.autoPlay(), e.interrupted = i; }, e.prototype.selectHandler = function (e) { var t = this, o = i(e.target).is(".slick-slide") ? i(e.target) : i(e.target).parents(".slick-slide"), s = parseInt(o.attr("data-slick-index")); s || (s = 0), t.slideCount <= t.options.slidesToShow ? t.slideHandler(s, !1, !0) : t.slideHandler(s); }, e.prototype.slideHandler = function (i, e, t) { var o, s, n, r, l, d = null, a = this; if (e = e || !1, !(!0 === a.animating && !0 === a.options.waitForAnimate || !0 === a.options.fade && a.currentSlide === i)) { if (!1 === e && a.asNavFor(i), o = i, d = a.getLeft(o), r = a.getLeft(a.currentSlide), a.currentLeft = null === a.swipeLeft ? r : a.swipeLeft, !1 === a.options.infinite && !1 === a.options.centerMode && (i < 0 || i > a.getDotCount() * a.options.slidesToScroll)) { !1 === a.options.fade && (o = a.currentSlide, !0 !== t ? a.animateSlide(r, function () { a.postSlide(o); }) : a.postSlide(o)); } else { if (!1 === a.options.infinite && !0 === a.options.centerMode && (i < 0 || i > a.slideCount - a.options.slidesToScroll)) { !1 === a.options.fade && (o = a.currentSlide, !0 !== t ? a.animateSlide(r, function () { a.postSlide(o); }) : a.postSlide(o)); } else { if (a.options.autoplay && clearInterval(a.autoPlayTimer), s = o < 0 ? a.slideCount % a.options.slidesToScroll != 0 ? a.slideCount - a.slideCount % a.options.slidesToScroll : a.slideCount + o : o >= a.slideCount ? a.slideCount % a.options.slidesToScroll != 0 ? 0 : o - a.slideCount : o, a.animating = !0, a.$slider.trigger("beforeChange", [a, a.currentSlide, s]), n = a.currentSlide, a.currentSlide = s, a.setSlideClasses(a.currentSlide), a.options.asNavFor && (l = (l = a.getNavTarget()).slick("getSlick")).slideCount <= l.options.slidesToShow && l.setSlideClasses(a.currentSlide), a.updateDots(), a.updateArrows(), !0 === a.options.fade) { return !0 !== t ? (a.fadeSlideOut(n), a.fadeSlide(s, function () { a.postSlide(s); })) : a.postSlide(s), void a.animateHeight(); } !0 !== t ? a.animateSlide(d, function () { a.postSlide(s); }) : a.postSlide(s); } } } }, e.prototype.startLoad = function () { var i = this; !0 === i.options.arrows && i.slideCount > i.options.slidesToShow && (i.$prevArrow.hide(), i.$nextArrow.hide()), !0 === i.options.dots && i.slideCount > i.options.slidesToShow && i.$dots.hide(), i.$slider.addClass("slick-loading"); }, e.prototype.swipeDirection = function () { var i, e, t, o, s = this; return i = s.touchObject.startX - s.touchObject.curX, e = s.touchObject.startY - s.touchObject.curY, t = Math.atan2(e, i), (o = Math.round(180 * t / Math.PI)) < 0 && (o = 360 - Math.abs(o)), o <= 45 && o >= 0 ? !1 === s.options.rtl ? "left" : "right" : o <= 360 && o >= 315 ? !1 === s.options.rtl ? "left" : "right" : o >= 135 && o <= 225 ? !1 === s.options.rtl ? "right" : "left" : !0 === s.options.verticalSwiping ? o >= 35 && o <= 135 ? "down" : "up" : "vertical"; }, e.prototype.swipeEnd = function (i) { var e, t, o = this; if (o.dragging = !1, o.swiping = !1, o.scrolling) { return o.scrolling = !1, !1; } if (o.interrupted = !1, o.shouldClick = !(o.touchObject.swipeLength > 10), void 0 === o.touchObject.curX) { return !1; } if (!0 === o.touchObject.edgeHit && o.$slider.trigger("edge", [o, o.swipeDirection()]), o.touchObject.swipeLength >= o.touchObject.minSwipe) { switch (t = o.swipeDirection()) { case "left": case "down": e = o.options.swipeToSlide ? o.checkNavigable(o.currentSlide + o.getSlideCount()) : o.currentSlide + o.getSlideCount(), o.currentDirection = 0; break; case "right": case "up": e = o.options.swipeToSlide ? o.checkNavigable(o.currentSlide - o.getSlideCount()) : o.currentSlide - o.getSlideCount(), o.currentDirection = 1; } "vertical" != t && (o.slideHandler(e), o.touchObject = {}, o.$slider.trigger("swipe", [o, t])); } else { o.touchObject.startX !== o.touchObject.curX && (o.slideHandler(o.currentSlide), o.touchObject = {}); } }, e.prototype.swipeHandler = function (i) { var e = this; if (!(!1 === e.options.swipe || "ontouchend" in document && !1 === e.options.swipe || !1 === e.options.draggable && -1 !== i.type.indexOf("mouse"))) { switch (e.touchObject.fingerCount = i.originalEvent && void 0 !== i.originalEvent.touches ? i.originalEvent.touches.length : 1, e.touchObject.minSwipe = e.listWidth / e.options.touchThreshold, !0 === e.options.verticalSwiping && (e.touchObject.minSwipe = e.listHeight / e.options.touchThreshold), i.data.action) { case "start": e.swipeStart(i); break; case "move": e.swipeMove(i); break; case "end": e.swipeEnd(i); } } }, e.prototype.swipeMove = function (i) { var e, t, o, s, n, r, l = this; return n = void 0 !== i.originalEvent ? i.originalEvent.touches : null, !(!l.dragging || l.scrolling || n && 1 !== n.length) && (e = l.getLeft(l.currentSlide), l.touchObject.curX = void 0 !== n ? n[0].pageX : i.clientX, l.touchObject.curY = void 0 !== n ? n[0].pageY : i.clientY, l.touchObject.swipeLength = Math.round(Math.sqrt(Math.pow(l.touchObject.curX - l.touchObject.startX, 2))), r = Math.round(Math.sqrt(Math.pow(l.touchObject.curY - l.touchObject.startY, 2))), !l.options.verticalSwiping && !l.swiping && r > 4 ? (l.scrolling = !0, !1) : (!0 === l.options.verticalSwiping && (l.touchObject.swipeLength = r), t = l.swipeDirection(), void 0 !== i.originalEvent && l.touchObject.swipeLength > 4 && (l.swiping = !0, i.preventDefault()), s = (!1 === l.options.rtl ? 1 : -1) * (l.touchObject.curX > l.touchObject.startX ? 1 : -1), !0 === l.options.verticalSwiping && (s = l.touchObject.curY > l.touchObject.startY ? 1 : -1), o = l.touchObject.swipeLength, l.touchObject.edgeHit = !1, !1 === l.options.infinite && (0 === l.currentSlide && "right" === t || l.currentSlide >= l.getDotCount() && "left" === t) && (o = l.touchObject.swipeLength * l.options.edgeFriction, l.touchObject.edgeHit = !0), !1 === l.options.vertical ? l.swipeLeft = e + o * s : l.swipeLeft = e + o * (l.$list.height() / l.listWidth) * s, !0 === l.options.verticalSwiping && (l.swipeLeft = e + o * s), !0 !== l.options.fade && !1 !== l.options.touchMove && (!0 === l.animating ? (l.swipeLeft = null, !1) : void l.setCSS(l.swipeLeft)))); }, e.prototype.swipeStart = function (i) { var e, t = this; if (t.interrupted = !0, 1 !== t.touchObject.fingerCount || t.slideCount <= t.options.slidesToShow) { return t.touchObject = {}, !1; } void 0 !== i.originalEvent && void 0 !== i.originalEvent.touches && (e = i.originalEvent.touches[0]), t.touchObject.startX = t.touchObject.curX = void 0 !== e ? e.pageX : i.clientX, t.touchObject.startY = t.touchObject.curY = void 0 !== e ? e.pageY : i.clientY, t.dragging = !0; }, e.prototype.unfilterSlides = e.prototype.slickUnfilter = function () { var i = this; null !== i.$slidesCache && (i.unload(), i.$slideTrack.children(this.options.slide).detach(), i.$slidesCache.appendTo(i.$slideTrack), i.reinit()); }, e.prototype.unload = function () { var e = this; i(".slick-cloned", e.$slider).remove(), e.$dots && e.$dots.remove(), e.$prevArrow && e.htmlExpr.test(e.options.prevArrow) && e.$prevArrow.remove(), e.$nextArrow && e.htmlExpr.test(e.options.nextArrow) && e.$nextArrow.remove(), e.$slides.removeClass("slick-slide slick-active slick-visible slick-current").attr("aria-hidden", "true").css("width", ""); }, e.prototype.unslick = function (i) { var e = this; e.$slider.trigger("unslick", [e, i]), e.destroy(); }, e.prototype.updateArrows = function () { var i = this; Math.floor(i.options.slidesToShow / 2), !0 === i.options.arrows && i.slideCount > i.options.slidesToShow && !i.options.infinite && (i.$prevArrow.removeClass("slick-disabled").attr("aria-disabled", "false"), i.$nextArrow.removeClass("slick-disabled").attr("aria-disabled", "false"), 0 === i.currentSlide ? (i.$prevArrow.addClass("slick-disabled").attr("aria-disabled", "true"), i.$nextArrow.removeClass("slick-disabled").attr("aria-disabled", "false")) : i.currentSlide >= i.slideCount - i.options.slidesToShow && !1 === i.options.centerMode ? (i.$nextArrow.addClass("slick-disabled").attr("aria-disabled", "true"), i.$prevArrow.removeClass("slick-disabled").attr("aria-disabled", "false")) : i.currentSlide >= i.slideCount - 1 && !0 === i.options.centerMode && (i.$nextArrow.addClass("slick-disabled").attr("aria-disabled", "true"), i.$prevArrow.removeClass("slick-disabled").attr("aria-disabled", "false"))); }, e.prototype.updateDots = function () { var i = this; null !== i.$dots && (i.$dots.find("li").removeClass("slick-active").end(), i.$dots.find("li").eq(Math.floor(i.currentSlide / i.options.slidesToScroll)).addClass("slick-active")); }, e.prototype.visibility = function () { var i = this; i.options.autoplay && (document[i.hidden] ? i.interrupted = !0 : i.interrupted = !1); }, i.fn.slick = function () { var i, t, o = this, s = arguments[0], n = Array.prototype.slice.call(arguments, 1), r = o.length; for (i = 0; i < r; i++) { if ("object" == typeof s || void 0 === s ? o[i].slick = new e(o[i], s) : t = o[i].slick[s].apply(o[i].slick, n), void 0 !== t) { return t; } } return o; }; }); })(); for (d = 0; d < this.data.dimensions.length; d++) { if (this.data.dimensions[d].usable) { this.data.dimensions[d].matchMedia = window.matchMedia(this.data.dimensions[d].media); this.data.dimensions[d].matchMedia.d = d; if (this.data.dimensions[d].matchMedia.matches) { this.initializeCarousel(this.data.dimensions[d]); } else { initializeOnBreakpoint(this.data.dimensions[d]); } } }}function Carousel_initializeCarousel(e) { const self = this; log("function initializeCarousel executed!"); if (!e.matchMedia.matches) { return; } var dim = e.matchMedia.d, $c = $("#" + self.instance.tagId + " .slick-carousel-dimension" + dim); $c.append(self.buildSlides(dim)); $c.on("init", function (e) { var $c = $(e.currentTarget), $d = $c.find(".slick-dots"), pp, variance = 5; $c.find("img").each(function (i, o) { var w; function setupImage(o) { var w = o.width(); if (1 < w) { o.css({"max-width": w, "width": "100%", "margin": "auto"}); } else { setTimeout(setupImage, 100, o); } } o = $(o); setupImage(o); }); if (!self.data.hideDots) { $d.prepend("
"); $pp = $c.find(".carrusel-reproducción-pausa"); if (self.data.autoPlay) { $pp.addClass("carrusel-pausa").html("pausa"); } else { $pp.addClass("carousel-play").html("pause"); } function pause(e) { var $pp = $(e.currentTarget), $c = $pp.closest(".slick -carrusel"); $pp.html("reproducir"); $c.slick("slickPause"); $pp.removeClass("carrusel-pausa"); $pp.addClass("carrusel-reproducir"); } $c.on("clic", ".carrusel-reproducir", función (e) { var $pp = $(e.objetivo actual), $c = $pp.más cercano(".slick-carrusel"); $pp .html("pausa"); $c.slick("slickPlay"); $pp.removeClass("carrusel-reproducir"); $pp.addClass("carrusel-pausa"); }); $c.on( "clic", ".carrusel-pausa", función (e) { pausa(e); }); $c.on("clic", ".slick-arrow, .slick-dots button", función (e) { var $d = $(e.objetivoactual); e.objetivoactual = $d.más cercano(".slick-carrusel").find(".carrusel-reproducir-pausa"); pausa(e); }); setTimeout (función () { $d.width($d.width() + varianza).css({derecha: 0, izquierda: 0}); }, 1000); } }); log("self.config:" , self.config); $c.slick({puntos: self.config.slick.dots, reproducción automática: self.data.autoPlay, velocidad de reproducción automática: self.data.delayTime, pauseOnHover: self.config.slick.pauseOnHover, slidesToShow: e.slidesToShow, slidesToScroll: e.slidesToScroll, infinite: self.data.infinite});}function Carousel_convertToLinkObj(s) { const self = this; if (!s.hasOwnProperty("enlace")) { s.enlace = {}; if (s.hasOwnProperty("linkURL")) { s.link.url = s.linkURL; } if (s.hasOwnProperty("linkText")) { s.link.text = s.linkText; } }}function Carousel_buildSlides(d) { const self = this; var cadena = ""; for (i = 0; i < self.data.slides.length; i++) { self.convertToLinkObj(self.data.slides[i]); if (self.data.slides[i].imageURL.length > d && "" !== self.data.slides[i].imageURL[d]) { str += "
"; cadena += "
"; cadena += "
"; cadena += "
"; } } return str;}function isNull(v) { return N === v;}function isUndefined(v) { return U === typeof v;}function isBoolean(v) { return B === typeof v;}function isFunction(v) { return F === typeof v;}function isNumber(v) { return "number" === typeof v;}function isString(v) { return S === typeof v;}function isStringEmpty(v) { return E === v;}function isArray(v) { return Array.isArray(v);}function isArrayEmpty(v) { return v.length ? false : true;}function isObject(v) { return O === typeof v;}function isObjectEmpty(v) { var i, c = true; for (i in v) { c = false; break; } return c;}function isObjectNotEmpty(v) { return !isObjectEmpty(v);}function isObjectAndEmpty(v) { return isObject(v) && isObjectEmpty(v);}function isObjectAndNotEmpty(v) { return isObject(v) && isObjectNotEmpty(v);}function isBaseObject(v) { return O === typeof v && N !== v && "Object" === v.constructor.name;}function isBaseObjectAndEmpty(v) { return isBaseObject(v) && isObjectEmpty(v);}function isBaseObjectAndNotEmpty(v) { return isBaseObject() && isObjectNotEmpty(v);}function isEmpty(v) { var i, c; return isNull(v) || isUndefined(v) || isStringEmpty(v) || (isObject(v) && isObjectEmpty(v)) || (isArray(v) && isArrayEmpty(v));}function toBoolean(v, d) { var r = d; if (isUndefined(d) || !isBoolean(d)) { d = false; } if (isNaN(v)) { r = String(!d).toUpperCase() === v.toUpperCase() ? !d : d; } else { r = Number(!d) === v ? !d : d; } return r;}function getUrlParm(url, name) { var str = url, s = str.indexOf(name + "="), e, p, value = ""; if (-1 !== s) { e = str.indexOf("&", s); if (-1 === e) { e = str.length; } p = str.substring(s, e).split("="); if (1 < p.length) { value = p[1]; } } return value;}function addUrlParms(url, parms) { const q = "?", a = "&"; var sep = q, pos = -1, p; if (!url) { url = ""; } pos = url.lastIndexOf(q); if (-1 !== pos) { if (url.length - 1 === pos) { sep = E; } else { sep = a; } } for (p in parms) { if (U !== typeof parms[p] && E !== parms[p]) { url += sep + p + "=" + parms[p]; sep = a; } } return url;}function objPropDef(o, pn, dv, vt, iv, npn) { var i = 1; function isMatch(c, cw, isTyped) { var ret = false, i; if (isFunction(cw)) { ret = cw(c); } else { if (isTyped) { c = typeof c; } if (Array.isArray(cw)) { for (i = 0; i < cw.length; i++) { if (c === cw[i]) { ret = true; break; } } } } return ret; } function isDefault(o, p) { var ret = false; if (o.hasOwnProperty(p) && o[p] !== dv) { if (!isMatch(o[p], vt, true) || isMatch(o[p], iv, false)) { ret = true; } } else { ret = true; } return ret; } if (isString(npn)) { if (isDefault(o, npn)) { if (isDefault(o, pn)) { o[npn] = dv; } else { o[npn] = o[pn]; } } delete o[pn]; } else { if (isDefault(o, pn)) { o[pn] = dv; } }}function jsonClone(json) { const FS = "\u0192s", functions = []; var clone; function replacer(n, v) { var nv = {}; if (isFunction(v)) { nv[FS] = functions.push(v) - 1; v = nv; } return v; } function reviver(n, v) { if (isBaseObject(v) && v.hasOwnProperty(FS)) { v = functions[v[FS]]; } return v; } if (json) { clone = JSON.parse(JSON.stringify(json, replacer), reviver); } return clone;}function jsonCompare(a, b) { return (JSON.stringify(a) === JSON.stringify(b));}function performJsonAjaxRequests(requests, success, failure, requestsData, simulateSendFunc, simTime) { const MIME_TYPE = "application/json"; var reqs = jsonClone(requests), name, ready, rn, co, results = {}, pubsub = {}, isSim = isFunction(simulateSendFunc), allDone = false; requestsData = jsonClone(isBaseObject(requestsData) ? requestsData : {}); if (!isNumber(simTime)) { simTime = 0; } function defaultSimulateSendFunc(request, data, handle) { handle({type: "load", currentTarget: {responseText: JSON.stringify(data)}}); } if (!isSim) { simulateSendFunc = defaultSimulateSendFunc; } function sub(name, func, data) { if (!pubsub[name]) { pubsub[name] = []; } pubsub[name].push({func: func, data: data}); } function pub(name, data) { var subs = pubsub[name], i, s; if (subs) { for (i = 0; i < subs.length; i++) { s = subs[i]; setTimeout(function (s) { s.func(name, data, s.data); }, 0, s); } } } function can(name, func) { var subs = pubsub[name], i, s; if (subs) { for (i = 0; i < subs.length; i++) { s = subs[i]; if (func === s.func) { subs.splice(i, 1); break; } } } } function isRequestReady(ready) { var ret = true, i; function isReadyAnds(ready) { var ret = true, r; if (Object.keys(ready).length) { for (r in ready) { if (results[r]) { if (ready[r] !== results[r].success) { ret = -1; break; } } else { ret = false; break; } } } return ret; } function isReadyOrs(ready) { var ret = true; if (ready.length) { for (i = 0; i < ready.length; i++) { ret = isReadyAnds(ready[i]); if (-1 < ret) { if (ret) { break; } } else { ready.splice(i--, 1); } } if (0 > ret) { if (0 < i) { ret = false; } else { ret = -1; } } } else { ret = -1; } return ret; } if (!isUndefined(ready) && !isNull(ready)) { if (isArray(ready)) { ret = isReadyOrs(ready); } else { if (isObject(ready)) { ret = isReadyAnds(ready); } else { if (isFunction(ready)) { ret = ready(jsonClone(results)); } else { if (isBoolean(ready)) { ret = ready ? true : -1; } } } } } return ret; } function mapData(request, resultsData) { var map = request.map, requestData = requestsData[request.name], pName, resName, resResults; if (map && isFunction(map)) { if (!requestData) { requestData = requestsData[request.name] = {}; } map(requestData, jsonClone(resultsData)); } else { if (isObjectAndNotEmpty(request.subscribes) && isObjectNotEmpty(resultsData) && isObject(requestData)) { for (pName in requestData) { if (isUndefined(requestData[pName])) { for (resName in resultsData) { resResults = resultsData[resName].out; if (resResults.hasOwnProperty(pName) && !isUndefined(resResults[pName])) { requestData[pName] = resResults[pName]; } } } } } } } function isRetry(retry, status, type) { var ret = false, wt; function isCount(retry) { var ret = false; if (isNumber(retry.max)) { if (0 < retry.max) { if (!retry.count) { retry.count = 0; } if (retry.count < retry.max) { ret = true; } } } else { ret = true; } return ret; } function isStatus(s, status) { var ret = false; if (isNumber(s)) { if (status === s) { ret = true; } } else { if (isArray(s)) { if (-1 !== s.indexOf(status)) { ret = true; } } } return ret; } if (retry) { if (isCount(retry)) { if (isObject(retry.when)) { if (retry.when.status) { ret = isStatus(retry.when.status, status); } if (!ret && (wt = retry.when[type])) { if (wt) { if (isBoolean(wt)) { ret = wt; } else { ret = isStatus(retry.when[type], status); } } } } else { ret = true; } } } return ret; } function makeRequest(request, data) { const MG = "GET", MP = "POST", cache = jsonAjaxResponseCache, pending = jsonAjaxInProgressRequests; var n, req = new XMLHttpRequest(), rname = request.name; function sets(target, method, sets) { var name; if (sets) { for (name in sets) { target[method](name, sets[name]); } } } function handle(e, fromCache) { var result, target = e.currentTarget || e.target || e.srcElement, responseText = target.responseText, reqStatus = isSim ? e.status : req.status; function isSuccess(e, r) { var ret = true; if (isFunction(request.isSuccess)) { ret = request.isSuccess(e, r); } return ret; } if (isRetry(request.retry, reqStatus, e.type)) { setTimeout(makeRequest, 0, request, data); } else { if (pending.hasOwnProperty(request.url) && pending[request.url].request === request) { delete pending[request.url]; } result = results[rname] = {}; result.fromCache = (!!fromCache); if (requestsData[rname]) { result.in = requestsData[rname]; } if ("load" === e.type) { try { result.out = JSON.parse(responseText); if (isSuccess(e, result.out)) { if (!fromCache) { saveResponse(request, data, e); } result.success = true; if (isFunction(request.success)) { setTimeout(request.success, 0, results); } } else { result.success = false; result[e.type] = req.status; result.event = e; } } catch (e) { result.success = false; result.required = request.required; result.parse = "Invalid Json Body!"; result.event = e; if (isFunction(request.failure)) { setTimeout(request.failure, 0, results); } } } else { result.success = false; result.required = request.required; result[e.type] = req.status; result.event = e; if (isFunction(request.failure)) { setTimeout(request.failure, 0, results); } } pub(rname, request); } } function buildCacheKey(request, data) { return request.url + (data ? JSON.stringify(data) : E); } function saveResponse(request, data, e) { if (request.cache && request.url && "" !== request.url) { log("storing response to cache:", request, e); cache[buildCacheKey(request, data)] = {e: e, data: data, time: new Date().getTime()}; } } function isCached(request, data) { const time = new Date().getTime(), cacheKey = buildCacheKey(request, data); var ret = false, cacheValue; if (request.cache && cache.hasOwnProperty(cacheKey)) { cacheValue = cache[cacheKey]; log("request.cache:", request.cache, "cacheValue.time:", cacheValue.time, "+=", cacheValue.time + request.cache, "time:", time); if (0 > request.cache || cacheValue.time + request.cache > time) { log("response cache used, request:", request, "response:", jsonClone(cacheValue.e)); handle(cacheValue.e, true); ret = true; } else { log("deleting cache for request:", request, jsonClone(cache[request._url])); delete cache[cacheKey]; } } return ret; } function addHandlers(req) { req.addEventListener("load", handle); req.addEventListener("error", handle); req.addEventListener("abort", handle); req.addEventListener("timeout", handle); } if (request.url && "" !== request.url) { if (pending.hasOwnProperty(request.url) && jsonCompare(pending[request.url].data, data)) { log("batch pending: found match!", request.url, "hold!"); addHandlers(pending[request.url].req); request.held = true; } else { if (!request.method) { request.method = MG; } if (MG === request.method) { request._url = addUrlParms(request.url, data); } else { request._url = request.url; } if (!isCached(request, data)) { if (isSim) { setTimeout(simulateSendFunc, 0, request, data, handle); } else { req.overrideMimeType("application/json"); addHandlers(req); sets(req, "addEventListener", request.handlers); req.open(request.method, request._url); sets(req, "setRequestHeader", request.headers); if (0 < request.timeout) { req.timeout = request.timeout; } if (MG === request.method) { try { req.send(); pending[request.url] = {request: request, data: data, req: req}; } catch (e) { log("req.send() Exception:", e); } } else { if (MP === request.method) { req.setRequestHeader("Content-Type", "application/json"); try { req.send(JSON.stringify(data)); pending[request.url] = {request: request, data: data, req: req}; } catch (e) { log("req.send() Exception:", e); } } else { log("Invalid request method.", "request:", request); } } } } } } else { setTimeout(defaultSimulateSendFunc, 0, request, data, handle); } } function performRequest(request, requestsData) { var isReady = false; isReady = isRequestReady(request._ready); if (-1 === isReady) { results[request.name] = {success: false, ready: request._ready}; if (isFunction(request.failure)) { setTimeout(request.failure, 0, results); } pub(request.name, request); } else { if (isReady) { mapData(request, results); makeRequest(request, requestsData[request.name]); } } } function startBatch(requests, requestsData) { var name, i, keys, request; function extractSubscribes(ready) { var subs = {}, i; function add(obj) { var keys = obj, i; if (!isArray(obj)) { keys = Object.keys(obj); } for (i = 0; i < keys.length; i++) { subs[keys[i]] = true; } } if (ready) { if (isArray(ready)) { for (i = 0; i < ready.length; i++) { add(ready[i]); } } else { if (isObject(ready)) { add(ready); } else { if (isFunction(ready)) { if (ready.subs) { add(ready.subs); } else { add(requests); } } } } } return subs; } function publish(name, pubData, subData) { can(name, publish); performRequest(subData, requestsData); } function checkDone(name, pubData, subData) { var isDone = true, isSuccess = true; if (allDone) { return; } for (name in requests) { if (!results[name]) { isDone = false; break; } } if (isDone) { allDone = true; pubsub = {}; for (name in requests) { if (requests[name].required && !results[name].success) { isSuccess = false; break; } } if (isSuccess) { success(results, requests); } else { failure(results, requests); } } } for (name in requests) { request = requests[name]; request.name = name; if (!isNumber(request.cache)) { request.cache = 0; } objPropDef(request, "required", true, ["boolean"]); if (request.hasOwnProperty("ready")) { request._ready = jsonClone(request.ready); } request.subscribes = extractSubscribes(request._ready); keys = Object.keys(request.subscribes); for (i = 0; i < keys.length; i++) { sub(keys[i], publish, request); } sub(name, checkDone, requests[name]); } for (name in requests) { performRequest(requests[name], requestsData); } } startBatch(reqs, requestsData);}function pad(val, count, str) { var i; val = "" + val || ""; count = count || 0; str = "" + str || ""; if (0 > count) { count = -count; for (i = val.length; i < count; i++) { val = val + str; } } else { for (i = val.length; i < count; i++) { val = str + val; } } return val;}function createId(type) { var c = config.ids, pre = c.prefix, sep = c.separator, td = c.type, sd = c.system, system, date = new Date(), id; type = onEtoVal(type, td); type = pad(type, -3, c.pad).substr(-0, 3).toUpperCase(); system = pad(sd, -3, c.pad).substr(-0, 3).toUpperCase(); id = pre + sep + type + sep + system + pad(date.getTime(), 16, "0") + pad(nextId++, 16, "0"); return id;}function onNtoE(v) { return N === v ? E : v;}function onEtoVal(v, val) { return E === v ? val : v;}function log() { var d, s, i; if (!DEBUG) { return; } d = "componentManager:"; s = "console.log(d"; for (i = 0; i < arguments.length; i++) { s += ",arguments[" + i + "]"; } s += ");"; eval(s);}function newInstance(cName, cData, cConfig) { var instance = null, template = {}; if (U === typeof cConfig) { cConfig = {}; } if (cNames.hasOwnProperty(cName)) { instance = {}; template = cNames[cName]; copyObject(instance, template); instance.data = mergeObjects(instance.default.data, cData); instance.config = mergeObjects(instance.default.config, cConfig); if (!template.hasOwnProperty("class")) { template["class"] = {}; } instance["class"] = template["class"]; } else { log("ERROR:", "Definition for component", cName, "NOT found!"); } return instance;}function buildStyle(style, parents) { const E = "", S = " "; var a, p, str = "", sep = "", pre = style.pre, sel = style.sel, post = style.post, attr = style.attr; function buildAttrString(attr) { var a, str = ""; for (a in attr) { str += a + ":" + attr[a] + ";"; } return str; } if (isEmpty(attr) || !isObject(attr) && !isArray(attr)) { return E; } if (isEmpty(parents)) { parents = E; } if (isEmpty(pre)) { pre = E; } if (isEmpty(sel)) { sel = E; } if (isEmpty(post)) { post = E; } if (isString(sel)) { str += parents + S + pre + (isStringEmpty(pre) ? E : S) + sel + (isStringEmpty(sel) ? E : S) + post; } else { if (isArray(sel)) { for (p = 0; p < sel.length; p++) { str += sep + parents + S + pre + (isStringEmpty(pre) ? E : S) + sel[p] + (isStringEmpty(sel[p]) ? E : S) + post; sep = ","; } } } if (isStringEmpty(str)) { return E; } str += "{"; if (isArray(attr)) { for (p = 0; p < attr.length; p++) { str += buildAttrString(attr[p]); } } else { str += buildAttrString(attr); } str += "}"; return str;}function buildTagString(tag) { var tstr = "", astr = "", cstr = "", a, p; if (tag.hasOwnProperty("content") && isString(tag.content)) { cstr += tag.content; } else { if (isArray(tag.content)) { } } if (tag.hasOwnProperty("name") && isString(tag.name) && !isStringEmpty(tag.name)) { if (tag.hasOwnProperty("attr") && isObject(tag.attr)) { for (a in tag.attr) { astr += " " + a + "=\"" + tag.attr[a] + "\""; } } if (tag.hasOwnProperty("prop") && isObject(tag.prop)) { for (p in tag.prop) { if (tag.prop[p]) { astr += " " + p; } } } tstr += "<" + tag.name + astr + ">" + cstr + "" + tag.name + ">"; } return tstr;}function buildComponentTag(contentFunc) { const _self = this; var tagId, html = ""; if (!_self.instance || !_self.instance.tagId) { tagId = createId("COM"); _self.instance = {tagId: tagId}; } else { tagId = _self.instance.tagId; } html += "
"; if (contentFunc) { html += contentFunc.call(_self); } html += "
"; return html;}function copyObjectNameMapDefault(sourceName, sourceValue) { return sourceName;}function copyObject(d, s, nameMap) { var j, k, js, stack = []; if ("función" !== typeof nameMap ) { nameMap = copyObjectNameMapDefault; } stack.push({s: s, d: d}); while (0 < stack.length) { p = stack.pop(); s = p.s; d = p.d; for (j in s) { js = nameMap(j, s[j]); if ("cadena" === tipo de s[j]) { d[js] = s[j]; } else { if ("objeto" = == tipo de s[j]) { if (Array.isArray(s[j])) { if (U === tipo de d[js]) { d[js] = []; } for (k = 0; k < s[j].longitud; k++) { if ("cadena" === tipo de s[j][k]) { d[js][k] = s[j][k]; } else { if ("objeto" === tipo de s[j][k]) { if (U === tipo de d[js][k]) { if (Array.isArray(s[j][k])) { d [js][k] = []; } else { d[js][k] = {}; } } } } stack.push({s: s[j][k], d: d[js][ k]}); } } else { if (U === tipo de d[j]) { d[js] = {}; } stack.push({s: s[j], d: d[js]} ); } } else { d[js] = s[j]; } } } }}function mergeObjects() { var i = 0, n, r = {}, p; for (i = 0; i < argumentos. longitud;i++) { n = argumentos[i]; copiarObjeto(r, n); } return r;}function persist() { var _self = this; if (!coms.hasOwnProperty(_self.instance.tagId)) { coms[_self.instance.tagId] = _self; }}función Bopis_html() { const _self = esto; var f, cadena = ""; f = _self.config.característica; if (_self.config.features.hasOwnProperty(f)) { _self.feature = _self.config.features[f]; if (_self.hasOwnProperty(f) && _self.isFunction(_self[f])) { str += _self[f](); } } return str;}function Bopis_getDeliveryConfigBatch(callback) { const _self = this; const SP = "sitePreferences", DC = "deliveryConfig"; constante AS = [S], AB = [B]; const lote = {}; lote[SP] = {"url": _self.baseAjaxUrl + "SitePreferences-GetPreferencesJSON?prefcontext=deliveryOptions", "cache": 60000}; lote[DC] = {"url": _self.baseAjaxUrl + "Stores-DeliveryConfig", "caché": 1800000, éxito: función (resultados) { if (resultados.deliveryConfig.success && resultados.deliveryConfig.out.sddZipCode) { if (window.libs && window.libs.notify) { window.libs.notify.api.fire("dc-done", {sddZip: results.deliveryConfig.out.sddZipCode}); } } }}; _self.performJsonAjaxRequests(batch, function (r, rq) { var d, n, data = {}; function merge(d, s) { var n; for (n in s) { d[n] = s[n] ; } } merge(datos, r[SP].out); merge(datos, r[DC].out); _self.objPropDef(datos, "storeId", E, AS); _self.objPropDef(datos, "zipCode ", E, AS); _self.objPropDef(datos, "sddZipCode", E, AS); _self.objPropDef(datos, "StoreInventoryService", "dom", AS, null, "storeInvService"); _self.objPropDef(datos , "FIND_IN_STORE_ENABLE", _self.default.data.fisEnabled, AB, null, "fisEnabled"); _self.objPropDef(data, "enableStorePickUp", _self.default.data.bopisEnabled, AB, null, "bopisEnabled"); _self .objPropDef(datos, "habilitarSameDayDeliveryPDP", _self.default.data.sddEnabled, AB, null, "sddEnabled"); _self.objPropDef(datos, "useSFCCforStoreInv", false, AB, null, "storeInvSfccOnly"); objPropDef(datos , "BOPISPickupReadyHours", 4, ["número"], nulo, "readyHours"); if (_self.isFunction(callback)) { try { callback(data); } catch (e) { log("Exception:", e); } } }, function (r) { log("error en getDeliveryConfigBatch: resultados:", r); });}function Bopis_getStoresByZipPidBatch(pid, orin, zip, sddZip, sddStoreId, callback) { const _self = this; const prod = "www.belk.com", dev = "www.belkdev.com"; host var = prod; if (prod !== ventana.ubicación.host) { host = dev; } const lote = {deliveryConfig: {url: _self.baseAjaxUrl + "Stores-DeliveryConfig", "cache": 1800000, requerido: falso, éxito: función (resultados) { if (resultados.deliveryConfig.success && resultados.deliveryConfig.out .sddZipCode) { if (window.libs && window.libs.notify) { window.libs.notify.api.fire("dc-done", {sddZip: results.deliveryConfig.out.sddZipCode}); } } }}, storeCall: {url: _self.baseAjaxUrl + "Stores-GetStoresByZip", "cache": 60000, requerido: false}, InventoryCall: {url: "https://" + host + "/inventory/" + _self.data.storeInvService, método: "POST", requerido: falso, "caché": 60000, tiempo de espera: 3000, listo: {storesCall: true}, mapa: función (destino, resultados) { const fuente = resultados.storesCall .afuera; var yo; destino.tiendas = []; for (i = 0; i < source.length; i++) { dest.stores[i] = source[i].storeId; } }, isSuccess: function (e, r) { var ret = true; if (r.statusCode) { log("statusCode en respuesta de inventario:", r); ret = falso; } if (!r.hasOwnProperty(pid)) { log("falta pid", pid, " en respuesta de inventario:", r); ret = falso; } retorno ret; }}, backupCall: {url: _self.baseAjaxUrl + "StoreInventory-RedesignInventory", "cache": 60000, required: false, ready: [{storesCall: false}, {inventoryCall: false}]}, successNode: {ready: [{storesCall: true, InventoryCall: true}, {backupCall: true}], required: true, map: function (dest, r) { var id, n, o; if (r.deliveryConfig.success) { for (n in r.deliveryConfig.out) { dest[n] = r.deliveryConfig.out[n]; } objPropDef(dest, "BOPISPickupReadyHours", 4, ["number"], null, "readyHours"); } if (r.storesCall.success && r.inventoryCall.success) { dest.stores = r.storesCall.out; for (n = 0; n < dest.stores.length; n++) { dest.stores[n].id = dest.stores[n].storeId; eliminar destino.tiendas[n].storeId; } if (r.inventoryCall.out[pid]) { o = r.inventoryCall.out[pid]; for (n = 0; n < dest.stores.length; n++) { id = dest.stores[n].id; if (o.hasOwnProperty(id)) { dest.stores[n].quantity = o[id]; if (0 < o[id]) { dest.success = true; } } else { destino.tiendas[n].cantidad = 0; } } } else { for (n = 0; n < destino.tiendas.longitud; n++) { destino.tiendas[n].cantidad = 0; } } _self.fixStoreData(destino); if (E !== sddStoreId) { for (n = 0; n < dest.stores.length; n++) { if (sddStoreId === dest.stores[n].id) { dest.sddStore = dest.stores[ norte]; romper; } } } } else { if (r.backupCall.success) { for (n in r.backupCall.out) { dest[n] = r.backupCall.out[n]; } } else { log("getStoresByZipPidBatch alcance de SuccessNode con datos no válidos."); } } }}}, data = {storesCall: {zipCode: zip, sddZipCode: sddZip, sddStore: sddStoreId}, InventoryCall: {items: [{pid: pid, orin: orin}]}, backupCall: {pid: pid, código postal: zip, sddZip: sddZip, sddStoreId: sddStoreId}}; function suc(r, rq) { var data = r.successNode.out, parms = {pid: pid, orin: orin, zip: zip, sddZip: sddZip, sddStoreId: sddStoreId}; if (_self.isFunction(callback)) { try { callback(parámetros, datos); } catch (e) { log("Excepción:", e); } } } function fai(r) { log("fallo del lote: resultados:", r); } if (_self.data.storeInvSfccOnly) { lote.storesCall.ready = false; lote.inventarioCall.ready = falso; } _self.performJsonAjaxRequests(batch, suc, fai, data);}function Bopis_validateData(cData) { const _self = this; var valid = {productOnlineOnly: false, bopisEnabled: false, findInStoreEnabled: false, curbSidePickupEnabled: false, bopisProduct: false, bopisSku: false, zip: false, storeId: false, skuId: false, productInStock: false, skuStockLevel: false, surchargeAmount: false, isPreOrderEnabled: false, showPreOrder: false, isQuickView: false, releaseDate: false, preOrderPromoId: false, preOrderPromoDetails: false, storeSearchDistance: false}, allValid = false; if (!_self.isBoolean(cData.productOnlineOnly)) { cData.bopisEnabled = _self.toBoolean(cData.bopisEnabled, _self.default.data.productOnlineOnly); } if (_self.isBoolean(cData.productOnlineOnly)) { valid.productOnlineOnly = true; } if (!_self.isBoolean(cData.bopisEnabled)) { cData.bopisEnabled = _self.toBoolean(cData.bopisEnabled, _self.default.data.bopisEnabled); } if (_self.isBoolean(cData.bopisEnabled)) { valid.bopisEnabled = true; } if (!_self.isBoolean(cData.findInStoreEnabled)) { cData.findInStoreEnabled = _self.toBoolean(cData.findInStoreEnabled, _self.default.data.findInStoreEnabled); } if (_self.isBoolean(cData.findInStoreEnabled)) { valid.findInStoreEnabled = true; } if (_self.isBoolean(cData.curbSidePickupEnabled)) { valid.curbSidePickupEnabled = true; } if (!_self.isBoolean(cData.bopisProduct)) { cData.bopisProduct = _self.toBoolean(cData.bopisProduct, _self.default.data.bopisProduct); } if (_self.isBoolean(cData.bopisProduct)) { valid.bopisProduct = true; } if (!_self.isBoolean(cData.bopisSku)) { cData.bopisSku = _self.toBoolean(cData.bopisSku, _self.default.data.bopisSku); } if (_self.isBoolean(cData.bopisSku)) { valid.bopisSku = true; } if (!_self.isString(cData.zip)) { cData.zip = new String(cData.zip); } if (5 !== cData.zip.length) { cData.zip = cData.zip.substring(0, 5); } if (_self.isStringEmpty(cData.zip) || !isNaN(cData.zip) && (5 === cData.zip.length)) { valid.zip = true; } if (_self.isNumber(cData.storeId)) { cData.storeId = new String(cData.storeId); } if (!_self.isString(cData.storeId) || isNaN(cData.storeId)) { cData.storeId = _self.default.data.storeId; } if (_self.isString(cData.storeId) && !isNaN(cData.storeId)) { valid.storeId = true; } if (_self.isNumber(cData.skuId)) { cData.skuId = new String(cData.skuId); } if (!_self.isString(cData.skuId)) { cData.skuId = _self.default.data.skuId; } if (_self.isString(cData.skuId)) { valid.skuId = true; } if (!_self.isBoolean(cData.productInStock)) { cData.productInStock = _self.toBoolean(cData.productInStock, _self.default.data.productInStock); } if (_self.isBoolean(cData.productInStock)) { valid.productInStock = true; } if (!_self.isNumber(cData.skuStockLevel) && !isNaN(cData.skuStockLevel)) { cData.skuStockLevel = Número(cData.skuStockLevel); } if (_self.isNumber(cData.skuStockLevel)) { valid.skuStockLevel = true; } if (_self.isNumber(cData.surchargeAmount)) { valid.surchargeAmount = true; } if (_self.isBoolean(cData.isPreOrderEnabled)) { valid.isPreOrderEnabled = true; } if (_self.isBoolean(cData.showPreOrder)) { valid.showPreOrder = true; } if (_self.isBoolean(cData.isQuickView)) { valid.isQuickView = true; } if (_self.isString(cData.releaseDate)) { valid.releaseDate = true; } if (_self.isString(cData.preOrderPromoId)) { valid.preOrderPromoId = true; } if (_self.isString(cData.preOrderPromoDetails)) { valid.preOrderPromoDetails = true; } if (_self.isNumber(cData.storeSearchDistance)) { valid.storeSearchDistance = true; } else { cData.storeSearchDistance = _self.default.data.storeSearchDistance; } for (i in valid) { if (valid[i]) { allValid = true; } más { allValid = false; romper; } } devolver todos los válidos? true : valid;}function Bopis_reset() { const _self = this; _self.error = falso; _self.resultados de la búsqueda = {}; _self.copyObject(_self.searchResults, _self.default.config.init.searchResults); _self.tiendas = []; _self.hasPreOrderResponse = falso; _self.shipPromoMsg = ""; _self.isShipPromoMsg = falso; _self.selectedStoreIds = [];}función Bopis_plp() { const _self = esto; var str = "", storeName = _self.config.messaging.selectStore, ids = "", i, urlStoreId = "", mm = window.matchMedia("(max-width:767px)"); if (isUndefined(_self.config.messaging.bopis) || !isString(_self.config.messaging.bopis) || isStringEmpty(_self.config.messaging.bopis)) { _self.config.messaging.bopis = _self.default .config.mensajería.bopis; } _self.checked = false; if (-1 !== window.location.href.indexOf("searchType=FreePickup")) { _self.checked = true; } función buildBopisPromoMsg() { volver "" + _self.promoMsg + ""; } function build() { var str = "", isStore = !_self.isObjectEmpty(_self.data.store), bopisPromoAssetID = window.SitePreferences.BOPIS_CLEARANCE_COUPON_ENABLED ? "bopis-clearance-promo" : "bopis-promo-messaging "; cadena += "" + _self.config.messaging.bopis + _self.pickupTodayOrTomorrow(); if (1 < _self.selectedStoreIds.length) { storeName = _self.config.messaging.atStoresX.replace("X", _self.selectedStoreIds.length); } else { if (isStore) { storeName = _self.data.store.name; } } str += " " + _self.buildStoreSelectionToggle(storeName); str += ""; cadena += "
"; cadena += ""; if (!_self.isStringEmpty(_self.promoMsg)) { str += buildBopisPromoMsg(); } else { _self.getBopisPromoMessaging(bopisPromoAssetID, function (data) { if (data.hasOwnProperty("isOnline") && data.isOnline && data.hasOwnProperty("assetContent") && !_self.isStringEmpty(data.assetContent)) { _self.promoMsg = data.assetContent;$("#" + _self.instance.tagId + " .promo").html(buildBopisPromoMsg ()); } }); } cadena += ""; const newMoveSel = "#bopis-pickup"; const oldMoveSel = "#secundario"; var moveToSel = newMoveSel; if (!window.facetNav || !window.facetNav.nav) { moveToSel = oldMoveSel; } var moveTryCount = 0 ; var toi = null; function startMoveTo(obj, toSel) { if (toi) { clearTimeout(toi); toi = null; } moveTo(obj, toSel); } function moveTo(obj, toSel) { var to = document. querySelector(toSel), plp; if (!_self.isNull(to)) { to.prepend(obj); _self.addStoreSelectionHandlers(); switch (toSel) { case oldMoveSel: case newMoveSel: $("#results-products" ).css({ancho: "auto"}); $(".bopis-filter-options").css({display: "none"}); plp = comp.querySelector(".plp"); plp. classList.add("facet"); if (oldMoveSel === moveToSel) { plp.classList.add("wrap"); } break; default: $("#results-products").css({width: " "}); $(".bopis-filter-options").css({display: ""}); plp = comp.querySelector(".plp"); plp.classList.remove("faceta"); if (oldMoveSel === moveToSel) { plp.classList.remove("wrap"); } } } else { if (newMoveSel === moveToSel) { moveTryCount++; if (moveTryCount > 20) { moveToSel = oldMoveSel; aSel = moverASel; } } toi = setTimeout(moveTo, 50, obj, toSel); } } var noMovimiento = true; var comp = document.querySelector("#" + _self.instance.tagId); if (_self.feature.moveToLeftOnDesktop) { mm.addListener(function bpchange(e) { var comp = document.querySelector("#" + _self.instance.tagId); if (!comp) { mm.removeListener(bpchange); if (toi) { clearTimeout(toi); toi = null; } return; } if (noMove !== e.matches) { noMove = e.matches; if (noMove) { startMoveTo(comp, ".bopis-filter- options"); } else { startMoveTo(comp, moveToSel); } } }); noMovimiento = mm.coincidencias; } if (!_self.isNull(comp)) { $(comp).find(".plp .center-vert").html(str); _self.addStoreSelectionHandlers(); if (!noMove) { startMoveTo(comp, moveToSel); } } } función getStores(zip) { var encontrado = {}; if (!_self.isStringEmpty(zip)) { _self.getStoresByZip(zip, function (zip, data) { var i; _self.log("getStoresByZip with zip:", zip, " datos devueltos:", datos); if (_self.isObject(data) && data.hasOwnProperty("success") && data.success) { _self.data.zip = zip; _self.stores = data.stores; if (data.hasOwnProperty("readyHours") && _self .isNumber(data.readyHours)) { _self.readyHours = data.readyHours; } if (data.hasOwnProperty("pickupToday") && _self.isBoolean(data.pickupToday)) { _self.pickupToday = data.pickupToday; } if ( data.hasOwnProperty("pickupDay") && _self.isString(data.pickupDay)) { _self.data.pickupDay = data.pickupDay; } if (0 === _self.selectedStoreIds.length) { if (!_self.isArrayEmpty( _self.stores)) { encontrado = _self.findFirstBopisStore(); } if (!_self.isUndefined(found.store)) { _self.data.store = found.store; _self.selectedStoreIds.push(found.store.id) ; } else { _self.data.store = {}; } } else { if (!_self.isArrayEmpty(_self.stores)) { for (i = 0; i < _self.selectedStoreIds.length; i++) { encontrado = _self.findStore(_self.selectedStoreIds[i]); if (!found.hasOwnProperty("store") || !found.store.hasOwnProperty("bopis") || !found.store.bopis) { _self.selectedStoreIds.splice(i--, 1); } } encontrado = {}; if (0 !== _self.selectedStoreIds.length) { encontrado = _self.findStore(_self.selectedStoreIds[0]); } } if (found.hasOwnProperty("store") && found.store.hasOwnProperty("bopis") && found.store.bopis) { _self.data.store = found.store; } else { _self.data.store = {}; } } } construir(); }); } más { _self.data.zip = zip; construir(); } } urlStoreId = _self.getUrlParm(ventana.ubicación.href, "storeId"); if (!_self.isStringEmpty(urlStoreId)) { ids = decodeURIComponent(urlStoreId); } else { if (window.hasOwnProperty("User") && window.User.hasOwnProperty("storeId") && !_self.isNull(window.User.storeId)) { ids = window.User.storeId; } } if (!_self.isStringEmpty(ids)) { ids = ids.split("|"); for (i = 0; i < ids.longitud; i++) { _self.selectedStoreIds.push(ids[i]); } } function closePopper(e) { var $t = $(e.objetivo), $p; if (_self["clase"].ignoreNextClosePopperSelf === _self) { _self["clase"].ignoreNextClosePopperSelf = null; devolver; } if (0 !== $t.filter("#" + _self.instance.tagId + " .as-link").length) { return; } if ("filterByStorePickup" === $t.attr("for")) { return; } $p = $t.closest("#" + _self.instance.tagId + " .popper"); if (0 === $p.longitud) { if (_self.isPopperOpen) { _self.hidePopper(); } } } window.libs.notify.api.request(["jquery-ready"], función () { const ENS = "hacer clic". + _self.component.class + ".popper"; var zip, $B = $("cuerpo"); $B.off(ENS); $B.on(ENS, closePopper); if (_self.isStringEmpty(_self.data.zip)) { _self.getDeliveryConfigBatch(función (datos) { if ( !_self.isObjectEmpty(data)) { _self.data.bopisEnabled = data.bopisEnabled; _self.data.findInStoreEnabled = data.fisEnabled; _self.data.storeId = data.storeId; if ("" !== data.zipCode) { zip = data.zipCode; getStores(zip); } else { getStores(_self.data.zip); } } else { build(); } }); } else { getStores(_self.data.zip); } } ); document.addEventListener("brdata_ready", function (e) { const verificado = (-1 !== window.location.href.indexOf("searchType=FreePickup")); _self.update({verificado: verificado}); } ); cadena += "
"; return str;}function Bopis_pdp() { const _self = this; const zipClass = "select-zip"; var valid, str = "", e, pid = "", zip = ""; valid = _self.validateData (_self.data); log("datos válidos:", válido); if (isUndefined(_self.config.messaging.bopis) || !isString(_self.config.messaging.bopis) || isStringEmpty(_self.config. mensajería.bopis)) { _self.config.messaging.bopis = _self.default.config.messaging.bopis; } pid = _self.data.skuId; _self.objPropDef(_self.data, "skuOrin", "", [" string"]); orin = _self.data.skuOrin; zip = _self.data.zip; function closePopper(e) { if (_self.ignoreNextClosePopper) { _self.ignoreNextClosePopper = false; return; } var $t = $(e .target), $p = $t.closest("#" + _self.instance.tagId + " .popper"); if (0 !== $t.filter("#" + _self.instance.tagId + " .as-link").length) { return; } if (0 !== $t.filter("#" + _self.instance.tagId + " .rradio").length) { return; } if (0 ! == $t.filter("#" + _self.instancia.tagId + " .rcheckbox").longitud) { return; } if (0 !== $t.filter("#" + _self.instancia.tagId + " .vlabel").longitud) { retorno; } if ($t.hasClass("rradio")) { return; } if (0 !== $t.filter("#" + _self.instance.tagId + " #receive-option-pickup").length) { return; } if (0 === $p.longitud) { if (_self.isPopperOpen) { _self.hidePopper(); } } } función build() { var $C = $("#" + _self.instance.tagId); $C.find(".pdp").html(_self.buildPDP()); $C.find(".reserva-espacio").removeClass("reserva-espacio"); _self.addOutlineHandlers(); _self.addStoreSelectionHandlers(); _self.addPDPZipSelectionHandlers(); _self.addConnsZipSelectionHandler(); } función getStores(pid, orin, zip, sddZip, sddStoreId) { var encontrado = {}; if (_self.isUndefined(pid)) { pid = ""; } if (_self.isUndefined(orin)) { orin = ""; } if (_self.isUndefined(zip)) { zip = ""; } if (_self.isUndefined(sddZip)) { sddZip = ""; } if (_self.isUndefined(sddStoreId)) { sddStoreId = ""; } if (!_self.isStringEmpty(pid) && (_self.data.findInStoreEnabled && !_self.isStringEmpty(zip) || !_self.isStringEmpty(sddZip) && !_self.isStringEmpty(sddStoreId))) { if (_self.isStringEmpty (sddStoreId)) { sddZip = ""; } else { if (_self.isStringEmpty(sddZip)) { sddStoreId = ""; } } _self.getStoresByZipPidBatch(pid, orin, zip, sddZip, sddStoreId, function (parms, data) { if (_self.isObject(data) && data.hasOwnProperty("success") && data.success) { _self.data. skuId = parms.pid; _self.data.zip = parms.zip; if (data.hasOwnProperty("stores")) { _self.stores = data.stores; } if (data.hasOwnProperty("readyHours")) { _self .readyHours = data.readyHours; } if (data.hasOwnProperty("pickupToday")) { _self.pickupToday = data.pickupToday; } if (data.hasOwnProperty("pickupDay") && _self.isString(data.pickupDay)) { _self.data.pickupDay = data.pickupDay; } if (data.hasOwnProperty("sddStore")) { _self.data.sddStore = data.sddStore; _self.data.sddStoreId = _self.data.sddStore.id; } if ( data.hasOwnProperty("sameDay")) { _self.data.sddSameDay = data.sameDay; } if (!_self.isArrayEmpty(_self.stores)) { if (!_self.isNull(_self.data.preferredStoreId)) { encontrado = _self.findStore(_self.data.preferredStoreId); } else { if (!_self.isObjectEmpty(_self.data.store)) { encontrado = _self.findStore(_self.data.store.id); } } } if (!_self.isUndefined(found.store)) { _self.data.store = found.store; _self.data.storeId = _self.data.store.id; } else { if (0 < _self.stores.length) { _self.data.store = _self.stores[0]; _self.data.storeId = _self.data.store.id; } } if (_self.isObjectEmpty(_self.data.store) || !_self.data.store.bopis || 0 === _self.data.store.quantity) { _self.searchResults = _self.searchStores(_self.stores ); if (_self.searchResults.bopis) { _self.data.store = _self.searchResults.store; _self.data.storeId = _self.data.store.id; } } } construir(); }); } más { _self.data.zip = zip; construir(); } } window.libs.notify.api.request(["jquery-ready"], function () { const ENS = "click." + _self.component.class + ".popper"; var $B = $(" cuerpo"); $B.off(ENS); $B.on(ENS, closePopper); if (_self.isStringEmpty(_self.data.zip)) { _self.getDeliveryConfigBatch(función (datos) { if (!_self. isObjectEmpty(data)) { _self.data.bopisEnabled = data.bopisEnabled; _self.data.findInStoreEnabled = data.fisEnabled; _self.data.storeId = data.storeId; _self.data.preferredStoreId = _self.data.storeId; _self. data.zip = data.zipCode; _self.data.sddEnabled = data.sddEnabled; _self.data.sddZip = data.sddZipCode; _self.data.storeInvService = data.storeInvService; _self.data.storeInvSfccOnly = data.storeInvSfccOnly; if ( _self.data.sddEnabled && E !== _self.data.sddZip) { _self.getSddStore(función (datos) { if (!_self.isObjectEmpty(datos) && data.hasOwnProperty("store") && !_self.isStringEmpty( data.store)) { _self.data.sddStoreId = data.store; } if (_self.isStoresDataNeeded()) { getStores(pid, _self.data.skuOrin, _self.data.zip, _self.data.sddZip, _self. datos.sddStoreId); } más { compilar(); } }); } else { if (_self.isStoresDataNeeded()) { getStores(pid, _self.data.skuOrin, _self.data.zip); } más { compilar(); } } } más { compilar(); } }); } else { if (_self.isStoresDataNeeded()) { getStores(pid, _self.data.skuOrin, _self.data.zip, _self.data.sddZip, _self.data.sddStoreId); } más { compilar(); } } }); _self.persist(); cadena += "
"; return str;}function Bopis_bag() { const _self = this; var valid, str = ""; if (!_self.class.hasOwnProperty("isClosePoppers")) { _self.class.isClosePoppers = false; } if ( !_self.class.hasOwnProperty("ignoreNextClosePopperSelf")) { _self.class.ignoreNextClosePopperSelf = null; } _self.readyHours = 4; _self.pickupToday = false; if (!_self.isUndefined(_self.data.readyHours) && _self. isNumber(_self.data.readyHours)) { _self.readyHours = _self.data.readyHours; } if (!_self.isUndefined(_self.data.pickupToday) && _self.isBoolean(_self.data.pickupToday)) { _self.pickupToday = _self.data.pickupToday; } if (!_self.isString(_self.data.pickupDay)) { _self.data.pickupDay = ""; } if (isUndefined(_self.config.messaging.bopis) || !isString( _self.config.messaging.bopis) || isStringEmpty(_self.config.messaging.bopis)) { _self.config.messaging.bopis = _self.default.config.messaging.bopis; } if (!_self.data.hasOwnProperty( "sessionZip")) { _self.data.sessionZip = ""; } function closePoppers(e) { var $t = $(e.target), ignoreSelf = null, pid = ""; if (0 !== $t.closest(".receive-option-pickup").length) { pid = $t.closest("." + _self.component.class).attr("id"); if ("" !== pid && coms.hasOwnProperty(pid)) { ignoreSelf = coms[pid]; } } if (!isNull(_self.class.ignoreNextClosePopperSelf)) { ignoreSelf = _self.class.ignoreNextClosePopperSelf; _self.class.ignoreNextClosePopperSelf = nulo; } _self.hidePoppers(ignoreSelf); } function build() { const ENS = "clic". + _self.componente.clase + ".popper"; var $B = $("cuerpo"); var $C = $("#" + _self.instance.tagId); $C.find(".bolsa").html(_self.buildPDP()); $C.find(".reserva-espacio").removeClass("reserva-espacio"); _self.addStoreSelectionHandlers(); _self.addConnsZipSelectionHandler(); if (!_self.class.isClosePoppers) { $B.off(ENS); $B.on(ENS, cerrarPoppers); _self.class.isClosePoppers = verdadero; } } if (_self.data.productInStock) { _self.getDeliveryConfigBatch(función (datos) { _self.data.storeInvService = data.storeInvService; _self.data.storeInvSfccOnly = data.storeInvSfccOnly; window.libs.notify.api.request( ["jquery-ready"], function () { build(); }); }); _self.persist(); cadena += "
"; } return str;}function Bopis_bagSddBanner() { const _self = this; const zipClass = "select-zip", sddM = _self.config.messaging.sdd; var str = ""; function formatPrice(p) { const regEx = /(\d(?=(\d{3})+\.))/g; devuelve "$" + Número(p).toFixed(2).replace(regEx, "$1,"); } if (isNumber(_self.data.sddFee) || isString(_self.data.sddFee) && !isStringEmpty(_self.data.sddFee)) { _self.data.formattedSddFee = formatPrice(_self.data.sddFee); } else { _self .data.formattedSddFee = ""; } function closePopper(e) { if (_self.ignoreNextClosePopper) { _self.ignoreNextClosePopper = false; return; } var $t = $(e.target), $p = $t.closest( "#" + _self.instance.tagId + " .popper"); if (0 !== $t.filter("#" + _self.instance.tagId + " .as-link").length) { return; } if (0 !== $t.filter("#" + _self.instancia.tagId + " .rradio").longitud) { return; } if (0 !== $t.filter("#" + _self .instance.tagId + " .rcheckbox").longitud) { return; } if (0 !== $t.filter("#" + _self.instance.tagId + " .vlabel").length) { return; } if ($t.hasClass("rradio")) { return; } if (0 === $p.longitud) { if (_self.isPopperOpen) { _self.hidePopper(); } } } function buildSddMessage() { var msg = "", fee = _self.isStringEmpty(_self.data.formattedSddFee) ? "" : "(" + _self.data.formattedSddFee + ") "; función día(mismodía) { var mensaje = ""; if (mismoDía) { msj = "hoy"; } else { msj = "mañana"; } devolver mensaje; } función llenar(mensaje) { var rX = /{{X}}/, rS = /{{S}}/, rC = /{{C}}/, rE = /{{E}}/; msg = msg.replace(rX, _self.data.sddItemCount); msg = msg.replace(rS, 1 < _self.data.sddItemCount ? "s" : ""); msg = msg.replace(rC, _self.data.sddCutoffTime + " ET"); msg = msg.replace(rE, _self.data.sddEndTime.replace(" ", "")); if (!_self.data.hasReducedEliteFee && 0 !== _self.data.sddFee) { tarifa de devolución + mensaje; } más { devolver mensaje; } } if (_self.data.hasSdd) { if (_self.data.sddZip) { if (_self.data.sddStoreId) { if (0 < _self.data.sddItemCount) { if (_self.data.sddSelected) { if (_self.data.sddSameDay) { msg = fill(sddM.eligibleActive); } más { mensaje = llenar (sddM.eligibleActiveCutoff); } } else { if (_self.data.hasPresale) { if (_self.data.sddSameDay) { msg = fill(sddM.eligiblePresale); } más { mensaje = llenar (sddM.elegiblePresaleCutoff); } } else { if (_self.data.sddSameDay) { msg = fill(sddM.eligible); } más { mensaje = llenar (sddM.eligibleCutoff); } } } } else { msg = _self.data.sddFee === 0 ? "(" + sddM.Free + ")" + " " + sddM.noSddInZip : fee + sddM.noSddInZip; } } else { msg = _self.data.sddFee === 0 ? "(" + sddM.Free + ")" + " " + sddM.zipNotEligible : fee + sddM.zipNotEligible; } } else { msg = _self.data.sddFee === 0 ? "(" + sddM.Free + ")" + " " + sddM.noZip : fee + sddM.noZip; } } más { } devolver mensaje; } function addSelectionHandlers() { var $C = $("#" + _self.instance.tagId); var $zObj = $C.find("." + zipClass), $in, len; $zObj.on("clic", function (e) { if ($zObj.prop("marcado")) { _self.showPopper(zipClass); $in = $C.find(".popper .buscar-por- zip .zip-code"); $in.focus(); len = $in.val().length; $in[0].setSelectionRange(len, len); } else { _self.hidePopper(); } e .stopPropagation();}); var $cbObj = $C.find("#selectSdd"); $cbObj.on("clic", function (e) { if ($cbObj.prop("marcado")) { $("#sddSelected").val(true); } else { $("#sddSelected") .val(false); } if (window.progress) { window.progress.show(); } $("input[type=\"hidden\"][name$=\"_updateCart\"]").remove (); $("entrada[tipo=\"oculto\"][nombre$=\"_updateGiftBox\"]").remove(); $("entrada[tipo=\"oculto\"][nombre$= \"_updateSSDZipCode\"]").remove(); $("#update-sddOption").click(); }); } function build() { var str = "", zipLabel = "", isTo = false, isDisabled = false, fee = _self.isStringEmpty(_self.data.formattedSddFee) ? "" : _self.data.formattedSddFee; if (_self.isStringEmpty(_self.data.sddZip)) { zipLabel = "Revisar mi área"; } else { zipLabel = _self.data.sddZip, isTo = true; } if (!_self.data.sddZip || !_self.data.sddStoreId || !_self.data.sddItemCount) { isDisabled = true; } cadena += "
"; cadena += "
"; cadena += "
"; cadena += ""; cadena += "
"; cadena += "" + (¿está desactivado? "" : (_self.data.sddSameDay ? sddM.sameDayPre : sddM.nextDayPre)); str += isDisabled ? "" : _self.data.isEliteCustomer ? (0 === _self.data.sddFee ? sddM.elitesPre : _self.data.hasReducedEliteFee ? fee : "") : 0 === _self.data.sddFee ? sddM.Free : ""; str += " " + sddM.title + (isDisabled ? "" : ( _self.data.hasReducedEliteFee && _self.data.isEliteCustomer && 0 !== _self.data.sddFee ? " " + sddM.forElites + " " : " ")) + _self.buildToolTip(_self.data.sddToolTip) + (isTo ? " a " : "") + ""; str += " " + _self.buildSelectionToggle(zipClass, zipLabel); str += ""; str += "
"; cadena += ""; str += generarMensajeSdd(); str += "
"; cadena += "
"; cadena += "
"; return str; } if (_self.data.hasSdd) { window.libs.notify.api.request(["jquery-ready"], function () { const ENS = "click." + _self.instance.tagId + ".popper"; var $B = $("cuerpo"); $B.off(ENS); $B.on(ENS, closePopper); addSelectionHandlers(); }); str = "
"; cadena += "
"; cadena += construir(); cadena += "
"; cadena += "
"; } return str;}function Bopis_isPickupDisabled() { const _self = this; const NITP = true; var isDisabled = true; if (!_self.data.mirakl && !_self.error && !_self.data.productOnlineOnly && !_self .data.skuOnlineOnly && _self.data.bopisEnabled && _self.data.findInStoreEnabled && _self.data.bopisProduct && !_self.isStringEmpty(_self.data.skuId) && _self.data.bopisSku && !(_self.data.isConnsItem || (window.pageData && window.pageData.isConnsProduct)) && (NITP || !_self.isStringEmpty(_self.data.zip)) && ((NITP && _self.isStringEmpty(_self.data.zip)) || !_self. isObjectEmpty(_self.data.store) && _self.data.store.bopis && 0 < _self.data.store.quantity || _self.searchResults.bopis)) { isDisabled = false; } return isDisabled;}function Bopis_isStoresDataNeeded(data) { const _self = this; if (!data) { data = _self.data; } return data.bopisEnabled && data.findInStoreEnabled && data.bopisProduct && !data.mirakl && !data.productOnlineOnly && !data.skuOnlineOnly && !(data .isConnsItem || (window.pageData && window.pageData.isConnsProduct));}function Bopis_buildInputRC(config) { const _self = this; var c = config, str = "", marcada = c.isChecked? "marcado": ""; function pc(c) { return _self.isUndefined(c) || !_self.isString(c) || _self.isStringEmpty(c) ? "" : " " === c[0] ? c : " " + c; } if (!c.isDisabled) { if (c.isMultiSelect) { str += ""; } más { cadena += ""; } } más { cadena += "
"; } cadena += ""; return str;}function Bopis_buildPDP() { const _self = this; const regD = /{{D}}/; var M = _self.config.messaging, str = "", name = "receive-option", cantidad = 0, labelText = "", skuSelected = false, pid = "", preOrderPromoDetails = "", preOrderPromoId = "", isConnsItem = _self.config.feature === "bag" ? _self.data.isConnsItem : (window. pageData && window.pageData.isConnsProduct); if (_self.config.feature !== "bolsa" && (isConnsItem && !_self.isObjectEmpty(_self.data.connsSKUData) && !_self.isObjectEmpty(_self.data.connsInvData) && !_self.data.connsInvData.conns)) { return; } if (!_self.isStringEmpty(_self.data.skuId)) { skuSelected = true; } if (_self.isObject(_self.data.store) && _self.data .store.hasOwnProperty("cantidad") && _self.isNumber(_self.data.store.quantity)) { cantidad = _self.data.store.quantity; } if ("pdp" === _self.config.feature && skuSelected && !_self.data.skuShipEligible && 0 >= cantidad && !_self.data.connsSKUData) { str += "
"; cadena += ""; str += M.bopisOnly; str += ""; str += ""; str += M.productOutNear.replace(/{{Z}}/, _self.data.zip).replace(regD, _self.data.storeSearchDistance); str += "
"; } else { if (_self.data.productInStock) { if (!skuSelected) { str += "
"; cadena += ""; si (_self.data.skuShipEligible) { str += ""; if (!_self.isStringEmpty(_self.shipPromoMsg)) { str += _self.shipPromoMsg; } str += ""; str += ""; str += M.selectSizeForOpt; } else { str += "" + M.bopisOnly + ""; str += ""; str += M.selectSizeBopisOnly; } str += "
"; } else { if (0 < _self.data.skuStockLevel) { if (_self.data.sddEnabled && _self.data.skuSddEligible) { str += _self.buildSddEligibleBanner(); } str += "
"; cadena += "
" + M.receiveOptionsHeader + "
"; if (!_self.isObjectEmpty(_self.data.connsSKUData) && !_self.isObjectEmpty(_self.data.connsInvData) && isConnsItem) { str += _self.buildConnsOption(); } else { str += "
"; labelText = _self.buildProductShipStatus(_self.data.skuStockLevel, _self.data.productInStock && !skuSelected, _self.data.surchargeAmount); str += _self.buildInputRC({isDisabled: !_self.data.skuShipEligible, isMultiSelect: false , id: nombre + "-envío", valor: "envío", nombre: nombre, contenido: labelText, isChecked: "bag" === _self.config.feature && !_self.isObjectEmpty(_self.data.store) && _self.data.bopisSelected ? false : true, isMessage: false}); str += "
"; } cadena += "
"; if (_self.data.isPreOrderEnabled && _self.data.showPreOrder && ("bag" === _self.config.feature || _self.hasPreOrderResponse)) { str += _self.buildPreSaleOption(); } str += "
"; str += _self.buildPickupOption(); str += "
"; str += _self.buildStoreId(); if (isConnsItem && "bag" !== _self.config.feature) { str += "
"; if (!_self.isObjectEmpty(_self.data.connsSKUData)) { str += _self.buildConnsFields(); } else { $("#add-to-cart").addClass("add-to-cart desactivado -deshabilitado").prop("deshabilitado", verdadero).attr("tipo", "botón"); } str += "
"; } } else { if (isConnsItem) { if (!_self.isObjectEmpty(_self.data.connsSKUData) && !_self.isObjectEmpty(_self.data.connsInvData)) { str += "
"; cadena += "
" + M.receiveOptionsHeader + "
"; str += _self.buildConnsOption(); str += "
"; } if ("bolsa" !== _self.config.feature) { str += "
"; if (!_self.isObjectEmpty(_self.data.connsSKUData)) { str += _self.buildConnsFields(); } else { $("#add-to-cart").addClass("add-to-cart desactivado -deshabilitado").prop("deshabilitado", verdadero).attr("tipo", "botón"); } str += "
"; } } más { cadena += "
"; str += M.skuOut; str += "
"; } } } } más { cadena += "
"; str += M.productoFuera; str += "
"; } } function updatePreOrderRadio(invStatus) { var $C = $("#" + _self.instance.tagId); if (invStatus) { var preOrderContent = ""; preOrderContent += _self.buildPreSaleOption(); $C. find(".preorder-container").html(preOrderContent).show(); } else { $C.find(".preorder-container").hide(); } } if ("pdp" === _self .config.feature && _self.data.isPreOrderEnabled && _self.data.showPreOrder) { pid = _self.data.skuId; if (_self.isStringEmpty(pid)) { pid = _self.data.productId; } preOrderPromoDetails = _self.data .preOrderPromoDetails; preOrderPromoId = _self.data.preOrderPromoId; _self.getPreOrderFCInventory(pid, preOrderPromoDetails, function (pid, preOrderPromoDetails, data) { _self.hasPreOrderResponse = true; if (data.hasOwnProperty("preOrderInStock") && data.preOrderInStock && data .hasOwnProperty("preOrderATSCount") && data.preOrderATSCount > 0) { _self.data.hasPreOrderInventory = true; updatePreOrderRadio(true); _self.addStoreSelectionHandlers(); updatePDPPreOrderIndicators(); } else { _self.data.hasPreOrderInventory = false; actualizarPreOrderRadio(falso); actualizarPDPPPreOrderIndicators(); } }); } else { if (_self.data.isQuickView && !_self.data.showPreOrder && _self.data.skuId !== "") { _self.data.hasPreOrderInventory = false; _self.hasPreOrderResponse = verdadero; actualizarPreOrderRadio(falso); actualizarPDPPPreOrderIndicators(); } } función actualizarEnvíoPromoMsg() { var $C; if (_self.isString(_self.shipPromoMsg) && !_self.isStringEmpty(_self.shipPromoMsg)) { $C = $("#" + _self.instance.tagId); $C.find(".ship-message .ship-promo").html((_self.isStringEmpty(_self.data.skuId) ? "" : " - ") + _self.shipPromoMsg); } } if ("pdp" === _self.config.feature && _self.data.skuShipEligible && (!_self.isShipPromoMsg || _self.lastSkuId !== _self.data.skuId)) { _self.isShipPromoMsg = true; pid = _self.data.skuId; if (_self.isStringEmpty(pid)) { pid = _self.data.productId; } _self.getShippingPromoMessage(pid, function (pid, data) { _self.lastSkuId = _self.data.skuId; if (data.hasOwnProperty("shippingMsg")) { if (_self.isString(data.shippingMsg) && !_self. isStringEmpty(data.shippingMsg)) { _self.shipPromoMsg = data.shippingMsg; updateShipPromoMsg(); } else { if (_self.isObject(data.shippingMsg) && !_self.isObjectEmpty(data.shippingMsg)) { if (_self.isStringEmpty (_self.data.skuId) && data.shippingMsg.long) { _self.shipPromoMsg = data.shippingMsg.long; } else { if (data.shippingMsg.short) { _self.shipPromoMsg = data.shippingMsg.short; } } updateShipPromoMsg (); } } } }); } function actualizarPDPPPreOrderIndicators() { var $poGiftBadge = $(".preorder-gift-badge"), $pdTop = $(".product-detail.top"), badgeHtml = "
", $promoContainer = $(".promotion"), $promoCallOutMessage = $(".promotion .callout-message"), $poPromoMessage = $(".callout-message-row.preorder-promo-message"), $ regularPromoMessage = $(".callout-message-row:not(.preorder-promo-message)"); if (_self.data.hasPreOrderInventory) { if ($poGiftBadge.length === 0 && $pdTop.length > 0 ) { $pdTop.prepend(badgeHtml); } else { $poGiftBadge.show(); } } else { if ($poGiftBadge.length!== 0) { $poGiftBadge.hide(); } if ($poPromoMessage.length !== 0 && $regularPromoMessage.length === 0) { $promoContainer.hide(); $poPromoMessage.hide(); } else { if ($poPromoMessage.length !== 0) { $poPromoMessage.hide() ; } } } } if (_self.isStringEmpty(_self.promoMsg) || _self.data.bopisPromoAssetID !== _self.promoMsgAssetID) { _self.promoMsgAssetID = _self.data.bopisPromoAssetID; _self.getBopisPromoMessaging(_self.data.bopisPromoAssetID , función (datos) { if (datos.hasOwnProperty("isOnline") && data.isOnline && data.hasOwnProperty("assetContent") && !_self.isStringEmpty(data.assetContent)) { _self.promoMsg = data.assetContent; $("#" + _self.instance.tagId + " .promo-msg").html(_self.promoMsg); } }); } return str;}function Bopis_fixStoreData(data) { const _self = this; var yo; if (datos.almacenes) { for (i = 0; i < datos.almacenes.longitud; i++) { datos.almacenes[i].distancia = datos.almacenes[i].distancia.reemplazar(/[^.0- 9]/g, ""); data.stores[i].name = data.stores[i].name.replace(/Belk /gi, ""); } }}function Bopis_getBopisPromoMessaging(bopisPromoAssetID, callback) { const _self = this; var CAN = bopisPromoAssetID !== "" ? bopisPromoAssetID : "bopis-promo-messaging"; var url = _self.baseAjaxUrl; url += "COContent-GetContentAsset?assetName="; URL += PUEDE; $.ajax(url, {éxito: función (datos, estado de texto, jqXHR) { log("getBopisPromoMessaging ajax éxito: datos:", datos, "estado de texto:", estado de texto, "jqXHR:", jqXHR); if (_self. isFunction(callback)) { try { callback(data); } catch (e) { log("Exception:", e); } } }, error: function (jqXHR, textStatus, errorThrown) { log("getBopisPromoMessaging ajax error : jqXHR:", jqXHR, "textStatus:", textStatus, "errorThrown:", errorThrown); }, complete: function (jqXHR, textStatus) { log("getBopisPromoMessaging ajax complete: jqXHR:", jqXHR, "textStatus:" , textStatus); }});}function Bopis_getShippingPromoMessage(pid, callback) { const _self = this; var url = _self.baseAjaxUrl; url += "Producto-GetShippingPromoMsg?pid="; URL += pid; $.ajax(url, {éxito: función (datos, estado de texto, jqXHR) { log("getShippingPromoMessage ajax éxito: datos:", datos, "estado de texto:", estado de texto, "jqXHR:", jqXHR); if (_self. isUndefined(data)) { data = {}; } if (_self.isFunction(callback)) { try { callback(pid, data); } catch (e) { log("Exception:", e); } } } , error: function (jqXHR, textStatus, errorThrown) { log("getShippingPromoMessage ajax error: jqXHR:", jqXHR, "textStatus:", textStatus, "errorThrown:", errorThrown); if (_self.isFunction(callback)) { intente { callback(pid, {}); } catch (e) { log("Exception:", e); } } }, complete: function (jqXHR, textStatus) { log("getShippingPromoMessage ajax complete: jqXHR:", jqXHR, "textStatus:", textStatus); }});}function Bopis_getStoresByZip(zip, callback) { const _self = this; var url = _self.baseAjaxUrl; _self.error = falso; if (_self.isStringEmpty(zip)) { retorno; } url += "Tiendas-GetBopisStoresByZip?zipCode=" + zip; devolución de llamada = devolución de llamada || function (zip, data) { log("No se ha dado devolución de llamada para getStoresByZip call by zip:", zip, "datos devueltos:", data); }; $.ajax(url, {éxito: función (datos, estado de texto, jqXHR) { log("getStoresByZip ajax éxito: datos:", datos, "estado de texto:", estado de texto, "jqXHR:", jqXHR); if (_self. isObject(data) && data.hasOwnProperty("success") && data.success) { _self.fixStoreData(data); } if (!data.success) { _self.error = true; } if (_self.isFunction(callback) ) { try { callback(zip, data); } catch (e) { log("Exception:", e); } } }, error: function (jqXHR, textStatus, errorThrown) { log("getStoresByZip ajax error: jqXHR :", jqXHR, "textStatus:", textStatus, "errorThrown:", errorThrown); }, complete: function (jqXHR, textStatus) { log("getStoresByZip ajax complete: jqXHR:", jqXHR, "textStatus:", textStatus ); }});}function Bopis_getSddStore(callback) { const _self = this; var url = _self.baseAjaxUrl, cachedData; log("_self.sddZipToStoreCache:", _self.sddZipToStoreCache); if (_self.sddZipToStoreCache.hasOwnProperty(_self.data.sddZip)) { cachedData = _self.sddZipToStoreCache[_self.data.sddZip]; if (!_self.isUndefined(cachedData) && !_self.isObjectEmpty(cachedData) && _self.isFunction(callback)) { try { callback(cachedData); } catch (e) { log("Excepción:", e); } devolver; } } url += "COSameDayDelivery-GetDeliveryAssuranceStore?zipCode=" + _self.data.sddZip; $.ajax(url, {éxito: función (datos, estado de texto, jqXHR) { log("getSddStore ajax éxito: datos:", datos, "estado de texto:", estado de texto, "jqXHR:", jqXHR); if (_self. isObject(datos) && !_self.isObjectEmpty(datos) && data.hasOwnProperty("zipCode") && _self.isString(data.zipCode) && !_self.isStringEmpty(data.zipCode)) { _self.sddZipToStoreCache[data.zipCode] = datos; } else { datos = {}; } if (_self.isFunction(callback)) { try { callback(datos); } catch (e) { log("Exception:", e); } } }, error : function (jqXHR, textStatus, errorThrown) { log("getSddStore ajax error: jqXHR:", jqXHR, "textStatus:", textStatus, "errorThrown:", errorThrown); if (_self.isFunction(callback)) { try { callback({}); } catch (e) { log("Exception:", e); } } }, complete: function (jqXHR, textStatus) { log("getSddStore ajax complete: jqXHR:", jqXHR, "textStatus :", textStatus); }});}function Bopis_setSessionStore(storeId, callback) { const _self = this; var url = _self.baseAjaxUrl; url += "StoreInventory-SetPreferredStore?storeId=" + storeId; $.ajax(url, {éxito: función (datos, estado de texto, jqXHR) { log("setSessionStore ajax éxito: datos:", datos, "estado de texto:", estado de texto, "jqXHR:", jqXHR); if (_self. isFunction(callback)) { try { callback(data); } catch (e) { log("Exception:", e); } } }, error: function (jqXHR, textStatus, errorThrown) { log("setSessionStore ajax error : jqXHR:", jqXHR, "textStatus:", textStatus, "errorThrown:", errorThrown); }, complete: function (jqXHR, textStatus) { log("setSessionStore ajax complete: jqXHR:", jqXHR, "textStatus:" , textStatus); }});}function Bopis_getPreOrderFCInventory(pid, preOrderPromoDetails, callback) { log("getPreOrderFCInventory llamado con pid:", pid, "preOrderPromoDetails:", preOrderPromoDetails, "callback", callback); const _self = esto; var url = _self.baseAjaxUrl + "COPreOrder-GetPreOrderFCInventory"; if (_self.isStringEmpty(preOrderPromoDetails)) { return; } devolución de llamada = devolución de llamada || function (preOrderPromoDetails, data) { log("No se devolvió la llamada para getPreOrderFCInventory por preOrderPromoDetails:", preOrderPromoDetails, "datos devueltos:", data); }; preOrderPromoDetails = JSON.parse(preOrderPromoDetails); PreOrderPromoDetails.pid = pid; $.ajax({método: "POST", tipo de datos: "json", tipo de contenido: "aplicación/json", url: url, datos: JSON.stringify(preOrderPromoDetails), éxito: función (datos, textStatus, jqXHR) { log ("getPreOrderFCInventory ajax success: data:", data, "textStatus:", textStatus, "jqXHR:", jqXHR); if (_self.isFunction(callback)) { try { callback(pid, preOrderPromoDetails, data); } catch (e) { log("Exception:", e); } } }, error: function (jqXHR, textStatus, errorThrown) { log("getPreOrderFCInventory ajax error: jqXHR:", jqXHR, "textStatus:", textStatus, " errorThrown:", errorThrown); }, complete: function (jqXHR, textStatus) { log("getPreOrderFCInventory ajax complete: jqXHR:", jqXHR, "textStatus:", textStatus); }});}function Bopis_availabilityMessage(cantidad, forceInStock , isPunc, forPopper) { const _self = this; const p = ".", e = "!", n = ""; var M = _self.config.messaging, str = "cantidad) { str += " menos\">" + M.stock["menos"]; if (5 > cantidad) { str += " (" + M.stock.lowX.replace("X", cantidad) + ")"; } } else { if (forceInStock || 5 < cantidad) { str += " in\">" + M.stock["in"] + (!forPopper && isPunc ? p : ""); } else { if (0 === cantidad) { str += " out\">" + M.stock.out; } else { if (5 === cantidad) { str += " low\">" + M.stock.bajo; } else { if (5 > cantidad) { str += " bajo\">" + M.stock.lowX.replace("X", cantidad) + (isPunc ? e : ""); } } } } } str += ""; return str;}function Bopis_buildSelectionToggle(theClass, text) { const _self = this; var str = ""; str += ""; str += ""; cadena += "
"; return str;}function Bopis_buildStoreSelectionToggle(text) { const _self = this; var str = ""; str += ""; str += ""; cadena += "
"; return str;}function Bopis_searchStores(stores) { const _self = this; var i, store, ret = {}; _self.copyObject(ret, _self.default.config.init.searchResults); if (0 < stores. longitud) { for (i = 0; i < tiendas.longitud; i++) { tienda = tiendas[i]; if (0 < tienda.cantidad) { ret.inStore = true; if (tienda.bopis) { ret.bopis = true; ret.store = store; break; } } } ret.isSearch = true; } return ret;}function Bopis_updateInStockOnly() { const _self = this; var $C = $("#" + _self.instance.tagId ), $d = $C.find(".popper.bopis .stores li .filter-instockonly").closest("li"), $inp = $C.find(".popper.bopis .filters input[name =\"solo en stock\"]"); if ($inp.length) { if ($inp.prop("checked")) { _self.inStockOnly = true; $d.hide(); } else { _self.inStockOnly = false; $d.show(); } _self.updatePopperScrollbar(); }}function Bopis_searchResponse(pid, zip, data) { const _self = this; var $C = $("#" + _self. instancia.tagId); if (_self.isObject(data) && data.hasOwnProperty("success") && data.success) { _self.data.skuId = pid; _self.datos.zip = zip; if (data.hasOwnProperty("stores") && _self.isArray(data.stores) && 0 < data.stores.length) { _self.data.store = data.stores[0]; _self.tiendas = datos.tiendas; } else { _self.data.store = {}; _self.tiendas = []; } if (data.hasOwnProperty("readyHours") && _self.isNumber(data.readyHours)) { _self.readyHours = data.readyHours; } if (data.hasOwnProperty("pickupToday") && _self.isBoolean(data.pickupToday)) { _self.pickupToday = data.pickupToday; } if (data.hasOwnProperty("pickupDay") && _self.isString(data.pickupDay)) { _self.data.pickupDay = data.pickupDay; } _self.searchResults = _self.searchStores(_self.stores); if (_self.searchResults.bopis) { if (_self.feature.myStore) { $C.find(".my-store").replaceWith(buildMyStoreHtml(_self.stores[0], 0)); } $C.find(".popper.bopis .stores").empty(); $C.find(".popper.bopis .stores").append(_self.buildStoresHtml()); $C.find(".popper.bopis .zip-link").hide().html(_self.data.zip); $C.find(".popper.bopis .show-on-results").show(); $C.find(".popper.bopis .no-stores-msg").remove(); $C.find(".popper.bopis .zip-link").show(); $C.find(".popper.bopis .buscar-por-zip").hide(); _self.updateInStockOnly(); _self.updatePopperScrollbar(); _self.addStoreItemHandlers(); } else { $C.find(".popper.bopis .show-on-results").hide(); $C.find(".popper.bopis .buscar-por-zip").show(); $C.find(".popper.bopis .no-stores-msg").remove(); $C.find(".popper.bopis").append("
" + _self.config.messaging.notInStockX.replace("X", "" + código postal + "") + " " + _self.config.messaging.tryArea + "
"); } } else { log("¿Se detuvo aquí?"); $C.find(".popper.bopis .show-on-results").hide(); $C.find(".popper.bopis . buscar-por-zip").show(); $C.find(".popper.bopis .no-stores-msg").remove(); $C.find(".popper.bopis").append( "
" + _self.config.messaging.notInStockX.replace("X", "" + código postal + "") + " " + _self.config.messaging.tryArea + "
"); } if (ventana.progreso) { ventana.progreso.hide(); }}function Bopis_recogerHoyOMañana() { const _self = esto; var ret = "Hoy"; if (!_self.recogerHoy) { if ("" === _self.data.pickupDay) { ret = " Tomorrow"; } else { ret = " " + _self.data.pickupDay; } } return ret;}function Bopis_buildPickupOption() { const _self = this; var str = " ", name = "opción de recepción", labelText = "", isDisabled = true, skuSelected = false, hideRadio = false, M = _self.config.messaging, isChecked = false; skuSelected = !_self.isStringEmpty(_self.data. skuId); if (skuSelected && !_self.isArrayEmpty(_self.stores) && (!_self.data.bopisSku || _self.isObjectEmpty(_self.data.store) || !_self.data.store.bopis || 0 = == _self.data.store.quantity)) { _self.searchResults = _self.searchStores(_self.stores); } str += "
"; isDisabled = _self.isPickupDisabled(); hideRadio = (!skuSelected || 0 === _self.data.skuStockLevel); if (hideRadio) { labelText += ""; if (skuSelected) { labelText += _self.config.messaging.skuOut; } else { labelText += _self.config.messaging.selectSize; } labelText += ""; } else { labelText = _self.buildProductPickupStatus(); } if ("bag" === _self.config.feature && !_self.isObjectEmpty(_self.data.store) && _self.data.bopisSelected) { isChecked = true ; } else { if (!_self.data.skuShipEligible) { isChecked = true; } } str += _self.buildInputRC({isDisabled: isDisabled, isMultiSelect: false, id: name + "-pickup", value: "pickup" , nombre: nombre, contenido: labelText, isChecked: isChecked, isMessage: hideRadio}); str += "
"; return str;}function Bopis_buildPreSaleOption() { const _self = this; var str = "", name = "receive-option", labelText = "", M = _self.config.messaging; if (!_self.data. tieneInventarioPrepedido) { return str; } str += "
"; textoetiqueta += "" + M.PreVentaHeader + " -" + M.preSaleShipMessage + " " + _self.data.releaseDate + "
" + M.preVentaCupónExclusiónMensaje + ""; if ("bolsa" === _self.config.feature && _self.data.preOrderSelected) { _self.fromPreOrder = true; } str += _self.buildInputRC({isMultiSelect: false, id: nombre + "-preventa" , valor: "preventa", nombre: nombre, contenido: labelText, isChecked: "bag" === _self.config.feature && _self.data.preOrderSelected ? true : false}); str += ""; str += "
"; return str;}function Bopis_buildProductShipStatus(skuStockLevel, forceInStock, recargoAmount) { const _self = this; var str = "", M = _self.config.messaging; function fill(msg) { var rE = /{{E}} /, rT = /{{T}}/; msg = msg.replace(rE, _self.data.sddEndTime.replace(" ", "")); msg = msg.replace(rT, _self.data.sddSameDay ? "hoy" : "mañana"); return msj; } str += ""; if (_self.data.skuShipEligible) { str += ("bolsa" === _self.config.feature && !isStringEmpty(_self.data.sddStoreId)) ? M.sdd.title : M.shipFree; if ( "bolsa" === _self.config.feature && !isStringEmpty(_self.data.sddStoreId)) { str += ""; str += " - " + relleno(M.sdd.entrega); str += ""; } else { if ("bolsa" === _self.config.feature && !_self.isStringEmpty(_self.data.estimatedShippingMessage)) { str += ""; str += " - " + _self.config.messaging.estimatedDelivery + _self.data.estimatedShippingMessage; str += ""; } más { cadena += ""; if (!_self.isStringEmpty(_self.shipPromoMsg)) { str += " - " + _self.shipPromoMsg; } str += ""; } } cadena += " "; function storeMsg(store) { var sto = {msg: M.atNearStore, name: M.selectStore}; if (!_self.isObjectEmpty(store)) { if (store.closed) { sto.msg = M.storeClosed ; } else { sto.msg = M.atMyStore; } sto.name = store.name; } return sto; } function ofZip(msg) { var str = br + ssm + msg; if (!_self.isStringEmpty(_self. data.zip)) { str += " of " + _self.data.zip; } str += tc; return str; } función inStoreScenarios() { if (_self.searchResults.isSearch && _self.searchResults.inStore) { if (0 < _self.data.store.quantity) { msg = bh + M.notBopis + tc; if (_self.data.store.closed) { msg += br + ssm + M.storeClosed + tc; } else { msg += br + ssm + M.atMyStore + tc; } msg += _self.buildStoreSelectionToggle(_self.data.store.name); msg += br + _self.availabilityMessage(_self.data.store.quantity, false, true, false); } else { if (!_self.data.skuOnlineOnly) { mensaje = bh + M.noBopisNearby + tc; } else { mensaje = bh + M.notBopis + tc; } msg += br + ssm + M.atNearStore + tc;mensaje += " " + _self.buildStoreSelectionToggle(M.selectStore); } } else { if (_self.data.skuOnlineOnly) { mensaje = bh + M.notBopis + tc; mensaje += br + ssm + _self.config.messaging.skuOnlineOnly + tc; } else { if (_self.data.bopisSku) { mensaje = bh + M.noBopisNearby + tc; msg += ofZip(M.notNearby.replace(regD, _self.data.storeSearchDistance)); mensaje += br + _self.buildStoreSelectionToggle(M.selectZip); } else { mensaje = bh + M.notBopis + tc; if (_self.data.store.closed) { msg += br + ssm + M.storeClosed + tc; } else { msg += br + ssm + M.atNearStore + tc; msg += " " + _self.buildStoreSelectionToggle(M.selectStore); } } } } } if (_self.data.mirakl) { mensaje = bh + M.notBopis + tc; } else { if (_self.data.productOnlineOnly) { mensaje = bh + M.notBopis + tc; if ("pdp" === _self.config.feature) { msg += br + _self.config.messaging.productOnlineOnly; } } else { if (_self.data.skuOnlineOnly) { mensaje = bh + M.notBopis + tc; if ("pdp" === _self.config.feature) { msg += br + ssm + M.skuOnlineOnly + tc; } } else { if (!_self.data.productInStock) { log("(!_self.data.productInStock) El escenario NO debería haber ocurrido"); } else { if (_self.data.bopisEnabled && _self.data.findInStoreEnabled) { if (_self.error) { if (_self.data.skuOnlineOnly) { mensaje = bh + M.notBopis + tc; if ("pdp" === _self.config.feature) { msg += br + ssm + _self.config.messaging.skuOnlineOnly + tc; } } else { if (_self.data.bopisSku) { mensaje = bh + M.noBopisNearby + tc; } else { mensaje = bh + M.notBopis + tc; } msg += ofZip(M.notNearby.replace(regD, _self.data.storeSearchDistance)); mensaje += br + _self.buildStoreSelectionToggle(M.selectZip); } } else { if (_self.data.bopisProduct) { if (!_self.isStringEmpty(_self.data.skuId)) { if (_self.data.bopisSku) { if (!_self.isStringEmpty(_self.data.zip) ) { if (!_self.isObjectEmpty(_self.data.store)) { if (_self.data.store.bopis && 0 < _self.data.store.quantity) { msg = bh + M.bopis + _self.pickupTodayOrTomorrow( ) + tc; msg += br + _self.availabilityMessage(_self.data.store.quantity, false, false, false); mensaje += "en"; mensaje += _self.buildStoreSelectionToggle(_self.data.store.name); mensaje += br + pro; if (_self.isStringEmpty(_self.promoMsg)) { mensaje += M.readyTimeX.replace("X", _self.readyHours); } else { msg += _self.promoMsg; } msg += tc; } else { if (_self.searchResults.bopis) { msg = bh + M.bopis + _self.pickupTodayOrTomorrow() + tc; msg += br + M.cercano + " " + _self.buildStoreSelectionToggle(M.selectStore); msg += br + pro; if (_self.isStringEmpty(_self.promoMsg)) { msg += M.readyTimeX.replace("X ", _self.readyHours); } else { mensaje += _self.promoMsg; } msg += tc; } else { if ("bolso" === _self.config.feature) { mensaje = bh + M.notBopis + tc ; } else { inStoreScenarios(); } } } } else { if (0 === _self.stores.length) { msg = bh + M.notBopis + tc; msg += ofZip(M.noStoresNearby.replace(regD, _self.data.storeSearchDistance)); msg += br + _self.buildStoreSelectionToggle(M.selectZip); } else { msg = bh + M.noBopisNearby + _self.pickupTodayOrTomorrow() + tc; msg += " " + _self.buildStoreSelectionToggle (M.selectStore); } } } else { msg = bh + M.bopis + _self.pickupTodayOrTomorrow() + tc; msg += " " + _self.buildStoreSelectionToggle(M.selectStore); } } else { if ("bolsa" === _self.config.feature) { msg = bh + M.notBopis + tc; } más { inStoreScenarios(); } } } else { log("(_self.isStringEmpty(data.prdoductId)) El escenario NO debería haber ocurrido"); } } else { if (!_self.isStringEmpty(data.prdoductId)) { if (_self.data.bopisSku) { } else { } } else { msg = bh + M.notBopis + tc; msg += br + M.selectSize; } } } } else { if ("bolsa" === _self.config.feature) { msg = bh + M.notBopis + tc; } else { mensaje = bh + M.bopisDisabled + tc; if (_self.data.findInStoreEnabled) { sto = storeMsg(_self.data.store); msg += br + ssm + sto.msg + tc + " " + _self.buildStoreSelectionToggle(sto.name); } } } } } } } str += mensaje; cadena += " "; cadena += " "; cadena += " Mi tiendacerca " + _self.datos.zip + " "; str += _self.buildStoreHtml(almacenar, compensar); str += " Siempre incluido en los resultados del filtro "; cadena += " "; cadena += " ", el =" "; cadena += " "; cadena += " " + "" + mensaje + "" + _self.buildToolTip(_self.data.sddToolTip) + (isTo ? " a " : " ") + alternar + " "; cadena += " "; cadena += " "; cadena += " "; if (!isSdd && !isConns) { str += " " + mensaje + " " + código postal + " "; } cadena += " "; if (VC.showFilters && !VC.myStore) { str += ""; } cadena += " "; if (!isSdd && !isConns) { if (VC.myStore && 0 < _self.stores.length) { str += buildMyStoreHtml(_self.stores[0], 0); } if (!_self.searchResults.isSearch || _self.searchResults.bopis || _self.searchResults.inStore) { str += " "; } más { cadena += " "; zipStr = "" + código postal + ""; if (0 < _self.stores.length) { noStoresMsg = _self.config.messaging.notInStockX.replace("X", zipStr); } else { noStoresMsg = _self.config.messaging.notInStockX.replace("X" , zipStr); } str += " " + noStoresMsg + " " + _self.config.messaging.tryArea + " "; } si (VC.isMultiSelect) { str += " "; } } cadena += " " + _self.config.messaging.notInStockX.replace("X", "" + código postal + "") + " " + _self.config.messaging.tryArea + " " + _self.config.messaging.notInStockX.replace("X", "" + _self.datos.zip + "") + " " + _self.config.messaging.tryArea + " "; labelText = _self.buildConnsDeliveryStatus(); labelText += "
"; str += _self.availabilityMessage(skuStockLevel, forceInStock, true, false); if (_self.isNumber(surchargeAmount) && 0 !== recargoAmount) { str += "$" + ImporteRecargo + " " + M.ImporteRecargoAplica + ""; } } else { str += _self.config.messaging.noShip; str += "
"; cadena += "" + _self.config.messaging.bopisOnly + ""; } cadena += ""; return str;}function Bopis_buildProductPickupStatus() { const _self = this; const regD = /{{D}}/; var str = "", msg = "", br = "
", bh = "", tc = "", ssm = "", pro = "", M = _self.config.messaging, sto = {}; str += "
" + tienda.distancia + " mi"; if (store.bopis) { if (VC.showStock) { str += _self.availabilityMessage(store.quantity, false, true, true); } } else { str += "Temporalmente no disponible"; } cadena += ""; return str;}function Bopis_buildMyStoreHtml(store, offset) { const _self = this; var str = ""; str += ""; cadena += _self.buildStoresHtml(); cadena += "
"; return str;}function Bopis_buildConnsZipSelectionToggle(theClass, text) { const _self = this; var str = ""; str += ""; str += ""; cadena += "
"; return str;}function Bopis_addConnsZipSelectionHandler() { const _self = this, zipClass = "select-zip-conns", ENS = "click". + _self.component.class + "." + zipClass + ".popper"; var $in, len; var $C = $("#" + _self.instance.tagId); var $zObj = $C.find("." + zipClass); $zObj.off(ENS); $zObj. on(ENS, function (e) { $(".toggle-carrot.select-store").prop("checked", false); $(".toggle-carrot.select-store + .vlabel + .popper- ubicación .popper").hide(); _self.isPopperOpen = false; if ($(e.currentTarget).prop("checked")) { _self.showPopper(zipClass); $in = $C.find(". popper .buscar-por-zip .zip-code.conns"); $in.focus(); len = $in.val().length; $in[0].setSelectionRange(len, len); } else { _self.hidePopper(); } e.stopPropagation(); });}function Bopis_buildConnsDeliveryStatus() { const _self = this, zipClass = "select-zip-conns", M = _self.config.messaging, toDeliver = M.connsToDeliver , inStock = _self.data.connsInvData.inStock && (_self.config.feature === "pdp" ? _self.data.connsInvData.hasOwnProperty("conns") && _self.data.connsInvData.conns.ubicación != "" : verdadero), isDeliveryItem = _self.data.connsSKUData.hasOwnProperty("entrega") && _self.data.connsSKUData.delivery, deliveryOptionTitle = isDeliveryItem ? M.connsTruckDelivery : M.ship, errorDeliveryElement = document.querySelector("#js-error-delivery"); var str = "", deliveryMessage = "", zipLabel = "Elija su área", disponibilidad = inStock ? "Disponible": "No se puede", isConnsZipAvailable = !_self.isStringEmpty(_self.data.connsZip); cadena += "
",MARKO='\x3c!-- dwMarker="contenido" dwContentID="',MARKC='" --\x3e';HIDED="ocultar-escritorio",HIDEM="ocultar-móvil",SE="< \/script>",SIB='
FAQs
¿La corbata y el pañuelo de bolsillo tienen que combinar? ›
Una pregunta que nos hacen a menudo es si deberías combinar tu corbata y tu pañuelo de bolsillo. La respuesta corta es no. Si bien puede parecer una manera fácil de coordinar su atuendo, combinar su pañuelo de bolsillo y su corbata o pajarita es definitivamente un no-no en la vestimenta moderna .
¿Qué pañuelo de bolsillo va con una corbata rosa? ›Esta combinación proporciona un elegante esquema de color triádico/monocromático, con el pañuelo de bolsillo azul que complementa perfectamente la corbata rosa (triádica) y la chaqueta azul marino (esquema de color monocromático).
¿Quién llevaba un pañuelo de bolsillo rojo? ›No obstante, los historiadores creen que el pañuelo de bolsillo moderno se originó en el Antiguo Egipto, donde se usaban piezas de lino de color rojo como símbolo de estatus. Los paños de lino de color rojo estaban limitados a los miembros de la casta de clase alta de Egipto , muchos de los cuales los usaban para proyectar su riqueza.
¿Cuándo no llevar pañuelo de bolsillo? ›Si llevas un blazer y unos chinos o un traje de dos piezas, la elección entre añadir un pañuelo de bolsillo depende en gran medida de lo informal que sea el look general. Si la parte superior y los zapatos se inclinan hacia lo formal, entonces se puede introducir un pañuelo de bolsillo. Si llevas camiseta y zapatillas deportivas , es recomendable dejarlo fuera.
¿Cuándo debo usar un pañuelo de bolsillo? ›Como regla general, las personas usan pañuelos de bolsillo en ocasiones más formales, como bodas, galas, bailes, alfombras rojas, eventos de etiqueta y reuniones de trabajo/profesionales . Para esmóquines negros, los pañuelos de bolsillo de color sólido, como blanco o grisáceo, se ven mejor.
¿Qué color de corbata va mejor con una camisa de vestir rosa? ›Camisa rosa
Las camisas rosas son bastante versátiles y se verían geniales con corbatas a juego. El azul es un color que contrasta con el rosa, y no hay una corbata de mejor color para combinar con una camisa rosa. Puede elegir entre corbatas de color azul sólido o texturizado como esta corbata de tweed azul turco para combinar con su camisa rosa.
Por ejemplo, si llevas una camisa azul o un traje azul, puedes jugar con los colores tono sobre tono eligiendo un pañuelo de bolsillo azul claro . Este es un buen consejo incluso si la corbata está presente.
¿Puedes usar una corbata negra con una camisa rosa? ›Lazo negro
Se puede pero no con una camiseta rosa . Sin embargo, tal vez no sea un negro liso sobre un rosa liso. Elija una corbata con un toque de rosa y estará listo para rodar y pasear.
El conocido «Pocket Square” o pañuelo de bolsillo ha sido siempre un símbolo de sobriedad y elegancia del verdadero gentleman. En nuestro país fue desapareciendo poco a poco, pero esta tendencia vuelve a ocupar su destacado puesto en la moda masculina para darle un toque espectacular a todos tus looks.
¿Cómo se llama el pañuelo que va en el saco? ›El pañuelo de bolsillo –llamado pochette, en francés, pocket square o handkerchief en inglés– es un detalle que completa la indumentaria masculina y que demuestra como pocos complementos el buen gusto en el vestir de quien lo lleva.
¿Por qué se llama pañuelo? ›
La palabra pañuelo era originalmente "pañuelo de mano" y se hizo popular en el siglo XVI . Los pañuelos eran pequeñas piezas de tela que, desde alrededor de la Edad Media, se usaban para cubrir la cabeza y el cabello.
¿Los hombres usan pañuelos de bolsillo? ›En realidad, la mayoría de los hombres no usan pañuelos de bolsillo porque realmente no saben que es una opción, no saben dónde los consigues o incluso cómo los doblas para que funcionen. Es por eso que la mayoría ni siquiera los ha considerado como parte de su arsenal de trajes/chaquetas. Algunos pueden temer que pueda llamar la atención sobre ti.
¿Deben los invitados a la boda llevar un pañuelo de bolsillo? ›En general, los pañuelos de bolsillo definitivamente no son un requisito , son solo un accesorio divertido destinado a agregar algo de personalidad a tu estilo. Aún así, tanto Wright como McGoff los recomiendan, especialmente para los novios. "Si te vas a casar y usas una chaqueta, debes usar un pañuelo de bolsillo", dice McGoff.
¿Puedes poner un pañuelo de bolsillo en una camisa de vestir? ›Nunca agregue un pañuelo de bolsillo a su abrigo, abrigo o camisa . Solo debe agregarse a su traje o chaqueta. ¡No hagas coincidir exactamente tu pañuelo de bolsillo con tu corbata o pajarita!
¿El pañuelo de bolsillo debe ser más claro o más oscuro que la corbata? ›Reglas para combinar corbatas y pañuelos de bolsillo
Tu pañuelo de bolsillo debe elegir al menos uno de los colores de tu corbata, pero eso no significa necesariamente que el tono deba combinar. Su pañuelo de bolsillo debe darle un acento sutil a su corbata, lo que podría significar mostrar un tono ligeramente más claro o más oscuro .
Debes tratar de ser formal y respetuoso. Es posible que desee usar un traje negro con un pañuelo de bolsillo monocromático simple (generalmente blanco) doblado en un borde recto simple . Básicamente, cualquier evento en el que use un blazer o un traje, también debe usar un pañuelo de bolsillo como complemento de su traje.
¿Qué tamaño debe tener un pañuelo de bolsillo? ›¿Cuál es el mejor tamaño para un pañuelo de bolsillo? Los pañuelos de bolsillo generalmente varían en tamaño desde poco menos de 10 x 10 pulgadas hasta aproximadamente 17 x 17 pulgadas , según la tela utilizada. Los materiales más gruesos son generalmente más fáciles de plegar en tamaños más pequeños; sin embargo, los materiales más delgados requieren un tamaño mayor para que no pierdan su forma.
¿Qué color de corbata combina con todo? ›Una corbata negra combina con todo y es adecuada para todas las ocasiones, desde funerales hasta el trabajo.
¿Se puede llevar corbata con cualquier camisa? ›Choose a type of tie that matches the shirt you are going to wear . Tenga en cuenta que no todas las corbatas son buenas para todas las camisas. Generalmente, las corbatas anchas son para camisas con cuellos anchos y las corbatas angostas son para camisas con cuellos angostos.
¿Qué corbata llevar con camisa negra? ›Esto sería seguir la famosa regla antes mencionada de que la corbata debe ser de un color más oscuro que la camisa. Como el negro es el más oscuro, no hay color más oscuro para elegir para una corbata. Otra idea si quieres usar tu camisa negra favorita para un evento formal sería usarla con un lazo.
¿Qué color de corbata y pañuelo de bolsillo con traje azul marino? ›
Combinación Marrón
Lo hemos combinado con nuestro pañuelo de bolsillo Before the Race by Degas. Marrón y azul marino es realmente una gran combinación que, en nuestra opinión, está infrautilizada y siempre funciona bien, ya que son paletas de colores complementarias.
Los colores de corbatas para traje azul más acertados son: el rojo, el gris y el negro, porque logran que se acentúan los colores y forman un buen equilibrio.
¿Qué corbata me pongo con un blazer azul marino? ›Las opciones más populares son el azul, el verde y el morado , pero las corbatas rojas o rosadas también pueden funcionar bien con un traje azul marino. Al elegir una corbata, tenga en cuenta que cuanto más brillante sea el tono de la corbata, más informal se verá. Si va a una ocasión formal, intente elegir algo más oscuro en la sombra.
¿La corbata negra significa que tienes que vestir de negro? ›Pero para ser claros, un código de vestimenta de corbata negra no requiere que una mujer vista de negro . Todos los colores son aceptables y hay algunos fantásticos tonos de joyas que gritan el nivel adecuado de opulencia para una ocasión elegante.
¿Es lo mismo corbata negra que formal? ›¿Qué es un evento de corbata negra? La corbata negra es un código de vestimenta formal para ocasiones nocturnas, como una cena, una ceremonia de entrega de premios, un cumpleaños importante o una boda. Menos formal que la corbata blanca pero más formal que la vestimenta de negocios, se usa tradicionalmente para eventos después de las 6:00 p. m.
¿Qué significa corbata negra opcional? ›Corbata negra opcional:
Un código de vestimenta opcional de corbata negra ofrece a los invitados un par de opciones formales para elegir . Los hombres deben vestir esmoquin, pero pueden optar por un traje oscuro. Las mujeres pueden elegir un vestido de noche formal, un vestido de cóctel más corto o prendas separadas elegantes.
¿La regla número uno para los pañuelos de vestir (o pañuelos de bolsillo)? El pañuelo y la corbata nunca, nunca hacen juego . Por eso, te recomendamos evitar como la peste esos pañuelos de bolsillo sedosos y estampados que suelen venderse con corbatas a juego.
¿Cuál es el propósito de un pañuelo? ›Los pañuelos son imprescindibles para mantenerte limpio a ti, a tu ropa y a tu equipo . Se pueden usar para limpiar pequeños líos como limpiarse las manos o la cara. Si no hay un pañuelo cerca, probablemente uses tu propia ropa. No seas un vago limpiándote las manos en las mangas o los pantalones cada vez que algo las toque.
¿Los hombres todavía usan pañuelos? ›¿Se siguen usando pañuelos? Sí, los pañuelos todavía se usan y no solo por las generaciones mayores . Millennials y Gen Z'ers están cambiando a pañuelos, y no es solo para hacer una declaración. Es porque son increíblemente prácticos, convenientes y ecológicos.
¿Dónde debe guardar un hombre su pañuelo? ›Por supuesto que podrían hacerlo en un apuro real. Pero normalmente se lleva un pañuelo en el bolsillo del pantalón , fuera de la vista. Los pañuelos no tienen que ser elegantes. Solo uno blanco liso servirá.
¿Qué tipo de pañuelo es mejor? ›
Los pañuelos hechos 100% de algodón liviano de alta calidad son los mejores porque el algodón es absorbente, liviano y duradero. Pero la suavidad depende de la calidad del algodón utilizado. Otras telas absorbentes como el lino liviano, la gasa de algodón y la batista de algodón también son buenas opciones para los pañuelos.
¿Qué pasa si se hace un nudo en un pañuelo? ›Se creía en la Grecia clásica que un nudo en cualquier trozo de lienzo que se llevara como bolso o hatillo contrarresta el mal de ojo; acaso se relacione con ello la costumbre supersticiosa de hacer un nudo en el pañuelo para no caer en el olvido de algo.
¿Qué significa el pañuelo en el traje? ›«El pañuelo significa un plus de etiqueta y de distinción. Ese toque diferenciador de carácter, que no ideología, está considerado como uno de los mejores exponentes de la elegancia masculina y de una marcada personalidad. De algodón, lino fino, lana o seda, quien lo lleva disfruta vistiendo y de su libertad.
¿De dónde vienen los pañuelos de bolsillo? ›El pañuelo de bolsillo se originó primero como un simple pañuelo blanco liso. Los antiguos egipcios llevaban pequeños cuadrados de lino, algunos de los cuales estaban teñidos con polvo rojo, lo que indica que se usaban con fines decorativos o estéticos.
¿Debe un pañuelo de bolsillo combinar con la camisa? ›No hay una regla fija para elegir un pañuelo de bolsillo. Simplemente debe complementar su camisa y corbata, no combinarlos . Si se ve bien y se siente bien, salga por la puerta.
¿Se puede llevar un pañuelo de bolsillo en una camisa? ›Nunca agregue un pañuelo de bolsillo a su abrigo, abrigo o camisa . Solo debe agregarse a su traje o chaqueta. ¡No hagas coincidir exactamente tu pañuelo de bolsillo con tu corbata o pajarita! Puede ser su primer instinto hacer coincidir exactamente sus accesorios, pero según los estándares de moda de hoy en día, esto es un no definitivo.
¿Cómo va la corbata en un traje? ›El largo de la corbata: lo clásico
Desde la perspectiva clásica, la regla de oro para la corbata es simple: la punta debe terminar a la mitad de la pretina o del cinturón, quedando justo en ese punto.
Según las normas del protocolo del buen vestir, el pañuelo debe ir colocado en el bolsillo superior izquierdo de la chaqueta, permitiendo que asome del mismo unos tres centímetros aproximadamente.
¿Cómo se llama el pañuelo en el bolsillo? ›El pañuelo de bolsillo –llamado pochette, en francés, pocket square o handkerchief en inglés– es un detalle que completa la indumentaria masculina y que demuestra como pocos complementos el buen gusto en el vestir de quien lo lleva.
¿Debo usar un pañuelo de bolsillo con un blazer? ›Every time you put on a suit coat, sport coat or blazer, a pocket square should be worn . Ciertamente, cada vez que se encuentre en un entorno formal, debe tener un pañuelo de bolsillo. Con o sin corbata, la chaqueta de su traje siempre debe tener un pañuelo en el bolsillo del pecho.
¿Qué significado tiene el pañuelo negro? ›
El paliacate en México
El característico estampado de bacterias, especialmente en su combinación de rojo, blanco y negro, es reconocido en México como un símbolo del hombre trabajador, también como subversión política y resistencia cultural. En particular, cuando está asociado con los rebeldes zapatistas.
El pañuelo sólo cumple funciones cuando se está resfriado, cuando se llora o cuando se debe quitar el rouge dejado quizá por un beso “non sancto”. Entonces si se regala un pañuelo se está deseando a la persona que lo recibe que se enferme, que tenga una desgracia o que descubra la infidelidad del ser amado.
¿Qué pañuelo significa? ›El término pañuelo es un diminutivo de paño. El concepto alude al trozo pequeño de tela que se utiliza principalmente para secarse el sudor o limpiarse la nariz.
¿Qué tipo de corbata está de moda? ›Existen al menos dos tipos de corbatas: la larga, que es el tipo más usual actualmente, y la corta o "de moño". En la actualidad, es complemento de la camisa y el traje; asimismo, existen las corbatas de tipo estilizadas, que también son conocidas como corte "slim".