• File: Collection.php
  • Full Path: /home/lef/public_html/wp-content/plugins/woocommerce-multilingual/vendor/otgs/installer/includes/utilities/Collection.php
  • File size: 3.23 KB
  • MIME-type: text/x-php
  • Charset: utf-8
<?php

namespace OTGS\Installer;

class Collection {
	/**
	 * @var array
	 */
	private $array;

	/**
	 * The items contained in the collection.
	 *
	 * @var mixed[]
	 */
	protected $items = [];

	private function __construct( array $array ) {
		$this->array = $array;
	}

	/**
	 * @param array $array
	 *
	 * @return Collection
	 */
	public static function of( array $array ) {
		return new static( $array );
	}

	/**
	 * @param callable $fn
	 *
	 * @return Collection
	 */
	public function filter( callable $fn ) {
		return self::of( array_filter( $this->array, $fn ) );
	}

	/**
	 * @param callable $fn
	 *
	 * @return Collection
	 */
	public function map( callable $fn ) {
		$keys = array_keys( $this->array );

		$items = array_map( $fn, $this->array, $keys );

		$combined = array_combine( $keys, $items );

		return self::of( false !== $combined ? $combined : [] );
	}

	/**
	 * Converts array from key => vales to an array of pairs [ key, value ]
	 * @return Collection
	 */
	public function entities() {
		$toPairs = function ( $value, $key ) { return [ $key, $value ]; };

		return $this->map( $toPairs );
	}

	/**
	 * @param string $column
	 *
	 * @return Collection
	 */
	public function pluck( $column ) {
		return self::of( array_column( $this->array, $column ) );
	}

	/**
	 * @param callable $fn
	 * @param mixed    $initial
	 *
	 * @return mixed
	 */
	public function reduce( callable $fn, $initial = 0 ) {
		return array_reduce( $this->array, $fn, $initial );
	}

	/**
	 * @return Collection
	 */
	public function values() {
		return self::of( array_values( $this->array ) );
	}

	/**
	 * @param array $other
	 *
	 * @return Collection
	 */
	public function mergeRecursive( array $other ) {
		return self::of( array_merge_recursive( $this->array, $other ) );
	}

	/**
	 * @param string $key
	 *
	 * @return mixed|Collection|NullCollection|array
	 */
	public function get( $key = null ) {
		if ( null !== $key ) {
			$data = array_key_exists( $key, $this->array ) ? $this->array[ $key ] : null;
			if ( is_array( $data ) ) {
				return self::of( $data );
			} elseif ( is_null( $data ) ) {
				return new NullCollection();
			}

			return $data;
		}

		return $this->array;
	}

	public function getOrNull( $key = null ) {
		return $this->get( $key );
	}

	public function contains( $value ) {
		return in_array( $value, $this->array, true );
	}

	public function head() {
		if ( count( $this->array ) ) {
			$temp   = array_values( $this->array );
			$result = $temp[0];
			if ( is_array( $result ) ) {
				return self::of( $result );
			}

			return $result;
		}

		return new NullCollection();
	}

	/**
	 * Determine if an item exists at an offset.
	 *
	 * @param  mixed  $key
	 * @return bool
	 */
	public function offsetExists($key)
	{
		return array_key_exists($key, $this->items);
	}

	/**
	 * Determine if an item exists in the collection by key.
	 *
	 * @param  mixed  $key
	 * @return bool
	 */
	public function has($key)
	{
		return $this->offsetExists($key);
	}
}

class NullCollection {

	public function map( callable $fn ) { return $this; }

	public function filter( callable $fn ) { return $this; }

	public function head() { return $this; }

	public function pluck() { return $this; }

	public function get() { return $this; }

	public function getOrNull() { return null; }

}