HOME


Mini Shell 1.0
DIR: /home/dhnidqcz/pragmaticsng.org/wp-content/plugins/event-tickets/src/functions/commerce/
Upload File :
Current File : /home/dhnidqcz/pragmaticsng.org/wp-content/plugins/event-tickets/src/functions/commerce/orm.php
<?php
use \Tribe__Utils__Array as Arr;

/**
 * Builds and returns the correct Orders repository.
 *
 * @since 5.1.9
 *
 * @param string $repository The slug of the repository to build/return.
 *
 * @return Tribe__Repository__Interface An instance of the requested repository
 *                                      class.
 */
function tec_tc_orders( $repository = 'default' ) {
	$map = [
		'default' => TEC\Tickets\Commerce\Repositories\Order_Repository::class,
	];

	$args = func_num_args() > 1 ? array_slice( func_get_args(), 1 ) : [];

	/**
	 * Filters the map relating orders repository slugs to service container bindings.
	 *
	 * @since 5.1.9
	 *
	 * @param array  $map        A map in the shape [ <repository_slug> => <service_name> ]
	 * @param string $repository The currently requested implementation.
	 * @param array  $args       An array of additional call arguments used to call the function beside the
	 *                           repository slug.
	 */
	$map = apply_filters( 'tec_tickets_commerce_orders_repository_map', $map, $repository, $args );

	return tribe( Arr::get( $map, $repository, $map['default'] ) );
}

/**
 * Builds and returns the correct Tickets repository.
 *
 * @since 5.1.9
 *
 * @param string $repository The slug of the repository to build/return.
 *
 * @return Tribe__Repository__Interface An instance of the requested repository
 *                                      class.
 */
function tec_tc_tickets( $repository = 'default' ) {
	$map = [
		'default' => TEC\Tickets\Commerce\Repositories\Tickets_Repository::class,
	];

	$args = func_num_args() > 1 ? array_slice( func_get_args(), 1 ) : [];

	/**
	 * Filters the map relating tickets repository slugs to service container bindings.
	 *
	 * @since 5.1.9
	 *
	 * @param array  $map        A map in the shape [ <repository_slug> => <service_name> ]
	 * @param string $repository The currently requested implementation.
	 * @param array  $args       An array of additional call arguments used to call the function beside the
	 *                           repository slug.
	 */
	$map = apply_filters( 'tec_tickets_commerce_tickets_repository_map', $map, $repository, $args );

	return tribe( Arr::get( $map, $repository, $map['default'] ) );
}

/**
 * Builds and returns the correct Attendees repository.
 *
 * @since 5.1.9
 *
 * @param string $repository The slug of the repository to build/return.
 *
 * @return Tribe__Repository__Interface An instance of the requested repository
 *                                      class.
 */
function tec_tc_attendees( $repository = 'default' ) {
	$map = [
		'default' => TEC\Tickets\Commerce\Repositories\Attendees_Repository::class,
		'rsvp'    => Tribe__Tickets__Repositories__Attendee__RSVP::class,
	];

	$args = func_num_args() > 1 ? array_slice( func_get_args(), 1 ) : [];

	/**
	 * Filters the map relating attendees repository slugs to service container bindings.
	 *
	 * @since 5.1.9
	 *
	 * @param array  $map        A map in the shape [ <repository_slug> => <service_name> ]
	 * @param string $repository The currently requested implementation.
	 * @param array  $args       An array of additional call arguments used to call the function beside the
	 *                           repository slug.
	 */
	$map = apply_filters( 'tec_tickets_commerce_attendees_repository_map', $map, $repository, $args );

	if ( 'all' === $repository ) {
		return array_map(
			function ( $repo ) use ( $map ) {
				return Arr::get( $map, $repo, $map[ $repo ] );
			},
			array_keys( $map )
		);
	}

	return tribe( Arr::get( $map, $repository, $map['default'] ) );
}