/* Minification failed. Returning unminified contents.
(7107,42-43): run-time error JS1195: Expected expression: .
(7107,51-52): run-time error JS1004: Expected ';': )
(7145,6-7): run-time error JS1004: Expected ';': )
(7148,52-53): run-time error JS1004: Expected ';': {
(7150,6-7): run-time error JS1195: Expected expression: )
(7152,35-36): run-time error JS1004: Expected ';': {
(7192,1-2): run-time error JS1002: Syntax error: }
(7194,70-71): run-time error JS1004: Expected ';': {
 */
/*!
 DataTables 1.10.16
 ©2008-2017 SpryMedia Ltd - datatables.net/license
*/
(function(h){"function"===typeof define&&define.amd?define(["jquery"],function(E){return h(E,window,document)}):"object"===typeof exports?module.exports=function(E,G){E||(E=window);G||(G="undefined"!==typeof window?require("jquery"):require("jquery")(E));return h(G,E,E.document)}:h(jQuery,window,document)})(function(h,E,G,k){function X(a){var b,c,d={};h.each(a,function(e){if((b=e.match(/^([^A-Z]+?)([A-Z])/))&&-1!=="a aa ai ao as b fn i m o s ".indexOf(b[1]+" "))c=e.replace(b[0],b[2].toLowerCase()),
d[c]=e,"o"===b[1]&&X(a[e])});a._hungarianMap=d}function I(a,b,c){a._hungarianMap||X(a);var d;h.each(b,function(e){d=a._hungarianMap[e];if(d!==k&&(c||b[d]===k))"o"===d.charAt(0)?(b[d]||(b[d]={}),h.extend(!0,b[d],b[e]),I(a[d],b[d],c)):b[d]=b[e]})}function Ca(a){var b=m.defaults.oLanguage,c=a.sZeroRecords;!a.sEmptyTable&&(c&&"No data available in table"===b.sEmptyTable)&&F(a,a,"sZeroRecords","sEmptyTable");!a.sLoadingRecords&&(c&&"Loading..."===b.sLoadingRecords)&&F(a,a,"sZeroRecords","sLoadingRecords");
a.sInfoThousands&&(a.sThousands=a.sInfoThousands);(a=a.sDecimal)&&cb(a)}function db(a){A(a,"ordering","bSort");A(a,"orderMulti","bSortMulti");A(a,"orderClasses","bSortClasses");A(a,"orderCellsTop","bSortCellsTop");A(a,"order","aaSorting");A(a,"orderFixed","aaSortingFixed");A(a,"paging","bPaginate");A(a,"pagingType","sPaginationType");A(a,"pageLength","iDisplayLength");A(a,"searching","bFilter");"boolean"===typeof a.sScrollX&&(a.sScrollX=a.sScrollX?"100%":"");"boolean"===typeof a.scrollX&&(a.scrollX=
a.scrollX?"100%":"");if(a=a.aoSearchCols)for(var b=0,c=a.length;b<c;b++)a[b]&&I(m.models.oSearch,a[b])}function eb(a){A(a,"orderable","bSortable");A(a,"orderData","aDataSort");A(a,"orderSequence","asSorting");A(a,"orderDataType","sortDataType");var b=a.aDataSort;"number"===typeof b&&!h.isArray(b)&&(a.aDataSort=[b])}function fb(a){if(!m.__browser){var b={};m.__browser=b;var c=h("<div/>").css({position:"fixed",top:0,left:-1*h(E).scrollLeft(),height:1,width:1,overflow:"hidden"}).append(h("<div/>").css({position:"absolute",
top:1,left:1,width:100,overflow:"scroll"}).append(h("<div/>").css({width:"100%",height:10}))).appendTo("body"),d=c.children(),e=d.children();b.barWidth=d[0].offsetWidth-d[0].clientWidth;b.bScrollOversize=100===e[0].offsetWidth&&100!==d[0].clientWidth;b.bScrollbarLeft=1!==Math.round(e.offset().left);b.bBounding=c[0].getBoundingClientRect().width?!0:!1;c.remove()}h.extend(a.oBrowser,m.__browser);a.oScroll.iBarWidth=m.__browser.barWidth}function gb(a,b,c,d,e,f){var g,j=!1;c!==k&&(g=c,j=!0);for(;d!==
e;)a.hasOwnProperty(d)&&(g=j?b(g,a[d],d,a):a[d],j=!0,d+=f);return g}function Da(a,b){var c=m.defaults.column,d=a.aoColumns.length,c=h.extend({},m.models.oColumn,c,{nTh:b?b:G.createElement("th"),sTitle:c.sTitle?c.sTitle:b?b.innerHTML:"",aDataSort:c.aDataSort?c.aDataSort:[d],mData:c.mData?c.mData:d,idx:d});a.aoColumns.push(c);c=a.aoPreSearchCols;c[d]=h.extend({},m.models.oSearch,c[d]);ja(a,d,h(b).data())}function ja(a,b,c){var b=a.aoColumns[b],d=a.oClasses,e=h(b.nTh);if(!b.sWidthOrig){b.sWidthOrig=
e.attr("width")||null;var f=(e.attr("style")||"").match(/width:\s*(\d+[pxem%]+)/);f&&(b.sWidthOrig=f[1])}c!==k&&null!==c&&(eb(c),I(m.defaults.column,c),c.mDataProp!==k&&!c.mData&&(c.mData=c.mDataProp),c.sType&&(b._sManualType=c.sType),c.className&&!c.sClass&&(c.sClass=c.className),c.sClass&&e.addClass(c.sClass),h.extend(b,c),F(b,c,"sWidth","sWidthOrig"),c.iDataSort!==k&&(b.aDataSort=[c.iDataSort]),F(b,c,"aDataSort"));var g=b.mData,j=Q(g),i=b.mRender?Q(b.mRender):null,c=function(a){return"string"===
typeof a&&-1!==a.indexOf("@")};b._bAttrSrc=h.isPlainObject(g)&&(c(g.sort)||c(g.type)||c(g.filter));b._setter=null;b.fnGetData=function(a,b,c){var d=j(a,b,k,c);return i&&b?i(d,b,a,c):d};b.fnSetData=function(a,b,c){return R(g)(a,b,c)};"number"!==typeof g&&(a._rowReadObject=!0);a.oFeatures.bSort||(b.bSortable=!1,e.addClass(d.sSortableNone));a=-1!==h.inArray("asc",b.asSorting);c=-1!==h.inArray("desc",b.asSorting);!b.bSortable||!a&&!c?(b.sSortingClass=d.sSortableNone,b.sSortingClassJUI=""):a&&!c?(b.sSortingClass=
d.sSortableAsc,b.sSortingClassJUI=d.sSortJUIAscAllowed):!a&&c?(b.sSortingClass=d.sSortableDesc,b.sSortingClassJUI=d.sSortJUIDescAllowed):(b.sSortingClass=d.sSortable,b.sSortingClassJUI=d.sSortJUI)}function Y(a){if(!1!==a.oFeatures.bAutoWidth){var b=a.aoColumns;Ea(a);for(var c=0,d=b.length;c<d;c++)b[c].nTh.style.width=b[c].sWidth}b=a.oScroll;(""!==b.sY||""!==b.sX)&&ka(a);r(a,null,"column-sizing",[a])}function Z(a,b){var c=la(a,"bVisible");return"number"===typeof c[b]?c[b]:null}function $(a,b){var c=
la(a,"bVisible"),c=h.inArray(b,c);return-1!==c?c:null}function aa(a){var b=0;h.each(a.aoColumns,function(a,d){d.bVisible&&"none"!==h(d.nTh).css("display")&&b++});return b}function la(a,b){var c=[];h.map(a.aoColumns,function(a,e){a[b]&&c.push(e)});return c}function Fa(a){var b=a.aoColumns,c=a.aoData,d=m.ext.type.detect,e,f,g,j,i,h,l,q,t;e=0;for(f=b.length;e<f;e++)if(l=b[e],t=[],!l.sType&&l._sManualType)l.sType=l._sManualType;else if(!l.sType){g=0;for(j=d.length;g<j;g++){i=0;for(h=c.length;i<h;i++){t[i]===
k&&(t[i]=B(a,i,e,"type"));q=d[g](t[i],a);if(!q&&g!==d.length-1)break;if("html"===q)break}if(q){l.sType=q;break}}l.sType||(l.sType="string")}}function hb(a,b,c,d){var e,f,g,j,i,n,l=a.aoColumns;if(b)for(e=b.length-1;0<=e;e--){n=b[e];var q=n.targets!==k?n.targets:n.aTargets;h.isArray(q)||(q=[q]);f=0;for(g=q.length;f<g;f++)if("number"===typeof q[f]&&0<=q[f]){for(;l.length<=q[f];)Da(a);d(q[f],n)}else if("number"===typeof q[f]&&0>q[f])d(l.length+q[f],n);else if("string"===typeof q[f]){j=0;for(i=l.length;j<
i;j++)("_all"==q[f]||h(l[j].nTh).hasClass(q[f]))&&d(j,n)}}if(c){e=0;for(a=c.length;e<a;e++)d(e,c[e])}}function M(a,b,c,d){var e=a.aoData.length,f=h.extend(!0,{},m.models.oRow,{src:c?"dom":"data",idx:e});f._aData=b;a.aoData.push(f);for(var g=a.aoColumns,j=0,i=g.length;j<i;j++)g[j].sType=null;a.aiDisplayMaster.push(e);b=a.rowIdFn(b);b!==k&&(a.aIds[b]=f);(c||!a.oFeatures.bDeferRender)&&Ga(a,e,c,d);return e}function ma(a,b){var c;b instanceof h||(b=h(b));return b.map(function(b,e){c=Ha(a,e);return M(a,
c.data,e,c.cells)})}function B(a,b,c,d){var e=a.iDraw,f=a.aoColumns[c],g=a.aoData[b]._aData,j=f.sDefaultContent,i=f.fnGetData(g,d,{settings:a,row:b,col:c});if(i===k)return a.iDrawError!=e&&null===j&&(J(a,0,"Requested unknown parameter "+("function"==typeof f.mData?"{function}":"'"+f.mData+"'")+" for row "+b+", column "+c,4),a.iDrawError=e),j;if((i===g||null===i)&&null!==j&&d!==k)i=j;else if("function"===typeof i)return i.call(g);return null===i&&"display"==d?"":i}function ib(a,b,c,d){a.aoColumns[c].fnSetData(a.aoData[b]._aData,
d,{settings:a,row:b,col:c})}function Ia(a){return h.map(a.match(/(\\.|[^\.])+/g)||[""],function(a){return a.replace(/\\\./g,".")})}function Q(a){if(h.isPlainObject(a)){var b={};h.each(a,function(a,c){c&&(b[a]=Q(c))});return function(a,c,f,g){var j=b[c]||b._;return j!==k?j(a,c,f,g):a}}if(null===a)return function(a){return a};if("function"===typeof a)return function(b,c,f,g){return a(b,c,f,g)};if("string"===typeof a&&(-1!==a.indexOf(".")||-1!==a.indexOf("[")||-1!==a.indexOf("("))){var c=function(a,
b,f){var g,j;if(""!==f){j=Ia(f);for(var i=0,n=j.length;i<n;i++){f=j[i].match(ba);g=j[i].match(U);if(f){j[i]=j[i].replace(ba,"");""!==j[i]&&(a=a[j[i]]);g=[];j.splice(0,i+1);j=j.join(".");if(h.isArray(a)){i=0;for(n=a.length;i<n;i++)g.push(c(a[i],b,j))}a=f[0].substring(1,f[0].length-1);a=""===a?g:g.join(a);break}else if(g){j[i]=j[i].replace(U,"");a=a[j[i]]();continue}if(null===a||a[j[i]]===k)return k;a=a[j[i]]}}return a};return function(b,e){return c(b,e,a)}}return function(b){return b[a]}}function R(a){if(h.isPlainObject(a))return R(a._);
if(null===a)return function(){};if("function"===typeof a)return function(b,d,e){a(b,"set",d,e)};if("string"===typeof a&&(-1!==a.indexOf(".")||-1!==a.indexOf("[")||-1!==a.indexOf("("))){var b=function(a,d,e){var e=Ia(e),f;f=e[e.length-1];for(var g,j,i=0,n=e.length-1;i<n;i++){g=e[i].match(ba);j=e[i].match(U);if(g){e[i]=e[i].replace(ba,"");a[e[i]]=[];f=e.slice();f.splice(0,i+1);g=f.join(".");if(h.isArray(d)){j=0;for(n=d.length;j<n;j++)f={},b(f,d[j],g),a[e[i]].push(f)}else a[e[i]]=d;return}j&&(e[i]=e[i].replace(U,
""),a=a[e[i]](d));if(null===a[e[i]]||a[e[i]]===k)a[e[i]]={};a=a[e[i]]}if(f.match(U))a[f.replace(U,"")](d);else a[f.replace(ba,"")]=d};return function(c,d){return b(c,d,a)}}return function(b,d){b[a]=d}}function Ja(a){return D(a.aoData,"_aData")}function na(a){a.aoData.length=0;a.aiDisplayMaster.length=0;a.aiDisplay.length=0;a.aIds={}}function oa(a,b,c){for(var d=-1,e=0,f=a.length;e<f;e++)a[e]==b?d=e:a[e]>b&&a[e]--; -1!=d&&c===k&&a.splice(d,1)}function ca(a,b,c,d){var e=a.aoData[b],f,g=function(c,d){for(;c.childNodes.length;)c.removeChild(c.firstChild);
c.innerHTML=B(a,b,d,"display")};if("dom"===c||(!c||"auto"===c)&&"dom"===e.src)e._aData=Ha(a,e,d,d===k?k:e._aData).data;else{var j=e.anCells;if(j)if(d!==k)g(j[d],d);else{c=0;for(f=j.length;c<f;c++)g(j[c],c)}}e._aSortData=null;e._aFilterData=null;g=a.aoColumns;if(d!==k)g[d].sType=null;else{c=0;for(f=g.length;c<f;c++)g[c].sType=null;Ka(a,e)}}function Ha(a,b,c,d){var e=[],f=b.firstChild,g,j,i=0,n,l=a.aoColumns,q=a._rowReadObject,d=d!==k?d:q?{}:[],t=function(a,b){if("string"===typeof a){var c=a.indexOf("@");
-1!==c&&(c=a.substring(c+1),R(a)(d,b.getAttribute(c)))}},m=function(a){if(c===k||c===i)j=l[i],n=h.trim(a.innerHTML),j&&j._bAttrSrc?(R(j.mData._)(d,n),t(j.mData.sort,a),t(j.mData.type,a),t(j.mData.filter,a)):q?(j._setter||(j._setter=R(j.mData)),j._setter(d,n)):d[i]=n;i++};if(f)for(;f;){g=f.nodeName.toUpperCase();if("TD"==g||"TH"==g)m(f),e.push(f);f=f.nextSibling}else{e=b.anCells;f=0;for(g=e.length;f<g;f++)m(e[f])}if(b=b.firstChild?b:b.nTr)(b=b.getAttribute("id"))&&R(a.rowId)(d,b);return{data:d,cells:e}}
function Ga(a,b,c,d){var e=a.aoData[b],f=e._aData,g=[],j,i,n,l,q;if(null===e.nTr){j=c||G.createElement("tr");e.nTr=j;e.anCells=g;j._DT_RowIndex=b;Ka(a,e);l=0;for(q=a.aoColumns.length;l<q;l++){n=a.aoColumns[l];i=c?d[l]:G.createElement(n.sCellType);i._DT_CellIndex={row:b,column:l};g.push(i);if((!c||n.mRender||n.mData!==l)&&(!h.isPlainObject(n.mData)||n.mData._!==l+".display"))i.innerHTML=B(a,b,l,"display");n.sClass&&(i.className+=" "+n.sClass);n.bVisible&&!c?j.appendChild(i):!n.bVisible&&c&&i.parentNode.removeChild(i);
n.fnCreatedCell&&n.fnCreatedCell.call(a.oInstance,i,B(a,b,l),f,b,l)}r(a,"aoRowCreatedCallback",null,[j,f,b])}e.nTr.setAttribute("role","row")}function Ka(a,b){var c=b.nTr,d=b._aData;if(c){var e=a.rowIdFn(d);e&&(c.id=e);d.DT_RowClass&&(e=d.DT_RowClass.split(" "),b.__rowc=b.__rowc?qa(b.__rowc.concat(e)):e,h(c).removeClass(b.__rowc.join(" ")).addClass(d.DT_RowClass));d.DT_RowAttr&&h(c).attr(d.DT_RowAttr);d.DT_RowData&&h(c).data(d.DT_RowData)}}function jb(a){var b,c,d,e,f,g=a.nTHead,j=a.nTFoot,i=0===
h("th, td",g).length,n=a.oClasses,l=a.aoColumns;i&&(e=h("<tr/>").appendTo(g));b=0;for(c=l.length;b<c;b++)f=l[b],d=h(f.nTh).addClass(f.sClass),i&&d.appendTo(e),a.oFeatures.bSort&&(d.addClass(f.sSortingClass),!1!==f.bSortable&&(d.attr("tabindex",a.iTabIndex).attr("aria-controls",a.sTableId),La(a,f.nTh,b))),f.sTitle!=d[0].innerHTML&&d.html(f.sTitle),Ma(a,"header")(a,d,f,n);i&&da(a.aoHeader,g);h(g).find(">tr").attr("role","row");h(g).find(">tr>th, >tr>td").addClass(n.sHeaderTH);h(j).find(">tr>th, >tr>td").addClass(n.sFooterTH);
if(null!==j){a=a.aoFooter[0];b=0;for(c=a.length;b<c;b++)f=l[b],f.nTf=a[b].cell,f.sClass&&h(f.nTf).addClass(f.sClass)}}function ea(a,b,c){var d,e,f,g=[],j=[],i=a.aoColumns.length,n;if(b){c===k&&(c=!1);d=0;for(e=b.length;d<e;d++){g[d]=b[d].slice();g[d].nTr=b[d].nTr;for(f=i-1;0<=f;f--)!a.aoColumns[f].bVisible&&!c&&g[d].splice(f,1);j.push([])}d=0;for(e=g.length;d<e;d++){if(a=g[d].nTr)for(;f=a.firstChild;)a.removeChild(f);f=0;for(b=g[d].length;f<b;f++)if(n=i=1,j[d][f]===k){a.appendChild(g[d][f].cell);
for(j[d][f]=1;g[d+i]!==k&&g[d][f].cell==g[d+i][f].cell;)j[d+i][f]=1,i++;for(;g[d][f+n]!==k&&g[d][f].cell==g[d][f+n].cell;){for(c=0;c<i;c++)j[d+c][f+n]=1;n++}h(g[d][f].cell).attr("rowspan",i).attr("colspan",n)}}}}function N(a){var b=r(a,"aoPreDrawCallback","preDraw",[a]);if(-1!==h.inArray(!1,b))C(a,!1);else{var b=[],c=0,d=a.asStripeClasses,e=d.length,f=a.oLanguage,g=a.iInitDisplayStart,j="ssp"==y(a),i=a.aiDisplay;a.bDrawing=!0;g!==k&&-1!==g&&(a._iDisplayStart=j?g:g>=a.fnRecordsDisplay()?0:g,a.iInitDisplayStart=
-1);var g=a._iDisplayStart,n=a.fnDisplayEnd();if(a.bDeferLoading)a.bDeferLoading=!1,a.iDraw++,C(a,!1);else if(j){if(!a.bDestroying&&!kb(a))return}else a.iDraw++;if(0!==i.length){f=j?a.aoData.length:n;for(j=j?0:g;j<f;j++){var l=i[j],q=a.aoData[l];null===q.nTr&&Ga(a,l);l=q.nTr;if(0!==e){var t=d[c%e];q._sRowStripe!=t&&(h(l).removeClass(q._sRowStripe).addClass(t),q._sRowStripe=t)}r(a,"aoRowCallback",null,[l,q._aData,c,j]);b.push(l);c++}}else c=f.sZeroRecords,1==a.iDraw&&"ajax"==y(a)?c=f.sLoadingRecords:
f.sEmptyTable&&0===a.fnRecordsTotal()&&(c=f.sEmptyTable),b[0]=h("<tr/>",{"class":e?d[0]:""}).append(h("<td />",{valign:"top",colSpan:aa(a),"class":a.oClasses.sRowEmpty}).html(c))[0];r(a,"aoHeaderCallback","header",[h(a.nTHead).children("tr")[0],Ja(a),g,n,i]);r(a,"aoFooterCallback","footer",[h(a.nTFoot).children("tr")[0],Ja(a),g,n,i]);d=h(a.nTBody);d.children().detach();d.append(h(b));r(a,"aoDrawCallback","draw",[a]);a.bSorted=!1;a.bFiltered=!1;a.bDrawing=!1}}function S(a,b){var c=a.oFeatures,d=c.bFilter;
c.bSort&&lb(a);d?fa(a,a.oPreviousSearch):a.aiDisplay=a.aiDisplayMaster.slice();!0!==b&&(a._iDisplayStart=0);a._drawHold=b;N(a);a._drawHold=!1}function mb(a){var b=a.oClasses,c=h(a.nTable),c=h("<div/>").insertBefore(c),d=a.oFeatures,e=h("<div/>",{id:a.sTableId+"_wrapper","class":b.sWrapper+(a.nTFoot?"":" "+b.sNoFooter)});a.nHolding=c[0];a.nTableWrapper=e[0];a.nTableReinsertBefore=a.nTable.nextSibling;for(var f=a.sDom.split(""),g,j,i,n,l,q,k=0;k<f.length;k++){g=null;j=f[k];if("<"==j){i=h("<div/>")[0];
n=f[k+1];if("'"==n||'"'==n){l="";for(q=2;f[k+q]!=n;)l+=f[k+q],q++;"H"==l?l=b.sJUIHeader:"F"==l&&(l=b.sJUIFooter);-1!=l.indexOf(".")?(n=l.split("."),i.id=n[0].substr(1,n[0].length-1),i.className=n[1]):"#"==l.charAt(0)?i.id=l.substr(1,l.length-1):i.className=l;k+=q}e.append(i);e=h(i)}else if(">"==j)e=e.parent();else if("l"==j&&d.bPaginate&&d.bLengthChange)g=nb(a);else if("f"==j&&d.bFilter)g=ob(a);else if("r"==j&&d.bProcessing)g=pb(a);else if("t"==j)g=qb(a);else if("i"==j&&d.bInfo)g=rb(a);else if("p"==
j&&d.bPaginate)g=sb(a);else if(0!==m.ext.feature.length){i=m.ext.feature;q=0;for(n=i.length;q<n;q++)if(j==i[q].cFeature){g=i[q].fnInit(a);break}}g&&(i=a.aanFeatures,i[j]||(i[j]=[]),i[j].push(g),e.append(g))}c.replaceWith(e);a.nHolding=null}function da(a,b){var c=h(b).children("tr"),d,e,f,g,j,i,n,l,q,k;a.splice(0,a.length);f=0;for(i=c.length;f<i;f++)a.push([]);f=0;for(i=c.length;f<i;f++){d=c[f];for(e=d.firstChild;e;){if("TD"==e.nodeName.toUpperCase()||"TH"==e.nodeName.toUpperCase()){l=1*e.getAttribute("colspan");
q=1*e.getAttribute("rowspan");l=!l||0===l||1===l?1:l;q=!q||0===q||1===q?1:q;g=0;for(j=a[f];j[g];)g++;n=g;k=1===l?!0:!1;for(j=0;j<l;j++)for(g=0;g<q;g++)a[f+g][n+j]={cell:e,unique:k},a[f+g].nTr=d}e=e.nextSibling}}}function ra(a,b,c){var d=[];c||(c=a.aoHeader,b&&(c=[],da(c,b)));for(var b=0,e=c.length;b<e;b++)for(var f=0,g=c[b].length;f<g;f++)if(c[b][f].unique&&(!d[f]||!a.bSortCellsTop))d[f]=c[b][f].cell;return d}function sa(a,b,c){r(a,"aoServerParams","serverParams",[b]);if(b&&h.isArray(b)){var d={},
e=/(.*?)\[\]$/;h.each(b,function(a,b){var c=b.name.match(e);c?(c=c[0],d[c]||(d[c]=[]),d[c].push(b.value)):d[b.name]=b.value});b=d}var f,g=a.ajax,j=a.oInstance,i=function(b){r(a,null,"xhr",[a,b,a.jqXHR]);c(b)};if(h.isPlainObject(g)&&g.data){f=g.data;var n=h.isFunction(f)?f(b,a):f,b=h.isFunction(f)&&n?n:h.extend(!0,b,n);delete g.data}n={data:b,success:function(b){var c=b.error||b.sError;c&&J(a,0,c);a.json=b;i(b)},dataType:"json",cache:!1,type:a.sServerMethod,error:function(b,c){var d=r(a,null,"xhr",
[a,null,a.jqXHR]);-1===h.inArray(!0,d)&&("parsererror"==c?J(a,0,"Invalid JSON response",1):4===b.readyState&&J(a,0,"Ajax error",7));C(a,!1)}};a.oAjaxData=b;r(a,null,"preXhr",[a,b]);a.fnServerData?a.fnServerData.call(j,a.sAjaxSource,h.map(b,function(a,b){return{name:b,value:a}}),i,a):a.sAjaxSource||"string"===typeof g?a.jqXHR=h.ajax(h.extend(n,{url:g||a.sAjaxSource})):h.isFunction(g)?a.jqXHR=g.call(j,b,i,a):(a.jqXHR=h.ajax(h.extend(n,g)),g.data=f)}function kb(a){return a.bAjaxDataGet?(a.iDraw++,C(a,
!0),sa(a,tb(a),function(b){ub(a,b)}),!1):!0}function tb(a){var b=a.aoColumns,c=b.length,d=a.oFeatures,e=a.oPreviousSearch,f=a.aoPreSearchCols,g,j=[],i,n,l,k=V(a);g=a._iDisplayStart;i=!1!==d.bPaginate?a._iDisplayLength:-1;var t=function(a,b){j.push({name:a,value:b})};t("sEcho",a.iDraw);t("iColumns",c);t("sColumns",D(b,"sName").join(","));t("iDisplayStart",g);t("iDisplayLength",i);var pa={draw:a.iDraw,columns:[],order:[],start:g,length:i,search:{value:e.sSearch,regex:e.bRegex}};for(g=0;g<c;g++)n=b[g],
l=f[g],i="function"==typeof n.mData?"function":n.mData,pa.columns.push({data:i,name:n.sName,searchable:n.bSearchable,orderable:n.bSortable,search:{value:l.sSearch,regex:l.bRegex}}),t("mDataProp_"+g,i),d.bFilter&&(t("sSearch_"+g,l.sSearch),t("bRegex_"+g,l.bRegex),t("bSearchable_"+g,n.bSearchable)),d.bSort&&t("bSortable_"+g,n.bSortable);d.bFilter&&(t("sSearch",e.sSearch),t("bRegex",e.bRegex));d.bSort&&(h.each(k,function(a,b){pa.order.push({column:b.col,dir:b.dir});t("iSortCol_"+a,b.col);t("sSortDir_"+
a,b.dir)}),t("iSortingCols",k.length));b=m.ext.legacy.ajax;return null===b?a.sAjaxSource?j:pa:b?j:pa}function ub(a,b){var c=ta(a,b),d=b.sEcho!==k?b.sEcho:b.draw,e=b.iTotalRecords!==k?b.iTotalRecords:b.recordsTotal,f=b.iTotalDisplayRecords!==k?b.iTotalDisplayRecords:b.recordsFiltered;if(d){if(1*d<a.iDraw)return;a.iDraw=1*d}na(a);a._iRecordsTotal=parseInt(e,10);a._iRecordsDisplay=parseInt(f,10);d=0;for(e=c.length;d<e;d++)M(a,c[d]);a.aiDisplay=a.aiDisplayMaster.slice();a.bAjaxDataGet=!1;N(a);a._bInitComplete||
ua(a,b);a.bAjaxDataGet=!0;C(a,!1)}function ta(a,b){var c=h.isPlainObject(a.ajax)&&a.ajax.dataSrc!==k?a.ajax.dataSrc:a.sAjaxDataProp;return"data"===c?b.aaData||b[c]:""!==c?Q(c)(b):b}function ob(a){var b=a.oClasses,c=a.sTableId,d=a.oLanguage,e=a.oPreviousSearch,f=a.aanFeatures,g='<input type="search" class="'+b.sFilterInput+'"/>',j=d.sSearch,j=j.match(/_INPUT_/)?j.replace("_INPUT_",g):j+g,b=h("<div/>",{id:!f.f?c+"_filter":null,"class":b.sFilter}).append(h("<label/>").append(j)),f=function(){var b=!this.value?
"":this.value;b!=e.sSearch&&(fa(a,{sSearch:b,bRegex:e.bRegex,bSmart:e.bSmart,bCaseInsensitive:e.bCaseInsensitive}),a._iDisplayStart=0,N(a))},g=null!==a.searchDelay?a.searchDelay:"ssp"===y(a)?400:0,i=h("input",b).val(e.sSearch).attr("placeholder",d.sSearchPlaceholder).on("keyup.DT search.DT input.DT paste.DT cut.DT",g?Na(f,g):f).on("keypress.DT",function(a){if(13==a.keyCode)return!1}).attr("aria-controls",c);h(a.nTable).on("search.dt.DT",function(b,c){if(a===c)try{i[0]!==G.activeElement&&i.val(e.sSearch)}catch(d){}});
return b[0]}function fa(a,b,c){var d=a.oPreviousSearch,e=a.aoPreSearchCols,f=function(a){d.sSearch=a.sSearch;d.bRegex=a.bRegex;d.bSmart=a.bSmart;d.bCaseInsensitive=a.bCaseInsensitive};Fa(a);if("ssp"!=y(a)){vb(a,b.sSearch,c,b.bEscapeRegex!==k?!b.bEscapeRegex:b.bRegex,b.bSmart,b.bCaseInsensitive);f(b);for(b=0;b<e.length;b++)wb(a,e[b].sSearch,b,e[b].bEscapeRegex!==k?!e[b].bEscapeRegex:e[b].bRegex,e[b].bSmart,e[b].bCaseInsensitive);xb(a)}else f(b);a.bFiltered=!0;r(a,null,"search",[a])}function xb(a){for(var b=
m.ext.search,c=a.aiDisplay,d,e,f=0,g=b.length;f<g;f++){for(var j=[],i=0,n=c.length;i<n;i++)e=c[i],d=a.aoData[e],b[f](a,d._aFilterData,e,d._aData,i)&&j.push(e);c.length=0;h.merge(c,j)}}function wb(a,b,c,d,e,f){if(""!==b){for(var g=[],j=a.aiDisplay,d=Oa(b,d,e,f),e=0;e<j.length;e++)b=a.aoData[j[e]]._aFilterData[c],d.test(b)&&g.push(j[e]);a.aiDisplay=g}}function vb(a,b,c,d,e,f){var d=Oa(b,d,e,f),f=a.oPreviousSearch.sSearch,g=a.aiDisplayMaster,j,e=[];0!==m.ext.search.length&&(c=!0);j=yb(a);if(0>=b.length)a.aiDisplay=
g.slice();else{if(j||c||f.length>b.length||0!==b.indexOf(f)||a.bSorted)a.aiDisplay=g.slice();b=a.aiDisplay;for(c=0;c<b.length;c++)d.test(a.aoData[b[c]]._sFilterRow)&&e.push(b[c]);a.aiDisplay=e}}function Oa(a,b,c,d){a=b?a:Pa(a);c&&(a="^(?=.*?"+h.map(a.match(/"[^"]+"|[^ ]+/g)||[""],function(a){if('"'===a.charAt(0))var b=a.match(/^"(.*)"$/),a=b?b[1]:a;return a.replace('"',"")}).join(")(?=.*?")+").*$");return RegExp(a,d?"i":"")}function yb(a){var b=a.aoColumns,c,d,e,f,g,j,i,h,l=m.ext.type.search;c=!1;
d=0;for(f=a.aoData.length;d<f;d++)if(h=a.aoData[d],!h._aFilterData){j=[];e=0;for(g=b.length;e<g;e++)c=b[e],c.bSearchable?(i=B(a,d,e,"filter"),l[c.sType]&&(i=l[c.sType](i)),null===i&&(i=""),"string"!==typeof i&&i.toString&&(i=i.toString())):i="",i.indexOf&&-1!==i.indexOf("&")&&(va.innerHTML=i,i=Wb?va.textContent:va.innerText),i.replace&&(i=i.replace(/[\r\n]/g,"")),j.push(i);h._aFilterData=j;h._sFilterRow=j.join("  ");c=!0}return c}function zb(a){return{search:a.sSearch,smart:a.bSmart,regex:a.bRegex,
caseInsensitive:a.bCaseInsensitive}}function Ab(a){return{sSearch:a.search,bSmart:a.smart,bRegex:a.regex,bCaseInsensitive:a.caseInsensitive}}function rb(a){var b=a.sTableId,c=a.aanFeatures.i,d=h("<div/>",{"class":a.oClasses.sInfo,id:!c?b+"_info":null});c||(a.aoDrawCallback.push({fn:Bb,sName:"information"}),d.attr("role","status").attr("aria-live","polite"),h(a.nTable).attr("aria-describedby",b+"_info"));return d[0]}function Bb(a){var b=a.aanFeatures.i;if(0!==b.length){var c=a.oLanguage,d=a._iDisplayStart+
1,e=a.fnDisplayEnd(),f=a.fnRecordsTotal(),g=a.fnRecordsDisplay(),j=g?c.sInfo:c.sInfoEmpty;g!==f&&(j+=" "+c.sInfoFiltered);j+=c.sInfoPostFix;j=Cb(a,j);c=c.fnInfoCallback;null!==c&&(j=c.call(a.oInstance,a,d,e,f,g,j));h(b).html(j)}}function Cb(a,b){var c=a.fnFormatNumber,d=a._iDisplayStart+1,e=a._iDisplayLength,f=a.fnRecordsDisplay(),g=-1===e;return b.replace(/_START_/g,c.call(a,d)).replace(/_END_/g,c.call(a,a.fnDisplayEnd())).replace(/_MAX_/g,c.call(a,a.fnRecordsTotal())).replace(/_TOTAL_/g,c.call(a,
f)).replace(/_PAGE_/g,c.call(a,g?1:Math.ceil(d/e))).replace(/_PAGES_/g,c.call(a,g?1:Math.ceil(f/e)))}function ga(a){var b,c,d=a.iInitDisplayStart,e=a.aoColumns,f;c=a.oFeatures;var g=a.bDeferLoading;if(a.bInitialised){mb(a);jb(a);ea(a,a.aoHeader);ea(a,a.aoFooter);C(a,!0);c.bAutoWidth&&Ea(a);b=0;for(c=e.length;b<c;b++)f=e[b],f.sWidth&&(f.nTh.style.width=v(f.sWidth));r(a,null,"preInit",[a]);S(a);e=y(a);if("ssp"!=e||g)"ajax"==e?sa(a,[],function(c){var f=ta(a,c);for(b=0;b<f.length;b++)M(a,f[b]);a.iInitDisplayStart=
d;S(a);C(a,!1);ua(a,c)},a):(C(a,!1),ua(a))}else setTimeout(function(){ga(a)},200)}function ua(a,b){a._bInitComplete=!0;(b||a.oInit.aaData)&&Y(a);r(a,null,"plugin-init",[a,b]);r(a,"aoInitComplete","init",[a,b])}function Qa(a,b){var c=parseInt(b,10);a._iDisplayLength=c;Ra(a);r(a,null,"length",[a,c])}function nb(a){for(var b=a.oClasses,c=a.sTableId,d=a.aLengthMenu,e=h.isArray(d[0]),f=e?d[0]:d,d=e?d[1]:d,e=h("<select/>",{name:c+"_length","aria-controls":c,"class":b.sLengthSelect}),g=0,j=f.length;g<j;g++)e[0][g]=
new Option("number"===typeof d[g]?a.fnFormatNumber(d[g]):d[g],f[g]);var i=h("<div><label/></div>").addClass(b.sLength);a.aanFeatures.l||(i[0].id=c+"_length");i.children().append(a.oLanguage.sLengthMenu.replace("_MENU_",e[0].outerHTML));h("select",i).val(a._iDisplayLength).on("change.DT",function(){Qa(a,h(this).val());N(a)});h(a.nTable).on("length.dt.DT",function(b,c,d){a===c&&h("select",i).val(d)});return i[0]}function sb(a){var b=a.sPaginationType,c=m.ext.pager[b],d="function"===typeof c,e=function(a){N(a)},
b=h("<div/>").addClass(a.oClasses.sPaging+b)[0],f=a.aanFeatures;d||c.fnInit(a,b,e);f.p||(b.id=a.sTableId+"_paginate",a.aoDrawCallback.push({fn:function(a){if(d){var b=a._iDisplayStart,i=a._iDisplayLength,h=a.fnRecordsDisplay(),l=-1===i,b=l?0:Math.ceil(b/i),i=l?1:Math.ceil(h/i),h=c(b,i),k,l=0;for(k=f.p.length;l<k;l++)Ma(a,"pageButton")(a,f.p[l],l,h,b,i)}else c.fnUpdate(a,e)},sName:"pagination"}));return b}function Sa(a,b,c){var d=a._iDisplayStart,e=a._iDisplayLength,f=a.fnRecordsDisplay();0===f||-1===
e?d=0:"number"===typeof b?(d=b*e,d>f&&(d=0)):"first"==b?d=0:"previous"==b?(d=0<=e?d-e:0,0>d&&(d=0)):"next"==b?d+e<f&&(d+=e):"last"==b?d=Math.floor((f-1)/e)*e:J(a,0,"Unknown paging action: "+b,5);b=a._iDisplayStart!==d;a._iDisplayStart=d;b&&(r(a,null,"page",[a]),c&&N(a));return b}function pb(a){return h("<div/>",{id:!a.aanFeatures.r?a.sTableId+"_processing":null,"class":a.oClasses.sProcessing}).html(a.oLanguage.sProcessing).insertBefore(a.nTable)[0]}function C(a,b){a.oFeatures.bProcessing&&h(a.aanFeatures.r).css("display",
b?"block":"none");r(a,null,"processing",[a,b])}function qb(a){var b=h(a.nTable);b.attr("role","grid");var c=a.oScroll;if(""===c.sX&&""===c.sY)return a.nTable;var d=c.sX,e=c.sY,f=a.oClasses,g=b.children("caption"),j=g.length?g[0]._captionSide:null,i=h(b[0].cloneNode(!1)),n=h(b[0].cloneNode(!1)),l=b.children("tfoot");l.length||(l=null);i=h("<div/>",{"class":f.sScrollWrapper}).append(h("<div/>",{"class":f.sScrollHead}).css({overflow:"hidden",position:"relative",border:0,width:d?!d?null:v(d):"100%"}).append(h("<div/>",
{"class":f.sScrollHeadInner}).css({"box-sizing":"content-box",width:c.sXInner||"100%"}).append(i.removeAttr("id").css("margin-left",0).append("top"===j?g:null).append(b.children("thead"))))).append(h("<div/>",{"class":f.sScrollBody}).css({position:"relative",overflow:"auto",width:!d?null:v(d)}).append(b));l&&i.append(h("<div/>",{"class":f.sScrollFoot}).css({overflow:"hidden",border:0,width:d?!d?null:v(d):"100%"}).append(h("<div/>",{"class":f.sScrollFootInner}).append(n.removeAttr("id").css("margin-left",
0).append("bottom"===j?g:null).append(b.children("tfoot")))));var b=i.children(),k=b[0],f=b[1],t=l?b[2]:null;if(d)h(f).on("scroll.DT",function(){var a=this.scrollLeft;k.scrollLeft=a;l&&(t.scrollLeft=a)});h(f).css(e&&c.bCollapse?"max-height":"height",e);a.nScrollHead=k;a.nScrollBody=f;a.nScrollFoot=t;a.aoDrawCallback.push({fn:ka,sName:"scrolling"});return i[0]}function ka(a){var b=a.oScroll,c=b.sX,d=b.sXInner,e=b.sY,b=b.iBarWidth,f=h(a.nScrollHead),g=f[0].style,j=f.children("div"),i=j[0].style,n=j.children("table"),
j=a.nScrollBody,l=h(j),q=j.style,t=h(a.nScrollFoot).children("div"),m=t.children("table"),o=h(a.nTHead),p=h(a.nTable),s=p[0],r=s.style,u=a.nTFoot?h(a.nTFoot):null,x=a.oBrowser,T=x.bScrollOversize,Xb=D(a.aoColumns,"nTh"),O,K,P,w,Ta=[],y=[],z=[],A=[],B,C=function(a){a=a.style;a.paddingTop="0";a.paddingBottom="0";a.borderTopWidth="0";a.borderBottomWidth="0";a.height=0};K=j.scrollHeight>j.clientHeight;if(a.scrollBarVis!==K&&a.scrollBarVis!==k)a.scrollBarVis=K,Y(a);else{a.scrollBarVis=K;p.children("thead, tfoot").remove();
u&&(P=u.clone().prependTo(p),O=u.find("tr"),P=P.find("tr"));w=o.clone().prependTo(p);o=o.find("tr");K=w.find("tr");w.find("th, td").removeAttr("tabindex");c||(q.width="100%",f[0].style.width="100%");h.each(ra(a,w),function(b,c){B=Z(a,b);c.style.width=a.aoColumns[B].sWidth});u&&H(function(a){a.style.width=""},P);f=p.outerWidth();if(""===c){r.width="100%";if(T&&(p.find("tbody").height()>j.offsetHeight||"scroll"==l.css("overflow-y")))r.width=v(p.outerWidth()-b);f=p.outerWidth()}else""!==d&&(r.width=
v(d),f=p.outerWidth());H(C,K);H(function(a){z.push(a.innerHTML);Ta.push(v(h(a).css("width")))},K);H(function(a,b){if(h.inArray(a,Xb)!==-1)a.style.width=Ta[b]},o);h(K).height(0);u&&(H(C,P),H(function(a){A.push(a.innerHTML);y.push(v(h(a).css("width")))},P),H(function(a,b){a.style.width=y[b]},O),h(P).height(0));H(function(a,b){a.innerHTML='<div class="dataTables_sizing" style="height:0;overflow:hidden;">'+z[b]+"</div>";a.style.width=Ta[b]},K);u&&H(function(a,b){a.innerHTML='<div class="dataTables_sizing" style="height:0;overflow:hidden;">'+
A[b]+"</div>";a.style.width=y[b]},P);if(p.outerWidth()<f){O=j.scrollHeight>j.offsetHeight||"scroll"==l.css("overflow-y")?f+b:f;if(T&&(j.scrollHeight>j.offsetHeight||"scroll"==l.css("overflow-y")))r.width=v(O-b);(""===c||""!==d)&&J(a,1,"Possible column misalignment",6)}else O="100%";q.width=v(O);g.width=v(O);u&&(a.nScrollFoot.style.width=v(O));!e&&T&&(q.height=v(s.offsetHeight+b));c=p.outerWidth();n[0].style.width=v(c);i.width=v(c);d=p.height()>j.clientHeight||"scroll"==l.css("overflow-y");e="padding"+
(x.bScrollbarLeft?"Left":"Right");i[e]=d?b+"px":"0px";u&&(m[0].style.width=v(c),t[0].style.width=v(c),t[0].style[e]=d?b+"px":"0px");p.children("colgroup").insertBefore(p.children("thead"));l.scroll();if((a.bSorted||a.bFiltered)&&!a._drawHold)j.scrollTop=0}}function H(a,b,c){for(var d=0,e=0,f=b.length,g,j;e<f;){g=b[e].firstChild;for(j=c?c[e].firstChild:null;g;)1===g.nodeType&&(c?a(g,j,d):a(g,d),d++),g=g.nextSibling,j=c?j.nextSibling:null;e++}}function Ea(a){var b=a.nTable,c=a.aoColumns,d=a.oScroll,
e=d.sY,f=d.sX,g=d.sXInner,j=c.length,i=la(a,"bVisible"),n=h("th",a.nTHead),l=b.getAttribute("width"),k=b.parentNode,t=!1,m,o,p=a.oBrowser,d=p.bScrollOversize;(m=b.style.width)&&-1!==m.indexOf("%")&&(l=m);for(m=0;m<i.length;m++)o=c[i[m]],null!==o.sWidth&&(o.sWidth=Db(o.sWidthOrig,k),t=!0);if(d||!t&&!f&&!e&&j==aa(a)&&j==n.length)for(m=0;m<j;m++)i=Z(a,m),null!==i&&(c[i].sWidth=v(n.eq(m).width()));else{j=h(b).clone().css("visibility","hidden").removeAttr("id");j.find("tbody tr").remove();var s=h("<tr/>").appendTo(j.find("tbody"));
j.find("thead, tfoot").remove();j.append(h(a.nTHead).clone()).append(h(a.nTFoot).clone());j.find("tfoot th, tfoot td").css("width","");n=ra(a,j.find("thead")[0]);for(m=0;m<i.length;m++)o=c[i[m]],n[m].style.width=null!==o.sWidthOrig&&""!==o.sWidthOrig?v(o.sWidthOrig):"",o.sWidthOrig&&f&&h(n[m]).append(h("<div/>").css({width:o.sWidthOrig,margin:0,padding:0,border:0,height:1}));if(a.aoData.length)for(m=0;m<i.length;m++)t=i[m],o=c[t],h(Eb(a,t)).clone(!1).append(o.sContentPadding).appendTo(s);h("[name]",
j).removeAttr("name");o=h("<div/>").css(f||e?{position:"absolute",top:0,left:0,height:1,right:0,overflow:"hidden"}:{}).append(j).appendTo(k);f&&g?j.width(g):f?(j.css("width","auto"),j.removeAttr("width"),j.width()<k.clientWidth&&l&&j.width(k.clientWidth)):e?j.width(k.clientWidth):l&&j.width(l);for(m=e=0;m<i.length;m++)k=h(n[m]),g=k.outerWidth()-k.width(),k=p.bBounding?Math.ceil(n[m].getBoundingClientRect().width):k.outerWidth(),e+=k,c[i[m]].sWidth=v(k-g);b.style.width=v(e);o.remove()}l&&(b.style.width=
v(l));if((l||f)&&!a._reszEvt)b=function(){h(E).on("resize.DT-"+a.sInstance,Na(function(){Y(a)}))},d?setTimeout(b,1E3):b(),a._reszEvt=!0}function Db(a,b){if(!a)return 0;var c=h("<div/>").css("width",v(a)).appendTo(b||G.body),d=c[0].offsetWidth;c.remove();return d}function Eb(a,b){var c=Fb(a,b);if(0>c)return null;var d=a.aoData[c];return!d.nTr?h("<td/>").html(B(a,c,b,"display"))[0]:d.anCells[b]}function Fb(a,b){for(var c,d=-1,e=-1,f=0,g=a.aoData.length;f<g;f++)c=B(a,f,b,"display")+"",c=c.replace(Yb,
""),c=c.replace(/&nbsp;/g," "),c.length>d&&(d=c.length,e=f);return e}function v(a){return null===a?"0px":"number"==typeof a?0>a?"0px":a+"px":a.match(/\d$/)?a+"px":a}function V(a){var b,c,d=[],e=a.aoColumns,f,g,j,i;b=a.aaSortingFixed;c=h.isPlainObject(b);var n=[];f=function(a){a.length&&!h.isArray(a[0])?n.push(a):h.merge(n,a)};h.isArray(b)&&f(b);c&&b.pre&&f(b.pre);f(a.aaSorting);c&&b.post&&f(b.post);for(a=0;a<n.length;a++){i=n[a][0];f=e[i].aDataSort;b=0;for(c=f.length;b<c;b++)g=f[b],j=e[g].sType||
"string",n[a]._idx===k&&(n[a]._idx=h.inArray(n[a][1],e[g].asSorting)),d.push({src:i,col:g,dir:n[a][1],index:n[a]._idx,type:j,formatter:m.ext.type.order[j+"-pre"]})}return d}function lb(a){var b,c,d=[],e=m.ext.type.order,f=a.aoData,g=0,j,i=a.aiDisplayMaster,h;Fa(a);h=V(a);b=0;for(c=h.length;b<c;b++)j=h[b],j.formatter&&g++,Gb(a,j.col);if("ssp"!=y(a)&&0!==h.length){b=0;for(c=i.length;b<c;b++)d[i[b]]=b;g===h.length?i.sort(function(a,b){var c,e,g,j,i=h.length,k=f[a]._aSortData,m=f[b]._aSortData;for(g=
0;g<i;g++)if(j=h[g],c=k[j.col],e=m[j.col],c=c<e?-1:c>e?1:0,0!==c)return"asc"===j.dir?c:-c;c=d[a];e=d[b];return c<e?-1:c>e?1:0}):i.sort(function(a,b){var c,g,j,i,k=h.length,m=f[a]._aSortData,o=f[b]._aSortData;for(j=0;j<k;j++)if(i=h[j],c=m[i.col],g=o[i.col],i=e[i.type+"-"+i.dir]||e["string-"+i.dir],c=i(c,g),0!==c)return c;c=d[a];g=d[b];return c<g?-1:c>g?1:0})}a.bSorted=!0}function Hb(a){for(var b,c,d=a.aoColumns,e=V(a),a=a.oLanguage.oAria,f=0,g=d.length;f<g;f++){c=d[f];var j=c.asSorting;b=c.sTitle.replace(/<.*?>/g,
"");var i=c.nTh;i.removeAttribute("aria-sort");c.bSortable&&(0<e.length&&e[0].col==f?(i.setAttribute("aria-sort","asc"==e[0].dir?"ascending":"descending"),c=j[e[0].index+1]||j[0]):c=j[0],b+="asc"===c?a.sSortAscending:a.sSortDescending);i.setAttribute("aria-label",b)}}function Ua(a,b,c,d){var e=a.aaSorting,f=a.aoColumns[b].asSorting,g=function(a,b){var c=a._idx;c===k&&(c=h.inArray(a[1],f));return c+1<f.length?c+1:b?null:0};"number"===typeof e[0]&&(e=a.aaSorting=[e]);c&&a.oFeatures.bSortMulti?(c=h.inArray(b,
D(e,"0")),-1!==c?(b=g(e[c],!0),null===b&&1===e.length&&(b=0),null===b?e.splice(c,1):(e[c][1]=f[b],e[c]._idx=b)):(e.push([b,f[0],0]),e[e.length-1]._idx=0)):e.length&&e[0][0]==b?(b=g(e[0]),e.length=1,e[0][1]=f[b],e[0]._idx=b):(e.length=0,e.push([b,f[0]]),e[0]._idx=0);S(a);"function"==typeof d&&d(a)}function La(a,b,c,d){var e=a.aoColumns[c];Va(b,{},function(b){!1!==e.bSortable&&(a.oFeatures.bProcessing?(C(a,!0),setTimeout(function(){Ua(a,c,b.shiftKey,d);"ssp"!==y(a)&&C(a,!1)},0)):Ua(a,c,b.shiftKey,d))})}
function wa(a){var b=a.aLastSort,c=a.oClasses.sSortColumn,d=V(a),e=a.oFeatures,f,g;if(e.bSort&&e.bSortClasses){e=0;for(f=b.length;e<f;e++)g=b[e].src,h(D(a.aoData,"anCells",g)).removeClass(c+(2>e?e+1:3));e=0;for(f=d.length;e<f;e++)g=d[e].src,h(D(a.aoData,"anCells",g)).addClass(c+(2>e?e+1:3))}a.aLastSort=d}function Gb(a,b){var c=a.aoColumns[b],d=m.ext.order[c.sSortDataType],e;d&&(e=d.call(a.oInstance,a,b,$(a,b)));for(var f,g=m.ext.type.order[c.sType+"-pre"],j=0,i=a.aoData.length;j<i;j++)if(c=a.aoData[j],
c._aSortData||(c._aSortData=[]),!c._aSortData[b]||d)f=d?e[j]:B(a,j,b,"sort"),c._aSortData[b]=g?g(f):f}function xa(a){if(a.oFeatures.bStateSave&&!a.bDestroying){var b={time:+new Date,start:a._iDisplayStart,length:a._iDisplayLength,order:h.extend(!0,[],a.aaSorting),search:zb(a.oPreviousSearch),columns:h.map(a.aoColumns,function(b,d){return{visible:b.bVisible,search:zb(a.aoPreSearchCols[d])}})};r(a,"aoStateSaveParams","stateSaveParams",[a,b]);a.oSavedState=b;a.fnStateSaveCallback.call(a.oInstance,a,
b)}}function Ib(a,b,c){var d,e,f=a.aoColumns,b=function(b){if(b&&b.time){var g=r(a,"aoStateLoadParams","stateLoadParams",[a,b]);if(-1===h.inArray(!1,g)&&(g=a.iStateDuration,!(0<g&&b.time<+new Date-1E3*g)&&!(b.columns&&f.length!==b.columns.length))){a.oLoadedState=h.extend(!0,{},b);b.start!==k&&(a._iDisplayStart=b.start,a.iInitDisplayStart=b.start);b.length!==k&&(a._iDisplayLength=b.length);b.order!==k&&(a.aaSorting=[],h.each(b.order,function(b,c){a.aaSorting.push(c[0]>=f.length?[0,c[1]]:c)}));b.search!==
k&&h.extend(a.oPreviousSearch,Ab(b.search));if(b.columns){d=0;for(e=b.columns.length;d<e;d++)g=b.columns[d],g.visible!==k&&(f[d].bVisible=g.visible),g.search!==k&&h.extend(a.aoPreSearchCols[d],Ab(g.search))}r(a,"aoStateLoaded","stateLoaded",[a,b])}}c()};if(a.oFeatures.bStateSave){var g=a.fnStateLoadCallback.call(a.oInstance,a,b);g!==k&&b(g)}else c()}function ya(a){var b=m.settings,a=h.inArray(a,D(b,"nTable"));return-1!==a?b[a]:null}function J(a,b,c,d){c="DataTables warning: "+(a?"table id="+a.sTableId+
" - ":"")+c;d&&(c+=". For more information about this error, please see http://datatables.net/tn/"+d);if(b)E.console&&console.log&&console.log(c);else if(b=m.ext,b=b.sErrMode||b.errMode,a&&r(a,null,"error",[a,d,c]),"alert"==b)alert(c);else{if("throw"==b)throw Error(c);"function"==typeof b&&b(a,d,c)}}function F(a,b,c,d){h.isArray(c)?h.each(c,function(c,d){h.isArray(d)?F(a,b,d[0],d[1]):F(a,b,d)}):(d===k&&(d=c),b[c]!==k&&(a[d]=b[c]))}function Jb(a,b,c){var d,e;for(e in b)b.hasOwnProperty(e)&&(d=b[e],
h.isPlainObject(d)?(h.isPlainObject(a[e])||(a[e]={}),h.extend(!0,a[e],d)):a[e]=c&&"data"!==e&&"aaData"!==e&&h.isArray(d)?d.slice():d);return a}function Va(a,b,c){h(a).on("click.DT",b,function(b){a.blur();c(b)}).on("keypress.DT",b,function(a){13===a.which&&(a.preventDefault(),c(a))}).on("selectstart.DT",function(){return!1})}function z(a,b,c,d){c&&a[b].push({fn:c,sName:d})}function r(a,b,c,d){var e=[];b&&(e=h.map(a[b].slice().reverse(),function(b){return b.fn.apply(a.oInstance,d)}));null!==c&&(b=h.Event(c+
".dt"),h(a.nTable).trigger(b,d),e.push(b.result));return e}function Ra(a){var b=a._iDisplayStart,c=a.fnDisplayEnd(),d=a._iDisplayLength;b>=c&&(b=c-d);b-=b%d;if(-1===d||0>b)b=0;a._iDisplayStart=b}function Ma(a,b){var c=a.renderer,d=m.ext.renderer[b];return h.isPlainObject(c)&&c[b]?d[c[b]]||d._:"string"===typeof c?d[c]||d._:d._}function y(a){return a.oFeatures.bServerSide?"ssp":a.ajax||a.sAjaxSource?"ajax":"dom"}function ha(a,b){var c=[],c=Kb.numbers_length,d=Math.floor(c/2);b<=c?c=W(0,b):a<=d?(c=W(0,
c-2),c.push("ellipsis"),c.push(b-1)):(a>=b-1-d?c=W(b-(c-2),b):(c=W(a-d+2,a+d-1),c.push("ellipsis"),c.push(b-1)),c.splice(0,0,"ellipsis"),c.splice(0,0,0));c.DT_el="span";return c}function cb(a){h.each({num:function(b){return za(b,a)},"num-fmt":function(b){return za(b,a,Wa)},"html-num":function(b){return za(b,a,Aa)},"html-num-fmt":function(b){return za(b,a,Aa,Wa)}},function(b,c){x.type.order[b+a+"-pre"]=c;b.match(/^html\-/)&&(x.type.search[b+a]=x.type.search.html)})}function Lb(a){return function(){var b=
[ya(this[m.ext.iApiIndex])].concat(Array.prototype.slice.call(arguments));return m.ext.internal[a].apply(this,b)}}var m=function(a){this.$=function(a,b){return this.api(!0).$(a,b)};this._=function(a,b){return this.api(!0).rows(a,b).data()};this.api=function(a){return a?new s(ya(this[x.iApiIndex])):new s(this)};this.fnAddData=function(a,b){var c=this.api(!0),d=h.isArray(a)&&(h.isArray(a[0])||h.isPlainObject(a[0]))?c.rows.add(a):c.row.add(a);(b===k||b)&&c.draw();return d.flatten().toArray()};this.fnAdjustColumnSizing=
function(a){var b=this.api(!0).columns.adjust(),c=b.settings()[0],d=c.oScroll;a===k||a?b.draw(!1):(""!==d.sX||""!==d.sY)&&ka(c)};this.fnClearTable=function(a){var b=this.api(!0).clear();(a===k||a)&&b.draw()};this.fnClose=function(a){this.api(!0).row(a).child.hide()};this.fnDeleteRow=function(a,b,c){var d=this.api(!0),a=d.rows(a),e=a.settings()[0],h=e.aoData[a[0][0]];a.remove();b&&b.call(this,e,h);(c===k||c)&&d.draw();return h};this.fnDestroy=function(a){this.api(!0).destroy(a)};this.fnDraw=function(a){this.api(!0).draw(a)};
this.fnFilter=function(a,b,c,d,e,h){e=this.api(!0);null===b||b===k?e.search(a,c,d,h):e.column(b).search(a,c,d,h);e.draw()};this.fnGetData=function(a,b){var c=this.api(!0);if(a!==k){var d=a.nodeName?a.nodeName.toLowerCase():"";return b!==k||"td"==d||"th"==d?c.cell(a,b).data():c.row(a).data()||null}return c.data().toArray()};this.fnGetNodes=function(a){var b=this.api(!0);return a!==k?b.row(a).node():b.rows().nodes().flatten().toArray()};this.fnGetPosition=function(a){var b=this.api(!0),c=a.nodeName.toUpperCase();
return"TR"==c?b.row(a).index():"TD"==c||"TH"==c?(a=b.cell(a).index(),[a.row,a.columnVisible,a.column]):null};this.fnIsOpen=function(a){return this.api(!0).row(a).child.isShown()};this.fnOpen=function(a,b,c){return this.api(!0).row(a).child(b,c).show().child()[0]};this.fnPageChange=function(a,b){var c=this.api(!0).page(a);(b===k||b)&&c.draw(!1)};this.fnSetColumnVis=function(a,b,c){a=this.api(!0).column(a).visible(b);(c===k||c)&&a.columns.adjust().draw()};this.fnSettings=function(){return ya(this[x.iApiIndex])};
this.fnSort=function(a){this.api(!0).order(a).draw()};this.fnSortListener=function(a,b,c){this.api(!0).order.listener(a,b,c)};this.fnUpdate=function(a,b,c,d,e){var h=this.api(!0);c===k||null===c?h.row(b).data(a):h.cell(b,c).data(a);(e===k||e)&&h.columns.adjust();(d===k||d)&&h.draw();return 0};this.fnVersionCheck=x.fnVersionCheck;var b=this,c=a===k,d=this.length;c&&(a={});this.oApi=this.internal=x.internal;for(var e in m.ext.internal)e&&(this[e]=Lb(e));this.each(function(){var e={},g=1<d?Jb(e,a,!0):
a,j=0,i,e=this.getAttribute("id"),n=!1,l=m.defaults,q=h(this);if("table"!=this.nodeName.toLowerCase())J(null,0,"Non-table node initialisation ("+this.nodeName+")",2);else{db(l);eb(l.column);I(l,l,!0);I(l.column,l.column,!0);I(l,h.extend(g,q.data()));var t=m.settings,j=0;for(i=t.length;j<i;j++){var o=t[j];if(o.nTable==this||o.nTHead.parentNode==this||o.nTFoot&&o.nTFoot.parentNode==this){var s=g.bRetrieve!==k?g.bRetrieve:l.bRetrieve;if(c||s)return o.oInstance;if(g.bDestroy!==k?g.bDestroy:l.bDestroy){o.oInstance.fnDestroy();
break}else{J(o,0,"Cannot reinitialise DataTable",3);return}}if(o.sTableId==this.id){t.splice(j,1);break}}if(null===e||""===e)this.id=e="DataTables_Table_"+m.ext._unique++;var p=h.extend(!0,{},m.models.oSettings,{sDestroyWidth:q[0].style.width,sInstance:e,sTableId:e});p.nTable=this;p.oApi=b.internal;p.oInit=g;t.push(p);p.oInstance=1===b.length?b:q.dataTable();db(g);g.oLanguage&&Ca(g.oLanguage);g.aLengthMenu&&!g.iDisplayLength&&(g.iDisplayLength=h.isArray(g.aLengthMenu[0])?g.aLengthMenu[0][0]:g.aLengthMenu[0]);
g=Jb(h.extend(!0,{},l),g);F(p.oFeatures,g,"bPaginate bLengthChange bFilter bSort bSortMulti bInfo bProcessing bAutoWidth bSortClasses bServerSide bDeferRender".split(" "));F(p,g,["asStripeClasses","ajax","fnServerData","fnFormatNumber","sServerMethod","aaSorting","aaSortingFixed","aLengthMenu","sPaginationType","sAjaxSource","sAjaxDataProp","iStateDuration","sDom","bSortCellsTop","iTabIndex","fnStateLoadCallback","fnStateSaveCallback","renderer","searchDelay","rowId",["iCookieDuration","iStateDuration"],
["oSearch","oPreviousSearch"],["aoSearchCols","aoPreSearchCols"],["iDisplayLength","_iDisplayLength"]]);F(p.oScroll,g,[["sScrollX","sX"],["sScrollXInner","sXInner"],["sScrollY","sY"],["bScrollCollapse","bCollapse"]]);F(p.oLanguage,g,"fnInfoCallback");z(p,"aoDrawCallback",g.fnDrawCallback,"user");z(p,"aoServerParams",g.fnServerParams,"user");z(p,"aoStateSaveParams",g.fnStateSaveParams,"user");z(p,"aoStateLoadParams",g.fnStateLoadParams,"user");z(p,"aoStateLoaded",g.fnStateLoaded,"user");z(p,"aoRowCallback",
g.fnRowCallback,"user");z(p,"aoRowCreatedCallback",g.fnCreatedRow,"user");z(p,"aoHeaderCallback",g.fnHeaderCallback,"user");z(p,"aoFooterCallback",g.fnFooterCallback,"user");z(p,"aoInitComplete",g.fnInitComplete,"user");z(p,"aoPreDrawCallback",g.fnPreDrawCallback,"user");p.rowIdFn=Q(g.rowId);fb(p);var u=p.oClasses;h.extend(u,m.ext.classes,g.oClasses);q.addClass(u.sTable);p.iInitDisplayStart===k&&(p.iInitDisplayStart=g.iDisplayStart,p._iDisplayStart=g.iDisplayStart);null!==g.iDeferLoading&&(p.bDeferLoading=
!0,e=h.isArray(g.iDeferLoading),p._iRecordsDisplay=e?g.iDeferLoading[0]:g.iDeferLoading,p._iRecordsTotal=e?g.iDeferLoading[1]:g.iDeferLoading);var v=p.oLanguage;h.extend(!0,v,g.oLanguage);v.sUrl&&(h.ajax({dataType:"json",url:v.sUrl,success:function(a){Ca(a);I(l.oLanguage,a);h.extend(true,v,a);ga(p)},error:function(){ga(p)}}),n=!0);null===g.asStripeClasses&&(p.asStripeClasses=[u.sStripeOdd,u.sStripeEven]);var e=p.asStripeClasses,x=q.children("tbody").find("tr").eq(0);-1!==h.inArray(!0,h.map(e,function(a){return x.hasClass(a)}))&&
(h("tbody tr",this).removeClass(e.join(" ")),p.asDestroyStripes=e.slice());e=[];t=this.getElementsByTagName("thead");0!==t.length&&(da(p.aoHeader,t[0]),e=ra(p));if(null===g.aoColumns){t=[];j=0;for(i=e.length;j<i;j++)t.push(null)}else t=g.aoColumns;j=0;for(i=t.length;j<i;j++)Da(p,e?e[j]:null);hb(p,g.aoColumnDefs,t,function(a,b){ja(p,a,b)});if(x.length){var w=function(a,b){return a.getAttribute("data-"+b)!==null?b:null};h(x[0]).children("th, td").each(function(a,b){var c=p.aoColumns[a];if(c.mData===
a){var d=w(b,"sort")||w(b,"order"),e=w(b,"filter")||w(b,"search");if(d!==null||e!==null){c.mData={_:a+".display",sort:d!==null?a+".@data-"+d:k,type:d!==null?a+".@data-"+d:k,filter:e!==null?a+".@data-"+e:k};ja(p,a)}}})}var T=p.oFeatures,e=function(){if(g.aaSorting===k){var a=p.aaSorting;j=0;for(i=a.length;j<i;j++)a[j][1]=p.aoColumns[j].asSorting[0]}wa(p);T.bSort&&z(p,"aoDrawCallback",function(){if(p.bSorted){var a=V(p),b={};h.each(a,function(a,c){b[c.src]=c.dir});r(p,null,"order",[p,a,b]);Hb(p)}});
z(p,"aoDrawCallback",function(){(p.bSorted||y(p)==="ssp"||T.bDeferRender)&&wa(p)},"sc");var a=q.children("caption").each(function(){this._captionSide=h(this).css("caption-side")}),b=q.children("thead");b.length===0&&(b=h("<thead/>").appendTo(q));p.nTHead=b[0];b=q.children("tbody");b.length===0&&(b=h("<tbody/>").appendTo(q));p.nTBody=b[0];b=q.children("tfoot");if(b.length===0&&a.length>0&&(p.oScroll.sX!==""||p.oScroll.sY!==""))b=h("<tfoot/>").appendTo(q);if(b.length===0||b.children().length===0)q.addClass(u.sNoFooter);
else if(b.length>0){p.nTFoot=b[0];da(p.aoFooter,p.nTFoot)}if(g.aaData)for(j=0;j<g.aaData.length;j++)M(p,g.aaData[j]);else(p.bDeferLoading||y(p)=="dom")&&ma(p,h(p.nTBody).children("tr"));p.aiDisplay=p.aiDisplayMaster.slice();p.bInitialised=true;n===false&&ga(p)};g.bStateSave?(T.bStateSave=!0,z(p,"aoDrawCallback",xa,"state_save"),Ib(p,g,e)):e()}});b=null;return this},x,s,o,u,Xa={},Mb=/[\r\n]/g,Aa=/<.*?>/g,Zb=/^\d{2,4}[\.\/\-]\d{1,2}[\.\/\-]\d{1,2}([T ]{1}\d{1,2}[:\.]\d{2}([\.:]\d{2})?)?$/,$b=RegExp("(\\/|\\.|\\*|\\+|\\?|\\||\\(|\\)|\\[|\\]|\\{|\\}|\\\\|\\$|\\^|\\-)",
"g"),Wa=/[',$£€¥%\u2009\u202F\u20BD\u20a9\u20BArfk]/gi,L=function(a){return!a||!0===a||"-"===a?!0:!1},Nb=function(a){var b=parseInt(a,10);return!isNaN(b)&&isFinite(a)?b:null},Ob=function(a,b){Xa[b]||(Xa[b]=RegExp(Pa(b),"g"));return"string"===typeof a&&"."!==b?a.replace(/\./g,"").replace(Xa[b],"."):a},Ya=function(a,b,c){var d="string"===typeof a;if(L(a))return!0;b&&d&&(a=Ob(a,b));c&&d&&(a=a.replace(Wa,""));return!isNaN(parseFloat(a))&&isFinite(a)},Pb=function(a,b,c){return L(a)?!0:!(L(a)||"string"===
typeof a)?null:Ya(a.replace(Aa,""),b,c)?!0:null},D=function(a,b,c){var d=[],e=0,f=a.length;if(c!==k)for(;e<f;e++)a[e]&&a[e][b]&&d.push(a[e][b][c]);else for(;e<f;e++)a[e]&&d.push(a[e][b]);return d},ia=function(a,b,c,d){var e=[],f=0,g=b.length;if(d!==k)for(;f<g;f++)a[b[f]][c]&&e.push(a[b[f]][c][d]);else for(;f<g;f++)e.push(a[b[f]][c]);return e},W=function(a,b){var c=[],d;b===k?(b=0,d=a):(d=b,b=a);for(var e=b;e<d;e++)c.push(e);return c},Qb=function(a){for(var b=[],c=0,d=a.length;c<d;c++)a[c]&&b.push(a[c]);
return b},qa=function(a){var b;a:{if(!(2>a.length)){b=a.slice().sort();for(var c=b[0],d=1,e=b.length;d<e;d++){if(b[d]===c){b=!1;break a}c=b[d]}}b=!0}if(b)return a.slice();b=[];var e=a.length,f,g=0,d=0;a:for(;d<e;d++){c=a[d];for(f=0;f<g;f++)if(b[f]===c)continue a;b.push(c);g++}return b};m.util={throttle:function(a,b){var c=b!==k?b:200,d,e;return function(){var b=this,g=+new Date,j=arguments;d&&g<d+c?(clearTimeout(e),e=setTimeout(function(){d=k;a.apply(b,j)},c)):(d=g,a.apply(b,j))}},escapeRegex:function(a){return a.replace($b,
"\\$1")}};var A=function(a,b,c){a[b]!==k&&(a[c]=a[b])},ba=/\[.*?\]$/,U=/\(\)$/,Pa=m.util.escapeRegex,va=h("<div>")[0],Wb=va.textContent!==k,Yb=/<.*?>/g,Na=m.util.throttle,Rb=[],w=Array.prototype,ac=function(a){var b,c,d=m.settings,e=h.map(d,function(a){return a.nTable});if(a){if(a.nTable&&a.oApi)return[a];if(a.nodeName&&"table"===a.nodeName.toLowerCase())return b=h.inArray(a,e),-1!==b?[d[b]]:null;if(a&&"function"===typeof a.settings)return a.settings().toArray();"string"===typeof a?c=h(a):a instanceof
h&&(c=a)}else return[];if(c)return c.map(function(){b=h.inArray(this,e);return-1!==b?d[b]:null}).toArray()};s=function(a,b){if(!(this instanceof s))return new s(a,b);var c=[],d=function(a){(a=ac(a))&&(c=c.concat(a))};if(h.isArray(a))for(var e=0,f=a.length;e<f;e++)d(a[e]);else d(a);this.context=qa(c);b&&h.merge(this,b);this.selector={rows:null,cols:null,opts:null};s.extend(this,this,Rb)};m.Api=s;h.extend(s.prototype,{any:function(){return 0!==this.count()},concat:w.concat,context:[],count:function(){return this.flatten().length},
each:function(a){for(var b=0,c=this.length;b<c;b++)a.call(this,this[b],b,this);return this},eq:function(a){var b=this.context;return b.length>a?new s(b[a],this[a]):null},filter:function(a){var b=[];if(w.filter)b=w.filter.call(this,a,this);else for(var c=0,d=this.length;c<d;c++)a.call(this,this[c],c,this)&&b.push(this[c]);return new s(this.context,b)},flatten:function(){var a=[];return new s(this.context,a.concat.apply(a,this.toArray()))},join:w.join,indexOf:w.indexOf||function(a,b){for(var c=b||0,
d=this.length;c<d;c++)if(this[c]===a)return c;return-1},iterator:function(a,b,c,d){var e=[],f,g,j,h,n,l=this.context,m,o,u=this.selector;"string"===typeof a&&(d=c,c=b,b=a,a=!1);g=0;for(j=l.length;g<j;g++){var r=new s(l[g]);if("table"===b)f=c.call(r,l[g],g),f!==k&&e.push(f);else if("columns"===b||"rows"===b)f=c.call(r,l[g],this[g],g),f!==k&&e.push(f);else if("column"===b||"column-rows"===b||"row"===b||"cell"===b){o=this[g];"column-rows"===b&&(m=Ba(l[g],u.opts));h=0;for(n=o.length;h<n;h++)f=o[h],f=
"cell"===b?c.call(r,l[g],f.row,f.column,g,h):c.call(r,l[g],f,g,h,m),f!==k&&e.push(f)}}return e.length||d?(a=new s(l,a?e.concat.apply([],e):e),b=a.selector,b.rows=u.rows,b.cols=u.cols,b.opts=u.opts,a):this},lastIndexOf:w.lastIndexOf||function(a,b){return this.indexOf.apply(this.toArray.reverse(),arguments)},length:0,map:function(a){var b=[];if(w.map)b=w.map.call(this,a,this);else for(var c=0,d=this.length;c<d;c++)b.push(a.call(this,this[c],c));return new s(this.context,b)},pluck:function(a){return this.map(function(b){return b[a]})},
pop:w.pop,push:w.push,reduce:w.reduce||function(a,b){return gb(this,a,b,0,this.length,1)},reduceRight:w.reduceRight||function(a,b){return gb(this,a,b,this.length-1,-1,-1)},reverse:w.reverse,selector:null,shift:w.shift,slice:function(){return new s(this.context,this)},sort:w.sort,splice:w.splice,toArray:function(){return w.slice.call(this)},to$:function(){return h(this)},toJQuery:function(){return h(this)},unique:function(){return new s(this.context,qa(this))},unshift:w.unshift});s.extend=function(a,
b,c){if(c.length&&b&&(b instanceof s||b.__dt_wrapper)){var d,e,f,g=function(a,b,c){return function(){var d=b.apply(a,arguments);s.extend(d,d,c.methodExt);return d}};d=0;for(e=c.length;d<e;d++)f=c[d],b[f.name]="function"===typeof f.val?g(a,f.val,f):h.isPlainObject(f.val)?{}:f.val,b[f.name].__dt_wrapper=!0,s.extend(a,b[f.name],f.propExt)}};s.register=o=function(a,b){if(h.isArray(a))for(var c=0,d=a.length;c<d;c++)s.register(a[c],b);else for(var e=a.split("."),f=Rb,g,j,c=0,d=e.length;c<d;c++){g=(j=-1!==
e[c].indexOf("()"))?e[c].replace("()",""):e[c];var i;a:{i=0;for(var n=f.length;i<n;i++)if(f[i].name===g){i=f[i];break a}i=null}i||(i={name:g,val:{},methodExt:[],propExt:[]},f.push(i));c===d-1?i.val=b:f=j?i.methodExt:i.propExt}};s.registerPlural=u=function(a,b,c){s.register(a,c);s.register(b,function(){var a=c.apply(this,arguments);return a===this?this:a instanceof s?a.length?h.isArray(a[0])?new s(a.context,a[0]):a[0]:k:a})};o("tables()",function(a){var b;if(a){b=s;var c=this.context;if("number"===
typeof a)a=[c[a]];else var d=h.map(c,function(a){return a.nTable}),a=h(d).filter(a).map(function(){var a=h.inArray(this,d);return c[a]}).toArray();b=new b(a)}else b=this;return b});o("table()",function(a){var a=this.tables(a),b=a.context;return b.length?new s(b[0]):a});u("tables().nodes()","table().node()",function(){return this.iterator("table",function(a){return a.nTable},1)});u("tables().body()","table().body()",function(){return this.iterator("table",function(a){return a.nTBody},1)});u("tables().header()",
"table().header()",function(){return this.iterator("table",function(a){return a.nTHead},1)});u("tables().footer()","table().footer()",function(){return this.iterator("table",function(a){return a.nTFoot},1)});u("tables().containers()","table().container()",function(){return this.iterator("table",function(a){return a.nTableWrapper},1)});o("draw()",function(a){return this.iterator("table",function(b){"page"===a?N(b):("string"===typeof a&&(a="full-hold"===a?!1:!0),S(b,!1===a))})});o("page()",function(a){return a===
k?this.page.info().page:this.iterator("table",function(b){Sa(b,a)})});o("page.info()",function(){if(0===this.context.length)return k;var a=this.context[0],b=a._iDisplayStart,c=a.oFeatures.bPaginate?a._iDisplayLength:-1,d=a.fnRecordsDisplay(),e=-1===c;return{page:e?0:Math.floor(b/c),pages:e?1:Math.ceil(d/c),start:b,end:a.fnDisplayEnd(),length:c,recordsTotal:a.fnRecordsTotal(),recordsDisplay:d,serverSide:"ssp"===y(a)}});o("page.len()",function(a){return a===k?0!==this.context.length?this.context[0]._iDisplayLength:
k:this.iterator("table",function(b){Qa(b,a)})});var Sb=function(a,b,c){if(c){var d=new s(a);d.one("draw",function(){c(d.ajax.json())})}if("ssp"==y(a))S(a,b);else{C(a,!0);var e=a.jqXHR;e&&4!==e.readyState&&e.abort();sa(a,[],function(c){na(a);for(var c=ta(a,c),d=0,e=c.length;d<e;d++)M(a,c[d]);S(a,b);C(a,!1)})}};o("ajax.json()",function(){var a=this.context;if(0<a.length)return a[0].json});o("ajax.params()",function(){var a=this.context;if(0<a.length)return a[0].oAjaxData});o("ajax.reload()",function(a,
b){return this.iterator("table",function(c){Sb(c,!1===b,a)})});o("ajax.url()",function(a){var b=this.context;if(a===k){if(0===b.length)return k;b=b[0];return b.ajax?h.isPlainObject(b.ajax)?b.ajax.url:b.ajax:b.sAjaxSource}return this.iterator("table",function(b){h.isPlainObject(b.ajax)?b.ajax.url=a:b.ajax=a})});o("ajax.url().load()",function(a,b){return this.iterator("table",function(c){Sb(c,!1===b,a)})});var Za=function(a,b,c,d,e){var f=[],g,j,i,n,l,m;i=typeof b;if(!b||"string"===i||"function"===
i||b.length===k)b=[b];i=0;for(n=b.length;i<n;i++){j=b[i]&&b[i].split&&!b[i].match(/[\[\(:]/)?b[i].split(","):[b[i]];l=0;for(m=j.length;l<m;l++)(g=c("string"===typeof j[l]?h.trim(j[l]):j[l]))&&g.length&&(f=f.concat(g))}a=x.selector[a];if(a.length){i=0;for(n=a.length;i<n;i++)f=a[i](d,e,f)}return qa(f)},$a=function(a){a||(a={});a.filter&&a.search===k&&(a.search=a.filter);return h.extend({search:"none",order:"current",page:"all"},a)},ab=function(a){for(var b=0,c=a.length;b<c;b++)if(0<a[b].length)return a[0]=
a[b],a[0].length=1,a.length=1,a.context=[a.context[b]],a;a.length=0;return a},Ba=function(a,b){var c,d,e,f=[],g=a.aiDisplay;c=a.aiDisplayMaster;var j=b.search;d=b.order;e=b.page;if("ssp"==y(a))return"removed"===j?[]:W(0,c.length);if("current"==e){c=a._iDisplayStart;for(d=a.fnDisplayEnd();c<d;c++)f.push(g[c])}else if("current"==d||"applied"==d)f="none"==j?c.slice():"applied"==j?g.slice():h.map(c,function(a){return-1===h.inArray(a,g)?a:null});else if("index"==d||"original"==d){c=0;for(d=a.aoData.length;c<
d;c++)"none"==j?f.push(c):(e=h.inArray(c,g),(-1===e&&"removed"==j||0<=e&&"applied"==j)&&f.push(c))}return f};o("rows()",function(a,b){a===k?a="":h.isPlainObject(a)&&(b=a,a="");var b=$a(b),c=this.iterator("table",function(c){var e=b,f;return Za("row",a,function(a){var b=Nb(a);if(b!==null&&!e)return[b];f||(f=Ba(c,e));if(b!==null&&h.inArray(b,f)!==-1)return[b];if(a===null||a===k||a==="")return f;if(typeof a==="function")return h.map(f,function(b){var e=c.aoData[b];return a(b,e._aData,e.nTr)?b:null});
b=Qb(ia(c.aoData,f,"nTr"));if(a.nodeName){if(a._DT_RowIndex!==k)return[a._DT_RowIndex];if(a._DT_CellIndex)return[a._DT_CellIndex.row];b=h(a).closest("*[data-dt-row]");return b.length?[b.data("dt-row")]:[]}if(typeof a==="string"&&a.charAt(0)==="#"){var i=c.aIds[a.replace(/^#/,"")];if(i!==k)return[i.idx]}return h(b).filter(a).map(function(){return this._DT_RowIndex}).toArray()},c,e)},1);c.selector.rows=a;c.selector.opts=b;return c});o("rows().nodes()",function(){return this.iterator("row",function(a,
b){return a.aoData[b].nTr||k},1)});o("rows().data()",function(){return this.iterator(!0,"rows",function(a,b){return ia(a.aoData,b,"_aData")},1)});u("rows().cache()","row().cache()",function(a){return this.iterator("row",function(b,c){var d=b.aoData[c];return"search"===a?d._aFilterData:d._aSortData},1)});u("rows().invalidate()","row().invalidate()",function(a){return this.iterator("row",function(b,c){ca(b,c,a)})});u("rows().indexes()","row().index()",function(){return this.iterator("row",function(a,
b){return b},1)});u("rows().ids()","row().id()",function(a){for(var b=[],c=this.context,d=0,e=c.length;d<e;d++)for(var f=0,g=this[d].length;f<g;f++){var h=c[d].rowIdFn(c[d].aoData[this[d][f]]._aData);b.push((!0===a?"#":"")+h)}return new s(c,b)});u("rows().remove()","row().remove()",function(){var a=this;this.iterator("row",function(b,c,d){var e=b.aoData,f=e[c],g,h,i,n,l;e.splice(c,1);g=0;for(h=e.length;g<h;g++)if(i=e[g],l=i.anCells,null!==i.nTr&&(i.nTr._DT_RowIndex=g),null!==l){i=0;for(n=l.length;i<
n;i++)l[i]._DT_CellIndex.row=g}oa(b.aiDisplayMaster,c);oa(b.aiDisplay,c);oa(a[d],c,!1);0<b._iRecordsDisplay&&b._iRecordsDisplay--;Ra(b);c=b.rowIdFn(f._aData);c!==k&&delete b.aIds[c]});this.iterator("table",function(a){for(var c=0,d=a.aoData.length;c<d;c++)a.aoData[c].idx=c});return this});o("rows.add()",function(a){var b=this.iterator("table",function(b){var c,f,g,h=[];f=0;for(g=a.length;f<g;f++)c=a[f],c.nodeName&&"TR"===c.nodeName.toUpperCase()?h.push(ma(b,c)[0]):h.push(M(b,c));return h},1),c=this.rows(-1);
c.pop();h.merge(c,b);return c});o("row()",function(a,b){return ab(this.rows(a,b))});o("row().data()",function(a){var b=this.context;if(a===k)return b.length&&this.length?b[0].aoData[this[0]]._aData:k;b[0].aoData[this[0]]._aData=a;ca(b[0],this[0],"data");return this});o("row().node()",function(){var a=this.context;return a.length&&this.length?a[0].aoData[this[0]].nTr||null:null});o("row.add()",function(a){a instanceof h&&a.length&&(a=a[0]);var b=this.iterator("table",function(b){return a.nodeName&&
"TR"===a.nodeName.toUpperCase()?ma(b,a)[0]:M(b,a)});return this.row(b[0])});var bb=function(a,b){var c=a.context;if(c.length&&(c=c[0].aoData[b!==k?b:a[0]])&&c._details)c._details.remove(),c._detailsShow=k,c._details=k},Tb=function(a,b){var c=a.context;if(c.length&&a.length){var d=c[0].aoData[a[0]];if(d._details){(d._detailsShow=b)?d._details.insertAfter(d.nTr):d._details.detach();var e=c[0],f=new s(e),g=e.aoData;f.off("draw.dt.DT_details column-visibility.dt.DT_details destroy.dt.DT_details");0<D(g,
"_details").length&&(f.on("draw.dt.DT_details",function(a,b){e===b&&f.rows({page:"current"}).eq(0).each(function(a){a=g[a];a._detailsShow&&a._details.insertAfter(a.nTr)})}),f.on("column-visibility.dt.DT_details",function(a,b){if(e===b)for(var c,d=aa(b),f=0,h=g.length;f<h;f++)c=g[f],c._details&&c._details.children("td[colspan]").attr("colspan",d)}),f.on("destroy.dt.DT_details",function(a,b){if(e===b)for(var c=0,d=g.length;c<d;c++)g[c]._details&&bb(f,c)}))}}};o("row().child()",function(a,b){var c=this.context;
if(a===k)return c.length&&this.length?c[0].aoData[this[0]]._details:k;if(!0===a)this.child.show();else if(!1===a)bb(this);else if(c.length&&this.length){var d=c[0],c=c[0].aoData[this[0]],e=[],f=function(a,b){if(h.isArray(a)||a instanceof h)for(var c=0,k=a.length;c<k;c++)f(a[c],b);else a.nodeName&&"tr"===a.nodeName.toLowerCase()?e.push(a):(c=h("<tr><td/></tr>").addClass(b),h("td",c).addClass(b).html(a)[0].colSpan=aa(d),e.push(c[0]))};f(a,b);c._details&&c._details.detach();c._details=h(e);c._detailsShow&&
c._details.insertAfter(c.nTr)}return this});o(["row().child.show()","row().child().show()"],function(){Tb(this,!0);return this});o(["row().child.hide()","row().child().hide()"],function(){Tb(this,!1);return this});o(["row().child.remove()","row().child().remove()"],function(){bb(this);return this});o("row().child.isShown()",function(){var a=this.context;return a.length&&this.length?a[0].aoData[this[0]]._detailsShow||!1:!1});var bc=/^([^:]+):(name|visIdx|visible)$/,Ub=function(a,b,c,d,e){for(var c=
[],d=0,f=e.length;d<f;d++)c.push(B(a,e[d],b));return c};o("columns()",function(a,b){a===k?a="":h.isPlainObject(a)&&(b=a,a="");var b=$a(b),c=this.iterator("table",function(c){var e=a,f=b,g=c.aoColumns,j=D(g,"sName"),i=D(g,"nTh");return Za("column",e,function(a){var b=Nb(a);if(a==="")return W(g.length);if(b!==null)return[b>=0?b:g.length+b];if(typeof a==="function"){var e=Ba(c,f);return h.map(g,function(b,f){return a(f,Ub(c,f,0,0,e),i[f])?f:null})}var k=typeof a==="string"?a.match(bc):"";if(k)switch(k[2]){case "visIdx":case "visible":b=
parseInt(k[1],10);if(b<0){var m=h.map(g,function(a,b){return a.bVisible?b:null});return[m[m.length+b]]}return[Z(c,b)];case "name":return h.map(j,function(a,b){return a===k[1]?b:null});default:return[]}if(a.nodeName&&a._DT_CellIndex)return[a._DT_CellIndex.column];b=h(i).filter(a).map(function(){return h.inArray(this,i)}).toArray();if(b.length||!a.nodeName)return b;b=h(a).closest("*[data-dt-column]");return b.length?[b.data("dt-column")]:[]},c,f)},1);c.selector.cols=a;c.selector.opts=b;return c});u("columns().header()",
"column().header()",function(){return this.iterator("column",function(a,b){return a.aoColumns[b].nTh},1)});u("columns().footer()","column().footer()",function(){return this.iterator("column",function(a,b){return a.aoColumns[b].nTf},1)});u("columns().data()","column().data()",function(){return this.iterator("column-rows",Ub,1)});u("columns().dataSrc()","column().dataSrc()",function(){return this.iterator("column",function(a,b){return a.aoColumns[b].mData},1)});u("columns().cache()","column().cache()",
function(a){return this.iterator("column-rows",function(b,c,d,e,f){return ia(b.aoData,f,"search"===a?"_aFilterData":"_aSortData",c)},1)});u("columns().nodes()","column().nodes()",function(){return this.iterator("column-rows",function(a,b,c,d,e){return ia(a.aoData,e,"anCells",b)},1)});u("columns().visible()","column().visible()",function(a,b){var c=this.iterator("column",function(b,c){if(a===k)return b.aoColumns[c].bVisible;var f=b.aoColumns,g=f[c],j=b.aoData,i,n,l;if(a!==k&&g.bVisible!==a){if(a){var m=
h.inArray(!0,D(f,"bVisible"),c+1);i=0;for(n=j.length;i<n;i++)l=j[i].nTr,f=j[i].anCells,l&&l.insertBefore(f[c],f[m]||null)}else h(D(b.aoData,"anCells",c)).detach();g.bVisible=a;ea(b,b.aoHeader);ea(b,b.aoFooter);xa(b)}});a!==k&&(this.iterator("column",function(c,e){r(c,null,"column-visibility",[c,e,a,b])}),(b===k||b)&&this.columns.adjust());return c});u("columns().indexes()","column().index()",function(a){return this.iterator("column",function(b,c){return"visible"===a?$(b,c):c},1)});o("columns.adjust()",
function(){return this.iterator("table",function(a){Y(a)},1)});o("column.index()",function(a,b){if(0!==this.context.length){var c=this.context[0];if("fromVisible"===a||"toData"===a)return Z(c,b);if("fromData"===a||"toVisible"===a)return $(c,b)}});o("column()",function(a,b){return ab(this.columns(a,b))});o("cells()",function(a,b,c){h.isPlainObject(a)&&(a.row===k?(c=a,a=null):(c=b,b=null));h.isPlainObject(b)&&(c=b,b=null);if(null===b||b===k)return this.iterator("table",function(b){var d=a,e=$a(c),f=
b.aoData,g=Ba(b,e),j=Qb(ia(f,g,"anCells")),i=h([].concat.apply([],j)),l,n=b.aoColumns.length,m,o,u,s,r,v;return Za("cell",d,function(a){var c=typeof a==="function";if(a===null||a===k||c){m=[];o=0;for(u=g.length;o<u;o++){l=g[o];for(s=0;s<n;s++){r={row:l,column:s};if(c){v=f[l];a(r,B(b,l,s),v.anCells?v.anCells[s]:null)&&m.push(r)}else m.push(r)}}return m}if(h.isPlainObject(a))return[a];c=i.filter(a).map(function(a,b){return{row:b._DT_CellIndex.row,column:b._DT_CellIndex.column}}).toArray();if(c.length||
!a.nodeName)return c;v=h(a).closest("*[data-dt-row]");return v.length?[{row:v.data("dt-row"),column:v.data("dt-column")}]:[]},b,e)});var d=this.columns(b,c),e=this.rows(a,c),f,g,j,i,n,l=this.iterator("table",function(a,b){f=[];g=0;for(j=e[b].length;g<j;g++){i=0;for(n=d[b].length;i<n;i++)f.push({row:e[b][g],column:d[b][i]})}return f},1);h.extend(l.selector,{cols:b,rows:a,opts:c});return l});u("cells().nodes()","cell().node()",function(){return this.iterator("cell",function(a,b,c){return(a=a.aoData[b])&&
a.anCells?a.anCells[c]:k},1)});o("cells().data()",function(){return this.iterator("cell",function(a,b,c){return B(a,b,c)},1)});u("cells().cache()","cell().cache()",function(a){a="search"===a?"_aFilterData":"_aSortData";return this.iterator("cell",function(b,c,d){return b.aoData[c][a][d]},1)});u("cells().render()","cell().render()",function(a){return this.iterator("cell",function(b,c,d){return B(b,c,d,a)},1)});u("cells().indexes()","cell().index()",function(){return this.iterator("cell",function(a,
b,c){return{row:b,column:c,columnVisible:$(a,c)}},1)});u("cells().invalidate()","cell().invalidate()",function(a){return this.iterator("cell",function(b,c,d){ca(b,c,a,d)})});o("cell()",function(a,b,c){return ab(this.cells(a,b,c))});o("cell().data()",function(a){var b=this.context,c=this[0];if(a===k)return b.length&&c.length?B(b[0],c[0].row,c[0].column):k;ib(b[0],c[0].row,c[0].column,a);ca(b[0],c[0].row,"data",c[0].column);return this});o("order()",function(a,b){var c=this.context;if(a===k)return 0!==
c.length?c[0].aaSorting:k;"number"===typeof a?a=[[a,b]]:a.length&&!h.isArray(a[0])&&(a=Array.prototype.slice.call(arguments));return this.iterator("table",function(b){b.aaSorting=a.slice()})});o("order.listener()",function(a,b,c){return this.iterator("table",function(d){La(d,a,b,c)})});o("order.fixed()",function(a){if(!a){var b=this.context,b=b.length?b[0].aaSortingFixed:k;return h.isArray(b)?{pre:b}:b}return this.iterator("table",function(b){b.aaSortingFixed=h.extend(!0,{},a)})});o(["columns().order()",
"column().order()"],function(a){var b=this;return this.iterator("table",function(c,d){var e=[];h.each(b[d],function(b,c){e.push([c,a])});c.aaSorting=e})});o("search()",function(a,b,c,d){var e=this.context;return a===k?0!==e.length?e[0].oPreviousSearch.sSearch:k:this.iterator("table",function(e){e.oFeatures.bFilter&&fa(e,h.extend({},e.oPreviousSearch,{sSearch:a+"",bRegex:null===b?!1:b,bSmart:null===c?!0:c,bCaseInsensitive:null===d?!0:d}),1)})});u("columns().search()","column().search()",function(a,
b,c,d){return this.iterator("column",function(e,f){var g=e.aoPreSearchCols;if(a===k)return g[f].sSearch;e.oFeatures.bFilter&&(h.extend(g[f],{sSearch:a+"",bRegex:null===b?!1:b,bSmart:null===c?!0:c,bCaseInsensitive:null===d?!0:d}),fa(e,e.oPreviousSearch,1))})});o("state()",function(){return this.context.length?this.context[0].oSavedState:null});o("state.clear()",function(){return this.iterator("table",function(a){a.fnStateSaveCallback.call(a.oInstance,a,{})})});o("state.loaded()",function(){return this.context.length?
this.context[0].oLoadedState:null});o("state.save()",function(){return this.iterator("table",function(a){xa(a)})});m.versionCheck=m.fnVersionCheck=function(a){for(var b=m.version.split("."),a=a.split("."),c,d,e=0,f=a.length;e<f;e++)if(c=parseInt(b[e],10)||0,d=parseInt(a[e],10)||0,c!==d)return c>d;return!0};m.isDataTable=m.fnIsDataTable=function(a){var b=h(a).get(0),c=!1;if(a instanceof m.Api)return!0;h.each(m.settings,function(a,e){var f=e.nScrollHead?h("table",e.nScrollHead)[0]:null,g=e.nScrollFoot?
h("table",e.nScrollFoot)[0]:null;if(e.nTable===b||f===b||g===b)c=!0});return c};m.tables=m.fnTables=function(a){var b=!1;h.isPlainObject(a)&&(b=a.api,a=a.visible);var c=h.map(m.settings,function(b){if(!a||a&&h(b.nTable).is(":visible"))return b.nTable});return b?new s(c):c};m.camelToHungarian=I;o("$()",function(a,b){var c=this.rows(b).nodes(),c=h(c);return h([].concat(c.filter(a).toArray(),c.find(a).toArray()))});h.each(["on","one","off"],function(a,b){o(b+"()",function(){var a=Array.prototype.slice.call(arguments);
a[0]=h.map(a[0].split(/\s/),function(a){return!a.match(/\.dt\b/)?a+".dt":a}).join(" ");var d=h(this.tables().nodes());d[b].apply(d,a);return this})});o("clear()",function(){return this.iterator("table",function(a){na(a)})});o("settings()",function(){return new s(this.context,this.context)});o("init()",function(){var a=this.context;return a.length?a[0].oInit:null});o("data()",function(){return this.iterator("table",function(a){return D(a.aoData,"_aData")}).flatten()});o("destroy()",function(a){a=a||
!1;return this.iterator("table",function(b){var c=b.nTableWrapper.parentNode,d=b.oClasses,e=b.nTable,f=b.nTBody,g=b.nTHead,j=b.nTFoot,i=h(e),f=h(f),k=h(b.nTableWrapper),l=h.map(b.aoData,function(a){return a.nTr}),o;b.bDestroying=!0;r(b,"aoDestroyCallback","destroy",[b]);a||(new s(b)).columns().visible(!0);k.off(".DT").find(":not(tbody *)").off(".DT");h(E).off(".DT-"+b.sInstance);e!=g.parentNode&&(i.children("thead").detach(),i.append(g));j&&e!=j.parentNode&&(i.children("tfoot").detach(),i.append(j));
b.aaSorting=[];b.aaSortingFixed=[];wa(b);h(l).removeClass(b.asStripeClasses.join(" "));h("th, td",g).removeClass(d.sSortable+" "+d.sSortableAsc+" "+d.sSortableDesc+" "+d.sSortableNone);f.children().detach();f.append(l);g=a?"remove":"detach";i[g]();k[g]();!a&&c&&(c.insertBefore(e,b.nTableReinsertBefore),i.css("width",b.sDestroyWidth).removeClass(d.sTable),(o=b.asDestroyStripes.length)&&f.children().each(function(a){h(this).addClass(b.asDestroyStripes[a%o])}));c=h.inArray(b,m.settings);-1!==c&&m.settings.splice(c,
1)})});h.each(["column","row","cell"],function(a,b){o(b+"s().every()",function(a){var d=this.selector.opts,e=this;return this.iterator(b,function(f,g,h,i,n){a.call(e[b](g,"cell"===b?h:d,"cell"===b?d:k),g,h,i,n)})})});o("i18n()",function(a,b,c){var d=this.context[0],a=Q(a)(d.oLanguage);a===k&&(a=b);c!==k&&h.isPlainObject(a)&&(a=a[c]!==k?a[c]:a._);return a.replace("%d",c)});m.version="1.10.16";m.settings=[];m.models={};m.models.oSearch={bCaseInsensitive:!0,sSearch:"",bRegex:!1,bSmart:!0};m.models.oRow=
{nTr:null,anCells:null,_aData:[],_aSortData:null,_aFilterData:null,_sFilterRow:null,_sRowStripe:"",src:null,idx:-1};m.models.oColumn={idx:null,aDataSort:null,asSorting:null,bSearchable:null,bSortable:null,bVisible:null,_sManualType:null,_bAttrSrc:!1,fnCreatedCell:null,fnGetData:null,fnSetData:null,mData:null,mRender:null,nTh:null,nTf:null,sClass:null,sContentPadding:null,sDefaultContent:null,sName:null,sSortDataType:"std",sSortingClass:null,sSortingClassJUI:null,sTitle:null,sType:null,sWidth:null,
sWidthOrig:null};m.defaults={aaData:null,aaSorting:[[0,"asc"]],aaSortingFixed:[],ajax:null,aLengthMenu:[10,25,50,100],aoColumns:null,aoColumnDefs:null,aoSearchCols:[],asStripeClasses:null,bAutoWidth:!0,bDeferRender:!1,bDestroy:!1,bFilter:!0,bInfo:!0,bLengthChange:!0,bPaginate:!0,bProcessing:!1,bRetrieve:!1,bScrollCollapse:!1,bServerSide:!1,bSort:!0,bSortMulti:!0,bSortCellsTop:!1,bSortClasses:!0,bStateSave:!1,fnCreatedRow:null,fnDrawCallback:null,fnFooterCallback:null,fnFormatNumber:function(a){return a.toString().replace(/\B(?=(\d{3})+(?!\d))/g,
this.oLanguage.sThousands)},fnHeaderCallback:null,fnInfoCallback:null,fnInitComplete:null,fnPreDrawCallback:null,fnRowCallback:null,fnServerData:null,fnServerParams:null,fnStateLoadCallback:function(a){try{return JSON.parse((-1===a.iStateDuration?sessionStorage:localStorage).getItem("DataTables_"+a.sInstance+"_"+location.pathname))}catch(b){}},fnStateLoadParams:null,fnStateLoaded:null,fnStateSaveCallback:function(a,b){try{(-1===a.iStateDuration?sessionStorage:localStorage).setItem("DataTables_"+a.sInstance+
"_"+location.pathname,JSON.stringify(b))}catch(c){}},fnStateSaveParams:null,iStateDuration:7200,iDeferLoading:null,iDisplayLength:10,iDisplayStart:0,iTabIndex:0,oClasses:{},oLanguage:{oAria:{sSortAscending:": activate to sort column ascending",sSortDescending:": activate to sort column descending"},oPaginate:{sFirst:"First",sLast:"Last",sNext:"Next",sPrevious:"Previous"},sEmptyTable:"No data available in table",sInfo:"Showing _START_ to _END_ of _TOTAL_ entries",sInfoEmpty:"Showing 0 to 0 of 0 entries",
sInfoFiltered:"(filtered from _MAX_ total entries)",sInfoPostFix:"",sDecimal:"",sThousands:",",sLengthMenu:"Show _MENU_ entries",sLoadingRecords:"Loading...",sProcessing:"Processing...",sSearch:"Search:",sSearchPlaceholder:"",sUrl:"",sZeroRecords:"No matching records found"},oSearch:h.extend({},m.models.oSearch),sAjaxDataProp:"data",sAjaxSource:null,sDom:"lfrtip",searchDelay:null,sPaginationType:"simple_numbers",sScrollX:"",sScrollXInner:"",sScrollY:"",sServerMethod:"GET",renderer:null,rowId:"DT_RowId"};
X(m.defaults);m.defaults.column={aDataSort:null,iDataSort:-1,asSorting:["asc","desc"],bSearchable:!0,bSortable:!0,bVisible:!0,fnCreatedCell:null,mData:null,mRender:null,sCellType:"td",sClass:"",sContentPadding:"",sDefaultContent:null,sName:"",sSortDataType:"std",sTitle:null,sType:null,sWidth:null};X(m.defaults.column);m.models.oSettings={oFeatures:{bAutoWidth:null,bDeferRender:null,bFilter:null,bInfo:null,bLengthChange:null,bPaginate:null,bProcessing:null,bServerSide:null,bSort:null,bSortMulti:null,
bSortClasses:null,bStateSave:null},oScroll:{bCollapse:null,iBarWidth:0,sX:null,sXInner:null,sY:null},oLanguage:{fnInfoCallback:null},oBrowser:{bScrollOversize:!1,bScrollbarLeft:!1,bBounding:!1,barWidth:0},ajax:null,aanFeatures:[],aoData:[],aiDisplay:[],aiDisplayMaster:[],aIds:{},aoColumns:[],aoHeader:[],aoFooter:[],oPreviousSearch:{},aoPreSearchCols:[],aaSorting:null,aaSortingFixed:[],asStripeClasses:null,asDestroyStripes:[],sDestroyWidth:0,aoRowCallback:[],aoHeaderCallback:[],aoFooterCallback:[],
aoDrawCallback:[],aoRowCreatedCallback:[],aoPreDrawCallback:[],aoInitComplete:[],aoStateSaveParams:[],aoStateLoadParams:[],aoStateLoaded:[],sTableId:"",nTable:null,nTHead:null,nTFoot:null,nTBody:null,nTableWrapper:null,bDeferLoading:!1,bInitialised:!1,aoOpenRows:[],sDom:null,searchDelay:null,sPaginationType:"two_button",iStateDuration:0,aoStateSave:[],aoStateLoad:[],oSavedState:null,oLoadedState:null,sAjaxSource:null,sAjaxDataProp:null,bAjaxDataGet:!0,jqXHR:null,json:k,oAjaxData:k,fnServerData:null,
aoServerParams:[],sServerMethod:null,fnFormatNumber:null,aLengthMenu:null,iDraw:0,bDrawing:!1,iDrawError:-1,_iDisplayLength:10,_iDisplayStart:0,_iRecordsTotal:0,_iRecordsDisplay:0,oClasses:{},bFiltered:!1,bSorted:!1,bSortCellsTop:null,oInit:null,aoDestroyCallback:[],fnRecordsTotal:function(){return"ssp"==y(this)?1*this._iRecordsTotal:this.aiDisplayMaster.length},fnRecordsDisplay:function(){return"ssp"==y(this)?1*this._iRecordsDisplay:this.aiDisplay.length},fnDisplayEnd:function(){var a=this._iDisplayLength,
b=this._iDisplayStart,c=b+a,d=this.aiDisplay.length,e=this.oFeatures,f=e.bPaginate;return e.bServerSide?!1===f||-1===a?b+d:Math.min(b+a,this._iRecordsDisplay):!f||c>d||-1===a?d:c},oInstance:null,sInstance:null,iTabIndex:0,nScrollHead:null,nScrollFoot:null,aLastSort:[],oPlugins:{},rowIdFn:null,rowId:null};m.ext=x={buttons:{},classes:{},builder:"-source-",errMode:"alert",feature:[],search:[],selector:{cell:[],column:[],row:[]},internal:{},legacy:{ajax:null},pager:{},renderer:{pageButton:{},header:{}},
order:{},type:{detect:[],search:{},order:{}},_unique:0,fnVersionCheck:m.fnVersionCheck,iApiIndex:0,oJUIClasses:{},sVersion:m.version};h.extend(x,{afnFiltering:x.search,aTypes:x.type.detect,ofnSearch:x.type.search,oSort:x.type.order,afnSortData:x.order,aoFeatures:x.feature,oApi:x.internal,oStdClasses:x.classes,oPagination:x.pager});h.extend(m.ext.classes,{sTable:"dataTable",sNoFooter:"no-footer",sPageButton:"paginate_button",sPageButtonActive:"current",sPageButtonDisabled:"disabled",sStripeOdd:"odd",
sStripeEven:"even",sRowEmpty:"dataTables_empty",sWrapper:"dataTables_wrapper",sFilter:"dataTables_filter",sInfo:"dataTables_info",sPaging:"dataTables_paginate paging_",sLength:"dataTables_length",sProcessing:"dataTables_processing",sSortAsc:"sorting_asc",sSortDesc:"sorting_desc",sSortable:"sorting",sSortableAsc:"sorting_asc_disabled",sSortableDesc:"sorting_desc_disabled",sSortableNone:"sorting_disabled",sSortColumn:"sorting_",sFilterInput:"",sLengthSelect:"",sScrollWrapper:"dataTables_scroll",sScrollHead:"dataTables_scrollHead",
sScrollHeadInner:"dataTables_scrollHeadInner",sScrollBody:"dataTables_scrollBody",sScrollFoot:"dataTables_scrollFoot",sScrollFootInner:"dataTables_scrollFootInner",sHeaderTH:"",sFooterTH:"",sSortJUIAsc:"",sSortJUIDesc:"",sSortJUI:"",sSortJUIAscAllowed:"",sSortJUIDescAllowed:"",sSortJUIWrapper:"",sSortIcon:"",sJUIHeader:"",sJUIFooter:""});var Kb=m.ext.pager;h.extend(Kb,{simple:function(){return["previous","next"]},full:function(){return["first","previous","next","last"]},numbers:function(a,b){return[ha(a,
b)]},simple_numbers:function(a,b){return["previous",ha(a,b),"next"]},full_numbers:function(a,b){return["first","previous",ha(a,b),"next","last"]},first_last_numbers:function(a,b){return["first",ha(a,b),"last"]},_numbers:ha,numbers_length:7});h.extend(!0,m.ext.renderer,{pageButton:{_:function(a,b,c,d,e,f){var g=a.oClasses,j=a.oLanguage.oPaginate,i=a.oLanguage.oAria.paginate||{},n,l,m=0,o=function(b,d){var k,s,u,r,v=function(b){Sa(a,b.data.action,true)};k=0;for(s=d.length;k<s;k++){r=d[k];if(h.isArray(r)){u=
h("<"+(r.DT_el||"div")+"/>").appendTo(b);o(u,r)}else{n=null;l="";switch(r){case "ellipsis":b.append('<span class="ellipsis">&#x2026;</span>');break;case "first":n=j.sFirst;l=r+(e>0?"":" "+g.sPageButtonDisabled);break;case "previous":n=j.sPrevious;l=r+(e>0?"":" "+g.sPageButtonDisabled);break;case "next":n=j.sNext;l=r+(e<f-1?"":" "+g.sPageButtonDisabled);break;case "last":n=j.sLast;l=r+(e<f-1?"":" "+g.sPageButtonDisabled);break;default:n=r+1;l=e===r?g.sPageButtonActive:""}if(n!==null){u=h("<a>",{"class":g.sPageButton+
" "+l,"aria-controls":a.sTableId,"aria-label":i[r],"data-dt-idx":m,tabindex:a.iTabIndex,id:c===0&&typeof r==="string"?a.sTableId+"_"+r:null}).html(n).appendTo(b);Va(u,{action:r},v);m++}}}},s;try{s=h(b).find(G.activeElement).data("dt-idx")}catch(u){}o(h(b).empty(),d);s!==k&&h(b).find("[data-dt-idx="+s+"]").focus()}}});h.extend(m.ext.type.detect,[function(a,b){var c=b.oLanguage.sDecimal;return Ya(a,c)?"num"+c:null},function(a){if(a&&!(a instanceof Date)&&!Zb.test(a))return null;var b=Date.parse(a);
return null!==b&&!isNaN(b)||L(a)?"date":null},function(a,b){var c=b.oLanguage.sDecimal;return Ya(a,c,!0)?"num-fmt"+c:null},function(a,b){var c=b.oLanguage.sDecimal;return Pb(a,c)?"html-num"+c:null},function(a,b){var c=b.oLanguage.sDecimal;return Pb(a,c,!0)?"html-num-fmt"+c:null},function(a){return L(a)||"string"===typeof a&&-1!==a.indexOf("<")?"html":null}]);h.extend(m.ext.type.search,{html:function(a){return L(a)?a:"string"===typeof a?a.replace(Mb," ").replace(Aa,""):""},string:function(a){return L(a)?
a:"string"===typeof a?a.replace(Mb," "):a}});var za=function(a,b,c,d){if(0!==a&&(!a||"-"===a))return-Infinity;b&&(a=Ob(a,b));a.replace&&(c&&(a=a.replace(c,"")),d&&(a=a.replace(d,"")));return 1*a};h.extend(x.type.order,{"date-pre":function(a){return Date.parse(a)||-Infinity},"html-pre":function(a){return L(a)?"":a.replace?a.replace(/<.*?>/g,"").toLowerCase():a+""},"string-pre":function(a){return L(a)?"":"string"===typeof a?a.toLowerCase():!a.toString?"":a.toString()},"string-asc":function(a,b){return a<
b?-1:a>b?1:0},"string-desc":function(a,b){return a<b?1:a>b?-1:0}});cb("");h.extend(!0,m.ext.renderer,{header:{_:function(a,b,c,d){h(a.nTable).on("order.dt.DT",function(e,f,g,h){if(a===f){e=c.idx;b.removeClass(c.sSortingClass+" "+d.sSortAsc+" "+d.sSortDesc).addClass(h[e]=="asc"?d.sSortAsc:h[e]=="desc"?d.sSortDesc:c.sSortingClass)}})},jqueryui:function(a,b,c,d){h("<div/>").addClass(d.sSortJUIWrapper).append(b.contents()).append(h("<span/>").addClass(d.sSortIcon+" "+c.sSortingClassJUI)).appendTo(b);
h(a.nTable).on("order.dt.DT",function(e,f,g,h){if(a===f){e=c.idx;b.removeClass(d.sSortAsc+" "+d.sSortDesc).addClass(h[e]=="asc"?d.sSortAsc:h[e]=="desc"?d.sSortDesc:c.sSortingClass);b.find("span."+d.sSortIcon).removeClass(d.sSortJUIAsc+" "+d.sSortJUIDesc+" "+d.sSortJUI+" "+d.sSortJUIAscAllowed+" "+d.sSortJUIDescAllowed).addClass(h[e]=="asc"?d.sSortJUIAsc:h[e]=="desc"?d.sSortJUIDesc:c.sSortingClassJUI)}})}}});var Vb=function(a){return"string"===typeof a?a.replace(/</g,"&lt;").replace(/>/g,"&gt;").replace(/"/g,
"&quot;"):a};m.render={number:function(a,b,c,d,e){return{display:function(f){if("number"!==typeof f&&"string"!==typeof f)return f;var g=0>f?"-":"",h=parseFloat(f);if(isNaN(h))return Vb(f);h=h.toFixed(c);f=Math.abs(h);h=parseInt(f,10);f=c?b+(f-h).toFixed(c).substring(2):"";return g+(d||"")+h.toString().replace(/\B(?=(\d{3})+(?!\d))/g,a)+f+(e||"")}}},text:function(){return{display:Vb}}};h.extend(m.ext.internal,{_fnExternApiFunc:Lb,_fnBuildAjax:sa,_fnAjaxUpdate:kb,_fnAjaxParameters:tb,_fnAjaxUpdateDraw:ub,
_fnAjaxDataSrc:ta,_fnAddColumn:Da,_fnColumnOptions:ja,_fnAdjustColumnSizing:Y,_fnVisibleToColumnIndex:Z,_fnColumnIndexToVisible:$,_fnVisbleColumns:aa,_fnGetColumns:la,_fnColumnTypes:Fa,_fnApplyColumnDefs:hb,_fnHungarianMap:X,_fnCamelToHungarian:I,_fnLanguageCompat:Ca,_fnBrowserDetect:fb,_fnAddData:M,_fnAddTr:ma,_fnNodeToDataIndex:function(a,b){return b._DT_RowIndex!==k?b._DT_RowIndex:null},_fnNodeToColumnIndex:function(a,b,c){return h.inArray(c,a.aoData[b].anCells)},_fnGetCellData:B,_fnSetCellData:ib,
_fnSplitObjNotation:Ia,_fnGetObjectDataFn:Q,_fnSetObjectDataFn:R,_fnGetDataMaster:Ja,_fnClearTable:na,_fnDeleteIndex:oa,_fnInvalidate:ca,_fnGetRowElements:Ha,_fnCreateTr:Ga,_fnBuildHead:jb,_fnDrawHead:ea,_fnDraw:N,_fnReDraw:S,_fnAddOptionsHtml:mb,_fnDetectHeader:da,_fnGetUniqueThs:ra,_fnFeatureHtmlFilter:ob,_fnFilterComplete:fa,_fnFilterCustom:xb,_fnFilterColumn:wb,_fnFilter:vb,_fnFilterCreateSearch:Oa,_fnEscapeRegex:Pa,_fnFilterData:yb,_fnFeatureHtmlInfo:rb,_fnUpdateInfo:Bb,_fnInfoMacros:Cb,_fnInitialise:ga,
_fnInitComplete:ua,_fnLengthChange:Qa,_fnFeatureHtmlLength:nb,_fnFeatureHtmlPaginate:sb,_fnPageChange:Sa,_fnFeatureHtmlProcessing:pb,_fnProcessingDisplay:C,_fnFeatureHtmlTable:qb,_fnScrollDraw:ka,_fnApplyToChildren:H,_fnCalculateColumnWidths:Ea,_fnThrottle:Na,_fnConvertToWidth:Db,_fnGetWidestNode:Eb,_fnGetMaxLenString:Fb,_fnStringToCss:v,_fnSortFlatten:V,_fnSort:lb,_fnSortAria:Hb,_fnSortListener:Ua,_fnSortAttachListener:La,_fnSortingClasses:wa,_fnSortData:Gb,_fnSaveState:xa,_fnLoadState:Ib,_fnSettingsFromNode:ya,
_fnLog:J,_fnMap:F,_fnBindAction:Va,_fnCallbackReg:z,_fnCallbackFire:r,_fnLengthOverflow:Ra,_fnRenderer:Ma,_fnDataSource:y,_fnRowAttributes:Ka,_fnCalculateEnd:function(){}});h.fn.dataTable=m;m.$=h;h.fn.dataTableSettings=m.settings;h.fn.dataTableExt=m.ext;h.fn.DataTable=function(a){return h(this).dataTable(a).api()};h.each(m,function(a,b){h.fn.DataTable[a]=b});return h.fn.dataTable});
;
/*!
 DataTables Bootstrap 3 integration
 ©2011-2015 SpryMedia Ltd - datatables.net/license
*/
(function(b){"function"===typeof define&&define.amd?define(["jquery","datatables.net"],function(a){return b(a,window,document)}):"object"===typeof exports?module.exports=function(a,d){a||(a=window);if(!d||!d.fn.dataTable)d=require("datatables.net")(a,d).$;return b(d,a,a.document)}:b(jQuery,window,document)})(function(b,a,d,m){var f=b.fn.dataTable;b.extend(!0,f.defaults,{dom:"<'row'<'col-sm-6'l><'col-sm-6'f>><'row'<'col-sm-12'tr>><'row'<'col-sm-5'i><'col-sm-7'p>>",renderer:"bootstrap"});b.extend(f.ext.classes,
{sWrapper:"dataTables_wrapper form-inline dt-bootstrap",sFilterInput:"form-control input-sm",sLengthSelect:"form-control input-sm",sProcessing:"dataTables_processing panel panel-default"});f.ext.renderer.pageButton.bootstrap=function(a,h,r,s,j,n){var o=new f.Api(a),t=a.oClasses,k=a.oLanguage.oPaginate,u=a.oLanguage.oAria.paginate||{},e,g,p=0,q=function(d,f){var l,h,i,c,m=function(a){a.preventDefault();!b(a.currentTarget).hasClass("disabled")&&o.page()!=a.data.action&&o.page(a.data.action).draw("page")};
l=0;for(h=f.length;l<h;l++)if(c=f[l],b.isArray(c))q(d,c);else{g=e="";switch(c){case "ellipsis":e="&#x2026;";g="disabled";break;case "first":e=k.sFirst;g=c+(0<j?"":" disabled");break;case "previous":e=k.sPrevious;g=c+(0<j?"":" disabled");break;case "next":e=k.sNext;g=c+(j<n-1?"":" disabled");break;case "last":e=k.sLast;g=c+(j<n-1?"":" disabled");break;default:e=c+1,g=j===c?"active":""}e&&(i=b("<li>",{"class":t.sPageButton+" "+g,id:0===r&&"string"===typeof c?a.sTableId+"_"+c:null}).append(b("<a>",{href:"#",
"aria-controls":a.sTableId,"aria-label":u[c],"data-dt-idx":p,tabindex:a.iTabIndex}).html(e)).appendTo(d),a.oApi._fnBindAction(i,{action:c},m),p++)}},i;try{i=b(h).find(d.activeElement).data("dt-idx")}catch(v){}q(b(h).empty().html('<ul class="pagination"/>').children("ul"),s);i!==m&&b(h).find("[data-dt-idx="+i+"]").focus()};return f});
;
'use strict';

(function (globals) {
    if (window.jQuery) {
        $(document).ready(function () {
            if (typeof globals.bmgAccordionReady == 'undefined') {
                bmgAccordion.init();
                globals.bmgAccordionReady = true;
            }
        });
    } else {
        throw new Error('Block Accordion\'s JavaScript requires jQuery');
    }
}(this));


var bmgAccordion = (function () {
    return {
        init: function () {
            $(".toggle-accordion span").click(function () {
                var $this = $(this);
                if ($this.data('open')) {
                    $this.html($this.data('label-expand'));
                    $this.parents('.block-accordion').find('.panel-collapse.in').collapse('toggle');
                    $this.parents('.block-accordion').find('.panel-title > a').addClass('collapsed').addClass('panel-icon-down').removeClass("panel-icon-up"); // Update status on the link. It's important if you have icons on the link to open / close
                    $this.data('open', false);
                } else {
                    $this.html($this.data('label-collapse'));
                    $this.parents('.block-accordion').find('.panel-collapse').not('.in').collapse('toggle');
                    $this.parents('.block-accordion').find('.panel-title > a').removeClass('collapsed').removeClass("panel-icon-down").addClass('panel-icon-up'); // Update status on the link. It's important if you have icons on the link to open / close
                    $this.data('open', true);
                }                
            });
        }
    }
})();;
window.AnalyticsLog = false;

function CenterFinder($gMapLocator) {
    this.gMapLocator = $gMapLocator;
    this.initLat = this.gMapLocator.data("lat"); //default latitude for map initialization
    this.initLng = this.gMapLocator.data("lng"); //default longitude for map initialization
    this.initZoom = this.gMapLocator.data("zoom"); //default zoom
    this.blockId = this.gMapLocator.data('id');
    this.displayAllOnLoad = this.gMapLocator.data().displayOnLoad === "True";

    this.noSuggest = false;

    var proxy = this;

    this.map = new google.maps.Map(document.getElementById('map'), {
        center: {
            lat: proxy.initLat,
            lng: proxy.initLng
        },
        zoom: proxy.initZoom
    });

    var countryRestrict = {
        'country': 'us'
    };
    this.autocomplete = new google.maps.places.Autocomplete((document.getElementById('searchTerm')), {
        types: ['(regions)'],
        componentRestrictions: countryRestrict
    });

    this.autocomplete.setFields(['address_components', 'geometry', 'icon', 'name']);

    google.maps.event.addListener(proxy.autocomplete, 'place_changed', function () {

        var place = proxy.autocomplete.getPlace();

        var address = '';

        if (!place.geometry) {
            // User entered the name of a Place that was not suggested and
            // pressed the Enter key, or the Place Details request failed.
            // Do anything you like with what was entered in the ac field.            
            return;
        }

        if (place.address_components) {
            address = [
                (place.address_components[0] && place.address_components[0].short_name || ''),
                (place.address_components[1] && place.address_components[1].short_name || ''),
                (place.address_components[2] && place.address_components[2].short_name || '')
            ].join(' ');

            proxy.noSuggest = false;

            var analytics = {
                search: {
                    searchTerm: address
                },
                searchComponent: 'search using suggestions'
            }

            sendAnalytics(analytics, "search");
        }
    });

    this.currentMarker;
    this.currentGeometryObj = null;

    this.searchEventsEnabled = false;
    this.paginationEventsEnabled = false;

    this.epiData = [];
    this.markersData = []; // Episerver Markers Data
    this.markersList = []; // List of markers
    this.pinsList = []; // List of pins

    //Pagination Variables
    this.pages = []; // Array of pages
    this.currentPage = 0;
    this.numItemsToShow = this.gMapLocator.data("items-to-show");
    this.numPaginationLimit = this.gMapLocator.data("pagination-limit");

    this.sliceBegin = 0;
    this.sliceEnd = this.numPaginationLimit;

    this.numOfPages = 0;
    this.middlePaginationLimit = Math.round(this.numPaginationLimit / 2);

    this.activeInfoWindow;

    this.enableSearchEvents();

    /**
     * Initial load
     */

    if (this.displayAllOnLoad) {
        var pos = {
            lat: this.initLat,
            lng: this.initLng
        };
        this.map.setCenter(pos);
        this.replaceCurrentMarker(this.initLat, this.initLng);
        this.findPins(this.initLat, this.initLng, this.getFilterValue());
    }
    this.geolocate();
    this.InitDisclaimer();
}

/**
 * Geolocation of user
 */
CenterFinder.prototype.geolocate = function () {

    var proxy = this;
    // Try HTML5 geolocation.
    if (navigator.geolocation) {
        navigator.geolocation.getCurrentPosition(function (position) {
            var pos = {
                lat: position.coords.latitude,
                lng: position.coords.longitude
            };
            proxy.map.setCenter(pos);
            proxy.replaceCurrentMarker(position.coords.latitude, position.coords.longitude);
            proxy.getUserZipCode();

            if (proxy.displayAllOnLoad) {
                proxy.sortMarkers();
                proxy.fitBounds(proxy);
            }
            else {
                proxy.findPins(position.coords.latitude, position.coords.longitude, proxy.getFilterValue());
                proxy.filter();
                proxy.InitDisclaimer($('.marker2site, .marker2map'));
            }

            proxy.removeAllPins();
            proxy.sortMarkers();
            proxy.changePage();

            proxy.setCenterByDefault();
        }, function (error) {
            handleLocationError(true);
            console.log(error);
            var analyticsParam = {
                search: {
                    searchTerm: $("#searchTerm").val()
                }
            }

            if (error.code == error.PERMISSION_DENIED) {
                // User block location 
                sendAnalytics(analyticsParam, 'block');
            } else {
                // User close location prompt window
                sendAnalytics(analyticsParam, 'close');
            }
        });
    } else {
        // Browser doesn't support Geolocation
        handleLocationError(false);
    }

    function handleLocationError(browserHasGeolocation) {
        (browserHasGeolocation) ? console.log('Error: The Geolocation service failed.') : console.log('Error: Your browser doesn\'t support geolocation.');
    }
}

CenterFinder.prototype.getFilterValue = function () {
    if ($('.js-filter-radio:checked').length > 0)
        return $('.js-filter-radio:checked').val();
    else
        return 'all';
}

/**
 * Get the user zipcode location
 */
CenterFinder.prototype.getUserZipCode = function () {
    var geocoder = new google.maps.Geocoder();
    geocoder.geocode({
        address: this.currentMarker.position.lat() + "," + this.currentMarker.position.lng()
    },
        function (results, status) {
            if (status == 'OK') {
                var postalCode = results[0]["address_components"].filter(function (address) {
                    return address.types[0] == "postal_code";
                });
                if (postalCode.length > 0) {
                    var postalCodeNumber = postalCode[0]["short_name"];
                    $(".centerfinder-search-text").html(postalCodeNumber);
                    $("#searchTerm").val(postalCodeNumber);

                    var analyticsParam = {
                        search: {
                            searchTerm: postalCodeNumber
                        },
                        searchComponent: 'autopopulate search'
                    }
                    sendAnalytics(analyticsParam, 'autopopulate');
                }
            }
        }
    );
}


/**
 * Set center defined by episerver
 */
CenterFinder.prototype.setCenterByDefault = function () {
    if (this.activeInfoWindow) {
        this.activeInfoWindow.close();
    }
    this.map.setCenter({
        lat: this.initLat,
        lng: this.initLng
    });
    this.map.setZoom(this.initZoom);
}

CenterFinder.prototype.findPreviewToken = function (segmentName) {
    var token = 0;
    if (window.location.pathname.includes(segmentName)) {
        var paths = window.location.pathname.split("/");
        for (var index = 0; index < paths.length; index++) {
            if (paths[index] === segmentName && index + 1 < paths.length) {
                token = paths[index + 1];
                break;
            }
        }
    }
    return token;
}
/**
 * Perform search in episerver
 */
CenterFinder.prototype.findPins = function (latitude, longitude, filter, onSuccess) {
    var proxy = this;

    // send the external review token in the request
    var token = proxy.findPreviewToken("externalcontentview");
    if (!token) {
        token = proxy.findPreviewToken("externalcontentreviews");
    }

    var urlDomain = this.format('//{0}/CenterFinderBlock/FindMarkers/{1}/{2}/{3}/{4}/{5}', window.location.hostname, this.blockId, latitude, longitude, token, filter);

    $.ajax({
        url: urlDomain,
        method: "GET",
        dataType: "json",
        //contentType: 'application/json; charset=UTF-8'
    }).done(function (data) {
        proxy.epiData = data;
        proxy.filter();
        if (proxy.displayAllOnLoad) {
            proxy.sortMarkers();
        }
        proxy.removeAllPins();
        proxy.changePage();
        proxy.InitDisclaimer($('.marker2site, .marker2map'));
        if (typeof (onSuccess) === 'function') {
            onSuccess(proxy);
        }
    }).fail(function (xhr, status, errorThrown) {
        console.log("Fail I don't get any data: " + errorThrown);
        console.log("Status: " + status);

    });
}

/**
 * Initial Load
 */
CenterFinder.prototype.initLoad = function () {
    this.renderPagination();
    this.renderMarkersList();
    this.renderPins();
    this.bindEvents();
}

/**
 * Filter by tag value
 **/
CenterFinder.prototype.filter = function (val, skipEvents) {
    var proxy = this;

    function Page(index, selected) {
        this.index = index;
        this.selected = selected;
        this.pageNumber = (index + 1);
    }
    if (typeof (val) != "undefined" && val != null && val != "") {
        var filtered = proxy.epiData.filter(function (element) {
            if (element.Tags != null && Array.isArray(element.Tags) && element.Tags.length > 0) {
                return typeof (element.Tags.find(function (tagElement) {
                    return tagElement.Code == val
                })) != 'undefined';
            }
            return false;
        });
        proxy.markersData = $.extend(true, [], filtered);
        for (var i = 0; i < proxy.markersData.length; i++) {
            proxy.markersData[i].order = (i + 1).toString();
        }

    } else {
        proxy.markersData = proxy.epiData;
    }
    if (proxy.markersData !== null) {
        proxy.numOfPages = Math.ceil(proxy.markersData.length / proxy.numItemsToShow);

        if (proxy.pages != null && proxy.pages.length > 0) {
            proxy.pages = [];
        }

        for (var i = 0; i < proxy.numOfPages; i++) {
            proxy.pages.push(new Page(i, (i == 0)));
        }
        this.currentPage = 0;
        if (typeof (skipEvents) == "undefined" || !skipEvents)
            proxy.initLoad();
        else {
            proxy.removeAllPins();
            proxy.changePage();
        }
    }
}

/**
 * Handle search results
 */
CenterFinder.prototype.HandleSearchResult = function (results, status) {
    var proxy = this;
    $(".centerfinder-search-text").html("");
    if (status == 'OK') {
        var result = results[0];
        var isUSResult = (result["address_components"].map(function (address, index) {
            return address["short_name"] === "US"
        }).indexOf(true) > -1);
        if (isUSResult) {
            $(".centerfinder-search-text").html($('#searchTerm').val());

            proxy.removeAllPins();

            var latlng = result.geometry.location;
            proxy.map.setCenter({
                lat: latlng.lat(),
                lng: latlng.lng()
            });
            proxy.replaceCurrentMarker(latlng.lat(), latlng.lng());

            for (var i = 0; i < proxy.pages.length; i++) {
                proxy.pages[i].selected = i === 0;
            };

            proxy.currentPage = 0;

            var success = function (proxy) {
                if (result.geometry && result.geometry.viewport) {
                    proxy.currentGeometryObj = result.geometry;
                    proxy.fitBounds(proxy);
                }
            }

            proxy.findPins(latlng.lat(), latlng.lng(), proxy.getFilterValue(), success);

        } else {
            proxy.showError(true);
        }
    } else {
        proxy.showError(false);
    }
}

CenterFinder.prototype.fitBounds = function (proxy) {
    if (proxy.currentGeometryObj == null) return;

    var viewport = proxy.currentGeometryObj.viewport;
    var newBounds = new google.maps.LatLngBounds();

    if (typeof (proxy.markersData) !== 'undefined' && proxy.markersData.length > 0) {

        var firstPinPos = new google.maps.LatLng({
            lat: proxy.markersData[0].Latitude,
            lng: proxy.markersData[0].Longitude
        });

        var mirrorLat = proxy.currentGeometryObj.location.lat() + (proxy.currentGeometryObj.location.lat() - firstPinPos.lat());
        var mirrorLng = proxy.currentGeometryObj.location.lng() + (proxy.currentGeometryObj.location.lng() - firstPinPos.lng());
        var fakePinPos = new google.maps.LatLng({
            lat: mirrorLat,
            lng: mirrorLng
        });

        newBounds.extend(proxy.currentGeometryObj.location);
        newBounds.extend(firstPinPos);
        newBounds.extend(fakePinPos);
    } else {
        newBounds = proxy.currentGeometryObj.viewport;
    }

    proxy.map.fitBounds(newBounds);
}

/**
 * Bind eventListeners
 */
CenterFinder.prototype.bindEvents = function () {
    if (this.paginationEventsEnabled) return;
    var proxy = this;

    /* Pagination changes  */
    $(".homepage").on("click", ".centerfinder-pages li", function (e) {
        if (proxy.pages[proxy.currentPage].index !== $(this).data("page")) {
            $(".centerfinder-pages li").removeClass("active");
            proxy.pages[proxy.currentPage].selected = false;
            $(this).addClass("active");
            proxy.currentPage = $(this).data("page");
            proxy.pages[proxy.currentPage].selected = true;
            proxy.changePage();
            proxy.InitDisclaimer($('.marker2site, .marker2map'));
        }
    });

    $('.js-filter-radio').on('change', function () {
        var $this = $(this);
        //proxy.filter($this.val(), true);
        var analytics = {
            selectedFilter: $this.attr("id").toLowerCase()
        };
        sendAnalytics(analytics, "centerFilter");
        proxy.findPins(proxy.currentMarker.position.lat(), proxy.currentMarker.position.lng(), $this.val(), proxy.fitBounds);
    });

    this.paginationEventsEnabled = true;
}

CenterFinder.prototype.enableSearchEvents = function () {
    if (this.searchEventsEnabled) return;

    var proxy = this;
    /* Search  */
    $('#searchTerm').keydown(function (e) {
        var key = e.which;

        if (key === 13) {
            e.preventDefault();
            $(this).blur();

            // Send Analytics on using Enter key
            proxy.noSuggest = true;

            setTimeout(function () {
                if (proxy.noSuggest) {
                    var analytics = {
                        search: {
                            searchTerm: $('#searchTerm').val()
                        },
                        searchComponent: 'search using enter key'
                    };
                    sendAnalytics(analytics, 'search');
                }
            }, 1000);



            var geocoder = new google.maps.Geocoder();
            geocoder.geocode({
                address: $('#searchTerm').val()
            },
                function (results, status) {
                    proxy.HandleSearchResult(results, status)
                }
            );
        }

        if ($(this).val() != '') {
            $(this).next('.clean-input').show();
        } else {
            $(this).next('.clean-input').hide();
        }
    });

    /* When user focus on search text */
    $(".centerfinder-input").focus(function () {
        $(this).removeClass("error");
        $(".centerfinder-search-error").removeClass("error");
    });

    /* When user click to find marker */
    $('.centerfinder-btn-search').on('click', function (e) {
        e.preventDefault();
        var geocoder = new google.maps.Geocoder();
        geocoder.geocode({
            address: $('#searchTerm').val()
        },
            function (results, status) {
                proxy.HandleSearchResult(results, status)
            }
        );

        var analytics = {
            search: {
                searchTerm: $('#searchTerm').val()
            },
            searchComponent: 'search button clicked'
        };

        sendAnalytics(analytics, 'search');
    });

    $('.centerfinder-input-field .clean-input').on('click', function () {
        $('#searchTerm').val('');
        $(this).hide();
    });

    /* Google autocomplete */
    var autocomplete_OnPlaceChangedHandler = function () {
        var place = proxy.autocomplete.getPlace();
        if (place.address_components != null && Array.isArray(place.address_components) && place.address_components.length > 0) {
            proxy.HandleSearchResult([place], "OK");
        }
    };

    proxy.autocomplete.addListener('place_changed', autocomplete_OnPlaceChangedHandler);

    this.searchEventsEnabled = true;
}

/**
 * string format function
 **/
CenterFinder.prototype.format = function (str) {
    for (var k in arguments) {
        if (k > 0) {
            str = str.replace("{" + (k - 1) + "}", arguments[k]);
        }
    }
    return str;
}

/**
 * Placeholder for Search text
 */
CenterFinder.prototype.updateErrorPlaceholder = function (errorText, searchTerm) {
    var $errorElement = $('.centerfinder-search-error');

    errorText = this.format(errorText, '<b>' + searchTerm.trim() + '</b>');
    $errorElement.html(errorText);
}

/**
 * Show Error under search
 * @param boolean is place found outside US
 */
CenterFinder.prototype.showError = function (outsideUS) {
    this.setCenterByDefault();

    var text = "";
    var $errorElement = $('.centerfinder-search-error');

    if (outsideUS) {
        text = $errorElement.data('error-outside');
    } else {
        text = $errorElement.data('error');
    }
    this.updateErrorPlaceholder(text, $('#searchTerm').val());

    $(".centerfinder-search").addClass("error");
    $errorElement.addClass("error");
}

/**
 * Create the Pagination
 */
CenterFinder.prototype.renderPagination = function () {
    var pagination = $(".centerfinder-pagination");
    var htmlPagination = "<ul class='centerfinder-pages primary-brand-color'>";

    var proxy = this;

    var objCurrentPage = this.pages[this.currentPage];
    var showPreviousButton = false;
    //If it's the last results
    if (objCurrentPage != null && (objCurrentPage.index + this.middlePaginationLimit) >= this.numPaginationLimit && this.numOfPages > this.numPaginationLimit) {
        this.sliceBegin = objCurrentPage.index - Math.round(this.numPaginationLimit / 2);
        this.sliceBegin = this.sliceBegin <= 0 ? 0 : this.sliceBegin;
        this.sliceEnd = objCurrentPage.index + Math.round(this.numPaginationLimit / 2);
        if (objCurrentPage.index + this.middlePaginationLimit > this.numOfPages) {
            this.sliceEnd = this.numOfPages;
            this.sliceBegin = this.numOfPages - this.numPaginationLimit + 1;
            showPreviousButton = true;
        } else if (objCurrentPage.index > this.middlePaginationLimit && (this.middlePaginationLimit + objCurrentPage.index) !== this.numPaginationLimit && this.numPaginationLimit > 1) {
            this.sliceBegin = this.sliceEnd - this.numPaginationLimit + 1;
            if (this.sliceEnd + 1 === this.numOfPages)
                this.sliceEnd += 1;
            showPreviousButton = true;
        } else {
            this.sliceBegin = this.sliceEnd - this.numPaginationLimit + 1;
            if (objCurrentPage.index + this.middlePaginationLimit >= this.numPaginationLimit)
                showPreviousButton = true;
        }
        if (this.currentPage + this.middlePaginationLimit >= this.numOfPages)
            this.sliceBegin = this.sliceEnd - this.numPaginationLimit;

        if (this.numPaginationLimit === 1)
            this.sliceBegin = objCurrentPage.index;
        if (this.numPaginationLimit === 1 && objCurrentPage.index === 0)
            showPreviousButton = false;

        if (showPreviousButton)
            htmlPagination += "<li data-page='" + (objCurrentPage.index - 1) + "' >&lsaquo;</li>";

    } else {
        this.sliceBegin = 0;
        this.sliceEnd = this.numPaginationLimit;
    }

    $.map(proxy.pages.slice(this.sliceBegin, this.sliceEnd), function (page) {
        htmlPagination += "<li data-page='" + (page.index) + "' " + (page.selected ? " class='active' " : "") + ">" + ((page.index) + 1) + "</li>";
    });

    if (objCurrentPage != null && objCurrentPage.index + this.middlePaginationLimit < this.numOfPages) {
        if (this.numOfPages - objCurrentPage.index > this.middlePaginationLimit && this.sliceEnd != this.numOfPages && this.numOfPages > this.numPaginationLimit)
            htmlPagination += "<li data-page='" + (objCurrentPage.index + 1) + "' >&rsaquo;</li>";
    }

    htmlPagination += "</ul>";

    pagination.html(htmlPagination);

    $("body").scrollTop($(".google-map-locator").offset().top);
}

/**
 * Change the page
 */
CenterFinder.prototype.changePage = function () {
    this.renderPagination();
    this.renderMarkersList();
    this.renderPins();
}

/**
 * Refresh pins
 */
CenterFinder.prototype.refreshPins = function () {
    this.removeAllPins();
    this.renderPins();
}


/**
 * Add current Marker
 */
CenterFinder.prototype.replaceCurrentMarker = function (latitude, longitude) {
    var proxy = this;
    if (this.currentMarker && this.currentMarker.getMap() != null) {
        this.currentMarker.setMap(null);
    }
    this.currentMarker = new google.maps.Marker({
        position: {
            lat: latitude,
            lng: longitude
        },
        map: proxy.map
    });

};

/**
 * Added InfoWindow 
 */
CenterFinder.prototype.afterAddInfo = function (marker) {

    $(".centerfinder-marker-search-item").removeClass("active").find(".active").removeClass("active");
    var markerItem = $(".marker-item-" + marker.order);
    markerItem.find(".centerfinder-location-number").addClass("active");
    markerItem.addClass("active");
}

/**
 * Render Pin
 */
CenterFinder.prototype.addPin = function (marker, InfoViewContent) {
    var proxy = this;

    var markerFontSize = marker.order.length > 2 ? "9px" : "12px";

    var infowindow = new google.maps.InfoWindow({
        content: '<div class="markerWI">' + InfoViewContent + '</div>',
        domready: function () {
            proxy.afterAddInfo(marker);
        },
        closeclick: function () {
            $(".centerfinder-marker-search-item").find(".active").removeClass("active");
        }
    });

    var marker = new google.maps.Marker({
        position: {
            lat: marker.Latitude,
            lng: marker.Longitude,
        },
        map: proxy.map,
        title: marker.Center.replace("<br>", " "),
        label: {
            text: marker.order,
            color: "white",
            fontSize: markerFontSize
        },
    });


    marker.addListener('click', function () {
        if (proxy.activeInfoWindow) {
            proxy.activeInfoWindow.close();
        }

        google.maps.event.addListener(infowindow, 'domready', proxy.InfoWindowDOMReadyHandler);
        infowindow.open(proxy.map, marker);

        proxy.activeInfoWindow = infowindow;

        var analytics = {
            bubbleInfo: {
                'location': marker.title
            },
            searchComponent: 'bubble'
        }
        sendAnalytics(analytics, "bubble");
    });


    return {
        marker: marker,
        infoWindow: infowindow
    };
};

/**
 * Focus pin
 */
CenterFinder.prototype.focusPin = function (marker) {

    this.refreshPins();
    this.map.setZoom(14);

    var position = {
        lat: marker.Latitude,
        lng: marker.Longitude
    }

    var pin = this.pinsList[marker.order - 1];

    if (this.activeInfoWindow) {
        this.activeInfoWindow.close();
    }

    google.maps.event.addListener(pin.infoWindow, 'domready', this.InfoWindowDOMReadyHandler);
    pin.infoWindow.open(this.map, pin.marker);

    this.activeInfoWindow = pin.infoWindow;

    this.map.panTo(position);

    // Analytics
    var analytics = {
        bubbleInfo: {
            'location': marker.Center
        },
        searchComponent: 'left navigation'
    }
    sendAnalytics(analytics, "bubble");
};

CenterFinder.prototype.InfoWindowDOMReadyHandler = function () {
    try {
        interstitialSetupExternalLinks($('.marker2site, .marker2map'));
    } catch (error) { }
};

CenterFinder.prototype.InitDisclaimer = function ($anchors) {
    try {
        interstitialSetupExternalLinks($anchors);
    } catch (error) { }
};


/**
 * Remove pin from map
 */
CenterFinder.prototype.removeMarker = function (marker) {
    marker.setMap(null);
}


/**
 * Remove all markers
 */
CenterFinder.prototype.removeAllPins = function () {
    this.pinsList.forEach(function (pin) {
        pin.marker.setMap(null);
    });

    this.pinsList = [];
}

/**
 * Clear zipcode
 */
CenterFinder.prototype.clearMarkers = function () {
    if (this.markersData != null) {
        $(".centerfinder-result-search-count").html(this.markersData.length);
    }
    else {
        $(".centerfinder-result-search-count").html("0");
    }
    $(".centerfinder-markers").html("");
}

/**
 * Sort markers 
 */
CenterFinder.prototype.sortMarkers = function () {
    if (this.markersData != null) {
        var proxy = this;
        this.markersData.forEach(function (marker, index) {
            var distance = proxy.getDistanceFromLatLonInMiles(marker.Latitude, marker.Longitude);
            marker.Distance = distance;
            marker.distanceFromCurrent = (distance).toFixed(2);
        });

        this.markersData.sort(proxy.sortByDistance);
        $(".marker-pagination").html();

        this.markersData.forEach(function (marker, index) {
            proxy.markersData[index].order = (index + 1).toString();
        });
    }
}


/**
 * Render Markers List Sidebar
 */
CenterFinder.prototype.renderMarkersList = function () {
    var proxy = this;


    this.clearMarkers();

    if (proxy.markersData == null || proxy.markersData.length == 0) return;

    // Do the pagination in markersInfo
    $.map(proxy.markersData.slice(
        proxy.pages[proxy.currentPage].index * proxy.numItemsToShow,
        proxy.pages[proxy.currentPage].pageNumber * proxy.numItemsToShow
    ), function (marker, index) {

        var website;

        marker.Center = marker.Center ? marker.Center : "";
        marker.Address = marker.Address ? marker.Address : "";
        marker.City = marker.City ? marker.City : "";
        marker.State = marker.State ? marker.State : "";
        marker.ZIP = marker.ZIP ? marker.ZIP : "";
        marker.ContactPerson = marker.ContactPerson ? marker.ContactPerson : "";
        marker.PhoneNumber = marker.PhoneNumber ? marker.PhoneNumber : "";
        marker.PhoneNumber2 = marker.PhoneNumber2 ? marker.PhoneNumber2 : "";
        marker.PhoneNumberPrefix = marker.PhoneNumberPrefix ? marker.PhoneNumberPrefix + ' ' : "";
        marker.PhoneNumber2Prefix = marker.PhoneNumber2Prefix ? marker.PhoneNumber2Prefix + ' ' : "";
        marker.Website = marker.Website ? marker.Website : "";
        marker.CertificationStatus = marker.CertificationStatus ? marker.CertificationStatus : "";
        marker.Tags = marker.Tags ? marker.Tags : [];
        website = marker.Website ? "Website" : "";

        var markerSpanClass = marker.order.length > 2 ? "small" : "normal";

        var item = '<div class="centerfinder-marker-search-item marker-item-' + marker.order + '" data-order=' + marker.order + ' data-lat=' + marker.Latitude + ' data-lng=' + marker.Longitude + '>';
        item += '<div class="col-lg-12 col-md-12 col-sm-12 col-xs-12 centerfinder-marker-item">';
        item += '<div class="centerfinder-location-number"><span class="' + markerSpanClass + '">' + marker.order + '</span></div>';
        item += '<ul><li class="marker-title">' + marker.Center + '</li>';
        item += '<li class="visible-xs address">' + marker.Address + '</li>';
        item += '<li class="visible-xs address">' + marker.City + ' ' + marker.State + ' ' + marker.ZIP + '</li>';
        item += '<li class="visible-xs address">' + marker.ContactPerson + '</li>';
        item += '<li class="visible-xs phone">' + marker.PhoneNumberPrefix + '<a class="primary-brand-color" href="tel:' + marker.PhoneNumber + '">' + marker.PhoneNumber + '</a></li>';
        item += '<li class="visible-xs">' + marker.PhoneNumber2Prefix + '<a class="primary-brand-color" href="tel:' + marker.PhoneNumber2 + '">' + marker.PhoneNumber2 + '</a></li>';
        item += '<li><span class="certified">' + marker.CertificationStatus + '</span></li>';
        item += marker.Tags.length == 0 ? '' : '<li class="center-type">' + marker.Tags.map(function (tag) {
            return tag.ImageUrl == null ? '<span>' + tag.Abbreviation + '</span>' : '<img class="center-type" src=' + tag.ImageUrl + ' />'
        }).join('') + '</li>';

        var googleDirectionUrl = proxy.format("https://www.google.com/maps/dir/'{0},{1}'/'{2},{3}'/", proxy.currentMarker.position.lat(), proxy.currentMarker.position.lng(), marker.Latitude, marker.Longitude);

        item += '<li class="visible-xs hidden-item directions marker-item-' + marker.order + '"><a href="' + googleDirectionUrl + '" class="marker2map primary-brand-color-bg primary-brand-color-bg-hover " data-target="#interstitialPopUp" data-lat="' + marker.Latitude + '" data-order=' + marker.order + ' data-lng="' + marker.Longitude + '" target="_blank" >Get Directions</a></li>';
        if (marker.Website != "") {
            item += '<li class="visible-xs website"><a class="marker2site primary-brand-color-bg primary-brand-color-bg-hover" href="' + marker.Website + '" data-target="#interstitialPopUp" target="_blank" >' + website + '</a></li>';
        }
        item += '<li class="distance">' + marker.distanceFromCurrent + ' miles</li></ul></div></div>';

        item = $(item);

        item.appendTo(".centerfinder-markers");

        item.on('click', function () {
            proxy.focusPin(marker);
        });

        proxy.markersList.push(item);

    }).join('');

}


/**
 * Render Pins on Map
 */
CenterFinder.prototype.renderPins = function () {

    if (this.markersData == null) return;

    var proxy = this;

    this.markersData.forEach(function (marker, index) {

        var InfoViewContent = "";
        var website;
        var pin;

        //check what need to be in infoWindow ( 1. separated data like, title, city etc. 2. XhtmlContent in one variable
        if (!marker.XhtmlContent) {

            marker.Center = marker.Center ? marker.Center : "";
            marker.Address = marker.Address ? marker.Address : "";
            marker.City = marker.City ? marker.City : "";
            marker.State = marker.State ? marker.State : "";
            marker.ZIP = marker.ZIP ? marker.ZIP : "";
            marker.ContactPerson = marker.ContactPerson ? marker.ContactPerson : "";
            marker.PhoneNumber = marker.PhoneNumber ? marker.PhoneNumber : "";
            marker.PhoneNumber2 = marker.PhoneNumber2 ? marker.PhoneNumber2 : "";
            marker.PhoneNumberPrefix = marker.PhoneNumberPrefix ? marker.PhoneNumberPrefix + ' ' : "";
            marker.PhoneNumber2Prefix = marker.PhoneNumber2Prefix ? marker.PhoneNumber2Prefix + ' ' : "";
            marker.Website = marker.Website ? marker.Website : "";
            marker.CertificationStatus = marker.CertificationStatus ? marker.CertificationStatus : "";
            marker.Tags = marker.Tags ? marker.Tags : [];
            website = marker.Website ? "Website" : "";

            InfoViewContent += '<div class="markerWItitleLabel">' + marker.Center + '</div>';
            InfoViewContent += '<div class="address">';
            InfoViewContent += '<div class="markerWIAddress">' + marker.Address + '</div>';
            InfoViewContent += '<div class="markerWICity">' + marker.City + ' ' + marker.State + ' ' + marker.ZIP + '</div>';
            InfoViewContent += '</div>';
            InfoViewContent += '<div class="contact">';
            InfoViewContent += '<div class="markerWIContact">' + marker.ContactPerson + '</div>';
            InfoViewContent += '<div class="markerWIPhone">' + marker.PhoneNumberPrefix + marker.PhoneNumber + '</div>';
            InfoViewContent += '<div class="markerWIPhone">' + marker.PhoneNumber2Prefix + marker.PhoneNumber2 + '</div>';
            InfoViewContent += '</div>';
            InfoViewContent += '<div class="markerWICertificationStatus">' + marker.CertificationStatus + '</div>';
            InfoViewContent += marker.Tags.length == 0 ? '' : '<div class="markerWICenterType">' + marker.Tags.map(function (tag) {
                return tag.ImageUrl == null ? '<span>' + tag.Abbreviation + '</span>' : '<img class="center-type"  src=' + tag.ImageUrl + ' />'
            }).join('') + '</div>';

            var googleDirectionUrl = proxy.format("https://www.google.com/maps/dir/'{0},{1}'/'{2},{3}'/", proxy.currentMarker.position.lat(), proxy.currentMarker.position.lng(), marker.Latitude, marker.Longitude);

            InfoViewContent += '<div class="markerWIDirections"><a class="marker2map primary-brand-color-bg primary-brand-color-bg-hover " href="' + googleDirectionUrl + '" data-target="#interstitialPopUp" target="_blank">Get Directions</a></div>';
            if (marker.Website != "") {
                InfoViewContent += '<div class="markerWIWebsite"><a class="marker2site primary-brand-color-bg primary-brand-color-bg-hover " href="' + marker.Website + '" data-target="#interstitialPopUp" target="_blank">' + website + '</a></div>';
            }
            InfoViewContent += '<div class="markerWIDistance"><span>' + marker.distanceFromCurrent + '</span> miles</div>';

            pin = proxy.addPin(marker, InfoViewContent);
        } else {
            pin = proxy.addPin(marker, marker.XhtmlContent);
        }
        proxy.pinsList.push(pin);

    }); // end foreach
}

/**
 * Get distance from current location and specific marker
 */
CenterFinder.prototype.getDistanceFromLatLonInMiles = function (lat2, lon2) {

    function deg2rad(deg) {
        return deg * (Math.PI / 180)
    }

    var lat1, lon1;
    if (this.currentMarker !== undefined) {
        lat1 = this.currentMarker.position.lat();
        lon1 = this.currentMarker.position.lng();
    }
    var R = 6371; // Radius of the earth in km
    var dLat = deg2rad(lat2 - lat1); // deg2rad below
    var dLon = deg2rad(lon2 - lon1);
    var a =
        Math.sin(dLat / 2) * Math.sin(dLat / 2) +
        Math.cos(deg2rad(lat1)) * Math.cos(deg2rad(lat2)) *
        Math.sin(dLon / 2) * Math.sin(dLon / 2);
    var c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a));
    var d = (R * c) * 0.621371192; // Distance in miles
    return d;
}


/**
 * Sort by closest distance
 */
CenterFinder.prototype.sortByDistance = function (a, b) {
    var aDistance = parseFloat(a.Distance);
    var bDistance = parseFloat(b.Distance);
    return aDistance - bDistance;
}

/**
 * Capture Analytics
 */
CenterFinder.prototype.captureSearchTerm = function (term) {

}


/**
 * Send Analytics event
 */
function sendAnalytics(param, track) {
    if (AnalyticsLog) {
        console.log('Send Analytics: ', param, track);
    }
    try {
        if (typeof (dataLayer) !== "undefined") {
            // Merge dataLayer with new parameters;
            for (var attrname in param) {
                dataLayer[attrname] = param[attrname];
            }
        }
    } catch (error) {
        console.log('Analytics failed: ' + error);
    }

    /*GTM Onco tracking*/
    try {
        if (typeof (dataLayerOnco) !== "undefined") {
            switch (track) {
                case "close":
                    sendGtmEventDataLayerOnco("locations", "click on allow autopulated search", param.search.searchTerm);
                    break;
                case "block":
                    sendGtmEventDataLayerOnco("locations", "click on block autopulated search", param.search.searchTerm);
                    break;
                case "autopopulate":
                    sendGtmEventDataLayerOnco("locations", "click on allow autopulated search", param.search.searchTerm);
                    break;
                case "search":
                    if (param.searchComponent == "search button clicked") {
                        sendGtmEventDataLayerOnco("locations", "click on search button", param.search.searchTerm);
                    }
                    else if (param.searchComponent == "search using suggestions") {
                        sendGtmEventDataLayerOnco("locations", "click on suggestion search", param.search.searchTerm);
                    }
                    else {
                        sendGtmEventDataLayerOnco("locations", param.searchComponent, param.search.searchTerm);
                    }
                    break;
                case "bubble":
                    if (param.searchComponent == "left navigation") {
                        sendGtmEventDataLayerOnco("locations", "click on a result from left navigation", param.bubbleInfo.location);
                    }
                    else if (param.searchComponent == "bubble") {
                        sendGtmEventDataLayerOnco("locations", "select a pin on map", param.bubbleInfo.location);
                    }

                    break;
                case "centerFilter":
                    sendGtmEventDataLayerOnco("locations", "click on treatment center type", param.selectedFilter);
                    break;
            }
        }
    } catch (error) {
        console.log('Analytics failed: ' + error);
    }
}
/*GTM Onco tracking function*/
function sendGtmEventDataLayerOnco(category, action, label) {
    if (typeof (dataLayerOnco) !== "undefined") {
        dataLayerOnco.push({
            'event': 'gtm_event',
            'eventInfo': {
                'category': category ? category : "",
                'action': action ? action : "",
                'label': label ? label : ""
            }
        });
    }
}

$(document).ready(function () {
    var locator = $('.google-map-locator');
    if (locator.length > 0) {
        var centerFinder = new CenterFinder($('.google-map-locator'));
    }


});;
var UrlArray = [];
var InitialLength = 0;
window.onload = function () {
    $('#CrawlerStart').on('click', function () {
        $('.progress-bar').css('width', 0 + '%').attr('aria-valuenow', 0).html(Math.round(0) + '%');
        $('.test-url').each(function () {
            UrlArray.push($(this));
        });
        InitialLength = UrlArray.length;
        testSynchronousUrls();
    });


};
function testUrl($a) {
    $.ajax({
        type: 'HEAD',
        url: $a.data('url'),
        dataType: 'jsonp',
        success: function (data, textStatus, request) {
            if (request.getResponseHeader('Transfer-Encoding') === null) {
                urlLoadingDone($a, 200);
            } else {
                urlLoadingDone($a, "");
            }
        },
        error: function (error) {
            urlLoadingDone($a, error.status);
        }
    });

}

function urlLoadingDone($a, status) {
    if ($a !== null) {
        if (status === 200) {
            $a.next('.status').addClass('ok');
        } else {
            $a.next('.status').addClass('fail');
            $a.next('.status').append(status);
            $('div.panel-group').has('.fail').addClass('warning');
        }
    }
}

function IncreaseLoadingBar() {
    var value = 100 - (UrlArray.length / InitialLength * 100);
    $('.progress-bar').css('width', value + '%').attr('aria-valuenow', value).html(Math.round(value) + '%');
}


function findUrlElByUrl(urlArr, url) {
    for (var i = 0; i < urlArr.length; i++) {
        if (urlArr[i].data('url') === url) return urlArr[i];
    }

    return null;
}

function testSynchronousUrls() {
    var numOfReq = $('#error-crawler-container').data('numofreq');
    var reqNb = 5;
    if (numOfReq !== null)
        reqNb = parseInt(numOfReq);

    if (reqNb === 0) reqNb = 5;

    if (reqNb === null)
        if (UrlArray.length < reqNb) {
            reqNb = UrlArray.length;
        }
    var batchURLs = UrlArray.splice(0, reqNb);
    var requestsArr = [];
    if (batchURLs.length > 0) {
        for (var i = 0; i < batchURLs.length; i++) {
            requestsArr.push(getAjaxRequest($(batchURLs[i]).data('url')));
        }

        $.when.apply(undefined, requestsArr).then(function () {
            for (var i = 0; i < arguments.length; i++) {
                var responseData = arguments[i][0], responseStatus = arguments[i][1], responseReq = arguments[i][2];
                if (responseData.Success === true) {
                    urlLoadingDone(findUrlElByUrl(batchURLs, responseData.Url), responseData.Status);
                } else {
                    urlLoadingDone(findUrlElByUrl(batchURLs, responseData.Url), '');
                }

            }
            IncreaseLoadingBar();
            testSynchronousUrls();
        });
    }
}



function getAjaxRequest(url) {
    return $.ajax({
        method: 'GET',
        url: '/modules/digione.bmg/UrlProxy/HeadRequestTo?url=' + url
    });
};
var boomerang = boomerang || {};

(function() {
    if (boomerang.externalLinkDisclaimer !== undefined) {
        return;
    }

    boomerang.externalLinkDisclaimer = function() {};
    boomerang.externalLinkDisclaimer.prototype = {
        $container: null,

        /* This function will look every links, and change the onclick to open an external link popup, if needed.
        The parameter linkContainer can be passed, it will apply the disclaimers to the links in the specified selector
        */
        setupExternalLinks: function (container,linkContainer) {
            this.$container = $(container);
            var self = this;
            if (self.$container.length !== 0) {
                var excludedUrls = self.$container
                    .attr('data-excluded-urls')
                    .split(',')
                    .filter(function (n) { return n != ''; })
                    .map(function (n) { return decodeURIComponent(n); });

                var $links = $("a:not(.js-popup)");
                if (linkContainer) {
                    $links = $(linkContainer).find("a:not(.js-popup)");
                }

                $links.each(function () {
                    if (this.href) {
                        var domain = this.href.split("?");
                        if (!$(this).hasClass('no-disclaimer') && domain[0].indexOf('http') != -1 && domain[0].indexOf(window.location.hostname) == -1 && !self.disclaimerExcludeUrl(domain[0], excludedUrls)) {
                            $(this).off("click.showdisclaimer").on("click.showdisclaimer", function (e) {
                                e.preventDefault();
                                self.openExternalLinkDisclaimer(this.href, this.target);
                                return false;
                            });
                        }
                    }
                });
            }
        },

        /* Function to handle the disclaimer */
        openExternalLinkDisclaimer: function (url, target) {
            var self = this;
            self.$container.find(".js-disclaimerPopUpOKButton").unbind('click').one("click", function () {
                self.$container.modal('hide');
                window.open(url, target);
            });
            self.$container.modal('show');
        },

        /* Function that checks if the url provided is in the array */
        disclaimerExcludeUrl: function(url, excludedUrls) {
            var re = /www./gi;
            for (var l = 0; l < excludedUrls.length; l++) {
                var excludedUrl = excludedUrls[l];
                if (url.indexOf(excludedUrl) == 0 || url.indexOf(excludedUrl.replace(re, "")) == 0) {
                    return true;
                }
            }
            return false;
        }
    };

})();

$(document).ready(function () {

    $(".js-externalLinkDisclaimerPopUp").each(function (index, value) {
        var externalLinkDisclaimer = new boomerang.externalLinkDisclaimer();
        externalLinkDisclaimer.setupExternalLinks(value);
    });
});;
var componentFancyboxImageSettings = componentFancyboxImageSettings ||
{
    helpers : {
        overlay : {
            css: {
                'background': "rgba(0, 0, 0, 0.86)"
            }
        },
        title : {
            type : "inside" // 'float', 'inside', 'outside' or 'over'
        }
    }

}

$(document).ready(function () {
    $(".component-fancybox-image-thumb").fancybox(componentFancyboxImageSettings);
});;
$(document).ready(function() {
    // code for the collapses
});
"use strict";
(function (root, factory) {
    if (typeof exports === 'object') {
        module.exports = factory();
    }
    else if (typeof define === 'function' && define.amd) {
        define(['jquery', 'googlemaps!'], factory);
    }
    else {
        root.GMaps = factory();
    }


}(this, function () {

    /*!
     * GMaps.js v0.4.24
     * http://hpneo.github.com/gmaps/
     *
     * Copyright 2016, Gustavo Leon
     * Released under the MIT License.
     */

    var extend_object = function (obj, new_obj) {
        var name;

        if (obj === new_obj) {
            return obj;
        }

        for (name in new_obj) {
            if (new_obj[name] !== undefined) {
                obj[name] = new_obj[name];
            }
        }

        return obj;
    };

    var replace_object = function (obj, replace) {
        var name;

        if (obj === replace) {
            return obj;
        }

        for (name in replace) {
            if (obj[name] != undefined) {
                obj[name] = replace[name];
            }
        }

        return obj;
    };

    var array_map = function (array, callback) {
        var original_callback_params = Array.prototype.slice.call(arguments, 2),
            array_return = [],
            array_length = array.length,
            i;

        if (Array.prototype.map && array.map === Array.prototype.map) {
            array_return = Array.prototype.map.call(array, function (item) {
                var callback_params = original_callback_params.slice(0);
                callback_params.splice(0, 0, item);

                return callback.apply(this, callback_params);
            });
        }
        else {
            for (i = 0; i < array_length; i++) {
                callback_params = original_callback_params;
                callback_params.splice(0, 0, array[i]);
                array_return.push(callback.apply(this, callback_params));
            }
        }

        return array_return;
    };

    var array_flat = function (array) {
        var new_array = [],
            i;

        for (i = 0; i < array.length; i++) {
            new_array = new_array.concat(array[i]);
        }

        return new_array;
    };

    var coordsToLatLngs = function (coords, useGeoJSON) {
        var first_coord = coords[0],
            second_coord = coords[1];

        if (useGeoJSON) {
            first_coord = coords[1];
            second_coord = coords[0];
        }

        return new google.maps.LatLng(first_coord, second_coord);
    };

    var arrayToLatLng = function (coords, useGeoJSON) {
        var i;

        for (i = 0; i < coords.length; i++) {
            if (!(coords[i] instanceof google.maps.LatLng)) {
                if (coords[i].length > 0 && typeof (coords[i][0]) === "object") {
                    coords[i] = arrayToLatLng(coords[i], useGeoJSON);
                }
                else {
                    coords[i] = coordsToLatLngs(coords[i], useGeoJSON);
                }
            }
        }

        return coords;
    };

    var getElementsByClassName = function (class_name, context) {
        var element,
            _class = class_name.replace('.', '');

        if ('jQuery' in this && context) {
            element = $("." + _class, context)[0];
        } else {
            element = document.getElementsByClassName(_class)[0];
        }
        return element;

    };

    var getElementById = function (id, context) {
        var element,
        id = id.replace('#', '');

        if ('jQuery' in window && context) {
            element = $('#' + id, context)[0];
        } else {
            element = document.getElementById(id);
        };

        return element;
    };

    var findAbsolutePosition = function (obj) {
        var curleft = 0,
            curtop = 0;

        if (obj.offsetParent) {
            do {
                curleft += obj.offsetLeft;
                curtop += obj.offsetTop;
            } while (obj = obj.offsetParent);
        }

        return [curleft, curtop];
    };

    var GMaps = (function (global) {
        "use strict";

        var doc = document;
        /**
         * Creates a new GMaps instance, including a Google Maps map.
         * @class GMaps
         * @constructs
         * @param {object} options - `options` accepts all the [MapOptions](https://developers.google.com/maps/documentation/javascript/reference#MapOptions) and [events](https://developers.google.com/maps/documentation/javascript/reference#Map) listed in the Google Maps API. Also accepts:
         * * `lat` (number): Latitude of the map's center
         * * `lng` (number): Longitude of the map's center
         * * `el` (string or HTMLElement): container where the map will be rendered
         * * `markerClusterer` (function): A function to create a marker cluster. You can use MarkerClusterer or MarkerClustererPlus.
         */
        var GMaps = function (options) {

            if (!(typeof window.google === 'object' && window.google.maps)) {
                if (typeof window.console === 'object' && window.console.error) {
                    console.error('Google Maps API is required. Please register the following JavaScript library https://maps.googleapis.com/maps/api/js.');
                }

                return function () { };
            }

            if (!this) return new GMaps(options);

            options.zoom = options.zoom || 15;
            options.mapType = options.mapType || 'roadmap';

            //maxZoom restriction
            if (options.mapType == 'roadmap') options.maxZoom = 22;

            var valueOrDefault = function (value, defaultValue) {
                return value === undefined ? defaultValue : value;
            };

            var self = this,
                i,
                events_that_hide_context_menu = [
                  'bounds_changed', 'center_changed', 'click', 'dblclick', 'drag',
                  'dragend', 'dragstart', 'idle', 'maptypeid_changed', 'projection_changed',
                  'resize', 'tilesloaded', 'zoom_changed'
                ],
                events_that_doesnt_hide_context_menu = ['mousemove', 'mouseout', 'mouseover'],
                options_to_be_deleted = ['el', 'lat', 'lng', 'mapType', 'width', 'height', 'markerClusterer', 'enableNewStyle'],
                identifier = options.el || options.div,
                markerClustererFunction = options.markerClusterer,
                mapType = google.maps.MapTypeId[options.mapType.toUpperCase()],
                map_center = new google.maps.LatLng(options.lat, options.lng),
                zoomControl = valueOrDefault(options.zoomControl, true),
                zoomControlOpt = options.zoomControlOpt || {
                    style: 'DEFAULT',
                    position: 'TOP_LEFT'
                },
                zoomControlStyle = zoomControlOpt.style || 'DEFAULT',
                zoomControlPosition = zoomControlOpt.position || 'TOP_LEFT',
                panControl = valueOrDefault(options.panControl, true),
                mapTypeControl = valueOrDefault(options.mapTypeControl, true),
                scaleControl = valueOrDefault(options.scaleControl, true),
                streetViewControl = valueOrDefault(options.streetViewControl, true),
                overviewMapControl = valueOrDefault(overviewMapControl, true),
                map_options = {},
                map_base_options = {
                    zoom: this.zoom,
                    center: map_center,
                    mapTypeId: mapType
                },
                map_controls_options = {
                    panControl: panControl,
                    zoomControl: zoomControl,
                    zoomControlOptions: {
                        style: google.maps.ZoomControlStyle[zoomControlStyle],
                        position: google.maps.ControlPosition[zoomControlPosition]
                    },
                    mapTypeControl: mapTypeControl,
                    scaleControl: scaleControl,
                    streetViewControl: streetViewControl,
                    overviewMapControl: overviewMapControl
                };

            if (typeof (options.el) === 'string' || typeof (options.div) === 'string') {
                if (identifier.indexOf("#") > -1) {
                    /**
                     * Container element
                     *
                     * @type {HTMLElement}
                     */
                    this.el = getElementById(identifier, options.context);
                } else {
                    this.el = getElementsByClassName.apply(this, [identifier, options.context]);
                }
            } else {
                this.el = identifier;
            }

            if (typeof (this.el) === 'undefined' || this.el === null) {
                throw 'No element defined.';
            }

            window.context_menu = window.context_menu || {};
            window.context_menu[self.el.id] = {};

            /**
             * Collection of custom controls in the map UI
             *
             * @type {array}
             */
            this.controls = [];
            /**
             * Collection of map's overlays
             *
             * @type {array}
             */
            this.overlays = [];
            /**
             * Collection of KML/GeoRSS and FusionTable layers
             *
             * @type {array}
             */
            this.layers = [];
            /**
             * Collection of data layers (See {@link GMaps#addLayer})
             *
             * @type {object}
             */
            this.singleLayers = {};
            /**
             * Collection of map's markers
             *
             * @type {array}
             */
            this.markers = [];
            /**
             * Collection of map's lines
             *
             * @type {array}
             */
            this.polylines = [];
            /**
             * Collection of map's routes requested by {@link GMaps#getRoutes}, {@link GMaps#renderRoute}, {@link GMaps#drawRoute}, {@link GMaps#travelRoute} or {@link GMaps#drawSteppedRoute}
             *
             * @type {array}
             */
            this.routes = [];
            /**
             * Collection of map's polygons
             *
             * @type {array}
             */
            this.polygons = [];
            this.infoWindow = null;
            this.overlay_el = null;
            /**
             * Current map's zoom
             *
             * @type {number}
             */
            this.zoom = options.zoom;
            this.registered_events = {};

            this.el.style.width = options.width || this.el.scrollWidth || this.el.offsetWidth;
            this.el.style.height = options.height || this.el.scrollHeight || this.el.offsetHeight;

            google.maps.visualRefresh = options.enableNewStyle;

            for (i = 0; i < options_to_be_deleted.length; i++) {
                delete options[options_to_be_deleted[i]];
            }

            if (options.disableDefaultUI != true) {
                map_base_options = extend_object(map_base_options, map_controls_options);
            }

            map_options = extend_object(map_base_options, options);

            for (i = 0; i < events_that_hide_context_menu.length; i++) {
                delete map_options[events_that_hide_context_menu[i]];
            }

            for (i = 0; i < events_that_doesnt_hide_context_menu.length; i++) {
                delete map_options[events_that_doesnt_hide_context_menu[i]];
            }

            /**
             * Google Maps map instance
             *
             * @type {google.maps.Map}
             */
            this.map = new google.maps.Map(this.el, map_options);

            if (markerClustererFunction) {
                /**
                 * Marker Clusterer instance
                 *
                 * @type {object}
                 */
                this.markerClusterer = markerClustererFunction.apply(this, [this.map]);
            }

            var buildContextMenuHTML = function (control, e) {
                var html = '',
                    options = window.context_menu[self.el.id][control];

                for (var i in options) {
                    if (options.hasOwnProperty(i)) {
                        var option = options[i];

                        html += '<li><a id="' + control + '_' + i + '" href="#">' + option.title + '</a></li>';
                    }
                }

                if (!getElementById('gmaps_context_menu')) return;

                var context_menu_element = getElementById('gmaps_context_menu');

                context_menu_element.innerHTML = html;

                var context_menu_items = context_menu_element.getElementsByTagName('a'),
                    context_menu_items_count = context_menu_items.length,
                    i;

                for (i = 0; i < context_menu_items_count; i++) {
                    var context_menu_item = context_menu_items[i];

                    var assign_menu_item_action = function (ev) {
                        ev.preventDefault();

                        options[this.id.replace(control + '_', '')].action.apply(self, [e]);
                        self.hideContextMenu();
                    };

                    google.maps.event.clearListeners(context_menu_item, 'click');
                    google.maps.event.addDomListenerOnce(context_menu_item, 'click', assign_menu_item_action, false);
                }

                var position = findAbsolutePosition.apply(this, [self.el]),
                    left = position[0] + e.pixel.x - 15,
                    top = position[1] + e.pixel.y - 15;

                context_menu_element.style.left = left + "px";
                context_menu_element.style.top = top + "px";

                // context_menu_element.style.display = 'block';
            };

            this.buildContextMenu = function (control, e) {
                if (control === 'marker') {
                    e.pixel = {};

                    var overlay = new google.maps.OverlayView();
                    overlay.setMap(self.map);

                    overlay.draw = function () {
                        var projection = overlay.getProjection(),
                            position = e.marker.getPosition();

                        e.pixel = projection.fromLatLngToContainerPixel(position);

                        buildContextMenuHTML(control, e);
                    };
                }
                else {
                    buildContextMenuHTML(control, e);
                }

                var context_menu_element = getElementById('gmaps_context_menu');

                setTimeout(function () {
                    context_menu_element.style.display = 'block';
                }, 0);
            };

            /**
             * Add a context menu for a map or a marker.
             *
             * @param {object} options - The `options` object should contain:
             * * `control` (string): Kind of control the context menu will be attached. Can be "map" or "marker".
             * * `options` (array): A collection of context menu items:
             *   * `title` (string): Item's title shown in the context menu.
             *   * `name` (string): Item's identifier.
             *   * `action` (function): Function triggered after selecting the context menu item.
             */
            this.setContextMenu = function (options) {
                window.context_menu[self.el.id][options.control] = {};

                var i,
                    ul = doc.createElement('ul');

                for (i in options.options) {
                    if (options.options.hasOwnProperty(i)) {
                        var option = options.options[i];

                        window.context_menu[self.el.id][options.control][option.name] = {
                            title: option.title,
                            action: option.action
                        };
                    }
                }

                ul.id = 'gmaps_context_menu';
                ul.style.display = 'none';
                ul.style.position = 'absolute';
                ul.style.minWidth = '100px';
                ul.style.background = 'white';
                ul.style.listStyle = 'none';
                ul.style.padding = '8px';
                ul.style.boxShadow = '2px 2px 6px #ccc';

                if (!getElementById('gmaps_context_menu')) {
                    doc.body.appendChild(ul);
                }

                var context_menu_element = getElementById('gmaps_context_menu');

                google.maps.event.addDomListener(context_menu_element, 'mouseout', function (ev) {
                    if (!ev.relatedTarget || !this.contains(ev.relatedTarget)) {
                        window.setTimeout(function () {
                            context_menu_element.style.display = 'none';
                        }, 400);
                    }
                }, false);
            };

            /**
             * Hide the current context menu
             */
            this.hideContextMenu = function () {
                var context_menu_element = getElementById('gmaps_context_menu');

                if (context_menu_element) {
                    context_menu_element.style.display = 'none';
                }
            };

            var setupListener = function (object, name) {
                google.maps.event.addListener(object, name, function (e) {
                    if (e == undefined) {
                        e = this;
                    }

                    options[name].apply(this, [e]);

                    self.hideContextMenu();
                });
            };

            //google.maps.event.addListener(this.map, 'idle', this.hideContextMenu);
            google.maps.event.addListener(this.map, 'zoom_changed', this.hideContextMenu);

            for (var ev = 0; ev < events_that_hide_context_menu.length; ev++) {
                var name = events_that_hide_context_menu[ev];

                if (name in options) {
                    setupListener(this.map, name);
                }
            }

            for (var ev = 0; ev < events_that_doesnt_hide_context_menu.length; ev++) {
                var name = events_that_doesnt_hide_context_menu[ev];

                if (name in options) {
                    setupListener(this.map, name);
                }
            }

            google.maps.event.addListener(this.map, 'rightclick', function (e) {
                if (options.rightclick) {
                    options.rightclick.apply(this, [e]);
                }

                if (window.context_menu[self.el.id]['map'] != undefined) {
                    self.buildContextMenu('map', e);
                }
            });

            /**
             * Trigger a `resize` event, useful if you need to repaint the current map (for changes in the viewport or display / hide actions).
             */
            this.refresh = function () {
                google.maps.event.trigger(this.map, 'resize');
            };

            /**
             * Adjust the map zoom to include all the markers added in the map.
             */
            this.fitZoom = function () {
                var latLngs = [],
                    markers_length = this.markers.length,
                    i;

                for (i = 0; i < markers_length; i++) {
                    if (typeof (this.markers[i].visible) === 'boolean' && this.markers[i].visible) {
                        latLngs.push(this.markers[i].getPosition());
                    }
                }

                this.fitLatLngBounds(latLngs);
            };

            /**
             * Adjust the map zoom to include all the coordinates in the `latLngs` array.
             *
             * @param {array} latLngs - Collection of `google.maps.LatLng` objects.
             */
            this.fitLatLngBounds = function (latLngs) {
                var total = latLngs.length,
                    bounds = new google.maps.LatLngBounds(),
                    i;

                for (i = 0; i < total; i++) {
                    bounds.extend(latLngs[i]);
                }

                this.map.fitBounds(bounds);
            };

            /**
             * Center the map using the `lat` and `lng` coordinates.
             *
             * @param {number} lat - Latitude of the coordinate.
             * @param {number} lng - Longitude of the coordinate.
             * @param {function} [callback] - Callback that will be executed after the map is centered.
             */
            this.setCenter = function (lat, lng, callback) {
                this.map.panTo(new google.maps.LatLng(lat, lng));

                if (callback) {
                    callback();
                }
            };

            /**
             * Return the HTML element container of the map.
             *
             * @returns {HTMLElement} the element container.
             */
            this.getElement = function () {
                return this.el;
            };

            /**
             * Increase the map's zoom.
             *
             * @param {number} [magnitude] - The number of times the map will be zoomed in.
             */
            this.zoomIn = function (value) {
                value = value || 1;

                this.zoom = this.map.getZoom() + value;
                this.map.setZoom(this.zoom);
            };

            /**
             * Decrease the map's zoom.
             *
             * @param {number} [magnitude] - The number of times the map will be zoomed out.
             */
            this.zoomOut = function (value) {
                value = value || 1;

                this.zoom = this.map.getZoom() - value;
                this.map.setZoom(this.zoom);
            };

            var native_methods = [],
                method;

            for (method in this.map) {
                if (typeof (this.map[method]) == 'function' && !this[method]) {
                    native_methods.push(method);
                }
            }

            for (i = 0; i < native_methods.length; i++) {
                (function (gmaps, scope, method_name) {
                    gmaps[method_name] = function () {
                        return scope[method_name].apply(scope, arguments);
                    };
                })(this, this.map, native_methods[i]);
            }
        };

        return GMaps;
    })(this);

    GMaps.prototype.createControl = function (options) {
        var control = document.createElement('div');

        control.style.cursor = 'pointer';

        if (options.disableDefaultStyles !== true) {
            control.style.fontFamily = 'Roboto, Arial, sans-serif';
            control.style.fontSize = '11px';
            control.style.boxShadow = 'rgba(0, 0, 0, 0.298039) 0px 1px 4px -1px';
        }

        for (var option in options.style) {
            control.style[option] = options.style[option];
        }

        if (options.id) {
            control.id = options.id;
        }

        if (options.title) {
            control.title = options.title;
        }

        if (options.classes) {
            control.className = options.classes;
        }

        if (options.content) {
            if (typeof options.content === 'string') {
                control.innerHTML = options.content;
            }
            else if (options.content instanceof HTMLElement) {
                control.appendChild(options.content);
            }
        }

        if (options.position) {
            control.position = google.maps.ControlPosition[options.position.toUpperCase()];
        }

        for (var ev in options.events) {
            (function (object, name) {
                google.maps.event.addDomListener(object, name, function () {
                    options.events[name].apply(this, [this]);
                });
            })(control, ev);
        }

        control.index = 1;

        return control;
    };

    /**
     * Add a custom control to the map UI.
     *
     * @param {object} options - The `options` object should contain:
     * * `style` (object): The keys and values of this object should be valid CSS properties and values.
     * * `id` (string): The HTML id for the custom control.
     * * `classes` (string): A string containing all the HTML classes for the custom control.
     * * `content` (string or HTML element): The content of the custom control.
     * * `position` (string): Any valid [`google.maps.ControlPosition`](https://developers.google.com/maps/documentation/javascript/controls#ControlPositioning) value, in lower or upper case.
     * * `events` (object): The keys of this object should be valid DOM events. The values should be functions.
     * * `disableDefaultStyles` (boolean): If false, removes the default styles for the controls like font (family and size), and box shadow.
     * @returns {HTMLElement}
     */
    GMaps.prototype.addControl = function (options) {
        var control = this.createControl(options);

        this.controls.push(control);
        this.map.controls[control.position].push(control);

        return control;
    };

    /**
     * Remove a control from the map. `control` should be a control returned by `addControl()`.
     *
     * @param {HTMLElement} control - One of the controls returned by `addControl()`.
     * @returns {HTMLElement} the removed control.
     */
    GMaps.prototype.removeControl = function (control) {
        var position = null,
            i;

        for (i = 0; i < this.controls.length; i++) {
            if (this.controls[i] == control) {
                position = this.controls[i].position;
                this.controls.splice(i, 1);
            }
        }

        if (position) {
            for (i = 0; i < this.map.controls.length; i++) {
                var controlsForPosition = this.map.controls[control.position];

                if (controlsForPosition.getAt(i) == control) {
                    controlsForPosition.removeAt(i);

                    break;
                }
            }
        }

        return control;
    };

    GMaps.prototype.createMarker = function (options) {
        if (options.lat == undefined && options.lng == undefined && options.position == undefined) {
            throw 'No latitude or longitude defined.';
        }

        var self = this,
            details = options.details,
            fences = options.fences,
            outside = options.outside,
            base_options = {
                position: new google.maps.LatLng(options.lat, options.lng),
                map: null
            },
            marker_options = extend_object(base_options, options);

        delete marker_options.lat;
        delete marker_options.lng;
        delete marker_options.fences;
        delete marker_options.outside;

        var marker = new google.maps.Marker(marker_options);

        marker.fences = fences;

        if (options.infoWindow) {
            marker.infoWindow = new google.maps.InfoWindow(options.infoWindow);

            var info_window_events = ['closeclick', 'content_changed', 'domready', 'position_changed', 'zindex_changed'];
            for (var ev = 0; ev < info_window_events.length; ev++) {
                (function (object, name) {
                    if (options.infoWindow[name]) {
                        google.maps.event.addListener(object, name, function (e) {
                            options.infoWindow[name].apply(this, [e]);
                        });
                    }
                })(marker.infoWindow, info_window_events[ev]);
            }
        }

        var marker_events = ['animation_changed', 'clickable_changed', 'cursor_changed', 'draggable_changed', 'flat_changed', 'icon_changed', 'position_changed', 'shadow_changed', 'shape_changed', 'title_changed', 'visible_changed', 'zindex_changed'];

        var marker_events_with_mouse = ['dblclick', 'drag', 'dragend', 'dragstart', 'mousedown', 'mouseout', 'mouseover', 'mouseup'];

        for (var ev = 0; ev < marker_events.length; ev++) {
            (function (object, name) {
                if (options[name]) {
                    google.maps.event.addListener(object, name, function () {
                        options[name].apply(this, [this]);
                    });
                }
            })(marker, marker_events[ev]);
        }

        for (var ev = 0; ev < marker_events_with_mouse.length; ev++) {
            (function (map, object, name) {
                if (options[name]) {
                    google.maps.event.addListener(object, name, function (me) {
                        if (!me.pixel) {
                            me.pixel = map.getProjection().fromLatLngToPoint(me.latLng)
                        }

                        options[name].apply(this, [me]);
                    });
                }
            })(this.map, marker, marker_events_with_mouse[ev]);
        }

        google.maps.event.addListener(marker, 'click', function () {
            this.details = details;

            if (options.click) {
                options.click.apply(this, [this]);
            }

            if (marker.infoWindow) {
                self.hideInfoWindows();
                marker.infoWindow.open(self.map, marker);
            }
        });

        google.maps.event.addListener(marker, 'rightclick', function (e) {
            e.marker = this;

            if (options.rightclick) {
                options.rightclick.apply(this, [e]);
            }

            if (window.context_menu[self.el.id]['marker'] != undefined) {
                self.buildContextMenu('marker', e);
            }
        });

        if (marker.fences) {
            google.maps.event.addListener(marker, 'dragend', function () {
                self.checkMarkerGeofence(marker, function (m, f) {
                    outside(m, f);
                });
            });
        }

        return marker;
    };

    GMaps.prototype.pinColor = function (color) {
        return {
            path: 'M 0,0 C -2,-20 -10,-22 -10,-30 A 10,10 0 1,1 10,-30 C 10,-22 2,-20 0,0 z M -2,-30 a 2,2 0 1,1 4,0 2,2 0 1,1 -4,0',
            fillColor: color,
            fillOpacity: 1,
            strokeColor: '#000',
            strokeWeight: 2,
            scale: 1
        };
    }

    GMaps.prototype.addMarker = function (options) {
        var marker;
        if (options.hasOwnProperty('gm_accessors_')) {
            // Native google.maps.Marker object
            marker = options;
        }
        else {
            if ((options.hasOwnProperty('lat') && options.hasOwnProperty('lng')) || options.position) {
                marker = this.createMarker(options);
            }
            else {
                throw 'No latitude or longitude defined.';
            }
        }

        marker.setMap(this.map);

        if (this.markerClusterer) {
            this.markerClusterer.addMarker(marker);
        }

        this.markers.push(marker);

        GMaps.fire('marker_added', marker, this);

        return marker;
    };

    GMaps.prototype.addMarkers = function (array) {
        for (var i = 0, marker; marker = array[i]; i++) {
            this.addMarker(marker);
        }

        return this.markers;
    };

    GMaps.prototype.hideInfoWindows = function () {
        for (var i = 0, marker; marker = this.markers[i]; i++) {
            if (marker.infoWindow) {
                marker.infoWindow.close();
            }
        }
    };

    GMaps.prototype.removeMarker = function (marker) {
        for (var i = 0; i < this.markers.length; i++) {
            if (this.markers[i] === marker) {
                this.markers[i].setMap(null);
                this.markers.splice(i, 1);

                if (this.markerClusterer) {
                    this.markerClusterer.removeMarker(marker);
                }

                GMaps.fire('marker_removed', marker, this);

                break;
            }
        }

        return marker;
    };

    GMaps.prototype.removeMarkers = function (collection) {
        var new_markers = [];

        if (typeof collection == 'undefined') {
            for (var i = 0; i < this.markers.length; i++) {
                var marker = this.markers[i];
                marker.setMap(null);

                GMaps.fire('marker_removed', marker, this);
            }

            if (this.markerClusterer && this.markerClusterer.clearMarkers) {
                this.markerClusterer.clearMarkers();
            }

            this.markers = new_markers;
        }
        else {
            for (var i = 0; i < collection.length; i++) {
                var index = this.markers.indexOf(collection[i]);

                if (index > -1) {
                    var marker = this.markers[index];
                    marker.setMap(null);

                    if (this.markerClusterer) {
                        this.markerClusterer.removeMarker(marker);
                    }

                    GMaps.fire('marker_removed', marker, this);
                }
            }

            for (var i = 0; i < this.markers.length; i++) {
                var marker = this.markers[i];
                if (marker.getMap() != null) {
                    new_markers.push(marker);
                }
            }

            this.markers = new_markers;
        }
    };

    GMaps.prototype.drawOverlay = function (options) {
        var overlay = new google.maps.OverlayView(),
            auto_show = true;

        overlay.setMap(this.map);

        if (options.auto_show != null) {
            auto_show = options.auto_show;
        }

        overlay.onAdd = function () {
            var el = document.createElement('div');

            el.style.borderStyle = "none";
            el.style.borderWidth = "0px";
            el.style.position = "absolute";
            el.style.zIndex = 100;
            el.innerHTML = options.content;

            overlay.el = el;

            if (!options.layer) {
                options.layer = 'overlayLayer';
            }

            var panes = this.getPanes(),
                overlayLayer = panes[options.layer],
                stop_overlay_events = ['contextmenu', 'DOMMouseScroll', 'dblclick', 'mousedown'];

            overlayLayer.appendChild(el);

            for (var ev = 0; ev < stop_overlay_events.length; ev++) {
                (function (object, name) {
                    google.maps.event.addDomListener(object, name, function (e) {
                        if (navigator.userAgent.toLowerCase().indexOf('msie') != -1 && document.all) {
                            e.cancelBubble = true;
                            e.returnValue = false;
                        }
                        else {
                            e.stopPropagation();
                        }
                    });
                })(el, stop_overlay_events[ev]);
            }

            if (options.click) {
                panes.overlayMouseTarget.appendChild(overlay.el);
                google.maps.event.addDomListener(overlay.el, 'click', function () {
                    options.click.apply(overlay, [overlay]);
                });
            }

            google.maps.event.trigger(this, 'ready');
        };

        overlay.draw = function () {
            var projection = this.getProjection(),
                pixel = projection.fromLatLngToDivPixel(new google.maps.LatLng(options.lat, options.lng));

            options.horizontalOffset = options.horizontalOffset || 0;
            options.verticalOffset = options.verticalOffset || 0;

            var el = overlay.el,
                content = el.children[0],
                content_height = content.clientHeight,
                content_width = content.clientWidth;

            switch (options.verticalAlign) {
                case 'top':
                    el.style.top = (pixel.y - content_height + options.verticalOffset) + 'px';
                    break;
                default:
                case 'middle':
                    el.style.top = (pixel.y - (content_height / 2) + options.verticalOffset) + 'px';
                    break;
                case 'bottom':
                    el.style.top = (pixel.y + options.verticalOffset) + 'px';
                    break;
            }

            switch (options.horizontalAlign) {
                case 'left':
                    el.style.left = (pixel.x - content_width + options.horizontalOffset) + 'px';
                    break;
                default:
                case 'center':
                    el.style.left = (pixel.x - (content_width / 2) + options.horizontalOffset) + 'px';
                    break;
                case 'right':
                    el.style.left = (pixel.x + options.horizontalOffset) + 'px';
                    break;
            }

            el.style.display = auto_show ? 'block' : 'none';

            if (!auto_show) {
                options.show.apply(this, [el]);
            }
        };

        overlay.onRemove = function () {
            var el = overlay.el;

            if (options.remove) {
                options.remove.apply(this, [el]);
            }
            else {
                overlay.el.parentNode.removeChild(overlay.el);
                overlay.el = null;
            }
        };

        this.overlays.push(overlay);
        return overlay;
    };

    GMaps.prototype.removeOverlay = function (overlay) {
        for (var i = 0; i < this.overlays.length; i++) {
            if (this.overlays[i] === overlay) {
                this.overlays[i].setMap(null);
                this.overlays.splice(i, 1);

                break;
            }
        }
    };

    GMaps.prototype.removeOverlays = function () {
        for (var i = 0, item; item = this.overlays[i]; i++) {
            item.setMap(null);
        }

        this.overlays = [];
    };

    GMaps.prototype.drawPolyline = function (options) {
        var path = [],
            points = options.path;

        if (points.length) {
            if (points[0][0] === undefined) {
                path = points;
            }
            else {
                for (var i = 0, latlng; latlng = points[i]; i++) {
                    path.push(new google.maps.LatLng(latlng[0], latlng[1]));
                }
            }
        }

        var polyline_options = {
            map: this.map,
            path: path,
            strokeColor: options.strokeColor,
            strokeOpacity: options.strokeOpacity,
            strokeWeight: options.strokeWeight,
            geodesic: options.geodesic,
            clickable: true,
            editable: false,
            visible: true
        };

        if (options.hasOwnProperty("clickable")) {
            polyline_options.clickable = options.clickable;
        }

        if (options.hasOwnProperty("editable")) {
            polyline_options.editable = options.editable;
        }

        if (options.hasOwnProperty("icons")) {
            polyline_options.icons = options.icons;
        }

        if (options.hasOwnProperty("zIndex")) {
            polyline_options.zIndex = options.zIndex;
        }

        var polyline = new google.maps.Polyline(polyline_options);

        var polyline_events = ['click', 'dblclick', 'mousedown', 'mousemove', 'mouseout', 'mouseover', 'mouseup', 'rightclick'];

        for (var ev = 0; ev < polyline_events.length; ev++) {
            (function (object, name) {
                if (options[name]) {
                    google.maps.event.addListener(object, name, function (e) {
                        options[name].apply(this, [e]);
                    });
                }
            })(polyline, polyline_events[ev]);
        }

        this.polylines.push(polyline);

        GMaps.fire('polyline_added', polyline, this);

        return polyline;
    };

    GMaps.prototype.removePolyline = function (polyline) {
        for (var i = 0; i < this.polylines.length; i++) {
            if (this.polylines[i] === polyline) {
                this.polylines[i].setMap(null);
                this.polylines.splice(i, 1);

                GMaps.fire('polyline_removed', polyline, this);

                break;
            }
        }
    };

    GMaps.prototype.removePolylines = function () {
        for (var i = 0, item; item = this.polylines[i]; i++) {
            item.setMap(null);
        }

        this.polylines = [];
    };

    GMaps.prototype.drawCircle = function (options) {
        options = extend_object({
            map: this.map,
            center: new google.maps.LatLng(options.lat, options.lng)
        }, options);

        delete options.lat;
        delete options.lng;

        var polygon = new google.maps.Circle(options),
            polygon_events = ['click', 'dblclick', 'mousedown', 'mousemove', 'mouseout', 'mouseover', 'mouseup', 'rightclick'];

        for (var ev = 0; ev < polygon_events.length; ev++) {
            (function (object, name) {
                if (options[name]) {
                    google.maps.event.addListener(object, name, function (e) {
                        options[name].apply(this, [e]);
                    });
                }
            })(polygon, polygon_events[ev]);
        }

        this.polygons.push(polygon);

        return polygon;
    };

    GMaps.prototype.drawRectangle = function (options) {
        options = extend_object({
            map: this.map
        }, options);

        var latLngBounds = new google.maps.LatLngBounds(
          new google.maps.LatLng(options.bounds[0][0], options.bounds[0][1]),
          new google.maps.LatLng(options.bounds[1][0], options.bounds[1][1])
        );

        options.bounds = latLngBounds;

        var polygon = new google.maps.Rectangle(options),
            polygon_events = ['click', 'dblclick', 'mousedown', 'mousemove', 'mouseout', 'mouseover', 'mouseup', 'rightclick'];

        for (var ev = 0; ev < polygon_events.length; ev++) {
            (function (object, name) {
                if (options[name]) {
                    google.maps.event.addListener(object, name, function (e) {
                        options[name].apply(this, [e]);
                    });
                }
            })(polygon, polygon_events[ev]);
        }

        this.polygons.push(polygon);

        return polygon;
    };

    GMaps.prototype.drawPolygon = function (options) {
        var useGeoJSON = false;

        if (options.hasOwnProperty("useGeoJSON")) {
            useGeoJSON = options.useGeoJSON;
        }

        delete options.useGeoJSON;

        options = extend_object({
            map: this.map
        }, options);

        if (useGeoJSON == false) {
            options.paths = [options.paths.slice(0)];
        }

        if (options.paths.length > 0) {
            if (options.paths[0].length > 0) {
                options.paths = array_flat(array_map(options.paths, arrayToLatLng, useGeoJSON));
            }
        }

        var polygon = new google.maps.Polygon(options),
            polygon_events = ['click', 'dblclick', 'mousedown', 'mousemove', 'mouseout', 'mouseover', 'mouseup', 'rightclick'];

        for (var ev = 0; ev < polygon_events.length; ev++) {
            (function (object, name) {
                if (options[name]) {
                    google.maps.event.addListener(object, name, function (e) {
                        options[name].apply(this, [e]);
                    });
                }
            })(polygon, polygon_events[ev]);
        }

        this.polygons.push(polygon);

        GMaps.fire('polygon_added', polygon, this);

        return polygon;
    };

    GMaps.prototype.removePolygon = function (polygon) {
        for (var i = 0; i < this.polygons.length; i++) {
            if (this.polygons[i] === polygon) {
                this.polygons[i].setMap(null);
                this.polygons.splice(i, 1);

                GMaps.fire('polygon_removed', polygon, this);

                break;
            }
        }
    };

    GMaps.prototype.removePolygons = function () {
        for (var i = 0, item; item = this.polygons[i]; i++) {
            item.setMap(null);
        }

        this.polygons = [];
    };

    GMaps.prototype.getFromFusionTables = function (options) {
        var events = options.events;

        delete options.events;

        var fusion_tables_options = options,
            layer = new google.maps.FusionTablesLayer(fusion_tables_options);

        for (var ev in events) {
            (function (object, name) {
                google.maps.event.addListener(object, name, function (e) {
                    events[name].apply(this, [e]);
                });
            })(layer, ev);
        }

        this.layers.push(layer);

        return layer;
    };

    GMaps.prototype.loadFromFusionTables = function (options) {
        var layer = this.getFromFusionTables(options);
        layer.setMap(this.map);

        return layer;
    };

    GMaps.prototype.getFromKML = function (options) {
        var url = options.url,
            events = options.events;

        delete options.url;
        delete options.events;

        var kml_options = options,
            layer = new google.maps.KmlLayer(url, kml_options);

        for (var ev in events) {
            (function (object, name) {
                google.maps.event.addListener(object, name, function (e) {
                    events[name].apply(this, [e]);
                });
            })(layer, ev);
        }

        this.layers.push(layer);

        return layer;
    };

    GMaps.prototype.loadFromKML = function (options) {
        var layer = this.getFromKML(options);
        layer.setMap(this.map);

        return layer;
    };

    GMaps.prototype.addLayer = function (layerName, options) {
        //var default_layers = ['weather', 'clouds', 'traffic', 'transit', 'bicycling', 'panoramio', 'places'];
        options = options || {};
        var layer;

        switch (layerName) {
            case 'weather': this.singleLayers.weather = layer = new google.maps.weather.WeatherLayer();
                break;
            case 'clouds': this.singleLayers.clouds = layer = new google.maps.weather.CloudLayer();
                break;
            case 'traffic': this.singleLayers.traffic = layer = new google.maps.TrafficLayer();
                break;
            case 'transit': this.singleLayers.transit = layer = new google.maps.TransitLayer();
                break;
            case 'bicycling': this.singleLayers.bicycling = layer = new google.maps.BicyclingLayer();
                break;
            case 'panoramio':
                this.singleLayers.panoramio = layer = new google.maps.panoramio.PanoramioLayer();
                layer.setTag(options.filter);
                delete options.filter;

                //click event
                if (options.click) {
                    google.maps.event.addListener(layer, 'click', function (event) {
                        options.click(event);
                        delete options.click;
                    });
                }
                break;
            case 'places':
                this.singleLayers.places = layer = new google.maps.places.PlacesService(this.map);

                //search, nearbySearch, radarSearch callback, Both are the same
                if (options.search || options.nearbySearch || options.radarSearch) {
                    var placeSearchRequest = {
                        bounds: options.bounds || null,
                        keyword: options.keyword || null,
                        location: options.location || null,
                        name: options.name || null,
                        radius: options.radius || null,
                        rankBy: options.rankBy || null,
                        types: options.types || null
                    };

                    if (options.radarSearch) {
                        layer.radarSearch(placeSearchRequest, options.radarSearch);
                    }

                    if (options.search) {
                        layer.search(placeSearchRequest, options.search);
                    }

                    if (options.nearbySearch) {
                        layer.nearbySearch(placeSearchRequest, options.nearbySearch);
                    }
                }

                //textSearch callback
                if (options.textSearch) {
                    var textSearchRequest = {
                        bounds: options.bounds || null,
                        location: options.location || null,
                        query: options.query || null,
                        radius: options.radius || null
                    };

                    layer.textSearch(textSearchRequest, options.textSearch);
                }
                break;
        }

        if (layer !== undefined) {
            if (typeof layer.setOptions == 'function') {
                layer.setOptions(options);
            }
            if (typeof layer.setMap == 'function') {
                layer.setMap(this.map);
            }

            return layer;
        }
    };

    GMaps.prototype.removeLayer = function (layer) {
        if (typeof (layer) == "string" && this.singleLayers[layer] !== undefined) {
            this.singleLayers[layer].setMap(null);

            delete this.singleLayers[layer];
        }
        else {
            for (var i = 0; i < this.layers.length; i++) {
                if (this.layers[i] === layer) {
                    this.layers[i].setMap(null);
                    this.layers.splice(i, 1);

                    break;
                }
            }
        }
    };

    var travelMode, unitSystem;

    GMaps.prototype.getRoutes = function (options) {
        switch (options.travelMode) {
            case 'bicycling':
                travelMode = google.maps.TravelMode.BICYCLING;
                break;
            case 'transit':
                travelMode = google.maps.TravelMode.TRANSIT;
                break;
            case 'driving':
                travelMode = google.maps.TravelMode.DRIVING;
                break;
            default:
                travelMode = google.maps.TravelMode.WALKING;
                break;
        }

        if (options.unitSystem === 'imperial') {
            unitSystem = google.maps.UnitSystem.IMPERIAL;
        }
        else {
            unitSystem = google.maps.UnitSystem.METRIC;
        }

        var base_options = {
            avoidHighways: false,
            avoidTolls: false,
            optimizeWaypoints: false,
            waypoints: []
        },
            request_options = extend_object(base_options, options);

        request_options.origin = /string/.test(typeof options.origin) ? options.origin : new google.maps.LatLng(options.origin[0], options.origin[1]);
        request_options.destination = /string/.test(typeof options.destination) ? options.destination : new google.maps.LatLng(options.destination[0], options.destination[1]);
        request_options.travelMode = travelMode;
        request_options.unitSystem = unitSystem;

        delete request_options.callback;
        delete request_options.error;

        var self = this,
            routes = [],
            service = new google.maps.DirectionsService();

        service.route(request_options, function (result, status) {
            if (status === google.maps.DirectionsStatus.OK) {
                for (var r in result.routes) {
                    if (result.routes.hasOwnProperty(r)) {
                        routes.push(result.routes[r]);
                    }
                }

                if (options.callback) {
                    options.callback(routes, result, status);
                }
            }
            else {
                if (options.error) {
                    options.error(result, status);
                }
            }
        });
    };

    GMaps.prototype.removeRoutes = function () {
        this.routes.length = 0;
    };

    GMaps.prototype.getElevations = function (options) {
        options = extend_object({
            locations: [],
            path: false,
            samples: 256
        }, options);

        if (options.locations.length > 0) {
            if (options.locations[0].length > 0) {
                options.locations = array_flat(array_map([options.locations], arrayToLatLng, false));
            }
        }

        var callback = options.callback;
        delete options.callback;

        var service = new google.maps.ElevationService();

        //location request
        if (!options.path) {
            delete options.path;
            delete options.samples;

            service.getElevationForLocations(options, function (result, status) {
                if (callback && typeof (callback) === "function") {
                    callback(result, status);
                }
            });
            //path request
        } else {
            var pathRequest = {
                path: options.locations,
                samples: options.samples
            };

            service.getElevationAlongPath(pathRequest, function (result, status) {
                if (callback && typeof (callback) === "function") {
                    callback(result, status);
                }
            });
        }
    };

    GMaps.prototype.cleanRoute = GMaps.prototype.removePolylines;

    GMaps.prototype.renderRoute = function (options, renderOptions) {
        var self = this,
            panel = ((typeof renderOptions.panel === 'string') ? document.getElementById(renderOptions.panel.replace('#', '')) : renderOptions.panel),
            display;

        renderOptions.panel = panel;
        renderOptions = extend_object({
            map: this.map
        }, renderOptions);
        display = new google.maps.DirectionsRenderer(renderOptions);

        this.getRoutes({
            origin: options.origin,
            destination: options.destination,
            travelMode: options.travelMode,
            waypoints: options.waypoints,
            unitSystem: options.unitSystem,
            error: options.error,
            avoidHighways: options.avoidHighways,
            avoidTolls: options.avoidTolls,
            optimizeWaypoints: options.optimizeWaypoints,
            callback: function (routes, response, status) {
                if (status === google.maps.DirectionsStatus.OK) {
                    display.setDirections(response);
                }
            }
        });
    };

    GMaps.prototype.drawRoute = function (options) {
        var self = this;

        this.getRoutes({
            origin: options.origin,
            destination: options.destination,
            travelMode: options.travelMode,
            waypoints: options.waypoints,
            unitSystem: options.unitSystem,
            error: options.error,
            avoidHighways: options.avoidHighways,
            avoidTolls: options.avoidTolls,
            optimizeWaypoints: options.optimizeWaypoints,
            callback: function (routes) {
                if (routes.length > 0) {
                    var polyline_options = {
                        path: routes[routes.length - 1].overview_path,
                        strokeColor: options.strokeColor,
                        strokeOpacity: options.strokeOpacity,
                        strokeWeight: options.strokeWeight
                    };

                    if (options.hasOwnProperty("icons")) {
                        polyline_options.icons = options.icons;
                    }

                    self.drawPolyline(polyline_options);

                    if (options.callback) {
                        options.callback(routes[routes.length - 1]);
                    }
                }
            }
        });
    };

    GMaps.prototype.travelRoute = function (options) {
        if (options.origin && options.destination) {
            this.getRoutes({
                origin: options.origin,
                destination: options.destination,
                travelMode: options.travelMode,
                waypoints: options.waypoints,
                unitSystem: options.unitSystem,
                error: options.error,
                callback: function (e) {
                    //start callback
                    if (e.length > 0 && options.start) {
                        options.start(e[e.length - 1]);
                    }

                    //step callback
                    if (e.length > 0 && options.step) {
                        var route = e[e.length - 1];
                        if (route.legs.length > 0) {
                            var steps = route.legs[0].steps;
                            for (var i = 0, step; step = steps[i]; i++) {
                                step.step_number = i;
                                options.step(step, (route.legs[0].steps.length - 1));
                            }
                        }
                    }

                    //end callback
                    if (e.length > 0 && options.end) {
                        options.end(e[e.length - 1]);
                    }
                }
            });
        }
        else if (options.route) {
            if (options.route.legs.length > 0) {
                var steps = options.route.legs[0].steps;
                for (var i = 0, step; step = steps[i]; i++) {
                    step.step_number = i;
                    options.step(step);
                }
            }
        }
    };

    GMaps.prototype.drawSteppedRoute = function (options) {
        var self = this;

        if (options.origin && options.destination) {
            this.getRoutes({
                origin: options.origin,
                destination: options.destination,
                travelMode: options.travelMode,
                waypoints: options.waypoints,
                error: options.error,
                callback: function (e) {
                    //start callback
                    if (e.length > 0 && options.start) {
                        options.start(e[e.length - 1]);
                    }

                    //step callback
                    if (e.length > 0 && options.step) {
                        var route = e[e.length - 1];
                        if (route.legs.length > 0) {
                            var steps = route.legs[0].steps;
                            for (var i = 0, step; step = steps[i]; i++) {
                                step.step_number = i;
                                var polyline_options = {
                                    path: step.path,
                                    strokeColor: options.strokeColor,
                                    strokeOpacity: options.strokeOpacity,
                                    strokeWeight: options.strokeWeight
                                };

                                if (options.hasOwnProperty("icons")) {
                                    polyline_options.icons = options.icons;
                                }

                                self.drawPolyline(polyline_options);
                                options.step(step, (route.legs[0].steps.length - 1));
                            }
                        }
                    }

                    //end callback
                    if (e.length > 0 && options.end) {
                        options.end(e[e.length - 1]);
                    }
                }
            });
        }
        else if (options.route) {
            if (options.route.legs.length > 0) {
                var steps = options.route.legs[0].steps;
                for (var i = 0, step; step = steps[i]; i++) {
                    step.step_number = i;
                    var polyline_options = {
                        path: step.path,
                        strokeColor: options.strokeColor,
                        strokeOpacity: options.strokeOpacity,
                        strokeWeight: options.strokeWeight
                    };

                    if (options.hasOwnProperty("icons")) {
                        polyline_options.icons = options.icons;
                    }

                    self.drawPolyline(polyline_options);
                    options.step(step);
                }
            }
        }
    };

    GMaps.Route = function (options) {
        this.origin = options.origin;
        this.destination = options.destination;
        this.waypoints = options.waypoints;

        this.map = options.map;
        this.route = options.route;
        this.step_count = 0;
        this.steps = this.route.legs[0].steps;
        this.steps_length = this.steps.length;

        var polyline_options = {
            path: new google.maps.MVCArray(),
            strokeColor: options.strokeColor,
            strokeOpacity: options.strokeOpacity,
            strokeWeight: options.strokeWeight
        };

        if (options.hasOwnProperty("icons")) {
            polyline_options.icons = options.icons;
        }

        this.polyline = this.map.drawPolyline(polyline_options).getPath();
    };

    GMaps.Route.prototype.getRoute = function (options) {
        var self = this;

        this.map.getRoutes({
            origin: this.origin,
            destination: this.destination,
            travelMode: options.travelMode,
            waypoints: this.waypoints || [],
            error: options.error,
            callback: function () {
                self.route = e[0];

                if (options.callback) {
                    options.callback.call(self);
                }
            }
        });
    };

    GMaps.Route.prototype.back = function () {
        if (this.step_count > 0) {
            this.step_count--;
            var path = this.route.legs[0].steps[this.step_count].path;

            for (var p in path) {
                if (path.hasOwnProperty(p)) {
                    this.polyline.pop();
                }
            }
        }
    };

    GMaps.Route.prototype.forward = function () {
        if (this.step_count < this.steps_length) {
            var path = this.route.legs[0].steps[this.step_count].path;

            for (var p in path) {
                if (path.hasOwnProperty(p)) {
                    this.polyline.push(path[p]);
                }
            }
            this.step_count++;
        }
    };

    GMaps.prototype.checkGeofence = function (lat, lng, fence) {
        return fence.containsLatLng(new google.maps.LatLng(lat, lng));
    };

    GMaps.prototype.checkMarkerGeofence = function (marker, outside_callback) {
        if (marker.fences) {
            for (var i = 0, fence; fence = marker.fences[i]; i++) {
                var pos = marker.getPosition();
                if (!this.checkGeofence(pos.lat(), pos.lng(), fence)) {
                    outside_callback(marker, fence);
                }
            }
        }
    };

    GMaps.prototype.toImage = function (options) {
        var options = options || {},
            static_map_options = {};

        static_map_options['size'] = options['size'] || [this.el.clientWidth, this.el.clientHeight];
        static_map_options['lat'] = this.getCenter().lat();
        static_map_options['lng'] = this.getCenter().lng();

        if (this.markers.length > 0) {
            static_map_options['markers'] = [];

            for (var i = 0; i < this.markers.length; i++) {
                static_map_options['markers'].push({
                    lat: this.markers[i].getPosition().lat(),
                    lng: this.markers[i].getPosition().lng()
                });
            }
        }

        if (this.polylines.length > 0) {
            var polyline = this.polylines[0];

            static_map_options['polyline'] = {};
            static_map_options['polyline']['path'] = google.maps.geometry.encoding.encodePath(polyline.getPath());
            static_map_options['polyline']['strokeColor'] = polyline.strokeColor
            static_map_options['polyline']['strokeOpacity'] = polyline.strokeOpacity
            static_map_options['polyline']['strokeWeight'] = polyline.strokeWeight
        }

        return GMaps.staticMapURL(static_map_options);
    };

    GMaps.staticMapURL = function (options) {
        var parameters = [],
            data,
            static_root = (location.protocol === 'file:' ? 'http:' : location.protocol) + '//maps.googleapis.com/maps/api/staticmap';

        if (options.url) {
            static_root = options.url;
            delete options.url;
        }

        static_root += '?';

        var markers = options.markers;

        delete options.markers;

        if (!markers && options.marker) {
            markers = [options.marker];
            delete options.marker;
        }

        var styles = options.styles;

        delete options.styles;

        var polyline = options.polyline;
        delete options.polyline;

        /** Map options **/
        if (options.center) {
            parameters.push('center=' + options.center);
            delete options.center;
        }
        else if (options.address) {
            parameters.push('center=' + options.address);
            delete options.address;
        }
        else if (options.lat) {
            parameters.push(['center=', options.lat, ',', options.lng].join(''));
            delete options.lat;
            delete options.lng;
        }
        else if (options.visible) {
            var visible = encodeURI(options.visible.join('|'));
            parameters.push('visible=' + visible);
        }

        var size = options.size;
        if (size) {
            if (size.join) {
                size = size.join('x');
            }
            delete options.size;
        }
        else {
            size = '630x300';
        }
        parameters.push('size=' + size);

        if (!options.zoom && options.zoom !== false) {
            options.zoom = 15;
        }

        var sensor = options.hasOwnProperty('sensor') ? !!options.sensor : true;
        delete options.sensor;
        parameters.push('sensor=' + sensor);

        for (var param in options) {
            if (options.hasOwnProperty(param)) {
                parameters.push(param + '=' + options[param]);
            }
        }

        /** Markers **/
        if (markers) {
            var marker, loc;

            for (var i = 0; data = markers[i]; i++) {
                marker = [];

                if (data.size && data.size !== 'normal') {
                    marker.push('size:' + data.size);
                    delete data.size;
                }
                else if (data.icon) {
                    marker.push('icon:' + encodeURI(data.icon));
                    delete data.icon;
                }

                if (data.color) {
                    marker.push('color:' + data.color.replace('#', '0x'));
                    delete data.color;
                }

                if (data.label) {
                    marker.push('label:' + data.label[0].toUpperCase());
                    delete data.label;
                }

                loc = (data.address ? data.address : data.lat + ',' + data.lng);
                delete data.address;
                delete data.lat;
                delete data.lng;

                for (var param in data) {
                    if (data.hasOwnProperty(param)) {
                        marker.push(param + ':' + data[param]);
                    }
                }

                if (marker.length || i === 0) {
                    marker.push(loc);
                    marker = marker.join('|');
                    parameters.push('markers=' + encodeURI(marker));
                }
                    // New marker without styles
                else {
                    marker = parameters.pop() + encodeURI('|' + loc);
                    parameters.push(marker);
                }
            }
        }

        /** Map Styles **/
        if (styles) {
            for (var i = 0; i < styles.length; i++) {
                var styleRule = [];
                if (styles[i].featureType) {
                    styleRule.push('feature:' + styles[i].featureType.toLowerCase());
                }

                if (styles[i].elementType) {
                    styleRule.push('element:' + styles[i].elementType.toLowerCase());
                }

                for (var j = 0; j < styles[i].stylers.length; j++) {
                    for (var p in styles[i].stylers[j]) {
                        var ruleArg = styles[i].stylers[j][p];
                        if (p == 'hue' || p == 'color') {
                            ruleArg = '0x' + ruleArg.substring(1);
                        }
                        styleRule.push(p + ':' + ruleArg);
                    }
                }

                var rule = styleRule.join('|');
                if (rule != '') {
                    parameters.push('style=' + rule);
                }
            }
        }

        /** Polylines **/
        function parseColor(color, opacity) {
            if (color[0] === '#') {
                color = color.replace('#', '0x');

                if (opacity) {
                    opacity = parseFloat(opacity);
                    opacity = Math.min(1, Math.max(opacity, 0));
                    if (opacity === 0) {
                        return '0x00000000';
                    }
                    opacity = (opacity * 255).toString(16);
                    if (opacity.length === 1) {
                        opacity += opacity;
                    }

                    color = color.slice(0, 8) + opacity;
                }
            }
            return color;
        }

        if (polyline) {
            data = polyline;
            polyline = [];

            if (data.strokeWeight) {
                polyline.push('weight:' + parseInt(data.strokeWeight, 10));
            }

            if (data.strokeColor) {
                var color = parseColor(data.strokeColor, data.strokeOpacity);
                polyline.push('color:' + color);
            }

            if (data.fillColor) {
                var fillcolor = parseColor(data.fillColor, data.fillOpacity);
                polyline.push('fillcolor:' + fillcolor);
            }

            var path = data.path;
            if (path.join) {
                for (var j = 0, pos; pos = path[j]; j++) {
                    polyline.push(pos.join(','));
                }
            }
            else {
                polyline.push('enc:' + path);
            }

            polyline = polyline.join('|');
            parameters.push('path=' + encodeURI(polyline));
        }

        /** Retina support **/
        var dpi = window.devicePixelRatio || 1;
        parameters.push('scale=' + dpi);

        parameters = parameters.join('&');
        return static_root + parameters;
    };

    GMaps.prototype.addMapType = function (mapTypeId, options) {
        if (options.hasOwnProperty("getTileUrl") && typeof (options["getTileUrl"]) == "function") {
            options.tileSize = options.tileSize || new google.maps.Size(256, 256);

            var mapType = new google.maps.ImageMapType(options);

            this.map.mapTypes.set(mapTypeId, mapType);
        }
        else {
            throw "'getTileUrl' function required.";
        }
    };

    GMaps.prototype.addOverlayMapType = function (options) {
        if (options.hasOwnProperty("getTile") && typeof (options["getTile"]) == "function") {
            var overlayMapTypeIndex = options.index;

            delete options.index;

            this.map.overlayMapTypes.insertAt(overlayMapTypeIndex, options);
        }
        else {
            throw "'getTile' function required.";
        }
    };

    GMaps.prototype.removeOverlayMapType = function (overlayMapTypeIndex) {
        this.map.overlayMapTypes.removeAt(overlayMapTypeIndex);
    };

    GMaps.prototype.addStyle = function (options) {
        var styledMapType = new google.maps.StyledMapType(options.styles, { name: options.styledMapName });

        this.map.mapTypes.set(options.mapTypeId, styledMapType);
    };

    GMaps.prototype.setStyle = function (mapTypeId) {
        this.map.setMapTypeId(mapTypeId);
    };

    GMaps.prototype.createPanorama = function (streetview_options) {
        if (!streetview_options.hasOwnProperty('lat') || !streetview_options.hasOwnProperty('lng')) {
            streetview_options.lat = this.getCenter().lat();
            streetview_options.lng = this.getCenter().lng();
        }

        this.panorama = GMaps.createPanorama(streetview_options);

        this.map.setStreetView(this.panorama);

        return this.panorama;
    };

    GMaps.createPanorama = function (options) {
        var el = getElementById(options.el, options.context);

        options.position = new google.maps.LatLng(options.lat, options.lng);

        delete options.el;
        delete options.context;
        delete options.lat;
        delete options.lng;

        var streetview_events = ['closeclick', 'links_changed', 'pano_changed', 'position_changed', 'pov_changed', 'resize', 'visible_changed'],
            streetview_options = extend_object({ visible: true }, options);

        for (var i = 0; i < streetview_events.length; i++) {
            delete streetview_options[streetview_events[i]];
        }

        var panorama = new google.maps.StreetViewPanorama(el, streetview_options);

        for (var i = 0; i < streetview_events.length; i++) {
            (function (object, name) {
                if (options[name]) {
                    google.maps.event.addListener(object, name, function () {
                        options[name].apply(this);
                    });
                }
            })(panorama, streetview_events[i]);
        }

        return panorama;
    };

    GMaps.prototype.on = function (event_name, handler) {
        return GMaps.on(event_name, this, handler);
    };

    GMaps.prototype.off = function (event_name) {
        GMaps.off(event_name, this);
    };

    GMaps.prototype.once = function (event_name, handler) {
        return GMaps.once(event_name, this, handler);
    };

    GMaps.custom_events = ['marker_added', 'marker_removed', 'polyline_added', 'polyline_removed', 'polygon_added', 'polygon_removed', 'geolocated', 'geolocation_failed'];

    GMaps.on = function (event_name, object, handler) {
        if (GMaps.custom_events.indexOf(event_name) == -1) {
            if (object instanceof GMaps) object = object.map;
            return google.maps.event.addListener(object, event_name, handler);
        }
        else {
            var registered_event = {
                handler: handler,
                eventName: event_name
            };

            object.registered_events[event_name] = object.registered_events[event_name] || [];
            object.registered_events[event_name].push(registered_event);

            return registered_event;
        }
    };

    GMaps.off = function (event_name, object) {
        if (GMaps.custom_events.indexOf(event_name) == -1) {
            if (object instanceof GMaps) object = object.map;
            google.maps.event.clearListeners(object, event_name);
        }
        else {
            object.registered_events[event_name] = [];
        }
    };

    GMaps.once = function (event_name, object, handler) {
        if (GMaps.custom_events.indexOf(event_name) == -1) {
            if (object instanceof GMaps) object = object.map;
            return google.maps.event.addListenerOnce(object, event_name, handler);
        }
    };

    GMaps.fire = function (event_name, object, scope) {
        if (GMaps.custom_events.indexOf(event_name) == -1) {
            google.maps.event.trigger(object, event_name, Array.prototype.slice.apply(arguments).slice(2));
        }
        else {
            if (event_name in scope.registered_events) {
                var firing_events = scope.registered_events[event_name];

                for (var i = 0; i < firing_events.length; i++) {
                    (function (handler, scope, object) {
                        handler.apply(scope, [object]);
                    })(firing_events[i]['handler'], scope, object);
                }
            }
        }
    };

    GMaps.geolocate = function (options) {
        var complete_callback = options.always || options.complete;

        if (navigator.geolocation) {
            navigator.geolocation.getCurrentPosition(function (position) {
                options.success(position);

                if (complete_callback) {
                    complete_callback();
                }
            }, function (error) {
                options.error(error);

                if (complete_callback) {
                    complete_callback();
                }
            }, options.options);
        }
        else {
            options.not_supported();

            if (complete_callback) {
                complete_callback();
            }
        }
    };

    GMaps.geocode = function (options) {
        this.geocoder = new google.maps.Geocoder();
        var callback = options.callback;
        if (options.hasOwnProperty('lat') && options.hasOwnProperty('lng')) {
            options.latLng = new google.maps.LatLng(options.lat, options.lng);
        }

        delete options.lat;
        delete options.lng;
        delete options.callback;

        this.geocoder.geocode(options, function (results, status) {
            callback(results, status);
        });
    };

    if (typeof window.google === 'object' && window.google.maps) {
        //==========================
        // Polygon containsLatLng
        // https://github.com/tparkin/Google-Maps-Point-in-Polygon
        // Poygon getBounds extension - google-maps-extensions
        // http://code.google.com/p/google-maps-extensions/source/browse/google.maps.Polygon.getBounds.js
        if (!google.maps.Polygon.prototype.getBounds) {
            google.maps.Polygon.prototype.getBounds = function (latLng) {
                var bounds = new google.maps.LatLngBounds();
                var paths = this.getPaths();
                var path;

                for (var p = 0; p < paths.getLength() ; p++) {
                    path = paths.getAt(p);
                    for (var i = 0; i < path.getLength() ; i++) {
                        bounds.extend(path.getAt(i));
                    }
                }

                return bounds;
            };
        }

        if (!google.maps.Polygon.prototype.containsLatLng) {
            // Polygon containsLatLng - method to determine if a latLng is within a polygon
            google.maps.Polygon.prototype.containsLatLng = function (latLng) {
                // Exclude points outside of bounds as there is no way they are in the poly
                var bounds = this.getBounds();

                if (bounds !== null && !bounds.contains(latLng)) {
                    return false;
                }

                // Raycast point in polygon method
                var inPoly = false;

                var numPaths = this.getPaths().getLength();
                for (var p = 0; p < numPaths; p++) {
                    var path = this.getPaths().getAt(p);
                    var numPoints = path.getLength();
                    var j = numPoints - 1;

                    for (var i = 0; i < numPoints; i++) {
                        var vertex1 = path.getAt(i);
                        var vertex2 = path.getAt(j);

                        if (vertex1.lng() < latLng.lng() && vertex2.lng() >= latLng.lng() || vertex2.lng() < latLng.lng() && vertex1.lng() >= latLng.lng()) {
                            if (vertex1.lat() + (latLng.lng() - vertex1.lng()) / (vertex2.lng() - vertex1.lng()) * (vertex2.lat() - vertex1.lat()) < latLng.lat()) {
                                inPoly = !inPoly;
                            }
                        }

                        j = i;
                    }
                }

                return inPoly;
            };
        }

        if (!google.maps.Circle.prototype.containsLatLng) {
            google.maps.Circle.prototype.containsLatLng = function (latLng) {
                if (google.maps.geometry) {
                    return google.maps.geometry.spherical.computeDistanceBetween(this.getCenter(), latLng) <= this.getRadius();
                }
                else {
                    return true;
                }
            };
        }

        google.maps.Rectangle.prototype.containsLatLng = function (latLng) {
            return this.getBounds().contains(latLng);
        };

        google.maps.LatLngBounds.prototype.containsLatLng = function (latLng) {
            return this.contains(latLng);
        };

        google.maps.Marker.prototype.setFences = function (fences) {
            this.fences = fences;
        };

        google.maps.Marker.prototype.addFence = function (fence) {
            this.fences.push(fence);
        };

        google.maps.Marker.prototype.getId = function () {
            return this['__gm_id'];
        };
    }

    //==========================
    // Array indexOf
    // https://developer.mozilla.org/en-US/docs/JavaScript/Reference/Global_Objects/Array/indexOf
    if (!Array.prototype.indexOf) {
        Array.prototype.indexOf = function (searchElement /*, fromIndex */) {
            "use strict";
            if (this == null) {
                throw new TypeError();
            }
            var t = Object(this);
            var len = t.length >>> 0;
            if (len === 0) {
                return -1;
            }
            var n = 0;
            if (arguments.length > 1) {
                n = Number(arguments[1]);
                if (n != n) { // shortcut for verifying if it's NaN
                    n = 0;
                } else if (n != 0 && n != Infinity && n != -Infinity) {
                    n = (n > 0 || -1) * Math.floor(Math.abs(n));
                }
            }
            if (n >= len) {
                return -1;
            }
            var k = n >= 0 ? n : Math.max(len - Math.abs(n), 0);
            for (; k < len; k++) {
                if (k in t && t[k] === searchElement) {
                    return k;
                }
            }
            return -1;
        }
    }

    return GMaps;
}));
;
$('document').ready(function () {
    $(".indications-container a").on("click", function () {
        var label = $(this.parentNode.parentNode).find("h3")[0].innerText.trim();
        gtmEventDataLayerOnco("navigation", "click on gateway element", label);
    });
});;
(function ($, undefined) {

    var init = function ($popup, selector) {

        var $currentLink;

        $(selector).click(function (e) {

            if ($(this).is('a')) {
                $currentLink = $(this);
                $popup.modal('show');
                e.preventDefault();
                return false;
            }
            $currentLink = null;
            return true;
        });

        $popup.find('button.js-link-disclaimer-popup-ok').click(function () {
            if ($currentLink != null) {
                $popup.modal('hide');
                proccedLinkAction($currentLink);
            }
        });

        function proccedLinkAction($link) {
            var elem = $link[0];
            if (elem.href) {
                window.open(elem.href, elem.target);
            }
            if (typeof elem.onclick == "function") {
                elem.onclick.apply(elem);
            }
        }
    };


    $(document).ready(function () {

        $('.js-link-disclaimer-popup').each(function (index, element) {
            var selector = $(element).attr('data-selector');
            init($(element), selector);
        });
    });

})(jQuery);
window.AnalyticsLog = false;

function LocationFinder($gMapLocator) {
    this.gMapLocator = $gMapLocator;
    this.initLat = this.gMapLocator.data("lat"); //default latitude for map initialization
    this.initLng = this.gMapLocator.data("lng"); //default longitude for map initialization
    this.initZoom = this.gMapLocator.data("zoom"); //default zoom
    this.blockId = this.gMapLocator.data('id');
    this.displayAllOnLoad = this.gMapLocator.data().displayOnLoad === "True";

    this.noSuggest = false;

    var proxy = this;

    var mapElement = $("#map");
    this.map = new google.maps.Map(mapElement.get(0), {
        center: {
            lat: proxy.initLat,
            lng: proxy.initLng
        },
        zoom: proxy.initZoom
    });

    var fullscreenDiv = mapElement.children("div:first");
    $("#interstitialPopUp").clone().attr('id', 'interstitialPopUpMap').appendTo(fullscreenDiv);

    var countryRestrict = {
        'country': 'us'
    };
    this.autocomplete = new google.maps.places.Autocomplete((document.getElementById('searchTerm')), {
        types: ['(regions)'],
        componentRestrictions: countryRestrict
    });

    this.autocomplete.setFields(['address_components', 'geometry', 'icon', 'name']);

    google.maps.event.addListener(proxy.autocomplete, 'place_changed', function () {

        var place = proxy.autocomplete.getPlace();

        var address = '';

        if (!place.geometry) {
            // User entered the name of a Place that was not suggested and
            // pressed the Enter key, or the Place Details request failed.
            // Do anything you like with what was entered in the ac field.            
            return;
        }

        if (place.address_components) {
            address = [
                (place.address_components[0] && place.address_components[0].short_name || ''),
                (place.address_components[1] && place.address_components[1].short_name || ''),
                (place.address_components[2] && place.address_components[2].short_name || '')
            ].join(' ');

            proxy.noSuggest = false;

            var analytics = {
                search: {
                    searchTerm: address
                },
                searchComponent: 'search using suggestions'
            }

            sendAnalytics(analytics, "search");
        }
    });

    this.currentMarker;
    this.currentGeometryObj = null;

    this.searchEventsEnabled = false;
    this.paginationEventsEnabled = false;

    this.epiData = [];
    this.markersData = []; // Episerver Markers Data
    this.markersList = []; // List of markers
    this.pinsList = []; // List of pins

    //Pagination Variables
    this.currentPage = 0;
    this.numItemsToShow = this.gMapLocator.data("items-to-show");
    this.numItemsToShowMore = this.gMapLocator.data("items-to-show-more");

    this.activeInfoWindow;

    this.enableSearchEvents();

    /**
     * Initial load
     */

    if (this.displayAllOnLoad) {
        var pos = {
            lat: this.initLat,
            lng: this.initLng
        };
        this.map.setCenter(pos);
        this.replaceCurrentMarker(this.initLat, this.initLng);
        this.findPins(this.initLat, this.initLng, this.getFilterValue());
    }
    this.geolocate();
    this.InitDisclaimer();
}

/**
 * Geolocation of user
 */
LocationFinder.prototype.geolocate = function () {

    var proxy = this;
    // Try HTML5 geolocation.
    if (navigator.geolocation) {
        navigator.geolocation.getCurrentPosition(function (position) {
            var pos = {
                lat: position.coords.latitude,
                lng: position.coords.longitude
            };
            proxy.map.setCenter(pos);
            proxy.replaceCurrentMarker(position.coords.latitude, position.coords.longitude);
            proxy.getUserZipCode();

            if (proxy.displayAllOnLoad) {
                proxy.sortMarkers();
                proxy.fitBounds(proxy);
            }
            else {
                proxy.findPins(position.coords.latitude, position.coords.longitude, proxy.getFilterValue());
                /*proxy.filter();
                proxy.InitDisclaimer($('.marker2site, .marker2map'));*/
            }

            /*proxy.removeAllPins();
            proxy.sortMarkers();
            proxy.changePage();*/

            proxy.setCenterByDefault();
        }, function (error) {
            handleLocationError(true);
            console.log(error);
            var analyticsParam = {
                search: {
                    searchTerm: $("#searchTerm").val()
                }
            }

            if (error.code == error.PERMISSION_DENIED) {
                // User block location 
                sendAnalytics(analyticsParam, 'block');
            } else {
                // User close location prompt window
                sendAnalytics(analyticsParam, 'close');
            }
        });
    } else {
        // Browser doesn't support Geolocation
        handleLocationError(false);
    }

    function handleLocationError(browserHasGeolocation) {
        (browserHasGeolocation) ? console.log('Error: The Geolocation service failed.') : console.log('Error: Your browser doesn\'t support geolocation.');
    }
}

LocationFinder.prototype.getFilterValue = function () {
    if ($('.js-filter-radio:checked').length > 0)
        return $('.js-filter-radio:checked').val();
    else
        return 'all';
}

/**
 * Get the user zipcode location
 */
LocationFinder.prototype.getUserZipCode = function () {
    var geocoder = new google.maps.Geocoder();
    geocoder.geocode({
        address: this.currentMarker.position.lat() + "," + this.currentMarker.position.lng()
    },
        function (results, status) {
            if (status == 'OK') {
                var postalCode = results[0]["address_components"].filter(function (address) {
                    return address.types[0] == "postal_code";
                });
                if (postalCode.length > 0) {
                    var postalCodeNumber = postalCode[0]["short_name"];
                    $(".centerfinder-search-text").html(postalCodeNumber);
                    $("#searchTerm").val(postalCodeNumber);

                    var analyticsParam = {
                        search: {
                            searchTerm: postalCodeNumber
                        },
                        searchComponent: 'autopopulate search'
                    }
                    sendAnalytics(analyticsParam, 'autopopulate');
                }
            }
        }
    );
}


/**
 * Set center defined by episerver
 */
LocationFinder.prototype.setCenterByDefault = function () {
    if (this.activeInfoWindow) {
        this.activeInfoWindow.close();
    }
    this.map.setCenter({
        lat: this.initLat,
        lng: this.initLng
    });
    this.map.setZoom(this.initZoom);
}

LocationFinder.prototype.findPreviewToken = function (segmentName) {
    var token = 0;
    if (window.location.pathname.includes(segmentName)) {
        var paths = window.location.pathname.split("/");
        for (var index = 0; index < paths.length; index++) {
            if (paths[index] === segmentName && index + 1 < paths.length) {
                token = paths[index + 1];
                break;
            }
        }
    }
    return token;
}
/**
 * Perform search in episerver
 */
LocationFinder.prototype.findPins = function (latitude, longitude, filter, onSuccess) {
    var proxy = this;

    // send the external review token in the request
    var token = proxy.findPreviewToken("externalcontentview");
    if (!token) {
        token = proxy.findPreviewToken("externalcontentreviews");
    }

    var urlDomain = this.format('//{0}/LocationFinderBlock/FindMarkers/{1}/{2}/{3}/{4}/{5}', window.location.hostname, this.blockId, latitude, longitude, token, filter);

    $.ajax({
        url: urlDomain,
        method: "GET",
        dataType: "json",
        //contentType: 'application/json; charset=UTF-8'
    }).done(function (data) {
        proxy.epiData = data;
        //proxy.filter();
        proxy.markersData = proxy.epiData;
        if (proxy.displayAllOnLoad) {
            proxy.sortMarkers();
        }
        proxy.removeAllPins();
        proxy.changePage();
        proxy.bindEvents();
        proxy.InitDisclaimer($('.marker2site, .marker2map'));
        if (typeof (onSuccess) === 'function') {
            onSuccess(proxy);
        }
    }).fail(function (xhr, status, errorThrown) {
        console.log("Fail I don't get any data: " + errorThrown);
        console.log("Status: " + status);

    });
}

/**
 * Initial Load
 */
LocationFinder.prototype.initLoad = function () {
    this.renderMarkersList();
    this.renderPins();
    this.bindEvents();
}

/**
 * Filter by tag value
 **/
LocationFinder.prototype.filter = function (val, skipEvents) {
    var proxy = this;

    if (typeof (val) != "undefined" && val != null && val != "") {
        var filtered = proxy.epiData.filter(function (element) {
            if (element.Tags != null && Array.isArray(element.Tags) && element.Tags.length > 0) {
                return typeof (element.Tags.find(function (tagElement) {
                    return tagElement.Code == val
                })) != 'undefined';
            }
            return false;
        });
        proxy.markersData = $.extend(true, [], filtered);
        for (var i = 0; i < proxy.markersData.length; i++) {
            proxy.markersData[i].order = (i + 1).toString();
        }

    } else {
        proxy.markersData = proxy.epiData;
    }
    if (proxy.markersData !== null) {
        this.currentPage = 0;
        if (typeof (skipEvents) == "undefined" || !skipEvents)
            proxy.initLoad();
        else {
            proxy.removeAllPins();
            proxy.changePage();
        }
    }
}

/**
 * Handle search results
 */
LocationFinder.prototype.HandleSearchResult = function (results, status) {
    var proxy = this;
    $(".centerfinder-search-text").html("");
    if (status == 'OK') {
        var result = results[0];
        var isUSResult = (result["address_components"].map(function (address, index) {
            return address["short_name"] === "US"
        }).indexOf(true) > -1);
        if (isUSResult) {
            $(".centerfinder-search-text").html($('#searchTerm').val());

            proxy.removeAllPins();

            var latlng = result.geometry.location;
            proxy.map.setCenter({
                lat: latlng.lat(),
                lng: latlng.lng()
            });
            proxy.replaceCurrentMarker(latlng.lat(), latlng.lng());

            proxy.currentPage = 0;

            var success = function (proxy) {
                if (result.geometry && result.geometry.viewport) {
                    proxy.currentGeometryObj = result.geometry;
                    proxy.fitBounds(proxy);
                }
            }

            proxy.findPins(latlng.lat(), latlng.lng(), proxy.getFilterValue(), success);

        } else {
            proxy.showError(true);
        }
    } else {
        proxy.showError(false);
    }
}

LocationFinder.prototype.fitBounds = function (proxy) {
    if (proxy.currentGeometryObj == null) return;

    var viewport = proxy.currentGeometryObj.viewport;
    var newBounds = new google.maps.LatLngBounds();

    if (typeof (proxy.markersData) !== 'undefined' && proxy.markersData.length > 0) {

        var firstPinPos = new google.maps.LatLng({
            lat: proxy.markersData[0].Latitude,
            lng: proxy.markersData[0].Longitude
        });

        var mirrorLat = proxy.currentGeometryObj.location.lat() + (proxy.currentGeometryObj.location.lat() - firstPinPos.lat());
        var mirrorLng = proxy.currentGeometryObj.location.lng() + (proxy.currentGeometryObj.location.lng() - firstPinPos.lng());
        var fakePinPos = new google.maps.LatLng({
            lat: mirrorLat,
            lng: mirrorLng
        });

        newBounds.extend(proxy.currentGeometryObj.location);
        newBounds.extend(firstPinPos);
        newBounds.extend(fakePinPos);
    } else {
        newBounds = proxy.currentGeometryObj.viewport;
    }

    proxy.map.fitBounds(newBounds);
}

/**
 * Bind eventListeners
 */
LocationFinder.prototype.bindEvents = function () {
    if (this.paginationEventsEnabled) return;
    var proxy = this;

    $('.centerfinder-showmore-button').on('click', function () {
        proxy.currentPage = proxy.currentPage + 1;
        proxy.changePage(true);
    });

    $('.js-filter-radio').on('change', function () {
        var $this = $(this);
        //proxy.filter($this.val(), true);
        var analytics = {
            selectedFilter: $this.attr("id").toLowerCase()
        };
        sendAnalytics(analytics, "centerFilter");
        proxy.findPins(proxy.currentMarker.position.lat(), proxy.currentMarker.position.lng(), $this.val(), proxy.fitBounds);
    });

    this.paginationEventsEnabled = true;
}

LocationFinder.prototype.enableSearchEvents = function () {
    if (this.searchEventsEnabled) return;

    var proxy = this;
    /* Search  */
    $('#searchTerm').keydown(function (e) {
        var key = e.which;

        if (key === 13) {
            e.preventDefault();
            $(this).blur();

            // Send Analytics on using Enter key
            proxy.noSuggest = true;

            setTimeout(function () {
                if (proxy.noSuggest) {
                    var analytics = {
                        search: {
                            searchTerm: $('#searchTerm').val()
                        },
                        searchComponent: 'search using enter key'
                    };
                    sendAnalytics(analytics, 'search');
                }
            }, 1000);



            var geocoder = new google.maps.Geocoder();
            geocoder.geocode({
                address: $('#searchTerm').val()
            },
                function (results, status) {
                    proxy.HandleSearchResult(results, status)
                }
            );
        }

        if ($(this).val() != '') {
            $(this).next('.clean-input').show();
        } else {
            $(this).next('.clean-input').hide();
        }
    });

    /* When user focus on search text */
    $(".centerfinder-input").focus(function () {
        $(this).removeClass("error");
        $(".centerfinder-search-error").removeClass("error");
    });

    /* When user click to find marker */
    $('.centerfinder-btn-search').on('click', function (e) {
        e.preventDefault();
        var geocoder = new google.maps.Geocoder();
        geocoder.geocode({
            address: $('#searchTerm').val()
        },
            function (results, status) {
                proxy.HandleSearchResult(results, status)
            }
        );

        var analytics = {
            search: {
                searchTerm: $('#searchTerm').val()
            },
            searchComponent: 'search button clicked'
        };

        sendAnalytics(analytics, 'search');
    });

    $('.centerfinder-input-field .clean-input').on('click', function () {
        $('#searchTerm').val('');
        $(this).hide();
    });

    /* Google autocomplete */
    var autocomplete_OnPlaceChangedHandler = function () {
        var place = proxy.autocomplete.getPlace();
        if (place.address_components != null && Array.isArray(place.address_components) && place.address_components.length > 0) {
            proxy.HandleSearchResult([place], "OK");
        }
    };

    proxy.autocomplete.addListener('place_changed', autocomplete_OnPlaceChangedHandler);

    this.searchEventsEnabled = true;
}

/**
 * string format function
 **/
LocationFinder.prototype.format = function (str) {
    for (var k in arguments) {
        if (k > 0) {
            str = str.replace("{" + (k - 1) + "}", arguments[k]);
        }
    }
    return str;
}

/**
 * Placeholder for Search text
 */
LocationFinder.prototype.updateErrorPlaceholder = function (errorText, searchTerm) {
    var $errorElement = $('.centerfinder-search-error');

    errorText = this.format(errorText, '<b>' + searchTerm.trim() + '</b>');
    $errorElement.html(errorText);
}

/**
 * Show Error under search
 * @param boolean is place found outside US
 */
LocationFinder.prototype.showError = function (outsideUS) {
    this.setCenterByDefault();

    var text = "";
    var $errorElement = $('.centerfinder-search-error');

    if (outsideUS) {
        text = $errorElement.data('error-outside');
    } else {
        text = $errorElement.data('error');
    }
    this.updateErrorPlaceholder(text, $('#searchTerm').val());

    $(".centerfinder-search").addClass("error");
    $errorElement.addClass("error");
}

/**
 * Change the page
 */
LocationFinder.prototype.changePage = function (addMarkers) {
    this.renderMarkersList(addMarkers);
    this.renderPins();
}

/**
 * Refresh pins
 */
LocationFinder.prototype.refreshPins = function () {
    this.removeAllPins();
    this.renderPins();
}


/**
 * Add current Marker
 */
LocationFinder.prototype.replaceCurrentMarker = function (latitude, longitude) {
    var proxy = this;
    if (this.currentMarker && this.currentMarker.getMap() != null) {
        this.currentMarker.setMap(null);
    }
    this.currentMarker = new google.maps.Marker({
        position: {
            lat: latitude,
            lng: longitude
        },
        map: proxy.map
    });

};

/**
 * Added InfoWindow 
 */
LocationFinder.prototype.afterAddInfo = function (marker) {

    $(".centerfinder-marker-search-item").removeClass("active").find(".active").removeClass("active");
    var markerItem = $(".marker-item-" + marker.order);
    markerItem.find(".centerfinder-location-number").addClass("active");
    markerItem.addClass("active");
}

/**
 * Render Pin
 */
LocationFinder.prototype.addPin = function (marker, InfoViewContent) {
    var proxy = this;

    var markerFontSize = marker.order.length > 2 ? "9px" : "12px";

    var infowindow = new google.maps.InfoWindow({
        content: '<div class="markerWI">' + InfoViewContent + '</div>',
        domready: function () {
            proxy.afterAddInfo(marker);
        },
        closeclick: function () {
            $(".centerfinder-marker-search-item").find(".active").removeClass("active");
        }
    });

    var marker = new google.maps.Marker({
        position: {
            lat: marker.Latitude,
            lng: marker.Longitude,
        },
        map: proxy.map,
        title: marker.Center.replace("<br>", " "),
        label: {
            text: marker.order,
            color: "white",
            fontSize: markerFontSize
        },
    });


    marker.addListener('click', function () {
        if (proxy.activeInfoWindow) {
            proxy.activeInfoWindow.close();
        }

        google.maps.event.addListener(infowindow, 'domready', proxy.InfoWindowDOMReadyHandler);
        infowindow.open(proxy.map, marker);

        proxy.activeInfoWindow = infowindow;

        var analytics = {
            bubbleInfo: {
                'location': marker.title
            },
            searchComponent: 'bubble'
        }
        sendAnalytics(analytics, "bubble");
    });


    return {
        marker: marker,
        infoWindow: infowindow
    };
};

/**
 * Focus pin
 */
LocationFinder.prototype.focusPin = function (marker) {

    this.refreshPins();
    this.map.setZoom(14);

    var position = {
        lat: marker.Latitude,
        lng: marker.Longitude
    }

    var pin = this.pinsList[marker.order - 1];

    if (this.activeInfoWindow) {
        this.activeInfoWindow.close();
    }

    google.maps.event.addListener(pin.infoWindow, 'domready', this.InfoWindowDOMReadyHandler);
    pin.infoWindow.open(this.map, pin.marker);

    this.activeInfoWindow = pin.infoWindow;

    this.map.panTo(position);

    // Analytics
    var analytics = {
        bubbleInfo: {
            'location': marker.Center
        },
        searchComponent: 'left navigation'
    }
    sendAnalytics(analytics, "bubble");
};

LocationFinder.prototype.InfoWindowDOMReadyHandler = function () {
    try {
        interstitialSetupExternalLinks($('.marker2site, .marker2map'));
    } catch (error) { }
};

LocationFinder.prototype.InitDisclaimer = function ($anchors) {
    try {
        interstitialSetupExternalLinks($anchors);
    } catch (error) { }
};


/**
 * Remove pin from map
 */
LocationFinder.prototype.removeMarker = function (marker) {
    marker.setMap(null);
}


/**
 * Remove all markers
 */
LocationFinder.prototype.removeAllPins = function () {
    this.pinsList.forEach(function (pin) {
        pin.marker.setMap(null);
    });

    this.pinsList = [];
}

/**
 * Sort markers 
 */
LocationFinder.prototype.sortMarkers = function () {
    if (this.markersData != null) {
        var proxy = this;
        this.markersData.forEach(function (marker, index) {
            var distance = proxy.getDistanceFromLatLonInMiles(marker.Latitude, marker.Longitude);
            marker.Distance = distance;
            marker.distanceFromCurrent = (distance).toFixed(2);
        });

        this.markersData.sort(proxy.sortByDistance);

        this.markersData.forEach(function (marker, index) {
            proxy.markersData[index].order = (index + 1).toString();
        });
    }
}


/**
 * Render Markers List Sidebar
 */
LocationFinder.prototype.renderMarkersList = function (addMarkers) {
    var proxy = this;

    if (this.markersData != null) {
        $(".centerfinder-result-search-count").html(this.markersData.length);
    }
    else {
        $(".centerfinder-result-search-count").html("0");
    }

    if (typeof (addMarkers) == "undefined" || !addMarkers) {
        $(".centerfinder-markers").html("");
    }


    if (proxy.markersData == null || proxy.markersData.length == 0) return;

    var startMarkerNum = proxy.currentPage == 0 ? 0 : proxy.numItemsToShow + ((proxy.currentPage - 1) * proxy.numItemsToShowMore);
    var endMarkerNum = startMarkerNum + (proxy.currentPage == 0 ? proxy.numItemsToShow : proxy.numItemsToShowMore);
    // Do the pagination in markersInfo
    $.map(
        proxy.markersData.slice(startMarkerNum, endMarkerNum),
        function (marker, index) {

            var website;

            marker.Center = marker.Center ? marker.Center : "";
            marker.Address = marker.Address ? marker.Address : "";
            marker.City = marker.City ? marker.City : "";
            marker.State = marker.State ? marker.State : "";
            marker.ZIP = marker.ZIP ? marker.ZIP : "";
            marker.ContactPerson = marker.ContactPerson ? marker.ContactPerson : "";
            marker.PhoneNumber = marker.PhoneNumber ? marker.PhoneNumber : "";
            marker.PhoneNumber2 = marker.PhoneNumber2 ? marker.PhoneNumber2 : "";
            marker.PhoneNumberPrefix = marker.PhoneNumberPrefix ? marker.PhoneNumberPrefix + ' ' : "";
            marker.PhoneNumber2Prefix = marker.PhoneNumber2Prefix ? marker.PhoneNumber2Prefix + ' ' : "";
            marker.Website = marker.Website ? marker.Website : "";
            marker.CertificationStatus = marker.CertificationStatus ? marker.CertificationStatus : "";
            marker.Tags = marker.Tags ? marker.Tags : [];
            website = marker.Website ? "Website" : "";

            var markerSpanClass = marker.order.length > 2 ? "small" : "normal";

            var item = '<div class="centerfinder-marker-search-item marker-item-' + marker.order + '" data-order=' + marker.order + ' data-lat=' + marker.Latitude + ' data-lng=' + marker.Longitude + '>';
            item += '<div class="col-lg-12 col-md-12 col-sm-12 col-xs-12 centerfinder-marker-item">';
            item += '<div class="centerfinder-location-number"><span class="' + markerSpanClass + '">' + marker.order + '</span></div>';
            item += '<ul><li class="marker-title">' + marker.Center + '</li>';
            item += '<li class="visible-xs address">' + marker.Address + '</li>';
            item += '<li class="visible-xs address">' + marker.City + ' ' + marker.State + ' ' + marker.ZIP + '</li>';
            item += '<li class="visible-xs address">' + marker.ContactPerson + '</li>';
            item += '<li class="visible-xs phone">' + marker.PhoneNumberPrefix + '<a class="brandColor primary-brand-color" href="tel:' + marker.PhoneNumber + '">' + marker.PhoneNumber + '</a></li>';
            item += '<li class="visible-xs">' + marker.PhoneNumber2Prefix + '<a class="primary-brand-color" href="tel:' + marker.PhoneNumber2 + '">' + marker.PhoneNumber2 + '</a></li>';
            item += '<li><span class="certified">' + marker.CertificationStatus + '</span></li>';
            item += marker.Tags.length == 0 ? '' : '<li class="center-type">' + marker.Tags.map(function (tag) {
                return tag.ImageUrl == null ? '<span>' + tag.Abbreviation + '</span>' : '<img class="center-type" src=' + tag.ImageUrl + ' />'
            }).join('') + '</li>';

            var googleDirectionUrl = proxy.format("https://www.google.com/maps/dir/'{0},{1}'/'{2},{3}'/", proxy.currentMarker.position.lat(), proxy.currentMarker.position.lng(), marker.Latitude, marker.Longitude);

            item += '<li class="visible-xs hidden-item directions marker-item-' + marker.order + '"><a href="' + googleDirectionUrl + '" class="marker2map brandBackColor primary-brand-color-bg primary-brand-color-bg-hover " data-target="#interstitialPopUp" data-lat="' + marker.Latitude + '" data-order=' + marker.order + ' data-lng="' + marker.Longitude + '" target="_blank" >Get Directions</a></li>';
            if (marker.Website != "") {
                item += '<li class="visible-xs website"><a class="marker2site brandBackColor primary-brand-color-bg primary-brand-color-bg-hover" href="' + marker.Website + '" data-target="#interstitialPopUp" target="_blank" >' + website + '</a></li>';
            }
            item += '<li class="distance">' + marker.distanceFromCurrent + ' miles</li></ul></div></div>';

            item = $(item);

            item.appendTo(".centerfinder-markers");

            item.on('click', function () {
                proxy.focusPin(marker);
            });

            proxy.markersList.push(item);

        }).join('');

}


/**
 * Render Pins on Map
 */
LocationFinder.prototype.renderPins = function () {

    if (this.markersData == null) return;

    var proxy = this;

    this.markersData.forEach(function (marker, index) {

        var InfoViewContent = "";
        var website;
        var pin;

        //check what need to be in infoWindow ( 1. separated data like, title, city etc. 2. XhtmlContent in one variable
        if (!marker.XhtmlContent) {

            marker.Center = marker.Center ? marker.Center : "";
            marker.Address = marker.Address ? marker.Address : "";
            marker.City = marker.City ? marker.City : "";
            marker.State = marker.State ? marker.State : "";
            marker.ZIP = marker.ZIP ? marker.ZIP : "";
            marker.ContactPerson = marker.ContactPerson ? marker.ContactPerson : "";
            marker.PhoneNumber = marker.PhoneNumber ? marker.PhoneNumber : "";
            marker.PhoneNumber2 = marker.PhoneNumber2 ? marker.PhoneNumber2 : "";
            marker.PhoneNumberPrefix = marker.PhoneNumberPrefix ? marker.PhoneNumberPrefix + ' ' : "";
            marker.PhoneNumber2Prefix = marker.PhoneNumber2Prefix ? marker.PhoneNumber2Prefix + ' ' : "";
            marker.Website = marker.Website ? marker.Website : "";
            marker.CertificationStatus = marker.CertificationStatus ? marker.CertificationStatus : "";
            marker.Tags = marker.Tags ? marker.Tags : [];
            website = marker.Website ? "Website" : "";

            InfoViewContent += '<div class="markerWItitleLabel">' + marker.Center + '</div>';
            InfoViewContent += '<div class="address">';
            InfoViewContent += '<div class="markerWIAddress">' + marker.Address + '</div>';
            InfoViewContent += '<div class="markerWICity">' + marker.City + ' ' + marker.State + ' ' + marker.ZIP + '</div>';
            InfoViewContent += '</div>';
            InfoViewContent += '<div class="contact">';
            InfoViewContent += '<div class="markerWIContact">' + marker.ContactPerson + '</div>';
            InfoViewContent += '<div class="markerWIPhone">' + marker.PhoneNumberPrefix + marker.PhoneNumber + '</div>';
            InfoViewContent += '<div class="markerWIPhone">' + marker.PhoneNumber2Prefix + marker.PhoneNumber2 + '</div>';
            InfoViewContent += '</div>';
            InfoViewContent += '<div class="markerWICertificationStatus">' + marker.CertificationStatus + '</div>';
            InfoViewContent += marker.Tags.length == 0 ? '' : '<div class="markerWICenterType">' + marker.Tags.map(function (tag) {
                return tag.ImageUrl == null ? '<span>' + tag.Abbreviation + '</span>' : '<img class="center-type"  src=' + tag.ImageUrl + ' />'
            }).join('') + '</div>';

            var googleDirectionUrl = proxy.format("https://www.google.com/maps/dir/'{0},{1}'/'{2},{3}'/", proxy.currentMarker.position.lat(), proxy.currentMarker.position.lng(), marker.Latitude, marker.Longitude);

            InfoViewContent += '<div class="markerWIDirections"><a class="marker2map brandBackColor primary-brand-color-bg primary-brand-color-bg-hover " href="' + googleDirectionUrl + '" data-target="#interstitialPopUpMap" target="_blank">Get Directions</a></div>';
            if (marker.Website != "") {
                InfoViewContent += '<div class="markerWIWebsite"><a class="marker2site brandBackColor primary-brand-color-bg primary-brand-color-bg-hover " href="' + marker.Website + '" data-target="#interstitialPopUpMap" target="_blank">' + website + '</a></div>';
            }
            InfoViewContent += '<div class="markerWIDistance"><span>' + marker.distanceFromCurrent + '</span> miles</div>';

            pin = proxy.addPin(marker, InfoViewContent);
        } else {
            pin = proxy.addPin(marker, marker.XhtmlContent);
        }
        proxy.pinsList.push(pin);

    }); // end foreach
}

/**
 * Get distance from current location and specific marker
 */
LocationFinder.prototype.getDistanceFromLatLonInMiles = function (lat2, lon2) {

    function deg2rad(deg) {
        return deg * (Math.PI / 180)
    }

    var lat1, lon1;
    if (this.currentMarker !== undefined) {
        lat1 = this.currentMarker.position.lat();
        lon1 = this.currentMarker.position.lng();
    }
    var R = 6371; // Radius of the earth in km
    var dLat = deg2rad(lat2 - lat1); // deg2rad below
    var dLon = deg2rad(lon2 - lon1);
    var a =
        Math.sin(dLat / 2) * Math.sin(dLat / 2) +
        Math.cos(deg2rad(lat1)) * Math.cos(deg2rad(lat2)) *
        Math.sin(dLon / 2) * Math.sin(dLon / 2);
    var c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a));
    var d = (R * c) * 0.621371192; // Distance in miles
    return d;
}


/**
 * Sort by closest distance
 */
LocationFinder.prototype.sortByDistance = function (a, b) {
    var aDistance = parseFloat(a.Distance);
    var bDistance = parseFloat(b.Distance);
    return aDistance - bDistance;
}

/**
 * Capture Analytics
 */
LocationFinder.prototype.captureSearchTerm = function (term) {

}


/**
 * Send Analytics event
 */
function sendAnalytics(param, track) {
    if (AnalyticsLog) {
        console.log('Send Analytics: ', param, track);
    }
    try {
        if (typeof (dataLayer) !== "undefined") {
            // Merge dataLayer with new parameters;
            for (var attrname in param) {
                dataLayer[attrname] = param[attrname];
            }
        }
    } catch (error) {
        console.log('Analytics failed: ' + error);
    }

    /*GTM Onco tracking*/
    try {
        if (typeof (dataLayerOnco) !== "undefined") {
            switch (track) {
                case "close":
                    sendGtmEventDataLayerOnco("locations", "click on allow autopulated search", param.search.searchTerm);
                    break;
                case "block":
                    sendGtmEventDataLayerOnco("locations", "click on block autopulated search", param.search.searchTerm);
                    break;
                case "autopopulate":
                    sendGtmEventDataLayerOnco("locations", "click on allow autopulated search", param.search.searchTerm);
                    break;
                case "search":
                    if (param.searchComponent == "search button clicked") {
                        sendGtmEventDataLayerOnco("locations", "click on search button", param.search.searchTerm);
                    }
                    else if (param.searchComponent == "search using suggestions") {
                        sendGtmEventDataLayerOnco("locations", "click on suggestion search", param.search.searchTerm);
                    }
                    else {
                        sendGtmEventDataLayerOnco("locations", param.searchComponent, param.search.searchTerm);
                    }
                    break;
                case "bubble":
                    if (param.searchComponent == "left navigation") {
                        sendGtmEventDataLayerOnco("locations", "click on a result from left navigation", param.bubbleInfo.location);
                    }
                    else if (param.searchComponent == "bubble") {
                        sendGtmEventDataLayerOnco("locations", "select a pin on map", param.bubbleInfo.location);
                    }

                    break;
                case "centerFilter":
                    sendGtmEventDataLayerOnco("locations", "click on treatment center type", param.selectedFilter);
                    break;
            }
        }
    } catch (error) {
        console.log('Analytics failed: ' + error);
    }
}
/*GTM Onco tracking function*/
function sendGtmEventDataLayerOnco(category, action, label) {
    if (typeof (dataLayerOnco) !== "undefined") {
        dataLayerOnco.push({
            'event': 'gtm_event',
            'eventInfo': {
                'category': category ? category : "",
                'action': action ? action : "",
                'label': label ? label : ""
            }
        });
    }
}

$(document).ready(function () {
    var locator = $('.google-map-locator-v2');
    if (locator.length > 0) {
        var centerFinder = new LocationFinder(locator);
    }


});;
/**
 * Modal window
 */
function MosaicModal(container, tiles) {
  var proxy = this;
  this.modal = $(container).find('.modal');
  this.tiles = tiles;
  this.body = this.modal.find('.swipe-wrapper');
  this.curIndex = 0;
  this.buttonNext = this.modal.find('.btn-next');
  this.buttonPrev = this.modal.find('.btn-prev');
  this.story = null;
  this.animation = false;
  this.player = null;

  this.modal.prependTo('body');

  this.buttonNext.on('click', function () {
    proxy.showNextStory();
  });

  this.buttonPrev.on('click', function () {    
    proxy.showPrevStory();    
  });

  this.modal.on('hide.bs.modal', function () {    
    proxy.clearContent();
  });

  this.modal.swipe({
    swipe: function (event, direction) {
     // if (!proxy.animation) {
        proxy.swipeContent(direction);
      //}
    },
    allowPageScroll: 'vertical',
    fallbackToMouseEvents: false
  });
}

MosaicModal.prototype.clearContent = function () {
  if (this.story) {
    var $video = this.story.find('.block-video');
    var targetId = $video.attr('data-targetid');
    kWidget.destroy(targetId);    
  }
  this.body.empty();
}

MosaicModal.prototype.showTileStory = function (card) {
  var proxy = this;

  this.clearContent();

  var i = 0;
  do {
    if (this.tiles[i].id == card.id) {
      this.curIndex = i;
      i = this.tiles.length;
    }
    i++;
  } while (i < this.tiles.length);

  this.story = $(card).find('.grid-story').clone(true);
  this.story.appendTo(this.body);
  this.modal.modal('show');

  this.modal.on('shown.bs.modal', function () {
    proxy.body.css('height', proxy.story.height() + 'px');
  });

  this.bindImageSlider();
}

MosaicModal.prototype.bindImageSlider = function () {
  var blocks = this.body.find('.grid-story-media > div > div');
  var container = this.body.find('.grid-story-media > div').addClass('wrapper');
  var proxy = this;

  var videoBlock = blocks.find('.video-content-block');

  if (videoBlock.length > 0) {
    this.playVideo(function () {
      videoBlock.find('.thumbnail').hide();
    });
  } 

  blocks.each(function () {
    var block = $(this);
    block.on('click touchend', function () {

      var blocks = proxy.body.find('.grid-story-media > div > div');
      if (blocks.index(block) == 2) {
        blocks.eq(0).appendTo(container);
        videoBlock.find('.thumbnail').show();
      }
      block.prependTo(container);

      // Video thumbnail show hide on slide
      if (block.find(videoBlock).length > 0) {
        videoBlock.find('.thumbnail').hide();
        proxy.playVideo();
      } else {
        if (proxy.player != null) {
          proxy.player.sendNotification('doPause');
        }
        videoBlock.find('.thumbnail').show();
      }
    });
  })
}

MosaicModal.prototype.showNextStory = function () {  
  this.curIndex++;
  if (this.curIndex == this.tiles.length) {
    this.curIndex = 0;
  }

  this.clearContent();
  this.story = this.tiles.eq(this.curIndex).find('.grid-story').clone(true)
  this.story.appendTo(this.body);
  this.bindImageSlider();
  this.body.css('height', this.story.height() + 'px');
  this.modal.animate({
    scrollTop: 0
  }, 'slow');
}

MosaicModal.prototype.showPrevStory = function () {  
  this.curIndex--;
  if (this.curIndex < 0) {
    this.curIndex = this.tiles.length - 1;
  }
  this.clearContent();
  this.story = this.tiles.eq(this.curIndex).find('.grid-story').clone().appendTo(this.body);
  this.bindImageSlider();
  this.body.css('height', this.story.height() + 'px');
  this.modal.animate({
    scrollTop: 0
  }, 'slow');
}

MosaicModal.prototype.playVideo = function (callback) {
  var $video = this.story.find('.block-video');
  var targetId = $video.attr('data-targetid');
  var wid = $video.attr('data-wid');
  var playerId = $video.attr('data-playerId');
  var partnerId = $video.attr('data-partnerId');
  var uiconfId = $video.attr('data-uiconfId');
  var entryId = $video.attr('data-entryId');
  var brandThemeCss = $video.attr('data-brandtheme') || "";
  var kalturaCss = $video.attr('data-kalturacss') || "";
  var thumbnailUrl = $video.attr('data-thumbnailurl') || "";

  var proxy = this;

  kWidget.embed({
    'targetId': targetId,
    'wid': wid,
    'player_id': playerId,
    'partner_id': partnerId,
    'uiconf_id': uiconfId,
    'entry_id': entryId,
    'flashvars': {
      'autoPlay': false,
      'loop': false,
      'thumbnailUrl': thumbnailUrl,
      'showControls': true,
      'showTitle': false,
      'streamerType': 'auto',
      'IframeCustomPluginCss1': brandThemeCss,
      'IframeCustomPluginCss2': kalturaCss,
      "EmbedPlayer.EnableIpadHTMLControls": false,

      'loadingSpinner': {
        'plugin': false
      }
    },
    'readyCallback': function (playerId) {
      proxy.player = document.getElementById(playerId);
      if (typeof callback != 'undefined') {
        callback();
      }      
    }
  });
}

MosaicModal.prototype.swipeContent = function (direction) {
  this.animation = true;

  var proxy = this;
  var nextStory;

  switch (direction) {
    case 'left':
      {
        // next
        this.curIndex++;
        if (this.curIndex == this.tiles.length) {
          this.curIndex = 0;
        }

        nextStory = this.tiles.eq(this.curIndex).find('.grid-story').clone().addClass('next').appendTo(this.body);

        this.story.addClass('prev');

        setTimeout(function () {
          nextStory.removeClass('next');
        }, 100);

        setTimeout(function () {
          proxy.story.remove();
          //proxy.clearContent();
          proxy.story = nextStory;
          proxy.bindImageSlider();
          proxy.body.css('height', proxy.story.height() + 'px');
          proxy.animation = false;
        }, 500);

        break;
      }
    case 'right':
      {
        // prev
        this.curIndex--;
        if (this.curIndex < 0) {
          this.curIndex = this.tiles.length - 1;
        }

        nextStory = this.tiles.eq(this.curIndex).find('.grid-story').clone().addClass('prev').appendTo(this.body);

        this.story.addClass('next');

        setTimeout(function () {
          nextStory.removeClass('prev');
        }, 100);

        setTimeout(function () {
          proxy.story.remove();
          //proxy.clearContent();
          proxy.story = nextStory;
          proxy.bindImageSlider();
          proxy.body.css('height', proxy.story.height() + 'px');
          proxy.animation = false;          
        }, 500);

        break;
      }
  }
};
if (!Array.prototype.fill) {
  Object.defineProperty(Array.prototype, 'fill', {
    value: function (value) {

      // Steps 1-2.
      if (this == null) {
        throw new TypeError('this is null or not defined');
      }

      var O = Object(this);

      // Steps 3-5.
      var len = O.length >>> 0;

      // Steps 6-7.
      var start = arguments[1];
      var relativeStart = start >> 0;

      // Step 8.
      var k = relativeStart < 0 ?
        Math.max(len + relativeStart, 0) :
        Math.min(relativeStart, len);

      // Steps 9-10.
      var end = arguments[2];
      var relativeEnd = end === undefined ?
        len : end >> 0;

      // Step 11.
      var final = relativeEnd < 0 ?
        Math.max(len + relativeEnd, 0) :
        Math.min(relativeEnd, len);

      // Step 12.
      while (k < final) {
        O[k] = value;
        k++;
      }

      // Step 13.
      return O;
    }
  });
}

(function ($) {
  $.fn.pop = function () {
    var top = this.get(-1);
    this.splice(this.length - 1, 1);
    return top;
  };

  $.fn.shift = function () {
    var bottom = this.get(0);
    this.splice(0, 1);
    return bottom;
  };
})(jQuery);

function Tiles(settings, gridTiles, allTiles) {
  this.tile = document.querySelector('.dummyBox');
  this.grid = [];
  this.cards = [];
  this.curSettings = settings;
  this.draw();

  return this.cards;
  
}

Tiles.prototype.draw = function () {
  this.createShadowGrid();
  this.uiPrepare();

  // Fill big cards 
  this.fillCards(this.curSettings.numberOfBig, {
    row: 4,
    col: 4
  });

  // Fill medium cards
  this.fillCards(this.curSettings.nubmerOfMedium, {
    row: 2,
    col: 2
  });

  this.createRemainingCards(this.cards);
 // this.fillTilesWithBlocks();
}

Tiles.prototype.createShadowGrid = function () {
  this.grid = new Array(this.curSettings.rows);

  for (var i = 0; i < this.curSettings.rows; i++) {
    this.grid[i] = new Array(this.curSettings.cols);
    this.grid[i].fill(0);
  }
}

Tiles.prototype.uiPrepare = function () {
  this.fillShadowGrid(this.curSettings.head.position, this.curSettings.head.size);
  this.fillShadowGrid(this.curSettings.subhead.position, this.curSettings.subhead.size);
  this.fillShadowGrid(this.curSettings.controls.position, this.curSettings.controls.size);
}

Tiles.prototype.getRandomInt = function (min, max) {
  return Math.floor(Math.random() * Math.floor(max));
}

Tiles.prototype.getFreeCoords = function () {
  var randomRow;
  var randomCol;
  var attempt = 0;
  do {
    randomRow = this.getRandomInt(0, this.curSettings.rows);
    randomCol = this.getRandomInt(0, this.curSettings.cols);
    attempt++;
  }
  while (this.grid[randomRow][randomCol] != 0 && attempt < 100);

  return {
    row: randomRow,
    col: randomCol
  }
}

Tiles.prototype.isPlaceAvaiable = function (coords, size) {
  // check if we can put needed size in tile
  var avaiable = true;
  // check if out of grid size
  if (coords.row + size.row <= this.curSettings.rows && coords.col + size.col <= this.curSettings.cols) {
    if (coords.row % 2 == 0 && coords.col % 2 == 0) {
      for (var i = coords.row; i < coords.row + size.row; i++) {
        for (var j = coords.col; j < coords.col + size.col; j++) {
          if (this.grid[i][j] > 0) {
            avaiable = false;
          }
        }
      }
    } else {
      avaiable = false;
    }
  } else {
    avaiable = false;
  }
  return avaiable;
}

Tiles.prototype.fillShadowGrid = function (coords, size) {
  for (var i = coords.row; i < coords.row + size.row; i++) {
    for (var j = coords.col; j < coords.col + size.col; j++) {
      this.grid[i][j] = 1;
    }
  }
}

Tiles.prototype.fillCards = function (number, size) {
  for (var i = 0; i < number; i++) {
    var tileCoords;
    var procceed = false;
    var attempt = 0;

    do {
      tileCoords = this.getFreeCoords();

      if (this.isPlaceAvaiable(tileCoords, size)) {
        this.fillShadowGrid(tileCoords, size);
        this.createCard(tileCoords, size);
        procceed = false;
      } else {
        procceed = true;
      }
      attempt++;
    } while (procceed && attempt < 100);
  }
}

Tiles.prototype.createCard = function (coords, size, block) {
  this.cards.push({
    coords: coords,
    size: size,
    className: (size.row == 4) ? 'big' : 'medium'
  })
}

Tiles.prototype.createRemainingCards = function (cards) {
  for (var i = 0; i < this.curSettings.rows; i++) {
    for (var j = 0; j < this.curSettings.cols; j++) {
      if (this.grid[i][j] == 0) {
        cards.push({
          coords: {
            row: i,
            col: j
          },
          size: {
            row: 1,
            col: 1
          },
          className: 'small'
        });
      }
    }
  }
}

Tiles.prototype.fillTilesWithBlocks = function () {
  var iterator = 0;
  for (var i = 0; i < this.cards.length; i++) {
    if (typeof this.tiles[i] !== 'undefined') {
      this.cards[i].block = this.tiles[i];
      this.cards[i].number = i;
      this.cards[i].id = this.tiles[i].id;
    }/*  else {
      // If list of stories is ended
      this.cards[i].block = this.allTiles[iterator].cloneNode(true); 
      this.cards[i].id = this.allTiles[iterator].id;
      this.cards[i].number = 10000;      
      this.cards[i].block.classList.remove('big');
      this.cards[i].block.classList.remove('medium');
      this.cards[i].block.classList.add('small');
      this.cards[i].block.classList.add('fake');
      iterator++;
    } */
  }
}


Tiles.prototype.splitTilesBySlides = function () {

  var numberOfSlides = Math.ceil(this.tiles.length / this.curSettings.numberOfAllTiles);

  var bigTiles = this.tiles.filter(function (index, item) {
    return item.dataset.size === "big";
  });
  var mediumTiles = this.tiles.filter(function (index, item) {
    return item.dataset.size === "medium";
  });

  var smallTiles = this.tiles.filter(function (index, item) {
    return item.dataset.size === "small";
  });

  var tilesGroupBySlides = [];
  var tileGroup = [];

  for (var i = 0; i < numberOfSlides; i++) {
    // fill slide with tiles needed size
    var tileGroup = [];
    var tilesNumber = this.curSettings.numberOfAllTiles;

    for (var b = 0; b < this.curSettings.numberOfBig; b++) {
      /*  if (bigTiles.length == 0) {
         tileGroup.push(false);
       } else { */
      tileGroup.push(bigTiles.pop());
      //}
      tilesNumber--;
    }

    for (var m = 0; m < this.curSettings.nubmerOfMedium; m++) {
      /*  if (mediumTiles.length == 0) {
         tileGroup.push(false)
       } else { */
      tileGroup.push(mediumTiles.pop());
      //}
      tilesNumber--;
    }

    // fill other tiles with small
    for (var s = 0; s < tilesNumber; s++) {
      /*  if (smallTiles.length == 0) {
         tileGroup.push(false)
       } else { */
      tileGroup.push(smallTiles.pop());
      //}
    }

    tilesGroupBySlides.push(tileGroup);
  }

  //tilesGroupBySlides = this.fillEmptySlots(tilesGroupBySlides, bigTiles, mediumTiles, smallTiles);

  return tilesGroupBySlides;
}


;
function Mosaic(element) {
  this.heading = element.querySelector('.heading');
  this.subheading = element.querySelector('.subheading');
  this.container = element.querySelector('.grid');
  this.dummyBox = element.querySelector('.dummyBox')
  this.controls = {
    prev: element.querySelector('.control.prev'),
    next: element.querySelector('.control.next')
  }
  this.slides = [];
  this.curSlide = 0;
  this.isAnimated = false;
  this.tiles = $(this.container).find('.grid-tile');
  this.modal = new MosaicModal(element, this.tiles);
  this.sortedTiles = [];

  this.colors = {
    heading: "",
    subheading: ""
  }

  this.settings = {
    phones: {
      rows: 40,
      cols: 8,
      numberOfAllTiles: 180,
      numberOfBig: 7,
      nubmerOfMedium: 27,
      numberOfSmallTiles: 144,
      head: {
        position: {
          row: 2,
          col: 0
        },
        size: {
          row: 4,
          col: 6
        }
      },
      subhead: {
        position: {
          row: 16,
          col: 4
        },
        size: {
          row: 4,
          col: 4
        }
      },
      controls: {
        position: {
          row: 0,
          col: 0
        },
        size: {
          row: 0,
          col: 0
        }
      }
    },
    tablet: {
      rows: 14,
      cols: 16,
      numberOfAllTiles: 36,
      numberOfBig: 4,
      nubmerOfMedium: 24,
      numberOfSmallTiles: 0,
      head: {
        position: {
          row: 0,
          col: 0
        },
        size: {
          row: 4,
          col: 6
        }
      },
      subhead: {
        position: {
          row: 8,
          col: 10
        },
        size: {
          row: 4,
          col: 4
        }
      },
      controls: {
        position: {
          row: 12,
          col: 10
        },
        size: {
          row: 2,
          col: 4
        }
      }
    },
    medium: {
      rows: 10,
      cols: 20,
      numberOfAllTiles: 56,
      numberOfBig: 3,
      nubmerOfMedium: 17,
      numberOfSmallTiles: 0,
      head: {
        position: {
          row: 0,
          col: 0
        },
        size: {
          row: 4,
          col: 6
        }
      },
      subhead: {
        position: {
          row: 6,
          col: 16
        },
        size: {
          row: 4,
          col: 4
        }
      },
      controls: {
        position: {
          row: 8,
          col: 12
        },
        size: {
          row: 2,
          col: 4
        }
      }
    },
    desktops: {
      rows: 8,
      cols: 24,
      numberOfAllTiles: 33,
      numberOfBig: 4,
      nubmerOfMedium: 17,
      numberOfSmallTiles: 0,
      head: {
        position: {
          row: 0,
          col: 0
        },
        size: {
          row: 4,
          col: 6
        }
      },
      subhead: {
        position: {
          row: 4,
          col: 20
        },
        size: {
          row: 4,
          col: 4
        }
      },
      controls: {
        position: {
          row: 6,
          col: 16
        },
        size: {
          row: 2,
          col: 4
        }
      }
    },
    desktops2: {
      rows: 10,
      cols: 26,
      numberOfAllTiles: 84,
      numberOfBig: 5,
      nubmerOfMedium: 24,
      numberOfSmallTiles: 0,
      head: {
        position: {
          row: 2,
          col: 0
        },
        size: {
          row: 4,
          col: 6
        }
      },
      subhead: {
        position: {
          row: 4,
          col: 20
        },
        size: {
          row: 4,
          col: 6
        }
      },
      controls: {
        position: {
          row: 8,
          col: 20
        },
        size: {
          row: 2,
          col: 4
        }
      }
    },
    desktops3: {
      rows: 10,
      cols: 32,
      numberOfAllTiles: 91,
      numberOfBig: 6,
      nubmerOfMedium: 38,
      numberOfSmallTiles: 0,
      head: {
        position: {
          row: 2,
          col: 0
        },
        size: {
          row: 4,
          col: 8
        }
      },
      subhead: {
        position: {
          row: 4,
          col: 24
        },
        size: {
          row: 4,
          col: 6
        }
      },
      controls: {
        position: {
          row: 8,
          col: 24
        },
        size: {
          row: 2,
          col: 4
        }
      }
    }
  }

  this.curSettings = {}

  this.draw();
  this.bindControls();
}

Mosaic.prototype.groupTilesBySize = function () {
  var bigTiles = this.tiles.filter(function (index, item) {
    return item.dataset.size === "big";
  });
  var mediumTiles = this.tiles.filter(function (index, item) {
    return item.dataset.size === "medium";
  });

  var smallTiles = this.tiles.filter(function (index, item) {
    return item.dataset.size === "small";
  });

  var groupedTiles = $.merge(bigTiles, $.merge(mediumTiles, smallTiles));

  return groupedTiles;
}

Mosaic.prototype.fillTilesWithCards = function (tilesGroupBySlides) {
  for (var i = 0; i < this.slides.length; i++) {
    for (var j = 0; j < this.slides[i].length; j++) {
      this.slides[i][j].block = tilesGroupBySlides[i][j];
    }
  }
}

Mosaic.prototype.draw = function () {
  this.setGridSettings();
  this.uiPrepare();


  var numberOfSlides = Math.ceil(this.tiles.length / this.curSettings.numberOfAllTiles);

  // split tiles in slides
  for (var i = 0; i < numberOfSlides; i++) {
    this.slides[i] = new Tiles(this.curSettings);    
  }
  
  var tilesGroupBySlides = this.fillGridWithTiles(this.groupTilesBySize());
  this.fillTilesWithCards(tilesGroupBySlides);

  for (var i=0; i< this.slides.length; i++) {    
    this.renderGrid(this.slides[i]);
  }

  // initial setup of first slide
    for (var i = 0; i < this.slides[0].length; i++) {
        if (typeof (this.slides[0][i].block) == "undefined") {
            continue;
        }
    this.slides[0][i].block.classList.add('active');
    this.slides[0][i].block.style.left = this.slides[0][i].coords.col * this.curSettings.xsize + 'px';
  }
}



Mosaic.prototype.fillGridWithTiles = function(groupedTiles){

  var tileIndex = 0;
  var fake = false;
  var tilesGroupBySlides = [];  
  
  for (var i=0; i< this.slides.length; i++) {
    tilesGroupBySlides.push([]);
    for (var a = 0; a < this.curSettings.numberOfBig; a++) {
      tilesGroupBySlides[i].push(getNextTile());
    }
  }

  for (var i = 0; i < this.slides.length; i++) {
    for (var b = 0; b < this.curSettings.nubmerOfMedium; b++) {
      tilesGroupBySlides[i].push(getNextTile());
    }
  }

  for (var i = 0; i < this.slides.length; i++) {
    for (var c = 0; c < this.curSettings.numberOfSmallTiles; c++) {
       tilesGroupBySlides[i].push(getNextTile());
    }
  }
  


  function getNextTile(){   
    
    if (tileIndex == groupedTiles.length) {
      tileIndex = 0;
      fake = true;
    }

    var block = null;
    
    if (fake) {
      block = groupedTiles[tileIndex].cloneNode(true);
      block.classList.add('fake');    
    } else {
      block = groupedTiles[tileIndex];      
    } 

    tileIndex++;
    
    return block;    
  }

  return tilesGroupBySlides;
}


Mosaic.prototype.shuffle = function (array) {
  var m = array.length,
    t, i;

  // While there remain elements to shuffle…
  while (m) {
    // Pick a remaining element…
    i = Math.floor(Math.random() * m--);

    // And swap it with the current element.
    t = array[m];
    array[m] = array[i];
    array[i] = t;
  }

  return array;
}

Mosaic.prototype.setGridSettings = function () {
  this.curSettings = this.settings.desktops3;

  var width = $(window).width();


  if (width >= 768 && width < 991) {
    this.curSettings = this.settings.tablet;
    
  }
  if (width >= 992 && width < 1199) {
    this.curSettings = this.settings.medium;
      
  }
  if (width >= 1200 && width < 1440) {
    this.curSettings = this.settings.desktops;
      
  }
  if (width >= 1440 && width < 1681) {
    this.curSettings = this.settings.desktops2;    
  }
  if (width >= 1681 && width < 1887) {
    this.curSettings = this.settings.desktops2;
  }

    if (width < 768) {
      this.curSettings = this.settings.phones;
      this.curSettings.numberOfAllTiles = this.tiles.length;
      //this.curSettings.numberOfSmallTiles = 0;
      if (this.tiles.length < 40) {
        this.curSettings.numberOfAllTiles = 140;        
      }
      this.curSettings.rows = Math.ceil(this.curSettings.numberOfAllTiles / 2.9); // 2.8 - empirical number to fit tiles on mobile screen
      this.container.style.height = this.curSettings.rows * this.dummyBox.offsetHeight + 'px';
      this.curSettings.nubmerOfMedium = Math.ceil(this.curSettings.numberOfAllTiles / 5);
      this.curSettings.numberOfBig = Math.ceil(this.curSettings.numberOfAllTiles / 20);
    } else {
      this.countTiles();
    }

  this.curSettings.xsize = $(this.dummyBox).width();
  this.curSettings.ysize = $(this.dummyBox).height();
}

Mosaic.prototype.clear = function () {
  this.slides = [];
  this.curSlide = 0;
  $(this.container).attr('style', '');

  // remove extra empty blocks
  $(this.container).find('.grid-tile.fake').remove();
  $(this.heading).attr('style', '').css('background-color', this.colors.heading);
  $(this.subheading).attr('style', '').css('background-color', this.colors.subheading);
  $(this.controls.prev).attr('style', '');
  $(this.controls.next).attr('style', '');

  this.tiles.each(function () {
    $(this).removeClass('big medium small active').attr('style', '');
  });
}

Mosaic.prototype.uiPrepare = function () {

  this.colors.heading = $(this.heading).css('background-color');
  this.colors.subheading = $(this.subheading).css('background-color');
  // heading
  this.setBlockPosition(this.heading, this.curSettings.head.position, this.curSettings.head.size)
  //subheading 
  this.setBlockPosition(this.subheading, this.curSettings.subhead.position, this.curSettings.subhead.size);

  // control prev
  this.setBlockPosition(this.controls.prev, this.curSettings.controls.position, {
    row: 2,
    col: 2
  });

  // control next
  this.setBlockPosition(this.controls.next, {
    row: this.curSettings.controls.position.row,
    col: this.curSettings.controls.position.col + 2
  }, {
    row: 2,
    col: 2
  });
}

Mosaic.prototype.countTiles = function (){
  var gridSize = this.curSettings.rows * this.curSettings.cols;

  var controlPlace = {};
  controlPlace.head = this.curSettings.head.size.col * this.curSettings.head.size.row;
  controlPlace.subhead = this.curSettings.subhead.size.col * this.curSettings.subhead.size.row;
  controlPlace.controls = this.curSettings.controls.size.col *  this.curSettings.controls.size.row;

  var bigPlace = this.curSettings.numberOfBig*16;
  var mediumPlace = this.curSettings.nubmerOfMedium * 4;

  this.curSettings.numberOfSmallTiles = gridSize - controlPlace.head - controlPlace.subhead - controlPlace.controls - bigPlace - mediumPlace;
  this.curSettings.numberOfAllTiles = this.curSettings.numberOfBig + this.curSettings.nubmerOfMedium + this.curSettings.numberOfSmallTiles;
}

Mosaic.prototype.setBlockPosition = function (block, coords, size) {
  var style = (block.getAttribute('style')) ? block.getAttribute('style') : "";
  block.setAttribute('style', style + ' top:' + coords.row * this.curSettings.ysize + 'px; left:' + coords
    .col *
    this.curSettings.xsize + 'px; width:' + size.col * this.curSettings.xsize + 'px; height:' + size.row * this.curSettings.ysize + 'px;');
}

Mosaic.prototype.renderGrid = function (cards) {
  var width = $(window).width();

  if (width < 768) {
    // Adopt size of tiles
      for (var i = 0; i < cards.length; i++) {
          if (typeof (cards[i].block) == "undefined")
          {
              continue;
          }
      switch (cards[i].className) {
        case 'small':
          cards[i].block.setAttribute('style', 'width:' + this.curSettings.xsize + 'px; height:' + this.curSettings.ysize + 'px;');
          break;

        case 'medium':
          cards[i].block.setAttribute('style', 'width:' + this.curSettings.xsize * 2 + 'px; height:' + this.curSettings.ysize * 2 + 'px;');
          break;

        case 'big':
          cards[i].block.setAttribute('style', 'width:' + this.curSettings.xsize * 4 + 'px; height:' + this.curSettings.ysize * 4 + 'px;');
          break;
      }

      cards[i].block.setAttribute(
        'style', cards[i].block.getAttribute('style') + ' top:' + cards[i].coords.row * this.curSettings.ysize + 'px; left:100%;'
      );     

       // Append empty blocks
      if (cards[i].block.classList.contains('fake')) {
        this.container.appendChild(cards[i].block);
      }

      cards[i].block.classList.add(cards[i].className);
      this.bindEventsToCard(cards[i].block);
    }
  } else {
    for (var i = 0; i < cards.length; i++) {
      cards[i].block.setAttribute(
        'style', 'top:' + cards[i].coords.row * this.curSettings.ysize + 'px; left:100%;'
      );

      // Append empty blocks
      if (cards[i].block.classList.contains('fake')) {
        this.container.appendChild(cards[i].block);
      }       

      cards[i].block.classList.add(cards[i].className);
      this.bindEventsToCard(cards[i].block);
    }
  }

}

Mosaic.prototype.bindEventsToCard = function (card) {
  var proxy = this;

  card.addEventListener('click', function () {
    proxy.modal.showTileStory(card);
  });

}

Mosaic.prototype.bindControls = function () {

  var proxy = this;
  this.controls.prev.addEventListener('click', function () {
    if (!proxy.isAnimated) {
      proxy.slidePrev();
    }
  });
  this.controls.next.addEventListener('click', function () {
    if (!proxy.isAnimated) {
      proxy.slideNext();
    }
  });
}

/**
 * Next slide
 */
Mosaic.prototype.slideNext = function () {
  if (this.slides.length > 1) {
    var nextSlideIndex = this.curSlide + 1;

    if (nextSlideIndex === this.slides.length) {
      nextSlideIndex = 0;
    }

    this.animateSlide(nextSlideIndex);
  }
}

/**
 * Previous slide
 */
Mosaic.prototype.slidePrev = function () {
  if (this.slides.length > 1) {
    var nextSlideIndex = this.curSlide - 1;
    if (nextSlideIndex < 0) {
      nextSlideIndex = this.slides.length - 1;
    }

    this.animateSlide(nextSlideIndex);
  }
}

Mosaic.prototype.animateSlide = function (slideIndex) {
  this.isAnimated = true;
  var proxy = this;

  for (var i = 0; i < this.slides[slideIndex].length; i++) {
    this.slides[slideIndex][i].block.classList.add('animate');
    this.slides[slideIndex][i].block.style.left = this.slides[slideIndex][i].coords.col * this.curSettings.xsize + 'px';
  }

  setTimeout(function () {
    for (var i = 0; i < proxy.slides[proxy.curSlide].length; i++) {
      proxy.slides[proxy.curSlide][i].block.classList.remove('active');
      proxy.slides[proxy.curSlide][i].block.style.left = '100%';
    }

    for (var i = 0; i < proxy.slides[slideIndex].length; i++) {
      proxy.slides[slideIndex][i].block.classList.add('active');
      proxy.slides[slideIndex][i].block.classList.remove('animate');
    }
    proxy.curSlide = slideIndex;
    proxy.isAnimated = false;
  }, 2500);
}

$(document).ready(function () {
  $('.mosaic').each(function () {
    var mosaic = new Mosaic(this);

    var windowWidth = $(window).width();

    $(window).resize(function () {

      if ($(window).width() != windowWidth) {
        windowWidth = $(window).width();
        mosaic.clear();
        mosaic.draw();
      }
    });

    window.addEventListener("orientationchange", function () {

      windowWidth = $(window).width();
      mosaic.clear();
      mosaic.draw();

    });
  });
});;
(function ($) {

    var init = function ($block) {

        if ($block.data('componentReportBlockInitialized') === true) {
            return;
        }

        function getTotalBlocksText(total) {
            return total + (total === 1 ? " Block" : " Blocks");
        }

        function getTotalPagesText(total) {
            return total + (total === 1 ? " Page" : " Pages");
        }

        function showProgress($progress, show) {
            show ? $progress.show() : $progress.hide();
        }

        $block.find('.js-pages-modal').on('show.bs.modal', function (e) {
            var $invoker = $(e.relatedTarget);
            var info = $invoker.data('info');
            var type = $invoker.data('type');
            var total = $invoker.data('total');

            var $self = $(this);

            if (type && info && total) {
                $self.find('.modal-header').append('<h4 class="modal-title"><span class="js-type"></span></h4><h5><b><span class="site-page-name" style="display:none;"></span></b>&nbsp;(<span class="js-total"></span>)</h5>');
            }

            var $progress = $self.find(".js-progress");
            $self.find(".js-info").html("");
            showProgress($progress, true);

            $self.find(".js-type").text(type);
            $self.find(".js-total").text(getTotalPagesText(total));

            function filterPagesByLanguage(language) {
                if (language == "") {
                    $self.find(".js-page-by-language").show();
                    $self.find(".js-page-by-id").show();
                } else {
                    $self.find(".js-page-by-id").show();

                    $self.find(".js-page-by-language").hide();
                    $self.find(".js-page-by-language[data-language=" + language + "]").show();
                }

                $self.find(".js-page-by-id").each(function (index, element) {
                    var filteredPages;
                    if (language == "") {
                        filteredPages = $(element).find(".js-page-by-language");
                    } else {
                        filteredPages = $(element).find(".js-page-by-language[data-language=" + language + "]");
                    }

                    if (filteredPages.length === 0) {
                        $(element).hide();
                    }

                    $(element).find(".js-total-by-id").text(getTotalPagesText(filteredPages.length));
                });

                total = $self.find(".js-page-by-language:visible").length;
                $self.find(".js-total").text(getTotalPagesText(total));
            }

            $.post('/ReportComponentsList/LoadPageType', { info: info })
                .done(function (data) {
                    showProgress($progress, false);
                    $self.find(".js-info").html(data);

                    $self.find(".js-info .js-page .js-languages").change(function() {
                        var language = $(this).val();

                        filterPagesByLanguage(language);
                    });

                })
                .fail(function () {
                    showProgress($progress, false);
                });
        });

        $block.find('.js-blocks-modal').on('show.bs.modal', function (e) {
            var $invoker = $(e.relatedTarget);
            var info = $invoker.data('info');
            var type = $invoker.data('type');
            var total = $invoker.data('total');

            var $self = $(this);

            if (type && info && total) {
                $self.find('.modal-header').append('<h4 class="modal-title modal-title-style"><span class="js-type"></span></h4><h5><b><span class="block-page-name" style="display:none;"></span></b>&nbsp;(<span class="js-total"></span>)</h5>');
            }

            var $progress = $self.find(".js-progress");
            $self.find(".js-info").html("");
            showProgress($progress, true);

            $self.find(".js-type").text(type);
            $self.find(".js-total").text(getTotalBlocksText(total));

            $.post('/ReportComponentsList/LoadBlockType', { info: info })
                .done(function (data) {
                    showProgress($progress, false);
                    $self.find(".js-info").html(data);
                })
                .fail(function () {
                    showProgress($progress, false);
                });
        });

        $block.find('.js-pages-modal, .js-blocks-modal').on('hidden.bs.modal', function (e) {
            var $self = $(this);
            $self.find('.modal-header h4').remove();
            $self.find('.modal-header h5').remove();
        });

        $block.data('componentReportBlockInitialized', true);
    };

    $(document).ready(function () {
        $('.js-report-component-block').each(function (index, element) {
            init($(element));
        });
    });

})(jQuery)
;
'use strict';

var bmgSharing = (function () {
    var modulePath = '/sharingdata/';
    var title = '';
    var url = '';

    function handleClicks($target) {
        var $emailModal = $target.find('.share-email-modal');
        $emailModal.on("hidden", function () { closeEmailModal($emailModal); });

        var blockSharing = $target.hasClass('block-sharing-block'); //Boolean, true is block sharing, false for page sharing

        //Page Sharing, default behavior
        if (!blockSharing) {

            $target.find('.inner > a').not('.share-email').click(function (e) {
                e.preventDefault();

                if (($(this).hasClass('share-twitter') || $(this).hasClass('share-linkedin') || $(this).hasClass('share-yammer')) && $target.data('title') != "") {
                    title = $target.data('title');

                    if ($(this).hasClass('share-twitter')) {
                        popup($(this).attr('href'), '?url=' + encodeURIComponent(url) + '&text=' + encodeURIComponent(title));
                    }

                    else if ($(this).hasClass('share-linkedin')) {
                        popup($(this).attr('href'), '?mini=true&url=' + encodeURIComponent(url) + '&title=' + encodeURIComponent(title));
                    }

                    else if ($(this).hasClass('share-yammer')) {
                        popup($(this).attr('href'), '?status=' + encodeURIComponent((title != '' ? title + '\n' : '') + url));
                    }
                }
                else
                    popup($(this).attr('href'), '');
            });
            /*
            $target.find('.share-email').click(function (e) {
                e.preventDefault();
                $emailModal.modal();
            });
            */
            $target.find('a.share-email').click(function (e) {
                var href = $(this).attr('href');
                url = href != '#' ? href : '';
                title = '';
                e.preventDefault();
                $emailModal.modal();
            });
        }

            //Block sharing
        else {
            $target.find('.inner > a').click(function (e) {
                e.preventDefault();

                url = '';
                title = '';

                //Manual mode
                if (!$target.data('auto')) {
                    title = $target.data('title');
                    if ($target.data('url') != '')
                        url = $target.data('url');

                    //Auto Mode
                } else if ($target.data('parent') != '') {
                    var $parent = $target.parents($target.data('parent')).first();

                    if ($target.data('title') != '')
                        title = $parent.find($target.data('title')).first().text();

                    if ($target.data('url') != '')
                        url = $parent.find($target.data('url')).first().attr('href');
                }

                if (url == '') {
                    url = window.location.href;// +  window.location.hash;
                }


                if ($(this).hasClass('share-facebook')) {
                    //Can customize description with something like this
                    /*https://www.facebook.com/dialog/feed?app_id=' + appId + '&display=popup&link=' + encodeURI(url) + '&description=' + encodeURIComponent(text) + '&redirect_uri=' + encodeURI(url) + '&picture=' + encodeURI(picture)*/
                    popup($(this).attr('href'), '?u=' + encodeURIComponent(url));
                }

                else if ($(this).hasClass('share-twitter')) {
                    popup($(this).attr('href'), '?url=' + encodeURIComponent(url) + '&text=' + encodeURIComponent(title));
                }

                else if ($(this).hasClass('share-linkedin')) {
                    popup($(this).attr('href'), '?mini=true&url=' + encodeURIComponent(url) + '&title=' + encodeURIComponent(title));
                }

                else if ($(this).hasClass('share-yammer')) {
                    popup($(this).attr('href'), '?status=' + encodeURIComponent((title != '' ? title + '\n' : '') + url));
                }

                else if ($(this).hasClass('share-googlep')) {
                    popup($(this).attr('href'), '?url=' + encodeURIComponent(url));
                }

                else if ($(this).hasClass('share-email')) {
                    $emailModal.modal();
                }

                else {
                    popup($(this).attr('href'), encodeURIComponent(url));
                }
            });
        }


        $emailModal.find('.btn-primary').click(function (e) {
            $emailModal.removeClass('share-complete share-success share-failed');

            //Trigger validation on change after first validation try
            $emailModal.find('.share-name, .share-email, .share-emailfrom, .share-message').off('keyup change').on('keyup change', function () { validateEmailForm($emailModal); });

            var formData = validateEmailForm($emailModal);
            if (formData !== false) {

                var $button = $(this);
                $button.prop("disabled", true).text($emailModal.data('loading'));

                var $shareResult = $emailModal.find('.share-result');
                $shareResult.removeClass('alert-danger alert-success in');
                //if ($shareResult.hasClass('in'))
                //    $shareResult.collapse('hide');

                formData.__RequestVerificationToken = $('input[name="__RequestVerificationToken"]').val();
                formData.blockID = $target.data('id');
                formData.url = url == '' ? document.URL : url;
                if (title != '') formData.title = title;

                $.post(modulePath + 'sharebyemail/', formData, function (data) {
                    $button.prop("disabled", false).text($emailModal.data('submit'));

                    if (data.success == true) {
                        $emailModal.addClass('share-complete share-success');
                        if (data.message != '')
                            $shareResult.addClass('alert-success').html(data.message).collapse('show');
                    } else {
                        $emailModal.addClass('share-complete share-failed');
                        $shareResult.addClass('alert-danger').html(data.message).collapse('show');
                    }

                }, 'json').fail(function () {
                    $emailModal.addClass('share-complete share-failed');
                    $button.prop("disabled", false).text($emailModal.data('submit'));
                    $shareResult.addClass('alert-danger').html($emailModal.data('error')).collapse('show');
                });
            }
        });
    }

    //Reset modal when closing it to prepare for next sharing
    function closeEmailModal($emailModal) {
        $emailModal.removeClass('share-complete share-success share-failed');
        var $emailName = $emailModal.find('.share-name');
        var $emailFrom = $emailModal.find('.share-emailfrom');
        var $emailTo = $emailModal.find('.share-email');
        var $emailMessage = $emailModal.find('.share-message');
        $emailName.val('');
        $emailFrom.val('');
        $emailTo.val('');
        $emailMessage.val($emailModal.find('.share-message-base').html());

        var $shareResult = $emailModal.find('.share-result');
        $shareResult.removeClass('alert-danger alert-success in').html('');

        $emailModal.find('.form-group').removeClass('has-feedback has-success has-error');
        $emailModal.find('.form-control-feedback').addClass('hide').removeClass('glyphicon-ok glyphicon-remove');
    }

    function validateEmailForm($target) {
        var isValid = true;
        var validationData = {};

        var $emailName = $target.find('.share-name');
        var $emailFrom = $target.find('.share-emailfrom');
        var $emailTo = $target.find('.share-email');
        var $emailMessage = $target.find('.share-message');
        var $cmsemailFrom = $target.find('.share-cmsemailfrom');
        validationData.cmsEmailFrom = $cmsemailFrom.val();

        //Sender name
        if ($emailName.length) {
            if ($emailName.val().trim() == '') {
                validationFeedback($emailName, false);
                isValid = false;
            } else {
                validationFeedback($emailName, true);
                validationData.name = $emailName.val();
            }
        }

        //Sender email
        if ($emailFrom.length) {
            if ($emailFrom.val().trim() == '' || !validationDataEmailAddress($emailFrom.val())) {
                validationFeedback($emailFrom, false);
                isValid = false;
            } else {
                validationFeedback($emailFrom, true);
                validationData.emailFrom = $emailFrom.val();
            }
        }


        //Recipient
        if ($emailTo.val().trim() == '' || !validationDataEmailAddress($emailTo.val())) {
            validationFeedback($emailTo, false);
            isValid = false;
        } else {
            validationFeedback($emailTo, true);
            validationData.emailTo = $emailTo.val();
        }


        //Mail body
        if ($emailMessage.length) {
            if ($emailMessage.val().trim() == '') {
                validationFeedback($emailMessage, false);
                isValid = false;
            } else {
                validationFeedback($emailMessage, true);
                validationData.message = $emailMessage.val();
            }
        }

        return isValid ? validationData : isValid;
    }

    function validationFeedback($field, valid) {
        //has-feedback
        //has-success glyphicon-ok (success)
        //has-error glyphicon-remove (error)
        if (valid) {
            $field.parent().removeClass('has-error').addClass('has-feedback has-success').find('.form-control-feedback').removeClass('hide glyphicon-remove').addClass('glyphicon-ok').next().text('Valid');
        } else {
            $field.parent().removeClass('has-success').addClass('has-feedback has-error').find('.form-control-feedback').removeClass('hide glyphicon-ok').addClass('glyphicon-remove').next().text('Error');
        }
    }

    function validationDataEmailAddress(emailAddress) {
        var pattern = new RegExp(/^((([a-z]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+(\.([a-z]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+)*)|((\x22)((((\x20|\x09)*(\x0d\x0a))?(\x20|\x09)+)?(([\x01-\x08\x0b\x0c\x0e-\x1f\x7f]|\x21|[\x23-\x5b]|[\x5d-\x7e]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(\\([\x01-\x09\x0b\x0c\x0d-\x7f]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]))))*(((\x20|\x09)*(\x0d\x0a))?(\x20|\x09)+)?(\x22)))@((([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.)+(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.?$/i);
        return pattern.test(emailAddress);
    }

    function popup(url, append) {
        var width = 640;
        var height = 300;
        var leftPosition, topPosition;
        //Allow for borders.
        leftPosition = (window.screen.width / 2) - ((width / 2) + 10);
        //Allow for title and status bars.
        topPosition = (window.screen.height / 2) - ((height / 2) + 50);

        // if ios then, else

        var newWindow = window.open(url + append, 'Share', 'height=300,width=640,resizable=yes,left=' + leftPosition + ',top=" + topPosition' + ",screenX=" + leftPosition + ",screenY=" + topPosition + ',toolbar=no,menubar=no,scrollbars=no,location=no,directories=no');
        try {
            if (!$(body).hasClass("touch")) {
                if (window.focus) { newWindow.focus() }
            }

        } catch (err) {

        }
        return false;
    }

    function getSharesCount($target) {
        if ($target.data('likes-count')) {
            var url = window.location.href;
            if ($target.find('.share-facebook').length) {
                getFacebookSharesCount($target, url);
            }

            if ($target.find('.share-twitter').length) {
                //2015-11-23: Disabled as Twitter removed the possibility to easily get the count
                //getTwitterSharesCount($target, url);
            }

            if ($target.find('.share-linkedin').length) {
                getLinkedinSharesCount($target, url);
            }

            if ($target.find('.share-googlep').length) {
                getGooglePSharesCount($target, url);
            }
        }
    }

    function getFacebookSharesCount($target, url) {
        var varToRead = $target.data('facebook-total') ? 'total_count' : 'share_count';

        var fullUrl = 'https://api.facebook.com/restserver.php?method=links.getStats&urls=' + url;

        $.ajax({
            type: "GET",
            url: fullUrl,
            cache: false,
            dataType: "xml",
            success: function (xml) {
                var total_count = $(xml).find(varToRead).first().text();
                $target.find('.share-facebook .network-likes').text(total_count);

            }
        });
    }

    function getTwitterSharesCount($target, url) {
        var fullUrl = 'https://cdn.api.twitter.com/1/urls/count.json?url=' + url + '&callback=?';
        $.getJSON(fullUrl, function (data) {
            $target.find('.share-twitter .network-likes').text(data.count);
        });
    }

    function getLinkedinSharesCount($target, url) {
        var fullUrl = "https://www.linkedin.com/countserv/count/share?url=" + url + "&format=jsonp&callback=?";

        $.getJSON(fullUrl, function (data) {
            $target.find('.share-linkedin .network-likes').text(data.count);
        });
    }

    function getGooglePSharesCount($target, url) {
        $.post(modulePath + 'GooglePlusSharesCount/', {
            url: url,
            __RequestVerificationToken: $('input[name="__RequestVerificationToken"]').val()
        }, function (data) {
            $target.find('.share-googlep .network-likes').text(data);
        }, 'text');
    }

    return {
        init: function () {
            $('.block-sharing-page, .block-sharing-block').each(function () {
                var $target = $(this);
                handleClicks($target);
                getSharesCount($target);
            });
        },
        initOnTarget: function ($initTarget) {
            $initTarget.find('.block-sharing-page, .block-sharing-block').each(function () {
                var $target = $(this);
                handleClicks($target);
                getSharesCount($target);
            });
        }
    }
})();

(function (globals) {
    if (window.jQuery) {
        $(document).ready(function () {
            if (typeof globals.bmgSharingReady == 'undefined') {
                bmgSharing.init();
                globals.bmgSharingReady = true;
            }
        });
    } else {
        throw new Error('Block Sharing\'s JavaScript requires jQuery');
    }
}(this));;
'use strict';

(function (globals) {
    if (window.jQuery) {
        $(document).ready(function () {
            if (typeof globals.bmgSocialReady == 'undefined') {
                bmgSocial.init();
                globals.bmgSocialReady = true;
            }
        });
    } else {
        throw new Error('Block Social\'s JavaScript requires jQuery');
    }
}(this));

var bmgSocial = (function () {
    var modulePath = '/SocialData/';
    var layoutImgFolder = '/static/calypsot/images/social/';


    function init() {
        $('.block-social').each(function () {
            if ($(this).data('id') != '') {
                var block = $(this);
                block.append('<i class="glyphicon glyphicon-refresh loading-icon"></i>');
                $.post(modulePath + 'GetFeed/', {
                    blockId: $(this).data('id'),
                    __RequestVerificationToken: $('input[name="__RequestVerificationToken"]').val()
                }, function (data) {
                    switch (data.type) {
                        case 'twitter':
                            DisplayTweets(block, data.data);
                            break;

                        case 'facebook':
                            DisplayFacebookFeed(block, data.data.data);
                            break;

                        case 'instagram':
                            DisplayInstagramFeed(block, data.data.data);
                            break;

                        case 'yammer':
                        	DisplayYammerFeed(block, data.data.messages, data.data.references);
                            break;

                        case 'rss':
                            DisplayRssFeed(block, data.data.items);
                            break;

                        case 'youtube':
                            DisplayYouTubeFeed(block, data.data.items);
                            break;
                    }
                }, 'json').done(function (e) {
                    block.find('.loading-icon').remove();
                });
            }
        });

        $('.block-slider-nav ul > li:first-child()').addClass("active");

        $('.block-slider-nav li').on('click', function (e) {
            var $target = $('.block-slider-content').children().eq($(this).index());
            $(".block-slider-nav li").removeClass("active");
            $(this).addClass("active");
            $('.block-slider-content').animate({ scrollLeft: $('.block-slider-content').scrollLeft() + $target.position().left }, 500);
        });
    }

    function DisplayTweets($element, data) {
        var intentUrl = 'https://twitter.com/intent/';

        var $target = $element.find('.block-social-posts');
        $.each(data, function (index) {
        	var text = data[index].text.replace(/((http|ftp|https):\/\/([\w_-]+(?:(?:\.[\w_-]+)+))([\w.,@?^=%&:/~+#-]*[\w@?^=%&/~+#-])?)/g, '<a href="$1" target="_blank">$1</a>');
        	text = text.replace(/#(\S*)/g, '<a href="https://twitter.com/hashtag/$1" target="_blank">#$1</a>');
        	text = text.replace(/@(\S*)/g, '<a href="https://twitter.com/$1" target="_blank">@$1</a>');

            $target.append('<div class="block-social-post"><img src="' + data[index].user.profile_image_url_https + '" alt="Alternate Text" /><div class="block-social-post-text"><p>' + text + '</p><div class="actions"><a href="' + intentUrl + 'tweet?in_reply_to=' + data[index].id_str + '" target="_blank"><img src="' + layoutImgFolder + 'twitter_reply.svg" alt="" /></a><a href="' + intentUrl + 'retweet?tweet_id=' + data[index].id_str + '" target="_blank"><img src="' + layoutImgFolder + 'twitter_retweet.svg" alt="" /><span>' + data[index].retweet_count + '</span></a><a href="' + intentUrl + 'favorite?tweet_id=' + data[index].id_str + '" target="_blank"><img src="' + layoutImgFolder + 'twitter_favorite.svg" alt="" /><span>' + data[index].favorite_count + '</span></a></div></div></div>');
        });
        $element.trigger("loadingDone");
    }

    function DisplayFacebookFeed($element, data) {
        var $target = $element.find('.block-social-posts');
        $.each(data, function (index) {
            $target.append('<div class="block-social-post"><img src="' + data[index].picture + '" alt="Alternate Text" /><div class="block-social-post-text"><p>' + data[index].message + '</p><div class="actions"><a href="' + data[index].actions[0].link + '" target="_blank">Share</a></div></div></div>');
        });
        $element.trigger("loadingDone");
    }

    function DisplayInstagramFeed($element, data) {
        var $target = $element.find('.block-social-posts');
        $.each(data, function (index) {
            $target.append('<div class="block-social-post"><img src="' + data[index].images.low_resolution.url + '" alt="Alternate Text" /><div class="block-social-post-text"><p>' + data[index].caption.text + '</p><div class="actions"><a href="' + data[index].link + '" target="_blank">More</a></div></div>');
        });
        $element.trigger("loadingDone");
    }

    function DisplayYammerFeed($element, data, references) {
    	var $target = $element.find('.block-social-posts');
    	$.each(data, function (index) {
    		var author;
        	$.each(references, function (indexref) {
        		if (data[index].sender_id == references[indexref].id)
        			author = references[indexref].full_name;
        	});
        	var post_date = moment(data[index].created_at);

        	$target.append('<div class="block-social-post"><div class="block-social-post-text"><p class="author_date">' + (author ? author + ' - ' : '') + post_date.format('DD/MM/YYYY hh:mm') + '</p><p>' + data[index].content_excerpt + '</p><div class="actions"><a href="' + data[index].web_url + '" target="_blank">More</a></div></div>');
        });
        $element.trigger("loadingDone");
    }

    function DisplayRssFeed($element, data) {
        var $target = $element.find('.block-social-posts');
        $.each(data, function (index) {
            $target.append('<div class="block-social-post"><div class="block-social-post-text"><p class="rss_title">' + data[index].title + '</p><div class="rss_content"><p>' + data[index].description + '</p></div><div class="actions"><a href="' + data[index].link + '" target="_blank">More</a></div></div>');
        });
        $element.trigger("loadingDone");
    }

    function DisplayYouTubeFeed($element, data) {
        //var intentUrl = 'https://twitter.com/intent/';

        var $target = $element.find('.block-social-posts');
        $.each(data, function (index) {
            $target.append('<div class="block-social-post"><img src="' + data[index].image + '"  height="40" "/><div class="block-social-post-text"><p class="yt_title">' + data[index].title + '</p><div class="actions"><a href="' + data[index].link + '" target="_blank">View video</a></div></div>');
        });
        $element.trigger("loadingDone");
    }

    return {
        init: function () {
            init();
        }
    }
})();;
$(document).ready(function() {
  var $body = $("html, body");
  var $header = $(".gc-header");
  var $nav = $(".gc-nav");
  var $carousel = $(".survey-block .carousel");
  var $controls = $(".survey-carousel .controls");

  // Animate height of items
  $carousel.on("slide.bs.carousel", function(e) {
    var nextH = $(e.relatedTarget).outerHeight();
    $(this)
      .find(".active")
      .parent()
      .animate(
        {
          height: nextH
        },
        500
      );
    $body.animate(
      {
        scrollTop: parseInt(
          $carousel.offset().top - $header.outerHeight() - $nav.outerHeight()
        )
      },
      300
    );
  });

  // Slider for mobile  view
  $carousel.find(".item .form-control-slider").each(function() {
    var $sliderContainer = $(this);
    var $values = $sliderContainer.find(".value");
    // start value
    $values
      .eq($sliderContainer.find(".input-slider").val())
      .addClass("current");

    $sliderContainer.find(".input-slider").on("input mouseover", function() {
      this.style.setProperty("--val", $(this).val());
      $values
        .removeClass("current")
        .eq($(this).val())
        .addClass("current");
    });
  });

  // Survey steps buttons functionality
  $carousel.find(".item").each(function(index) {
    $(this)
      .find("input, select, textarea")
      .on("input change", function() {
        if ($(this).val() != "") {
          $controls
            .eq(index)
            .find(".btn.right")
            .removeAttr("disabled");
        } else {
          $controls
            .eq(index)
            .find(".btn.right")
            .attr("disabled", "disabled");
        }
      });

    // IE event fix for range input
    $(this)
      .find("input[type=range]")
      .on("mouseover", function() {
        $controls
          .eq(index)
          .find(".btn.right")
          .removeAttr("disabled");
      });

    // Look checlboxes that at least one is on to proceed step
    var checkboxes = $(this).find("input[type=checkbox]");
    if (checkboxes.length > 0) {
      checkboxes.on("change", function() {
        if (checkboxes.filter(":checked").length == 0) {
          $controls
            .eq(index)
            .find(".btn.right")
            .attr("disabled", "disabled");
        }
      });
    }
  });
});

function showComplete() {
  $(".survey-carousel").hide();
  $(".survey-complete").show();

  var carousel = $(".survey-block .carousel");
  carousel.find("input[type=checkbox]:checked").each(function() {
    var $this = $(this);
    var element = $("<input/>")
      .attr("name", $this.attr("name"))
      .attr("value", $this.val())
      .attr("type", "hidden");
    element.appendTo(".email-results form, .download-results form");
  });
  carousel.find("input[type=radio]:checked,input[type=range]").each(function() {
    var $this = $(this);
    var element = $("<input/>")
      .attr("name", $this.attr("id"))
      .attr("value", $this.val())
      .attr("type", "hidden");
    element.appendTo(".email-results form, .download-results form");
  });
  carousel.find("input[type=text],textarea").each(function() {
    var $this = $(this);
    var element = $("<input/>")
      .attr("name", $this.attr("name"))
      .attr("value", $this.val())
      .attr("type", "hidden");
    element.appendTo(".email-results form, .download-results form");
  });
  carousel.find("select").each(function() {
    var $select = $(this);
    var option = $select.find("option:selected").each(function() {
      var $this = $(this);
      var element = $("<input/>")
        .attr("name", $this.val())
        .attr("value", $this.text())
        .attr("type", "hidden");
      element.appendTo(".email-results form, .download-results form");
    });
  });

    var question = $('div.item.survey-question.active h3').text().trim();
    window.dataLayerOnco = window.dataLayerOnco || [];
    dataLayerOnco.push({
        'event': 'gtm_event',
        'eventInfo': {
            'category': 'quiz',
            'action': 'complete quiz',
            'label': question
        }

    });
}

function OnSubmitSurveyStart() {
  $("#submitSurveyEmail").button("loading");
}


function OnSubmitSurveySuccess() {
  $("#submitSurveyEmail").button("reset");
  $(".email-results").hide();
  $(".email-confirm").show();
}



function ScreenerToolComplete() {
  $(".survey-carousel").hide();

  var carousel = $(".survey-block .carousel");
  var data = {
    "BlockId" : jQuery.data(carousel[0], "blockid")
  };

  carousel.find("input[type=radio]:checked,input[type=range]").each(function() {
    var $this = $(this);
    var input = {};    
    
    input[$this.attr("id")] = $this.val();
    $.extend(data, input);
  });

    var url = "/ScreenerToolBlock/Check"; //TODO Confirm that these urls continue to work. Currently this block is not in the solution
  var success = function(data) {    
    if (data["Eligible"]) {
      $(".survey-complete, .survey-eligible").show();
      $(".survey-complete-page-description").html(data["Message"]);
    } else {
      $(".survey-complete, .survey-not-eligible").show();
      $(".survey-complete-page-description").html(data["Message"]);
    }
  };
  $.ajax({
    type: "POST",
    url: url,
    data: data,
    success: success
  });
};

'use strict';

(function (globals) {
    if (window.jQuery) {
        $(document).ready(function () {
            if (typeof globals.bmgTeaserReady == 'undefined') {
                bmgTeaser.init();
                globals.bmgTeaserReady = true;
            }
        });
    } else {
        throw new Error('Block Teaser\'s JavaScript requires jQuery');
    }
}(this));

var bmgTeaser = (function () {
    return {
        init: function () {

            /*var emptyModal = '<div class="global-modal"><div class="modal fade" id="globalModal" tabindex="-1"><div class="modal-dialog"></div></div></div>'
            $('body').append(emptyModal);*/

            $(".teaser-block .has-modal").click(function (e) {
                e.preventDefault();
                //var $this = $(this);
                //var modalContent = $this.find('.modal').length ? $this.find('.modal .modal-content').clone() : $this.parent().siblings('.modal').find('.modal-content').clone();
                //$('#globalModal > .modal-dialog').empty().append(modalContent);
                //$('#globalModal > .modal-dialog > .modal-content').prepend('<button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">×</span></button>');
                //$('#globalModal').modal('show');
                $('#' + $(this).parents('.teaser-block').data('modal-id')).modal('show');
            })
        }
    }
})();


;
var videoList = videoList || [];
var $videoModal = null;
var activeVideo = 0;
var videoAccordionItems;

var currentPlayedTime = 0;

var kalturaActivePlayer = {
    playing: false
};
var KalturaVideoLibraryFactory = function (container) {
    this.container = container;
    this.video = this.container.find(".block-video");
    this.thumbnail = this.container.find(".thumbnail");
    this.videoPlayer = this.container.find(".video-player");
    this.mobileWrapper = this.container.find(".video-block-preview-mobile");
    this.targetId = this.videoPlayer.attr("data-targetid");
    this.wid = this.videoPlayer.attr("data-wid");
    this.playerId = this.videoPlayer.attr("data-playerId");
    this.partnerId = this.videoPlayer.attr("data-partnerId");
    this.uiconfId = this.videoPlayer.attr("data-uiconfId");
    this.entryId = this.videoPlayer.attr("data-entryId");
    this.kalturaCss = this.container.attr("data-kalturacss") || "";
    this.thumbnailUrl = this.videoPlayer.attr("data-thumbnailurl") || "";
    this.videoName = this.videoPlayer.attr("data-videoname");
    this.themeCss = this.container.attr("data-brandTheme") || "";
    this.redirectUrl = this.videoPlayer.attr("data-redirectUrl");
    this.player = null;
    this.kdp = {};
    this.params = {};
    this.previriousWindowSize = $(window).width();
    this.percentageStep = 5;

    this.initializeVideo();
};

KalturaVideoLibraryFactory.prototype.initializeVideo = function () {
    var proxy = this;
    var redirectURl;

    this.thumbnail.on("click", function () {
        // If video expired
        if (proxy.thumbnail.hasClass("expired-video")) {
            redirectURl = proxy.thumbnail.attr("data-redirecturl");
            window.open(redirectURl);
            return;
        } 

        if ($videoModal.data('bs.modal')?._isShown) {
            proxy.showVideo();
            return;
        }

        // If other videos is playing
        videoAccordionItems.removeClass("playing");

        if ($(window).width() < 1025) {
            // Mobile
            try {
                proxy.kdp.sendNotification("doPlay");
            }
            catch (e) {
                console.log("doPlay event unavailable");
            }
            proxy.container.addClass("playing played");
        } else {
            // Desktop
            if (
                $(this)
                    .parent()
                    .hasClass("video-accordion-item")
            ) {
                activeVideo = $(this)
                    .parent()
                    .index();
            } else {
                activeVideo = $(this).index();
            }

            proxy.showVideoInModal();
            $videoModal
                .find(".thumbnail")
                .eq(activeVideo)
                .addClass("playing");
        }
        kalturaActivePlayer.kdp = proxy.kdp;
    });

    //Pause video when closing modal and place it at homeplace
    $videoModal.on("hidden.bs.modal", function (e) {
        proxy.removeVideoFromModal();
    });

    if ($(window).width() < 1025) {
        this.showVideo();
    }

    $(window).resize(function () {
        setTimeout(function () {
            // check if resize need to change anything
            var binded = breakpointFires.bind(proxy)
            if (binded()) {
                if ($(window).width() < 1025) {
                    // go to mobile view
                    currentPlayedTime = proxy.params.phPos;
                    if ($videoModal.hasClass("in")) {
                        $videoModal.one("hidden.bs.modal", function (e) {
                            proxy.showVideo();
                        }).modal("hide");
                        kalturaActivePlayer.kdp.sendNotification("doSeek", currentPlayedTime);
                        kalturaActivePlayer.kdp.sendNotification("doPlay");
                    } else {
                        proxy.showVideo();
                    }
                } else {
                    // go to desktop view
                    videoAccordionItems.removeClass("playing");
                    currentPlayedTime = proxy.params.phPos;
                    if (kalturaActivePlayer.playing) {
                        kalturaActivePlayer.kdp.sendNotification("doPause");
                        // move to Modal
                        proxy.showVideoInModal();
                        $videoModal.on("shown.bs.modal", function (e) {
                            kalturaActivePlayer.kdp.sendNotification("doSeek", currentPlayedTime);
                            kalturaActivePlayer.kdp.sendNotification("doPlay");
                        });
                    }
                }
            }
        }, 200);
    });

    $videoModal.find(".modal-footer").append(this.thumbnail.clone(true));
};

KalturaVideoLibraryFactory.prototype.showVideo = function (callback) {
    var proxy = this;
    if (typeof (kWidget) !== 'undefined') {
        kWidget.embed({
            targetId: this.targetId,
            wid: this.wid,
            player_id: this.playerId,
            partner_id: this.partnerId,
            uiconf_id: this.uiconfId,
            entry_id: this.entryId,
            flashvars: {
                autoPlay: false,
                loop: "false",
                thumbnailUrl: this.thumbnailUrl,
                showControls: "false",
                showTitle: "false",
                streamerType: "auto",
                IframeCustomPluginCss1: this.themeCss,
                IframeCustomPluginCss2: this.kalturaCss
            },
            readyCallback: function (playerId) {
                proxy.kdp = $("#" + playerId).get(0);
                kalturaActivePlayer.kdp = proxy.kdp;
                proxy.videoInitialized = true;
                proxy.subscribeEvents();
                if (typeof callback != "undefined") callback(proxy.kdp);
            }
        });
    } else {
        proxy.videoInitialized = false;
    }
};

KalturaVideoLibraryFactory.prototype.showVideoInModal = function (callback) {
    var proxy = this;

    $videoModal.find(".modal-body .player").empty();
    $videoModal.find(".modal-footer").empty();
    $videoModal.find(".modal-footer").append(
        this.container
            .parent()
            .find(".thumbnail")
            .clone(true)
    );
    $videoModal.find(".modal-body .player").append(this.video);
    $videoModal.find(".videoCount").text($videoModal.find(".thumbnail").length);
    $videoModal.find(".currentVideo").text(activeVideo + 1);
    $videoModal.find(".btn-prev-next").css(
        "color",
        proxy.container
            .parents(".panel-body")
            .find(".btnColor")
            .val()
    );

    if (this.redirectUrl != "" && this.redirectUrl != undefined) {
        $videoModal.modal("show");
        var url = this.redirectUrl;
        setTimeout(function () {
            window.open(url);
        }, 3000);
    } else {
        kWidget.embed({
            targetId: this.targetId,
            wid: this.wid,
            player_id: this.playerId,
            partner_id: this.partnerId,
            uiconf_id: this.uiconfId,
            entry_id: this.entryId,
            flashvars: {
                autoPlay: true,
                loop: "false",
                thumbnailUrl: this.thumbnailUrl,
                showControls: "false",
                showTitle: "false",
                streamerType: "auto",
                IframeCustomPluginCss1: this.themeCss,
                IframeCustomPluginCss2: this.kalturaCss
            },
            readyCallback: function (playerId) {
                proxy.kdp = $("#" + playerId).get(0);
                kalturaActivePlayer.kdp = proxy.kdp;
                proxy.subscribeEvents();
                $videoModal.modal("show");
                if (typeof callback != "undefined") callback(proxy.kdp);
            }
        });
    }
};

KalturaVideoLibraryFactory.prototype.subscribeEvents = function () {
    var proxy = this;

    this.params = {
        vidName: this.videoName,
        lastTriggerPos: 0,
        phPos: 0,
        duration: 0
    };

    // Play video pauses other videos
    this.kdp.kBind("doPlay", function () {
        if (
            typeof kalturaActivePlayer.kdp != "undefined" &&
            kalturaActivePlayer.kdp.id != proxy.kdp.id
        ) {
            kalturaActivePlayer.kdp.sendNotification("doPause");
        }

        kalturaActivePlayer.kdp = proxy.kdp;
        kalturaActivePlayer.playing = true;
    });

    // Get duration and Video Name
    this.kdp.kBind("playerReady", function () {

        proxy.params.duration = parseInt(proxy.kdp.evaluate("{duration}"));

        if (proxy.params.vidName == "") {
            proxy.params.vidName = proxy.kdp.evaluate("{mediaProxy.entry.name}");
        }
    });

    // Hack for videos not displaying on IE
    this.kdp.kBind('layoutBuildDone', function () {
        var is_ie = navigator.userAgent.indexOf("MSIE ") > -1 || navigator.userAgent.indexOf("Trident/") > -1;
        if (is_ie) {
            var vid = $('.mwEmbedKalturaIframe');
            var vidStyle = vid.attr('style');
            vid.attr('style', vidStyle + 'position: relative !important');
            setTimeout(function () {
                vid.attr('style', vidStyle + 'position: absolute !important');
            }, 1000);
        }
    });

    // Track intial play
    this.kdp.kBind("firstPlay", function () {
        gtmEventDataLayerOnco("videos", "play a video", proxy.params.vidName);
    });

    //Track Video progression('videoclick_25p', 'videoclick_50p', 'videoclick_75p', 'videoclick_End')
    this.kdp.kBind("playerUpdatePlayhead", function (currentTime) {
        proxy.params.phPos = currentTime;

        var currentPosPercents = parseInt(currentTime / proxy.params.duration * 100);
        var pos = currentPosPercents % proxy.percentageStep;

        if (currentPosPercents - currentPosPercents % proxy.percentageStep > proxy.params.lastTriggerPos && pos > 0) {
            pos = 0;
        }

        if (currentPosPercents > 0 && currentPosPercents < 100 && pos == 0 && proxy.params.lastTriggerPos < currentPosPercents) {
            for (var i = proxy.params.lastTriggerPos + proxy.percentageStep; i <= currentPosPercents; i = i + proxy.percentageStep) {
                if (i % 10 === 0 || i % 25 === 0) {
                    var message = "view " + i + " percent of a video";
                    gtmEventDataLayerOnco("videos", message, proxy.params.vidName);
                    if (typeof dataLayer != 'undefined' && typeof dataLayer.page != 'undefined') {
                        dataLayer.page.videoName = proxy.params.vidName;
                    }
                    proxy.params.lastTriggerPos = i;
                }
            }
        }
    });

    this.kdp.kBind("playerPlayEnd", function () {
        if ($(window).width() < 1025) {
            $(this)
                .parents(".video-accordion-item")
                .removeClass("playing");
        }
        proxy.params.lastTriggerPos = 0;
        kalturaActivePlayer.playing = false;
        gtmEventDataLayerOnco("videos", "complete a video", proxy.params.vidName);

        proxy.playNextVideo();
    });

    this.kdp.kBind("playerPaused", function () {
        kalturaActivePlayer.playing = false;
        gtmEventDataLayerOnco("videos", "pause a video", proxy.params.vidName);
    });

    this.kdp.kBind("userInitiatedPlay", function () {
        if (proxy.params.vidName == "") {
            proxy.params.vidName = this.kdp.evaluate("{mediaProxy.entry.name}");
        }

        if (window.accIsReplayKdp) {
            gtmEventDataLayerOnco("videos", "replay a video", proxy.params.vidName);
        }
        else {
            gtmEventDataLayerOnco("videos", "play a video", proxy.params.vidName);
            window.accIsReplayKdp = true;
        }
    });
};

KalturaVideoLibraryFactory.prototype.removeVideoFromModal = function () {

    kalturaActivePlayer.kdp.sendNotification("doPause");
    this.mobileWrapper.append(this.video);
    this.showVideo();
};

KalturaVideoLibraryFactory.prototype.playNextVideo = function () {
    var modalThumbnail = $videoModal.find(".thumbnail");

    activeVideo++;
    // Skip expired videos
    while (modalThumbnail.eq(activeVideo).hasClass("expired-video")) {
      activeVideo++;
    }

    if (activeVideo >= $videoModal.find(".thumbnail").length) {
      activeVideo = 0;
    }

    modalThumbnail.eq(activeVideo).trigger("click");
};

function doModal() {
    var html =
        '<div id="videoAccordionModal" class="video-accordion-modal modal fade" tabindex="-1" role="dialog" aria-labelledby="video-modal" aria-hidden="true">';
    html += '<div class="modal-dialog" rol="document">';
    html += '<div class="modal-content">';
    html += '<div class="modal-header">';
    html +=
        '<a class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">&times;</span></a>';
    html += "</div>";
    html += '<div class="modal-body">';
    html += '<div class="player"></div>';
    html += '<div class="controls"><div class="btn primary-brand-color-bg">';
    html +=
        '<span class="prev btn-prev-next textcolor">Previous Video</span></div>';
    html +=
        '<div>Video <span class="currentVideo">1</span> of <span class="videoCount">10</span></div>';
    html +=
        '<div class="btn primary-brand-color-bg"><span class="next btn-prev-next textcolor">Next Video</span></div></div>';
    html += "</div>";
    html += '<div class="modal-footer clearfix">';
    html += "</div>";
    html += "</div>";
    html += "</div>";
    html += "</div>";

    html = $(html);
    $("body").append(html);

    return html;
}

function initPlayers() {
    $videoModal = doModal();
    videoAccordionItems.each(function () {
        var videoPlayer = new KalturaVideoLibraryFactory($(this));
        videoList.push(videoPlayer);
    });
}

function breakpointFires() {
    var newWidth = $(window).width();
    var result = false;

    if (newWidth < 1025 && this.previriousWindowSize >= 1025) {
        result = true;
    } else if (newWidth >= 1025 && this.previriousWindowSize < 1025) {
        result = true;
    }
    this.previriousWindowSize = newWidth;
    return result;
}

$(document).ready(function () {
    videoAccordionItems = $(".video-accordion-item");

    initPlayers();

    $(".video-accordion-modal .prev").on("click", function () {
        var modalThumbnail = $videoModal.find(".thumbnail");

        activeVideo--;

        // Skip expired videos
        while (modalThumbnail.eq(activeVideo).hasClass("expired-video")) {
          activeVideo--;
        }

        if (activeVideo < 0) {
          activeVideo = $videoModal.find(".thumbnail").length - 1;
        }

        modalThumbnail.eq(activeVideo).trigger("click");
    });

    $(".video-accordion-modal .next").on("click", function () {
        var modalThumbnail = $videoModal.find(".thumbnail");

        activeVideo++;
        // Skip expired videos
        while (modalThumbnail.eq(activeVideo).hasClass("expired-video")) {
          activeVideo++;
        }

        if (activeVideo >= $videoModal.find(".thumbnail").length) {
            activeVideo = 0;
        }

        modalThumbnail.eq(activeVideo).trigger("click");
    });
});
;
'use strict';

$(function () {

    if ($(".bmg-video-thumbnail").length != 0) {
        $('.bmg-video-thumbnail').click(function () {
            $(this).toggle(false);
            var video = $(this).next();
            video.toggle(true);
            var videoId = $(this).parents(".block-video").data('videoid');
            var videoPlayerObject;
            if (typeof videoId != undefined) {
                var playerId = "player_" + videoId;
                videoPlayerObject = window[playerId];

                if (typeof videoPlayerObject != undefined) {
                    videoPlayerObject.play();
                }

            }
        });
    }
    
});;
(function () {

    var LISTENERS = [];

    window.uStudio = (window.uStudio) ? window.uStudio : {};
    window.uStudio.Player = (window.uStudio.Player) ? window.uStudio.Player : {};

    window.uStudio.Player.registerPlayerCallback = function (callback) {
        LISTENERS.push(callback);
    };

    var PLAYERS = {};

    var Player = function (id, source, origin) {
        this.id = id;
        this.source = source;
        this.origin = origin;
        this.subscribers = {};
    };

    Player.prototype.handle_event = function (event, args) {
        var subscribers = this.subscribers[event] || [];
        for (var i = 0; i < subscribers.length; i++) {
            subscribers[i].apply(this, args);
        }
    };

    Player.prototype.subscribe = function (event, callback) {
        if (!this.subscribers[event]) {
            this.subscribers[event] = [];
        }
        this.subscribers[event].push(callback);
    };

    Player.prototype.broadcast = function (event, args) {
        args = (args) ? args : [];
        this.source.postMessage(window.JSON.stringify({
            event: event, arguments: args
        }), this.origin);
    };

    var onMessage = function (event) {

        // this doesn't take into account other services that might
        // use postMessage -- probably need to wrap with a few try / catches
        // just to keep exceptions from being raised.

        try { var data = JSON.parse(event.data); } catch (e) { return; }

        var id = data.id,
          player = PLAYERS[id];

        if (data.event === "uStudio.eventsReady") {

            if (!id) {
                // this should always come back, but you can also set it yourself
                // if it's desired (to track specific placements, etc.)
                id = "player-" + parseInt(Math.floor(Math.random() * 100000), 10);
            }

            if (!PLAYERS[id]) {
                PLAYERS[id] = new Player(id, event.source, event.origin);
                player = PLAYERS[id];
            }

            player.broadcast("uStudio.pageReady", [{ url: window.location.href, id: id }]);

            for (var i = 0; i < LISTENERS.length; i++) {
                LISTENERS[i](player);
            }

        } else {

            if (!data.id || !PLAYERS[id]) {
                // this is likely not a uStudio event...
                return;
            }

            // handling standard events
            player.handle_event(data.event, data.arguments);

        }

    };

    var addListener = function (eventName, listener) {
        if (window.attachEvent) {
            window.attachEvent("on" + eventName, listener);
        } else if (window.addEventListener) {
            window.addEventListener(eventName, listener, false);
        } else {
            document.addEventListener(eventName, listener, false);
        }
    };

    addListener("message", onMessage);

})();;
$(document).ready(function () {
    /**************************************************/
    /*************** SEEMORE BLOCK ********************/
    /**************************************************/
    $('.seemoreBlock').each(function () {
        var $this = $(this);
        var modalID = $this.siblings('.seemoreModal').attr('id');
        var seeMore = $this.find('.CTALabel').attr('data-target', '#' + modalID);
        $this.find('.ellipsis').after(seeMore);
    });
    /**************************************************/
    /*************** LARGE TOUT BLOCK *****************/
    /**************************************************/
    $('.large-tout-block').each(function () {
        var $this = $(this);
        var anchor = $this.find('.anchor');
        var domain = anchor.attr('href').split("?");
        if (domain[0].indexOf('http') != -1 && domain[0].indexOf(window.location.hostname) == -1) {
            // External link
            //$this.find('.icon').attr('class', '').addClass('icon glyphicon glyphicon-menu-right');
        }
    });
    /**************************************************/
    /*************** LANGUAGE SELECTOR BLOCK *****************/
    /**************************************************/
    $('.language-selector-block select').change(function () {
        var url = $(this).val();
        if (url && url != '') {
            window.location.href = url;
        }
    });
    /******************************************************************************************************************/
    /*************** VIDEO BLOCK (just CSS height change, functionality is in videoContentBlock.js ********************/
    /******************************************************************************************************************/
    // Full width view (play vid directly on the page)
    $('.video-content-block.full-width-view').each(function () {
        var $this = $(this);
        var thumbnail = $this.find('.thumbnail');
        // $this.find('.block-video.ooyala > .inner').height(thumbnail.height());
    });

    $('img:not([alt=""]), div:not([alt=""]), map:not([alt=""]), area:not([alt=""])').map(function () {
        var existingTitle = $(this).attr('title');
        if (existingTitle === undefined || existingTitle === '') {
            $(this).attr('title', $(this).attr('alt'));
        }
    });

});;
var DigiOne = DigiOne || {};

DigiOne.namespace = function(namespaceString) {
	var parts = namespaceString.split("."),
        parent = DigiOne,
		i;

	// strip redundant leading global
    if (parts[0] === "DigiOne") {
		parts = parts.slice(1);
	}

	for (i = 0; i < parts.length; i += 1) {
		if (typeof parent[parts[i]] === "undefined") {
			parent[parts[i]] = {};
		}
		parent = parent[parts[i]];
	}
	return parent;
};

DigiOne.namespace("DigiOne.Utils");

DigiOne.Utils = {
	createCookie: function(name, value, days) {
		var expires;
		if (days) {
			var date = new Date();
			date.setTime(date.getTime() + days * 24 * 60 * 60 * 1000);
			expires = "; expires=" + date.toGMTString();
		} else {
			expires = "";
		}
		document.cookie = name + "=" + value + expires + "; path=/";
	},

	getCookie: function(c_name) {
		if (document.cookie.length > 0) {
			c_start = document.cookie.indexOf(c_name + "=");
			if (c_start != -1) {
				c_start = c_start + c_name.length + 1;
				c_end = document.cookie.indexOf(";", c_start);
				if (c_end == -1) {
					c_end = document.cookie.length;
				}
				return unescape(document.cookie.substring(c_start, c_end));
			}
		}
		return "";
	}
};

var privacyPolicyDisclaimer = function(PPDisclaimerModal) {
	var closeBtn = PPDisclaimerModal.find("button.close , .modal-content button");
	//var OKBtn = PPDisclaimerModal.find('a.btn-continue');

    var cookieName = "Calypso-PrivacyPolicyDisclaimer"; // in the case when something went wrong;
    if (typeof globalPPDisclaimerCookieName != "undefined" && globalPPDisclaimerCookieName) {
        cookieName = globalPPDisclaimerCookieName;
    }

    if (DigiOne.Utils.getCookie(cookieName) === "") {
        DigiOne.Utils.createCookie(cookieName, "true", 30);
		PPDisclaimerModal.modal();

		closeBtn.click(function () {
			gtmEventDataLayerOnco("navigation", "close covid19 lightbox", null);
			PPDisclaimerModal.modal("hide");
		});

		//OKBtn.click(function () {
		//    PPDisclaimerModal.modal('hide');
		//});
	}
};

function closeMovingOnModal() {
	$("#movingOnDisclaimer").modal("hide");
}

$(document).ready(function() {
	var $PPDisclaimer = $("#privacyPolicyDisclaimer");

	var disLocation = location.href;
	var disLocationRef = disLocation.substring(disLocation.indexOf("?") + 5);

	var referrer = document.referrer.split("/")[2];

	//console.log(['document', document]);
	//console.log(['document.referrer', document.referrer]);
	//console.log(['referrer', referrer]);

	// Testing address
	//if (referrer == "http://novintegweb02d:9315/index.jsp") {
	//    var movingOnDisclaimer = $('#movingOnDisclaimer').modal('show');
	//    window.setTimeout(closeMovingOnModal, 20000);
	//    movingOnDisclaimer.on('hidden.bs.modal', function () {
	//        // Check the external flag "showLightboxGlobalFlag" hosted on http://www.pharma.us.novartis.com
	//        if (showLightboxGlobalFlag) {
	//            privacyPolicyDisclaimer($PPDisclaimer);
	//        }
	//    })
	//} else {
	//    // Check the external flag "showLightboxGlobalFlag" hosted on http://www.pharma.us.novartis.com
	//    if (showLightboxGlobalFlag) {
	//        privacyPolicyDisclaimer($PPDisclaimer);
	//    }
	//}

	// To be put back after client's test
	if (
		referrer == "www.interventionsprogram.com" ||
		disLocationRef == "interventionsprogram.com"
	) {
        if (DigiOne.Utils.getCookie("DigiOne-MovingOnDisclaimer") === "") {
            DigiOne.Utils.createCookie("DigiOne-MovingOnDisclaimer", "true", 365);

			var movingOnDisclaimer = $("#movingOnDisclaimer").modal("show");
			window.setTimeout(closeMovingOnModal, 20000);
			movingOnDisclaimer.on("hidden.bs.modal", function() {
				// Check the flag "displayGlobalPPDisclaimer" set on _root.cshtml file
				if (
					typeof displayGlobalPPDisclaimer != "undefined" &&
					displayGlobalPPDisclaimer
				) {
					privacyPolicyDisclaimer($PPDisclaimer);
				}
			});
		}
	} else {
		// Check the flag "displayGlobalPPDisclaimer" set on _root.cshtml file
		if (
			typeof displayGlobalPPDisclaimer != "undefined" &&
			displayGlobalPPDisclaimer
		) {
			privacyPolicyDisclaimer($PPDisclaimer);
		}
	}
});
;
if (typeof $$epiforms !== 'undefined') {
  $$epiforms(document).ready(function () {
    $$epiforms('.EPiServerForms, [data-f-type="form"]').on("formsNavigationNextStep formsSetupCompleted formsNavigationPrevStep", function (event) {
      var lastStep = event.targetStep != undefined && event.targetStep.index === event.workingFormInfo.$steps.length - 1;
      $(".Form__NavigationBar__Action.btnSubmit").prop("hidden", !lastStep);
      $(".Form__NavigationBar__Action.btnNext").prop("hidden", lastStep);
      $(".Form__NavigationBar__Action.btnPrev").prop("hidden", event.targetStep == undefined || event.targetStep.index === 0);
    });
    $$epiforms('.EPiServerForms, [data-f-type="form"]').on("formsStepValidating", function (event) {
      $(".FormTextbox").each(function () {
        if (event.isValid) {
          $(this).removeClass("error-height");
        }
        else {
          $(this).addClass("error-height");
        }
      });
    });
    $$epiforms('.EPiServerForms, [data-f-type="form"]').on("formsStepValidating", function (event) {
      $(".FormTextbox").each(function () {
        if (event.isValid) {
          $(this).removeClass("error-height");
        }
        else {
          $(this).addClass("error-height");
        }
      });
    });
    $$epiforms('.EPiServerForms, [data-f-type="form"]').on("formsNavigateToStep", function (event) {
      $(".FormTextbox").each(function () {
        $(this).removeClass("error-height");
      });
    });
  });
};
$(function () {

    var isMobileView = false;
    if (/Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent)) {
        isMobileView = true;
    }

    $('.product-expandable-callout-heading').on('click', function () {
        var $this = $(this);
        if (!$this.next().hasClass("collapsing")) {
            $(this).toggleClass("colapsed-header");
            $this.find("a").toggleClass("selected");
        }
    });

    $(".product-expandable-callout-block").on('click', function () {
        var $this = $(this);

        $this.nextUntil(".product-expandable-callout-block + :not(.product-expandable-callout-block)").each(function () {
            var collapsedPart = $(this).find('.panel-collapse');
            var headderPart = $(this).find('.product-expandable-callout-heading');
            $(this).find("a").removeClass("selected");
            if (collapsedPart.hasClass("in")) {
                collapsedPart.collapse('hide');
                headderPart.removeClass("colapsed-header");
            }
        });

        $this.prevUntil(":not(.product-expandable-callout-block)").each(function () {
            var collapsedPart = $(this).find('.panel-collapse');
            var headderPart = $(this).find('.product-expandable-callout-heading');
            $(this).find("a").removeClass("selected");
            if (collapsedPart.hasClass("in")) {
                collapsedPart.collapse('hide');
                headderPart.removeClass("colapsed-header");
            }
        });
    });


    if (isMobileView) {
        $(".product-expandable-callout-heading").each(function () {
            $(this).addClass("mobile-device");
        });
    }

});
window.dataLayerOnco = window.dataLayerOnco || [];

$(document).ready(function () {

    /*Links click event*/
    $('a')
        .not('#brand-detail-page .uso-tab-menu a')
        .not('.isiLink, .see-more')
        .not('.jsLvlLinkItem')
        .not('.jsFeaturedCtaBanner')
        .not('.jsArrowButton')
        .not('.onePageTemplatePage .uso-tab-menu a')
        .not("a[href ^= 'tel:']")
        .on('click', function () {
            var $this = $(this);
            var btnText = $this.text().toLowerCase();
            if (btnText == "sign up now" && $this.hasClass('cta-button') && $this.parents('.callout').length > 0 && $this.parents('.container').length > 0) {
                gtmEventDataLayerOnco("forms", "start enrollment", "");
            }
            else if ($this.parents('.selectpicker').length == 0 && $this.parents('#back-to-quiz-container-button').length == 0) {

                var pattern = /^.*\.(docx|DOCX|xlsx|XLSX|xls|doc|DOC|pdf|PDF)$/;
                if ($this.attr('href') !== undefined) {
                    var ext = $this.attr('href').match(pattern);
                    var isQuickLinks = $this.hasClass("quick-link");
                    var isDropDownMenu = $this.hasClass("dropdown-toggle");
                    var isCTAButton = $this.hasClass("jsDisclaimerButton");
                    var isQuickLinksTeaser = $this.parents(".quick-links-teaser,.quick-info-teaser-ISI,.quickLinkBlock,.seemoreBlocksContainerBlock ").length > 0 ? true : false;
                    var internLink = location.hostname === this.hostname || !this.hostname.length ? true : false;
                    var anchorLink = this.pathname == window.location.pathname && this.protocol == window.location.protocol && this.host == window.location.host;
                    var accordionLink = $this.parents(".product-expandable-callout-block").length > 0 ? true : false;
                    var productCalloutLink = $this.parents(".product-callout-block").length > 0 ? true : false;

           
                    /*Exit link tracking*/
                    if (!isDropDownMenu && ext == null && $this.attr('href') !== window.location.host && $this.attr('href').slice(0, 1) != "/" && $this.attr('href').slice(0, 1) != "#" && !isCTAButton) {
                        gtmEventDataLayerOnco("exit links", "click on exit link", $this.attr('href'));
                    }

                    /*Download documents event*/
                    if (ext != null) {
                        var fileName = getFile($this.attr('href'));
                        /*if (ext[1] == 'docx' || 'DOCX' || 'xlsx' || 'XLSX' || 'xls' || 'doc' || 'DOC' || 'pdf' || 'PDF') {*/
                        if (ext[1] == 'pdf' || 'PDF') {
                            gtmEventDataLayerOnco("pdf documents", "download a document", fileName);
                        }
                    }
                   
                    if (accordionLink) {
                        var accordionLinkTitle = $this.find('.panel-title').text().trim();
                        var accordionLinkTitleWithoutSC = accordionLinkTitle.replace(/[`~!@#$%^&*()_|+\-=?'"<>\{\}\[\]\\\/]/gi, '').replace(/(\r\n|\n|\r)/gm, " ").toLowerCase();
                        gtmEventDataLayerOnco("navigation", "click on " + accordionLinkTitleWithoutSC, accordionLinkTitleWithoutSC);
                    }
                    else if (productCalloutLink) {
                        var productCalloutLinkTitle = $this.find('.title').text().trim();
                        var productCalloutLinkTitleWithoutSC = productCalloutLinkTitle.replace(/[`~!@#$%^&*()_|+\-=?'"<>\{\}\[\]\\\/]/gi, '').replace(/(\r\n|\n|\r)/gm, " ").toLowerCase();
                        gtmEventDataLayerOnco("navigation", "click on fixed callout", productCalloutLinkTitleWithoutSC);
                        
                    }
                    else if (isQuickLinks || isQuickLinksTeaser || internLink) {
                        if ($this.children().length > 0) {
                            var linkTextOperated = $this.children().not('figure').text();
                            if (linkTextOperated == "" && anchorLink) {
                                linkTextOperated = $this.text().trim();
                            }
                        }
                        else {
                            linkTextOperated = $this.text().trim();
                        }
                        var linkText = $this.find("quick-link-text").length > 0 ? $this.find("quick-link-text").text() : linkTextOperated;
                        var linkTextWithoutSC = linkText.replace(/[`~!@#$%^&*()_|+\-=?;:'",.<>\{\}\[\]\\\/]/gi, '').replace(/(\r\n|\n|\r)/gm, " ").toLowerCase();
                        var gateWayLink = $this.hasClass("usop-condition-link") || $this.parent('.subpageTitle').length > 0 || $this.parents(".indicationsSelector").length > 0 || $this.parents(".indication-menu-block").length > 0;
                        var isiLink = $this.parents('.seemoreBlock,.seemoreBlocksContainerBlock').length > 0 ? true : false;
                        var trimmedText = $.trim(linkTextWithoutSC)
                        if ($this.attr('href') == "https://www.pharma.us.novartis.com/utils/contact/hcp/emailh") {
                            gtmEventDataLayerOnco("support", "click on " + trimmedText, "");
                        }
                        else if (gateWayLink) {
                            gtmEventDataLayerOnco("navigation", "click on gateway element", trimmedText);
                        }
                        else if (isiLink) {
                            gtmEventDataLayerOnco("navigation", "click on important safety information", "");
                        }
                        else if (anchorLink || isDropDownMenu) {
                            if (isDropDownMenu) {
                                trimmedText = btnText;
                            }
                            gtmEventDataLayerOnco("navigation", "click on anchor link", trimmedText);
                        }
                        else if (trimmedText != "") {
                            gtmEventDataLayerOnco("navigation", "click on " + trimmedText, trimmedText);
                        }

                    }

                }
            }
        });

    $('button.CTALabel').on('click', function () {
        var isQuickLinksTeaser = $(this).parents(".seemoreBlocksContainerBlock ").length > 0 ? true : false;
        var isiLink = $(this).parents('.seemoreBlock,.seemoreBlocksContainerBlock').length > 0 ? true : false;

        if (isQuickLinksTeaser && isiLink) {
            gtmEventDataLayerOnco("navigation", "click on important safety information", "");
        }
    });

    /*Navigation event*/

    $('.research-landing-page a').on('click', exitLinkOnco);
    $('#uso-product-page a').on('click', exitLinkOnco);

    /*Tel link click tracking*/
    $("a[href^='tel:']").click(function (event) {
        event.preventDefault();
        var isQuickLinksTeaser = $(this).parents(".quick-links-teaser,.quick-info-teaser-ISI,.quickLinkBlock,.seemoreBlocksContainerBlock ").length > 0 ? true : false;
        link = $(this).attr('href');
        tracklink = link.replace("tel:", "")
        if (isQuickLinksTeaser) {
            gtmEventDataLayerOnco("support", "click on patient support telephone number", tracklink);
        }
        else {
            gtmEventDataLayerOnco("support", "click on telephone number", tracklink);
        }
        

        setTimeout(function () {
            window.location = link;
        }, 300);
    });

    /*Mosaic page events*/
    $(".mosaic")
        .on('click', '.control', function () {
            if ($(this).hasClass("prev")) {
                gtmEventDataLayerOnco("navigation", "click on previous", "");
            }
            else if ($(this).hasClass("next")) {
                gtmEventDataLayerOnco("navigation", "click on next", "");
            }
        })
        .on('click', '.grid-tile', function () {
            gtmEventDataLayerOnco("navigation", "open a mosaic tile", "");
        });
    $('.grid-story').on("click", ".cta-link", function () {
        gtmEventDataLayerOnco("navigation", "select an item in a tile", "");
    });

    /*Quiz tracking event*/
    $('.survey-question-wrapper').on("change", "input", function () {
        var question = $('div.item.survey-question.active h3').text().trim();
        var answer = $(this).val();
        gtmEventDataLayerOnco("quiz", "select a quiz answer", question + ' - ' + answer);
    });
    $('.survey-block .carousel-indicators').on("click", "button[data-slide='next']", function () {
        var question = $('div.item.survey-question.active h3').text().trim();
        gtmEventDataLayerOnco("quiz", "click on next", question);
    });
    $('.survey-block .carousel-indicators').on("click", "button[data-slide='prev']", function () {
        var question = $('div.item.survey-question.active h3').text().trim();
        gtmEventDataLayerOnco("quiz", "click on back", question);
    });
    $('#back-to-quiz-container-button').on("click", "a", function (event) {
        event.preventDefault();
        event.stopImmediatePropagation();
        var question = $('div.item.survey-question.active h3').text().trim();
        gtmEventDataLayerOnco("quiz", "click on retake the quiz", question);
    });

    /*Survey event*/
    $('.product-printable-inventory').on("change", ".product-printable-inventory-checkbox", function(){
        var pageTitle = $("h1").eq(0).text().trim();
        gtmEventDataLayerOnco("quiz", "select an option", pageTitle);
    });
    $('.product-printable-inventory').on("click", ".product-printable-inventory-submit-button", function () {
        var buttonVal = $(this).val().toLowerCase();
        var labelToTrack = "";
        var pageTitle = $("h1").eq(0).text().trim();
        var sectionTitle = $('.active.product-printable-inventory-step .product-printable-inventory-step-nav-text-number').text() + $('.active.product-printable-inventory-step .product-printable-inventory-step-nav-text').text();
        var selectedAnswers = [];
        var lastQuestion = $('.product-printable-inventory-step-nav li').last().hasClass('active');
        var isPrintBtn = $(this).hasClass('product-printable-inventory-submit-button');
        var isStartOverBtn = $(this).hasClass('product-printable-inventory-start-over');

        $.each($("input.product-printable-inventory-checkbox:checked"), function () {
            selectedAnswers.push($(this).val());
        });

        labelToTrack = sectionTitle + " - " + selectedAnswers.join(", ");
        if (buttonVal == "continue" && !lastQuestion) {
            gtmEventDataLayerOnco("quiz", "click on " + buttonVal, labelToTrack);
        }
        else if (buttonVal == "back") {
            gtmEventDataLayerOnco("quiz", "click on " + buttonVal, pageTitle);
        }
        else if (buttonVal == "continue" && lastQuestion) {
            gtmEventDataLayerOnco("quiz", "complete quiz", pageTitle);
        }
        else if (isPrintBtn && !isStartOverBtn) {
            gtmEventDataLayerOnco("quiz", "print inventory", pageTitle);
        }
        else if (isPrintBtn && isStartOverBtn) {
            gtmEventDataLayerOnco("quiz", "start over quiz", pageTitle);
        }
    });

    $(document).on("click", ".markerWIDirections a.marker2map", function (e) {
        gtmEventDataLayerOnco("locations", "click on get direction", "");
    });
    $('li').on("click", function () { 
      if ($(this).parent().hasClass('carousel-indicators'))
      {
        gtmEventDataLayerOnco("navigation", "click on dots slideshow", "slideshow " + ($(this).index() + 1));
      }
    });

    $(".carousel-inner a").on("click", function () {
        dataLayerOnco.push({
            event: "gtm_event",
            eventInfo: {
                category: "navigation",
                action: "click on slideshow",
                label: this.innerText.trim()
            }
        })
    });
    if (-1 != window.location.pathname.indexOf("/living-with-sickle-cell-quiz"))
      jQuery(document).on("click", "button", function (a) {
        "Download Results" != this.innerText.trim() && "Send Results" != this.innerText.trim() ||
          gtmEventDataLayerOnco(
            "navigation",
            "click on " + this.innerText.trim(),
              this.innerText.trim());
    });
});

function gtmEventDataLayerOnco(category, action, label) {
    dataLayerOnco.push({
        'event': 'gtm_event',
        'eventInfo': {
            'category': category ? category : "",
            'action': action ? $.trim(action.replace(/[^ -~]+/g, "")) : "",
            'label': label ? $.trim(label.replace(/[^ -~]+/g, "")) : ""
        }
    });
}
function exitLinkOnco() {
    var href = $(this).attr('href');
    var boolExternalLink = isExternalLink(href);
    if (boolExternalLink) {
        gtmEventDataLayerOnco("exit links", "click on exit link", href);
    }
}
function isExternalLink(href) {
    var dataTarget = $(this).data('target');
    var domain = href.split("?");
    if (domain[0].indexOf('http') != -1 && domain[0].indexOf(window.location.hostname) == -1 && dataTarget != "none") {
        return true;
    } else {
        return false;
    }
}

function getFile(filePath) {
    return filePath.substr(filePath.lastIndexOf('/') + 1).split('.')[0];
};
var ImageGallery = function (container) {
    this.$container = $(container);
    this.$modal = this.$container.find('.modal');
    this.$carousel = this.$container.find('.carousel');
    this.$carouselItems = this.$carousel.find('.item');
    this.$carouselIndicator = this.$carousel.find('.carousel-indicators');
    this.$showMoreBtn = this.$container.find('.btn-see-more');
    this.$items = this.$container.find('.image-gallery-item');
    this.$hiddenItems = this.$container.find('.hidden');
    this.itemsPerPage = this.$container.data('items-per-page');

    var proxy = this;

    // See more btn
    this.$showMoreBtn.click(function () {
        proxy.showMore();
    });

    // Show modal carousel on image click
    this.$items.click(function () {
        proxy.showModal(proxy.$items.index($(this)));
    });

    this.$carousel.swipe({
        swipe: function (event, direction, distance, duration, fingerCount, fingerData) {

            if (direction == 'left') $(this).carousel('next');
            if (direction == 'right') $(this).carousel('prev');

        },
        allowPageScroll: "vertical"
    });
};

ImageGallery.prototype.showMore = function () {
    for (var i = 0; i < this.itemsPerPage; i++) {
        this.$hiddenItems.eq(i).removeClass('hidden');
    }
    this.$hiddenItems = this.$container.find('.hidden');
    if (this.$hiddenItems.length == 0) {
        this.$showMoreBtn.hide();
    }
};

ImageGallery.prototype.showModal = function (index) {
    this.$modal.modal('show');
    this.setActiveSlide(index);
};

ImageGallery.prototype.setActiveSlide = function (index) {
    this.$modal.carousel({ interval: false }).carousel(index);
};


$('document').ready(function () {
    $('.js-image-gallery-block').each(function () {
        var gallery = new ImageGallery(this);
    });
});;
function OnSubmitCompletePrintableInventory() {
    // Bring scroll to top of form
    checkIfActive();

    var position = $('.product-printable-inventory').offset().top;
    if ($(window).width() < 1024) {
        position = position - 75;
        
    }
    $('html, body').scrollTop(position);

    $('.gc-content-left-column').on('change', '.product-printable-inventory-checkbox', function () {
        var boxChecked = false;
        var valueSelected = $(".product-printable-inventory-submit-button").hasClass("value-selected");
      
        $('.product-printable-inventory-checkbox').each(function () {
            var $this = $(this);
            if ($this.is(':checked')) {
                boxChecked = true;
            }
        });

        if (boxChecked) {
            $(".product-printable-inventory-submit-button").removeAttr('disabled');
        }
        else if ($(".product-printable-inventory-step:last-child").hasClass("active") && valueSelected == false) {
            $(".primary-brand-color-bg").attr({ 'disabled': 'disabled' });
        }
    });


}

function checkIfActive() {
    var boxChecked = false;
    $('.product-printable-inventory-checkbox').each(function () {
        var $this = $(this);
        if ($this.is(':checked')) {
            boxChecked = true;
        }
    });

    if (boxChecked) {
        $(".product-printable-inventory-submit-button").removeAttr('disabled');
    }
};
$(document).ready(function () {
    LoadAnswerEvents();
    //setEqualHeight();
});

window.onload = function () {
    setEqualHeight();
};

function LoadAnswerEvents() {
    $('.products-quiz-answer-component img-responsive').load(setEqualHeight());
    $(document).on('click', '.products-quiz-answer-component', function () {
        $(this).parent().find('.products-quiz-answer-component').removeClass('primary-brand-color-bg');
        $(this).parent().find('.products-quiz-answer-component').addClass('primary-brand-color-bg-hover-15');
        $(this).addClass('primary-brand-color-bg');
        $(this).removeClass('primary-brand-color-bg-hover-15');
        var answerID = $('input[name="answer-id"]', this).val();
        var form = $(this).parents('#products-quiz-form');

        // Hide all descriptions
        $('.products-quiz-answer-description-container > div', form).hide();

        // Show description for the selected answer
        if (typeof answerID != 'undefined' && answerID != '') {
            //console.log('.products-quiz-answer-component-' + answerID);
            //$('#products-quiz-answer-component-' + answerID, form).css('display', 'block');
            $('#products-quiz-answer-component-' + answerID, form).show();
        }

        // If selected answer is correct, show buttons
        if ($('input[name="answer-correct"]', this).val() == 'True') {
            $('.products-quiz-form-button', form).show();
        }

        if ($(this).find("#answer-correct").val() == "False") {
            $('.products-quiz-form-button', form).hide();
        }
    });

}

function OnSubmitComplete() {
    LoadAnswerEvents();
    setEqualHeight();
    //setEqualHeight();

}

function BeforeSend(jqXHR, settings) {
    settings.data = encodeURI(settings.data);
}

function setEqualHeight() {
    setTimeout(function () {
        var maxHeight = 0;
        $(".products-quiz-answer-component").each(function () {
            $(this).css("height", "auto");
            if ($(this).outerHeight() > maxHeight) {
                maxHeight = $(this).outerHeight();
            }
        });
        $(".products-quiz-answer-component").each(function () {
            $(this).css("height", maxHeight);
        });
    },330);
    
}



$(window).on("orientationchange", function () {
    setTimeout(setEqualHeight, 130);
    
});

$(window).resize(function () {
    setTimeout(setEqualHeight, 130);
});
;
$(document).ready(function () {
    resizeContent();
});

$(window).resize(function () {
    resizeContent();
});

function resizeContent() {
    var content_height = $(window).height() - $('.header').height() - 20;
    $('.view-content').height(content_height);
}

function searchFunction() {
    var input, filter, outer, inner, title;
    input = document.getElementById("searchInput");
    filter = input.value.toUpperCase();
    outer = document.getElementById("cards_container");
    inner = outer.getElementsByClassName("cards");
    for (i = 0; i < inner.length; i++) {
        title = inner[i].getElementsByTagName("p")[0];
        if (title.innerHTML.toUpperCase().indexOf(filter) > -1) {
            inner[i].style.display = "";
        } else {
            inner[i].style.display = "none";
        }
    }
    if ($("div.cards:visible").length == 0) {
        $('.search-result').css("display", "block");
    } else {
        $('.search-result').css("display", "none");
    }
    $('.not-used').closest('.cards').hide();
}

$("#view-button").click(function () {
    $(".per-site-class").slideToggle("fast");
    $(".per-type-class").slideToggle("fast");
    $(this).text(function (i, v) {
        return v === 'View Types' ? 'View Sites' : 'View Types'
    })
    if ($("#searchInput").attr("placeholder") == ("Search for Sites..")) {
        $("#searchInput").attr("placeholder", "Search for Pages or Blocks..")
    } else {
        $("#searchInput").attr("placeholder", "Search for Sites..")
    }
    $('#hideNotUsed').prop('checked', true).triggerHandler('click');
    document.getElementById("searchInput").value = "";
    searchFunction();
});

$(".tabs").click(function () {
    $('.cards-body').removeClass('temp');
    $(this).addClass('current').siblings().removeClass('current');
    $(this).parent().next().addClass('temp');
    if ($(this).hasClass('page-info')) {
        $('.temp > .block-type').hide();
        $('.temp > .page-type').show();
    } else {
        $('.temp > .block-type').show();
        $('.temp > .page-type').hide();
    }
    $('.not-used').closest('.cards').hide();
});


var searchString;
function handleLangChange(event) {
    var selectElement = event.target;
    var value = selectElement.value;
    console.log('selected val: ' + value);
    searchString = value;

    $('.sub-table tr td:nth-child(2)').each(function () {
        var cellText = $(this).text().replace(/(\r\n|\n|\r)/gm, '').replace(/ /g,'');
        $(this).parent().show();
        if (value == "") {
            $(this).parent().show();
        }
        else if (value != cellText) {
            $(this).parent().hide();
        } 
    });
}

$('.list-items.list-items-page').click(function () {
    var page_name = $('span:first', this).html().replace(/ *\([^)]*\) */g, "");
    var page_text = "Used in: " + page_name;
    $(".site-page-name").text(page_text);
    $(".block-page-name").css({ "display": "none" });
    $(".site-page-name").css({ "display": "inline-block" });
});

$('.list-items.list-items-block').click(function () {
    var block_name = $('span:first', this).html().replace(/ *\([^)]*\) */g, "");
    var block_text = "Used in: " + block_name;
    $(".block-page-name").text(block_text);
    $(".block-page-name").css({ "display": "inline-block" });
    $(".site-page-name").css({ "display": "none" });
});

$('.page-type.list-items, .block-type.list-items').click(function () {
    $(".site-page-name, .block-page-name").css({ "display": "none" });
});

;
$(document).ready(function () {

    /* Replace all SVG images with inline SVG */
    // "img.svg" img[src$=".svg"]

    $('img.svg').each(function () {
        var $img = $(this);
        var imgID = $img.attr('id');
        var imgClass = $img.attr('class');
        var imgURL = $img.attr('src');

        $.get(imgURL, function (data) {
            // Get the SVG tag, ignore the rest
            var $svg = $(data).find('svg');

            // Add replaced image's ID to the new SVG
            if (typeof imgID !== 'undefined') {
                $svg = $svg.attr('id', imgID);
            }
            // Add replaced image's classes to the new SVG
            if (typeof imgClass !== 'undefined') {
                $svg = $svg.attr('class', imgClass + ' replaced-svg');
            }

            // Remove any invalid XML tags as per http://validator.w3.org
            $svg = $svg.removeAttr('xmlns:a');

            // Replace image with new SVG
            $img.replaceWith($svg);

        }, 'xml');
    });
});
(function (e) { var o = "left", n = "right", d = "up", v = "down", c = "in", w = "out", l = "none", r = "auto", k = "swipe", s = "pinch", x = "tap", i = "doubletap", b = "longtap", A = "horizontal", t = "vertical", h = "all", q = 10, f = "start", j = "move", g = "end", p = "cancel", a = "ontouchstart" in window, y = "TouchSwipe"; var m = { fingers: 1, threshold: 75, cancelThreshold: null, pinchThreshold: 20, maxTimeThreshold: null, fingerReleaseThreshold: 250, longTapThreshold: 500, doubleTapThreshold: 200, swipe: null, swipeLeft: null, swipeRight: null, swipeUp: null, swipeDown: null, swipeStatus: null, pinchIn: null, pinchOut: null, pinchStatus: null, click: null, tap: null, doubleTap: null, longTap: null, triggerOnTouchEnd: true, triggerOnTouchLeave: false, allowPageScroll: "auto", fallbackToMouseEvents: true, excludedElements: "button, input, select, textarea, a, .noSwipe" }; e.fn.swipe = function (D) { var C = e(this), B = C.data(y); if (B && typeof D === "string") { if (B[D]) { return B[D].apply(this, Array.prototype.slice.call(arguments, 1)) } else { e.error("Method " + D + " does not exist on jQuery.swipe") } } else { if (!B && (typeof D === "object" || !D)) { return u.apply(this, arguments) } } return C }; e.fn.swipe.defaults = m; e.fn.swipe.phases = { PHASE_START: f, PHASE_MOVE: j, PHASE_END: g, PHASE_CANCEL: p }; e.fn.swipe.directions = { LEFT: o, RIGHT: n, UP: d, DOWN: v, IN: c, OUT: w }; e.fn.swipe.pageScroll = { NONE: l, HORIZONTAL: A, VERTICAL: t, AUTO: r }; e.fn.swipe.fingers = { ONE: 1, TWO: 2, THREE: 3, ALL: h }; function u(B) { if (B && (B.allowPageScroll === undefined && (B.swipe !== undefined || B.swipeStatus !== undefined))) { B.allowPageScroll = l } if (B.click !== undefined && B.tap === undefined) { B.tap = B.click } if (!B) { B = {} } B = e.extend({}, e.fn.swipe.defaults, B); return this.each(function () { var D = e(this); var C = D.data(y); if (!C) { C = new z(this, B); D.data(y, C) } }) } function z(a0, aq) { var av = (a || !aq.fallbackToMouseEvents), G = av ? "touchstart" : "mousedown", au = av ? "touchmove" : "mousemove", R = av ? "touchend" : "mouseup", P = av ? null : "mouseleave", az = "touchcancel"; var ac = 0, aL = null, Y = 0, aX = 0, aV = 0, D = 1, am = 0, aF = 0, J = null; var aN = e(a0); var W = "start"; var T = 0; var aM = null; var Q = 0, aY = 0, a1 = 0, aa = 0, K = 0; var aS = null; try { aN.bind(G, aJ); aN.bind(az, a5) } catch (ag) { e.error("events not supported " + G + "," + az + " on jQuery.swipe") } this.enable = function () { aN.bind(G, aJ); aN.bind(az, a5); return aN }; this.disable = function () { aG(); return aN }; this.destroy = function () { aG(); aN.data(y, null); return aN }; this.option = function (a8, a7) { if (aq[a8] !== undefined) { if (a7 === undefined) { return aq[a8] } else { aq[a8] = a7 } } else { e.error("Option " + a8 + " does not exist on jQuery.swipe.options") } }; function aJ(a9) { if (ax()) { return } if (e(a9.target).closest(aq.excludedElements, aN).length > 0) { return } var ba = a9.originalEvent ? a9.originalEvent : a9; var a8, a7 = a ? ba.touches[0] : ba; W = f; if (a) { T = ba.touches.length } else { a9.preventDefault() } ac = 0; aL = null; aF = null; Y = 0; aX = 0; aV = 0; D = 1; am = 0; aM = af(); J = X(); O(); if (!a || (T === aq.fingers || aq.fingers === h) || aT()) { ae(0, a7); Q = ao(); if (T == 2) { ae(1, ba.touches[1]); aX = aV = ap(aM[0].start, aM[1].start) } if (aq.swipeStatus || aq.pinchStatus) { a8 = L(ba, W) } } else { a8 = false } if (a8 === false) { W = p; L(ba, W); return a8 } else { ak(true) } } function aZ(ba) { var bd = ba.originalEvent ? ba.originalEvent : ba; if (W === g || W === p || ai()) { return } var a9, a8 = a ? bd.touches[0] : bd; var bb = aD(a8); aY = ao(); if (a) { T = bd.touches.length } W = j; if (T == 2) { if (aX == 0) { ae(1, bd.touches[1]); aX = aV = ap(aM[0].start, aM[1].start) } else { aD(bd.touches[1]); aV = ap(aM[0].end, aM[1].end); aF = an(aM[0].end, aM[1].end) } D = a3(aX, aV); am = Math.abs(aX - aV) } if ((T === aq.fingers || aq.fingers === h) || !a || aT()) { aL = aH(bb.start, bb.end); ah(ba, aL); ac = aO(bb.start, bb.end); Y = aI(); aE(aL, ac); if (aq.swipeStatus || aq.pinchStatus) { a9 = L(bd, W) } if (!aq.triggerOnTouchEnd || aq.triggerOnTouchLeave) { var a7 = true; if (aq.triggerOnTouchLeave) { var bc = aU(this); a7 = B(bb.end, bc) } if (!aq.triggerOnTouchEnd && a7) { W = ay(j) } else { if (aq.triggerOnTouchLeave && !a7) { W = ay(g) } } if (W == p || W == g) { L(bd, W) } } } else { W = p; L(bd, W) } if (a9 === false) { W = p; L(bd, W) } } function I(a7) { var a8 = a7.originalEvent; if (a) { if (a8.touches.length > 0) { C(); return true } } if (ai()) { T = aa } a7.preventDefault(); aY = ao(); Y = aI(); if (a6()) { W = p; L(a8, W) } else { if (aq.triggerOnTouchEnd || (aq.triggerOnTouchEnd == false && W === j)) { W = g; L(a8, W) } else { if (!aq.triggerOnTouchEnd && a2()) { W = g; aB(a8, W, x) } else { if (W === j) { W = p; L(a8, W) } } } } ak(false) } function a5() { T = 0; aY = 0; Q = 0; aX = 0; aV = 0; D = 1; O(); ak(false) } function H(a7) { var a8 = a7.originalEvent; if (aq.triggerOnTouchLeave) { W = ay(g); L(a8, W) } } function aG() { aN.unbind(G, aJ); aN.unbind(az, a5); aN.unbind(au, aZ); aN.unbind(R, I); if (P) { aN.unbind(P, H) } ak(false) } function ay(bb) { var ba = bb; var a9 = aw(); var a8 = aj(); var a7 = a6(); if (!a9 || a7) { ba = p } else { if (a8 && bb == j && (!aq.triggerOnTouchEnd || aq.triggerOnTouchLeave)) { ba = g } else { if (!a8 && bb == g && aq.triggerOnTouchLeave) { ba = p } } } return ba } function L(a9, a7) { var a8 = undefined; if (F() || S()) { a8 = aB(a9, a7, k) } else { if ((M() || aT()) && a8 !== false) { a8 = aB(a9, a7, s) } } if (aC() && a8 !== false) { a8 = aB(a9, a7, i) } else { if (al() && a8 !== false) { a8 = aB(a9, a7, b) } else { if (ad() && a8 !== false) { a8 = aB(a9, a7, x) } } } if (a7 === p) { a5(a9) } if (a7 === g) { if (a) { if (a9.touches.length == 0) { a5(a9) } } else { a5(a9) } } return a8 } function aB(ba, a7, a9) { var a8 = undefined; if (a9 == k) { aN.trigger("swipeStatus", [a7, aL || null, ac || 0, Y || 0, T]); if (aq.swipeStatus) { a8 = aq.swipeStatus.call(aN, ba, a7, aL || null, ac || 0, Y || 0, T); if (a8 === false) { return false } } if (a7 == g && aR()) { aN.trigger("swipe", [aL, ac, Y, T]); if (aq.swipe) { a8 = aq.swipe.call(aN, ba, aL, ac, Y, T); if (a8 === false) { return false } } switch (aL) { case o: aN.trigger("swipeLeft", [aL, ac, Y, T]); if (aq.swipeLeft) { a8 = aq.swipeLeft.call(aN, ba, aL, ac, Y, T) } break; case n: aN.trigger("swipeRight", [aL, ac, Y, T]); if (aq.swipeRight) { a8 = aq.swipeRight.call(aN, ba, aL, ac, Y, T) } break; case d: aN.trigger("swipeUp", [aL, ac, Y, T]); if (aq.swipeUp) { a8 = aq.swipeUp.call(aN, ba, aL, ac, Y, T) } break; case v: aN.trigger("swipeDown", [aL, ac, Y, T]); if (aq.swipeDown) { a8 = aq.swipeDown.call(aN, ba, aL, ac, Y, T) } break } } } if (a9 == s) { aN.trigger("pinchStatus", [a7, aF || null, am || 0, Y || 0, T, D]); if (aq.pinchStatus) { a8 = aq.pinchStatus.call(aN, ba, a7, aF || null, am || 0, Y || 0, T, D); if (a8 === false) { return false } } if (a7 == g && a4()) { switch (aF) { case c: aN.trigger("pinchIn", [aF || null, am || 0, Y || 0, T, D]); if (aq.pinchIn) { a8 = aq.pinchIn.call(aN, ba, aF || null, am || 0, Y || 0, T, D) } break; case w: aN.trigger("pinchOut", [aF || null, am || 0, Y || 0, T, D]); if (aq.pinchOut) { a8 = aq.pinchOut.call(aN, ba, aF || null, am || 0, Y || 0, T, D) } break } } } if (a9 == x) { if (a7 === p || a7 === g) { clearTimeout(aS); if (V() && !E()) { K = ao(); aS = setTimeout(e.proxy(function () { K = null; aN.trigger("tap", [ba.target]); if (aq.tap) { a8 = aq.tap.call(aN, ba, ba.target) } }, this), aq.doubleTapThreshold) } else { K = null; aN.trigger("tap", [ba.target]); if (aq.tap) { a8 = aq.tap.call(aN, ba, ba.target) } } } } else { if (a9 == i) { if (a7 === p || a7 === g) { clearTimeout(aS); K = null; aN.trigger("doubletap", [ba.target]); if (aq.doubleTap) { a8 = aq.doubleTap.call(aN, ba, ba.target) } } } else { if (a9 == b) { if (a7 === p || a7 === g) { clearTimeout(aS); K = null; aN.trigger("longtap", [ba.target]); if (aq.longTap) { a8 = aq.longTap.call(aN, ba, ba.target) } } } } } return a8 } function aj() { var a7 = true; if (aq.threshold !== null) { a7 = ac >= aq.threshold } return a7 } function a6() { var a7 = false; if (aq.cancelThreshold !== null && aL !== null) { a7 = (aP(aL) - ac) >= aq.cancelThreshold } return a7 } function ab() { if (aq.pinchThreshold !== null) { return am >= aq.pinchThreshold } return true } function aw() { var a7; if (aq.maxTimeThreshold) { if (Y >= aq.maxTimeThreshold) { a7 = false } else { a7 = true } } else { a7 = true } return a7 } function ah(a7, a8) { if (aq.allowPageScroll === l || aT()) { a7.preventDefault() } else { var a9 = aq.allowPageScroll === r; switch (a8) { case o: if ((aq.swipeLeft && a9) || (!a9 && aq.allowPageScroll != A)) { a7.preventDefault() } break; case n: if ((aq.swipeRight && a9) || (!a9 && aq.allowPageScroll != A)) { a7.preventDefault() } break; case d: if ((aq.swipeUp && a9) || (!a9 && aq.allowPageScroll != t)) { a7.preventDefault() } break; case v: if ((aq.swipeDown && a9) || (!a9 && aq.allowPageScroll != t)) { a7.preventDefault() } break } } } function a4() { var a8 = aK(); var a7 = U(); var a9 = ab(); return a8 && a7 && a9 } function aT() { return !!(aq.pinchStatus || aq.pinchIn || aq.pinchOut) } function M() { return !!(a4() && aT()) } function aR() { var ba = aw(); var bc = aj(); var a9 = aK(); var a7 = U(); var a8 = a6(); var bb = !a8 && a7 && a9 && bc && ba; return bb } function S() { return !!(aq.swipe || aq.swipeStatus || aq.swipeLeft || aq.swipeRight || aq.swipeUp || aq.swipeDown) } function F() { return !!(aR() && S()) } function aK() { return ((T === aq.fingers || aq.fingers === h) || !a) } function U() { return aM[0].end.x !== 0 } function a2() { return !!(aq.tap) } function V() { return !!(aq.doubleTap) } function aQ() { return !!(aq.longTap) } function N() { if (K == null) { return false } var a7 = ao(); return (V() && ((a7 - K) <= aq.doubleTapThreshold)) } function E() { return N() } function at() { return ((T === 1 || !a) && (isNaN(ac) || ac === 0)) } function aW() { return ((Y > aq.longTapThreshold) && (ac < q)) } function ad() { return !!(at() && a2()) } function aC() { return !!(N() && V()) } function al() { return !!(aW() && aQ()) } function C() { a1 = ao(); aa = event.touches.length + 1 } function O() { a1 = 0; aa = 0 } function ai() { var a7 = false; if (a1) { var a8 = ao() - a1; if (a8 <= aq.fingerReleaseThreshold) { a7 = true } } return a7 } function ax() { return !!(aN.data(y + "_intouch") === true) } function ak(a7) { if (a7 === true) { aN.bind(au, aZ); aN.bind(R, I); if (P) { aN.bind(P, H) } } else { aN.unbind(au, aZ, false); aN.unbind(R, I, false); if (P) { aN.unbind(P, H, false) } } aN.data(y + "_intouch", a7 === true) } function ae(a8, a7) { var a9 = a7.identifier !== undefined ? a7.identifier : 0; aM[a8].identifier = a9; aM[a8].start.x = aM[a8].end.x = a7.pageX || a7.clientX; aM[a8].start.y = aM[a8].end.y = a7.pageY || a7.clientY; return aM[a8] } function aD(a7) { var a9 = a7.identifier !== undefined ? a7.identifier : 0; var a8 = Z(a9); a8.end.x = a7.pageX || a7.clientX; a8.end.y = a7.pageY || a7.clientY; return a8 } function Z(a8) { for (var a7 = 0; a7 < aM.length; a7++) { if (aM[a7].identifier == a8) { return aM[a7] } } } function af() { var a7 = []; for (var a8 = 0; a8 <= 5; a8++) { a7.push({ start: { x: 0, y: 0 }, end: { x: 0, y: 0 }, identifier: 0 }) } return a7 } function aE(a7, a8) { a8 = Math.max(a8, aP(a7)); J[a7].distance = a8 } function aP(a7) { return J[a7].distance } function X() { var a7 = {}; a7[o] = ar(o); a7[n] = ar(n); a7[d] = ar(d); a7[v] = ar(v); return a7 } function ar(a7) { return { direction: a7, distance: 0 } } function aI() { return aY - Q } function ap(ba, a9) { var a8 = Math.abs(ba.x - a9.x); var a7 = Math.abs(ba.y - a9.y); return Math.round(Math.sqrt(a8 * a8 + a7 * a7)) } function a3(a7, a8) { var a9 = (a8 / a7) * 1; return a9.toFixed(2) } function an() { if (D < 1) { return w } else { return c } } function aO(a8, a7) { return Math.round(Math.sqrt(Math.pow(a7.x - a8.x, 2) + Math.pow(a7.y - a8.y, 2))) } function aA(ba, a8) { var a7 = ba.x - a8.x; var bc = a8.y - ba.y; var a9 = Math.atan2(bc, a7); var bb = Math.round(a9 * 180 / Math.PI); if (bb < 0) { bb = 360 - Math.abs(bb) } return bb } function aH(a8, a7) { var a9 = aA(a8, a7); if ((a9 <= 45) && (a9 >= 0)) { return o } else { if ((a9 <= 360) && (a9 >= 315)) { return o } else { if ((a9 >= 135) && (a9 <= 225)) { return n } else { if ((a9 > 45) && (a9 < 135)) { return v } else { return d } } } } } function ao() { var a7 = new Date(); return a7.getTime() } function aU(a7) { a7 = e(a7); var a9 = a7.offset(); var a8 = { left: a9.left, right: a9.left + a7.outerWidth(), top: a9.top, bottom: a9.top + a7.outerHeight() }; return a8 } function B(a7, a8) { return (a7.x > a8.left && a7.x < a8.right && a7.y > a8.top && a7.y < a8.bottom) } } })(jQuery);
;
var DigiOne = DigiOne || {};

(function() {
    DigiOne.User = function() {
        var loading = new DigiOne.Loading();

        var alert = new DigiOne.Alert();

        var userService = new DigiOne.Service({ service: "user" });

        var EmptyUser = function() {
            return { name: "", lastName: "", specialist: "", email: "" };
        };

        var UserVM = function(data) {
            var self = this;
            self.id = ko.observable(data.id != null ? data.id : 0);
            self.name = ko.observable(data.name).extend({ required: true });
            self.lastName = ko.observable(data.lastName).extend({ required: true });
            self.email = ko.observable(data.email).extend({ email: true, required: true });
            self.isDirty = ko.observable(data.isTutor != null ? data.isTutor : false);

            self.isValid = ko.computed(function() {
                return self.email.isValid() && self.name.isValid() && self.lastName.isValid();
            });
        };

        var UserListVM = function() {
            var self = this;

            self.userList = ko.observableArray([]);
            self.actualUser = ko.validatedObservable();

            self.save = function() {
                if (!self.actualUser().isDirty()) {
                    self.userList.push(self.actualUser());
                }
                userService.post("post", self.saving, ko.toJSON(self.actualUser));
                self.actualUser(new UserVM(new EmptyUser()));

                $("#myModal").modal("hide");

                alert.show({ title: "User!", message: "the user was saved" });
            };

            self.saving = function(response) {
            };

            self.deleting = function(response) {
                alert.show({ title: "User!", message: "the user was deleted" });
            };

            self.edit = function(actual) {
                actual.isDirty(true);
                self.actualUser(actual);
                $("#myModal").modal("show");
            };

            self.remove = function(actual) {
                if (confirm("Do you want delete this entry?")) {
                    userService.remove("delete", self.removing, "id=" + actual.id());
                    self.userList.pop(actual);
                }
            };

            self.removing = function(result) {
                alert.show({ message: "the user was deleted" });
            };

            self.addNew = function() {
                self.actualUser(new UserVM(new EmptyUser()));
                $("#myModal").modal("show");
            };
            self.load = function() {
                userService.get("users", self.loading);
            };

            self.loading = function(response) {
                self.userList($.map(response, function(value) { return new UserVM(value); }));
            };
        };

        var mainViewModel = new UserListVM();

        return {
            init: function() {
                var users = $("#users")[0];
                if (typeof users != "undefined") {
                    mainViewModel.actualUser(new UserVM({ id: "", name: "", lastName: "", email: "", specialist: "" }));
                    mainViewModel.load();
                    ko.applyBindingsWithValidation(mainViewModel, users);
                }
            }
        };
    };
})();;
