You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
100 lines
2.8 KiB
100 lines
2.8 KiB
5 years ago
|
<?php
|
||
|
/**
|
||
|
* WPSEO plugin file.
|
||
|
*
|
||
|
* @package WPSEO\Admin
|
||
|
*/
|
||
|
|
||
|
/**
|
||
|
* Determines the location of an asset within the SEO plugin.
|
||
|
*/
|
||
|
final class WPSEO_Admin_Asset_SEO_Location implements WPSEO_Admin_Asset_Location {
|
||
|
|
||
|
/**
|
||
|
* Path to the plugin file.
|
||
|
*
|
||
|
* @var string
|
||
|
*/
|
||
|
protected $plugin_file;
|
||
|
|
||
|
/**
|
||
|
* The plugin file to base the asset location upon.
|
||
|
*
|
||
|
* @param string $plugin_file The plugin file string.
|
||
|
*/
|
||
|
public function __construct( $plugin_file ) {
|
||
|
$this->plugin_file = $plugin_file;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Determines the URL of the asset on the dev server.
|
||
|
*
|
||
|
* @param WPSEO_Admin_Asset $asset The asset to determine the URL for.
|
||
|
* @param string $type The type of asset. Usually JS or CSS.
|
||
|
*
|
||
|
* @return string The URL of the asset.
|
||
|
*/
|
||
|
public function get_url( WPSEO_Admin_Asset $asset, $type ) {
|
||
|
$path = $this->get_path( $asset, $type );
|
||
|
if ( empty( $path ) ) {
|
||
|
return '';
|
||
|
}
|
||
|
|
||
|
if ( YOAST_ENVIRONMENT !== 'development' && ! $asset->get_suffix() ) {
|
||
|
$plugin_path = plugin_dir_path( $this->plugin_file );
|
||
|
if ( ! file_exists( $plugin_path . $path ) ) {
|
||
|
|
||
|
// Give a notice to the user in the console (only once).
|
||
|
WPSEO_Utils::javascript_console_notification(
|
||
|
'Development Files',
|
||
|
sprintf(
|
||
|
/* translators: %1$s resolves to https://github.com/Yoast/wordpress-seo */
|
||
|
__( 'You are trying to load non-minified files. These are only available in our development package. Check out %1$s to see all the source files.', 'wordpress-seo' ),
|
||
|
'https://github.com/Yoast/wordpress-seo'
|
||
|
),
|
||
|
true
|
||
|
);
|
||
|
|
||
|
// Just load the .min file.
|
||
|
$path = $this->get_path( $asset, $type, '.min' );
|
||
|
}
|
||
|
}
|
||
|
|
||
|
return plugins_url( $path, $this->plugin_file );
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Determines the path relative to the plugin folder of an asset.
|
||
|
*
|
||
|
* @param WPSEO_Admin_Asset $asset The asset to determine the path
|
||
|
* for.
|
||
|
* @param string $type The type of asset.
|
||
|
* @param string|null $force_suffix The suffix to force, or null when
|
||
|
* to use the default suffix.
|
||
|
*
|
||
|
* @return string The path to the asset file.
|
||
|
*/
|
||
|
protected function get_path( WPSEO_Admin_Asset $asset, $type, $force_suffix = null ) {
|
||
|
$relative_path = '';
|
||
|
$rtl_suffix = '';
|
||
|
|
||
|
$suffix = ( $force_suffix === null ) ? $asset->get_suffix() : $force_suffix;
|
||
|
|
||
|
switch ( $type ) {
|
||
|
case WPSEO_Admin_Asset::TYPE_JS:
|
||
|
$relative_path = 'js/dist/' . $asset->get_src() . $suffix . '.js';
|
||
|
break;
|
||
|
|
||
|
case WPSEO_Admin_Asset::TYPE_CSS:
|
||
|
// Path and suffix for RTL stylesheets.
|
||
|
if ( function_exists( 'is_rtl' ) && is_rtl() && $asset->has_rtl() ) {
|
||
|
$rtl_suffix = '-rtl';
|
||
|
}
|
||
|
$relative_path = 'css/dist/' . $asset->get_src() . $rtl_suffix . $suffix . '.css';
|
||
|
break;
|
||
|
}
|
||
|
|
||
|
return $relative_path;
|
||
|
}
|
||
|
}
|