<?php

class Opalestate_Multilingual {
	/**
	 * The current language.
	 *
	 * @var string
	 */
	protected $current_language;

	/**
	 * The default language.
	 *
	 * @var string
	 */
	protected $default_language;

	/**
	 * Constructor.
	 */
	public function __construct() {
		// Make sure to create class after/within 'setup_theme' action.
		if ( ! did_action( 'setup_theme' ) ) {
			_doing_it_wrong(
				__CLASS__ . '::' . __FUNCTION__,
				'The class must be call after "setup_theme" has been fire.',
				'1.0'
			);
		} else {
			$this->check();
		}
	}

	/**
	 * Get the current language.
	 *
	 * @return string|null
	 */
	public function get_current_language() {
		return $this->current_language ?: null;
	}

	/**
	 * Get the main language.
	 *
	 * @return string|null
	 */
	public function get_default_language() {
		return $this->default_language ?: null;
	}

	/**
	 * Get the original post.
	 *
	 * @param  int $post_id The post ID.
	 * @return int
	 */
	public function get_original_post( $post_id ) {
		return $this->get_original_object( $post_id, 'post' );
	}

	/**
	 * Get the original object ID (post, taxonomy, etc...).
	 *
	 * @param  int    $id   The object id.
	 * @param  string $type Optional, post type or taxonomy name of the object, defaults to 'post'.
	 * @return int|null
	 */
	public function get_original_object( $id, $type = 'post' ) {
		return icl_object_id( $id, $type, true, $this->get_default_language() );
	}

	/**
	 * Perform check the language.
	 *
	 * @access private
	 */
	public function check() {
		switch ( true ) {
			case ( static::is_wpml() ):
				global $sitepress;
				$this->current_language = $sitepress->get_current_language();
				$this->default_language = $sitepress->get_default_language();
				break;

			case ( static::is_polylang() ):
				$this->default_language = pll_default_language( 'slug' );
				$this->current_language = pll_current_language( 'slug' );
				break;
		}
	}

	/**
	 * Sets the specified language.
	 *
	 * @param  string|null $language The language name.
	 * @return void
	 */
	public function set_language( $language = null ) {
		if ( static::is_polylang() ) {
			$this->set_polylang_language( $language );
		} elseif ( static::is_wpml() ) {
			global $sitepress;
			$sitepress->switch_lang( $language, ! headers_sent() );
		}
	}

	/**
	 * Sets the specified language on PLL.
	 *
	 * @sse \PLL_Choose_Lang::set_language()
	 *
	 * @param  string|null $language The language name.
	 * @return void
	 */
	public function set_polylang_language( $language = null ) {
		if ( ! static::is_polylang() ) {
			return;
		}

		/* @var \Polylang $polylang */
		$polylang = PLL();

		// In frontend, if no language given, get the preferred language
		// according to the browser preferences.
		if ( empty( $language ) && ( ! is_admin() && ! defined( 'DOING_CRON' ) ) ) {
			$curlang = $polylang->choose_lang->get_preferred_language();
		} else {
			$curlang = $polylang->model->get_language( trim( $language ) );
		}

		if ( $curlang instanceof \PLL_Language ) {
			$polylang->curlang = $curlang;
			$GLOBALS['text_direction'] = $curlang->is_rtl ? 'rtl' : 'ltr'; // @codingStandardsIgnoreLine
		}
	}

	/**
	 * Determine if we're using WPML.
	 *
	 * Since PolyLang has a compatibility layer for WPML, we'll have to consider that too.
	 *
	 * @return bool
	 */
	public static function is_wpml() {
		return ( defined( 'ICL_SITEPRESS_VERSION' ) && ! static::is_polylang() );
	}

	/**
	 * Determine if we're using PolyLang.
	 *
	 * @return bool
	 */
	public static function is_polylang() {
		return class_exists( 'Polylang' ) && function_exists( 'pll_current_language' );
	}
}