• File: first-time-configuration-notice-helper.php
  • Full Path: /home/matthif/www/wp-content/plugins/wordpress-seo/src/helpers/first-time-configuration-notice-helper.php
  • Date Modified: 02/24/2024 11:29 PM
  • File size: 4.76 KB
  • MIME-type: text/x-php
  • Charset: utf-8
<?php

namespace Yoast\WP\SEO\Helpers;

/**
 * A helper to determine the status of ftc and front-end related configuration.
 */
class First_Time_Configuration_Notice_Helper {

    
/**
     * The options' helper.
     *
     * @var Options_Helper
     */
    
private $options_helper;

    
/**
     * The indexing helper.
     *
     * @var Indexing_Helper
     */
    
private $indexing_helper;

    
/**
     * Whether we show the alternate mesage.
     *
     * @var bool
     */
    
private $show_alternate_message;

    
/**
     * First_Time_Configuration_Notice_Integration constructor.
     *
     * @param Options_Helper  $options_helper  The options helper.
     * @param Indexing_Helper $indexing_helper The indexing helper.
     */
    
public function __construct(
        
Options_Helper $options_helper,
        
Indexing_Helper $indexing_helper
    
) {
        
$this->options_helper         $options_helper;
        
$this->indexing_helper        $indexing_helper;
        
$this->show_alternate_message false;
    }

    
/**
     * Determines whether and where the "First-time SEO Configuration" admin notice should be displayed.
     *
     * @return bool Whether the "First-time SEO Configuration" admin notice should be displayed.
     */
    
public function should_display_first_time_configuration_notice() {
        if ( ! 
$this->options_helper->get'dismiss_configuration_workout_notice'false ) === false ) {
            return 
false;
        }
        if ( ! 
$this->on_wpseo_admin_page_or_dashboard() ) {
            return 
false;
        }

        return 
$this->first_time_configuration_not_finished();
    }

    
/**
     * Gets the first time configuration title based on the show_alternate_message boolean
     *
     * @return string
     */
    
public function get_first_time_configuration_title() {
        return ( ! 
$this->show_alternate_message ) ? \__'First-time SEO configuration''wordpress-seo' ) : \__'SEO configuration''wordpress-seo' );
    }

    
/**
     * Determines if the first time configuration is completely finished.
     *
     * @return bool
     */
    
public function first_time_configuration_not_finished() {
        if ( ! 
$this->user_can_do_first_time_configuration() ) {
            return 
false;
        }

        if ( 
$this->is_first_time_configuration_finished() ) {
            return 
false;
        }

        if ( 
$this->options_helper->get'first_time_install'false ) !== false ) {
            return ! 
$this->are_site_representation_name_and_logo_set() || $this->indexing_helper->get_unindexed_count() > 0;
        }

        if ( 
$this->indexing_helper->is_initial_indexing() === false ) {
            return 
false;
        }

        if ( 
$this->indexing_helper->is_finished_indexables_indexing() === true ) {
            return 
false;
        }

        
$this->show_alternate_message true;

        return ! 
$this->are_site_representation_name_and_logo_set();
    }

    
/**
     * Whether the user can do the first-time configuration.
     *
     * @return bool Whether the current user can do the first-time configuration.
     */
    
private function user_can_do_first_time_configuration() {
        return 
\current_user_can'wpseo_manage_options' );
    }

    
/**
     * Whether the user is currently visiting one of our admin pages or the WordPress dashboard.
     *
     * @return bool Whether the current page is a Yoast SEO admin page
     */
    
private function on_wpseo_admin_page_or_dashboard() {
        
$pagenow $GLOBALS['pagenow'];

        
// Show on the WP Dashboard.
        
if ( $pagenow === 'index.php' ) {
            return 
true;
        }

        
$page_from_get \filter_input\INPUT_GET'page' );

        
// Show on Yoast SEO pages, with some exceptions.
        
if ( $pagenow === 'admin.php' && \strpos$page_from_get'wpseo' ) === ) {
            
$exceptions = [
                
'wpseo_installation_successful',
                
'wpseo_installation_successful_free',
            ];

            if ( ! 
\in_array$page_from_get$exceptionstrue ) ) {
                return 
true;
            }
        }

        return 
false;
    }

    
/**
     * Whether all steps of the first-time configuration have been finished.
     *
     * @return bool Whether the first-time configuration has been finished.
     */
    
private function is_first_time_configuration_finished() {
        
$configuration_finished_steps $this->options_helper->get'configuration_finished_steps', [] );

        return 
\count$configuration_finished_steps ) === 3;
    }

    
/**
     * Whether the site representation name and logo have been set.
     *
     * @return bool  Whether the site representation name and logo have been set.
     */
    
private function are_site_representation_name_and_logo_set() {
        
$company_or_person $this->options_helper->get'company_or_person''' );

        if ( 
$company_or_person === '' ) {
            return 
false;
        }

        if ( 
$company_or_person === 'company' ) {
            return ! empty( 
$this->options_helper->get'company_name' ) ) && ! empty( $this->options_helper->get'company_logo''' ) );
        }

        return ! empty( 
$this->options_helper->get'company_or_person_user_id' ) ) && ! empty( $this->options_helper->get'person_logo''' ) );
    }

    
/**
     * Getter for the show alternate message boolean.
     *
     * @return bool
     */
    
public function should_show_alternate_message() {
        return 
$this->show_alternate_message;
    }
}