class-wpml-st-db-mappers-string-positions.php 1.86 KB
<?php

class WPML_ST_DB_Mappers_String_Positions {
	/**
	 * @var wpdb
	 */
	private $wpdb;

	/**
	 * @param wpdb $wpdb
	 */
	public function __construct( wpdb $wpdb ) {
		$this->wpdb = $wpdb;
	}

	/**
	 * @param int $string_id
	 * @param int $kind
	 *
	 * @return int
	 */
	public function get_count_of_positions_by_string_and_kind( $string_id, $kind ) {
		$query = "
			SELECT COUNT(id)
	        FROM {$this->wpdb->prefix}icl_string_positions 
	        WHERE string_id = %d AND kind = %d
        ";

		/** @var string $sql */
		$sql = $this->wpdb->prepare( $query, $string_id, $kind );
		return (int) $this->wpdb->get_var( $sql );
	}

	/**
	 * @param int $string_id
	 * @param int $kind
	 *
	 * @return array
	 */
	public function get_positions_by_string_and_kind( $string_id, $kind ) {
		$query = "
			SELECT position_in_page
            FROM {$this->wpdb->prefix}icl_string_positions
          	WHERE string_id = %d AND kind = %d
        ";

		/** @var string $sql */
		$sql = $this->wpdb->prepare( $query, $string_id, $kind );

		return $this->wpdb->get_col( $sql );
	}

	/**
	 * @param int    $string_id
	 * @param string $position
	 * @param int    $kind
	 *
	 * @return bool
	 */
	public function is_string_tracked( $string_id, $position, $kind ) {
		$query = "
			SELECT id
            FROM {$this->wpdb->prefix}icl_string_positions
            WHERE string_id=%d AND position_in_page=%s AND kind=%s
		";

		/** @var string $sql */
		$sql = $this->wpdb->prepare( $query, $string_id, $position, $kind );

		return (bool) $this->wpdb->get_var( $sql );
	}

	/**
	 * @param int    $string_id
	 * @param string $position
	 * @param int    $kind
	 */
	public function insert( $string_id, $position, $kind ) {
		$this->wpdb->insert( $this->wpdb->prefix . 'icl_string_positions', array(
			'string_id'        => $string_id,
			'kind'             => $kind,
			'position_in_page' => $position,
		) );
	}
}