first
This commit is contained in:
255
wp-content/plugins/wordpress-seo/admin/class-asset.php
Normal file
255
wp-content/plugins/wordpress-seo/admin/class-asset.php
Normal file
@ -0,0 +1,255 @@
|
||||
<?php
|
||||
/**
|
||||
* WPSEO plugin file.
|
||||
*
|
||||
* @package WPSEO\Admin
|
||||
*/
|
||||
|
||||
/**
|
||||
* Represents a WPSEO asset
|
||||
*/
|
||||
class WPSEO_Admin_Asset {
|
||||
|
||||
/**
|
||||
* Constant used to identify file type as a JS file.
|
||||
*
|
||||
* @var string
|
||||
*/
|
||||
const TYPE_JS = 'js';
|
||||
|
||||
/**
|
||||
* Constant used to identify file type as a CSS file.
|
||||
*
|
||||
* @var string
|
||||
*/
|
||||
const TYPE_CSS = 'css';
|
||||
|
||||
/**
|
||||
* The name option identifier.
|
||||
*
|
||||
* @var string
|
||||
*/
|
||||
const NAME = 'name';
|
||||
|
||||
/**
|
||||
* The source option identifier.
|
||||
*
|
||||
* @var string
|
||||
*/
|
||||
const SRC = 'src';
|
||||
|
||||
/**
|
||||
* The dependencies option identifier.
|
||||
*
|
||||
* @var string
|
||||
*/
|
||||
const DEPS = 'deps';
|
||||
|
||||
/**
|
||||
* The version option identifier.
|
||||
*
|
||||
* @var string
|
||||
*/
|
||||
const VERSION = 'version';
|
||||
|
||||
/* Style specific. */
|
||||
|
||||
/**
|
||||
* The media option identifier.
|
||||
*
|
||||
* @var string
|
||||
*/
|
||||
const MEDIA = 'media';
|
||||
|
||||
/**
|
||||
* The rtl option identifier.
|
||||
*
|
||||
* @var string
|
||||
*/
|
||||
const RTL = 'rtl';
|
||||
|
||||
/* Script specific. */
|
||||
|
||||
/**
|
||||
* The "in footer" option identifier.
|
||||
*
|
||||
* @var string
|
||||
*/
|
||||
const IN_FOOTER = 'in_footer';
|
||||
|
||||
/**
|
||||
* Asset identifier.
|
||||
*
|
||||
* @var string
|
||||
*/
|
||||
protected $name;
|
||||
|
||||
/**
|
||||
* Path to the asset.
|
||||
*
|
||||
* @var string
|
||||
*/
|
||||
protected $src;
|
||||
|
||||
/**
|
||||
* Asset dependencies.
|
||||
*
|
||||
* @var string|array
|
||||
*/
|
||||
protected $deps;
|
||||
|
||||
/**
|
||||
* Asset version.
|
||||
*
|
||||
* @var string
|
||||
*/
|
||||
protected $version;
|
||||
|
||||
/**
|
||||
* For CSS Assets. The type of media for which this stylesheet has been defined.
|
||||
*
|
||||
* See https://www.w3.org/TR/CSS2/media.html#media-types.
|
||||
*
|
||||
* @var string
|
||||
*/
|
||||
protected $media;
|
||||
|
||||
/**
|
||||
* For JS Assets. Whether or not the script should be loaded in the footer.
|
||||
*
|
||||
* @var bool
|
||||
*/
|
||||
protected $in_footer;
|
||||
|
||||
/**
|
||||
* For CSS Assets. Whether this stylesheet is a right-to-left stylesheet.
|
||||
*
|
||||
* @var bool
|
||||
*/
|
||||
protected $rtl;
|
||||
|
||||
/**
|
||||
* File suffix.
|
||||
*
|
||||
* @var string
|
||||
*/
|
||||
protected $suffix;
|
||||
|
||||
/**
|
||||
* Default asset arguments.
|
||||
*
|
||||
* @var array
|
||||
*/
|
||||
private $defaults = [
|
||||
'deps' => [],
|
||||
'in_footer' => true,
|
||||
'rtl' => true,
|
||||
'media' => 'all',
|
||||
'version' => '',
|
||||
'suffix' => '',
|
||||
];
|
||||
|
||||
/**
|
||||
* Constructs an instance of the WPSEO_Admin_Asset class.
|
||||
*
|
||||
* @param array $args The arguments for this asset.
|
||||
*
|
||||
* @throws InvalidArgumentException Throws when no name or src has been provided.
|
||||
*/
|
||||
public function __construct( array $args ) {
|
||||
if ( ! isset( $args['name'] ) ) {
|
||||
throw new InvalidArgumentException( 'name is a required argument' );
|
||||
}
|
||||
|
||||
if ( ! isset( $args['src'] ) ) {
|
||||
throw new InvalidArgumentException( 'src is a required argument' );
|
||||
}
|
||||
|
||||
$args = array_merge( $this->defaults, $args );
|
||||
|
||||
$this->name = $args['name'];
|
||||
$this->src = $args['src'];
|
||||
$this->deps = $args['deps'];
|
||||
$this->version = $args['version'];
|
||||
$this->media = $args['media'];
|
||||
$this->in_footer = $args['in_footer'];
|
||||
$this->rtl = $args['rtl'];
|
||||
$this->suffix = $args['suffix'];
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the asset identifier.
|
||||
*
|
||||
* @return string
|
||||
*/
|
||||
public function get_name() {
|
||||
return $this->name;
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the path to the asset.
|
||||
*
|
||||
* @return string
|
||||
*/
|
||||
public function get_src() {
|
||||
return $this->src;
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the asset dependencies.
|
||||
*
|
||||
* @return array|string
|
||||
*/
|
||||
public function get_deps() {
|
||||
return $this->deps;
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the asset version.
|
||||
*
|
||||
* @return string|null
|
||||
*/
|
||||
public function get_version() {
|
||||
if ( ! empty( $this->version ) ) {
|
||||
return $this->version;
|
||||
}
|
||||
|
||||
return null;
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the media type for CSS assets.
|
||||
*
|
||||
* @return string
|
||||
*/
|
||||
public function get_media() {
|
||||
return $this->media;
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns whether a script asset should be loaded in the footer of the page.
|
||||
*
|
||||
* @return bool
|
||||
*/
|
||||
public function is_in_footer() {
|
||||
return $this->in_footer;
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns whether this CSS has a RTL counterpart.
|
||||
*
|
||||
* @return bool
|
||||
*/
|
||||
public function has_rtl() {
|
||||
return $this->rtl;
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the file suffix.
|
||||
*
|
||||
* @return string
|
||||
*/
|
||||
public function get_suffix() {
|
||||
return $this->suffix;
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user