%PDF- %PDF-
Mini Shell

Mini Shell

Direktori : /var/www/arphotolab.eco-n-tech.co.uk/wp-content/plugins/polylang/include/
Upload File :
Create Path :
Current File : /var/www/arphotolab.eco-n-tech.co.uk/wp-content/plugins/polylang/include/language.php

<?php
/**
 * @package Polylang
 */

/**
 * A language object is made of two terms in 'language' and 'term_language' taxonomies.
 * Manipulating only one object per language instead of two terms should make things easier.
 *
 * @since 1.2
 */
class PLL_Language {
	/**
	 * Id of the term in 'language' taxonomy.
	 *
	 * @var int
	 */
	public $term_id;

	/**
	 * Language name. Ex: English.
	 *
	 * @var string
	 */
	public $name;

	/**
	 * Language code used in url. Ex: en.
	 *
	 * @var string
	 */
	public $slug;

	/**
	 * Order of the language when displayed in a list of languages.
	 *
	 * @var int
	 */
	public $term_group;

	/**
	 * Term taxonomy id in 'language' taxonomy.
	 *
	 * @var int
	 */
	public $term_taxonomy_id;

	/**
	 * Number of posts and pages in that language.
	 *
	 * @var int
	 */
	public $count;

	/**
	 * Id of the term in 'term_language' taxonomy.
	 *
	 * @var int
	 */
	public $tl_term_id;

	/**
	 * Term taxonomy id in 'term_language' taxonomy.
	 *
	 * @var int
	 */
	public $tl_term_taxonomy_id;

	/**
	 * Number of terms in that language.
	 *
	 * @var int
	 */
	public $tl_count;

	/**
	 * WordPress language locale. Ex: en_US.
	 *
	 * @var string
	 */
	public $locale;

	/**
	 * 1 if the language is rtl, 0 otherwise.
	 *
	 * @var int
	 */
	public $is_rtl;

	/**
	 * W3C locale.
	 *
	 * @var string.
	 */
	public $w3c;

	/**
	 * Facebook locale.
	 *
	 * @var string.
	 */
	public $facebook;

	/**
	 * Home url in this language.
	 *
	 * @var string
	 */
	public $home_url;

	/**
	 * Home url to use in search forms.
	 *
	 * @var string
	 */
	public $search_url;

	/**
	 * Host corresponding to this language.
	 *
	 * @var string
	 */
	public $host;

	/**
	 * Id of the post storing strings translations.
	 *
	 * @var int
	 */
	public $mo_id;

	/**
	 * Id of the page on front in this language ( set from pll_languages_list filter ).
	 *
	 * @var int
	 */
	public $page_on_front;

	/**
	 * Id of the page for posts in this language ( set from pll_languages_list filter ).
	 *
	 * @var int
	 */
	public $page_for_posts;

	/**
	 * Code of the flag.
	 *
	 * @var string
	 */
	public $flag_code;

	/**
	 * Url of the flag.
	 *
	 * @var string
	 */
	public $flag_url;

	/**
	 * Html markup of the flag.
	 *
	 * @var string
	 */
	public $flag;

	/**
	 * Url of the custom flag if it exists.
	 *
	 * @var string
	 */
	public $custom_flag_url;

	/**
	 * Html markup of the custom flag if it exists.
	 *
	 * @var string
	 */
	public $custom_flag;

	/**
	 * Constructor: builds a language object given its two corresponding terms in 'language' and 'term_language' taxonomies.
	 *
	 * @since 1.2
	 *
	 * @param WP_Term|array $language      Term in 'language' taxonomy or language object properties stored as an array.
	 * @param WP_Term       $term_language Corresponding 'term_language' term.
	 */
	public function __construct( $language, $term_language = null ) {
		if ( empty( $term_language ) ) {
			// Build the object from all properties stored as an array.
			foreach ( $language as $prop => $value ) {
				$this->$prop = $value;
			}
		} else {
			// Build the object from taxonomy terms.
			$this->term_id = (int) $language->term_id;
			$this->name = $language->name;
			$this->slug = $language->slug;
			$this->term_group = (int) $language->term_group;
			$this->term_taxonomy_id = (int) $language->term_taxonomy_id;
			$this->count = (int) $language->count;

			$this->tl_term_id = (int) $term_language->term_id;
			$this->tl_term_taxonomy_id = (int) $term_language->term_taxonomy_id;
			$this->tl_count = (int) $term_language->count;

			// The description field can contain any property.
			$description = maybe_unserialize( $language->description );
			foreach ( $description as $prop => $value ) {
				'rtl' == $prop ? $this->is_rtl = $value : $this->$prop = $value;
			}

			$this->mo_id = PLL_MO::get_id( $this );

			$languages = include POLYLANG_DIR . '/settings/languages.php';
			$this->w3c = isset( $languages[ $this->locale ]['w3c'] ) ? $languages[ $this->locale ]['w3c'] : str_replace( '_', '-', $this->locale );
			if ( isset( $languages[ $this->locale ]['facebook'] ) ) {
				$this->facebook = $languages[ $this->locale ]['facebook'];
			}
		}
	}

	/**
	 * Get the flag informations:
	 *
	 * @since 2.6
	 *
	 * @param string $code Flag code.
	 * @return array {
	 *   Flag informations.
	 *
	 *   @type string $url    Flag url.
	 *   @type string $src    Optional, src attribute value if different of the url, for example if base64 encoded.
	 *   @type int    $width  Optional, flag width in pixels.
	 *   @type int    $height Optional, flag height in pixels.
	 * }
	 */
	public static function get_flag_informations( $code ) {
		$flag = array( 'url' => '' );

		// Polylang builtin flags.
		if ( ! empty( $code ) && file_exists( POLYLANG_DIR . ( $file = '/flags/' . $code . '.png' ) ) ) {
			$flag['url'] = plugins_url( $file, POLYLANG_FILE );

			// If base64 encoded flags are preferred.
			if ( ! defined( 'PLL_ENCODED_FLAGS' ) || PLL_ENCODED_FLAGS ) {
				list( $flag['width'], $flag['height'] ) = getimagesize( POLYLANG_DIR . $file );
				$file_contents = file_get_contents( POLYLANG_DIR . $file ); // phpcs:ignore WordPress.WP.AlternativeFunctions.file_get_contents_file_get_contents
				$flag['src'] = 'data:image/png;base64,' . base64_encode( $file_contents ); // phpcs:ignore WordPress.PHP.DiscouragedPHPFunctions.obfuscation_base64_encode
			}
		}

		/**
		 * Filters flag informations:
		 *
		 * @since 2.4
		 *
		 * @param array  $flag {
		 *   Information about the flag.
		 *
		 *   @type string $url    Flag url.
		 *   @type string $src    Optional, src attribute value if different of the url, for example if base64 encoded.
		 *   @type int    $width  Optional, flag width in pixels.
		 *   @type int    $height Optional, flag height in pixels.
		 * }
		 * @param string $code Flag code.
		 */
		$flag = apply_filters( 'pll_flag', $flag, $code );

		$flag['url'] = esc_url_raw( $flag['url'] );

		if ( empty( $flag['src'] ) ) {
			$flag['src'] = esc_url( set_url_scheme( $flag['url'], 'relative' ) );
		}

		return $flag;
	}

	/**
	 * Sets flag_url and flag properties.
	 *
	 * @since 1.2
	 *
	 * @return void
	 */
	public function set_flag() {
		$flags = array( 'flag' => self::get_flag_informations( $this->flag_code ) );

		// Custom flags?
		$directories = array(
			PLL_LOCAL_DIR,
			get_stylesheet_directory() . '/polylang',
			get_template_directory() . '/polylang',
		);

		foreach ( $directories as $dir ) {
			if ( file_exists( $file = "{$dir}/{$this->locale}.png" ) || file_exists( $file = "{$dir}/{$this->locale}.jpg" ) || file_exists( $file = "{$dir}/{$this->locale}.svg" ) ) {
				$flags['custom_flag']['url'] = content_url( '/' . str_replace( WP_CONTENT_DIR, '', $file ) );
				break;
			}
		}

		/**
		 * Filters the custom flag informations.
		 *
		 * @param array  $flag {
		 *   Information about the custom flag.
		 *
		 *   @type string $url    Flag url.
		 *   @type string $src    Optional, src attribute value if different of the url, for example if base64 encoded.
		 *   @type int    $width  Optional, flag width in pixels.
		 *   @type int    $height Optional, flag height in pixels.
		 * }
		 * @param string $code Flag code.
		 *
		 * @since 2.4
		 */
		$flags['custom_flag'] = apply_filters( 'pll_custom_flag', empty( $flags['custom_flag'] ) ? null : $flags['custom_flag'], $this->flag_code );

		if ( ! empty( $flags['custom_flag']['url'] ) ) {
			if ( empty( $flags['custom_flag']['src'] ) ) {
				$flags['custom_flag']['src'] = esc_url( set_url_scheme( $flags['custom_flag']['url'], 'relative' ) );
			}

			$flags['custom_flag']['url'] = esc_url_raw( $flags['custom_flag']['url'] );
		} else {
			unset( $flags['custom_flag'] );
		}

		/**
		 * Filters the flag title attribute.
		 * Defaults to the language name.
		 *
		 * @since 0.7
		 *
		 * @param string $title  The flag title attribute.
		 * @param string $slug   The language code.
		 * @param string $locale The language locale.
		 */
		$title = apply_filters( 'pll_flag_title', $this->name, $this->slug, $this->locale );

		foreach ( $flags as $key => $flag ) {
			$this->{$key . '_url'} = empty( $flag['url'] ) ? '' : $flag['url'];

			/**
			 * Filters the html markup of a flag.
			 *
			 * @since 1.0.2
			 *
			 * @param string $flag Html markup of the flag or empty string.
			 * @param string $slug Language code.
			 */
			$this->{$key} = apply_filters(
				'pll_get_flag',
				self::get_flag_html( $flag, $title, $this->name ),
				$this->slug
			);
		}
	}

	/**
	 * Get HTML code for flag.
	 *
	 * @since 2.7
	 *
	 * @param array  $flag  Flag properties: src, width and height.
	 * @param string $title Optional title attribute.
	 * @param string $alt   Optional alt attribute.
	 * @return string
	 */
	public static function get_flag_html( $flag, $title = '', $alt = '' ) {
		if ( empty( $flag['src'] ) ) {
			return '';
		}

		$alt_attr    = empty( $alt ) ? '' : sprintf( ' alt="%s"', esc_attr( $alt ) );
		$width_attr  = empty( $flag['width'] ) ? '' : sprintf( ' width="%s"', (int) $flag['width'] );
		$height_attr = empty( $flag['height'] ) ? '' : sprintf( ' height="%s"', (int) $flag['height'] );

		$style = '';
		$sizes = array_intersect_key( $flag, array_flip( array( 'width', 'height' ) ) );

		if ( ! empty( $sizes ) ) {
			array_walk(
				$sizes,
				function ( &$value, $key ) {
					$value = sprintf( '%s: %dpx;', esc_attr( $key ), (int) $value );
				}
			);
			$style = sprintf( ' style="%s"', implode( ' ', $sizes ) );
		}

		return sprintf(
			'<img src="%s"%s%s%s%s />',
			$flag['src'],
			$alt_attr,
			$width_attr,
			$height_attr,
			$style
		);
	}

	/**
	 * Returns the html of the custom flag if any, or the default flag otherwise.
	 *
	 * @since 2.8
	 *
	 * @return string
	 */
	public function get_display_flag() {
		return empty( $this->custom_flag ) ? $this->flag : $this->custom_flag;
	}

	/**
	 * Returns the url of the custom flag if any, or the default flag otherwise.
	 *
	 * @since 2.8
	 *
	 * @return string
	 */
	public function get_display_flag_url() {
		return empty( $this->custom_flag_url ) ? $this->flag_url : $this->custom_flag_url;
	}

	/**
	 * Updates post and term count.
	 *
	 * @since 1.2
	 *
	 * @return void
	 */
	public function update_count() {
		wp_update_term_count( $this->term_taxonomy_id, 'language' ); // Posts count.
		wp_update_term_count( $this->tl_term_taxonomy_id, 'term_language' ); // Terms count.
	}

	/**
	 * Set home_url and search_url properties.
	 *
	 * @since 1.3
	 *
	 * @param string $search_url Home url to use in search forms.
	 * @param string $home_url   Home url.
	 * @return void
	 */
	public function set_home_url( $search_url, $home_url ) {
		$this->search_url = $search_url;
		$this->home_url = $home_url;
	}

	/**
	 * Sets the scheme of the home url and the flag urls.
	 *
	 * This can't be cached across pages.
	 *
	 * @since 2.8
	 *
	 * @return void
	 */
	public function set_url_scheme() {
		$this->home_url = set_url_scheme( $this->home_url );
		$this->search_url = set_url_scheme( $this->search_url );

		// Set url scheme, also for the flags.
		$this->flag_url = set_url_scheme( $this->flag_url );
		if ( ! empty( $this->custom_flag_url ) ) {
			$this->custom_flag_url = set_url_scheme( $this->custom_flag_url );
		}
	}

	/**
	 * Returns the language locale.
	 * Converts WP locales to W3C valid locales for display.
	 *
	 * @since 1.8
	 *
	 * @param string $filter Either 'display' or 'raw', defaults to raw.
	 * @return string
	 */
	public function get_locale( $filter = 'raw' ) {
		return 'display' === $filter ? $this->w3c : $this->locale;
	}
}

Zerion Mini Shell 1.0