%PDF- %PDF-
Mini Shell

Mini Shell

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

<?php

use Tribe\Tooltip\View as Tooltip_View;

/**
 * Class Tribe__Tickets__Status__Abstract_Commerce
 *
 * @since 4.10
 *
 */
class Tribe__Tickets__Status__Abstract_Commerce {

	/**
	 * @var string a string for the completed order status, usually completed or publish
	 */
	public $completed_status_id;

	/**
	 * @var array an array of status names for a commerce
	 */
	public $status_names = [];

	/**
	 * @var array an array of status objects
	 */
	public $statuses = [];

	/**
	 * @var int the quantity of tickets sold for a post type
	 */
	protected $qty = 0;

	/**
	 * @var int the amount of tickets sold for a post type
	 */
	protected $line_total = 0;

	/**
	 * Initialize Commerce Provider
	 *
	 * @since 4.10
	 *
	 */
	public function initialize_status_classes() {}

	/**
	 * Get the Completed Order
	 *
	 * @since 4.10
	 *
	 * @return Tribe__Tickets__Status__Abstract|false
	 */
	public function get_completed_status_class() {

		if ( isset( $this->statuses[ $this->completed_status_id ] ) ) {
			return $this->statuses[ $this->completed_status_id ];
		}

		return false;
	}

	/**
	 * Get Total Quantity of Tickets by Post Type, no matter what status they have
	 *
	 * @since 4.10
	 *
	 * @return int
	 */
	public function get_qty() {
		return $this->qty;
	}

	/**
	 * Add to the Total Order Quantity
	 *
	 * @since 4.10
	 *
	 * @param int $value
	 */
	public function add_qty( $value ) {
		$this->qty += $value;
	}

	/**
	 * Remove from the Total Order Quantity
	 *
	 * @since 4.10
	 *
	 * @param int $value
	 */
	public function remove_qty( $value ) {
		$this->qty -= $value;
	}

	/**
	 * Get Total Order Amount of all Orders for a Post Type, no matter what status they have
	 *
	 * @since 4.10
	 *
	 * @return int
	 */
	public function get_line_total() {
		return $this->line_total;
	}

	/**
	 * Add to the Total Line Total
	 *
	 * @since 4.10
	 *
	 * @param int $value
	 */
	public function add_line_total( $value ) {
		$this->line_total += $value;
	}

	/**
	 * Remove from the Total Line Total
	 *
	 * @since 4.10
	 *
	 * @param int $value
	 */
	public function remove_line_total( $value ) {
		$this->line_total -= $value;
	}

	/**
	 * Get Ticket Sale Information Overview
	 *
	 * @since 4.10
	 *
	 * @param array $ticket_sold An object of the ticket to get counts.
	 * @param int   $post_id     An ID of the post the ticket is attached to.
	 *
	 * @return string a string Ticket name, sold, and availability
	 */
	public function get_ticket_sale_infomation( $ticket_sold, $post_id ) {
		ob_start();
		?>
		<div class="tribe-event-meta tribe-event-meta-tickets-sold-itemized">
			<?php
				echo $this->get_name_and_sold_for_ticket( $ticket_sold, $post_id );
				echo $this->get_available_incomplete_counts_for_ticket( $ticket_sold );
			?>
		</div>
		<?php

		return ob_get_clean();
	}

	/**
	 * Get Name of Ticket, SKU, Price, and Amount Sold
	 *
	 * @since 4.10
	 *
	 * @param array $ticket_sold The ticket to get counts.
	 * @param int   $post_id int An ID of the post the ticket is attached to.
	 *
	 * @return string a string of the ticket name and sold
	 */
	public function get_name_and_sold_for_ticket( $ticket_sold, $post_id ) {
		if ( ! $ticket_sold['ticket'] instanceof Tribe__Tickets__Ticket_Object ) {
			return '';
		}

		$sold = $ticket_sold['completed'] ? $ticket_sold['completed'] : $ticket_sold['sold'];

		$sold_message = sprintf( '%s %d', esc_attr__( 'Sold', 'event-tickets' ), esc_html( $sold ) );

		$price = $ticket_sold['ticket']->price ?
			' (' . tribe_format_currency( number_format( $ticket_sold['ticket']->price, 2 ), $post_id ) . ')' :
			'';

		$sku = $ticket_sold['sku'] ?
			'title="' . sprintf( '%s: (%s)', esc_attr__( 'SKU', 'event-tickets' ), esc_attr__( $ticket_sold['sku'] ) ) . '"' :
			'';

		ob_start();
		?>
		<strong <?php echo $sku; ?>><?php echo esc_html( $ticket_sold['ticket']->name . $price ); ?>:</strong>
		<?php
		echo esc_html( $sold_message );

		return ob_get_clean();
	}

	/**
	 * Get the available and incomplete counts for a Ticket.
	 *
	 * @since 4.10
	 *
	 * @param array $ticket_sold Ticket array to get counts.
	 *
	 * @return string The available and/or incomplete counts for a ticket.
	 */
	public function get_available_incomplete_counts_for_ticket( $ticket_sold ) {
		/** @var Tribe__Tickets__Ticket_Object $ticket_object */
		$ticket_object = $ticket_sold['ticket'];

		if (
			-1 === (int) $ticket_object->available()
			|| $ticket_object::UNLIMITED_STOCK === $ticket_object->available()
		) {
			/** @var Tribe__Tickets__Tickets_Handler $tickets_handler */
			$tickets_handler = tribe( 'tickets.handler' );

			$available_text = $tickets_handler->unlimited_term;
		} else {
			$available_text = $ticket_object->available();
		}

		$availability = [];

		$availability['available'] = sprintf( '%s %s%s',
			esc_html( $available_text ),
			esc_html__( 'available', 'event-tickets' ),
			$this->get_availability_by_ticket_tooltip( $ticket_sold )
		);

		if ( $ticket_sold['incomplete'] > 0 ) {
			$availability['incomplete'] = sprintf( '%s %s%s',
				 $ticket_sold['incomplete'],
				 esc_html__( 'pending order completion', 'event-tickets' ),
				 $this->get_pending_by_ticket_tooltip( $ticket_sold )
			);
		}

		if ( empty( $availability ) ) {
			return '';
		}

		return '<div>' . implode( '- ', $availability ) . '</div>';

	}

	/**
	 * Get Sales by Ticket Type Tooltip
	 *
	 * @since 4.10
	 *
	 * @return string a string of html for the tooltip
	 */
	public function get_sale_by_ticket_tooltip() {

		$message = esc_html__( 'Sold counts tickets from completed orders only.', 'event-tickets' );

		/** @var Tooltip_View $tooltip */
		$tooltip = tribe( 'tooltip.view' );

		return $tooltip->render_tooltip( $message );
	}

	/**
	 * Get Total Ticket Sales Tooltip
	 *
	 * @since 4.10
	 *
	 * @return string a string of html for the tooltip
	 */
	public function get_total_sale_tooltip() {
		/** @var Tooltip_View $tooltip */
		$tooltip = tribe( 'tooltip.view' );

		$message = sprintf(
			esc_html__( 'Total Sales counts %s from all completed orders.', 'event-tickets' ),
			tribe_get_ticket_label_plural_lowercase( 'total_sales' )
		);

		return $tooltip->render_tooltip( $message );
	}

	/**
	 * Get Order Tooltip
	 *
	 * @since 4.10
	 *
	 * @return string a string of html for the tooltip
	 */
	public function get_total_order_tooltip() {

		$message = esc_html__( 'Total Ordered counts tickets from orders of any status, including pending and refunded.', 'event-tickets' );

		/** @var Tooltip_View $tooltip */
		$tooltip = tribe( 'tooltip.view' );

		return $tooltip->render_tooltip( $message );
	}

	/**
	 * Get Pending Tooltip per Ticket
	 *
	 * @since 4.10.5
	 *
	 * @param $ticket_sold object an object of the ticket to get counts
	 *
	 * @return string a string of html for the tooltip
	 */
	public function get_pending_by_ticket_tooltip( $ticket_sold ) {
		/** @var Tribe__Tickets__Status__Manager $status_mgr */
		$status_mgr = tribe( 'tickets.status' );

		$args = [
			'incomplete_statuses' => (array) $status_mgr->get_statuses_by_action( 'count_incomplete', $ticket_sold['ticket']->provider_class, null, true ),
		];

		/** @var Tribe__Tickets__Admin__Views $admin_views */
		$admin_views = tribe( 'tickets.admin.views' );

		$message = $admin_views->template( 'order-pending-completion', $args, false );

		/** @var Tooltip_View $tooltip */
		$tooltip = tribe( 'tooltip.view' );

		return $tooltip->render_tooltip( $message );
	}


	/**
	 * Get Availability Tooltip per Ticket
	 *
	 * @since 4.10.5
	 *
	 * @param $ticket_sold object an object of the ticket to get counts
	 *
	 * @return string a string of html for the tooltip
	 */
	public function get_availability_by_ticket_tooltip( $ticket_sold ) {

		$available[ __( 'Inventory', 'event-tickets' ) ] = $ticket_sold['ticket']->inventory();
		$available[ __( 'Stock', 'event-tickets' ) ]     = $ticket_sold['ticket']->stock();
		$available[ __( 'Capacity', 'event-tickets' ) ]  = $ticket_sold['ticket']->capacity();

		$args = [
			'available'        => $available,
		];
		$message = tribe( 'tickets.admin.views' )->template( 'order-available', $args, false );

		$args    = [ 'wrap_classes' => 'large' ];

		/** @var Tooltip_View $tooltip */
		$tooltip = tribe( 'tooltip.view' );

		return $tooltip->render_tooltip( $message, $args );

	}

}

Zerion Mini Shell 1.0