/home/grlogisticsandse/www/wp-content/plugins/siteseo/classes/Actions/Front/Metas/TitleMeta.php
<?php
/*
* SiteSEO
* https://siteseo.io/
* (c) SiteSEO Team <support@siteseo.io>
*/

/*
Copyright 2016 - 2024 - Benjamin Denis  (email : contact@seopress.org)
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License, version 2, as
published by the Free Software Foundation.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
GNU General Public License for more details.

You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
*/

namespace SiteSEO\Actions\Front\Metas;

defined('ABSPATH') or exit('Cheatin&#8217; uh?');

use SiteSEO\Core\Hooks\ExecuteHooksFrontend;

class TitleMeta implements ExecuteHooksFrontend {
	
	public $tagsToStringService;
	
	public function __construct() {
		$this->tagsToStringService = siteseo_get_service('TagsToString');
	}

	/**
	 * @since 4.4.0
	 *
	 * @return void
	 */
	public function hooks() {
		add_filter('pre_get_document_title', [$this, 'render'], 10);
	}

	/**
	 * @since
	 *
	 * @return string
	 *
	 * @param mixed $variablesArray
	 * @param mixed $variablesReplace
	 */
	protected function getHomeTitleTemplate($variablesArray, $variablesReplace) {
		if ( ! function_exists('siteseo_get_service')) {
			$titleOption = siteseo_get_service('TitleOption')->getHomeSiteTitle();
			if (empty($titleOption)) {
				return '';
			}
			$titleOption   = esc_attr($titleOption);

			return str_replace($variablesArray, $variablesReplace, $titleOption);
		}

		$title   = siteseo_get_service('TitleOption')->getHomeSiteTitle();
		$context = siteseo_get_service('ContextPage')->getContext();

		return $this->tagsToStringService->replace($title, $context);
	}

	/**
	 * @since 4.4.0
	 *
	 * @return string
	 */
	public function render() {
		$defaultHook = function_exists('siteseo_get_service');
		
		// TODO: remove if not needed
		require_once SITESEO_MAIN.'/options-titles-metas.php';

		if(apply_filters('siteseo_old_pre_get_document_title', true)){
			return;
		}

		$context = siteseo_get_service('ContextPage')->getContext();

		$variables = apply_filters('siteseo_dyn_variables_fn', null);

		$post = $variables['post'];
		$titleTemplate = $variables['siteseo_titles_title_template'];
		$siteseo_titles_template_variables_array = $variables['siteseo_titles_template_variables_array'];
		$siteseo_titles_template_replace_array = $variables['siteseo_titles_template_replace_array'];
		$page_id = get_option('page_for_posts');
		$getHomeSiteTitle = siteseo_get_service('TitleOption')->getHomeSiteTitle();
		$getArchivesAuthorTitle = siteseo_get_service('TitleOption')->getArchivesAuthorTitle();
		
		if (is_front_page() && is_home() && isset($post) && '' == get_post_meta($post->ID, '_siteseo_titles_title', true)) { //HOMEPAGE
			if ( ! empty($getHomeSiteTitle)) {
				$titleTemplate = $this->getHomeTitleTemplate($siteseo_titles_template_variables_array, $siteseo_titles_template_replace_array);
			}
		} elseif (is_front_page() && isset($post) && '' == get_post_meta($post->ID, '_siteseo_titles_title', true)) { //STATIC HOMEPAGE
			if ( ! empty($getHomeSiteTitle)) {
				$titleTemplate = $this->getHomeTitleTemplate($siteseo_titles_template_variables_array, $siteseo_titles_template_replace_array);
			}
		} elseif (is_home() && '' != get_post_meta($page_id, '_siteseo_titles_title', true)) { //BLOG PAGE
			if (get_post_meta($page_id, '_siteseo_titles_title', true)) { //IS METABOXE
				$titleOption   = esc_attr(get_post_meta($page_id, '_siteseo_titles_title', true));
				$titleTemplate = str_replace($siteseo_titles_template_variables_array, $siteseo_titles_template_replace_array, $titleOption);
			}
		} elseif (is_home() && ('posts' == get_option('show_on_front'))) { //YOUR LATEST POSTS
			if ( ! function_exists('siteseo_get_service')) {
				if(!empty($getHomeSiteTitle)) {
					$titleOption = esc_attr($getHomeSiteTitle);

					$titleTemplate = str_replace($siteseo_titles_template_variables_array, $siteseo_titles_template_replace_array, $titleOption);
				}
			} else {
				$title		 = siteseo_get_service('TitleOption')->getHomeSiteTitle();
				$titleTemplate = $this->tagsToStringService->replace($title, $context);
			}
		} elseif (function_exists('bp_is_group') && bp_is_group()) {
			if ('' != siteseo_get_service('TitleOption')->getTitleBpGroups()) {
				$titleOption = esc_attr(siteseo_get_service('TitleOption')->getTitleBpGroups());

				$titleTemplate = str_replace($siteseo_titles_template_variables_array, $siteseo_titles_template_replace_array, $titleOption);
			}
		} elseif (is_singular()) { //IS SINGULAR
			// Check Buddypress
			$buddyId = siteseo_get_service('BuddyPressGetCurrentId')->getCurrentId();
			if ($buddyId) {
				$post->ID = $buddyId;
			}

			if (get_post_meta($post->ID, '_siteseo_titles_title', true)) { //IS METABOXE
				$titleOption = esc_attr(get_post_meta($post->ID, '_siteseo_titles_title', true));

				preg_match_all('/%%_cf_(.*?)%%/', $titleOption, $matches); //custom fields

				if ( ! empty($matches)) {
					$siteseo_titles_cf_template_variables_array = [];
					$siteseo_titles_cf_template_replace_array   = [];

					foreach ($matches['0'] as $key => $value) {
						$siteseo_titles_cf_template_variables_array[] = $value;
					}

					foreach ($matches['1'] as $key => $value) {
						$siteseo_titles_cf_template_replace_array[] = esc_attr(get_post_meta($post->ID, $value, true));
					}
				}

				preg_match_all('/%%_ct_(.*?)%%/', $titleOption, $matches2); //custom terms taxonomy

				if ( ! empty($matches2)) {
					$siteseo_titles_ct_template_variables_array = [];
					$siteseo_titles_ct_template_replace_array   = [];

					foreach ($matches2['0'] as $key => $value) {
						$siteseo_titles_ct_template_variables_array[] = $value;
					}

					foreach ($matches2['1'] as $key => $value) {
						$term = wp_get_post_terms($post->ID, $value);
						if ( ! is_wp_error($term)) {
							$terms									   = esc_attr($term[0]->name);
							$siteseo_titles_ct_template_replace_array[] = apply_filters('siteseo_titles_custom_tax', $terms, $value);
						}
					}
				}

				preg_match_all('/%%_ucf_(.*?)%%/', $titleOption, $matches3); //user meta

				if ( ! empty($matches3)) {
					$siteseo_titles_ucf_template_variables_array = [];
					$siteseo_titles_ucf_template_replace_array   = [];

					foreach ($matches3['0'] as $key => $value) {
						$siteseo_titles_ucf_template_variables_array[] = $value;
					}

					foreach ($matches3['1'] as $key => $value) {
						$siteseo_titles_ucf_template_replace_array[] = esc_attr(get_user_meta(get_current_user_id(), $value, true));
					}
				}

				//Default
				$titleTemplate = str_replace($siteseo_titles_template_variables_array, $siteseo_titles_template_replace_array, $titleOption);

				//Custom fields
				if ( ! empty($matches) && ! empty($siteseo_titles_cf_template_variables_array) && ! empty($siteseo_titles_cf_template_replace_array)) {
					$titleTemplate = str_replace($siteseo_titles_cf_template_variables_array, $siteseo_titles_cf_template_replace_array, $titleTemplate);
				}

				//Custom terms taxonomy
				if ( ! empty($matches2) && ! empty($siteseo_titles_ct_template_variables_array) && ! empty($siteseo_titles_ct_template_replace_array)) {
					$titleTemplate = str_replace($siteseo_titles_ct_template_variables_array, $siteseo_titles_ct_template_replace_array, $titleTemplate);
				}

				//User meta
				if ( ! empty($matches3) && ! empty($siteseo_titles_ucf_template_variables_array) && ! empty($siteseo_titles_ucf_template_replace_array)) {
					$titleTemplate = str_replace($siteseo_titles_ucf_template_variables_array, $siteseo_titles_ucf_template_replace_array, $titleTemplate);
				}
			} else { //DEFAULT GLOBAL
				$siteseo_titles_single_titles_option = esc_attr(siteseo_titles_single_titles_option());

				preg_match_all('/%%_cf_(.*?)%%/', $siteseo_titles_single_titles_option, $matches); //custom fields

				if ( ! empty($matches)) {
					$siteseo_titles_cf_template_variables_array = [];
					$siteseo_titles_cf_template_replace_array   = [];

					foreach ($matches['0'] as $key => $value) {
						$siteseo_titles_cf_template_variables_array[] = $value;
					}

					foreach ($matches['1'] as $key => $value) {
						$siteseo_titles_cf_template_replace_array[] = esc_attr(get_post_meta($post->ID, $value, true));
					}
				}

				preg_match_all('/%%_ct_(.*?)%%/', $siteseo_titles_single_titles_option, $matches2); //custom terms taxonomy

				if ( ! empty($matches2)) {
					$siteseo_titles_ct_template_variables_array = [];
					$siteseo_titles_ct_template_replace_array   = [];

					foreach ($matches2['0'] as $key => $value) {
						$siteseo_titles_ct_template_variables_array[] = $value;
					}

					foreach ($matches2['1'] as $key => $value) {
						$term = wp_get_post_terms($post->ID, $value);
						if ( ! is_wp_error($term) && isset($term[0])) {
							$terms									   = esc_attr($term[0]->name);
							$siteseo_titles_ct_template_replace_array[] = apply_filters('siteseo_titles_custom_tax', $terms, $value);
						}
					}
				}

				preg_match_all('/%%_ucf_(.*?)%%/', $siteseo_titles_single_titles_option, $matches3); //user meta

				if ( ! empty($matches3)) {
					$siteseo_titles_ucf_template_variables_array = [];
					$siteseo_titles_ucf_template_replace_array   = [];

					foreach ($matches3['0'] as $key => $value) {
						$siteseo_titles_ucf_template_variables_array[] = $value;
					}

					foreach ($matches3['1'] as $key => $value) {
						$siteseo_titles_ucf_template_replace_array[] = esc_attr(get_user_meta(get_current_user_id(), $value, true));
					}
				}

				//Default
				$titleTemplate = str_replace($siteseo_titles_template_variables_array, $siteseo_titles_template_replace_array, $siteseo_titles_single_titles_option);

				//Custom fields
				if ( ! empty($matches) && ! empty($siteseo_titles_cf_template_variables_array) && ! empty($siteseo_titles_cf_template_replace_array)) {
					$titleTemplate = str_replace($siteseo_titles_cf_template_variables_array, $siteseo_titles_cf_template_replace_array, $titleTemplate);
				}

				//Custom terms taxonomy
				if ( ! empty($matches2) && ! empty($siteseo_titles_ct_template_variables_array) && ! empty($siteseo_titles_ct_template_replace_array)) {
					$titleTemplate = str_replace($siteseo_titles_ct_template_variables_array, $siteseo_titles_ct_template_replace_array, $titleTemplate);
				}

				//User meta
				if ( ! empty($matches3) && ! empty($siteseo_titles_ucf_template_variables_array) && ! empty($siteseo_titles_ucf_template_replace_array)) {
					$titleTemplate = str_replace($siteseo_titles_ucf_template_variables_array, $siteseo_titles_ucf_template_replace_array, $titleTemplate);
				}
			}
		} elseif (is_post_type_archive() && siteseo_titles_archive_titles_option()) { //IS POST TYPE ARCHIVE
			$siteseo_titles_archive_titles_option = esc_attr(siteseo_titles_archive_titles_option());

			$titleTemplate = str_replace($siteseo_titles_template_variables_array, $siteseo_titles_template_replace_array, $siteseo_titles_archive_titles_option);
		} elseif ((is_tax() || is_category() || is_tag()) && siteseo_titles_tax_titles_option()) { //IS TAX
			$siteseo_titles_tax_titles_option = esc_attr(siteseo_titles_tax_titles_option());

			if (get_term_meta(get_queried_object()->{'term_id'}, '_siteseo_titles_title', true)) {
				$titleTemplate = esc_attr(get_term_meta(get_queried_object()->{'term_id'}, '_siteseo_titles_title', true));
				$titleTemplate = str_replace($siteseo_titles_template_variables_array, $siteseo_titles_template_replace_array, $titleTemplate);
			} else {
				$titleTemplate = str_replace($siteseo_titles_template_variables_array, $siteseo_titles_template_replace_array, $siteseo_titles_tax_titles_option);
			}
		} elseif (is_author() && $getArchivesAuthorTitle) { //IS AUTHOR
			$siteseo_titles_archives_author_title_option = esc_attr($getArchivesAuthorTitle);

			preg_match_all('/%%_ucf_(.*?)%%/', $siteseo_titles_archives_author_title_option, $matches); //custom fields

			if ( ! empty($matches)) {
				$siteseo_titles_cf_template_variables_array = [];
				$siteseo_titles_cf_template_replace_array   = [];

				foreach ($matches['0'] as $key => $value) {
					$siteseo_titles_cf_template_variables_array[] = $value;
				}

				foreach ($matches['1'] as $key => $value) {
					$siteseo_titles_cf_template_replace_array[] = esc_attr(get_user_meta(get_current_user_id(), $value, true));
				}
			}

			//Default
			$titleTemplate = esc_attr($getArchivesAuthorTitle);

			//Custom fields
			if ( ! empty($matches) && ! empty($siteseo_titles_cf_template_variables_array) && ! empty($siteseo_titles_cf_template_replace_array)) {
				$titleTemplate = str_replace($siteseo_titles_cf_template_variables_array, $siteseo_titles_cf_template_replace_array, $titleTemplate);
			}

			$titleTemplate = str_replace($siteseo_titles_template_variables_array, $siteseo_titles_template_replace_array, $titleTemplate);
		} elseif (is_date() && siteseo_get_service('TitleOption')->getTitleArchivesDate()) { //IS DATE
			$siteseo_titles_archives_date_title_option = esc_attr(siteseo_get_service('TitleOption')->getTitleArchivesDate());

			$titleTemplate = str_replace($siteseo_titles_template_variables_array, $siteseo_titles_template_replace_array, $siteseo_titles_archives_date_title_option);
		} elseif (is_search() && siteseo_get_service('TitleOption')->getTitleArchivesSearch()) { //IS SEARCH
			$siteseo_titles_archives_search_title_option = esc_attr(siteseo_get_service('TitleOption')->getTitleArchivesSearch());

			$titleTemplate = str_replace($siteseo_titles_template_variables_array, $siteseo_titles_template_replace_array, $siteseo_titles_archives_search_title_option);
		} elseif (is_404() && siteseo_get_service('TitleOption')->getTitleArchives404()) { //IS 404
			$siteseo_titles_archives_404_title_option = esc_attr(siteseo_get_service('TitleOption')->getTitleArchives404());

			$titleTemplate = str_replace($siteseo_titles_template_variables_array, $siteseo_titles_template_replace_array, $siteseo_titles_archives_404_title_option);
		}

		//Hook on Title tag - 'siteseo_titles_title'
		if (has_filter('siteseo_titles_title')) {
			$titleTemplate = apply_filters('siteseo_titles_title', $titleTemplate);
		}

		//Return Title tag
		return $titleTemplate;
	}
}