");return c.inlineElement=f,f}return b.updateStatus("ready"),b._parseMarkup(d,{},c),d}}});var H,I="ajax",J=function(){H&&a(document.body).removeClass(H)},K=function(){J(),b.req&&b.req.abort()};a.magnificPopup.registerModule(I,{options:{settings:null,cursor:"mfp-ajax-cur",tError:'
The content could not be loaded.'},proto:{initAjax:function(){b.types.push(I),H=b.st.ajax.cursor,w(h+"."+I,K),w("BeforeChange."+I,K)},getAjax:function(c){H&&a(document.body).addClass(H),b.updateStatus("loading");var d=a.extend({url:c.src,success:function(d,e,f){var g={data:d,xhr:f};y("ParseAjax",g),b.appendContent(a(g.data),I),c.finished=!0,J(),b._setFocus(),setTimeout(function(){b.wrap.addClass(q)},16),b.updateStatus("ready"),y("AjaxContentAdded")},error:function(){J(),c.finished=c.loadError=!0,b.updateStatus("error",b.st.ajax.tError.replace("%url%",c.src))}},b.st.ajax.settings);return b.req=a.ajax(d),""}}});var L,M=function(c){if(c.data&&void 0!==c.data.title)return c.data.title;var d=b.st.image.titleSrc;if(d){if(a.isFunction(d))return d.call(b,c);if(c.el)return c.el.attr(d)||""}return""};a.magnificPopup.registerModule("image",{options:{markup:'
',cursor:"mfp-zoom-out-cur",titleSrc:"title",verticalFit:!0,tError:'
The image could not be loaded.'},proto:{initImage:function(){var c=b.st.image,d=".image";b.types.push("image"),w(m+d,function(){"image"===b.currItem.type&&c.cursor&&a(document.body).addClass(c.cursor)}),w(h+d,function(){c.cursor&&a(document.body).removeClass(c.cursor),v.off("resize"+p)}),w("Resize"+d,b.resizeImage),b.isLowIE&&w("AfterChange",b.resizeImage)},resizeImage:function(){var a=b.currItem;if(a&&a.img&&b.st.image.verticalFit){var c=0;b.isLowIE&&(c=parseInt(a.img.css("padding-top"),10)+parseInt(a.img.css("padding-bottom"),10)),a.img.css("max-height",b.wH-c)}},_onImageHasSize:function(a){a.img&&(a.hasSize=!0,L&&clearInterval(L),a.isCheckingImgSize=!1,y("ImageHasSize",a),a.imgHidden&&(b.content&&b.content.removeClass("mfp-loading"),a.imgHidden=!1))},findImageSize:function(a){var c=0,d=a.img[0],e=function(f){L&&clearInterval(L),L=setInterval(function(){return d.naturalWidth>0?void b._onImageHasSize(a):(c>200&&clearInterval(L),c++,void(3===c?e(10):40===c?e(50):100===c&&e(500)))},f)};e(1)},getImage:function(c,d){var e=0,f=function(){c&&(c.img[0].complete?(c.img.off(".mfploader"),c===b.currItem&&(b._onImageHasSize(c),b.updateStatus("ready")),c.hasSize=!0,c.loaded=!0,y("ImageLoadComplete")):(e++,200>e?setTimeout(f,100):g()))},g=function(){c&&(c.img.off(".mfploader"),c===b.currItem&&(b._onImageHasSize(c),b.updateStatus("error",h.tError.replace("%url%",c.src))),c.hasSize=!0,c.loaded=!0,c.loadError=!0)},h=b.st.image,i=d.find(".mfp-img");if(i.length){var j=document.createElement("img");j.className="mfp-img",c.el&&c.el.find("img").length&&(j.alt=c.el.find("img").attr("alt")),c.img=a(j).on("load.mfploader",f).on("error.mfploader",g),j.src=c.src,i.is("img")&&(c.img=c.img.clone()),j=c.img[0],j.naturalWidth>0?c.hasSize=!0:j.width||(c.hasSize=!1)}return b._parseMarkup(d,{title:M(c),img_replaceWith:c.img},c),b.resizeImage(),c.hasSize?(L&&clearInterval(L),c.loadError?(d.addClass("mfp-loading"),b.updateStatus("error",h.tError.replace("%url%",c.src))):(d.removeClass("mfp-loading"),b.updateStatus("ready")),d):(b.updateStatus("loading"),c.loading=!0,c.hasSize||(c.imgHidden=!0,d.addClass("mfp-loading"),b.findImageSize(c)),d)}}});var N,O=function(){return void 0===N&&(N=void 0!==document.createElement("p").style.MozTransform),N};a.magnificPopup.registerModule("zoom",{options:{enabled:!1,easing:"ease-in-out",duration:300,opener:function(a){return a.is("img")?a:a.find("img")}},proto:{initZoom:function(){var a,c=b.st.zoom,d=".zoom";if(c.enabled&&b.supportsTransition){var e,f,g=c.duration,j=function(a){var b=a.clone().removeAttr("style").removeAttr("class").addClass("mfp-animated-image"),d="all "+c.duration/1e3+"s "+c.easing,e={position:"fixed",zIndex:9999,left:0,top:0,"-webkit-backface-visibility":"hidden"},f="transition";return e["-webkit-"+f]=e["-moz-"+f]=e["-o-"+f]=e[f]=d,b.css(e),b},k=function(){b.content.css("visibility","visible")};w("BuildControls"+d,function(){if(b._allowZoom()){if(clearTimeout(e),b.content.css("visibility","hidden"),a=b._getItemToZoom(),!a)return void k();f=j(a),f.css(b._getOffset()),b.wrap.append(f),e=setTimeout(function(){f.css(b._getOffset(!0)),e=setTimeout(function(){k(),setTimeout(function(){f.remove(),a=f=null,y("ZoomAnimationEnded")},16)},g)},16)}}),w(i+d,function(){if(b._allowZoom()){if(clearTimeout(e),b.st.removalDelay=g,!a){if(a=b._getItemToZoom(),!a)return;f=j(a)}f.css(b._getOffset(!0)),b.wrap.append(f),b.content.css("visibility","hidden"),setTimeout(function(){f.css(b._getOffset())},16)}}),w(h+d,function(){b._allowZoom()&&(k(),f&&f.remove(),a=null)})}},_allowZoom:function(){return"image"===b.currItem.type},_getItemToZoom:function(){return b.currItem.hasSize?b.currItem.img:!1},_getOffset:function(c){var d;d=c?b.currItem.img:b.st.zoom.opener(b.currItem.el||b.currItem);var e=d.offset(),f=parseInt(d.css("padding-top"),10),g=parseInt(d.css("padding-bottom"),10);e.top-=a(window).scrollTop()-f;var h={width:d.width(),height:(u?d.innerHeight():d[0].offsetHeight)-g-f};return O()?h["-moz-transform"]=h.transform="translate("+e.left+"px,"+e.top+"px)":(h.left=e.left,h.top=e.top),h}}});var P="iframe",Q="//about:blank",R=function(a){if(b.currTemplate[P]){var c=b.currTemplate[P].find("iframe");c.length&&(a||(c[0].src=Q),b.isIE8&&c.css("display",a?"block":"none"))}};a.magnificPopup.registerModule(P,{options:{markup:'
',srcAction:"iframe_src",patterns:{youtube:{index:"youtube.com",id:"v=",src:"//www.youtube.com/embed/%id%?autoplay=1"},vimeo:{index:"vimeo.com/",id:"/",src:"//player.vimeo.com/video/%id%?autoplay=1"},gmaps:{index:"//maps.google.",src:"%id%&output=embed"}}},proto:{initIframe:function(){b.types.push(P),w("BeforeChange",function(a,b,c){b!==c&&(b===P?R():c===P&&R(!0))}),w(h+"."+P,function(){R()})},getIframe:function(c,d){var e=c.src,f=b.st.iframe;a.each(f.patterns,function(){return e.indexOf(this.index)>-1?(this.id&&(e="string"==typeof this.id?e.substr(e.lastIndexOf(this.id)+this.id.length,e.length):this.id.call(this,e)),e=this.src.replace("%id%",e),!1):void 0});var g={};return f.srcAction&&(g[f.srcAction]=e),b._parseMarkup(d,g,c),b.updateStatus("ready"),d}}});var S=function(a){var c=b.items.length;return a>c-1?a-c:0>a?c+a:a},T=function(a,b,c){return a.replace(/%curr%/gi,b+1).replace(/%total%/gi,c)};a.magnificPopup.registerModule("gallery",{options:{enabled:!1,arrowMarkup:'
',preload:[0,2],navigateByImgClick:!0,arrows:!0,tPrev:"Previous (Left arrow key)",tNext:"Next (Right arrow key)",tCounter:"%curr% of %total%"},proto:{initGallery:function(){var c=b.st.gallery,e=".mfp-gallery";return b.direction=!0,c&&c.enabled?(f+=" mfp-gallery",w(m+e,function(){c.navigateByImgClick&&b.wrap.on("click"+e,".mfp-img",function(){return b.items.length>1?(b.next(),!1):void 0}),d.on("keydown"+e,function(a){37===a.keyCode?b.prev():39===a.keyCode&&b.next()})}),w("UpdateStatus"+e,function(a,c){c.text&&(c.text=T(c.text,b.currItem.index,b.items.length))}),w(l+e,function(a,d,e,f){var g=b.items.length;e.counter=g>1?T(c.tCounter,f.index,g):""}),w("BuildControls"+e,function(){if(b.items.length>1&&c.arrows&&!b.arrowLeft){var d=c.arrowMarkup,e=b.arrowLeft=a(d.replace(/%title%/gi,c.tPrev).replace(/%dir%/gi,"left")).addClass(s),f=b.arrowRight=a(d.replace(/%title%/gi,c.tNext).replace(/%dir%/gi,"right")).addClass(s);e.click(function(){b.prev()}),f.click(function(){b.next()}),b.container.append(e.add(f))}}),w(n+e,function(){b._preloadTimeout&&clearTimeout(b._preloadTimeout),b._preloadTimeout=setTimeout(function(){b.preloadNearbyImages(),b._preloadTimeout=null},16)}),void w(h+e,function(){d.off(e),b.wrap.off("click"+e),b.arrowRight=b.arrowLeft=null})):!1},next:function(){b.direction=!0,b.index=S(b.index+1),b.updateItemHTML()},prev:function(){b.direction=!1,b.index=S(b.index-1),b.updateItemHTML()},goTo:function(a){b.direction=a>=b.index,b.index=a,b.updateItemHTML()},preloadNearbyImages:function(){var a,c=b.st.gallery.preload,d=Math.min(c[0],b.items.length),e=Math.min(c[1],b.items.length);for(a=1;a<=(b.direction?e:d);a++)b._preloadItem(b.index+a);for(a=1;a<=(b.direction?d:e);a++)b._preloadItem(b.index-a)},_preloadItem:function(c){if(c=S(c),!b.items[c].preloaded){var d=b.items[c];d.parsed||(d=b.parseEl(c)),y("LazyLoad",d),"image"===d.type&&(d.img=a('
![]()
').on("load.mfploader",function(){d.hasSize=!0}).on("error.mfploader",function(){d.hasSize=!0,d.loadError=!0,y("LazyLoadError",d)}).attr("src",d.src)),d.preloaded=!0}}}});var U="retina";a.magnificPopup.registerModule(U,{options:{replaceSrc:function(a){return a.src.replace(/\.\w+$/,function(a){return"@2x"+a})},ratio:1},proto:{initRetina:function(){if(window.devicePixelRatio>1){var a=b.st.retina,c=a.ratio;c=isNaN(c)?c():c,c>1&&(w("ImageHasSize."+U,function(a,b){b.img.css({"max-width":b.img[0].naturalWidth/c,width:"100%"})}),w("ElementParse."+U,function(b,d){d.src=a.replaceSrc(d,c)}))}}}}),A()});
// source --> https://atakent.kz/wp-content/themes/atakent/js/mapplic.js?ver=5.2.20
/*
* Mapplic - Custom Interactive Map Plugin by @sekler
* Version 4.1
* http://www.mapplic.com/
*/
;(function($) {
"use strict";
var Mapplic = function(element) {
var self = this;
self.o = {
source: 'map.json',
selector: '[id^=landmark] > *',
landmark: false,
mapfill: false,
height: 420,
markers: true,
minimap: true,
sidebar: true,
search: true,
deeplinking: true,
clearbutton: true,
zoombuttons: true,
zoomoutclose: false,
action: 'tooltip',
lightbox: false,
hovertip: true,
smartip: true,
fillcolor: '#4d5e6d',
fullscreen: true,
developer: false,
mousewheel: true,
alphabetic: false,
maxscale: 3,
zoom: true
};
self.el = element;
self.init = function(options) {
// Merging options with defaults
self.o = $.extend(self.o, options);
self.el.addClass('mapplic-element mapplic-loading').height(self.o.height);
if (typeof self.o.source === 'string') {
// Loading .json file with AJAX
$.getJSON(self.o.source, function(data) { // Success
processData(data);
self.el.removeClass('mapplic-loading');
}).fail(function() { // Failure: couldn't load JSON file or it is invalid.
console.error('Couldn\'t load map data. (Make sure to run the script through web server)');
self.el.removeClass('mapplic-loading').addClass('mapplic-error');
alert('Data file missing or invalid!\nMake sure to run the script through web server.');
});
}
else {
// Inline json object
processData(self.o.source);
self.el.removeClass('mapplic-loading');
}
return self;
}
// Tooltip
function Tooltip() {
this.el = null;
this.pin = null;
this.shift = 6;
this.drop = 0;
this.location = null;
this.tooltipthumb = true;
this.tooltiplink = true;
this.init = function() {
var s = this;
// Construct
this.el = $('
').addClass('mapplic-tooltip');
this.close = $('
').addClass('mapplic-tooltip-close').attr('href', '#').appendTo(this.el);
this.close.on('click touchend', function(e) {
e.preventDefault();
self.hideLocation();
self.moveTo(0.5, 0.5, self.fitscale, 400, 'easeInOutCubic');
if (!self.o.zoom || self.o.zoomoutclose) self.moveTo(0.5, 0.5, self.fitscale, 400, 'easeInOutCubic');
});
if (this.tooltipthumb) this.thumbnail = $('
![]()
').addClass('mapplic-tooltip-thumbnail').hide().appendTo(this.el);
this.content = $('
').addClass('mapplic-tooltip-content').appendTo(this.el);
this.title = $('
').addClass('mapplic-tooltip-title').appendTo(this.content);
this.desc = $('
').addClass('mapplic-tooltip-description').appendTo(this.content);
if (this.tooltiplink) this.link = $('
').addClass('mapplic-popup-link').attr('href', '#').hide().appendTo(this.el);
this.triangle = $('
').addClass('mapplic-tooltip-triangle').prependTo(this.el);
// Append
self.map.append(this.el);
return this;
}
this.show = function(location) {
if (location) {
var s = this;
this.location = location;
if (self.hovertip) self.hovertip.hide();
if (this.tooltipthumb) {
if (location.thumbnail) this.thumbnail.attr('src', location.thumbnail).show();
else this.thumbnail.hide();
}
if (this.tooltiplink) {
if (location.link) this.link.attr('href', location.link).show();
else this.link.hide();
}
this.title.text(location.title);
if (location.description) this.desc.html(location.description);
else this.desc.empty();
this.content[0].scrollTop = 0;
// Shift
this.pin = $('.mapplic-pin[data-location="' + location.id + '"]');
if (this.pin.length == 0) {
this.shift = 20;
}
else this.shift = Math.abs(parseFloat(this.pin.css('margin-top'))) + 20;
// Loading & positioning
$('img', this.el).off('load').on('load', function() {
s.position();
s.zoom(location);
});
this.position();
// Making it visible
this.el.stop().show();
this.zoom(location);
}
}
this.position = function() {
if (this.location) {
var cx = self.map.offset().left + self.map.width() * this.location.x - self.container.offset().left,
cy = self.map.offset().top + self.map.height() * this.location.y - self.container.offset().top;
var x = this.location.x * 100,
y = this.location.y * 100,
mt = -this.el.outerHeight() - this.shift,
ml = -this.el.outerWidth() / 2;
if (self.o.smartip) {
var verticalPos = 0.5;
// Top check
if (Math.abs(mt) > cy) {
mt = 8 + 2;
if (this.pin && this.pin.length) mt = this.pin.height() + parseFloat(this.pin.css('margin-top')) + 20;
this.el.addClass('mapplic-bottom');
}
else this.el.removeClass('mapplic-bottom');
// Left-right check
if (this.el.outerWidth()/2 > cx)
verticalPos = 0.5 - (this.el.outerWidth()/2 - cx)/this.el.outerWidth();
else if ((self.container.width() - cx - this.el.outerWidth()/2) < 0)
verticalPos = 0.5 + (cx + this.el.outerWidth()/2 - self.container.width())/this.el.outerWidth();
verticalPos = Math.max(0, Math.min(1, verticalPos));
ml = -this.el.outerWidth() * verticalPos;
this.triangle.css('left', Math.max(5, Math.min(95, verticalPos * 100)) + '%');
}
this.el.css({
left: x + '%',
top: y + '%',
marginTop: mt,
marginLeft: ml
});
this.drop = this.el.outerHeight() + this.shift;
}
}
this.zoom = function(location) {
var ry = 0.5,
zoom = location.zoom ? parseFloat(location.zoom) : self.o.maxscale;
ry = ((self.container.height() - this.drop) / 2 + this.drop) / self.container.height();
self.moveTo(location.x, location.y, zoom, 600, 'easeInOutCubic', ry);
}
this.hide = function() {
var s = this;
this.location = null;
this.el.stop().fadeOut(300, function() {
if (s.desc) s.desc.empty();
});
}
}
// Lightbox
function Lightbox() {
this.el = null;
this.init = function() {
// Construct
this.el = $('
').addClass('mapplic-lightbox mfp-hide');
this.title = $('
').addClass('mapplic-lightbox-title').appendTo(this.el);
this.desc = $('
').addClass('mapplic-lightbox-description').appendTo(this.el);
this.link = $('

').addClass('mapplic-popup-link').attr('href','#').hide().appendTo(this.el);
// Popup Image
$('body').magnificPopup({
delegate: '.popup-link',
type: 'ajax',
removalDelay: 1500,
callbacks: {
ajaxContentAdded: function() {
$('.mfp-bg').addClass('mfpbg_loaded');
setTimeout(function(){
$('.mfp-wrap').addClass('mfp_loaded');
},1000);
},
beforeClose: function() {
$('.mfp-wrap').removeClass('mfp_loaded');
setTimeout(function(){
$('.mfp-bg').removeClass('mfpbg_loaded');
},1000);
}
},
mainClass: 'map-mfp',
fixedContentPos: false,
fixedBgPos: false,
overflowY: 'auto',
prependTo: '.mapplic-container'
});
// Append
self.el.append(this.el);
return this;
}
this.show = function(location) {
this.location = location;
this.title.text(location.title);
this.desc.html(location.description);
if (location.link) this.link.attr('href', location.link).show();
else this.link.hide();
var s = this;
$.magnificPopup.open({
items: {
src: this.el
},
type: 'inline',
removalDelay: 300,
mainClass: 'mfp-fade',
callbacks: {
beforeClose: function() {
s.hide();
}
}
});
// Zoom
var zoom = location.zoom ? parseFloat(location.zoom) : self.o.maxscale;
self.moveTo(location.x, location.y, zoom, 600, 'easeInOutCubic');
// Hide tooltip
if (self.tooltip) self.tooltip.hide();
}
this.hide = function() {
this.location = null;
self.hideLocation();
if (!self.o.zoom || self.o.zoomoutclose) self.moveTo(0.5, 0.5, self.fitscale, 400, 'easeInOutCubic');
}
}
// HoverTooltip
function HoverTooltip() {
this.el = null;
this.pin = null;
this.shift = 6;
this.hovertipdesc = false;
this.init = function() {
var s = this;
// Construct
this.el = $('
').addClass('mapplic-tooltip mapplic-hovertip');
this.title = $('
').addClass('mapplic-tooltip-title').appendTo(this.el);
if (this.hovertipdesc) this.desc = $('
').addClass('mapplic-tooltip-description').appendTo(this.el);
this.triangle = $('
').addClass('mapplic-tooltip-triangle').appendTo(this.el);
// Events
// pins + old svg
$(self.map).on('mouseover', '.mapplic-layer a', function() {
var id = '';
if ($(this).hasClass('mapplic-pin')) {
id = $(this).data('location');
s.pin = $('.mapplic-pin[data-location="' + id + '"]');
s.shift = Math.abs(parseFloat(s.pin.css('margin-top'))) + 20;
}
else {
id = $(this).attr('xlink:href').slice(1);
s.shift = 20;
}
var location = self.getLocationData(id);
if (location) s.show(location);
}).on('mouseout', function() {
s.hide();
});
// new svg
if (self.o.selector) {
$(self.map).on('mouseover', self.o.selector, function() {
var location = self.getLocationData($(this).attr('id'));
s.shift = 20;
if (location) s.show(location);
}).on('mouseout', function() {
s.hide();
});
}
self.map.append(this.el);
return this;
}
this.show = function(location) {
if (self.tooltip.location != location) {
this.title.text(location.title);
if (this.hovertipdesc) this.desc.html(location.description);
this.position(location);
this.el.stop().fadeIn(100);
}
}
this.position = function(location) {
var cx = self.map.offset().left + self.map.width() * location.x - self.container.offset().left,
cy = self.map.offset().top + self.map.height() * location.y - self.container.offset().top;
var x = location.x * 100,
y = location.y * 100,
mt = -this.el.outerHeight() - this.shift,
ml = 0;
var verticalPos = 0.5;
// Top check
if (Math.abs(mt) > cy) {
mt = 8 + 2;
if (this.pin && this.pin.length) mt = this.pin.height() + parseFloat(this.pin.css('margin-top')) + 20;
this.el.addClass('mapplic-bottom');
}
else this.el.removeClass('mapplic-bottom');
// Left-right check
if (this.el.outerWidth()/2 > cx)
verticalPos = 0.5 - (this.el.outerWidth()/2 - cx)/this.el.outerWidth();
else if ((self.container.width() - cx - this.el.outerWidth()/2) < 0)
verticalPos = 0.5 + (cx + this.el.outerWidth()/2 - self.container.width())/this.el.outerWidth();
ml = -this.el.outerWidth() * verticalPos;
this.triangle.css('left', Math.max(10, Math.min(90, verticalPos * 100)) + '%');
this.el.css({
left: x + '%',
top: y + '%',
marginTop: mt,
marginLeft: ml
});
}
this.hide = function() {
this.el.stop().fadeOut(200);
}
}
// Deeplinking
function Deeplinking() {
this.param = 'location';
this.init = function() {
var s = this;
this.check(0);
window.onpopstate = function(e) {
if (e.state) {
s.check(600);
}
return false;
}
}
this.check = function(easing) {
var id = this.getUrlParam(this.param);
self.showLocation(id, easing, true);
}
this.getUrlParam = function(name) {
name = name.replace(/[\[]/, "\\[").replace(/[\]]/, "\\]");
var regex = new RegExp("[\\?&]" + name + "=([^]*)"),
results = regex.exec(location.search);
return results === null ? "" : decodeURIComponent(results[1].replace(/\+/g, " "));
}
this.update = function(id) {
var url = window.location.protocol + "//" + window.location.host + window.location.pathname + '?' + this.param + '=' + id;
window.history.pushState({path: url}, '', url);
}
// Clear
this.clear = function() {
history.pushState('', document.title, window.location.pathname);
}
}
// Old hash deeplinking method for old browsers
function DeeplinkingHash() {
this.param = 'location';
this.init = function() {
var s = this;
this.check(0);
$(window).on('hashchange', function() {
s.check(600);
});
}
this.check = function(easing) {
var id = location.hash.slice(this.param.length + 2);
self.showLocation(id, easing, true);
}
this.update = function(id) {
window.location.hash = this.param + '-' + id;
}
this.clear = function() {
window.location.hash = this.param;
}
}
// Minimap
function Minimap() {
this.el = null;
this.opacity = null;
this.init = function() {
this.el = $('
').addClass('mapplic-minimap').appendTo(self.container);
this.el.click(function(e) {
e.preventDefault();
var x = (e.pageX - $(this).offset().left) / $(this).width(),
y = (e.pageY - $(this).offset().top) / $(this).height();
self.moveTo(x, y, self.scale / self.fitscale, 100);
});
}
this.addLayer = function(data) {
var layer = $('
').addClass('mapplic-minimap-layer').attr('data-floor', data.id).appendTo(this.el),
s = this;
$('
![]()
').attr('src', data.minimap).addClass('mapplic-minimap-background').appendTo(layer);
$('
').addClass('mapplic-minimap-overlay').appendTo(layer);
$('
![]()
').attr('src', data.minimap).addClass('mapplic-minimap-active').on('load', function() {
s.update();
$(this).addClass('mapplic-clip-transition');
}).appendTo(layer);
}
this.show = function(target) {
$('.mapplic-minimap-layer', this.el).hide();
$('.mapplic-minimap-layer[data-floor="' + target + '"]', this.el).show();
}
this.update = function(x, y) {
var active = $('.mapplic-minimap-active', this.el);
if (x === undefined) x = self.x;
if (y === undefined) y = self.y;
var width = Math.round(self.container.width() / self.contentWidth / self.scale * this.el.width()),
height = Math.round(self.container.height() / self.contentHeight / self.scale * this.el.height()),
top = Math.round(-y / self.contentHeight / self.scale * this.el.height()),
left = Math.round(-x / self.contentWidth / self.scale * this.el.width()),
right = left + width,
bottom = top + height;
active.each(function() {
$(this)[0].style.clip = 'rect(' + top + 'px, ' + right + 'px, ' + bottom + 'px, ' + left + 'px)';
});
// Fade out effect
var s = this;
this.el.show();
this.el.css('opacity', 1.0);
clearTimeout(this.opacity);
this.opacity = setTimeout(function() {
s.el.css('opacity', 0);
setTimeout(function() { s.el.hide(); }, 600);
}, 2000);
}
}
// Sidebar
function Sidebar() {
this.el = null;
this.list = null;
this.init = function() {
var s = this;
this.el = $('
').addClass('mapplic-sidebar').appendTo(self.el);
if (self.o.search) {
var form = $('
').addClass('mapplic-search-form').submit(function() {
return false;
}).appendTo(this.el);
self.clear = $('
').attr('type', 'button').addClass('mapplic-search-clear').click(function() {
input.val('');
input.keyup();
}).appendTo(form);
var input = $('
').attr({'type': 'text', 'spellcheck': 'false', 'placeholder': 'Search...'}).addClass('mapplic-search-input').keyup(function() {
var keyword = $(this).val();
s.search(keyword);
}).prependTo(form);
}
var listContainer = $('
').addClass('mapplic-list-container').appendTo(this.el);
this.list = $('
').addClass('mapplic-list').appendTo(listContainer);
this.notfound = $('
').addClass('mapplic-not-found').text('Nothing found. Please try a different search.').appendTo(listContainer);
if (!self.o.search) listContainer.css('padding-top', '0');
}
this.addCategories = function(categories) {
var list = this.list;
if (categories) {
$.each(categories, function(index, category) {
var item = $('
').addClass('mapplic-list-category').attr('data-category', category.id);
var ol = $('
').css('border-color', category.color).appendTo(item);
if (category.show == 'false') ol.hide();
else item.addClass('mapplic-opened');
var link = $('
').attr('href', '#').attr('title', category.title).css('background-color', category.color).text(category.title).prependTo(item);
if (category.icon) $('
![]()
').attr('src', category.icon).addClass('mapplic-list-thumbnail').prependTo(link);
//$('
').text('0').addClass('mapplic-list-count').prependTo(link);
list.append(item);
});
$('.mlist-link').click(function(e) {
e.preventDefault();
//Expand or collapse this panel
$(this).next().slideToggle('slow');
//Hide the other panels
$(".mapplic-items").not($(this).next()).slideUp('slow');
});
}
}
this.addLocation = function(data) {
var item = $('
').addClass('mapplic-list-location').addClass('mapplic-list-shown').attr('data-location', data.id);
var link = $('
').attr('href', '#').click(function(e) {
e.preventDefault();
self.showLocation(data.id, 600);
// Scroll back to map on mobile
if ($(window).width() < 668) {
$('html, body').animate({
scrollTop: self.container.offset().top
}, 400);
}
}).appendTo(item);
//if (data.thumbnail) $('
![]()
').attr('src', data.thumbnail).addClass('mapplic-list-thumbnail').appendTo(link);
$('
').text(data.title).appendTo(link)
$('
').html(data.about).appendTo(link);
var category = $('.mapplic-list-category[data-category="' + data.category + '"]');
if (category.length) $('ol', category).append(item);
else this.list.append(item);
// Count
$('.mapplic-list-count', category).text($('.mapplic-list-shown', category).length);
}
this.search = function(keyword) {
if (keyword) self.clear.fadeIn(100);
else self.clear.fadeOut(100);
$('.mapplic-list li', self.el).each(function() {
if ($(this).text().search(new RegExp(keyword, "i")) < 0) {
$(this).removeClass('mapplic-list-shown');
$(this).slideUp(200);
} else {
$(this).addClass('mapplic-list-shown');
$(this).show();
}
});
$('.mapplic-list > li', self.el).each(function() {
var count = $('.mapplic-list-shown', this).length;
$('.mapplic-list-count', this).text(count);
});
// Show not-found text
if ($('.mapplic-list > li.mapplic-list-shown').length > 0) this.notfound.fadeOut(200);
else this.notfound.fadeIn(200);
}
}
// Developer tools
function DevTools() {
this.el = null;
this.init = function() {
this.el = $('
').addClass('mapplic-coordinates').appendTo(self.container);
this.el.append('x: ');
$('
').addClass('mapplic-coordinates-x').appendTo(this.el);
this.el.append(' y: ');
$('
').addClass('mapplic-coordinates-y').appendTo(this.el);
$('.mapplic-layer', self.map).on('mousemove', function(e) {
var x = (e.pageX - self.map.offset().left) / self.map.width(),
y = (e.pageY - self.map.offset().top) / self.map.height();
$('.mapplic-coordinates-x').text(parseFloat(x).toFixed(4));
$('.mapplic-coordinates-y').text(parseFloat(y).toFixed(4));
});
return this;
}
}
// Clear Button
function ClearButton() {
this.el = null;
this.init = function() {
this.el = $('
').attr('href', '#').addClass('mapplic-clear-button').appendTo(self.container);
this.el.on('click touchstart', function(e) {
e.preventDefault();
self.hideLocation();
self.moveTo(0.5, 0.5, self.fitscale, 400, 'easeInOutCubic');
});
return this;
}
}
// Zoom Buttons
function ZoomButtons() {
this.el = null;
this.init = function() {
this.el = $('
').addClass('mapplic-zoom-buttons').appendTo(self.container);
if (!self.o.clearbutton) this.el.css('bottom', '0');
// Zoom in button
this.zoomin = $('
').attr('href', '#').addClass('mapplic-zoomin-button').appendTo(this.el);
this.zoomin.on('click touchstart', function(e) {
e.preventDefault();
var scale = self.scale;
self.scale = normalizeScale(scale + scale * 0.8);
self.x = normalizeX(self.x - (self.container.width() / 2 - self.x) * (self.scale / scale - 1));
self.y = normalizeY(self.y - (self.container.height() / 2 - self.y) * (self.scale / scale - 1));
zoomTo(self.x, self.y, self.scale, 400, 'easeInOutCubic');
});
// Zoom out button
this.zoomout = $('').attr('href', '#').addClass('mapplic-zoomout-button').appendTo(this.el);
this.zoomout.on('click touchstart', function(e) {
e.preventDefault();
var scale = self.scale;
self.scale = normalizeScale(scale - scale * 0.4);
self.x = normalizeX(self.x - (self.container.width() / 2 - self.x) * (self.scale / scale - 1));
self.y = normalizeY(self.y - (self.container.height() / 2 - self.y) * (self.scale / scale - 1));
zoomTo(self.x, self.y, self.scale, 400, 'easeInOutCubic');
});
return this;
}
this.update = function(scale) {
this.zoomin.removeClass('mapplic-disabled');
this.zoomout.removeClass('mapplic-disabled');
if (scale == self.fitscale) this.zoomout.addClass('mapplic-disabled');
else if (scale == self.o.maxscale) this.zoomin.addClass('mapplic-disabled');
}
}
// Fullscreen
function Fullscreen() {
this.el = null;
this.init = function() {
// Fullscreen Button
$('').attr('href', '#').attr('href', '#').addClass('mapplic-fullscreen-button').click(function(e) {
e.preventDefault();
self.el.toggleClass('mapplic-fullscreen');
$(document).resize();
$('.main-header, .main-footer, .fp-controlArrow').toggleClass('hidden');
}).appendTo(self.container);
// Esc key
$(document).keyup(function(e) {
if (e.keyCode === 27) {
$('.mapplic-element.mapplic-fullscreen').removeClass('mapplic-fullscreen');
$(document).resize();
$('.main-header, .main-footer, .fp-controlArrow').show();
}
});
}
}
// Functions
var processData = function(data) {
self.data = data;
var shownLevel = null;
// Disable modules when landmark mode is active
self.o.landmark = self.el.data('landmark');
if (self.o.landmark) {
self.o.sidebar = false;
self.o.zoombuttons = false;
self.o.deeplinking = false;
}
self.container = $('
').addClass('mapplic-container').appendTo(self.el);
self.map = $('
').addClass('mapplic-map').appendTo(self.container);
if (self.o.zoom) self.map.addClass('mapplic-zoomable');
self.levelselect = $('
').addClass('mapplic-levels-select');
self.contentWidth = parseFloat(data.mapwidth);
self.contentHeight = parseFloat(data.mapheight);
// Create minimap
if (self.o.minimap) {
self.minimap = new Minimap();
self.minimap.init();
}
// Create sidebar
if (self.o.sidebar) {
self.sidebar = new Sidebar();
self.sidebar.init();
self.sidebar.addCategories(data.categories);
}
else self.container.css('width', '100%');
// Iterate through levels
var nrlevels = 0;
if (data.levels) {
$.each(data.levels, function(index, level) {
var source = level.map,
extension = source.substr((source.lastIndexOf('.') + 1)).toLowerCase();
// Create new map layer
var layer = $('
').addClass('mapplic-layer').attr('data-floor', level.id).hide().appendTo(self.map);
switch (extension) {
// Image formats
case 'jpg': case 'jpeg': case 'png': case 'gif':
$('
![]()
').attr('src', source).addClass('mapplic-map-image').appendTo(layer);
break;
// Vector format
case 'svg':
$('
').addClass('mapplic-map-image').load(source, function() {
// Setting up the locations on the map
$(self.o.selector, this).each(function() {
var location = self.getLocationData($(this).attr('id'));
if (location) {
$(this).attr('class', 'mapplic-clickable');
location.el = $(this);
var fill = null;
if (location.fill) fill = location.fill;
else if (self.o.fillcolor) fill = self.o.fillcolor;
if (fill) {
$(this).css('fill', fill);
$('> *', this).css('fill', fill);
}
// Landmark mode
if (self.o.landmark === location.id) $(this).attr('class', 'mapplic-active');
}
});
// Click event
$(self.o.selector, this).on('click touchend', function() {
if (!self.dragging) self.showLocation($(this).attr('id'), 600);
});
// Support for the old map format
$('svg a', this).each(function() {
var location = self.getLocationData($(this).attr('xlink:href').substr(1));
if (location) {
$(this).attr('class', 'mapplic-clickable');
location.el = $(this);
}
});
$('svg a', this).click(function(e) {
var id = $(this).attr('xlink:href').substr(1);
self.showLocation(id, 600);
e.preventDefault();
});
}).appendTo(layer);
break;
// Other
default:
alert('File type ' + extension + ' is not supported!');
}
// Create new minimap layer
if (self.minimap) self.minimap.addLayer(level);
// Build layer control
self.levelselect.prepend($('
').attr('value', level.id).text(level.title));
// Shown level
if (!shownLevel || level.show) shownLevel = level.id;
// Iterate through locations
$.each(level.locations, function(index, location) {
// Geolocation
if (location.lat && location.lng) {
var pos = latlngToPos(location.lat, location.lng);
location.x = pos.x;
location.y = pos.y;
}
var top = location.y * 100,
left = location.x * 100;
if (!location.pin) location.pin = 'default';
if (location.pin.indexOf('hidden') == -1) {
if (self.o.markers) {
var pin = $('
').attr('href', '#').addClass('mapplic-pin').css({'top': top + '%', 'left': left + '%'}).appendTo(layer);
pin.on('click touchend', function(e) {
e.preventDefault();
self.showLocation(location.id, 600);
});
if (location.label) pin.html(location.label);
if (location.fill) pin.css('background-color', location.fill);
pin.attr('data-location', location.id);
pin.addClass(location.pin);
location.el = pin;
}
}
if (self.sidebar) self.sidebar.addLocation(location);
});
nrlevels++;
});
}
// COMPONENTS
// Tooltip (default)
self.tooltip = new Tooltip().init();
// Lightbox
if (self.o.lightbox) self.lightbox = new Lightbox().init();
// Hover Tooltip
if (self.o.hovertip) self.hovertip = new HoverTooltip().init();
// Clear button
if (self.o.clearbutton) self.clearbutton = new ClearButton().init();
// Zoom buttons
if (self.o.zoombuttons) self.zoombuttons = new ZoomButtons().init();
// Fullscreen
if (self.o.fullscreen) self.fullscreen = new Fullscreen().init();
// Developer tools
if (self.o.developer) self.devtools = new DevTools().init();
// Level switcher
if (nrlevels > 1) {
self.levels = $('
').addClass('mapplic-levels');
var up = $('
').addClass('mapplic-levels-up').appendTo(self.levels);
self.levelselect.appendTo(self.levels);
var down = $('
').addClass('mapplic-levels-down').appendTo(self.levels);
self.container.append(self.levels);
self.levelselect.change(function() {
var value = $(this).val();
self.switchLevel(value);
});
up.click(function(e) {
e.preventDefault();
if (!$(this).hasClass('mapplic-disabled')) self.switchLevel('+');
});
down.click(function(e) {
e.preventDefault();
if (!$(this).hasClass('mapplic-disabled')) self.switchLevel('-');
});
}
self.switchLevel(shownLevel);
// Browser resize
$(window).resize(function() {
// Mobile
if ($(window).width() < 668) {
if (self.el.hasClass('mapplic-fullscreen')) self.container.height($(window).height());
else {
var height = Math.min(Math.max(self.container.width() * self.contentHeight / self.contentWidth, $(window).height() * 2/3), $(window).height() - 66);
self.container.height(height);
}
}
else self.container.height('100%');
var wr = self.container.width() / self.contentWidth,
hr = self.container.height() / self.contentHeight;
if (self.o.mapfill) {
if (wr > hr) self.fitscale = wr;
else self.fitscale = hr;
}
else {
if (wr < hr) self.fitscale = wr;
else self.fitscale = hr;
}
//if (!self.data.zoomlimit) self.o.maxscale = self.fitscale;
self.scale = normalizeScale(self.scale);
self.x = normalizeX(self.x);
self.y = normalizeY(self.y);
zoomTo(self.x, self.y, self.scale, 0);
}).resize();
// Landmark mode
if (self.o.landmark) {
self.showLocation(self.o.landmark, 0);
}
else {
var init = self.getLocationData('init'); // Landmark with ID 'init'
if (init) self.moveTo(init.x, init.y, parseFloat(init.zoom), 0);
else self.moveTo(0.5, 0.5, self.fitscale, 0);
}
// Deeplinking
if (self.o.deeplinking) {
if (history.pushState) self.deeplinking = new Deeplinking();
else self.deeplinking = new DeeplinkingHash();
self.deeplinking.init();
}
// Trigger event
self.el.trigger('mapready', self);
// Controls
if (self.o.zoom) addControls();
}
var addControls = function() {
var map = self.map,
mapbody = $('.mapplic-map-image', self.map);
document.ondragstart = function() { return false; } // IE drag fix
// Drag & drop
mapbody.on('mousedown', function(e) {
self.dragging = false;
map.data('mouseX', e.pageX);
map.data('mouseY', e.pageY);
if (map.is(':animated')) {
map.stop();
self.x = normalizeX(map.offset().left - self.container.offset().left);
self.y = normalizeY(map.offset().top - self.container.offset().top);
self.scale = normalizeScale(map.width() / self.contentWidth);
}
map.addClass('mapplic-dragging');
self.map.on('mousemove', function(e) {
self.dragging = true;
var x = e.pageX - map.data('mouseX') + self.x,
y = e.pageY - map.data('mouseY') + self.y;
x = normalizeX(x);
y = normalizeY(y);
zoomTo(x, y);
map.data('lastX', x);
map.data('lastY', y);
});
$(document).on('mouseup', function() {
self.x = map.data('lastX');
self.y = map.data('lastY');
self.map.off('mousemove');
$(document).off('mouseup');
map.removeClass('mapplic-dragging');
});
});
// Double click
self.el.on('dblclick', '.mapplic-map-image', function(e) {
e.preventDefault();
var scale = self.scale;
self.scale = normalizeScale(scale * 2);
self.x = normalizeX(self.x - (e.pageX - self.container.offset().left - self.x) * (self.scale/scale - 1));
self.y = normalizeY(self.y - (e.pageY - self.container.offset().top - self.y) * (self.scale/scale - 1));
zoomTo(self.x, self.y, self.scale, 400, 'easeInOutCubic');
});
// Mousewheel
if (self.o.mousewheel) {
$('.mapplic-layer', self.el).bind('mousewheel DOMMouseScroll', function(e, delta) {
var scale = self.scale;
self.scale = normalizeScale(scale + scale * delta / 5);
// Disable page scroll when zoom is applicable
//if (scale != self.scale)
e.preventDefault();
self.x = normalizeX(self.x - (e.pageX - self.container.offset().left - self.x) * (self.scale/scale - 1));
self.y = normalizeY(self.y - (e.pageY - self.container.offset().top - self.y) * (self.scale/scale - 1));
zoomTo(self.x, self.y, self.scale, 200, 'easeOutCubic');
});
}
// Touch support
if (!('ontouchstart' in window || 'onmsgesturechange' in window)) return true;
mapbody.on('touchstart', function(e) {
self.dragging = false;
var orig = e.originalEvent,
pos = map.position();
map.data('touchY', orig.changedTouches[0].pageY - pos.top);
map.data('touchX', orig.changedTouches[0].pageX - pos.left);
mapbody.on('touchmove', function(e) {
e.preventDefault();
self.dragging = true;
var orig = e.originalEvent;
var touches = orig.touches.length;
if (touches == 1) {
self.x = normalizeX(orig.changedTouches[0].pageX - map.data('touchX'));
self.y = normalizeY(orig.changedTouches[0].pageY - map.data('touchY'));
zoomTo(self.x, self.y, self.scale, 50);
}
else {
mapbody.off('touchmove');
}
});
mapbody.on('touchend', function(e) {
mapbody.off('touchmove touchend');
});
});
// Pinch zoom
var hammer = new Hammer(self.map[0], {
transform_always_block: true,
drag_block_horizontal: true,
drag_block_vertical: true
});
hammer.get('pinch').set({ enable: true });
var scale = 1, last_scale;
hammer.on('pinchstart', function(e) {
self.dragging = false;
scale = self.scale / self.fitscale;
last_scale = scale;
});
hammer.on('pinch', function(e) {
self.dragging = true;
if (e.scale != 1) scale = Math.max(1, Math.min(last_scale * e.scale, 100));
var oldscale = self.scale;
self.scale = normalizeScale(scale * self.fitscale);
self.x = normalizeX(self.x - (e.center.x - self.container.offset().left - self.x) * (self.scale / oldscale - 1));
self.y = normalizeY(self.y - (e.center.y - self.y) * (self.scale / oldscale - 1)); // - self.container.offset().top
zoomTo(self.x, self.y, self.scale, 100);
});
}
/* PRIVATE METHODS */
// Web Mercator (EPSG:3857) lat/lng projection
var latlngToPos = function(lat, lng) {
var deltaLng = self.data.rightLng - self.data.leftLng,
bottomLatDegree = self.data.bottomLat * Math.PI / 180,
mapWidth = ((self.data.mapwidth / deltaLng) * 360) / (2 * Math.PI),
mapOffsetY = (mapWidth / 2 * Math.log((1 + Math.sin(bottomLatDegree)) / (1 - Math.sin(bottomLatDegree))));
lat = lat * Math.PI / 180;
return {
x: ((lng - self.data.leftLng) * (self.data.mapwidth / deltaLng)) / self.data.mapwidth,
y: (self.data.mapheight - ((mapWidth / 2 * Math.log((1 + Math.sin(lat)) / (1 - Math.sin(lat)))) - mapOffsetY)) / self.data.mapheight
};
}
// jQuery bug add/remove class workaround (will be fixed in jQuery 3)
var addClass = function(element, c) {
var classes = element.attr('class');
if (classes.indexOf(c) == -1) element.attr('class', classes + ' ' + c);
}
var removeClass = function(element, c) {
var classes = element.attr('class');
if (classes) element.attr('class', classes.replace(c, '').trim());
}
var hasClass = function(element, c) {
var classes = element.attr('class');
return (classes.indexOf(c) > -1);
}
// Normalizing x, y and scale
var normalizeX = function(x) {
var minX = self.container.width() - self.contentWidth * self.scale;
if (minX < 0) {
if (x > 0) x = 0;
else if (x < minX) x = minX;
}
else x = minX/2;
return x;
}
var normalizeY = function(y) {
var minY = self.container.height() - self.contentHeight * self.scale;
if (minY < 0) {
if (y >= 0) y = 0;
else if (y < minY) y = minY;
}
else y = minY/2;
return y;
}
var normalizeScale = function(scale) {
if (scale < self.fitscale) scale = self.fitscale;
else if (scale > self.o.maxscale) scale = self.o.maxscale;
if (self.zoombuttons) self.zoombuttons.update(scale);
return scale;
}
var zoomTo = function(x, y, scale, d, easing) {
if (scale !== undefined) {
self.map.stop().animate({
'left': x,
'top': y,
'width': self.contentWidth * scale,
'height': self.contentHeight * scale
}, d, easing, function() {
if (self.tooltip) self.tooltip.position();
});
}
else {
self.map.css({
'left': x,
'top': y
});
}
if (self.tooltip) self.tooltip.position();
if (self.minimap) self.minimap.update(x, y);
// Trigger event
self.el.trigger('positionchanged', location);
}
/* PUBLIC METHODS */
self.switchLevel = function(target) {
switch (target) {
case '+':
target = $('option:selected', self.levelselect).removeAttr('selected').prev().prop('selected', 'selected').val();
break;
case '-':
target = $('option:selected', self.levelselect).removeAttr('selected').next().prop('selected', 'selected').val();
break;
default:
$('option[value="' + target + '"]', self.levelselect).prop('selected', 'selected');
}
// No such layer
if (!target) return;
var layer = $('.mapplic-layer[data-floor="' + target + '"]', self.el);
// Target layer is already active
if (layer.is(':visible')) return;
// Hide Tooltip
if (self.tooltip) self.tooltip.hide();
// Show target layer
$('.mapplic-layer:visible', self.map).hide();
layer.show();
// Show target minimap layer
if (self.minimap) self.minimap.show(target);
// Update control
var index = self.levelselect.get(0).selectedIndex,
up = $('.mapplic-levels-up', self.el),
down = $('.mapplic-levels-down', self.el);
up.removeClass('mapplic-disabled');
down.removeClass('mapplic-disabled');
if (index == 0) up.addClass('mapplic-disabled');
else if (index == self.levelselect.get(0).length - 1) down.addClass('mapplic-disabled');
// Trigger event
self.el.trigger('levelswitched', target);
}
self.moveTo = function(x, y, s, duration, easing, ry) {
duration = typeof duration !== 'undefined' ? duration : 400;
ry = typeof ry !== 'undefined' ? ry : 0.5;
s = typeof s !== 'undefined' ? s : self.scale/self.fitscale;
self.scale = normalizeScale(s);
self.x = normalizeX(self.container.width() * 0.5 - self.scale * self.contentWidth * x);
self.y = normalizeY(self.container.height() * ry - self.scale * self.contentHeight * y);
zoomTo(self.x, self.y, self.scale, duration, easing);
}
self.getLocationData = function(id) {
var data = null;
$.each(self.data.levels, function(index, level) {
$.each(level.locations, function(index, location) {
if (location.id == id) {
data = location;
}
});
});
return data;
}
self.showLocation = function(id, duration, check) {
$.each(self.data.levels, function(index, level) {
if (level.id == id) {
self.switchLevel(level.id);
return false;
}
$.each(level.locations, function(index, location) {
if (location.id == id) {
var action = (location.action && location.action != 'default') ? location.action : self.o.action;
switch (action) {
case 'open-link':
window.location.href = location.link;
return false;
case 'open-link-new-tab':
window.open(location.link);
return false;
case 'select':
if (location.el) {
if (hasClass(location.el, 'mapplic-active')) removeClass(location.el, 'mapplic-active');
else addClass(location.el, 'mapplic-active');
}
return false;
case 'none':
var zoom = location.zoom ? parseFloat(location.zoom) : self.o.maxscale;
self.switchLevel(level.id);
self.moveTo(location.x, location.y, zoom, 600, 'easeInOutCubic');
break;
case 'lightbox':
self.switchLevel(level.id);
self.lightbox.show(location);
break;
default:
self.switchLevel(level.id);
self.tooltip.show(location);
}
// Active state
removeClass($('.mapplic-active', self.el), 'mapplic-active');
if (location.el) addClass(location.el, 'mapplic-active');
// Deeplinking
if ((self.deeplinking) && (!check)) self.deeplinking.update(id);
// Trigger event
self.el.trigger('locationopened', location);
}
});
});
}
self.hideLocation = function() {
removeClass($('.mapplic-active', self.el), 'mapplic-active');
if (self.deeplinking) self.deeplinking.clear();
if (self.tooltip) self.tooltip.hide();
// Trigger event
self.el.trigger('locationclosed');
}
self.updateLocation = function(id) {
var location = self.getLocationData(id);
if ((location.id == id) && (location.el.is('a'))) {
// Geolocation
if (location.lat && location.lng) {
var pos = latlngToPos(location.lat, location.lng);
location.x = pos.x;
location.y = pos.y;
}
var top = location.y * 100,
left = location.x * 100;
location.el.css({'top': top + '%', 'left': left + '%'});
}
}
};
// Easing functions used by default
// For the full list of easing functions use jQuery Easing Plugin
$.extend($.easing,
{
def: 'easeOutQuad',
swing: function (x, t, b, c, d) {
//alert(jQuery.easing.default);
return jQuery.easing[jQuery.easing.def](x, t, b, c, d);
},
easeOutQuad: function (x, t, b, c, d) {
return -c *(t/=d)*(t-2) + b;
},
easeOutCubic: function (x, t, b, c, d) {
return c*((t=t/d-1)*t*t + 1) + b;
},
easeInOutCubic: function (x, t, b, c, d) {
if ((t/=d/2) < 1) return c/2*t*t*t + b;
return c/2*((t-=2)*t*t + 2) + b;
}
});
// jQuery Plugin
$.fn.mapplic = function(options) {
return this.each(function() {
var element = $(this);
// Plugin already initiated on element
if (element.data('mapplic')) return;
var instance = (new Mapplic(element)).init(options);
// Store plugin object in element's data
element.data('mapplic', instance);
});
};
})(jQuery);
// source --> https://atakent.kz/wp-content/themes/atakent/js/daymap-ru.js?ver=5.2.20
jQuery(document).ready(function(){
jQuery('#atakent_map').mapplic({
source: '/wp-content/themes/atakent/map.json?1',
height: '100vh',
minimap: true,
sidebar: true,
hovertip: true,
developer: true,
maxscale: 2,
search: false,
lightbox: true,
clearbutton: true,
zoombuttons: true,
fillcolor: false,
mapfill: true,
fullscreen: false
});
});
// source --> https://atakent.kz/wp-content/themes/atakent/js/theme.js?ver=5.2.20
jQuery(document).ready(function(){
setTimeout(function () {
jQuery('body').addClass("body-loaded");
}, 1000);
jQuery('.mec-countdown-details').prepend('
До мероприятия осталось:
');
});
// source --> https://atakent.kz/wp-content/plugins/cornerstone/assets/dist/js/site/cs-head.js?ver=3.4.6
var csHead=function(t){var e={};function r(n){if(e[n]){return e[n].exports}var i=e[n]={i:n,l:false,exports:{}};t[n].call(i.exports,i,i.exports,r);i.l=true;return i.exports}r.m=t;r.c=e;r.d=function(t,e,n){if(!r.o(t,e)){Object.defineProperty(t,e,{configurable:false,enumerable:true,get:n})}};r.n=function(t){var e=t&&t.__esModule?function e(){return t["default"]}:function e(){return t};r.d(e,"a",e);return e};r.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)};r.p="";return r(r.s=36)}([function(t,e){var r=t.exports=typeof window!="undefined"&&window.Math==Math?window:typeof self!="undefined"&&self.Math==Math?self:Function("return this")();if(typeof __g=="number")__g=r},function(t,e){var r={}.hasOwnProperty;t.exports=function(t,e){return r.call(t,e)}},function(t,e,r){var n=r(3);var i=r(10);t.exports=r(4)?function(t,e,r){return n.f(t,e,i(1,r))}:function(t,e,r){t[e]=r;return t}},function(t,e,r){var n=r(8);var i=r(28);var o=r(16);var a=Object.defineProperty;e.f=r(4)?Object.defineProperty:function t(e,r,u){n(e);r=o(r,true);n(u);if(i)try{return a(e,r,u)}catch(t){}if("get"in u||"set"in u)throw TypeError("Accessors not supported!");if("value"in u)e[r]=u.value;return e}},function(t,e,r){t.exports=!r(9)(function(){return Object.defineProperty({},"a",{get:function(){return 7}}).a!=7})},function(t,e,r){var n=r(48);var i=r(13);t.exports=function(t){return n(i(t))}},function(t,e,r){var n=r(20)("wks");var i=r(11);var o=r(0).Symbol;var a=typeof o=="function";var u=t.exports=function(t){return n[t]||(n[t]=a&&o[t]||(a?o:i)("Symbol."+t))};u.store=n},function(t,e){t.exports=function(t){return typeof t==="object"?t!==null:typeof t==="function"}},function(t,e,r){var n=r(7);t.exports=function(t){if(!n(t))throw TypeError(t+" is not an object!");return t}},function(t,e){t.exports=function(t){try{return!!t()}catch(t){return true}}},function(t,e){t.exports=function(t,e){return{enumerable:!(t&1),configurable:!(t&2),writable:!(t&4),value:e}}},function(t,e){var r=0;var n=Math.random();t.exports=function(t){return"Symbol(".concat(t===undefined?"":t,")_",(++r+n).toString(36))}},function(t,e){var r=Math.ceil;var n=Math.floor;t.exports=function(t){return isNaN(t=+t)?0:(t>0?n:r)(t)}},function(t,e){t.exports=function(t){if(t==undefined)throw TypeError("Can't call method on "+t);return t}},function(t,e){t.exports=true},function(t,e){var r=t.exports={version:"2.5.3"};if(typeof __e=="number")__e=r},function(t,e,r){var n=r(7);t.exports=function(t,e){if(!n(t))return t;var r,i;if(e&&typeof(r=t.toString)=="function"&&!n(i=r.call(t)))return i;if(typeof(r=t.valueOf)=="function"&&!n(i=r.call(t)))return i;if(!e&&typeof(r=t.toString)=="function"&&!n(i=r.call(t)))return i;throw TypeError("Can't convert object to primitive value")}},function(t,e){t.exports={}},function(t,e,r){var n=r(32);var i=r(21);t.exports=Object.keys||function t(e){return n(e,i)}},function(t,e,r){var n=r(20)("keys");var i=r(11);t.exports=function(t){return n[t]||(n[t]=i(t))}},function(t,e,r){var n=r(0);var i="__core-js_shared__";var o=n[i]||(n[i]={});t.exports=function(t){return o[t]||(o[t]={})}},function(t,e){t.exports="constructor,hasOwnProperty,isPrototypeOf,propertyIsEnumerable,toLocaleString,toString,valueOf".split(",")},function(t,e,r){var n=r(3).f;var i=r(1);var o=r(6)("toStringTag");t.exports=function(t,e,r){if(t&&!i(t=r?t:t.prototype,o))n(t,o,{configurable:true,value:e})}},function(t,e,r){e.f=r(6)},function(t,e,r){var n=r(0);var i=r(15);var o=r(14);var a=r(23);var u=r(3).f;t.exports=function(t){var e=i.Symbol||(i.Symbol=o?{}:n.Symbol||{});if(t.charAt(0)!="_"&&!(t in e))u(e,t,{value:a.f(t)})}},function(t,e){e.f={}.propertyIsEnumerable},function(t,e,r){"use strict";var n=r(14);var i=r(27);var o=r(30);var a=r(2);var u=r(1);var f=r(17);var s=r(46);var c=r(22);var l=r(53);var v=r(6)("iterator");var p=!([].keys&&"next"in[].keys());var d="@@iterator";var y="keys";var h="values";var m=function(){return this};t.exports=function(t,e,r,b,g,w,x){s(r,e,b);var S=function(t){if(!p&&t in T)return T[t];switch(t){case y:return function e(){return new r(this,t)};case h:return function e(){return new r(this,t)}}return function e(){return new r(this,t)}};var O=e+" Iterator";var _=g==h;var C=false;var T=t.prototype;var j=T[v]||T[d]||g&&T[g];var E=!p&&j||S(g);var P=g?!_?E:S("entries"):undefined;var M=e=="Array"?T.entries||j:j;var L,A,N;if(M){N=l(M.call(new t));if(N!==Object.prototype&&N.next){c(N,O,true);if(!n&&!u(N,v))a(N,v,m)}}if(_&&j&&j.name!==h){C=true;E=function t(){return j.call(this)}}if((!n||x)&&(p||C||!T[v])){a(T,v,E)}f[e]=E;f[O]=m;if(g){L={values:_?E:S(h),keys:w?E:S(y),entries:P};if(x)for(A in L){if(!(A in T))o(T,A,L[A])}else i(i.P+i.F*(p||C),e,L)}return L}},function(t,e,r){var n=r(0);var i=r(15);var o=r(44);var a=r(2);var u="prototype";var f=function(t,e,r){var s=t&f.F;var c=t&f.G;var l=t&f.S;var v=t&f.P;var p=t&f.B;var d=t&f.W;var y=c?i:i[e]||(i[e]={});var h=y[u];var m=c?n:l?n[e]:(n[e]||{})[u];var b,g,w;if(c)r=e;for(b in r){g=!s&&m&&m[b]!==undefined;if(g&&b in y)continue;w=g?m[b]:r[b];y[b]=c&&typeof m[b]!="function"?r[b]:p&&g?o(w,n):d&&m[b]==w?function(t){var e=function(e,r,n){if(this instanceof t){switch(arguments.length){case 0:return new t;case 1:return new t(e);case 2:return new t(e,r)}return new t(e,r,n)}return t.apply(this,arguments)};e[u]=t[u];return e}(w):v&&typeof w=="function"?o(Function.call,w):w;if(v){(y.virtual||(y.virtual={}))[b]=w;if(t&f.R&&h&&!h[b])a(h,b,w)}}};f.F=1;f.G=2;f.S=4;f.P=8;f.B=16;f.W=32;f.U=64;f.R=128;t.exports=f},function(t,e,r){t.exports=!r(4)&&!r(9)(function(){return Object.defineProperty(r(29)("div"),"a",{get:function(){return 7}}).a!=7})},function(t,e,r){var n=r(7);var i=r(0).document;var o=n(i)&&n(i.createElement);t.exports=function(t){return o?i.createElement(t):{}}},function(t,e,r){t.exports=r(2)},function(t,e,r){var n=r(8);var i=r(47);var o=r(21);var a=r(19)("IE_PROTO");var u=function(){};var f="prototype";var s=function(){var t=r(29)("iframe");var e=o.length;var n="<";var i=">";var a;t.style.display="none";r(52).appendChild(t);t.src="javascript:";a=t.contentWindow.document;a.open();a.write(n+"script"+i+"document.F=Object"+n+"/script"+i);a.close();s=a.F;while(e--)delete s[f][o[e]];return s()};t.exports=Object.create||function t(e,r){var o;if(e!==null){u[f]=n(e);o=new u;u[f]=null;o[a]=e}else o=s();return r===undefined?o:i(o,r)}},function(t,e,r){var n=r(1);var i=r(5);var o=r(49)(false);var a=r(19)("IE_PROTO");t.exports=function(t,e){var r=i(t);var u=0;var f=[];var s;for(s in r)if(s!=a)n(r,s)&&f.push(s);while(e.length>u)if(n(r,s=e[u++])){~o(f,s)||f.push(s)}return f}},function(t,e){var r={}.toString;t.exports=function(t){return r.call(t).slice(8,-1)}},function(t,e){e.f=Object.getOwnPropertySymbols},function(t,e,r){var n=r(32);var i=r(21).concat("length","prototype");e.f=Object.getOwnPropertyNames||function t(e){return n(e,i)}},function(t,e,r){"use strict";r(37);r(38);var n=r(70);var i=o(n);function o(t){return t&&t.__esModule?t:{default:t}}window.Modernizr=window.Modernizr||window.csModernizr;window.csGlobal=window.csGlobal||{};window.csGlobal.lateCSS=i.default},function(t,e,r){"use strict";(function(){if(!String.prototype.includes){String.prototype.includes=function(t,e){"use strict";if(typeof e!=="number"){e=0}if(e+t.length>this.length){return false}else{return this.indexOf(t,e)!==-1}}}})();(function(){if(typeof window.CustomEvent==="function"){return false}function t(t,e){e=e||{bubbles:false,cancelable:false,detail:undefined};var r=document.createEvent("CustomEvent");r.initCustomEvent(t,e.bubbles,e.cancelable,e.detail);return r}t.prototype=window.Event.prototype;window.CustomEvent=t})();if(!Array.prototype.includes){Object.defineProperty(Array.prototype,"includes",{value:function t(e,r){if(this==null){throw new TypeError('"this" is null or not defined')}var n=Object(this);var i=n.length>>>0;if(i===0){return false}var o=r|0;var a=Math.max(o>=0?o:i-Math.abs(o),0);function u(t,e){return t===e||typeof t==="number"&&typeof e==="number"&&isNaN(t)&&isNaN(e)}while(a
>>0;if(typeof e!=="function"){throw new TypeError("predicate must be a function")}var i=arguments[1];var o=0;while(o=t.length)return{value:undefined,done:true};r=n(t,e);this._i+=r.length;return{value:r,done:false}})},function(t,e,r){var n=r(12);var i=r(13);t.exports=function(t){return function(e,r){var o=String(i(e));var a=n(r);var u=o.length;var f,s;if(a<0||a>=u)return t?"":undefined;f=o.charCodeAt(a);return f<55296||f>56319||a+1===u||(s=o.charCodeAt(a+1))<56320||s>57343?t?o.charAt(a):f:t?o.slice(a,a+2):(f-55296<<10)+(s-56320)+65536}}},function(t,e,r){var n=r(45);t.exports=function(t,e,r){n(t);if(e===undefined)return t;switch(r){case 1:return function(r){return t.call(e,r)};case 2:return function(r,n){return t.call(e,r,n)};case 3:return function(r,n,i){return t.call(e,r,n,i)}}return function(){return t.apply(e,arguments)}}},function(t,e){t.exports=function(t){if(typeof t!="function")throw TypeError(t+" is not a function!");return t}},function(t,e,r){"use strict";var n=r(31);var i=r(10);var o=r(22);var a={};r(2)(a,r(6)("iterator"),function(){return this});t.exports=function(t,e,r){t.prototype=n(a,{next:i(1,r)});o(t,e+" Iterator")}},function(t,e,r){var n=r(3);var i=r(8);var o=r(18);t.exports=r(4)?Object.defineProperties:function t(e,r){i(e);var a=o(r);var u=a.length;var f=0;var s;while(u>f)n.f(e,s=a[f++],r[s]);return e}},function(t,e,r){var n=r(33);t.exports=Object("z").propertyIsEnumerable(0)?Object:function(t){return n(t)=="String"?t.split(""):Object(t)}},function(t,e,r){var n=r(5);var i=r(50);var o=r(51);t.exports=function(t){return function(e,r,a){var u=n(e);var f=i(u.length);var s=o(a,f);var c;if(t&&r!=r)while(f>s){c=u[s++];if(c!=c)return true}else for(;f>s;s++)if(t||s in u){if(u[s]===r)return t||s||0}return!t&&-1}}},function(t,e,r){var n=r(12);var i=Math.min;t.exports=function(t){return t>0?i(n(t),9007199254740991):0}},function(t,e,r){var n=r(12);var i=Math.max;var o=Math.min;t.exports=function(t,e){t=n(t);return t<0?i(t+e,0):o(t,e)}},function(t,e,r){var n=r(0).document;t.exports=n&&n.documentElement},function(t,e,r){var n=r(1);var i=r(54);var o=r(19)("IE_PROTO");var a=Object.prototype;t.exports=Object.getPrototypeOf||function(t){t=i(t);if(n(t,o))return t[o];if(typeof t.constructor=="function"&&t instanceof t.constructor){return t.constructor.prototype}return t instanceof Object?a:null}},function(t,e,r){var n=r(13);t.exports=function(t){return Object(n(t))}},function(t,e,r){r(56);var n=r(0);var i=r(2);var o=r(17);var a=r(6)("toStringTag");var u=("CSSRuleList,CSSStyleDeclaration,CSSValueList,ClientRectList,DOMRectList,DOMStringList,"+"DOMTokenList,DataTransferItemList,FileList,HTMLAllCollection,HTMLCollection,HTMLFormElement,HTMLSelectElement,"+"MediaList,MimeTypeArray,NamedNodeMap,NodeList,PaintRequestList,Plugin,PluginArray,SVGLengthList,SVGNumberList,"+"SVGPathSegList,SVGPointList,SVGStringList,SVGTransformList,SourceBufferList,StyleSheetList,TextTrackCueList,"+"TextTrackList,TouchList").split(",");for(var f=0;f=t.length){this._t=undefined;return i(1)}if(e=="keys")return i(0,r);if(e=="values")return i(0,t[r]);return i(0,[r,t[r]])},"values");o.Arguments=o.Array;n("keys");n("values");n("entries")},function(t,e){t.exports=function(){}},function(t,e){t.exports=function(t,e){return{value:e,done:!!t}}},function(t,e,r){t.exports={default:r(60),__esModule:true}},function(t,e,r){r(61);r(67);r(68);r(69);t.exports=r(15).Symbol},function(t,e,r){"use strict";var n=r(0);var i=r(1);var o=r(4);var a=r(27);var u=r(30);var f=r(62).KEY;var s=r(9);var c=r(20);var l=r(22);var v=r(11);var p=r(6);var d=r(23);var y=r(24);var h=r(63);var m=r(64);var b=r(8);var g=r(7);var w=r(5);var x=r(16);var S=r(10);var O=r(31);var _=r(65);var C=r(66);var T=r(3);var j=r(18);var E=C.f;var P=T.f;var M=_.f;var L=n.Symbol;var A=n.JSON;var N=A&&A.stringify;var k="prototype";var z=p("_hidden");var F=p("toPrimitive");var I={}.propertyIsEnumerable;var G=c("symbol-registry");var R=c("symbols");var D=c("op-symbols");var V=Object[k];var q=typeof L=="function";var B=n.QObject;var W=!B||!B[k]||!B[k].findChild;var H=o&&s(function(){return O(P({},"a",{get:function(){return P(this,"a",{value:7}).a}})).a!=7})?function(t,e,r){var n=E(V,e);if(n)delete V[e];P(t,e,r);if(n&&t!==V)P(V,e,n)}:P;var J=function(t){var e=R[t]=O(L[k]);e._k=t;return e};var Y=q&&typeof L.iterator=="symbol"?function(t){return typeof t=="symbol"}:function(t){return t instanceof L};var K=function t(e,r,n){if(e===V)K(D,r,n);b(e);r=x(r,true);b(n);if(i(R,r)){if(!n.enumerable){if(!i(e,z))P(e,z,S(1,{}));e[z][r]=true}else{if(i(e,z)&&e[z][r])e[z][r]=false;n=O(n,{enumerable:S(0,false)})}return H(e,r,n)}return P(e,r,n)};var U=function t(e,r){b(e);var n=h(r=w(r));var i=0;var o=n.length;var a;while(o>i)K(e,a=n[i++],r[a]);return e};var $=function t(e,r){return r===undefined?O(e):U(O(e),r)};var Q=function t(e){var r=I.call(this,e=x(e,true));if(this===V&&i(R,e)&&!i(D,e))return false;return r||!i(this,e)||!i(R,e)||i(this,z)&&this[z][e]?r:true};var Z=function t(e,r){e=w(e);r=x(r,true);if(e===V&&i(R,r)&&!i(D,r))return;var n=E(e,r);if(n&&i(R,r)&&!(i(e,z)&&e[z][r]))n.enumerable=true;return n};var X=function t(e){var r=M(w(e));var n=[];var o=0;var a;while(r.length>o){if(!i(R,a=r[o++])&&a!=z&&a!=f)n.push(a)}return n};var tt=function t(e){var r=e===V;var n=M(r?D:w(e));var o=[];var a=0;var u;while(n.length>a){if(i(R,u=n[a++])&&(r?i(V,u):true))o.push(R[u])}return o};if(!q){L=function t(){if(this instanceof L)throw TypeError("Symbol is not a constructor!");var e=v(arguments.length>0?arguments[0]:undefined);var r=function(t){if(this===V)r.call(D,t);if(i(this,z)&&i(this[z],e))this[z][e]=false;H(this,e,S(1,t))};if(o&&W)H(V,e,{configurable:true,set:r});return J(e)};u(L[k],"toString",function t(){return this._k});C.f=Z;T.f=K;r(35).f=_.f=X;r(25).f=Q;r(34).f=tt;if(o&&!r(14)){u(V,"propertyIsEnumerable",Q,true)}d.f=function(t){return J(p(t))}}a(a.G+a.W+a.F*!q,{Symbol:L});for(var et="hasInstance,isConcatSpreadable,iterator,match,replace,search,species,split,toPrimitive,toStringTag,unscopables".split(","),rt=0;et.length>rt;)p(et[rt++]);for(var nt=j(p.store),it=0;nt.length>it;)y(nt[it++]);a(a.S+a.F*!q,"Symbol",{for:function(t){return i(G,t+="")?G[t]:G[t]=L(t)},keyFor:function t(e){if(!Y(e))throw TypeError(e+" is not a symbol!");for(var r in G)if(G[r]===e)return r},useSetter:function(){W=true},useSimple:function(){W=false}});a(a.S+a.F*!q,"Object",{create:$,defineProperty:K,defineProperties:U,getOwnPropertyDescriptor:Z,getOwnPropertyNames:X,getOwnPropertySymbols:tt});A&&a(a.S+a.F*(!q||s(function(){var t=L();return N([t])!="[null]"||N({a:t})!="{}"||N(Object(t))!="{}"})),"JSON",{stringify:function t(e){var r=[e];var n=1;var i,o;while(arguments.length>n)r.push(arguments[n++]);o=i=r[1];if(!g(i)&&e===undefined||Y(e))return;if(!m(i))i=function(t,e){if(typeof o=="function")e=o.call(this,t,e);if(!Y(e))return e};r[1]=i;return N.apply(A,r)}});L[k][F]||r(2)(L[k],F,L[k].valueOf);l(L,"Symbol");l(Math,"Math",true);l(n.JSON,"JSON",true)},function(t,e,r){var n=r(11)("meta");var i=r(7);var o=r(1);var a=r(3).f;var u=0;var f=Object.isExtensible||function(){return true};var s=!r(9)(function(){return f(Object.preventExtensions({}))});var c=function(t){a(t,n,{value:{i:"O"+ ++u,w:{}}})};var l=function(t,e){if(!i(t))return typeof t=="symbol"?t:(typeof t=="string"?"S":"P")+t;if(!o(t,n)){if(!f(t))return"F";if(!e)return"E";c(t)}return t[n].i};var v=function(t,e){if(!o(t,n)){if(!f(t))return true;if(!e)return false;c(t)}return t[n].w};var p=function(t){if(s&&d.NEED&&f(t)&&!o(t,n))c(t);return t};var d=t.exports={KEY:n,NEED:false,fastKey:l,getWeak:v,onFreeze:p}},function(t,e,r){var n=r(18);var i=r(34);var o=r(25);t.exports=function(t){var e=n(t);var r=i.f;if(r){var a=r(t);var u=o.f;var f=0;var s;while(a.length>f)if(u.call(t,s=a[f++]))e.push(s)}return e}},function(t,e,r){var n=r(33);t.exports=Array.isArray||function t(e){return n(e)=="Array"}},function(t,e,r){var n=r(5);var i=r(35).f;var o={}.toString;var a=typeof window=="object"&&window&&Object.getOwnPropertyNames?Object.getOwnPropertyNames(window):[];var u=function(t){try{return i(t)}catch(t){return a.slice()}};t.exports.f=function t(e){return a&&o.call(e)=="[object Window]"?u(e):i(n(e))}},function(t,e,r){var n=r(25);var i=r(10);var o=r(5);var a=r(16);var u=r(1);var f=r(28);var s=Object.getOwnPropertyDescriptor;e.f=r(4)?s:function t(e,r){e=o(e);r=a(r,true);if(f)try{return s(e,r)}catch(t){}if(u(e,r))return i(!n.f.call(e,r),e[r])}},function(t,e){},function(t,e,r){r(24)("asyncIterator")},function(t,e,r){r(24)("observable")},function(t,e,r){"use strict";Object.defineProperty(e,"__esModule",{value:true});e.default=function(t){var e="";var r=window.document.querySelectorAll('script[data-cs-late-style="'+t+'"]');for(var i=0;i