Current File : /home/digitaw/www/wp-content/plugins/event-tickets/src/Tickets/Seating/Admin/Tabs/Layout_Card.php
<?php
/**
 * The Layout card object class.
 *
 * @since 5.16.0
 *
 * @package TEC\Tickets\Seating\Admin\Tabs;
 */

namespace TEC\Tickets\Seating\Admin\Tabs;

use TEC\Tickets\Seating\Admin;
use TEC\Tickets\Seating\Admin\Events\Associated_Events;
use TEC\Tickets\Seating\Service\Layouts as Layouts_Service;

/**
 * The Layout_Card Class.
 *
 * @since 5.16.0
 *
 * @package TEC\Tickets\Seating\Admin\Tabs;
 */
class Layout_Card {
	/**
	 * The Layout ID.
	 *
	 * @since 5.16.0
	 *
	 * @var string
	 */
	protected string $id;

	/**
	 * The Layout name.
	 *
	 * @since 5.16.0
	 *
	 * @var string
	 */
	protected string $name;

	/**
	 * The Layout map ID.
	 *
	 * @since 5.16.0
	 *
	 * @var string
	 */
	protected string $map;

	/**
	 * The number of seats in the Layout.
	 *
	 * @since 5.16.0
	 *
	 * @var int
	 */
	protected int $seats;

	/**
	 * The URL to the Layout's screenshot.
	 *
	 * @since 5.16.0
	 *
	 * @var string
	 */
	protected string $screenshot_url;

	/**
	 * Layout_Card constructor.
	 *
	 * @since 5.16.0
	 *
	 * @param string $id The Layout ID.
	 * @param string $name The Layout name.
	 * @param string $map The Layout map ID.
	 * @param int    $seats The number of seats in the Layout.
	 * @param string $screen_shot_url The URL to the Layout's screenshot.
	 */
	public function __construct( string $id, string $name, string $map, int $seats, string $screen_shot_url ) {
		$this->id             = $id;
		$this->name           = $name;
		$this->map            = $map;
		$this->seats          = $seats;
		$this->screenshot_url = $screen_shot_url;
	}

	/**
	 * Returns the Layout ID.
	 *
	 * @since 5.16.0
	 *
	 * @return string The Layout ID.
	 */
	public function get_id(): string {
		return $this->id;
	}

	/**
	 * Returns the Layout name.
	 *
	 * @since 5.16.0
	 *
	 * @return string The Layout name.
	 */
	public function get_name(): string {
		return $this->name;
	}

	/**
	 * Returns the Layout map ID.
	 *
	 * @since 5.16.0
	 *
	 * @return string The Layout map.
	 */
	public function get_map(): string {
		return $this->map;
	}

	/**
	 * Returns the number of seats in the Layout.
	 *
	 * @since 5.16.0
	 *
	 * @return int The number of seats in the Layout.
	 */
	public function get_seats(): int {
		return $this->seats;
	}

	/**
	 * Returns the URL to the Layout's screenshot.
	 *
	 * @since 5.16.0
	 *
	 * @return string The URL to the Layout's screenshot.
	 */
	public function get_screenshot_url(): string {
		return $this->screenshot_url;
	}

	/**
	 * Returns the URL to edit the Layout.
	 *
	 * @since 5.16.0
	 *
	 * @return string The URL to edit the Layout.
	 */
	public function get_edit_url(): string {
		return add_query_arg(
			[
				'page'     => Admin::get_menu_slug(),
				'tab'      => Layout_Edit::get_id(),
				'layoutId' => $this->get_id(),
			],
			admin_url( 'admin.php' )
		);
	}

	/**
	 * Returns the number of associated posts.
	 *
	 * @since 5.16.0
	 *
	 * @return int The number of associated posts.
	 */
	public function get_associated_posts_count(): int {
		return Layouts_Service::get_associated_posts_by_id( $this->get_id() );
	}

	/**
	 * Returns the URL to the Layout's associated posts.
	 *
	 * @since 5.16.0
	 *
	 * @return string The URL to the Layout's associated posts.
	 */
	public function get_associated_posts_url(): string {
		return add_query_arg(
			[
				'page'   => Associated_Events::SLUG,
				'layout' => $this->get_id(),
			],
			admin_url( 'admin.php' )
		);
	}
}