Uname: Linux premium264.web-hosting.com 4.18.0-553.lve.el8.x86_64 #1 SMP Mon May 27 15:27:34 UTC 2024 x86_64
Software: LiteSpeed
PHP version: 8.3.22 [ PHP INFO ] PHP os: Linux
Server Ip: 69.57.162.13
Your Ip: 216.73.216.219
User: workvvfb (1129) | Group: workvvfb (1084)
Safe Mode: OFF
Disable Function:
NONE

name : critical-wizard.js
/**
 * Javascript Library for Critical Wizard Admin
 * 
 * Generate Critical CSS
 * 
 * @author     P-THEMES
 * @since      2.3.0
 * @package    Porto
 * @subpackage Core
 */
'use strict';

window.themeAdmin = window.themeAdmin || {};

( function ( $ ) {
    /**
     * @since 2.3.0
     */
    var criticalWizard = {
        $form: $( '#porto-critical-form' ),
        $tableForm: $( '#porto-critical-table-form' ),
        $progressBar: $( '.porto-progress-bar' ),
        criticalDone: 0,
        criticalTodo: 0,
        init: function () {
            // Init select 2
            var $selectParticular = $( '#porto-select-particular' );
            $selectParticular.select2( {
                placeholder: $selectParticular.attr( 'data-placeholder' ),
            } );
            // Page Type On Change
            $( '#porto-critical-page' ).on( 'change', function () {
                if ( $( this ).val() == 'individual_pages' ) {
                    $( 'label[for=porto-select-particular]' ).removeClass( 'disabled' );
                } else {
                    $( 'label[for=porto-select-particular]' ).addClass( 'disabled' );
                }
            } );
            if ( $( '.temp-iframe' ).length == 0 ) {
                $( 'body' ).append( '<iframe class="temp-iframe" style="max-width: none; max-height: none; border: 0px;" aria-hidden="true" sandbox="allow-same-origin "></iframe>' );
            }
            this.$form.on( 'submit', function ( e ) {
                e.preventDefault();
                themeAdmin.criticalWizard.$progressBar.css( { width: '0' } );
                themeAdmin.criticalWizard.$progressBar.removeClass( 'failed' );
                $( this ).find( 'button' ).addClass( 'disabled' ).html( '<i class="fas fa-spinner fa-spin"></i> ' + wp.i18n.__( 'Generating Critical', 'porto-functionality' ) );
                $.post(
                    ajaxurl,
                    themeAdmin.criticalWizard.$form.serialize(),
                    async function ( response ) {
                        if ( typeof response.data == 'object' ) {
                            var urls = response.data;
                            var length = Object.keys( urls ).length;
                            if ( length == 0 ) return;
                            // 10% progress bar
                            themeAdmin.criticalWizard.$progressBar.css( { width: '10%' } );
                            // Initialize 
                            themeAdmin.criticalWizard.criticalDone = 0;
                            themeAdmin.criticalWizard.criticalTodo = length;
                            var urlKeys = Object.keys( urls );
                            for ( var i = 0; i < urlKeys.length; i++ ) {
                                var id = urlKeys[ i ];
                                var pageCriticalCss = {};
                                // desktop
                                await themeAdmin.criticalCss.main( urls[ id ].desktop );
                                pageCriticalCss[ 'desktop' ] = {
                                    css: themeAdmin.criticalCss.resultCriticalCss,
                                    preload: themeAdmin.criticalCss.resultPreload,
                                };
                                // mobile
                                await themeAdmin.criticalCss.main( urls[ id ].mobile, 'mobile', true );
                                pageCriticalCss[ 'mobile' ] = {
                                    css: themeAdmin.criticalCss.resultCriticalCss,
                                    preload: themeAdmin.criticalCss.resultPreload,
                                };

                                // to Server
                                await $.post(
                                    ajaxurl,
                                    {
                                        action: 'porto_save_critical',
                                        id: id,
                                        pageCriticalCss: pageCriticalCss,
                                        _wpnonce: themeAdmin.criticalWizard.$tableForm.data( 'nonce' )
                                    },
                                    function ( response ) {
                                        console.log( response );
                                    }
                                );
                            }
                            // to Server
                            await $.post(
                                ajaxurl,
                                {
                                    action: 'porto_clear_merged_css',
                                    _wpnonce: themeAdmin.criticalWizard.$tableForm.data( 'nonce' )
                                },
                                function ( response ) {
                                }
                            );
                            themeAdmin.criticalWizard.$progressBar.css( { width: '101%' } ); // because can't show progress rounded.                            
                        }
                        location.reload( true );
                        // themeAdmin.criticalWizard.$form.find( 'button' ).removeClass( 'disabled' ).html( wp.i18n.__( 'Generating Critical CSS', 'porto-functionality' ) );
                    }
                );
            } );
            this.$tableForm.on( 'click', '.porto-recompile-row', function ( e ) {
                e.preventDefault();
                var $this = $( this );
                if ( $this.hasClass( 'disabled' ) ) {
                    return false;
                }
                themeAdmin.criticalWizard.$progressBar.css( { width: '0' } );
                themeAdmin.criticalWizard.$progressBar.removeClass( 'failed' );
                themeAdmin.criticalWizard.$tableForm.find( '.button' ).addClass( 'disabled' );
                $this.html( '<i class="fas fa-spinner fa-spin"></i> ' + wp.i18n.__( 'Recompile', 'porto-functionality' ) );
                $.post(
                    ajaxurl,
                    {
                        action: 'porto_critical_get_page',
                        porto_critical_page: 'individual_pages',
                        porto_select_particular: $this.closest( 'tr' ).attr( 'data-page-id' ),
                        porto_critical_nonce: themeAdmin.criticalWizard.$tableForm.attr( 'data-nonce' ),
                    },
                    async function ( response ) {
                        if ( typeof response.data == 'object' ) {
                            var urls = response.data;
                            var length = Object.keys( urls ).length;
                            if ( length == 0 ) return;
                            // 10% progress bar
                            themeAdmin.criticalWizard.$progressBar.css( { width: '10%' } );
                            // Initialize 
                            themeAdmin.criticalWizard.criticalDone = 0;
                            themeAdmin.criticalWizard.criticalTodo = length;

                            var pageCriticalCss = {};
                            var id = Object.keys( urls )[ 0 ];
                            // desktop
                            await themeAdmin.criticalCss.main( urls[ id ].desktop );
                            pageCriticalCss[ 'desktop' ] = {
                                css: themeAdmin.criticalCss.resultCriticalCss,
                                preload: themeAdmin.criticalCss.resultPreload,
                            };
                            // mobile
                            await themeAdmin.criticalCss.main( urls[ id ].mobile, 'mobile', true );
                            pageCriticalCss[ 'mobile' ] = {
                                css: themeAdmin.criticalCss.resultCriticalCss,
                                preload: themeAdmin.criticalCss.resultPreload,
                            };

                            // to Server
                            await $.post(
                                ajaxurl,
                                {
                                    action: 'porto_save_critical',
                                    id: id,
                                    pageCriticalCss: pageCriticalCss,
                                    _wpnonce: themeAdmin.criticalWizard.$tableForm.data( 'nonce' )
                                },
                                function ( response ) {
                                    console.log( response );
                                }
                            );
                            await $.post(
                                ajaxurl,
                                {
                                    action: 'porto_clear_merged_css',
                                    _wpnonce: themeAdmin.criticalWizard.$tableForm.data( 'nonce' )
                                },
                                function ( response ) {
                                }
                            );
                            themeAdmin.criticalWizard.$progressBar.css( { width: '101%' } ); // because can't show progress rounded.
                        }
                        location.reload( true );
                        // themeAdmin.criticalWizard.$form.find( 'button' ).removeClass( 'disabled' ).html( wp.i18n.__( 'Generating Critical CSS', 'porto-functionality' ) );
                    }
                );
            } );
            this.$tableForm.on( 'submit', function ( e ) {

                var $this = $( this );
                if ( $this.find( '#bulk-action-selector-top' ).val() == 'porto_bulk_delete_critical' ) return;
                e.preventDefault();
                if ( $this.find( '#bulk-action-selector-top' ).val() == '-1' ) return;
                // regenerate
                themeAdmin.criticalWizard.$tableForm.find( '.button' ).addClass( 'disabled' );
                $this.find( '.button.action' ).html( '<i class="fas fa-spinner fa-spin"></i> ' + wp.i18n.__( 'Apply', 'porto-functionality' ) );

                themeAdmin.criticalWizard.$progressBar.css( { width: '0' } );
                themeAdmin.criticalWizard.$progressBar.removeClass( 'failed' );
                var recompilePages = [];
                $this.find( 'tbody tr' ).each( function () {
                    if ( $( this ).find( 'input[type="checkbox"]' ).is( ':checked' ) ) {
                        recompilePages.push( $( this ).attr( 'data-page-id' ) );
                    }
                } );
                $.post(
                    ajaxurl,
                    {
                        action: 'porto_critical_get_page',
                        porto_critical_page: 'individual_pages',
                        'porto_select_particular[]': recompilePages,
                        porto_critical_nonce: $this.attr( 'data-nonce' ),
                    },
                    async function ( response ) {
                        if ( typeof response.data == 'object' ) {
                            var urls = response.data;
                            var length = Object.keys( urls ).length;
                            if ( length == 0 ) return;
                            // 10% progress bar
                            themeAdmin.criticalWizard.$progressBar.css( { width: '10%' } );
                            // Initialize 
                            themeAdmin.criticalWizard.criticalDone = 0;
                            themeAdmin.criticalWizard.criticalTodo = length;
                            var urlKeys = Object.keys( urls );
                            for ( var i = 0; i < urlKeys.length; i++ ) {
                                var id = urlKeys[ i ];
                                var pageCriticalCss = {};
                                // desktop
                                await themeAdmin.criticalCss.main( urls[ id ].desktop );
                                pageCriticalCss[ 'desktop' ] = {
                                    css: themeAdmin.criticalCss.resultCriticalCss,
                                    preload: themeAdmin.criticalCss.resultPreload,
                                };
                                // mobile
                                await themeAdmin.criticalCss.main( urls[ id ].mobile, 'mobile', true );
                                pageCriticalCss[ 'mobile' ] = {
                                    css: themeAdmin.criticalCss.resultCriticalCss,
                                    preload: themeAdmin.criticalCss.resultPreload,
                                };
                                // to Server
                                await $.post(
                                    ajaxurl,
                                    {
                                        action: 'porto_save_critical',
                                        id: id,
                                        pageCriticalCss: pageCriticalCss,
                                        _wpnonce: themeAdmin.criticalWizard.$tableForm.data( 'nonce' )
                                    },
                                    function ( response ) {
                                        console.log( response );
                                    }
                                );
                            }
                            await $.post(
                                ajaxurl,
                                {
                                    action: 'porto_clear_merged_css',
                                    _wpnonce: themeAdmin.criticalWizard.$tableForm.data( 'nonce' )
                                },
                                function ( response ) {
                                }
                            );
                            themeAdmin.criticalWizard.$progressBar.css( { width: '101%' } ); // because can't show progress rounded.
                        }
                        location.reload( true );
                        // themeAdmin.criticalWizard.$form.find( 'button' ).removeClass( 'disabled' ).html( wp.i18n.__( 'Generating Critical CSS', 'porto-functionality' ) );
                    }
                );

            } );
        }
    }
    /**
     * Setup Critical Wizard
     * 
     * @since 2.3.0
     */
    themeAdmin.criticalWizard = criticalWizard;
    $( document ).ready( function () {
        criticalWizard.init();
    } );
} )( window.jQuery );
© 2025 GrazzMean