%PDF- %PDF-
Mini Shell

Mini Shell

Direktori : /var/www/html/higroup/wp-content/plugins/event-tickets/src/Tribe/Repositories/
Upload File :
Create Path :
Current File : /var/www/html/higroup/wp-content/plugins/event-tickets/src/Tribe/Repositories/Order.php

<?php

namespace Tribe\Tickets\Repositories;

use Tribe__Repository;
use Tribe__Utils__Array as Arr;

/**
 * The repository functionality for Ticket Orders.
 *
 * @since 5.1.0
 */
class Order extends Tribe__Repository {

	/**
	 * The unique fragment that will be used to identify this repository filters.
	 *
	 * @since 5.1.0
	 *
	 * @var string
	 */
	protected $filter_name = 'tickets-orders';

	/**
	 * Key name to use when limiting lists of keys.
	 *
	 * @since 5.1.0
	 *
	 * @var string
	 */
	protected $key_name = '';

	/**
	 * The attendee provider object used to interact with the Order.
	 *
	 * @since 5.1.0
	 *
	 * @var Tribe__Tickets__Tickets
	 */
	public $attendee_provider;

	/**
	 * The list of supported order statuses.
	 *
	 * @since 5.1.0
	 *
	 * @var array An array of all the order statuses supported by the repository.
	 */
	protected static $order_statuses;

	/**
	 * The list of supported public order statuses.
	 *
	 * @since 5.1.0
	 *
	 * @var array
	 */
	protected static $public_order_statuses;

	/**
	 * The list of supported private order statuses.
	 *
	 * @since 5.1.0
	 *
	 * @var array
	 */
	protected static $private_order_statuses;

	/**
	 * Tribe__Tickets__Attendee_Repository constructor.
	 *
	 * @since 5.1.0
	 */
	public function __construct() {
		parent::__construct();

		// The extending repository must specify $this->default_args['post_type'] and set it to a valid post type.
		$this->default_args = array_merge( $this->default_args, [
			'post_type'   => '_no_order_type_set',
			'orderby'     => [ 'date', 'title', 'ID' ],
			'post_status' => 'any',
		] );

		$this->init_order_statuses();
	}

	/**
	 * Initialize the order statuses needed for the Orders repository.
	 *
	 * @since 5.1.0
	 */
	protected function init_order_statuses() {
		// Statuses already generated.
		if ( ! empty( self::$order_statuses ) ) {
			return;
		}

		/** @var Tribe__Tickets__Status__Manager $status_mgr */
		$status_mgr = tribe( 'tickets.status' );

		/**
		 * Allow filtering the list of all order statuses supported by the Orders repository.
		 *
		 * @since 5.1.0
		 *
		 * @param array $statuses List of all order statuses.
		 */
		$statuses = apply_filters( 'tribe_tickets_repositories_order_statuses', [] );

		// Enforce lowercase for comparison purposes.
		$statuses = array_map( 'strtolower', $statuses );

		// Prevent unnecessary duplicates.
		$statuses = array_unique( $statuses );

		// Store for reuse.
		self::$order_statuses = $statuses;

		/**
		 * Allow filtering the list of public order statuses supported by the Orders repository.
		 *
		 * @since 5.1.0
		 *
		 * @param array $public_order_statuses List of public order statuses.
		 */
		self::$public_order_statuses = apply_filters( 'tribe_tickets_repositories_order_public_statuses', [] );

		// Set up the initial private order statuses.
		$private_order_statuses = array_diff( self::$order_statuses, self::$public_order_statuses );

		/**
		 * Allow filtering the list of private order statuses supported by the Orders repository.
		 *
		 * @since 5.1.0
		 *
		 * @param array $private_order_statuses List of private order statuses.
		 */
		self::$private_order_statuses = apply_filters( 'tribe_tickets_repositories_order_private_statuses', $private_order_statuses );
	}

	/**
	 * {@inheritDoc}
	 *
	 * @since 5.1.0
	 *
	 * @return WP_Post|false The new post object or false if unsuccessful.
	 */
	public function create() {
		// Extended repositories must handle their own order creation.
		return false;
	}

	/**
	 * Create an order for a ticket.
	 *
	 * @since 5.1.0
	 *
	 * @param array                                  $order_data List of order data to be saved.
	 * @param null|int|Tribe__Tickets__Ticket_Object $ticket     The ticket object, ticket ID, or null if not relying on it.
	 *
	 * @return int|string|false The order ID or false if not created.
	 */
	public function create_order_for_ticket( $order_data, $ticket = null ) {
		// Bail if we already have an order.
		if ( ! empty( $order_data['order_id'] ) ) {
			return false;
		}

		$tickets = Arr::get( $order_data, 'tickets', [] );

		if ( empty( $order_data['tickets'] ) ) {
			$ticket_id = $ticket;

			if ( is_object( $ticket ) ) {
				// Detect ticket ID from the object.
				$ticket_id = $ticket->ID;
			} elseif ( empty( $ticket ) && isset( $order_data['ticket_id'] ) ) {
				// Detect the ticket ID from the order data.
				$ticket_id = $order_data['ticket_id'];
			}

			// Bail if no valid ticket ID.
			if ( $ticket_id < 1 ) {
				return false;
			}

			$order_data['tickets'] = [
				[
					'id'       => $ticket_id,
					'quantity' => 1,
				],
			];
		}

		/**
		 * Allow filtering the order data being used to create an order for the ticket.
		 *
		 * @since 5.1.0
		 *
		 * @param array                         $order_data List of order data to be saved.
		 * @param Tribe__Tickets__Ticket_Object $ticket     The ticket object or null if not relying on it.
		 */
		$order_data = apply_filters( 'tribe_tickets_repositories_order_create_order_for_ticket_order_args', $order_data, $ticket );

		// Check if order creation is disabled.
		if ( empty( $order_data ) ) {
			return false;
		}

		try {
			$order = $this->set_args( $order_data )->create();
		} catch ( Tribe__Repository__Usage_Error $exception ) {
			return false;
		}

		// Check if order was created.
		if ( ! $order ) {
			return false;
		}

		return $order->ID;
	}
}

Zerion Mini Shell 1.0