Edit File by line
/home/zeestwma/richards.../wp-conte.../plugins/elemento.../includes
File: tracker.php
<?php
[0] Fix | Delete
namespace Elementor;
[1] Fix | Delete
[2] Fix | Delete
use Elementor\Core\Common\Modules\EventTracker\DB as Events_DB_Manager;
[3] Fix | Delete
use Elementor\Core\Experiments\Experiments_Reporter;
[4] Fix | Delete
use Elementor\Modules\System_Info\Module as System_Info_Module;
[5] Fix | Delete
[6] Fix | Delete
if ( ! defined( 'ABSPATH' ) ) {
[7] Fix | Delete
exit; // Exit if accessed directly.
[8] Fix | Delete
}
[9] Fix | Delete
[10] Fix | Delete
/**
[11] Fix | Delete
* Elementor tracker.
[12] Fix | Delete
*
[13] Fix | Delete
* Elementor tracker handler class is responsible for sending non-sensitive plugin
[14] Fix | Delete
* data to Elementor servers for users that actively allowed data tracking.
[15] Fix | Delete
*
[16] Fix | Delete
* @since 1.0.0
[17] Fix | Delete
*/
[18] Fix | Delete
class Tracker {
[19] Fix | Delete
[20] Fix | Delete
/**
[21] Fix | Delete
* API URL.
[22] Fix | Delete
*
[23] Fix | Delete
* Holds the URL of the Tracker API.
[24] Fix | Delete
*
[25] Fix | Delete
* @since 1.0.0
[26] Fix | Delete
* @access private
[27] Fix | Delete
*
[28] Fix | Delete
* @var string API URL.
[29] Fix | Delete
*/
[30] Fix | Delete
private static $api_url = 'https://my.elementor.com/api/v1/tracker/';
[31] Fix | Delete
[32] Fix | Delete
private static $notice_shown = false;
[33] Fix | Delete
[34] Fix | Delete
const LAST_TERMS_UPDATED = '2025-07-07';
[35] Fix | Delete
[36] Fix | Delete
/**
[37] Fix | Delete
* Init.
[38] Fix | Delete
*
[39] Fix | Delete
* Initialize Elementor tracker.
[40] Fix | Delete
*
[41] Fix | Delete
* @since 1.0.0
[42] Fix | Delete
* @access public
[43] Fix | Delete
* @static
[44] Fix | Delete
*/
[45] Fix | Delete
public static function init() {
[46] Fix | Delete
add_action( 'elementor/tracker/send_event', [ __CLASS__, 'send_tracking_data' ] );
[47] Fix | Delete
add_action( 'admin_init', [ __CLASS__, 'handle_tracker_actions' ] );
[48] Fix | Delete
[49] Fix | Delete
add_action( 'update_option_elementor_allow_tracking', [ __CLASS__, 'set_last_update_time' ] );
[50] Fix | Delete
}
[51] Fix | Delete
[52] Fix | Delete
/**
[53] Fix | Delete
* Check for settings opt-in.
[54] Fix | Delete
*
[55] Fix | Delete
* Checks whether the site admin has opted-in for data tracking, or not.
[56] Fix | Delete
*
[57] Fix | Delete
* @since 1.0.0
[58] Fix | Delete
* @access public
[59] Fix | Delete
* @static
[60] Fix | Delete
*
[61] Fix | Delete
* @param string $new_value Allowed tracking value.
[62] Fix | Delete
*
[63] Fix | Delete
* @return string Return `yes` if tracking allowed, `no` otherwise.
[64] Fix | Delete
*/
[65] Fix | Delete
public static function check_for_settings_optin( $new_value ) {
[66] Fix | Delete
$old_value = get_option( 'elementor_allow_tracking', 'no' );
[67] Fix | Delete
if ( $old_value !== $new_value && 'yes' === $new_value ) {
[68] Fix | Delete
Plugin::$instance->custom_tasks->add_tasks_requested_to_run( [
[69] Fix | Delete
'opt_in_recalculate_usage',
[70] Fix | Delete
'opt_in_send_tracking_data',
[71] Fix | Delete
] );
[72] Fix | Delete
}
[73] Fix | Delete
[74] Fix | Delete
self::set_last_update_time();
[75] Fix | Delete
[76] Fix | Delete
if ( empty( $new_value ) ) {
[77] Fix | Delete
$new_value = 'no';
[78] Fix | Delete
}
[79] Fix | Delete
[80] Fix | Delete
return $new_value;
[81] Fix | Delete
}
[82] Fix | Delete
[83] Fix | Delete
/**
[84] Fix | Delete
* Send tracking data.
[85] Fix | Delete
*
[86] Fix | Delete
* Decide whether to send tracking data, or not.
[87] Fix | Delete
*
[88] Fix | Delete
* @since 1.0.0
[89] Fix | Delete
* @access public
[90] Fix | Delete
* @static
[91] Fix | Delete
*
[92] Fix | Delete
* @param bool $override
[93] Fix | Delete
*/
[94] Fix | Delete
public static function send_tracking_data( $override = false ) {
[95] Fix | Delete
// Don't trigger this on AJAX Requests.
[96] Fix | Delete
if ( defined( 'DOING_AJAX' ) && DOING_AJAX ) {
[97] Fix | Delete
return;
[98] Fix | Delete
}
[99] Fix | Delete
[100] Fix | Delete
if ( ! self::is_allow_track() ) {
[101] Fix | Delete
return;
[102] Fix | Delete
}
[103] Fix | Delete
[104] Fix | Delete
$last_send = self::get_last_send_time();
[105] Fix | Delete
[106] Fix | Delete
/**
[107] Fix | Delete
* Tracker override send.
[108] Fix | Delete
*
[109] Fix | Delete
* Filters whether to override sending tracking data or not.
[110] Fix | Delete
*
[111] Fix | Delete
* @since 1.0.0
[112] Fix | Delete
*
[113] Fix | Delete
* @param bool $override Whether to override default setting or not.
[114] Fix | Delete
*/
[115] Fix | Delete
$override = apply_filters( 'elementor/tracker/send_override', $override );
[116] Fix | Delete
[117] Fix | Delete
if ( ! $override ) {
[118] Fix | Delete
$last_send_interval = strtotime( '-1 week' );
[119] Fix | Delete
[120] Fix | Delete
/**
[121] Fix | Delete
* Tracker last send interval.
[122] Fix | Delete
*
[123] Fix | Delete
* Filters the interval of between two tracking requests.
[124] Fix | Delete
*
[125] Fix | Delete
* @since 1.0.0
[126] Fix | Delete
*
[127] Fix | Delete
* @param int $last_send_interval A date/time string. Default is `strtotime( '-1 week' )`.
[128] Fix | Delete
*/
[129] Fix | Delete
$last_send_interval = apply_filters( 'elementor/tracker/last_send_interval', $last_send_interval );
[130] Fix | Delete
[131] Fix | Delete
// Send a maximum of once per week by default.
[132] Fix | Delete
if ( $last_send && $last_send > $last_send_interval ) {
[133] Fix | Delete
return;
[134] Fix | Delete
}
[135] Fix | Delete
} elseif ( $last_send && $last_send > strtotime( '-1 hours' ) ) {
[136] Fix | Delete
return;
[137] Fix | Delete
}
[138] Fix | Delete
[139] Fix | Delete
// Update time first before sending to ensure it is set.
[140] Fix | Delete
update_option( 'elementor_tracker_last_send', time() );
[141] Fix | Delete
[142] Fix | Delete
$params = self::get_tracking_data( empty( $last_send ) );
[143] Fix | Delete
[144] Fix | Delete
// Tracking data is used for System Info reports, and events should not be included in System Info reports,
[145] Fix | Delete
// so it is added here.
[146] Fix | Delete
$params['analytics_events'] = self::get_events();
[147] Fix | Delete
[148] Fix | Delete
add_filter( 'https_ssl_verify', '__return_false' );
[149] Fix | Delete
[150] Fix | Delete
wp_safe_remote_post(
[151] Fix | Delete
self::$api_url,
[152] Fix | Delete
[
[153] Fix | Delete
'timeout' => 25,
[154] Fix | Delete
'blocking' => false,
[155] Fix | Delete
'body' => [
[156] Fix | Delete
'data' => wp_json_encode( $params ),
[157] Fix | Delete
],
[158] Fix | Delete
]
[159] Fix | Delete
);
[160] Fix | Delete
[161] Fix | Delete
// After sending the event tracking data, we reset the events table.
[162] Fix | Delete
Events_DB_Manager::reset_table();
[163] Fix | Delete
}
[164] Fix | Delete
[165] Fix | Delete
/**
[166] Fix | Delete
* Is allow track.
[167] Fix | Delete
*
[168] Fix | Delete
* Checks whether the site admin has opted-in for data tracking, or not.
[169] Fix | Delete
*
[170] Fix | Delete
* @since 1.0.0
[171] Fix | Delete
* @access public
[172] Fix | Delete
* @static
[173] Fix | Delete
*/
[174] Fix | Delete
public static function is_allow_track() {
[175] Fix | Delete
return 'yes' === get_option( 'elementor_allow_tracking', 'no' );
[176] Fix | Delete
}
[177] Fix | Delete
[178] Fix | Delete
public static function get_last_update_time() {
[179] Fix | Delete
return get_option( 'elementor_allow_tracking_last_update', false );
[180] Fix | Delete
}
[181] Fix | Delete
[182] Fix | Delete
public static function set_last_update_time(): void {
[183] Fix | Delete
update_option( 'elementor_allow_tracking_last_update', gmdate( 'U' ) );
[184] Fix | Delete
}
[185] Fix | Delete
[186] Fix | Delete
public static function has_terms_changed( $terms_updated = self::LAST_TERMS_UPDATED ): bool {
[187] Fix | Delete
if ( ! self::is_allow_track() ) {
[188] Fix | Delete
return false;
[189] Fix | Delete
}
[190] Fix | Delete
[191] Fix | Delete
$last_update_time = self::get_last_update_time();
[192] Fix | Delete
if ( $last_update_time ) {
[193] Fix | Delete
$terms_updated_timestamp = strtotime( $terms_updated . ' UTC' );
[194] Fix | Delete
[195] Fix | Delete
return $last_update_time < $terms_updated_timestamp;
[196] Fix | Delete
}
[197] Fix | Delete
[198] Fix | Delete
return true;
[199] Fix | Delete
}
[200] Fix | Delete
[201] Fix | Delete
/**
[202] Fix | Delete
* Handle tracker actions.
[203] Fix | Delete
*
[204] Fix | Delete
* Check if the user opted-in or opted-out and update the database.
[205] Fix | Delete
*
[206] Fix | Delete
* Fired by `admin_init` action.
[207] Fix | Delete
*
[208] Fix | Delete
* @since 1.0.0
[209] Fix | Delete
* @access public
[210] Fix | Delete
* @static
[211] Fix | Delete
*/
[212] Fix | Delete
public static function handle_tracker_actions() {
[213] Fix | Delete
if ( ! isset( $_GET['elementor_tracker'] ) ) {
[214] Fix | Delete
return;
[215] Fix | Delete
}
[216] Fix | Delete
[217] Fix | Delete
if ( 'opt_into' === $_GET['elementor_tracker'] ) {
[218] Fix | Delete
check_admin_referer( 'opt_into' );
[219] Fix | Delete
[220] Fix | Delete
self::set_opt_in( true );
[221] Fix | Delete
}
[222] Fix | Delete
[223] Fix | Delete
if ( 'opt_out' === $_GET['elementor_tracker'] ) {
[224] Fix | Delete
check_admin_referer( 'opt_out' );
[225] Fix | Delete
[226] Fix | Delete
self::set_opt_in( false );
[227] Fix | Delete
}
[228] Fix | Delete
[229] Fix | Delete
wp_safe_redirect( remove_query_arg( 'elementor_tracker' ) );
[230] Fix | Delete
exit;
[231] Fix | Delete
}
[232] Fix | Delete
[233] Fix | Delete
/**
[234] Fix | Delete
* @since 2.2.0
[235] Fix | Delete
* @access public
[236] Fix | Delete
* @static
[237] Fix | Delete
*/
[238] Fix | Delete
public static function is_notice_shown() {
[239] Fix | Delete
return self::$notice_shown;
[240] Fix | Delete
}
[241] Fix | Delete
[242] Fix | Delete
public static function set_opt_in( $value ) {
[243] Fix | Delete
if ( $value ) {
[244] Fix | Delete
update_option( 'elementor_allow_tracking', 'yes' );
[245] Fix | Delete
self::set_last_update_time();
[246] Fix | Delete
[247] Fix | Delete
self::send_tracking_data( true );
[248] Fix | Delete
} else {
[249] Fix | Delete
update_option( 'elementor_allow_tracking', 'no' );
[250] Fix | Delete
update_option( 'elementor_tracker_notice', '1' );
[251] Fix | Delete
}
[252] Fix | Delete
}
[253] Fix | Delete
[254] Fix | Delete
/**
[255] Fix | Delete
* Get system reports data.
[256] Fix | Delete
*
[257] Fix | Delete
* Retrieve the data from system reports.
[258] Fix | Delete
*
[259] Fix | Delete
* @since 2.0.0
[260] Fix | Delete
* @access private
[261] Fix | Delete
* @static
[262] Fix | Delete
*
[263] Fix | Delete
* @return array The data from system reports.
[264] Fix | Delete
*/
[265] Fix | Delete
private static function get_system_reports_data() {
[266] Fix | Delete
$reports = Plugin::$instance->system_info->load_reports( System_Info_Module::get_allowed_reports() );
[267] Fix | Delete
[268] Fix | Delete
// The log report should not be sent with the usage data - it is not used and causes bloat.
[269] Fix | Delete
if ( isset( $reports['log'] ) ) {
[270] Fix | Delete
unset( $reports['log'] );
[271] Fix | Delete
}
[272] Fix | Delete
[273] Fix | Delete
$system_reports = [];
[274] Fix | Delete
foreach ( $reports as $report_key => $report_details ) {
[275] Fix | Delete
$system_reports[ $report_key ] = [];
[276] Fix | Delete
foreach ( $report_details['report']->get_report() as $sub_report_key => $sub_report_details ) {
[277] Fix | Delete
$system_reports[ $report_key ][ $sub_report_key ] = $sub_report_details['value'];
[278] Fix | Delete
}
[279] Fix | Delete
}
[280] Fix | Delete
return $system_reports;
[281] Fix | Delete
}
[282] Fix | Delete
[283] Fix | Delete
/**
[284] Fix | Delete
* Get last send time.
[285] Fix | Delete
*
[286] Fix | Delete
* Retrieve the last time tracking data was sent.
[287] Fix | Delete
*
[288] Fix | Delete
* @since 2.0.0
[289] Fix | Delete
* @access private
[290] Fix | Delete
* @static
[291] Fix | Delete
*
[292] Fix | Delete
* @return int|false The last time tracking data was sent, or false if
[293] Fix | Delete
* tracking data never sent.
[294] Fix | Delete
*/
[295] Fix | Delete
private static function get_last_send_time() {
[296] Fix | Delete
$last_send_time = get_option( 'elementor_tracker_last_send', false );
[297] Fix | Delete
[298] Fix | Delete
/**
[299] Fix | Delete
* Tracker last send time.
[300] Fix | Delete
*
[301] Fix | Delete
* Filters the last time tracking data was sent.
[302] Fix | Delete
*
[303] Fix | Delete
* @since 1.0.0
[304] Fix | Delete
*
[305] Fix | Delete
* @param int|false $last_send_time The last time tracking data was sent,
[306] Fix | Delete
* or false if tracking data never sent.
[307] Fix | Delete
*/
[308] Fix | Delete
$last_send_time = apply_filters( 'elementor/tracker/last_send_time', $last_send_time );
[309] Fix | Delete
[310] Fix | Delete
return $last_send_time;
[311] Fix | Delete
}
[312] Fix | Delete
[313] Fix | Delete
/**
[314] Fix | Delete
* Get non elementor post usages.
[315] Fix | Delete
*
[316] Fix | Delete
* Retrieve the number of posts that not using elementor.
[317] Fix | Delete
[318] Fix | Delete
* @return array The number of posts using not used by Elementor grouped by post types
[319] Fix | Delete
* and post status.
[320] Fix | Delete
*/
[321] Fix | Delete
public static function get_non_elementor_posts_usage() {
[322] Fix | Delete
global $wpdb;
[323] Fix | Delete
[324] Fix | Delete
$usage = [];
[325] Fix | Delete
[326] Fix | Delete
// phpcs:ignore WordPress.DB.DirectDatabaseQuery.NoCaching, WordPress.DB.DirectDatabaseQuery.DirectQuery
[327] Fix | Delete
$results = $wpdb->get_results(
[328] Fix | Delete
"SELECT `post_type`, `post_status`, COUNT(`ID`) `hits`
[329] Fix | Delete
FROM {$wpdb->posts} `p`
[330] Fix | Delete
LEFT JOIN {$wpdb->postmeta} `pm` ON(`p`.`ID` = `pm`.`post_id` AND `meta_key` = '_elementor_edit_mode' )
[331] Fix | Delete
WHERE `post_type` != 'elementor_library' AND `meta_value` IS NULL
[332] Fix | Delete
GROUP BY `post_type`, `post_status`;"
[333] Fix | Delete
);
[334] Fix | Delete
[335] Fix | Delete
if ( $results ) {
[336] Fix | Delete
foreach ( $results as $result ) {
[337] Fix | Delete
$usage[ $result->post_type ][ $result->post_status ] = $result->hits;
[338] Fix | Delete
}
[339] Fix | Delete
}
[340] Fix | Delete
[341] Fix | Delete
return $usage;
[342] Fix | Delete
}
[343] Fix | Delete
[344] Fix | Delete
/**
[345] Fix | Delete
* Get posts usage.
[346] Fix | Delete
*
[347] Fix | Delete
* Retrieve the number of posts using Elementor.
[348] Fix | Delete
*
[349] Fix | Delete
* @since 2.0.0
[350] Fix | Delete
* @access public
[351] Fix | Delete
* @static
[352] Fix | Delete
*
[353] Fix | Delete
* @return array The number of posts using Elementor grouped by post types
[354] Fix | Delete
* and post status.
[355] Fix | Delete
*/
[356] Fix | Delete
public static function get_posts_usage() {
[357] Fix | Delete
global $wpdb;
[358] Fix | Delete
[359] Fix | Delete
$usage = [];
[360] Fix | Delete
[361] Fix | Delete
// phpcs:ignore WordPress.DB.DirectDatabaseQuery.NoCaching, WordPress.DB.DirectDatabaseQuery.DirectQuery
[362] Fix | Delete
$results = $wpdb->get_results(
[363] Fix | Delete
"SELECT `post_type`, `post_status`, COUNT(`ID`) `hits`
[364] Fix | Delete
FROM {$wpdb->posts} `p`
[365] Fix | Delete
LEFT JOIN {$wpdb->postmeta} `pm` ON(`p`.`ID` = `pm`.`post_id`)
[366] Fix | Delete
WHERE `post_type` != 'elementor_library'
[367] Fix | Delete
AND `meta_key` = '_elementor_edit_mode' AND `meta_value` = 'builder'
[368] Fix | Delete
GROUP BY `post_type`, `post_status`;"
[369] Fix | Delete
);
[370] Fix | Delete
[371] Fix | Delete
if ( $results ) {
[372] Fix | Delete
foreach ( $results as $result ) {
[373] Fix | Delete
$usage[ $result->post_type ][ $result->post_status ] = (int) $result->hits;
[374] Fix | Delete
}
[375] Fix | Delete
}
[376] Fix | Delete
[377] Fix | Delete
return $usage;
[378] Fix | Delete
}
[379] Fix | Delete
[380] Fix | Delete
/**
[381] Fix | Delete
* Get library usage.
[382] Fix | Delete
*
[383] Fix | Delete
* Retrieve the number of Elementor library items saved.
[384] Fix | Delete
*
[385] Fix | Delete
* @since 2.0.0
[386] Fix | Delete
* @access public
[387] Fix | Delete
* @static
[388] Fix | Delete
*
[389] Fix | Delete
* @return array The number of Elementor library items grouped by post types
[390] Fix | Delete
* and meta value.
[391] Fix | Delete
*/
[392] Fix | Delete
public static function get_library_usage() {
[393] Fix | Delete
global $wpdb;
[394] Fix | Delete
[395] Fix | Delete
$usage = [];
[396] Fix | Delete
[397] Fix | Delete
// phpcs:ignore WordPress.DB.DirectDatabaseQuery.NoCaching, WordPress.DB.DirectDatabaseQuery.DirectQuery
[398] Fix | Delete
$results = $wpdb->get_results(
[399] Fix | Delete
"SELECT `meta_value`, COUNT(`ID`) `hits`
[400] Fix | Delete
FROM {$wpdb->posts} `p`
[401] Fix | Delete
LEFT JOIN {$wpdb->postmeta} `pm` ON(`p`.`ID` = `pm`.`post_id`)
[402] Fix | Delete
WHERE `post_type` = 'elementor_library'
[403] Fix | Delete
AND `meta_key` = '_elementor_template_type'
[404] Fix | Delete
GROUP BY `post_type`, `meta_value`;"
[405] Fix | Delete
);
[406] Fix | Delete
[407] Fix | Delete
if ( $results ) {
[408] Fix | Delete
foreach ( $results as $result ) {
[409] Fix | Delete
$usage[ $result->meta_value ] = $result->hits;
[410] Fix | Delete
}
[411] Fix | Delete
}
[412] Fix | Delete
[413] Fix | Delete
return $usage;
[414] Fix | Delete
}
[415] Fix | Delete
[416] Fix | Delete
/**
[417] Fix | Delete
* Get usage of general settings.
[418] Fix | Delete
* 'Elementor->Settings->General'.
[419] Fix | Delete
*
[420] Fix | Delete
* @return array
[421] Fix | Delete
*/
[422] Fix | Delete
public static function get_settings_general_usage() {
[423] Fix | Delete
return self::get_tracking_data_from_settings( 'general' );
[424] Fix | Delete
}
[425] Fix | Delete
[426] Fix | Delete
/**
[427] Fix | Delete
* Get usage of advanced settings.
[428] Fix | Delete
* 'Elementor->Settings->Advanced'.
[429] Fix | Delete
*
[430] Fix | Delete
* @return array
[431] Fix | Delete
*/
[432] Fix | Delete
public static function get_settings_advanced_usage() {
[433] Fix | Delete
return self::get_tracking_data_from_settings( 'advanced' );
[434] Fix | Delete
}
[435] Fix | Delete
[436] Fix | Delete
/**
[437] Fix | Delete
* Get usage of performance settings.
[438] Fix | Delete
* 'Elementor->Settings->Performance'.
[439] Fix | Delete
*
[440] Fix | Delete
* @return array
[441] Fix | Delete
*/
[442] Fix | Delete
public static function get_settings_performance_usage() {
[443] Fix | Delete
return self::get_tracking_data_from_settings( 'performance' );
[444] Fix | Delete
}
[445] Fix | Delete
[446] Fix | Delete
/**
[447] Fix | Delete
* Get usage of experiments settings.
[448] Fix | Delete
*
[449] Fix | Delete
* 'Elementor->Settings->Experiments'.
[450] Fix | Delete
*
[451] Fix | Delete
* @return array
[452] Fix | Delete
*/
[453] Fix | Delete
public static function get_settings_experiments_usage() {
[454] Fix | Delete
$system_info = Plugin::$instance->system_info;
[455] Fix | Delete
[456] Fix | Delete
/**
[457] Fix | Delete
* @var $experiments_report Experiments_Reporter
[458] Fix | Delete
*/
[459] Fix | Delete
$experiments_report = $system_info->create_reporter( [
[460] Fix | Delete
'class_name' => Experiments_Reporter::class,
[461] Fix | Delete
] );
[462] Fix | Delete
[463] Fix | Delete
return $experiments_report->get_experiments()['value'];
[464] Fix | Delete
}
[465] Fix | Delete
[466] Fix | Delete
/**
[467] Fix | Delete
* Get usage of general tools.
[468] Fix | Delete
* 'Elementor->Tools->General'.
[469] Fix | Delete
*
[470] Fix | Delete
* @return array
[471] Fix | Delete
*/
[472] Fix | Delete
public static function get_tools_general_usage() {
[473] Fix | Delete
return self::get_tracking_data_from_tools( 'general' );
[474] Fix | Delete
}
[475] Fix | Delete
[476] Fix | Delete
/**
[477] Fix | Delete
* Get usage of 'version control' tools.
[478] Fix | Delete
* 'Elementor->Tools->Version Control'.
[479] Fix | Delete
*
[480] Fix | Delete
* @return array
[481] Fix | Delete
*/
[482] Fix | Delete
public static function get_tools_version_control_usage() {
[483] Fix | Delete
return self::get_tracking_data_from_tools( 'versions' );
[484] Fix | Delete
}
[485] Fix | Delete
[486] Fix | Delete
/**
[487] Fix | Delete
* Get usage of 'maintenance' tools.
[488] Fix | Delete
* 'Elementor->Tools->Maintenance'.
[489] Fix | Delete
*
[490] Fix | Delete
* @return array
[491] Fix | Delete
*/
[492] Fix | Delete
public static function get_tools_maintenance_usage() {
[493] Fix | Delete
return self::get_tracking_data_from_tools( 'maintenance_mode' );
[494] Fix | Delete
}
[495] Fix | Delete
[496] Fix | Delete
/**
[497] Fix | Delete
* Get library usage extend.
[498] Fix | Delete
*
[499] Fix | Delete
12
It is recommended that you Edit text format, this type of Fix handles quite a lot in one request
Function