File "assets-translation-loader.php"
Full Path: /home/flipjqml/onlinebetsolution.com/next_old/wp-content/plugins/elementor/core/utils/assets-translation-loader.php
File size: 2.5 KB
MIME-type: text/x-php
Charset: utf-8
<?php
namespace Elementor\Core\Utils;
if ( ! defined( 'ABSPATH' ) ) {
exit; // Exit if accessed directly.
}
class Assets_Translation_Loader {
public static function for_handles( array $handles, $domain = null, $replace_callback = null ) {
self::set_domain( $handles, $domain );
self::replace_translation_path( $handles, $replace_callback );
}
private static function set_domain( array $handles, $domain = null ) {
if ( empty( $domain ) || ! is_string( $domain ) ) {
return;
}
foreach ( $handles as $handle ) {
wp_set_script_translations( $handle, $domain );
}
}
/**
* The purpose of this function is to replace the requested translation file
* with a file that contains all the translations for specific scripts.
*
* When developing a module and using Webpack's dynamic load feature, the script will be split into multiple chunks.
* As a result, the WordPress translations expressions will also be split into multiple files.
* Therefore, we replace the requested translation file with another file (generated in the build process)
* that contains all the translations for the specific script (including dynamically loaded chunks).
*
* Want to go deeper? Read the following article:
* @see https://developer.wordpress.com/2022/01/06/wordpress-plugin-i18n-webpack-and-composer/
*
* @param array $handles
* @param callable|null $replace_callback
*/
private static function replace_translation_path( array $handles, $replace_callback = null ) {
$sources = self::map_handles_to_src( $handles );
add_filter( 'load_script_textdomain_relative_path', function ( $relative_path, $src ) use ( $sources, $replace_callback ) {
if ( ! in_array( $src, $sources, true ) ) {
return $relative_path;
}
if ( is_callable( $replace_callback ) ) {
return $replace_callback( $relative_path, $src );
}
return self::default_replace_translation( $relative_path );
}, 10, 2 );
}
private static function map_handles_to_src( array $handles ) {
return array_map( function ( $handle ) {
return wp_scripts()->registered[ $handle ]->src;
}, $handles );
}
private static function default_replace_translation( $relative_path ) {
// Translations are always based on the non-minified filename.
$relative_path_without_ext = preg_replace( '/(\.min)?\.js$/i', '', $relative_path );
// By default, we suffix the file with `.strings` (e.g 'assets/js/editor.js' => 'assets/js/editor.strings.js').
return implode( '.', [
$relative_path_without_ext,
'strings',
'js',
] );
}
}