323 lines
22 KiB
PHP
Raw Normal View History

2024-05-20 15:37:46 +03:00
<?php
// no direct access
if (! isset($data)) {
exit;
}
// Show areas by:
// "Plugins", "Themes" (parent theme and child theme), "WordPress Core"
// External locations (outside plugins and themes)
// 3rd party external locations (e.g. Google API Fonts, CND urls such as the ones for Bootstrap etc.)
$listAreaStatus = $data['plugin_settings']['assets_list_layout_areas_status'];
$pluginsAreaStatus = $data['plugin_settings']['assets_list_layout_plugin_area_status'] ?: 'expanded';
/*
* -------------------------
* [START] BY EACH LOCATION
* -------------------------
*/
if (! empty($data['all']['styles']) || ! empty($data['all']['scripts'])) {
require_once __DIR__.'/_assets-top-area.php';
if (! function_exists('get_plugins') && ! is_admin()) {
require_once ABSPATH . 'wp-admin/includes/plugin.php';
}
$allPlugins = get_plugins();
$allThemes = wp_get_themes();
$allActivePluginsIcons = \WpAssetCleanUp\Misc::getAllActivePluginsIcons();
$data['view_by_location'] =
$data['rows_build_array'] =
$data['rows_by_location'] = true;
$data['rows_assets'] = array();
require_once __DIR__.'/_asset-style-rows.php';
require_once __DIR__.'/_asset-script-rows.php';
$locationsText = array(
'plugins' => '<span class="dashicons dashicons-admin-plugins"></span> '.esc_html__('From Plugins', 'wp-asset-clean-up').' (.css &amp; .js)',
'themes' => '<span class="dashicons dashicons-admin-appearance"></span> '.esc_html__('From Themes', 'wp-asset-clean-up').' (.css &amp; .js)',
'uploads' => '<span class="dashicons dashicons-wordpress"></span> '.esc_html__('WordPress Uploads Directory', 'wp-asset-clean-up').' (.css &amp; .js)',
'wp_core' => '<span class="dashicons dashicons-wordpress"></span> '.esc_html__('WordPress Core', 'wp-asset-clean-up').' (.css &amp; .js)',
'external' => '<span class="dashicons dashicons-cloud"></span> '.esc_html__('External 3rd Party', 'wp-asset-clean-up').' (.css &amp; .js)'
);
if (! empty($data['rows_assets'])) {
// Sorting: Plugins, Themes, Uploads Directory and External Assets
$rowsAssets = array('plugins' => array(), 'themes' => array(), 'uploads' => array(), 'wp_core' => array(), 'external' => array());
foreach ($data['rows_assets'] as $locationMain => $values) {
$rowsAssets[$locationMain] = $values;
}
foreach ($rowsAssets as $locationMain => $values) {
ksort($values);
$totalLocationAssets = count($values);
$hideLocationMainArea = ($locationMain === 'uploads' && $totalLocationAssets === 0);
$hideListOfAssetsOnly = ($locationMain === 'wp_core' && $data['plugin_settings']['hide_core_files']);
$contractExpandAllAssetsHtml = <<<HTML
<div class="wpacu-area-toggle-all-assets wpacu-right">
<a class="wpacu-area-contract-all-assets wpacu_area_handles_row_expand_contract"
data-wpacu-area="{$locationMain}" href="#">Contract</a>
|
<a class="wpacu-area-expand-all-assets wpacu_area_handles_row_expand_contract"
data-wpacu-area="{$locationMain}" href="#">Expand</a>
All Assets
</div>
HTML;
ob_start();
?>
<div <?php if ($hideLocationMainArea) {
echo 'style="display: none;"';
} ?> class="wpacu-assets-collapsible-wrap wpacu-by-location wpacu-<?php echo esc_attr($locationMain); ?>">
<a class="wpacu-assets-collapsible <?php if ($listAreaStatus !== 'contracted') { ?>wpacu-assets-collapsible-active<?php } ?>"
href="#wpacu-assets-collapsible-content-<?php echo esc_attr($locationMain); ?>">
<?php echo wp_kses($locationsText[$locationMain], array('span' => array('class' => array()))); ?> &#10141; Total files: {total_files_<?php echo esc_html($locationMain); ?>}
</a>
<div class="wpacu-assets-collapsible-content <?php if ($listAreaStatus !== 'contracted') { ?>wpacu-open<?php } ?>">
<?php if ($locationMain === 'external') { ?>
<div class="wpacu-assets-note wpacu-with-toggle-all-assets"><strong>Note:</strong> External .css and .js assets are considered
those who are hosted on a different domain (e.g. Google Font API, assets loaded from external
CDNs) and the ones outside the WordPress "plugins" (usually /wp-content/plugins/), "themes"
(usually /wp-content/themes/) and "uploads" (usually /wp-content/uploads/) directories.</div>
<?php if (count($values) > 0) { echo $contractExpandAllAssetsHtml; } ?>
<?php
// WP Core CSS/JS list is visible
} elseif ($locationMain === 'wp_core' && ! $data['plugin_settings']['hide_core_files']) { ?>
<div class="wpacu-assets-note wpacu-with-toggle-all-assets"><span style="color: red;" class="dashicons dashicons-warning"></span> <strong>Warning:</strong> Please be careful when doing any changes to the
following core assets as they can break the functionality of the front-end website. If you're
not sure about unloading any asset, just leave it loaded.</div>
<?php if (count($values) > 0) { echo $contractExpandAllAssetsHtml; } ?>
<?php
// WP Core CSS/JS list is hidden
} elseif ($locationMain === 'wp_core' && $data['plugin_settings']['hide_core_files']) {
?>
<div class="wpacu-assets-note"><strong>Note:</strong> By default, <?php echo WPACU_PLUGIN_TITLE; ?> does not show the list of CSS/JS loaded from the WordPress core. Usually, WordPress core files are loaded for a reason and this setting was applied to prevent accidental unload of files that could be needed (e.g. jQuery library, Underscore library etc.).</div>
<div class="wpacu-assets-note"><span class="dashicons dashicons-info"></span> If you believe that you do not need some loaded core files (e.g. WordPress Gutenberg styling - Handle: 'wp-block-library') and you want to manage the files loaded from <em>/wp-includes/</em>, you can go to the plugin's <strong>"Settings"</strong>, click on the <strong>"Plugin Usage Preferences"</strong> tab, scroll to <strong>"Hide WordPress Core Files From The Assets List?"</strong> and make sure the option <strong>is turned off</strong>.</div>
<?php
} elseif ($locationMain === 'uploads') { ?>
<div class="wpacu-assets-note" style="padding: 15px 15px 0 0;"><strong>Note:</strong> These are the
CSS/JS files load from the /wp-content/uploads/ WordPress directory. They were copied there by
other plugins or developers working on the website. In case the file was detected to be
generated by a specific plugin through various verification patterns (e.g. for plugins such as
Elementor, Oxygen Builder etc.), then it will be not listed here, but in the "From Plugins (.css
&amp; .js)" area for the detected plugin. This is to have all the files related to a plugin
organised in one place.</div>
<?php if (count($values) > 0) { echo $contractExpandAllAssetsHtml; } ?>
<?php
}
?>
<?php
$locationRowCount = 0;
$totalLocationAssets = count($values);
// Total files from all the plugins
$totalFilesArray[$locationMain] = 0;
// Default value (not contracted)
$pluginListContracted = false;
if ($totalLocationAssets > 0) {
$locI = 1;
// Going through each plugin/theme etc.
foreach ( $values as $locationChild => $values2 ) {
if ($locationMain === 'plugins') {
$totalPluginAssets = $totalBulkUnloadedAssetsPerPlugin = 0;
}
ksort( $values2 );
$assetRowsOutput = '';
// Going through each asset from the plugin/theme
foreach ( $values2 as $assetType => $assetRows ) {
foreach ( $assetRows as $assetRow ) {
$assetRowsOutput .= $assetRow . "\n";
if ( $locationMain === 'plugins' ) {
if (strpos( $assetRow, 'wpacu_is_bulk_unloaded' ) !== false ) {
$totalBulkUnloadedAssetsPerPlugin ++;
}
$totalPluginAssets ++;
}
$totalFilesArray[$locationMain] ++;
}
}
if ( $locationChild !== 'none' ) {
if ( $locationMain === 'plugins' ) {
$locationChildText = \WpAssetCleanUp\Info::getPluginInfo( $locationChild, $allPlugins, $allActivePluginsIcons );
$isLastPluginAsset = ( count( $values ) - 1 ) === $locationRowCount;
$pluginListContracted = ( $locationMain === 'plugins' && $pluginsAreaStatus === 'contracted' );
// Show it if there is at least one available "Unload on this page"
$showUnloadOnThisPageCheckUncheckAll = $totalPluginAssets !== $totalBulkUnloadedAssetsPerPlugin;
// Show it if all the assets from the plugin are bulk unloaded
$showLoadItOnThisPageCheckUncheckAll = $totalBulkUnloadedAssetsPerPlugin === $totalPluginAssets;
} elseif ( $locationMain === 'themes' ) {
$locationChildThemeArray = \WpAssetCleanUp\Info::getThemeInfo( $locationChild, $allThemes );
$locationChildText = $locationChildThemeArray['output'];
} else {
$locationChildText = $locationChild;
}
$extraClassesToAppend = '';
if ( $locationMain === 'plugins' && $isLastPluginAsset ) {
$extraClassesToAppend .= ' wpacu-area-last ';
}
if ($locI === 1) {
$extraClassesToAppend .= ' wpacu-location-child-area-first ';
}
// PLUGIN LIST: VIEW THEIR ASSETS
// EXPANDED (DEFAULT)
if ( $locationMain === 'plugins' ) {
if ( $pluginListContracted ) {
// CONTRACTED (+ -)
?>
<a href="#"
class="wpacu-plugin-contracted-wrap-link wpacu-pro wpacu-link-closed <?php if ( ( count( $values ) - 1 ) === $locationRowCount ) { echo 'wpacu-last-wrap-link'; } ?>">
<div class="wpacu-plugin-title-contracted wpacu-area-contracted">
<?php echo wp_kses($locationChildText, array('div' => array('class' => array(), 'style' => array()), 'span' => array('class' => array()))); ?> <span style="font-weight: 200;">/</span> <span style="font-weight: 400;"><?php echo (int)$totalPluginAssets; ?></span> files
</div>
</a>
<?php
} else { ?>
<div data-wpacu-plugin="<?php echo esc_attr($locationChild); ?>"
data-wpacu-area="<?php echo esc_attr($locationChild); ?>_plugin"
class="wpacu-location-child-area wpacu-area-expanded <?php echo esc_attr($extraClassesToAppend); ?>">
<div class="wpacu-area-title">
<?php echo wp_kses($locationChildText, array('div' => array('class' => array(), 'style' => array()), 'span' => array('class' => array()))); ?> <span style="font-weight: 200;">/</span> <span style="font-weight: 400;"><?php echo (int)$totalPluginAssets; ?></span> files
<?php
include '_view-by-location/_plugin-list-expanded-actions.php';
?>
</div>
<div class="wpacu-area-toggle-all-assets">
<a class="wpacu-area-contract-all-assets wpacu_area_handles_row_expand_contract"
data-wpacu-area="<?php echo esc_html($locationChild); ?>_plugin" href="#">Contract</a>
|
<a class="wpacu-area-expand-all-assets wpacu_area_handles_row_expand_contract"
data-wpacu-area="<?php echo esc_html($locationChild); ?>_plugin" href="#">Expand</a>
All Assets
</div>
</div>
<?php }
} elseif ( $locationMain === 'themes' ) {
?>
<div data-wpacu-area="<?php echo esc_attr($locationChild); ?>_theme"
class="wpacu-location-child-area wpacu-area-expanded <?php echo esc_attr($extraClassesToAppend); ?>">
<div class="wpacu-area-title <?php if ($locationChildThemeArray['has_icon'] === true) { echo 'wpacu-theme-has-icon'; } ?>"><?php echo \WpAssetCleanUp\Misc::stripIrrelevantHtmlTags($locationChildText); ?></div>
<div class="wpacu-area-toggle-all-assets">
<a class="wpacu-area-contract-all-assets wpacu_area_handles_row_expand_contract"
data-wpacu-area="<?php echo esc_html($locationChild); ?>_theme" href="#">Contract</a>
|
<a class="wpacu-area-expand-all-assets wpacu_area_handles_row_expand_contract"
data-wpacu-area="<?php echo esc_html($locationChild); ?>_theme" href="#">Expand</a>
All Assets
</div>
</div>
<?php
} else { // WordPress Core, Uploads, 3rd Party etc.
?>
<div data-wpacu-area="<?php echo esc_attr($locationChild); ?>"
class="wpacu-location-child-area wpacu-area-expanded <?php echo esc_attr($extraClassesToAppend); ?>">
<div class="wpacu-area-title"><?php echo wp_kses($locationChildText, array('div' => array('class' => array(), 'style' => array()), 'span' => array('class' => array()))); ?></div>
</div>
<?php
}
}
?>
<div class="wpacu-assets-table-list-wrap <?php if ( $locationMain === 'plugins' ) { echo ' wpacu-area-assets-wrap '; }
if ( $pluginListContracted ) {
echo ' wpacu-area-closed ';
if (isset($isLastPluginAsset) && $isLastPluginAsset) {
echo ' wpacu-area-assets-last ';
}
} ?>">
<?php
// CONTRACTED (+ -)
if ( $locationMain === 'plugins' && $pluginListContracted ) {
include '_view-by-location/_plugin-list-contracted-actions.php';
}
?>
<table <?php
if ( $locationMain === 'plugins' ) { echo ' data-wpacu-plugin="' . esc_attr($locationChild) . '" data-wpacu-area="' . esc_attr($locationChild) . '_plugin" '; }
if ( $locationMain === 'themes' ) { echo ' data-wpacu-area="' . esc_attr($locationChild) . '_theme" '; }
if ( in_array($locationMain, array('uploads', 'wp_core', 'external') ) ) { echo ' data-wpacu-area="' . esc_attr($locationMain) . '" '; }
?>
class="wpacu_list_table wpacu_list_by_location wpacu_widefat wpacu_striped">
<tbody>
<?php
if ( $locationMain === 'plugins' ) {
do_action('wpacu_assets_plugin_notice_table_row', $locationChild);
}
echo \WpAssetCleanUp\Misc::stripIrrelevantHtmlTags($assetRowsOutput);
?>
</tbody>
</table>
</div>
<?php
$locationRowCount ++;
}
} else {
// There are no loaded CSS/JS
$showOxygenMsg = $locationMain === 'themes' && in_array('oxygen/functions.php', \WpAssetCleanUp\Misc::getActivePlugins());
if ($showOxygenMsg) {
?>
<div style="padding: 12px 0;">
<img style="height: 30px; vertical-align: bottom;" src="" alt="" />
&nbsp;You're using <a href="<?php echo esc_url(admin_url('admin.php?page=ct_dashboard_page')); ?>" target="_blank"><span style="font-weight: 600; color: #6036ca;">Oxygen</span></a> to design your site, which disables the WordPress theme system. Thus, no assets related to the theme are loaded.
</div>
<?php } else { ?>
<div style="padding: 0 0 16px 16px;"><?php _e('There are no CSS/JS loaded from this location.', 'wp-asset-clean-up'); ?></div>
<?php } ?>
<?php
}
?>
</div>
</div>
<?php
$locationMainOutput = ob_get_clean();
$locationMainOutput = str_replace(
'{total_files_'.$locationMain.'}',
$totalFilesArray[$locationMain],
$locationMainOutput
);
echo \WpAssetCleanUp\Misc::stripIrrelevantHtmlTags($locationMainOutput);
}
}
if ( isset( $data['all']['hardcoded'] ) && ! empty( $data['all']['hardcoded'] ) ) {
$data['print_outer_html'] = true; // AJAX call from the Dashboard
include_once __DIR__ . '/_assets-hardcoded-list.php';
} elseif (isset($data['is_frontend_view']) && $data['is_frontend_view']) {
echo \WpAssetCleanUp\HardcodedAssets::getHardCodedManageAreaForFrontEndView($data); // AJAX call from the front-end view
}
}
/*
* -----------------------
* [END] BY EACH LOCATION
* -----------------------
*/
include_once __DIR__ . '/_page-options.php';
include '_inline_js.php';