Why Gemfury? Push, build, and install  RubyGems npm packages Python packages Maven artifacts PHP packages Go Modules Debian packages RPM packages NuGet packages

Repository URL to install this package:

Details    
jsarnowski/wp-simple-pay-pro / core / settings / class-subsection-collection.php
Size: Mime:
<?php
/**
 * Settings: Subsection collection
 *
 * @package SimplePay\Core\Settings
 * @copyright Copyright (c) 2020, Sandhills Development, LLC
 * @license http://opensource.org/licenses/gpl-2.0.php GNU Public License
 * @since 4.0.0
 */

namespace SimplePay\Core\Settings;

use SimplePay\Core\Utils;

if ( ! defined( 'ABSPATH' ) ) {
	exit;
}

/**
 * Subsection_Collection class.
 *
 * @since 4.0.0
 */
class Subsection_Collection extends Utils\Collection_Prioritized {

	/**
	 * Adds a Subsection to the collection.
	 *
	 * @since 4.0.0
	 *
	 * @param \SimplePay\Core\Settings\Subsection $subsection Settings Subsection arguments.
	 * @return \WP_Error|true True on successful addition, otherwise a \WP_Error object.
	 */
	public function add( $subsection ) {
		// Ensure a valid subsection.
		if ( ! $subsection instanceof \SimplePay\Core\Settings\Subsection ) {
			return new \WP_Error(
				'invalid_settings_subsection',
				__( 'Invalid settings subsection.', 'simple-pay' )
			);
		}

		// Validate ID.
		if ( empty( $subsection->id ) ) {
			return new \WP_Error(
				'invalid_settings_subsection_id',
				__( 'Parameter <code>id</code> is required when registering a settings subsection.', 'simple-pay' )
			);
		}

		// Validate section.
		if ( empty( $subsection->section ) ) {
			return new \WP_Error(
				'invalid_settings_subsection_section',
				__( 'Parameter <code>section</code> is required when registering a settings subsection.', 'simple-pay' )
			);
		} else {
			static $sections = array();

			if ( empty( $sections ) ) {
				$sections = Utils\get_collection( 'settings-sections' );
			}

			if ( false === $sections->get_item( $subsection->section ) ) {
				return new \WP_Error(
					'invalid_settings_subsection_section',
					sprintf(
						/* translators: %s Settings subsection parent seection. */
						__( 'Settings subsection parent section %s does not exist.', 'simple-pay' ),
						$subsection->section
					)
				);
			}
		}

		return $this->add_item( $subsection->id, $subsection );
	}

	/**
	 * Filters registered subsections given a criteria.
	 *
	 * @since 4.0.0
	 *
	 * @param string $by Attribute to filter by.
	 * @param string $value Attribute value to compare.
	 * @return array
	 */
	public function by( $by, $value ) {
		$subsections = $this->get_items();

		return array_filter(
			$subsections,
			function( $subsection ) use ( $by, $value ) {
				return $value === $subsection->$by;
			}
		);
	}

}