HEX
Server: LiteSpeed
System: Linux premium267.web-hosting.com 4.18.0-553.54.1.lve.el8.x86_64 #1 SMP Wed Jun 4 13:01:13 UTC 2025 x86_64
User: predezso (1249)
PHP: 8.1.33
Disabled: NONE
Upload Files
File: /home/predezso/uppoom.com/wp-content/plugins/bulk-delete/include/Core/Addon/FeatureAddon.php
<?php

namespace BulkWP\BulkDelete\Core\Addon;

use BulkWP\BulkDelete\Core\Base\BasePage;

defined( 'ABSPATH' ) || exit; // Exit if accessed directly.

/**
 * A Feature Add-on.
 *
 * All Feature Add-ons will extend this class.
 * A Feature Add-on contains a bunch of modules and may also have Schedulers.
 *
 * @since 6.0.0
 */
abstract class FeatureAddon extends BaseAddon {
	/**
	 * List of pages that are registered by this add-on.
	 *
	 * @var \BulkWP\BulkDelete\Core\Base\BaseAddonPage[]
	 */
	protected $pages = array();

	/**
	 * List of assets that should be loaded for pages.
	 *
	 * Typically this is used only for built-in pages. Custom pages might load assets themselves.
	 *
	 * @since 6.0.1
	 *
	 * @var array
	 */
	protected $page_assets = array();

	/**
	 * List of modules that are registered by this add-on.
	 *
	 * This is an associate array, where the key is the item type and value is the array of modules.
	 * Eg: $modules['item_type'] = array( $module1, $module2 );
	 *
	 * @var array
	 */
	protected $modules = array();

	/**
	 * List of schedulers that are registered by this add-on.
	 *
	 * @var \BulkWP\BulkDelete\Core\Base\BaseScheduler[]
	 */
	protected $schedulers = array();

	// phpcs:ignore Squiz.Commenting.FunctionComment.Missing
	public function register() {
		foreach ( $this->pages as $page ) {
			$page->for_addon( $this->addon_info );
		}

		if ( ! empty( $this->pages ) ) {
			add_filter( 'bd_primary_pages', array( $this, 'register_pages' ) );
		}

		foreach ( array_keys( $this->page_assets ) as $page_slug ) {
			add_action( "bd_after_enqueue_page_assets_for_{$page_slug}", array( $this, 'register_page_assets' ) );
		}

		foreach ( array_keys( $this->modules ) as $page_slug ) {
			add_action( "bd_after_modules_{$page_slug}", array( $this, 'register_modules_in_page' ) );
		}

		foreach ( $this->schedulers as $scheduler ) {
			$scheduler->register();
		}

		add_filter( 'bd_upsell_addons', array( $this, 'hide_upseller_modules' ) );
	}

	/**
	 * Register pages.
	 *
	 * @param \BulkWP\BulkDelete\Core\Base\BaseDeletePage[] $primary_pages List of registered Primary pages.
	 *
	 * @return \BulkWP\BulkDelete\Core\Base\BaseDeletePage[] Modified list of primary pages.
	 */
	public function register_pages( $primary_pages ) {
		foreach ( $this->pages as $page ) {
			/**
			 * After the modules are registered in the delete posts page.
			 *
			 * @since 6.0.0
			 *
			 * @param \BulkWP\BulkDelete\Core\Base\BaseDeletePage $page The page in which the modules are registered.
			 */
			do_action( "bd_after_modules_{$page->get_page_slug()}", $page ); //phpcs:ignore

			/**
			 * After the modules are registered in a delete page.
			 *
			 * @since 6.0.0
			 *
			 * @param BasePage $posts_page The page in which the modules are registered.
			 */
			do_action( 'bd_after_modules', $page ); //phpcs:ignore

			$primary_pages[ $page->get_page_slug() ] = $page;
		}

		return $primary_pages;
	}

	/**
	 * Register page assets.
	 *
	 * @since 6.0.1
	 *
	 * @param \BulkWP\BulkDelete\Core\Base\BaseDeletePage $page Page.
	 */
	public function register_page_assets( $page ) {
		$assets = $this->page_assets[ $page->get_page_slug() ];

		foreach ( $assets as $asset ) {
			$this->enqueue_asset( $asset );
		}
	}

	/**
	 * Enqueue page assets.
	 *
	 * @since 6.0.1
	 *
	 * @param array $asset Asset details.
	 */
	protected function enqueue_asset( $asset ) {
		if ( 'script' === $asset['type'] ) {
			$this->enqueue_script( $asset );
		}

		if ( 'style' === $asset['type'] ) {
			$this->enqueue_style( $asset );
		}
	}

	/**
	 * Enqueue Script.
	 *
	 * @since 6.0.1
	 *
	 * @param array $asset Asset details.
	 */
	protected function enqueue_script( $asset ) {
		wp_enqueue_script(
			$asset['handle'],
			$asset['file'],
			$asset['dependencies'],
			$this->addon_info->get_version(),
			true
		);
	}

	/**
	 * Enqueue Style.
	 *
	 * @since 6.0.1
	 *
	 * @param array $asset Asset details.
	 */
	protected function enqueue_style( $asset ) {
		wp_enqueue_style(
			$asset['handle'],
			$asset['file'],
			$asset['dependencies'],
			$this->addon_info->get_version()
		);
	}

	/**
	 * Register modules for a page.
	 *
	 * @param \BulkWP\BulkDelete\Core\Base\BaseDeletePage $page Page.
	 */
	public function register_modules_in_page( $page ) {
		$modules = $this->modules[ $page->get_page_slug() ];

		foreach ( $modules as $module ) {
			$page->add_module( $module );
		}
	}

	/**
	 * Hide Upseller messages for the modules provided by this add-on.
	 *
	 * @since 6.0.1
	 *
	 * @param array $modules Modules.
	 *
	 * @return array Modified list of modules.
	 */
	public function hide_upseller_modules( $modules ) {
		$addon_slug = $this->get_info()->get_addon_slug();

		$modified_module_list = array();

		foreach ( $modules as $module ) {
			if ( $module['slug'] === $addon_slug ) {
				continue;
			}

			$modified_module_list[] = $module;
		}

		return $modified_module_list;
	}
}