File "setup-udb.ts"

Full Path: /home/pumpbmko/public_html/wp-content/plugins/kirki/kirki-packages/settings/src/setup-udb.ts
File size: 6.98 KB
MIME-type: text/x-java
Charset: utf-8

import { emptyElement, getClosest, startLoading, stopLoading } from "./utils";
import jQuery from "jquery";

declare var wp: any;
declare var kirkiSettings: any;
declare var ajaxurl: any;

export default function setupUdb() {
	const adminPage: HTMLElement | null = document.querySelector(
		".kirki-settings-page"
	);
	if (!adminPage) return;

	const progressBox: HTMLElement | null = adminPage.querySelector(
		".installation-progress-metabox"
	);
	if (!progressBox) return;

	const progressList: HTMLElement | null = progressBox.querySelector(
		".installation-progress-list"
	);
	if (!progressList) return;

	let doingAjax = false;
	const udbData = kirkiSettings.recommendedPlugins.udb;

	document.addEventListener("click", handleDocumentClick);

	function handleDocumentClick(e: Event) {
		const button = getClosest(e.target as HTMLElement, ".kirki-install-udb");
		if (!button) return;

		e.preventDefault();
		prepareUdb(button);
	}

	function prepareUdb(button: HTMLElement) {
		if (!adminPage) return;
		if (doingAjax) return;
		startProcessing(button);
		addProgress("Preparing...", "loading");

		const nonce = adminPage.dataset.setupUdbNonce
			? adminPage.dataset.setupUdbNonce
			: "";

		jQuery
			.ajax({
				url: ajaxurl,
				method: "POST",
				data: {
					action: "kirki_prepare_install_udb",
					nonce: nonce,
				},
			})
			.done(function (response) {
				if (!response.success) {
					modifyPreviousProgress(response.data, "failed");
					stopProcessing(button, "");
					return;
				}

				if (response.data.finished) {
					modifyPreviousProgress(
						"Ultimate Dashboard has already been installed.",
						"done"
					);
					addProgress(response.data.message, "done");
					addProgress("All done! Redirecting...", "loading");
					stopProcessing(button, udbData.redirectUrl);
					return;
				}

				modifyPreviousProgress(response.data.message, "done");
				doingAjax = false;
				installUdb(button);
			})
			.fail(function (jqXHR) {
				let errorMessage: string =
					"Something went wrong. Please try again later.";

				if (jqXHR.responseJSON && jqXHR.responseJSON.data) {
					errorMessage = jqXHR.responseJSON.data;
				}

				modifyPreviousProgress(errorMessage, "failed");
				stopProcessing(button, "");
			});
	}

	function installUdb(button: HTMLElement) {
		if (doingAjax) return;
		doingAjax = true;
		addProgress("Installing Ultimate Dashboard", "loading");

		wp.updates.installPlugin({
			slug: udbData.slug,
			success: function () {
				modifyPreviousProgress(
					"Ultimate Dashboard has been installed successfully",
					"done"
				);
				doingAjax = false;
				activateUdb(button);
			},
			error: function (jqXHR: any) {
				let abort = true;

				if (jqXHR.errorCode && jqXHR.errorMessage) {
					if (jqXHR.errorCode === "folder_exists") {
						modifyPreviousProgress(
							"Ultimate Dashboard has already been installed.",
							"done"
						);

						doingAjax = false;
						abort = false;

						// Since the plugin has already installed since before, let's activate it.
						activateUdb(button);
					} else {
						modifyPreviousProgress(jqXHR.errorMessage, "failed");
					}
				} else {
					if (jqXHR.responseJSON && jqXHR.responseJSON.data) {
						modifyPreviousProgress(jqXHR.responseJSON.data, "failed");
					} else {
						modifyPreviousProgress(
							"Something went wrong. Please try again later.",
							"failed"
						);
					}
				}

				if (abort) stopProcessing(button, "");
			},
		});
	}

	function activateUdb(button: HTMLElement) {
		if (doingAjax) return;
		doingAjax = true;
		addProgress("Activating Ultimate Dashboard", "loading");

		jQuery.ajax({
			async: true,
			type: "GET",
			url: udbData.activationUrl,
			success: function () {
				modifyPreviousProgress(
					"Ultimate Dashboard has been activated successfully.",
					"done"
				);

				addProgress("All done! Redirecting...", "loading");
				stopProcessing(button, udbData.redirectUrl);
			},
			error: function (jqXHR: any) {
				if (jqXHR.errorCode && jqXHR.errorMessage) {
					modifyPreviousProgress(jqXHR.errorMessage, "failed");
				} else {
					if (jqXHR.responseJSON && jqXHR.responseJSON.data) {
						modifyPreviousProgress(jqXHR.responseJSON.data, "failed");
					} else {
						modifyPreviousProgress(
							"Something went wrong. Please try again later.",
							"failed"
						);
					}
				}

				stopProcessing(button, "");
			},
		});
	}

	function addProgress(text: string, status: string) {
		if (!progressList) return;
		const li = document.createElement("li");
		li.className = "installation-progress";

		if (status === "done") {
			li.classList.add("is-done");
		} else if (status === "failed") {
			li.classList.add("is-failed");
		} else {
			li.classList.add("is-loading");
		}

		const iconDiv = document.createElement("div");
		iconDiv.className = "progress-icon";
		li.appendChild(iconDiv);

		const textDiv = document.createElement("div");
		textDiv.className = "progress-text";
		textDiv.innerHTML = text;
		li.appendChild(textDiv);

		progressList.appendChild(li);
	}

	function modifyPreviousProgress(text: string, status: string) {
		if (!progressList) return;
		const li = progressList.querySelector(".installation-progress:last-child");
		if (!li) return;

		if (status === "done") {
			li.classList.remove("is-loading");
			li.classList.add("is-done");
		} else if (status === "failed") {
			li.classList.remove("is-loading");
			li.classList.add("is-failed");
		} else {
			li.classList.remove("is-done");
			li.classList.remove("is-failed");
			li.classList.add("is-loading");
		}

		if (text) {
			const textDiv = li.querySelector(".progress-text");
			if (!textDiv) return;
			textDiv.innerHTML = text;
		}
	}

	function disableOrEnableOtherButtons(
		actionType: string,
		currentButton: HTMLElement | HTMLButtonElement
	) {
		const buttons = document.querySelectorAll(".kirki-install-udb");
		if (!buttons.length) return;

		buttons.forEach((button) => {
			if (actionType === "disable") {
				if (currentButton && button === currentButton) return;
			}

			if (button.tagName.toLowerCase() === "button") {
				if (actionType === "disable") {
					// button.setAttribute("disabled", "disabled");
					button.classList.add("is-loading");
				} else {
					// button.removeAttribute("disabled");
					button.classList.remove("is-loading");
				}
			} else {
				if (actionType === "disable") {
					// button.classList.add("is-disabled");
					button.classList.add("is-loading");
				} else {
					// button.classList.remove("is-disabled");
					button.classList.remove("is-loading");
				}
			}
		});
	}

	function startProcessing(button: HTMLElement) {
		if (progressBox && progressList) {
			emptyElement(progressList);
			progressBox.classList.remove("is-hidden");
		}

		doingAjax = true;
		disableOrEnableOtherButtons("disable", button);
		startLoading(button);
	}

	function stopProcessing(button: HTMLElement, redirectUrl: string) {
		if (redirectUrl) {
			window.setTimeout(() => {
				window.location.replace(redirectUrl);
			}, 1000);
		}

		stopLoading(button);
		doingAjax = false;
		disableOrEnableOtherButtons("enable", button);
	}
}