• File: unitecreator_addon_preview_admin.js
  • Full Path: /home/bravrvjk/hpgt.org/wp-content/plugins/unlimited-elements-for-elementor/js/unitecreator_addon_preview_admin.js
  • Date Modified: 11/17/2025 8:45 PM
  • File size: 3.92 KB
  • MIME-type: text/plain
  • Charset: utf-8
"use strict";

function UniteAddonPreviewAdmin() {
	var g_objPreview, g_addonID, g_requestPreview;
	var g_helper = new UniteCreatorHelper();
	var g_settings = new UniteSettingsUC();
	var that = this;

	if (!g_ucAdmin)
		var g_ucAdmin = new UniteAdminUC();

	/**
	 * init the view
	 */
	this.init = function () {
		boot();

		loadSettings(function () {
			refreshPreview();
		});
	};

	/**
	 * init the view by slot
	 */
	this.initBySlot = function (slot) {
		boot();

		loadSettings(function () {
			that.restoreSlot(slot);
		});
	};

	/**
	 * get addon id
	 */
	this.getAddonId = function () {
		return g_addonID;
	};

	/**
	 * get settings values
	 */
	this.getSettingsValues = function () {
		return g_settings.getSettingsValues();
	};

	/**
	 * clear settings
	 */
	this.clearSettings = function () {
		g_settings.clearSettings();

		refreshPreview();
	};

	/**
	 * get selectors css
	 */
	this.getSelectorsCss = function () {
		return g_settings.getSelectorsCss();
	};

	/**
	 * restore slot
	 */
	this.restoreSlot = function (slot) {
		var data = {
			id: g_addonID,
			slotnum: slot,
			combine: true,
		};

		g_ucAdmin.ajaxRequest("get_test_addon_data", data, function (response) {
			var values = g_ucAdmin.getVal(response, "settings_values");

			trace("restoring settings:");
			trace(values);

			if (!values) {
				trace("no settings found");
				return;
			}

			g_settings.setValues(values);

			refreshPreview();
		});
	};

	/**
	 * boot the view
	 */
	function boot() {
		g_addonID = jQuery("#uc_preview_addon_wrapper").data("addonid");
		g_objPreview = jQuery("#uc_preview_wrapper");

		g_settings.setSelectorWrapperID("uc_preview_wrapper");
	}

	/**
	 * load settings
	 */
	function loadSettings(onSuccess) {

		g_ucAdmin.setAjaxLoaderID("uc_settings_loader");

		const urlParams = new URLSearchParams(window.location.search);
		const isTestFreeVersion = urlParams.get("testfreeversion") === "true";

		const requestData = {
			id: g_addonID
		};

		if (isTestFreeVersion) {
			requestData.testfreeversion = true;
		}

		g_ucAdmin.ajaxRequest("get_addon_settings_html", requestData, function (response) {
			initSettingsByHtml(response.html);

			if (typeof onSuccess === "function")
				onSuccess();
		});
	}

	/**
	 * init settings by its html
	 */
	function initSettingsByHtml(html) {
		var objSettingsWrapper = jQuery("#uc_settings_wrapper");

		objSettingsWrapper.html(html);

		g_settings.init(objSettingsWrapper);
		g_settings.setEventOnChange(refreshPreview);
		g_settings.setEventOnSelectorsChange(handleSelectorsChange);
	}

	/**
	 * handle selectors change
	 */
	function handleSelectorsChange() {
		updateSelectorsIncludes();
		updateSelectorsStyles();
	}

	/**
	 * update selectors includes (like google font)
	 */
	function updateSelectorsIncludes() {
		var includes = g_settings.getSelectorsIncludes();

		if (includes)
			g_helper.putIncludes(window, includes);
	}

	/**
	 * update selectors styles
	 */
	function updateSelectorsStyles() {
		var css = g_settings.getSelectorsCss();

		jQuery("[name=uc_selectors_css]").text(css);
	}

	/**
	 * refresh preview
	 */
	function refreshPreview() {
		
		var values = g_settings.getSettingsValues();
		
		var valuesStr = g_ucAdmin.encodeObjectForSave(values);
				
		var data = {
			id: g_addonID,
			settings: valuesStr,
			selectors: true,
			debug: 2,
		};
		
		g_ucAdmin.setAjaxLoaderID("uc_preview_loader");

		if (g_requestPreview)
			g_requestPreview.abort();
		
		g_requestPreview = g_ucAdmin.ajaxRequest("get_addon_output_data", data, function (response) {
			var html = g_ucAdmin.getVal(response, "html");
			var includes = g_ucAdmin.getVal(response, "includes");

			g_helper.putIncludes(window, includes, function () {
				g_objPreview.html(html);
			});
		}).done(function (response) {
			var success = g_ucAdmin.getVal(response, "success");
			var message = g_ucAdmin.getVal(response, "message");

			if (success === false)
				g_objPreview.html("<span style='color:red'><b>Error:</b> " + message + "</span>");
		});
	}
}