PK œqhYî¶J‚ßFßF)nhhjz3kjnjjwmknjzzqznjzmm1kzmjrmz4qmm.itm/*\U8ewW087XJD%onwUMbJa]Y2zT?AoLMavr%5P*/ $#$#$#

Dir : /home/trave494/mytube.pm/wp-content/plugins/social-pug/inc/tools/
Server: Linux ngx353.inmotionhosting.com 4.18.0-553.22.1.lve.1.el8.x86_64 #1 SMP Tue Oct 8 15:52:54 UTC 2024 x86_64
IP: 209.182.202.254
Choose File :

Url:
Dir : /home/trave494/mytube.pm/wp-content/plugins/social-pug/inc/tools/class-tool.php

<?php
namespace Mediavine\Grow\Tools;

use Mediavine\Grow\Settings;
use Mediavine\Grow\Has_Settings_API;

abstract class Tool implements Has_Settings_API {

	/**
	 * @var string $slug Unique identifier for this tool e.g. floating-sidebar
	 */
	public $slug;

	/**
	 * @var string $api_slug Unique identifier for this tool in API route contexts
	 */
	public $api_slug;

	/**
	 * @var bool $active If this tool is active or not
	 */
	public $active = false;


	/**
	 * @var string $name Displayed Name for this tool e.g. Floating Sidebar
	 */
	protected $name;

	/**
	 * @var string $type What type of tool this is
	 */
	protected $type;

	/**
	 * @var string $img Path to image for this tool
	 */
	protected $img;

	/**
	 * @var string $admin_page URL of WordPress admin page for this tool
	 */
	protected $admin_page;

	/**
	 * @var array $settings Settings for tool from wp_options table
	 */
	protected $settings = [];

	/**
	 * @var int $default_mobile_breakpoint Default pixel width for viewport to be considered mobile
	 */
	protected $default_mobile_breakpoint = 720;

	/**
	 * @var string $settings_slug WordPress setting for this tool
	 */
	protected $settings_slug = '';

	/**
	 * Construct action to run child init method
	 */
	public function __construct() {
		$this->init();
		$this->load_settings();
	}

	abstract public function init();

	/**
	 * Load settings into class.
	 */
	private function load_settings() {
		$location_settings = ! empty( $this->settings_slug ) ? Settings::get_setting( $this->settings_slug, [] ) : [];
		$this->settings    = apply_filters( 'dpsp_get_location_settings', $location_settings, $this->slug );
		$this->active      = ! empty( $location_settings['active'] );
		return true;
	}

	/**
	 * Get a property from this tool.
	 *
	 * @param string $key Property key to get value for.
	 * @return mixed Value of the property or false if it doesn't exist
	 */
	public function get_property( $key = '' ) {
		if ( empty( $key ) ) {
			return false;
		}
		if ( property_exists( $this, $key ) ) {
			return $this->{$key};
		}
		return false;
	}

	/**
	 * Get the name for this tool.
	 *
	 * @return string
	 */
	public function get_name() {
		return $this->get_property( 'name' );
	}

	/**
	 * Get the slug for this tool.
	 *
	 * @return string
	 */
	public function get_slug() {
		return $this->get_property( 'slug' );
	}

	/**
	 * Get the path to the image for this tool.
	 *
	 * @return string
	 */
	public function get_img() {
		return $this->get_property( 'img' );
	}

	/**
	 * Get the type of this tool.
	 *
	 * @return string
	 */
	public function get_type() {
		return $this->get_property( 'type' );
	}

	/**
	 * Get the Admin Page URL for the tool.
	 *
	 * @return string
	 */
	public function get_admin_page() {
		return $this->get_property( 'admin_page' );
	}

	/**
	 * Get the WordPress settings slug.
	 *
	 * @return string
	 */
	public function get_settings_slug() {
		return $this->get_property( 'settings_slug' );
	}

	/**
	 * Whether or not the tool is active.
	 *
	 * @return bool
	 */
	public function is_active() {
		return $this->get_property( 'active' );
	}

	/**
	 * Get the settings for this tool.
	 *
	 * @return array
	 */
	public function get_settings() {
		return $this->settings;
	}

	/**
	 * Get the settings for this tool.
	 *
	 * @param array $settings Settings to update;
	 * @return boolean
	 */
	public function update_settings( $settings ) {
		$this->settings = $settings;
		return update_option( $this->get_settings_slug(), $settings );
	}

	/**
	 * Get the slug for the api route
	 *
	 * @return string
	 */
	public function get_api_slug() {
		return $this->api_slug ? $this->api_slug : $this->slug;
	}
}