' . __( 'There are no product reviews yet.', 'woocommerce' ) . '
';
+ }
+ }
+
+ /**
+ * Network orders widget.
+ */
+ public function network_orders() {
+ $suffix = defined( 'SCRIPT_DEBUG' ) && SCRIPT_DEBUG ? '' : '.min';
+
+ wp_enqueue_style( 'wc-network-orders', WC()->plugin_url() . '/assets/css/network-order-widget.css', array(), WC_VERSION );
+
+ wp_enqueue_script( 'wc-network-orders', WC()->plugin_url() . '/assets/js/admin/network-orders' . $suffix . '.js', array( 'jquery', 'underscore' ), WC_VERSION, true );
+
+ $user = wp_get_current_user();
+ $blogs = get_blogs_of_user( $user->ID );
+ $blog_ids = wp_list_pluck( $blogs, 'userblog_id' );
+
+ wp_localize_script(
+ 'wc-network-orders', 'woocommerce_network_orders', array(
+ 'nonce' => wp_create_nonce( 'wp_rest' ),
+ 'sites' => array_values( $blog_ids ),
+ 'order_endpoint' => get_rest_url( null, 'wc/v2/orders/network' ),
+ )
+ );
+ ?>
+
@@ -367,9 +376,9 @@ class WC_Admin_Dashboard {
plugin_url() . '/assets/js/admin/wc-product-export' . $suffix . '.js', array( 'jquery' ), WC_VERSION );
- wp_localize_script( 'wc-product-export', 'wc_product_export_params', array(
- 'export_nonce' => wp_create_nonce( 'wc-product-export' ),
- ) );
+ wp_localize_script(
+ 'wc-product-export',
+ 'wc_product_export_params',
+ array(
+ 'export_nonce' => wp_create_nonce( 'wc-product-export' ),
+ )
+ );
}
/**
* Export page UI.
*/
public function product_exporter() {
- include_once( WC_ABSPATH . 'includes/export/class-wc-product-csv-exporter.php' );
- include_once( dirname( __FILE__ ) . '/views/html-admin-page-product-export.php' );
+ include_once WC_ABSPATH . 'includes/export/class-wc-product-csv-exporter.php';
+ include_once dirname( __FILE__ ) . '/views/html-admin-page-product-export.php';
}
/**
@@ -91,7 +95,7 @@ class WC_Admin_Exporters {
*/
public function download_export_file() {
if ( isset( $_GET['action'], $_GET['nonce'] ) && wp_verify_nonce( wp_unslash( $_GET['nonce'] ), 'product-csv' ) && 'download_product_csv' === wp_unslash( $_GET['action'] ) ) { // WPCS: input var ok, sanitization ok.
- include_once( WC_ABSPATH . 'includes/export/class-wc-product-csv-exporter.php' );
+ include_once WC_ABSPATH . 'includes/export/class-wc-product-csv-exporter.php';
$exporter = new WC_Product_CSV_Exporter();
if ( ! empty( $_GET['filename'] ) ) { // WPCS: input var ok.
@@ -112,7 +116,7 @@ class WC_Admin_Exporters {
wp_die( -1 );
}
- include_once( WC_ABSPATH . 'includes/export/class-wc-product-csv-exporter.php' );
+ include_once WC_ABSPATH . 'includes/export/class-wc-product-csv-exporter.php';
$step = isset( $_POST['step'] ) ? absint( $_POST['step'] ) : 1; // WPCS: input var ok, sanitization ok.
$exporter = new WC_Product_CSV_Exporter();
@@ -140,20 +144,31 @@ class WC_Admin_Exporters {
$exporter->set_page( $step );
$exporter->generate_file();
- $query_args = apply_filters( 'woocommerce_export_get_ajax_query_args', array( 'nonce' => wp_create_nonce( 'product-csv' ), 'action' => 'download_product_csv', 'filename' => $exporter->get_filename() ) );
+ $query_args = apply_filters(
+ 'woocommerce_export_get_ajax_query_args',
+ array(
+ 'nonce' => wp_create_nonce( 'product-csv' ),
+ 'action' => 'download_product_csv',
+ 'filename' => $exporter->get_filename(),
+ )
+ );
if ( 100 === $exporter->get_percent_complete() ) {
- wp_send_json_success( array(
- 'step' => 'done',
- 'percentage' => 100,
- 'url' => add_query_arg( $query_args, admin_url( 'edit.php?post_type=product&page=product_exporter' ) ),
- ) );
+ wp_send_json_success(
+ array(
+ 'step' => 'done',
+ 'percentage' => 100,
+ 'url' => add_query_arg( $query_args, admin_url( 'edit.php?post_type=product&page=product_exporter' ) ),
+ )
+ );
} else {
- wp_send_json_success( array(
- 'step' => ++$step,
- 'percentage' => $exporter->get_percent_complete(),
- 'columns' => $exporter->get_column_names(),
- ) );
+ wp_send_json_success(
+ array(
+ 'step' => ++$step,
+ 'percentage' => $exporter->get_percent_complete(),
+ 'columns' => $exporter->get_column_names(),
+ )
+ );
}
}
}
diff --git a/includes/admin/class-wc-admin-help.php b/includes/admin/class-wc-admin-help.php
index f4e579c900a..26d9b39c486 100644
--- a/includes/admin/class-wc-admin-help.php
+++ b/includes/admin/class-wc-admin-help.php
@@ -36,55 +36,63 @@ class WC_Admin_Help {
return;
}
- $screen->add_help_tab( array(
- 'id' => 'woocommerce_support_tab',
- 'title' => __( 'Help & Support', 'woocommerce' ),
- 'content' =>
- '
' . __( 'Help & Support', 'woocommerce' ) . '
' .
- '
' . sprintf(
- /* translators: %s: Documentation URL */
- __( 'Should you need help understanding, using, or extending WooCommerce, please read our documentation. You will find all kinds of resources including snippets, tutorials and much more.', 'woocommerce' ),
- 'https://docs.woocommerce.com/documentation/plugins/woocommerce/?utm_source=helptab&utm_medium=product&utm_content=docs&utm_campaign=woocommerceplugin'
- ) . '
' .
- '
' . sprintf(
- /* translators: %s: Forum URL */
- __( 'For further assistance with WooCommerce core you can use the community forum. If you need help with premium extensions sold by WooCommerce, please use our helpdesk.', 'woocommerce' ),
- 'https://wordpress.org/support/plugin/woocommerce',
- 'https://woocommerce.com/my-account/tickets/?utm_source=helptab&utm_medium=product&utm_content=tickets&utm_campaign=woocommerceplugin'
- ) . '
' .
- '
' . __( 'Before asking for help we recommend checking the system status page to identify any problems with your configuration.', 'woocommerce' ) . '
' .
- '
' . __( 'System status', 'woocommerce' ) . ' ' . __( 'Community forum', 'woocommerce' ) . ' ' . __( 'WooCommerce helpdesk', 'woocommerce' ) . '
',
- ) );
+ $screen->add_help_tab(
+ array(
+ 'id' => 'woocommerce_support_tab',
+ 'title' => __( 'Help & Support', 'woocommerce' ),
+ 'content' =>
+ '
' . __( 'Help & Support', 'woocommerce' ) . '
' .
+ '
' . sprintf(
+ /* translators: %s: Documentation URL */
+ __( 'Should you need help understanding, using, or extending WooCommerce, please read our documentation. You will find all kinds of resources including snippets, tutorials and much more.', 'woocommerce' ),
+ 'https://docs.woocommerce.com/documentation/plugins/woocommerce/?utm_source=helptab&utm_medium=product&utm_content=docs&utm_campaign=woocommerceplugin'
+ ) . '
' .
+ '
' . sprintf(
+ /* translators: %s: Forum URL */
+ __( 'For further assistance with WooCommerce core you can use the community forum. If you need help with premium extensions sold by WooCommerce, please use our helpdesk.', 'woocommerce' ),
+ 'https://wordpress.org/support/plugin/woocommerce',
+ 'https://woocommerce.com/my-account/tickets/?utm_source=helptab&utm_medium=product&utm_content=tickets&utm_campaign=woocommerceplugin'
+ ) . '
' .
+ '
' . __( 'Before asking for help we recommend checking the system status page to identify any problems with your configuration.', 'woocommerce' ) . '
' .
+ '
' . __( 'System status', 'woocommerce' ) . ' ' . __( 'Community forum', 'woocommerce' ) . ' ' . __( 'WooCommerce helpdesk', 'woocommerce' ) . '
',
+ )
+ );
- $screen->add_help_tab( array(
- 'id' => 'woocommerce_bugs_tab',
- 'title' => __( 'Found a bug?', 'woocommerce' ),
- 'content' =>
- '
' . __( 'Found a bug?', 'woocommerce' ) . '
' .
- /* translators: 1: GitHub issues URL 2: GitHub contribution guide URL 3: System status report URL */
- '
' . sprintf( __( 'If you find a bug within WooCommerce core you can create a ticket via Github issues. Ensure you read the contribution guide prior to submitting your report. To help us solve your issue, please be as descriptive as possible and include your system status report.', 'woocommerce' ), 'https://github.com/woocommerce/woocommerce/issues?state=open', 'https://github.com/woocommerce/woocommerce/blob/master/.github/CONTRIBUTING.md', admin_url( 'admin.php?page=wc-status' ) ) . '
' .
- '
' . __( 'Report a bug', 'woocommerce' ) . ' ' . __( 'System status', 'woocommerce' ) . '
',
+ $screen->add_help_tab(
+ array(
+ 'id' => 'woocommerce_bugs_tab',
+ 'title' => __( 'Found a bug?', 'woocommerce' ),
+ 'content' =>
+ '
' . __( 'Found a bug?', 'woocommerce' ) . '
' .
+ /* translators: 1: GitHub issues URL 2: GitHub contribution guide URL 3: System status report URL */
+ '
' . sprintf( __( 'If you find a bug within WooCommerce core you can create a ticket via Github issues. Ensure you read the contribution guide prior to submitting your report. To help us solve your issue, please be as descriptive as possible and include your system status report.', 'woocommerce' ), 'https://github.com/woocommerce/woocommerce/issues?state=open', 'https://github.com/woocommerce/woocommerce/blob/master/.github/CONTRIBUTING.md', admin_url( 'admin.php?page=wc-status' ) ) . '
' .
+ '
' . __( 'Report a bug', 'woocommerce' ) . ' ' . __( 'System status', 'woocommerce' ) . '
',
- ) );
+ )
+ );
- $screen->add_help_tab( array(
- 'id' => 'woocommerce_education_tab',
- 'title' => __( 'Education', 'woocommerce' ),
- 'content' =>
- '
' . __( 'Education', 'woocommerce' ) . '
' .
- '
' . __( 'If you would like to learn about using WooCommerce from an expert, consider following a WooCommerce course offered by one of our educational partners.', 'woocommerce' ) . '
' .
- '
' . __( 'View education partners', 'woocommerce' ) . '
',
- ) );
+ $screen->add_help_tab(
+ array(
+ 'id' => 'woocommerce_education_tab',
+ 'title' => __( 'Education', 'woocommerce' ),
+ 'content' =>
+ '
' . __( 'Education', 'woocommerce' ) . '
' .
+ '
' . __( 'If you would like to learn about using WooCommerce from an expert, consider following a WooCommerce course offered by one of our educational partners.', 'woocommerce' ) . '
' .
+ '
' . __( 'View education partners', 'woocommerce' ) . '
',
+ )
+ );
- $screen->add_help_tab( array(
- 'id' => 'woocommerce_onboard_tab',
- 'title' => __( 'Setup wizard', 'woocommerce' ),
- 'content' =>
- '
' . __( 'Setup wizard', 'woocommerce' ) . '
' .
- '
' . __( 'If you need to access the setup wizard again, please click on the button below.', 'woocommerce' ) . '
' .
- '
' . __( 'Setup wizard', 'woocommerce' ) . '
',
+ $screen->add_help_tab(
+ array(
+ 'id' => 'woocommerce_onboard_tab',
+ 'title' => __( 'Setup wizard', 'woocommerce' ),
+ 'content' =>
+ '
' . __( 'Setup wizard', 'woocommerce' ) . '
' .
+ '
' . __( 'If you need to access the setup wizard again, please click on the button below.', 'woocommerce' ) . '
' .
+ '
' . __( 'Setup wizard', 'woocommerce' ) . '
',
- ) );
+ )
+ );
$screen->set_help_sidebar(
'
' . __( 'For more information:', 'woocommerce' ) . '
' .
diff --git a/includes/admin/class-wc-admin-importers.php b/includes/admin/class-wc-admin-importers.php
index 43d88fa4d66..7829a1efed3 100644
--- a/includes/admin/class-wc-admin-importers.php
+++ b/includes/admin/class-wc-admin-importers.php
@@ -89,8 +89,8 @@ class WC_Admin_Importers {
exit;
}
- include_once( WC_ABSPATH . 'includes/import/class-wc-product-csv-importer.php' );
- include_once( WC_ABSPATH . 'includes/admin/importers/class-wc-product-csv-importer-controller.php' );
+ include_once WC_ABSPATH . 'includes/import/class-wc-product-csv-importer.php';
+ include_once WC_ABSPATH . 'includes/admin/importers/class-wc-product-csv-importer-controller.php';
$importer = new WC_Product_CSV_Importer_Controller();
$importer->dispatch();
@@ -102,7 +102,7 @@ class WC_Admin_Importers {
public function register_importers() {
if ( defined( 'WP_LOAD_IMPORTERS' ) ) {
add_action( 'import_start', array( $this, 'post_importer_compatibility' ) );
- register_importer( 'woocommerce_product_csv', __( 'WooCommerce products (CSV)', 'woocommerce' ), __( 'Import
products to your store via a csv file.', 'woocommerce' ), array( $this, 'product_importer' ) );
+ register_importer( 'woocommerce_product_csv', __( 'WooCommerce products (CSV)', 'woocommerce' ), __( 'Import
products to your store via a csv file.', 'woocommerce' ), array( $this, 'product_importer' ) );
register_importer( 'woocommerce_tax_rate_csv', __( 'WooCommerce tax rates (CSV)', 'woocommerce' ), __( 'Import
tax rates to your store via a csv file.', 'woocommerce' ), array( $this, 'tax_rates_importer' ) );
}
}
@@ -123,7 +123,7 @@ class WC_Admin_Importers {
}
// includes
- require( dirname( __FILE__ ) . '/importers/class-wc-tax-rate-importer.php' );
+ require dirname( __FILE__ ) . '/importers/class-wc-tax-rate-importer.php';
// Dispatch
$importer = new WC_Tax_Rate_Importer();
@@ -158,25 +158,29 @@ class WC_Admin_Importers {
// Create the taxonomy
if ( ! in_array( $attribute_name, wc_get_attribute_taxonomies() ) ) {
- wc_create_attribute( array(
- 'name' => $attribute_name,
- 'slug' => $attribute_name,
- 'type' => 'select',
- 'order_by' => 'menu_order',
- 'has_archives' => false,
- ) );
+ wc_create_attribute(
+ array(
+ 'name' => $attribute_name,
+ 'slug' => $attribute_name,
+ 'type' => 'select',
+ 'order_by' => 'menu_order',
+ 'has_archives' => false,
+ )
+ );
}
// Register the taxonomy now so that the import works!
register_taxonomy(
$term['domain'],
apply_filters( 'woocommerce_taxonomy_objects_' . $term['domain'], array( 'product' ) ),
- apply_filters( 'woocommerce_taxonomy_args_' . $term['domain'], array(
- 'hierarchical' => true,
- 'show_ui' => false,
- 'query_var' => true,
- 'rewrite' => false,
- ) )
+ apply_filters(
+ 'woocommerce_taxonomy_args_' . $term['domain'], array(
+ 'hierarchical' => true,
+ 'show_ui' => false,
+ 'query_var' => true,
+ 'rewrite' => false,
+ )
+ )
);
}
}
@@ -198,8 +202,8 @@ class WC_Admin_Importers {
wp_die( -1 );
}
- include_once( WC_ABSPATH . 'includes/admin/importers/class-wc-product-csv-importer-controller.php' );
- include_once( WC_ABSPATH . 'includes/import/class-wc-product-csv-importer.php' );
+ include_once WC_ABSPATH . 'includes/admin/importers/class-wc-product-csv-importer-controller.php';
+ include_once WC_ABSPATH . 'includes/import/class-wc-product-csv-importer.php';
$file = wc_clean( $_POST['file'] );
$params = array(
@@ -228,36 +232,40 @@ class WC_Admin_Importers {
if ( 100 === $percent_complete ) {
// Clear temp meta.
$wpdb->delete( $wpdb->postmeta, array( 'meta_key' => '_original_id' ) );
- $wpdb->query( "
- DELETE {$wpdb->posts}, {$wpdb->postmeta}, {$wpdb->term_relationships}
+ $wpdb->query(
+ "DELETE {$wpdb->posts}, {$wpdb->postmeta}, {$wpdb->term_relationships}
FROM {$wpdb->posts}
LEFT JOIN {$wpdb->term_relationships} ON ( {$wpdb->posts}.ID = {$wpdb->term_relationships}.object_id )
LEFT JOIN {$wpdb->postmeta} ON ( {$wpdb->posts}.ID = {$wpdb->postmeta}.post_id )
LEFT JOIN {$wpdb->term_taxonomy} ON ( {$wpdb->term_taxonomy}.term_taxonomy_id = {$wpdb->term_relationships}.term_taxonomy_id )
LEFT JOIN {$wpdb->terms} ON ( {$wpdb->terms}.term_id = {$wpdb->term_taxonomy}.term_id )
WHERE {$wpdb->posts}.post_type IN ( 'product', 'product_variation' )
- AND {$wpdb->posts}.post_status = 'importing'
- " );
+ AND {$wpdb->posts}.post_status = 'importing'"
+ );
// Send success.
- wp_send_json_success( array(
- 'position' => 'done',
- 'percentage' => 100,
- 'url' => add_query_arg( array( 'nonce' => wp_create_nonce( 'product-csv' ) ), admin_url( 'edit.php?post_type=product&page=product_importer&step=done' ) ),
- 'imported' => count( $results['imported'] ),
- 'failed' => count( $results['failed'] ),
- 'updated' => count( $results['updated'] ),
- 'skipped' => count( $results['skipped'] ),
- ) );
+ wp_send_json_success(
+ array(
+ 'position' => 'done',
+ 'percentage' => 100,
+ 'url' => add_query_arg( array( 'nonce' => wp_create_nonce( 'product-csv' ) ), admin_url( 'edit.php?post_type=product&page=product_importer&step=done' ) ),
+ 'imported' => count( $results['imported'] ),
+ 'failed' => count( $results['failed'] ),
+ 'updated' => count( $results['updated'] ),
+ 'skipped' => count( $results['skipped'] ),
+ )
+ );
} else {
- wp_send_json_success( array(
- 'position' => $importer->get_file_position(),
- 'percentage' => $percent_complete,
- 'imported' => count( $results['imported'] ),
- 'failed' => count( $results['failed'] ),
- 'updated' => count( $results['updated'] ),
- 'skipped' => count( $results['skipped'] ),
- ) );
+ wp_send_json_success(
+ array(
+ 'position' => $importer->get_file_position(),
+ 'percentage' => $percent_complete,
+ 'imported' => count( $results['imported'] ),
+ 'failed' => count( $results['failed'] ),
+ 'updated' => count( $results['updated'] ),
+ 'skipped' => count( $results['skipped'] ),
+ )
+ );
}
}
}
diff --git a/includes/admin/class-wc-admin-log-table-list.php b/includes/admin/class-wc-admin-log-table-list.php
index afc7f8a3e76..b518318064d 100644
--- a/includes/admin/class-wc-admin-log-table-list.php
+++ b/includes/admin/class-wc-admin-log-table-list.php
@@ -13,7 +13,7 @@ if ( ! defined( 'ABSPATH' ) ) {
}
if ( ! class_exists( 'WP_List_Table' ) ) {
- require_once( ABSPATH . 'wp-admin/includes/class-wp-list-table.php' );
+ require_once ABSPATH . 'wp-admin/includes/class-wp-list-table.php';
}
class WC_Admin_Log_Table_List extends WP_List_Table {
@@ -22,11 +22,13 @@ class WC_Admin_Log_Table_List extends WP_List_Table {
* Initialize the log table list.
*/
public function __construct() {
- parent::__construct( array(
- 'singular' => 'log',
- 'plural' => 'logs',
- 'ajax' => false,
- ) );
+ parent::__construct(
+ array(
+ 'singular' => 'log',
+ 'plural' => 'logs',
+ 'ajax' => false,
+ )
+ );
}
/**
@@ -37,14 +39,38 @@ class WC_Admin_Log_Table_List extends WP_List_Table {
public function level_dropdown() {
$levels = array(
- array( 'value' => WC_Log_Levels::EMERGENCY, 'label' => __( 'Emergency', 'woocommerce' ) ),
- array( 'value' => WC_Log_Levels::ALERT, 'label' => __( 'Alert', 'woocommerce' ) ),
- array( 'value' => WC_Log_Levels::CRITICAL, 'label' => __( 'Critical', 'woocommerce' ) ),
- array( 'value' => WC_Log_Levels::ERROR, 'label' => __( 'Error', 'woocommerce' ) ),
- array( 'value' => WC_Log_Levels::WARNING, 'label' => __( 'Warning', 'woocommerce' ) ),
- array( 'value' => WC_Log_Levels::NOTICE, 'label' => __( 'Notice', 'woocommerce' ) ),
- array( 'value' => WC_Log_Levels::INFO, 'label' => __( 'Info', 'woocommerce' ) ),
- array( 'value' => WC_Log_Levels::DEBUG, 'label' => __( 'Debug', 'woocommerce' ) ),
+ array(
+ 'value' => WC_Log_Levels::EMERGENCY,
+ 'label' => __( 'Emergency', 'woocommerce' ),
+ ),
+ array(
+ 'value' => WC_Log_Levels::ALERT,
+ 'label' => __( 'Alert', 'woocommerce' ),
+ ),
+ array(
+ 'value' => WC_Log_Levels::CRITICAL,
+ 'label' => __( 'Critical', 'woocommerce' ),
+ ),
+ array(
+ 'value' => WC_Log_Levels::ERROR,
+ 'label' => __( 'Error', 'woocommerce' ),
+ ),
+ array(
+ 'value' => WC_Log_Levels::WARNING,
+ 'label' => __( 'Warning', 'woocommerce' ),
+ ),
+ array(
+ 'value' => WC_Log_Levels::NOTICE,
+ 'label' => __( 'Notice', 'woocommerce' ),
+ ),
+ array(
+ 'value' => WC_Log_Levels::INFO,
+ 'label' => __( 'Info', 'woocommerce' ),
+ ),
+ array(
+ 'value' => WC_Log_Levels::DEBUG,
+ 'label' => __( 'Debug', 'woocommerce' ),
+ ),
);
$selected_level = isset( $_REQUEST['level'] ) ? $_REQUEST['level'] : '';
@@ -52,13 +78,16 @@ class WC_Admin_Log_Table_List extends WP_List_Table {
'
',
'timestamp' => __( 'Timestamp', 'woocommerce' ),
- 'level' => __( 'Level', 'woocommerce' ),
- 'message' => __( 'Message', 'woocommerce' ),
- 'source' => __( 'Source', 'woocommerce' ),
+ 'level' => __( 'Level', 'woocommerce' ),
+ 'message' => __( 'Message', 'woocommerce' ),
+ 'source' => __( 'Source', 'woocommerce' ),
);
}
@@ -95,10 +124,12 @@ class WC_Admin_Log_Table_List extends WP_List_Table {
* @return string
*/
public function column_timestamp( $log ) {
- return esc_html( mysql2date(
- get_option( 'date_format' ) . ' ' . get_option( 'time_format' ),
- $log['timestamp']
- ) );
+ return esc_html(
+ mysql2date(
+ get_option( 'date_format' ) . ' ' . get_option( 'time_format' ),
+ $log['timestamp']
+ )
+ );
}
/**
@@ -111,17 +142,17 @@ class WC_Admin_Log_Table_List extends WP_List_Table {
$level_key = WC_Log_Levels::get_severity_level( $log['level'] );
$levels = array(
'emergency' => __( 'Emergency', 'woocommerce' ),
- 'alert' => __( 'Alert', 'woocommerce' ),
- 'critical' => __( 'Critical', 'woocommerce' ),
- 'error' => __( 'Error', 'woocommerce' ),
- 'warning' => __( 'Warning', 'woocommerce' ),
- 'notice' => __( 'Notice', 'woocommerce' ),
- 'info' => __( 'Info', 'woocommerce' ),
- 'debug' => __( 'Debug', 'woocommerce' ),
+ 'alert' => __( 'Alert', 'woocommerce' ),
+ 'critical' => __( 'Critical', 'woocommerce' ),
+ 'error' => __( 'Error', 'woocommerce' ),
+ 'warning' => __( 'Warning', 'woocommerce' ),
+ 'notice' => __( 'Notice', 'woocommerce' ),
+ 'info' => __( 'Info', 'woocommerce' ),
+ 'debug' => __( 'Debug', 'woocommerce' ),
);
if ( isset( $levels[ $level_key ] ) ) {
- $level = $levels[ $level_key ];
+ $level = $levels[ $level_key ];
$level_class = sanitize_html_class( 'log-level--' . $level_key );
return '
' . esc_html( $level ) . '';
} else {
@@ -183,8 +214,8 @@ class WC_Admin_Log_Table_List extends WP_List_Table {
protected function get_sortable_columns() {
return array(
'timestamp' => array( 'timestamp', true ),
- 'level' => array( 'level', true ),
- 'source' => array( 'source', true ),
+ 'level' => array( 'level', true ),
+ 'source' => array( 'source', true ),
);
}
@@ -196,12 +227,12 @@ class WC_Admin_Log_Table_List extends WP_List_Table {
protected function source_dropdown() {
global $wpdb;
- $sources = $wpdb->get_col( "
- SELECT DISTINCT source
+ $sources = $wpdb->get_col(
+ "SELECT DISTINCT source
FROM {$wpdb->prefix}woocommerce_log
WHERE source != ''
- ORDER BY source ASC
- " );
+ ORDER BY source ASC"
+ );
if ( ! empty( $sources ) ) {
$selected_source = isset( $_REQUEST['source'] ) ? $_REQUEST['source'] : '';
@@ -209,13 +240,16 @@ class WC_Admin_Log_Table_List extends WP_List_Table {
prefix}woocommerce_log {$where}";
$total_items = $wpdb->get_var( $query_count );
- $this->set_pagination_args( array(
- 'total_items' => $total_items,
- 'per_page' => $per_page,
- 'total_pages' => ceil( $total_items / $per_page ),
- ) );
+ $this->set_pagination_args(
+ array(
+ 'total_items' => $total_items,
+ 'per_page' => $per_page,
+ 'total_pages' => ceil( $total_items / $per_page ),
+ )
+ );
}
/**
@@ -280,7 +316,7 @@ class WC_Admin_Log_Table_List extends WP_List_Table {
protected function get_items_query_offset() {
global $wpdb;
- $per_page = $this->get_items_per_page( 'woocommerce_status_log_items_per_page', 10 );
+ $per_page = $this->get_items_per_page( 'woocommerce_status_log_items_per_page', 10 );
$current_page = $this->get_pagenum();
if ( 1 < $current_page ) {
$offset = $per_page * ( $current_page - 1 );
diff --git a/includes/admin/class-wc-admin-menus.php b/includes/admin/class-wc-admin-menus.php
index fb14a868cb5..ca700685fd9 100644
--- a/includes/admin/class-wc-admin-menus.php
+++ b/includes/admin/class-wc-admin-menus.php
@@ -353,12 +353,14 @@ class WC_Admin_Menus {
}
// Add an option to visit the store.
- $wp_admin_bar->add_node( array(
- 'parent' => 'site-name',
- 'id' => 'view-store',
- 'title' => __( 'Visit Store', 'woocommerce' ),
- 'href' => wc_get_page_permalink( 'shop' ),
- ) );
+ $wp_admin_bar->add_node(
+ array(
+ 'parent' => 'site-name',
+ 'id' => 'view-store',
+ 'title' => __( 'Visit Store', 'woocommerce' ),
+ 'href' => wc_get_page_permalink( 'shop' ),
+ )
+ );
}
}
diff --git a/includes/admin/class-wc-admin-meta-boxes.php b/includes/admin/class-wc-admin-meta-boxes.php
index e5e7e5bdd94..e70a1cbafd9 100644
--- a/includes/admin/class-wc-admin-meta-boxes.php
+++ b/includes/admin/class-wc-admin-meta-boxes.php
@@ -31,7 +31,7 @@ class WC_Admin_Meta_Boxes {
*
* @var array
*/
- public static $meta_box_errors = array();
+ public static $meta_box_errors = array();
/**
* Constructor.
@@ -74,6 +74,7 @@ class WC_Admin_Meta_Boxes {
/**
* Add an error message.
+ *
* @param string $text
*/
public static function add_error( $text ) {
@@ -177,7 +178,7 @@ class WC_Admin_Meta_Boxes {
/**
* Check if we're saving, the trigger an action based on the post type.
*
- * @param int $post_id
+ * @param int $post_id
* @param object $post
*/
public function save_meta_boxes( $post_id, $post ) {
diff --git a/includes/admin/class-wc-admin-notices.php b/includes/admin/class-wc-admin-notices.php
index 49f66e2dab1..762a03af3c6 100644
--- a/includes/admin/class-wc-admin-notices.php
+++ b/includes/admin/class-wc-admin-notices.php
@@ -19,12 +19,14 @@ class WC_Admin_Notices {
/**
* Stores notices.
+ *
* @var array
*/
private static $notices = array();
/**
* Array of notices - name => callback.
+ *
* @var array
*/
private static $core_notices = array(
@@ -62,6 +64,7 @@ class WC_Admin_Notices {
/**
* Get notices
+ *
* @return array
*/
public static function get_notices() {
@@ -91,6 +94,7 @@ class WC_Admin_Notices {
/**
* Show a notice.
+ *
* @param string $name
*/
public static function add_notice( $name ) {
@@ -99,6 +103,7 @@ class WC_Admin_Notices {
/**
* Remove a notice from being displayed.
+ *
* @param string $name
*/
public static function remove_notice( $name ) {
@@ -108,7 +113,8 @@ class WC_Admin_Notices {
/**
* See if a notice is being shown.
- * @param string $name
+ *
+ * @param string $name
* @return boolean
*/
public static function has_notice( $name ) {
@@ -162,6 +168,7 @@ class WC_Admin_Notices {
/**
* Add a custom notice.
+ *
* @param string $name
* @param string $notice_html
*/
@@ -182,7 +189,7 @@ class WC_Admin_Notices {
$notice_html = get_option( 'woocommerce_admin_notice_' . $notice );
if ( $notice_html ) {
- include( 'views/html-notice-custom.php' );
+ include 'views/html-notice-custom.php';
}
}
}
@@ -196,12 +203,12 @@ class WC_Admin_Notices {
if ( version_compare( get_option( 'woocommerce_db_version' ), WC_VERSION, '<' ) ) {
$updater = new WC_Background_Updater();
if ( $updater->is_updating() || ! empty( $_GET['do_update_woocommerce'] ) ) {
- include( 'views/html-notice-updating.php' );
+ include 'views/html-notice-updating.php';
} else {
- include( 'views/html-notice-update.php' );
+ include 'views/html-notice-update.php';
}
} else {
- include( 'views/html-notice-updated.php' );
+ include 'views/html-notice-updated.php';
}
}
@@ -209,7 +216,7 @@ class WC_Admin_Notices {
* If we have just installed, show a message with the install pages button.
*/
public static function install_notice() {
- include( 'views/html-notice-install.php' );
+ include 'views/html-notice-install.php';
}
/**
@@ -221,7 +228,7 @@ class WC_Admin_Notices {
wc_deprecated_function( 'WC_Admin_Notices::theme_check_notice', '3.3.0' );
if ( ! current_theme_supports( 'woocommerce' ) ) {
- include( 'views/html-notice-theme-support.php' );
+ include 'views/html-notice-theme-support.php';
}
}
@@ -257,7 +264,7 @@ class WC_Admin_Notices {
}
if ( $outdated ) {
- include( 'views/html-notice-template-check.php' );
+ include 'views/html-notice-template-check.php';
} else {
self::remove_notice( 'template_files' );
}
@@ -278,7 +285,7 @@ class WC_Admin_Notices {
}
if ( $enabled ) {
- include( 'views/html-notice-legacy-shipping.php' );
+ include 'views/html-notice-legacy-shipping.php';
} else {
self::remove_notice( 'template_files' );
}
@@ -293,7 +300,7 @@ class WC_Admin_Notices {
$method_count = wc_get_shipping_method_count();
if ( $product_count->publish > 0 && 0 === $method_count ) {
- include( 'views/html-notice-no-shipping-methods.php' );
+ include 'views/html-notice-no-shipping-methods.php';
}
if ( $method_count > 0 ) {
@@ -313,7 +320,7 @@ class WC_Admin_Notices {
return;
}
if ( empty( $_GET['action'] ) ) {
- include( 'views/html-notice-simplify-commerce.php' );
+ include 'views/html-notice-simplify-commerce.php';
}
}
@@ -321,7 +328,7 @@ class WC_Admin_Notices {
* Notice shown when regenerating thumbnails background process is running.
*/
public static function regenerating_thumbnails_notice() {
- include( 'views/html-notice-regenerating-thumbnails.php' );
+ include 'views/html-notice-regenerating-thumbnails.php';
}
}
diff --git a/includes/admin/class-wc-admin-permalink-settings.php b/includes/admin/class-wc-admin-permalink-settings.php
index 64e78fef273..ec6534cc142 100644
--- a/includes/admin/class-wc-admin-permalink-settings.php
+++ b/includes/admin/class-wc-admin-permalink-settings.php
@@ -73,7 +73,7 @@ class WC_Admin_Permalink_Settings {
*/
public function product_category_slug_input() {
?>
-
+
-
+
shop would make your product links like
%sshop/sample-product/
. This setting affects product URLs only, not things such as product categories.', 'woocommerce' ), esc_url( home_url( '/' ) ) ) ) );
- $shop_page_id = wc_get_page_id( 'shop' );
- $base_slug = urldecode( ( $shop_page_id > 0 && get_post( $shop_page_id ) ) ? get_page_uri( $shop_page_id ) : _x( 'shop', 'default-slug', 'woocommerce' ) );
- $product_base = _x( 'product', 'default-slug', 'woocommerce' );
+ $shop_page_id = wc_get_page_id( 'shop' );
+ $base_slug = urldecode( ( $shop_page_id > 0 && get_post( $shop_page_id ) ) ? get_page_uri( $shop_page_id ) : _x( 'shop', 'default-slug', 'woocommerce' ) );
+ $product_base = _x( 'product', 'default-slug', 'woocommerce' );
$structures = array(
0 => '',
diff --git a/includes/admin/class-wc-admin-pointers.php b/includes/admin/class-wc-admin-pointers.php
index c4e7f2d4f62..af01866da68 100644
--- a/includes/admin/class-wc-admin-pointers.php
+++ b/includes/admin/class-wc-admin-pointers.php
@@ -33,9 +33,9 @@ class WC_Admin_Pointers {
}
switch ( $screen->id ) {
- case 'product' :
+ case 'product':
$this->create_product_tutorial();
- break;
+ break;
}
}
@@ -49,8 +49,8 @@ class WC_Admin_Pointers {
// These pointers will chain - they will not be shown at once.
$pointers = array(
'pointers' => array(
- 'title' => array(
- 'target' => "#title",
+ 'title' => array(
+ 'target' => '#title',
'next' => 'content',
'next_trigger' => array(
'target' => '#title',
@@ -65,8 +65,8 @@ class WC_Admin_Pointers {
),
),
),
- 'content' => array(
- 'target' => "#wp-content-editor-container",
+ 'content' => array(
+ 'target' => '#wp-content-editor-container',
'next' => 'product-type',
'next_trigger' => array(),
'options' => array(
@@ -78,14 +78,14 @@ class WC_Admin_Pointers {
),
),
),
- 'product-type' => array(
- 'target' => "#product-type",
+ 'product-type' => array(
+ 'target' => '#product-type',
'next' => 'virtual',
'next_trigger' => array(
- 'target' => "#product-type",
+ 'target' => '#product-type',
'event' => 'change blur click',
),
- 'options' => array(
+ 'options' => array(
'content' => '
' . esc_html__( 'Choose product type', 'woocommerce' ) . '
' .
'
' . esc_html__( 'Choose a type for this product. Simple is suitable for most physical goods and services (we recommend setting up a simple product for now).', 'woocommerce' ) . '
' .
'
' . esc_html__( 'Variable is for more complex products such as t-shirts with multiple sizes.', 'woocommerce' ) . '
' .
@@ -97,14 +97,14 @@ class WC_Admin_Pointers {
),
),
),
- 'virtual' => array(
- 'target' => "#_virtual",
+ 'virtual' => array(
+ 'target' => '#_virtual',
'next' => 'downloadable',
'next_trigger' => array(
- 'target' => "#_virtual",
+ 'target' => '#_virtual',
'event' => 'change',
),
- 'options' => array(
+ 'options' => array(
'content' => '
' . esc_html__( 'Virtual products', 'woocommerce' ) . '
' .
'
' . esc_html__( 'Check the "Virtual" box if this is a non-physical item, for example a service, which does not need shipping.', 'woocommerce' ) . '
',
'position' => array(
@@ -113,14 +113,14 @@ class WC_Admin_Pointers {
),
),
),
- 'downloadable' => array(
- 'target' => "#_downloadable",
+ 'downloadable' => array(
+ 'target' => '#_downloadable',
'next' => 'regular_price',
'next_trigger' => array(
- 'target' => "#_downloadable",
+ 'target' => '#_downloadable',
'event' => 'change',
),
- 'options' => array(
+ 'options' => array(
'content' => '
' . esc_html__( 'Downloadable products', 'woocommerce' ) . '
' .
'
' . esc_html__( 'If purchasing this product gives a customer access to a downloadable file, e.g. software, check this box.', 'woocommerce' ) . '
',
'position' => array(
@@ -129,14 +129,14 @@ class WC_Admin_Pointers {
),
),
),
- 'regular_price' => array(
- 'target' => "#_regular_price",
+ 'regular_price' => array(
+ 'target' => '#_regular_price',
'next' => 'postexcerpt',
'next_trigger' => array(
- 'target' => "#_regular_price",
+ 'target' => '#_regular_price',
'event' => 'input',
),
- 'options' => array(
+ 'options' => array(
'content' => '
' . esc_html__( 'Prices', 'woocommerce' ) . '
' .
'
' . esc_html__( 'Next you need to give your product a price.', 'woocommerce' ) . '
',
'position' => array(
@@ -145,14 +145,14 @@ class WC_Admin_Pointers {
),
),
),
- 'postexcerpt' => array(
- 'target' => "#postexcerpt",
+ 'postexcerpt' => array(
+ 'target' => '#postexcerpt',
'next' => 'postimagediv',
'next_trigger' => array(
- 'target' => "#postexcerpt",
+ 'target' => '#postexcerpt',
'event' => 'input',
),
- 'options' => array(
+ 'options' => array(
'content' => '
' . esc_html__( 'Product short description', 'woocommerce' ) . '
' .
'
' . esc_html__( 'Add a quick summary for your product here. This will appear on the product page under the product name.', 'woocommerce' ) . '
',
'position' => array(
@@ -161,9 +161,9 @@ class WC_Admin_Pointers {
),
),
),
- 'postimagediv' => array(
- 'target' => "#postimagediv",
- 'next' => 'product_tag',
+ 'postimagediv' => array(
+ 'target' => '#postimagediv',
+ 'next' => 'product_tag',
'options' => array(
'content' => '
' . esc_html__( 'Product images', 'woocommerce' ) . '
' .
'
' . esc_html__( "Upload or assign an image to your product here. This image will be shown in your store's catalog.", 'woocommerce' ) . '
',
@@ -173,9 +173,9 @@ class WC_Admin_Pointers {
),
),
),
- 'product_tag' => array(
- 'target' => "#tagsdiv-product_tag",
- 'next' => 'product_catdiv',
+ 'product_tag' => array(
+ 'target' => '#tagsdiv-product_tag',
+ 'next' => 'product_catdiv',
'options' => array(
'content' => '
' . esc_html__( 'Product tags', 'woocommerce' ) . '
' .
'
' . esc_html__( 'You can optionally "tag" your products here. Tags are a method of labeling your products to make them easier for customers to find.', 'woocommerce' ) . '
',
@@ -186,8 +186,8 @@ class WC_Admin_Pointers {
),
),
'product_catdiv' => array(
- 'target' => "#product_catdiv",
- 'next' => 'submitdiv',
+ 'target' => '#product_catdiv',
+ 'next' => 'submitdiv',
'options' => array(
'content' => '
' . esc_html__( 'Product categories', 'woocommerce' ) . '
' .
'
' . esc_html__( 'Optionally assign categories to your products to make them easier to browse through and find in your store.', 'woocommerce' ) . '
',
@@ -197,9 +197,9 @@ class WC_Admin_Pointers {
),
),
),
- 'submitdiv' => array(
- 'target' => "#submitdiv",
- 'next' => '',
+ 'submitdiv' => array(
+ 'target' => '#submitdiv',
+ 'next' => '',
'options' => array(
'content' => '
' . esc_html__( 'Publish your product!', 'woocommerce' ) . '
' .
'
' . esc_html__( 'When you are finished editing your product, hit the "Publish" button to publish your product to your store.', 'woocommerce' ) . '
',
@@ -217,14 +217,15 @@ class WC_Admin_Pointers {
/**
* Enqueue pointers and add script to page.
+ *
* @param array $pointers
*/
public function enqueue_pointers( $pointers ) {
$pointers = wp_json_encode( $pointers );
wp_enqueue_style( 'wp-pointer' );
wp_enqueue_script( 'wp-pointer' );
- wc_enqueue_js( "
- jQuery( function( $ ) {
+ wc_enqueue_js(
+ "jQuery( function( $ ) {
var wc_pointers = {$pointers};
setTimeout( init_wc_pointers, 800 );
@@ -277,8 +278,8 @@ class WC_Admin_Pointers {
});
}
}
- });
- " );
+ });"
+ );
}
}
diff --git a/includes/admin/class-wc-admin-post-types.php b/includes/admin/class-wc-admin-post-types.php
index 68f048c6acd..ca82662f569 100644
--- a/includes/admin/class-wc-admin-post-types.php
+++ b/includes/admin/class-wc-admin-post-types.php
@@ -28,10 +28,10 @@ class WC_Admin_Post_Types {
* Constructor.
*/
public function __construct() {
- include_once( dirname( __FILE__ ) . '/class-wc-admin-meta-boxes.php' );
+ include_once dirname( __FILE__ ) . '/class-wc-admin-meta-boxes.php';
if ( ! function_exists( 'duplicate_post_plugin_activation' ) ) {
- include_once( 'class-wc-admin-duplicate-product.php' );
+ include_once 'class-wc-admin-duplicate-product.php';
}
// Load correct list table classes for current screen.
@@ -65,7 +65,7 @@ class WC_Admin_Post_Types {
// Bulk / quick edit.
add_action( 'bulk_edit_custom_box', array( $this, 'bulk_edit' ), 10, 2 );
- add_action( 'quick_edit_custom_box', array( $this, 'quick_edit' ), 10, 2 );
+ add_action( 'quick_edit_custom_box', array( $this, 'quick_edit' ), 10, 2 );
add_action( 'save_post', array( $this, 'bulk_and_quick_edit_hook' ), 10, 2 );
add_action( 'woocommerce_product_bulk_and_quick_edit', array( $this, 'bulk_and_quick_edit_save_post' ), 10, 2 );
}
@@ -88,16 +88,16 @@ class WC_Admin_Post_Types {
}
switch ( $screen_id ) {
- case 'edit-shop_order' :
- include_once( 'list-tables/class-wc-admin-list-table-orders.php' );
+ case 'edit-shop_order':
+ include_once 'list-tables/class-wc-admin-list-table-orders.php';
new WC_Admin_List_Table_Orders();
break;
- case 'edit-shop_coupon' :
- include_once( 'list-tables/class-wc-admin-list-table-coupons.php' );
+ case 'edit-shop_coupon':
+ include_once 'list-tables/class-wc-admin-list-table-coupons.php';
new WC_Admin_List_Table_Coupons();
break;
- case 'edit-product' :
- include_once( 'list-tables/class-wc-admin-list-table-products.php' );
+ case 'edit-product':
+ include_once 'list-tables/class-wc-admin-list-table-products.php';
new WC_Admin_List_Table_Products();
break;
}
@@ -117,18 +117,18 @@ class WC_Admin_Post_Types {
global $post;
$messages['product'] = array(
- 0 => '', // Unused. Messages start at index 1.
- 1 => sprintf( __( 'Product updated.
View Product', 'woocommerce' ), esc_url( get_permalink( $post->ID ) ) ),
- 2 => __( 'Custom field updated.', 'woocommerce' ),
- 3 => __( 'Custom field deleted.', 'woocommerce' ),
- 4 => __( 'Product updated.', 'woocommerce' ),
- 5 => __( 'Revision restored.', 'woocommerce' ),
+ 0 => '', // Unused. Messages start at index 1.
+ 1 => sprintf( __( 'Product updated.
View Product', 'woocommerce' ), esc_url( get_permalink( $post->ID ) ) ),
+ 2 => __( 'Custom field updated.', 'woocommerce' ),
+ 3 => __( 'Custom field deleted.', 'woocommerce' ),
+ 4 => __( 'Product updated.', 'woocommerce' ),
+ 5 => __( 'Revision restored.', 'woocommerce' ),
/* translators: %s: product url */
- 6 => sprintf( __( 'Product published.
View Product', 'woocommerce' ), esc_url( get_permalink( $post->ID ) ) ),
- 7 => __( 'Product saved.', 'woocommerce' ),
+ 6 => sprintf( __( 'Product published.
View Product', 'woocommerce' ), esc_url( get_permalink( $post->ID ) ) ),
+ 7 => __( 'Product saved.', 'woocommerce' ),
/* translators: %s: product url */
- 8 => sprintf( __( 'Product submitted.
Preview product', 'woocommerce' ), esc_url( add_query_arg( 'preview', 'true', get_permalink( $post->ID ) ) ) ),
- 9 => sprintf(
+ 8 => sprintf( __( 'Product submitted.
Preview product', 'woocommerce' ), esc_url( add_query_arg( 'preview', 'true', get_permalink( $post->ID ) ) ) ),
+ 9 => sprintf(
/* translators: 1: date 2: product url */
__( 'Product scheduled for: %1$s.
Preview product', 'woocommerce' ),
'
' . date_i18n( __( 'M j, Y @ G:i', 'woocommerce' ), strtotime( $post->post_date ) ), esc_url( get_permalink( $post->ID ) ) . ''
@@ -138,16 +138,16 @@ class WC_Admin_Post_Types {
);
$messages['shop_order'] = array(
- 0 => '', // Unused. Messages start at index 1.
- 1 => __( 'Order updated.', 'woocommerce' ),
- 2 => __( 'Custom field updated.', 'woocommerce' ),
- 3 => __( 'Custom field deleted.', 'woocommerce' ),
- 4 => __( 'Order updated.', 'woocommerce' ),
- 5 => __( 'Revision restored.', 'woocommerce' ),
- 6 => __( 'Order updated.', 'woocommerce' ),
- 7 => __( 'Order saved.', 'woocommerce' ),
- 8 => __( 'Order submitted.', 'woocommerce' ),
- 9 => sprintf(
+ 0 => '', // Unused. Messages start at index 1.
+ 1 => __( 'Order updated.', 'woocommerce' ),
+ 2 => __( 'Custom field updated.', 'woocommerce' ),
+ 3 => __( 'Custom field deleted.', 'woocommerce' ),
+ 4 => __( 'Order updated.', 'woocommerce' ),
+ 5 => __( 'Revision restored.', 'woocommerce' ),
+ 6 => __( 'Order updated.', 'woocommerce' ),
+ 7 => __( 'Order saved.', 'woocommerce' ),
+ 8 => __( 'Order submitted.', 'woocommerce' ),
+ 9 => sprintf(
/* translators: %s: date */
__( 'Order scheduled for: %s.', 'woocommerce' ),
'
' . date_i18n( __( 'M j, Y @ G:i', 'woocommerce' ), strtotime( $post->post_date ) ) . ''
@@ -157,16 +157,16 @@ class WC_Admin_Post_Types {
);
$messages['shop_coupon'] = array(
- 0 => '', // Unused. Messages start at index 1.
- 1 => __( 'Coupon updated.', 'woocommerce' ),
- 2 => __( 'Custom field updated.', 'woocommerce' ),
- 3 => __( 'Custom field deleted.', 'woocommerce' ),
- 4 => __( 'Coupon updated.', 'woocommerce' ),
- 5 => __( 'Revision restored.', 'woocommerce' ),
- 6 => __( 'Coupon updated.', 'woocommerce' ),
- 7 => __( 'Coupon saved.', 'woocommerce' ),
- 8 => __( 'Coupon submitted.', 'woocommerce' ),
- 9 => sprintf(
+ 0 => '', // Unused. Messages start at index 1.
+ 1 => __( 'Coupon updated.', 'woocommerce' ),
+ 2 => __( 'Custom field updated.', 'woocommerce' ),
+ 3 => __( 'Custom field deleted.', 'woocommerce' ),
+ 4 => __( 'Coupon updated.', 'woocommerce' ),
+ 5 => __( 'Revision restored.', 'woocommerce' ),
+ 6 => __( 'Coupon updated.', 'woocommerce' ),
+ 7 => __( 'Coupon saved.', 'woocommerce' ),
+ 8 => __( 'Coupon submitted.', 'woocommerce' ),
+ 9 => sprintf(
/* translators: %s: date */
__( 'Coupon scheduled for: %s.', 'woocommerce' ),
'
' . date_i18n( __( 'M j, Y @ G:i', 'woocommerce' ), strtotime( $post->post_date ) ) . ''
@@ -238,11 +238,13 @@ class WC_Admin_Post_Types {
return;
}
- $shipping_class = get_terms( 'product_shipping_class', array(
- 'hide_empty' => false,
- ) );
+ $shipping_class = get_terms(
+ 'product_shipping_class', array(
+ 'hide_empty' => false,
+ )
+ );
- include( WC()->plugin_path() . '/includes/admin/views/html-bulk-edit-product.php' );
+ include WC()->plugin_path() . '/includes/admin/views/html-bulk-edit-product.php';
}
/**
@@ -256,11 +258,13 @@ class WC_Admin_Post_Types {
return;
}
- $shipping_class = get_terms( 'product_shipping_class', array(
- 'hide_empty' => false,
- ) );
+ $shipping_class = get_terms(
+ 'product_shipping_class', array(
+ 'hide_empty' => false,
+ )
+ );
- include( WC()->plugin_path() . '/includes/admin/views/html-quick-edit-product.php' );
+ include WC()->plugin_path() . '/includes/admin/views/html-quick-edit-product.php';
}
/**
@@ -497,7 +501,7 @@ class WC_Admin_Post_Types {
}
// Handle price - remove dates and set to lowest.
- $change_price_product_types = apply_filters( 'woocommerce_bulk_edit_save_price_product_types', array( 'simple', 'external' ) );
+ $change_price_product_types = apply_filters( 'woocommerce_bulk_edit_save_price_product_types', array( 'simple', 'external' ) );
$can_product_type_change_price = false;
foreach ( $change_price_product_types as $product_type ) {
if ( $product->is_type( $product_type ) ) {
@@ -521,7 +525,7 @@ class WC_Admin_Post_Types {
break;
case 2:
if ( $is_percentage ) {
- $percent = $regular_price / 100;
+ $percent = $regular_price / 100;
$new_price = $old_regular_price + ( round( $old_regular_price * $percent, wc_get_price_decimals() ) );
} else {
$new_price = $old_regular_price + $regular_price;
@@ -529,7 +533,7 @@ class WC_Admin_Post_Types {
break;
case 3:
if ( $is_percentage ) {
- $percent = $regular_price / 100;
+ $percent = $regular_price / 100;
$new_price = max( 0, $old_regular_price - ( round( $old_regular_price * $percent, wc_get_price_decimals() ) ) );
} else {
$new_price = max( 0, $old_regular_price - $regular_price );
@@ -542,7 +546,7 @@ class WC_Admin_Post_Types {
if ( isset( $new_price ) && $new_price !== $old_regular_price ) {
$price_changed = true;
- $new_price = round( $new_price, wc_get_price_decimals() );
+ $new_price = round( $new_price, wc_get_price_decimals() );
$product->set_regular_price( $new_price );
}
}
@@ -559,7 +563,7 @@ class WC_Admin_Post_Types {
break;
case 2:
if ( $is_percentage ) {
- $percent = $sale_price / 100;
+ $percent = $sale_price / 100;
$new_price = $old_sale_price + ( $old_sale_price * $percent );
} else {
$new_price = $old_sale_price + $sale_price;
@@ -567,7 +571,7 @@ class WC_Admin_Post_Types {
break;
case 3:
if ( $is_percentage ) {
- $percent = $sale_price / 100;
+ $percent = $sale_price / 100;
$new_price = max( 0, $old_sale_price - ( $old_sale_price * $percent ) );
} else {
$new_price = max( 0, $old_sale_price - $sale_price );
@@ -575,7 +579,7 @@ class WC_Admin_Post_Types {
break;
case 4:
if ( $is_percentage ) {
- $percent = $sale_price / 100;
+ $percent = $sale_price / 100;
$new_price = max( 0, $product->regular_price - ( $product->regular_price * $percent ) );
} else {
$new_price = max( 0, $product->regular_price - $sale_price );
@@ -588,7 +592,7 @@ class WC_Admin_Post_Types {
if ( isset( $new_price ) && $new_price !== $old_sale_price ) {
$price_changed = true;
- $new_price = ! empty( $new_price ) || '0' === $new_price ? round( $new_price, wc_get_price_decimals() ) : '';
+ $new_price = ! empty( $new_price ) || '0' === $new_price ? round( $new_price, wc_get_price_decimals() ) : '';
$product->set_sale_price( $new_price );
}
}
@@ -732,14 +736,17 @@ class WC_Admin_Post_Types {
$visibility_options = wc_get_product_visibility_options();
?>
-
+
+
+ if ( 'yes' === $current_featured ) {
+ echo ', ' . esc_html__( 'Featured', 'woocommerce' );
+ }
+ ?>
+
diff --git a/includes/admin/class-wc-admin-profile.php b/includes/admin/class-wc-admin-profile.php
index 5fe788b599f..ae23d2dbad9 100644
--- a/includes/admin/class-wc-admin-profile.php
+++ b/includes/admin/class-wc-admin-profile.php
@@ -14,229 +14,230 @@ if ( ! defined( 'ABSPATH' ) ) {
if ( ! class_exists( 'WC_Admin_Profile', false ) ) :
-/**
- * WC_Admin_Profile Class.
- */
-class WC_Admin_Profile {
-
/**
- * Hook in tabs.
+ * WC_Admin_Profile Class.
*/
- public function __construct() {
- add_action( 'show_user_profile', array( $this, 'add_customer_meta_fields' ) );
- add_action( 'edit_user_profile', array( $this, 'add_customer_meta_fields' ) );
+ class WC_Admin_Profile {
- add_action( 'personal_options_update', array( $this, 'save_customer_meta_fields' ) );
- add_action( 'edit_user_profile_update', array( $this, 'save_customer_meta_fields' ) );
- }
+ /**
+ * Hook in tabs.
+ */
+ public function __construct() {
+ add_action( 'show_user_profile', array( $this, 'add_customer_meta_fields' ) );
+ add_action( 'edit_user_profile', array( $this, 'add_customer_meta_fields' ) );
- /**
- * Get Address Fields for the edit user pages.
- *
- * @return array Fields to display which are filtered through woocommerce_customer_meta_fields before being returned
- */
- public function get_customer_meta_fields() {
- $show_fields = apply_filters('woocommerce_customer_meta_fields', array(
- 'billing' => array(
- 'title' => __( 'Customer billing address', 'woocommerce' ),
- 'fields' => array(
- 'billing_first_name' => array(
- 'label' => __( 'First name', 'woocommerce' ),
- 'description' => '',
- ),
- 'billing_last_name' => array(
- 'label' => __( 'Last name', 'woocommerce' ),
- 'description' => '',
- ),
- 'billing_company' => array(
- 'label' => __( 'Company', 'woocommerce' ),
- 'description' => '',
- ),
- 'billing_address_1' => array(
- 'label' => __( 'Address line 1', 'woocommerce' ),
- 'description' => '',
- ),
- 'billing_address_2' => array(
- 'label' => __( 'Address line 2', 'woocommerce' ),
- 'description' => '',
- ),
- 'billing_city' => array(
- 'label' => __( 'City', 'woocommerce' ),
- 'description' => '',
- ),
- 'billing_postcode' => array(
- 'label' => __( 'Postcode / ZIP', 'woocommerce' ),
- 'description' => '',
- ),
- 'billing_country' => array(
- 'label' => __( 'Country', 'woocommerce' ),
- 'description' => '',
- 'class' => 'js_field-country',
- 'type' => 'select',
- 'options' => array( '' => __( 'Select a country…', 'woocommerce' ) ) + WC()->countries->get_allowed_countries(),
- ),
- 'billing_state' => array(
- 'label' => __( 'State / County', 'woocommerce' ),
- 'description' => __( 'State / County or state code', 'woocommerce' ),
- 'class' => 'js_field-state',
- ),
- 'billing_phone' => array(
- 'label' => __( 'Phone', 'woocommerce' ),
- 'description' => '',
- ),
- 'billing_email' => array(
- 'label' => __( 'Email address', 'woocommerce' ),
- 'description' => '',
- ),
- ),
- ),
- 'shipping' => array(
- 'title' => __( 'Customer shipping address', 'woocommerce' ),
- 'fields' => array(
- 'copy_billing' => array(
- 'label' => __( 'Copy from billing address', 'woocommerce' ),
- 'description' => '',
- 'class' => 'js_copy-billing',
- 'type' => 'button',
- 'text' => __( 'Copy', 'woocommerce' ),
- ),
- 'shipping_first_name' => array(
- 'label' => __( 'First name', 'woocommerce' ),
- 'description' => '',
- ),
- 'shipping_last_name' => array(
- 'label' => __( 'Last name', 'woocommerce' ),
- 'description' => '',
- ),
- 'shipping_company' => array(
- 'label' => __( 'Company', 'woocommerce' ),
- 'description' => '',
- ),
- 'shipping_address_1' => array(
- 'label' => __( 'Address line 1', 'woocommerce' ),
- 'description' => '',
- ),
- 'shipping_address_2' => array(
- 'label' => __( 'Address line 2', 'woocommerce' ),
- 'description' => '',
- ),
- 'shipping_city' => array(
- 'label' => __( 'City', 'woocommerce' ),
- 'description' => '',
- ),
- 'shipping_postcode' => array(
- 'label' => __( 'Postcode / ZIP', 'woocommerce' ),
- 'description' => '',
- ),
- 'shipping_country' => array(
- 'label' => __( 'Country', 'woocommerce' ),
- 'description' => '',
- 'class' => 'js_field-country',
- 'type' => 'select',
- 'options' => array( '' => __( 'Select a country…', 'woocommerce' ) ) + WC()->countries->get_allowed_countries(),
- ),
- 'shipping_state' => array(
- 'label' => __( 'State / County', 'woocommerce' ),
- 'description' => __( 'State / County or state code', 'woocommerce' ),
- 'class' => 'js_field-state',
- ),
- ),
- ),
- ) );
- return $show_fields;
- }
-
- /**
- * Show Address Fields on edit user pages.
- *
- * @param WP_User $user
- */
- public function add_customer_meta_fields( $user ) {
- if ( ! current_user_can( 'manage_woocommerce' ) ) {
- return;
+ add_action( 'personal_options_update', array( $this, 'save_customer_meta_fields' ) );
+ add_action( 'edit_user_profile_update', array( $this, 'save_customer_meta_fields' ) );
}
- $show_fields = $this->get_customer_meta_fields();
+ /**
+ * Get Address Fields for the edit user pages.
+ *
+ * @return array Fields to display which are filtered through woocommerce_customer_meta_fields before being returned
+ */
+ public function get_customer_meta_fields() {
+ $show_fields = apply_filters(
+ 'woocommerce_customer_meta_fields', array(
+ 'billing' => array(
+ 'title' => __( 'Customer billing address', 'woocommerce' ),
+ 'fields' => array(
+ 'billing_first_name' => array(
+ 'label' => __( 'First name', 'woocommerce' ),
+ 'description' => '',
+ ),
+ 'billing_last_name' => array(
+ 'label' => __( 'Last name', 'woocommerce' ),
+ 'description' => '',
+ ),
+ 'billing_company' => array(
+ 'label' => __( 'Company', 'woocommerce' ),
+ 'description' => '',
+ ),
+ 'billing_address_1' => array(
+ 'label' => __( 'Address line 1', 'woocommerce' ),
+ 'description' => '',
+ ),
+ 'billing_address_2' => array(
+ 'label' => __( 'Address line 2', 'woocommerce' ),
+ 'description' => '',
+ ),
+ 'billing_city' => array(
+ 'label' => __( 'City', 'woocommerce' ),
+ 'description' => '',
+ ),
+ 'billing_postcode' => array(
+ 'label' => __( 'Postcode / ZIP', 'woocommerce' ),
+ 'description' => '',
+ ),
+ 'billing_country' => array(
+ 'label' => __( 'Country', 'woocommerce' ),
+ 'description' => '',
+ 'class' => 'js_field-country',
+ 'type' => 'select',
+ 'options' => array( '' => __( 'Select a country…', 'woocommerce' ) ) + WC()->countries->get_allowed_countries(),
+ ),
+ 'billing_state' => array(
+ 'label' => __( 'State / County', 'woocommerce' ),
+ 'description' => __( 'State / County or state code', 'woocommerce' ),
+ 'class' => 'js_field-state',
+ ),
+ 'billing_phone' => array(
+ 'label' => __( 'Phone', 'woocommerce' ),
+ 'description' => '',
+ ),
+ 'billing_email' => array(
+ 'label' => __( 'Email address', 'woocommerce' ),
+ 'description' => '',
+ ),
+ ),
+ ),
+ 'shipping' => array(
+ 'title' => __( 'Customer shipping address', 'woocommerce' ),
+ 'fields' => array(
+ 'copy_billing' => array(
+ 'label' => __( 'Copy from billing address', 'woocommerce' ),
+ 'description' => '',
+ 'class' => 'js_copy-billing',
+ 'type' => 'button',
+ 'text' => __( 'Copy', 'woocommerce' ),
+ ),
+ 'shipping_first_name' => array(
+ 'label' => __( 'First name', 'woocommerce' ),
+ 'description' => '',
+ ),
+ 'shipping_last_name' => array(
+ 'label' => __( 'Last name', 'woocommerce' ),
+ 'description' => '',
+ ),
+ 'shipping_company' => array(
+ 'label' => __( 'Company', 'woocommerce' ),
+ 'description' => '',
+ ),
+ 'shipping_address_1' => array(
+ 'label' => __( 'Address line 1', 'woocommerce' ),
+ 'description' => '',
+ ),
+ 'shipping_address_2' => array(
+ 'label' => __( 'Address line 2', 'woocommerce' ),
+ 'description' => '',
+ ),
+ 'shipping_city' => array(
+ 'label' => __( 'City', 'woocommerce' ),
+ 'description' => '',
+ ),
+ 'shipping_postcode' => array(
+ 'label' => __( 'Postcode / ZIP', 'woocommerce' ),
+ 'description' => '',
+ ),
+ 'shipping_country' => array(
+ 'label' => __( 'Country', 'woocommerce' ),
+ 'description' => '',
+ 'class' => 'js_field-country',
+ 'type' => 'select',
+ 'options' => array( '' => __( 'Select a country…', 'woocommerce' ) ) + WC()->countries->get_allowed_countries(),
+ ),
+ 'shipping_state' => array(
+ 'label' => __( 'State / County', 'woocommerce' ),
+ 'description' => __( 'State / County or state code', 'woocommerce' ),
+ 'class' => 'js_field-state',
+ ),
+ ),
+ ),
+ )
+ );
+ return $show_fields;
+ }
- foreach ( $show_fields as $fieldset_key => $fieldset ) :
- ?>
-
-
-
+
+ get_customer_meta_fields();
+ /**
+ * Save Address Fields on edit user pages.
+ *
+ * @param int $user_id User ID of the user being saved
+ */
+ public function save_customer_meta_fields( $user_id ) {
+ $save_fields = $this->get_customer_meta_fields();
- foreach ( $save_fields as $fieldset ) {
+ foreach ( $save_fields as $fieldset ) {
- foreach ( $fieldset['fields'] as $key => $field ) {
+ foreach ( $fieldset['fields'] as $key => $field ) {
- if ( isset( $field['type'] ) && 'checkbox' === $field['type'] ) {
- update_user_meta( $user_id, $key, isset( $_POST[ $key ] ) );
- } elseif ( isset( $_POST[ $key ] ) ) {
- update_user_meta( $user_id, $key, wc_clean( $_POST[ $key ] ) );
+ if ( isset( $field['type'] ) && 'checkbox' === $field['type'] ) {
+ update_user_meta( $user_id, $key, isset( $_POST[ $key ] ) );
+ } elseif ( isset( $_POST[ $key ] ) ) {
+ update_user_meta( $user_id, $key, wc_clean( $_POST[ $key ] ) );
+ }
}
}
}
- }
- /**
- * Get user meta for a given key, with fallbacks to core user info for pre-existing fields.
- *
- * @since 3.1.0
- * @param int $user_id User ID of the user being edited
- * @param string $key Key for user meta field
- * @return string
- */
- protected function get_user_meta( $user_id, $key ) {
- $value = get_user_meta( $user_id, $key, true );
- $existing_fields = array( 'billing_first_name', 'billing_last_name' );
- if ( ! $value && in_array( $key, $existing_fields ) ) {
- $value = get_user_meta( $user_id, str_replace( 'billing_', '', $key ), true );
- } elseif ( ! $value && ( 'billing_email' === $key ) ) {
- $user = get_userdata( $user_id );
- $value = $user->user_email;
+ /**
+ * Get user meta for a given key, with fallbacks to core user info for pre-existing fields.
+ *
+ * @since 3.1.0
+ * @param int $user_id User ID of the user being edited
+ * @param string $key Key for user meta field
+ * @return string
+ */
+ protected function get_user_meta( $user_id, $key ) {
+ $value = get_user_meta( $user_id, $key, true );
+ $existing_fields = array( 'billing_first_name', 'billing_last_name' );
+ if ( ! $value && in_array( $key, $existing_fields ) ) {
+ $value = get_user_meta( $user_id, str_replace( 'billing_', '', $key ), true );
+ } elseif ( ! $value && ( 'billing_email' === $key ) ) {
+ $user = get_userdata( $user_id );
+ $value = $user->user_email;
+ }
+
+ return $value;
}
-
- return $value;
}
-}
endif;
diff --git a/includes/admin/class-wc-admin-reports.php b/includes/admin/class-wc-admin-reports.php
index 5034515018f..c8594097dbc 100644
--- a/includes/admin/class-wc-admin-reports.php
+++ b/includes/admin/class-wc-admin-reports.php
@@ -32,8 +32,8 @@ class WC_Admin_Reports {
$current_tab = ! empty( $_GET['tab'] ) ? sanitize_title( $_GET['tab'] ) : $first_tab[0];
$current_report = isset( $_GET['report'] ) ? sanitize_title( $_GET['report'] ) : current( array_keys( $reports[ $current_tab ]['reports'] ) );
- include_once( dirname( __FILE__ ) . '/reports/class-wc-admin-report.php' );
- include_once( dirname( __FILE__ ) . '/views/html-admin-page-reports.php' );
+ include_once dirname( __FILE__ ) . '/reports/class-wc-admin-report.php';
+ include_once dirname( __FILE__ ) . '/views/html-admin-page-reports.php';
}
/**
@@ -43,16 +43,16 @@ class WC_Admin_Reports {
*/
public static function get_reports() {
$reports = array(
- 'orders' => array(
- 'title' => __( 'Orders', 'woocommerce' ),
+ 'orders' => array(
+ 'title' => __( 'Orders', 'woocommerce' ),
'reports' => array(
- 'sales_by_date' => array(
+ 'sales_by_date' => array(
'title' => __( 'Sales by date', 'woocommerce' ),
'description' => '',
'hide_title' => true,
'callback' => array( __CLASS__, 'get_report' ),
),
- 'sales_by_product' => array(
+ 'sales_by_product' => array(
'title' => __( 'Sales by product', 'woocommerce' ),
'description' => '',
'hide_title' => true,
@@ -64,13 +64,13 @@ class WC_Admin_Reports {
'hide_title' => true,
'callback' => array( __CLASS__, 'get_report' ),
),
- 'coupon_usage' => array(
+ 'coupon_usage' => array(
'title' => __( 'Coupons by date', 'woocommerce' ),
'description' => '',
'hide_title' => true,
'callback' => array( __CLASS__, 'get_report' ),
),
- 'downloads' => array(
+ 'downloads' => array(
'title' => __( 'Customer downloads', 'woocommerce' ),
'description' => '',
'hide_title' => true,
@@ -79,9 +79,9 @@ class WC_Admin_Reports {
),
),
'customers' => array(
- 'title' => __( 'Customers', 'woocommerce' ),
+ 'title' => __( 'Customers', 'woocommerce' ),
'reports' => array(
- 'customers' => array(
+ 'customers' => array(
'title' => __( 'Customers vs. guests', 'woocommerce' ),
'description' => '',
'hide_title' => true,
@@ -96,7 +96,7 @@ class WC_Admin_Reports {
),
),
'stock' => array(
- 'title' => __( 'Stock', 'woocommerce' ),
+ 'title' => __( 'Stock', 'woocommerce' ),
'reports' => array(
'low_in_stock' => array(
'title' => __( 'Low in stock', 'woocommerce' ),
@@ -122,7 +122,7 @@ class WC_Admin_Reports {
if ( wc_tax_enabled() ) {
$reports['taxes'] = array(
- 'title' => __( 'Taxes', 'woocommerce' ),
+ 'title' => __( 'Taxes', 'woocommerce' ),
'reports' => array(
'taxes_by_code' => array(
'title' => __( 'Taxes by code', 'woocommerce' ),
@@ -167,7 +167,7 @@ class WC_Admin_Reports {
$name = sanitize_title( str_replace( '_', '-', $name ) );
$class = 'WC_Report_' . str_replace( '-', '_', $name );
- include_once( apply_filters( 'wc_admin_reports_path', 'reports/class-wc-report-' . $name . '.php', $name, $class ) );
+ include_once apply_filters( 'wc_admin_reports_path', 'reports/class-wc-report-' . $name . '.php', $name, $class );
if ( ! class_exists( $class ) ) {
return;
diff --git a/includes/admin/class-wc-admin-setup-wizard.php b/includes/admin/class-wc-admin-setup-wizard.php
index 4f435f4c637..69486dff09c 100644
--- a/includes/admin/class-wc-admin-setup-wizard.php
+++ b/includes/admin/class-wc-admin-setup-wizard.php
@@ -88,16 +88,18 @@ class WC_Admin_Setup_Wizard {
* @return boolean
*/
protected function is_default_theme() {
- return wc_is_active_theme( array(
- 'twentyseventeen',
- 'twentysixteen',
- 'twentyfifteen',
- 'twentyfourteen',
- 'twentythirteen',
- 'twentyeleven',
- 'twentytwelve',
- 'twentyten',
- ) );
+ return wc_is_active_theme(
+ array(
+ 'twentyseventeen',
+ 'twentysixteen',
+ 'twentyfifteen',
+ 'twentyfourteen',
+ 'twentythirteen',
+ 'twentyeleven',
+ 'twentytwelve',
+ 'twentyten',
+ )
+ );
}
/**
@@ -185,28 +187,36 @@ class WC_Admin_Setup_Wizard {
wp_register_script( 'jquery-blockui', WC()->plugin_url() . '/assets/js/jquery-blockui/jquery.blockUI' . $suffix . '.js', array( 'jquery' ), '2.70', true );
wp_register_script( 'selectWoo', WC()->plugin_url() . '/assets/js/selectWoo/selectWoo.full' . $suffix . '.js', array( 'jquery' ), '1.0.0' );
wp_register_script( 'wc-enhanced-select', WC()->plugin_url() . '/assets/js/admin/wc-enhanced-select' . $suffix . '.js', array( 'jquery', 'selectWoo' ), WC_VERSION );
- wp_localize_script( 'wc-enhanced-select', 'wc_enhanced_select_params', array(
- 'i18n_no_matches' => _x( 'No matches found', 'enhanced select', 'woocommerce' ),
- 'i18n_ajax_error' => _x( 'Loading failed', 'enhanced select', 'woocommerce' ),
- 'i18n_input_too_short_1' => _x( 'Please enter 1 or more characters', 'enhanced select', 'woocommerce' ),
- 'i18n_input_too_short_n' => _x( 'Please enter %qty% or more characters', 'enhanced select', 'woocommerce' ),
- 'i18n_input_too_long_1' => _x( 'Please delete 1 character', 'enhanced select', 'woocommerce' ),
- 'i18n_input_too_long_n' => _x( 'Please delete %qty% characters', 'enhanced select', 'woocommerce' ),
- 'i18n_selection_too_long_1' => _x( 'You can only select 1 item', 'enhanced select', 'woocommerce' ),
- 'i18n_selection_too_long_n' => _x( 'You can only select %qty% items', 'enhanced select', 'woocommerce' ),
- 'i18n_load_more' => _x( 'Loading more results…', 'enhanced select', 'woocommerce' ),
- 'i18n_searching' => _x( 'Searching…', 'enhanced select', 'woocommerce' ),
- 'ajax_url' => admin_url( 'admin-ajax.php' ),
- 'search_products_nonce' => wp_create_nonce( 'search-products' ),
- 'search_customers_nonce' => wp_create_nonce( 'search-customers' ),
- ) );
+ wp_localize_script(
+ 'wc-enhanced-select',
+ 'wc_enhanced_select_params',
+ array(
+ 'i18n_no_matches' => _x( 'No matches found', 'enhanced select', 'woocommerce' ),
+ 'i18n_ajax_error' => _x( 'Loading failed', 'enhanced select', 'woocommerce' ),
+ 'i18n_input_too_short_1' => _x( 'Please enter 1 or more characters', 'enhanced select', 'woocommerce' ),
+ 'i18n_input_too_short_n' => _x( 'Please enter %qty% or more characters', 'enhanced select', 'woocommerce' ),
+ 'i18n_input_too_long_1' => _x( 'Please delete 1 character', 'enhanced select', 'woocommerce' ),
+ 'i18n_input_too_long_n' => _x( 'Please delete %qty% characters', 'enhanced select', 'woocommerce' ),
+ 'i18n_selection_too_long_1' => _x( 'You can only select 1 item', 'enhanced select', 'woocommerce' ),
+ 'i18n_selection_too_long_n' => _x( 'You can only select %qty% items', 'enhanced select', 'woocommerce' ),
+ 'i18n_load_more' => _x( 'Loading more results…', 'enhanced select', 'woocommerce' ),
+ 'i18n_searching' => _x( 'Searching…', 'enhanced select', 'woocommerce' ),
+ 'ajax_url' => admin_url( 'admin-ajax.php' ),
+ 'search_products_nonce' => wp_create_nonce( 'search-products' ),
+ 'search_customers_nonce' => wp_create_nonce( 'search-customers' ),
+ )
+ );
wp_enqueue_style( 'woocommerce_admin_styles', WC()->plugin_url() . '/assets/css/admin.css', array(), WC_VERSION );
wp_enqueue_style( 'wc-setup', WC()->plugin_url() . '/assets/css/wc-setup.css', array( 'dashicons', 'install' ), WC_VERSION );
wp_register_script( 'wc-setup', WC()->plugin_url() . '/assets/js/admin/wc-setup' . $suffix . '.js', array( 'jquery', 'wc-enhanced-select', 'jquery-blockui', 'wp-util' ), WC_VERSION );
- wp_localize_script( 'wc-setup', 'wc_setup_params', array(
- 'pending_jetpack_install' => $pending_jetpack ? 'yes' : 'no',
- ) );
+ wp_localize_script(
+ 'wc-setup',
+ 'wc_setup_params',
+ array(
+ 'pending_jetpack_install' => $pending_jetpack ? 'yes' : 'no',
+ )
+ );
// @codingStandardsIgnoreStart
if ( ! empty( $_POST['save_step'] ) && isset( $this->steps[ $this->step ]['handler'] ) ) {
@@ -601,10 +611,13 @@ class WC_Admin_Setup_Wizard {
add_action( 'shutdown', array( $this, 'run_deferred_actions' ) );
}
- array_push( $this->deferred_actions, array(
- 'func' => array( 'WC_Install', 'background_installer' ),
- 'args' => array( $plugin_id, $plugin_info ),
- ) );
+ array_push(
+ $this->deferred_actions,
+ array(
+ 'func' => array( 'WC_Install', 'background_installer' ),
+ 'args' => array( $plugin_id, $plugin_info ),
+ )
+ );
// Set the background installation flag for this plugin.
update_option( 'woocommerce_setup_background_installing_' . $plugin_id, true );
@@ -620,21 +633,27 @@ class WC_Admin_Setup_Wizard {
if ( empty( $this->deferred_actions ) ) {
add_action( 'shutdown', array( $this, 'run_deferred_actions' ) );
}
- array_push( $this->deferred_actions, array(
- 'func' => array( 'WC_Install', 'theme_background_installer' ),
- 'args' => array( $theme_id ),
- ) );
+ array_push(
+ $this->deferred_actions,
+ array(
+ 'func' => array( 'WC_Install', 'theme_background_installer' ),
+ 'args' => array( $theme_id ),
+ )
+ );
}
/**
* Helper method to install Jetpack.
*/
protected function install_jetpack() {
- $this->install_plugin( 'jetpack', array(
- 'file' => 'jetpack/jetpack.php',
- 'name' => __( 'Jetpack', 'woocommerce' ),
- 'repo-slug' => 'jetpack',
- ) );
+ $this->install_plugin(
+ 'jetpack',
+ array(
+ 'file' => 'jetpack/jetpack.php',
+ 'name' => __( 'Jetpack', 'woocommerce' ),
+ 'repo-slug' => 'jetpack',
+ )
+ );
}
/**
@@ -642,11 +661,14 @@ class WC_Admin_Setup_Wizard {
*/
protected function install_woocommerce_services() {
$this->install_jetpack();
- $this->install_plugin( 'woocommerce-services', array(
- 'file' => 'woocommerce-services/woocommerce-services.php',
- 'name' => __( 'WooCommerce Services', 'woocommerce' ),
- 'repo-slug' => 'woocommerce-services',
- ) );
+ $this->install_plugin(
+ 'woocommerce-services',
+ array(
+ 'file' => 'woocommerce-services/woocommerce-services.php',
+ 'name' => __( 'WooCommerce Services', 'woocommerce' ),
+ 'repo-slug' => 'woocommerce-services',
+ )
+ );
}
/**
@@ -853,10 +875,12 @@ class WC_Admin_Setup_Wizard {
@@ -871,10 +895,12 @@ class WC_Admin_Setup_Wizard {
diff --git a/includes/admin/class-wc-admin-status.php b/includes/admin/class-wc-admin-status.php
index f249f66aa46..e4b25a3a87c 100644
--- a/includes/admin/class-wc-admin-status.php
+++ b/includes/admin/class-wc-admin-status.php
@@ -19,14 +19,14 @@ class WC_Admin_Status {
* Handles output of the reports page in admin.
*/
public static function output() {
- include_once( dirname( __FILE__ ) . '/views/html-admin-page-status.php' );
+ include_once dirname( __FILE__ ) . '/views/html-admin-page-status.php';
}
/**
* Handles output of report.
*/
public static function status_report() {
- include_once( dirname( __FILE__ ) . '/views/html-admin-page-status-report.php' );
+ include_once dirname( __FILE__ ) . '/views/html-admin-page-status-report.php';
}
/**
@@ -36,13 +36,16 @@ class WC_Admin_Status {
$tools = self::get_tools();
if ( ! empty( $_GET['action'] ) && ! empty( $_REQUEST['_wpnonce'] ) && wp_verify_nonce( $_REQUEST['_wpnonce'], 'debug_action' ) ) {
- $tools_controller = new WC_REST_System_Status_Tools_Controller;
+ $tools_controller = new WC_REST_System_Status_Tools_Controller();
$action = wc_clean( $_GET['action'] );
if ( array_key_exists( $action, $tools ) ) {
$response = $tools_controller->execute_tool( $action );
} else {
- $response = array( 'success' => false, 'message' => __( 'Tool does not exist.', 'woocommerce' ) );
+ $response = array(
+ 'success' => false,
+ 'message' => __( 'Tool does not exist.', 'woocommerce' ),
+ );
}
if ( $response['success'] ) {
@@ -57,15 +60,16 @@ class WC_Admin_Status {
echo '
' . __( 'Your changes have been saved.', 'woocommerce' ) . '
';
}
- include_once( dirname( __FILE__ ) . '/views/html-admin-page-status-tools.php' );
+ include_once dirname( __FILE__ ) . '/views/html-admin-page-status-tools.php';
}
/**
* Get tools.
+ *
* @return array of tools
*/
public static function get_tools() {
- $tools_controller = new WC_REST_System_Status_Tools_Controller;
+ $tools_controller = new WC_REST_System_Status_Tools_Controller();
return $tools_controller->get_tools();
}
@@ -99,7 +103,7 @@ class WC_Admin_Status {
self::remove_log();
}
- include_once( 'views/html-admin-page-status-logs.php' );
+ include_once 'views/html-admin-page-status-logs.php';
}
/**
@@ -120,11 +124,12 @@ class WC_Admin_Status {
$log_table_list = new WC_Admin_Log_Table_List();
$log_table_list->prepare_items();
- include_once( 'views/html-admin-page-status-logs-db.php' );
+ include_once 'views/html-admin-page-status-logs-db.php';
}
/**
* Retrieve metadata from a file. Based on WP Core's get_file_data function.
+ *
* @since 2.1.1
* @param string $file Path to the file
* @return string
@@ -153,7 +158,7 @@ class WC_Admin_Status {
$version = _cleanup_header_comment( $match[1] );
}
- return $version ;
+ return $version;
}
/**
@@ -168,6 +173,7 @@ class WC_Admin_Status {
/**
* Scan the template files.
+ *
* @param string $template_path
* @return array
*/
@@ -180,7 +186,7 @@ class WC_Admin_Status {
foreach ( $files as $key => $value ) {
- if ( ! in_array( $value, array( ".", ".." ) ) ) {
+ if ( ! in_array( $value, array( '.', '..' ) ) ) {
if ( is_dir( $template_path . DIRECTORY_SEPARATOR . $value ) ) {
$sub_files = self::scan_template_files( $template_path . DIRECTORY_SEPARATOR . $value );
@@ -198,6 +204,7 @@ class WC_Admin_Status {
/**
* Scan the log files.
+ *
* @return array
*/
public static function scan_log_files() {
@@ -221,41 +228,48 @@ class WC_Admin_Status {
/**
* Get latest version of a theme by slug.
+ *
* @param object $theme WP_Theme object.
* @return string Version number if found.
*/
public static function get_latest_theme_version( $theme ) {
- include_once( ABSPATH . 'wp-admin/includes/theme.php' );
+ include_once ABSPATH . 'wp-admin/includes/theme.php';
- $api = themes_api( 'theme_information', array(
- 'slug' => $theme->get_stylesheet(),
- 'fields' => array(
- 'sections' => false,
- 'tags' => false,
- ),
- ) );
+ $api = themes_api(
+ 'theme_information',
+ array(
+ 'slug' => $theme->get_stylesheet(),
+ 'fields' => array(
+ 'sections' => false,
+ 'tags' => false,
+ ),
+ )
+ );
$update_theme_version = 0;
// Check .org for updates.
if ( is_object( $api ) && ! is_wp_error( $api ) ) {
$update_theme_version = $api->version;
-
- // Check WooThemes Theme Version.
- } elseif ( strstr( $theme->{'Author URI'}, 'woothemes' ) ) {
- $theme_dir = substr( strtolower( str_replace( ' ','', $theme->Name ) ), 0, 45 );
+ } elseif ( strstr( $theme->{'Author URI'}, 'woothemes' ) ) { // Check WooThemes Theme Version.
+ $theme_dir = substr( strtolower( str_replace( ' ', '', $theme->Name ) ), 0, 45 );
if ( false === ( $theme_version_data = get_transient( $theme_dir . '_version_data' ) ) ) {
$theme_changelog = wp_safe_remote_get( 'http://dzv365zjfbd8v.cloudfront.net/changelogs/' . $theme_dir . '/changelog.txt' );
- $cl_lines = explode( "\n", wp_remote_retrieve_body( $theme_changelog ) );
+ $cl_lines = explode( "\n", wp_remote_retrieve_body( $theme_changelog ) );
if ( ! empty( $cl_lines ) ) {
foreach ( $cl_lines as $line_num => $cl_line ) {
if ( preg_match( '/^[0-9]/', $cl_line ) ) {
- $theme_date = str_replace( '.' , '-' , trim( substr( $cl_line , 0 , strpos( $cl_line , '-' ) ) ) );
- $theme_version = preg_replace( '~[^0-9,.]~' , '' ,stristr( $cl_line , "version" ) );
- $theme_update = trim( str_replace( "*" , "" , $cl_lines[ $line_num + 1 ] ) );
- $theme_version_data = array( 'date' => $theme_date , 'version' => $theme_version , 'update' => $theme_update , 'changelog' => $theme_changelog );
- set_transient( $theme_dir . '_version_data', $theme_version_data , DAY_IN_SECONDS );
+ $theme_date = str_replace( '.', '-', trim( substr( $cl_line, 0, strpos( $cl_line, '-' ) ) ) );
+ $theme_version = preg_replace( '~[^0-9,.]~', '', stristr( $cl_line, 'version' ) );
+ $theme_update = trim( str_replace( '*', '', $cl_lines[ $line_num + 1 ] ) );
+ $theme_version_data = array(
+ 'date' => $theme_date,
+ 'version' => $theme_version,
+ 'update' => $theme_update,
+ 'changelog' => $theme_changelog,
+ );
+ set_transient( $theme_dir . '_version_data', $theme_version_data, DAY_IN_SECONDS );
break;
}
}
diff --git a/includes/admin/class-wc-admin-taxonomies.php b/includes/admin/class-wc-admin-taxonomies.php
index 887acb30882..694f572d4e4 100644
--- a/includes/admin/class-wc-admin-taxonomies.php
+++ b/includes/admin/class-wc-admin-taxonomies.php
@@ -59,8 +59,8 @@ class WC_Admin_Taxonomies {
/**
* Order term when created (put in position 0).
*
- * @param mixed $term_id
- * @param mixed $tt_id
+ * @param mixed $term_id
+ * @param mixed $tt_id
* @param string $taxonomy
*/
public function create_term( $term_id, $tt_id = '', $taxonomy = '' ) {
@@ -132,9 +132,9 @@ class WC_Admin_Taxonomies {
// Create the media frame.
file_frame = wp.media.frames.downloadable_file = wp.media({
- title: '',
+ title: '',
button: {
- text: ''
+ text: ''
},
multiple: false
});
@@ -242,9 +242,9 @@ class WC_Admin_Taxonomies {
// Create the media frame.
file_frame = wp.media.frames.downloadable_file = wp.media({
- title: '',
+ title: '',
button: {
- text: ''
+ text: ''
},
multiple: false
});
@@ -280,8 +280,8 @@ class WC_Admin_Taxonomies {
/**
* save_category_fields function.
*
- * @param mixed $term_id Term ID being saved
- * @param mixed $tt_id
+ * @param mixed $term_id Term ID being saved
+ * @param mixed $tt_id
* @param string $taxonomy
*/
public function save_category_fields( $term_id, $tt_id = '', $taxonomy = '' ) {
@@ -310,7 +310,7 @@ class WC_Admin_Taxonomies {
?>
-
+
'webhook',
- 'plural' => 'webhooks',
- 'ajax' => false,
- ) );
+ parent::__construct(
+ array(
+ 'singular' => 'webhook',
+ 'plural' => 'webhooks',
+ 'ajax' => false,
+ )
+ );
}
/**
@@ -79,9 +81,15 @@ class WC_Admin_Webhooks_Table_List extends WP_List_Table {
'id' => sprintf( __( 'ID: %d', 'woocommerce' ), $webhook->get_id() ),
'edit' => '' . esc_html__( 'Edit', 'woocommerce' ) . '',
/* translators: %s: webhook name */
- 'delete' => 'get_name() ) ) . '" href="' . esc_url( wp_nonce_url( add_query_arg( array(
- 'delete' => $webhook->get_id(),
- ), admin_url( 'admin.php?page=wc-settings&tab=api§ion=webhooks' ) ), 'delete-webhook' ) ) . '">' . esc_html__( 'Delete permanently', 'woocommerce' ) . '',
+ 'delete' => 'get_name() ) ) . '" href="' . esc_url(
+ wp_nonce_url(
+ add_query_arg(
+ array(
+ 'delete' => $webhook->get_id(),
+ ), admin_url( 'admin.php?page=wc-settings&tab=api§ion=webhooks' )
+ ), 'delete-webhook'
+ )
+ ) . '">' . esc_html__( 'Delete permanently', 'woocommerce' ) . '',
);
$actions = apply_filters( 'webhook_row_actions', $actions, $webhook );
@@ -237,9 +245,12 @@ class WC_Admin_Webhooks_Table_List extends WP_List_Table {
echo '
';
echo '';
echo '';
- submit_button( $text, '', '', false, array(
- 'id' => 'search-submit',
- ) );
+ submit_button(
+ $text, '', '', false,
+ array(
+ 'id' => 'search-submit',
+ )
+ );
echo '
';
}
@@ -276,10 +287,12 @@ class WC_Admin_Webhooks_Table_List extends WP_List_Table {
$total_items = count( $data_store->search_webhooks( $args ) );
// Set the pagination.
- $this->set_pagination_args( array(
- 'total_items' => $total_items,
- 'per_page' => $per_page,
- 'total_pages' => ceil( $total_items / $per_page ),
- ) );
+ $this->set_pagination_args(
+ array(
+ 'total_items' => $total_items,
+ 'per_page' => $per_page,
+ 'total_pages' => ceil( $total_items / $per_page ),
+ )
+ );
}
}
diff --git a/includes/admin/class-wc-admin-webhooks.php b/includes/admin/class-wc-admin-webhooks.php
index b3215eef7a8..9d09ac13050 100644
--- a/includes/admin/class-wc-admin-webhooks.php
+++ b/includes/admin/class-wc-admin-webhooks.php
@@ -276,10 +276,13 @@ class WC_Admin_Webhooks {
$webhooks_table_list = new WC_Admin_Webhooks_Table_List();
// Add screen option.
- add_screen_option( 'per_page', array(
- 'default' => 10,
- 'option' => 'woocommerce_webhooks_per_page',
- ) );
+ add_screen_option(
+ 'per_page',
+ array(
+ 'default' => 10,
+ 'option' => 'woocommerce_webhooks_per_page',
+ )
+ );
}
}
diff --git a/includes/admin/class-wc-admin.php b/includes/admin/class-wc-admin.php
index bab0a82db55..0d95cb3b097 100644
--- a/includes/admin/class-wc-admin.php
+++ b/includes/admin/class-wc-admin.php
@@ -44,46 +44,46 @@ class WC_Admin {
* Include any classes we need within admin.
*/
public function includes() {
- include_once( dirname( __FILE__ ) . '/wc-admin-functions.php' );
- include_once( dirname( __FILE__ ) . '/wc-meta-box-functions.php' );
- include_once( dirname( __FILE__ ) . '/class-wc-admin-post-types.php' );
- include_once( dirname( __FILE__ ) . '/class-wc-admin-taxonomies.php' );
- include_once( dirname( __FILE__ ) . '/class-wc-admin-menus.php' );
- include_once( dirname( __FILE__ ) . '/class-wc-admin-customize.php' );
- include_once( dirname( __FILE__ ) . '/class-wc-admin-notices.php' );
- include_once( dirname( __FILE__ ) . '/class-wc-admin-assets.php' );
- include_once( dirname( __FILE__ ) . '/class-wc-admin-api-keys.php' );
- include_once( dirname( __FILE__ ) . '/class-wc-admin-webhooks.php' );
- include_once( dirname( __FILE__ ) . '/class-wc-admin-pointers.php' );
- include_once( dirname( __FILE__ ) . '/class-wc-admin-importers.php' );
- include_once( dirname( __FILE__ ) . '/class-wc-admin-exporters.php' );
+ include_once dirname( __FILE__ ) . '/wc-admin-functions.php';
+ include_once dirname( __FILE__ ) . '/wc-meta-box-functions.php';
+ include_once dirname( __FILE__ ) . '/class-wc-admin-post-types.php';
+ include_once dirname( __FILE__ ) . '/class-wc-admin-taxonomies.php';
+ include_once dirname( __FILE__ ) . '/class-wc-admin-menus.php';
+ include_once dirname( __FILE__ ) . '/class-wc-admin-customize.php';
+ include_once dirname( __FILE__ ) . '/class-wc-admin-notices.php';
+ include_once dirname( __FILE__ ) . '/class-wc-admin-assets.php';
+ include_once dirname( __FILE__ ) . '/class-wc-admin-api-keys.php';
+ include_once dirname( __FILE__ ) . '/class-wc-admin-webhooks.php';
+ include_once dirname( __FILE__ ) . '/class-wc-admin-pointers.php';
+ include_once dirname( __FILE__ ) . '/class-wc-admin-importers.php';
+ include_once dirname( __FILE__ ) . '/class-wc-admin-exporters.php';
// Help Tabs
if ( apply_filters( 'woocommerce_enable_admin_help_tab', true ) ) {
- include_once( dirname( __FILE__ ) . '/class-wc-admin-help.php' );
+ include_once dirname( __FILE__ ) . '/class-wc-admin-help.php';
}
// Setup/welcome
if ( ! empty( $_GET['page'] ) ) {
switch ( $_GET['page'] ) {
- case 'wc-setup' :
- include_once( dirname( __FILE__ ) . '/class-wc-admin-setup-wizard.php' );
- break;
+ case 'wc-setup':
+ include_once dirname( __FILE__ ) . '/class-wc-admin-setup-wizard.php';
+ break;
}
}
// Importers
if ( defined( 'WP_LOAD_IMPORTERS' ) ) {
- include_once( dirname( __FILE__ ) . '/class-wc-admin-importers.php' );
+ include_once dirname( __FILE__ ) . '/class-wc-admin-importers.php';
}
// Helper
- include_once( dirname( __FILE__ ) . '/helper/class-wc-helper-options.php' );
- include_once( dirname( __FILE__ ) . '/helper/class-wc-helper-api.php' );
- include_once( dirname( __FILE__ ) . '/helper/class-wc-helper-updater.php' );
- include_once( dirname( __FILE__ ) . '/helper/class-wc-helper-plugin-info.php' );
- include_once( dirname( __FILE__ ) . '/helper/class-wc-helper-compat.php' );
- include_once( dirname( __FILE__ ) . '/helper/class-wc-helper.php' );
+ include_once dirname( __FILE__ ) . '/helper/class-wc-helper-options.php';
+ include_once dirname( __FILE__ ) . '/helper/class-wc-helper-api.php';
+ include_once dirname( __FILE__ ) . '/helper/class-wc-helper-updater.php';
+ include_once dirname( __FILE__ ) . '/helper/class-wc-helper-plugin-info.php';
+ include_once dirname( __FILE__ ) . '/helper/class-wc-helper-compat.php';
+ include_once dirname( __FILE__ ) . '/helper/class-wc-helper.php';
}
/**
@@ -95,25 +95,25 @@ class WC_Admin {
}
switch ( $screen->id ) {
- case 'dashboard' :
- case 'dashboard-network' :
- include( 'class-wc-admin-dashboard.php' );
- break;
- case 'options-permalink' :
- include( 'class-wc-admin-permalink-settings.php' );
- break;
- case 'plugins' :
- include ( 'plugin-updates/class-wc-plugins-screen-updates.php' );
- break;
- case 'update-core' :
- include( 'plugin-updates/class-wc-updates-screen-updates.php' );
- break;
- case 'users' :
- case 'user' :
- case 'profile' :
- case 'user-edit' :
- include( 'class-wc-admin-profile.php' );
- break;
+ case 'dashboard':
+ case 'dashboard-network':
+ include 'class-wc-admin-dashboard.php';
+ break;
+ case 'options-permalink':
+ include 'class-wc-admin-permalink-settings.php';
+ break;
+ case 'plugins':
+ include 'plugin-updates/class-wc-plugins-screen-updates.php';
+ break;
+ case 'update-core':
+ include 'plugin-updates/class-wc-updates-screen-updates.php';
+ break;
+ case 'users':
+ case 'user':
+ case 'profile':
+ case 'user-edit':
+ include 'class-wc-admin-profile.php';
+ break;
}
}
@@ -160,7 +160,7 @@ class WC_Admin {
public function prevent_admin_access() {
$prevent_access = false;
- if ( 'yes' === get_option( 'woocommerce_lock_down_admin', 'yes' ) && ! is_ajax() && basename( $_SERVER["SCRIPT_FILENAME"] ) !== 'admin-post.php' ) {
+ if ( 'yes' === get_option( 'woocommerce_lock_down_admin', 'yes' ) && ! is_ajax() && basename( $_SERVER['SCRIPT_FILENAME'] ) !== 'admin-post.php' ) {
$has_cap = false;
$access_caps = array( 'edit_posts', 'manage_woocommerce', 'view_admin_dashboard' );
@@ -193,21 +193,21 @@ class WC_Admin {
}
// load the mailer class
- $mailer = WC()->mailer();
+ $mailer = WC()->mailer();
// get the preview email subject
$email_heading = __( 'HTML email template', 'woocommerce' );
// get the preview email content
ob_start();
- include( 'views/html-email-template-preview.php' );
- $message = ob_get_clean();
+ include 'views/html-email-template-preview.php';
+ $message = ob_get_clean();
// create a new email
- $email = new WC_Email();
+ $email = new WC_Email();
// wrap the content with the email template and then add styles
- $message = apply_filters( 'woocommerce_mail_content', $email->style_inline( $mailer->wrap_message( $email_heading, $message ) ) );
+ $message = apply_filters( 'woocommerce_mail_content', $email->style_inline( $mailer->wrap_message( $email_heading, $message ) ) );
// print the preview email
echo $message;
@@ -242,12 +242,12 @@ class WC_Admin {
sprintf( '
%s', esc_html__( 'WooCommerce', 'woocommerce' ) ),
'
★★★★★'
);
- wc_enqueue_js( "
- jQuery( 'a.wc-rating-link' ).click( function() {
+ wc_enqueue_js(
+ "jQuery( 'a.wc-rating-link' ).click( function() {
jQuery.post( '" . WC()->ajax_url() . "', { action: 'woocommerce_rated' } );
jQuery( this ).parent().text( jQuery( this ).data( 'rated' ) );
- });
- " );
+ });"
+ );
} else {
$footer_text = __( 'Thank you for selling with WooCommerce.', 'woocommerce' );
}
@@ -264,9 +264,11 @@ class WC_Admin {
public function setup_wizard_check_jetpack() {
$jetpack_active = class_exists( 'Jetpack' );
- wp_send_json_success( array(
- 'is_active' => $jetpack_active ? 'yes' : 'no',
- ) );
+ wp_send_json_success(
+ array(
+ 'is_active' => $jetpack_active ? 'yes' : 'no',
+ )
+ );
}
}
diff --git a/includes/admin/helper/class-wc-helper-api.php b/includes/admin/helper/class-wc-helper-api.php
index 014b693d4b3..a5f159f95b9 100644
--- a/includes/admin/helper/class-wc-helper-api.php
+++ b/includes/admin/helper/class-wc-helper-api.php
@@ -26,7 +26,7 @@ class WC_Helper_API {
* Perform an HTTP request to the Helper API.
*
* @param string $endpoint The endpoint to request.
- * @param array $args Additional data for the request. Set authenticated to a truthy value to enable auth.
+ * @param array $args Additional data for the request. Set authenticated to a truthy value to enable auth.
*
* @return array|WP_Error The response from wp_safe_remote_request()
*/
@@ -53,7 +53,7 @@ class WC_Helper_API {
* Adds authentication headers to an HTTP request.
*
* @param string $url The request URI.
- * @param array $args By-ref, the args that will be passed to wp_remote_request().
+ * @param array $args By-ref, the args that will be passed to wp_remote_request().
* @return bool Were the headers added?
*/
private static function _authenticate( $url, &$args ) {
@@ -86,7 +86,7 @@ class WC_Helper_API {
}
$args['headers'] = array(
- 'Authorization' => 'Bearer ' . $auth['access_token'],
+ 'Authorization' => 'Bearer ' . $auth['access_token'],
'X-Woo-Signature' => $signature,
);
@@ -97,7 +97,7 @@ class WC_Helper_API {
* Wrapper for self::request().
*
* @param string $endpoint The helper API endpoint to request.
- * @param array $args Arguments passed to wp_remote_request().
+ * @param array $args Arguments passed to wp_remote_request().
*
* @return array The response object from wp_safe_remote_request().
*/
@@ -110,7 +110,7 @@ class WC_Helper_API {
* Wrapper for self::request().
*
* @param string $endpoint The helper API endpoint to request.
- * @param array $args Arguments passed to wp_remote_request().
+ * @param array $args Arguments passed to wp_remote_request().
*
* @return array The response object from wp_safe_remote_request().
*/
diff --git a/includes/admin/helper/class-wc-helper-compat.php b/includes/admin/helper/class-wc-helper-compat.php
index 4b4727a2e4f..e967da65e95 100644
--- a/includes/admin/helper/class-wc-helper-compat.php
+++ b/includes/admin/helper/class-wc-helper-compat.php
@@ -70,12 +70,15 @@ class WC_Helper_Compat {
return;
}
- $request = WC_Helper_API::post( 'oauth/migrate', array(
- 'body' => array(
- 'home_url' => home_url(),
- 'master_key' => $master_key,
- ),
- ) );
+ $request = WC_Helper_API::post(
+ 'oauth/migrate',
+ array(
+ 'body' => array(
+ 'home_url' => home_url(),
+ 'master_key' => $master_key,
+ ),
+ )
+ );
if ( is_wp_error( $request ) || wp_remote_retrieve_response_code( $request ) !== 200 ) {
WC_Helper::log( 'Call to oauth/migrate returned a non-200 response code' );
@@ -89,13 +92,16 @@ class WC_Helper_Compat {
}
// Obtain an access token.
- $request = WC_Helper_API::post( 'oauth/access_token', array(
- 'body' => array(
- 'request_token' => $request_token,
- 'home_url' => home_url(),
- 'migrate' => true,
- ),
- ) );
+ $request = WC_Helper_API::post(
+ 'oauth/access_token',
+ array(
+ 'body' => array(
+ 'request_token' => $request_token,
+ 'home_url' => home_url(),
+ 'migrate' => true,
+ ),
+ )
+ );
if ( is_wp_error( $request ) || wp_remote_retrieve_response_code( $request ) !== 200 ) {
WC_Helper::log( 'Call to oauth/access_token returned a non-200 response code' );
@@ -108,13 +114,16 @@ class WC_Helper_Compat {
return;
}
- WC_Helper_Options::update( 'auth', array(
- 'access_token' => $access_token['access_token'],
- 'access_token_secret' => $access_token['access_token_secret'],
- 'site_id' => $access_token['site_id'],
- 'user_id' => null, // Set this later
- 'updated' => time(),
- ) );
+ WC_Helper_Options::update(
+ 'auth',
+ array(
+ 'access_token' => $access_token['access_token'],
+ 'access_token_secret' => $access_token['access_token_secret'],
+ 'site_id' => $access_token['site_id'],
+ 'user_id' => null, // Set this later
+ 'updated' => time(),
+ )
+ );
// Obtain the connected user info.
if ( ! WC_Helper::_flush_authentication_cache() ) {
@@ -128,7 +137,7 @@ class WC_Helper_Compat {
* Attempt to deactivate the legacy helper plugin.
*/
public static function deactivate_plugin() {
- include_once( ABSPATH . 'wp-admin/includes/plugin.php' );
+ include_once ABSPATH . 'wp-admin/includes/plugin.php';
if ( ! function_exists( 'deactivate_plugins' ) ) {
return;
}
@@ -175,11 +184,13 @@ class WC_Helper_Compat {
* Render the legacy helper compat view.
*/
public static function render_compat_menu() {
- $helper_url = add_query_arg( array(
- 'page' => 'wc-addons',
- 'section' => 'helper',
- ), admin_url( 'admin.php' ) );
- include( WC_Helper::get_view_filename( 'html-helper-compat.php' ) );
+ $helper_url = add_query_arg(
+ array(
+ 'page' => 'wc-addons',
+ 'section' => 'helper',
+ ), admin_url( 'admin.php' )
+ );
+ include WC_Helper::get_view_filename( 'html-helper-compat.php' );
}
}
diff --git a/includes/admin/helper/class-wc-helper-options.php b/includes/admin/helper/class-wc-helper-options.php
index b11612f4fd5..f0e811d8aeb 100644
--- a/includes/admin/helper/class-wc-helper-options.php
+++ b/includes/admin/helper/class-wc-helper-options.php
@@ -23,12 +23,12 @@ class WC_Helper_Options {
* is not thread-safe, use with caution.
*
* @param string $key The key to update.
- * @param mixed $value The new option value.
+ * @param mixed $value The new option value.
*
* @return bool True if the option has been updated.
*/
public static function update( $key, $value ) {
- $options = get_option( self::$option_name, array() );
+ $options = get_option( self::$option_name, array() );
$options[ $key ] = $value;
return update_option( self::$option_name, $options, true );
}
@@ -39,7 +39,7 @@ class WC_Helper_Options {
* @see self::update
*
* @param string $key The key to fetch.
- * @param mixed $default The default option to return if the key does not exist.
+ * @param mixed $default The default option to return if the key does not exist.
*
* @return mixed An option or the default.
*/
diff --git a/includes/admin/helper/class-wc-helper-plugin-info.php b/includes/admin/helper/class-wc-helper-plugin-info.php
index e9c437f8790..ef7b9204bcf 100644
--- a/includes/admin/helper/class-wc-helper-plugin-info.php
+++ b/includes/admin/helper/class-wc-helper-plugin-info.php
@@ -45,7 +45,7 @@ class WC_Helper_Plugin_Info {
// Look through update data by slug.
$update_data = WC_Helper_Updater::get_update_data();
- $products = wp_list_filter( $update_data, array( 'slug' => $clean_slug ) );
+ $products = wp_list_filter( $update_data, array( 'slug' => $clean_slug ) );
if ( empty( $products ) ) {
return $response;
@@ -55,9 +55,13 @@ class WC_Helper_Plugin_Info {
$product_id = array_shift( $product_id );
// Fetch the product information from the Helper API.
- $request = WC_Helper_API::get( add_query_arg( array(
- 'product_id' => absint( $product_id ),
- ), 'info' ), array( 'authenticated' => true ) );
+ $request = WC_Helper_API::get(
+ add_query_arg(
+ array(
+ 'product_id' => absint( $product_id ),
+ ), 'info'
+ ), array( 'authenticated' => true )
+ );
$results = json_decode( wp_remote_retrieve_body( $request ), true );
if ( ! empty( $results ) ) {
diff --git a/includes/admin/helper/class-wc-helper-updater.php b/includes/admin/helper/class-wc-helper-updater.php
index 5734886ad43..02544b15dcb 100644
--- a/includes/admin/helper/class-wc-helper-updater.php
+++ b/includes/admin/helper/class-wc-helper-updater.php
@@ -36,16 +36,16 @@ class WC_Helper_Updater {
continue;
}
- $data = $update_data[ $plugin['_product_id'] ];
+ $data = $update_data[ $plugin['_product_id'] ];
$filename = $plugin['_filename'];
$item = array(
- 'id' => 'woocommerce-com-' . $plugin['_product_id'],
- 'slug' => 'woocommerce-com-' . $data['slug'],
- 'plugin' => $filename,
- 'new_version' => $data['version'],
- 'url' => $data['url'],
- 'package' => '',
+ 'id' => 'woocommerce-com-' . $plugin['_product_id'],
+ 'slug' => 'woocommerce-com-' . $data['slug'],
+ 'plugin' => $filename,
+ 'new_version' => $data['version'],
+ 'url' => $data['url'],
+ 'package' => '',
'upgrade_notice' => $data['upgrade_notice'],
);
@@ -85,10 +85,10 @@ class WC_Helper_Updater {
$slug = $theme['_stylesheet'];
$item = array(
- 'theme' => $slug,
+ 'theme' => $slug,
'new_version' => $data['version'],
- 'url' => $data['url'],
- 'package' => '',
+ 'url' => $data['url'],
+ 'package' => '',
);
if ( self::_has_active_subscription( $theme['_product_id'] ) ) {
@@ -122,7 +122,7 @@ class WC_Helper_Updater {
foreach ( WC_Helper::get_subscriptions() as $subscription ) {
$payload[ $subscription['product_id'] ] = array(
'product_id' => $subscription['product_id'],
- 'file_id' => '',
+ 'file_id' => '',
);
}
@@ -171,16 +171,18 @@ class WC_Helper_Updater {
}
$data = array(
- 'hash' => $hash,
- 'updated' => time(),
+ 'hash' => $hash,
+ 'updated' => time(),
'products' => array(),
- 'errors' => array(),
+ 'errors' => array(),
);
- $request = WC_Helper_API::post( 'update-check', array(
- 'body' => json_encode( array( 'products' => $payload ) ),
- 'authenticated' => true,
- ) );
+ $request = WC_Helper_API::post(
+ 'update-check', array(
+ 'body' => json_encode( array( 'products' => $payload ) ),
+ 'authenticated' => true,
+ )
+ );
if ( wp_remote_retrieve_response_code( $request ) !== 200 ) {
$data['errors'][] = 'http-error';
@@ -250,7 +252,7 @@ class WC_Helper_Updater {
return 0;
}
- $count = 0;
+ $count = 0;
$update_data = self::get_update_data();
if ( empty( $update_data ) ) {
diff --git a/includes/admin/helper/class-wc-helper.php b/includes/admin/helper/class-wc-helper.php
index 84e4dcba250..665a08051fd 100644
--- a/includes/admin/helper/class-wc-helper.php
+++ b/includes/admin/helper/class-wc-helper.php
@@ -49,7 +49,7 @@ class WC_Helper {
* Render the helper section content based on context.
*/
public static function render_helper_output() {
- $auth = WC_Helper_Options::get( 'auth' );
+ $auth = WC_Helper_Options::get( 'auth' );
$auth_user_data = WC_Helper_Options::get( 'auth_user_data' );
// Return success/error notices.
@@ -57,68 +57,78 @@ class WC_Helper {
// No active connection.
if ( empty( $auth['access_token'] ) ) {
- $connect_url = add_query_arg( array(
- 'page' => 'wc-addons',
- 'section' => 'helper',
- 'wc-helper-connect' => 1,
- 'wc-helper-nonce' => wp_create_nonce( 'connect' ),
- ), admin_url( 'admin.php' ) );
+ $connect_url = add_query_arg(
+ array(
+ 'page' => 'wc-addons',
+ 'section' => 'helper',
+ 'wc-helper-connect' => 1,
+ 'wc-helper-nonce' => wp_create_nonce( 'connect' ),
+ ), admin_url( 'admin.php' )
+ );
- include( self::get_view_filename( 'html-oauth-start.php' ) );
+ include self::get_view_filename( 'html-oauth-start.php' );
return;
}
- $disconnect_url = add_query_arg( array(
- 'page' => 'wc-addons',
- 'section' => 'helper',
- 'wc-helper-disconnect' => 1,
- 'wc-helper-nonce' => wp_create_nonce( 'disconnect' ),
- ), admin_url( 'admin.php' ) );
+ $disconnect_url = add_query_arg(
+ array(
+ 'page' => 'wc-addons',
+ 'section' => 'helper',
+ 'wc-helper-disconnect' => 1,
+ 'wc-helper-nonce' => wp_create_nonce( 'disconnect' ),
+ ), admin_url( 'admin.php' )
+ );
$current_filter = self::get_current_filter();
- $refresh_url = add_query_arg( array(
- 'page' => 'wc-addons',
- 'section' => 'helper',
- 'filter' => $current_filter,
- 'wc-helper-refresh' => 1,
- 'wc-helper-nonce' => wp_create_nonce( 'refresh' ),
- ), admin_url( 'admin.php' ) );
+ $refresh_url = add_query_arg(
+ array(
+ 'page' => 'wc-addons',
+ 'section' => 'helper',
+ 'filter' => $current_filter,
+ 'wc-helper-refresh' => 1,
+ 'wc-helper-nonce' => wp_create_nonce( 'refresh' ),
+ ), admin_url( 'admin.php' )
+ );
// Installed plugins and themes, with or without an active subscription.
$woo_plugins = self::get_local_woo_plugins();
- $woo_themes = self::get_local_woo_themes();
+ $woo_themes = self::get_local_woo_themes();
- $site_id = absint( $auth['site_id'] );
- $subscriptions = self::get_subscriptions();
- $updates = WC_Helper_Updater::get_update_data();
+ $site_id = absint( $auth['site_id'] );
+ $subscriptions = self::get_subscriptions();
+ $updates = WC_Helper_Updater::get_update_data();
$subscriptions_product_ids = wp_list_pluck( $subscriptions, 'product_id' );
foreach ( $subscriptions as &$subscription ) {
$subscription['active'] = in_array( $site_id, $subscription['connections'] );
- $subscription['activate_url'] = add_query_arg( array(
- 'page' => 'wc-addons',
- 'section' => 'helper',
- 'filter' => $current_filter,
- 'wc-helper-activate' => 1,
- 'wc-helper-product-key' => $subscription['product_key'],
- 'wc-helper-product-id' => $subscription['product_id'],
- 'wc-helper-nonce' => wp_create_nonce( 'activate:' . $subscription['product_key'] ),
- ), admin_url( 'admin.php' ) );
+ $subscription['activate_url'] = add_query_arg(
+ array(
+ 'page' => 'wc-addons',
+ 'section' => 'helper',
+ 'filter' => $current_filter,
+ 'wc-helper-activate' => 1,
+ 'wc-helper-product-key' => $subscription['product_key'],
+ 'wc-helper-product-id' => $subscription['product_id'],
+ 'wc-helper-nonce' => wp_create_nonce( 'activate:' . $subscription['product_key'] ),
+ ), admin_url( 'admin.php' )
+ );
- $subscription['deactivate_url'] = add_query_arg( array(
- 'page' => 'wc-addons',
- 'section' => 'helper',
- 'filter' => $current_filter,
- 'wc-helper-deactivate' => 1,
- 'wc-helper-product-key' => $subscription['product_key'],
- 'wc-helper-product-id' => $subscription['product_id'],
- 'wc-helper-nonce' => wp_create_nonce( 'deactivate:' . $subscription['product_key'] ),
- ), admin_url( 'admin.php' ) );
+ $subscription['deactivate_url'] = add_query_arg(
+ array(
+ 'page' => 'wc-addons',
+ 'section' => 'helper',
+ 'filter' => $current_filter,
+ 'wc-helper-deactivate' => 1,
+ 'wc-helper-product-key' => $subscription['product_key'],
+ 'wc-helper-product-id' => $subscription['product_id'],
+ 'wc-helper-nonce' => wp_create_nonce( 'deactivate:' . $subscription['product_key'] ),
+ ), admin_url( 'admin.php' )
+ );
$subscription['local'] = array(
'installed' => false,
- 'active' => false,
- 'version' => null,
+ 'active' => false,
+ 'version' => null,
);
$subscription['update_url'] = admin_url( 'update-core.php' );
@@ -126,9 +136,9 @@ class WC_Helper {
$local = wp_list_filter( array_merge( $woo_plugins, $woo_themes ), array( '_product_id' => $subscription['product_id'] ) );
if ( ! empty( $local ) ) {
- $local = array_shift( $local );
+ $local = array_shift( $local );
$subscription['local']['installed'] = true;
- $subscription['local']['version'] = $local['Version'];
+ $subscription['local']['version'] = $local['Version'];
if ( 'plugin' == $local['_type'] ) {
if ( is_plugin_active( $local['_filename'] ) ) {
@@ -156,7 +166,7 @@ class WC_Helper {
}
$subscription['download_primary'] = true;
- $subscription['download_url'] = $subscription['product_url'];
+ $subscription['download_url'] = $subscription['product_url'];
if ( ! $subscription['local']['installed'] && ! empty( $updates[ $subscription['product_id'] ] ) ) {
$subscription['download_url'] = $updates[ $subscription['product_id'] ]['package'];
}
@@ -166,18 +176,18 @@ class WC_Helper {
if ( $subscription['has_update'] && ! $subscription['expired'] ) {
$action = array(
/* translators: %s: version number */
- 'message' => sprintf( __( 'Version %s is
available.', 'woocommerce' ), esc_html( $updates[ $subscription['product_id'] ]['version'] ) ),
+ 'message' => sprintf( __( 'Version %s is
available.', 'woocommerce' ), esc_html( $updates[ $subscription['product_id'] ]['version'] ) ),
'button_label' => __( 'Update', 'woocommerce' ),
- 'button_url' => $subscription['update_url'],
- 'status' => 'update-available',
- 'icon' => 'dashicons-update',
+ 'button_url' => $subscription['update_url'],
+ 'status' => 'update-available',
+ 'icon' => 'dashicons-update',
);
// Subscription is not active on this site.
if ( ! $subscription['active'] ) {
- $action['message'] .= ' ' . __( 'To enable this update you need to
activate this subscription.', 'woocommerce' );
+ $action['message'] .= ' ' . __( 'To enable this update you need to
activate this subscription.', 'woocommerce' );
$action['button_label'] = null;
- $action['button_url'] = null;
+ $action['button_url'] = null;
}
$subscription['actions'][] = $action;
@@ -187,30 +197,30 @@ class WC_Helper {
$action = array(
/* translators: %s: version number */
'message' => sprintf( __( 'Version %s is
available.', 'woocommerce' ), esc_html( $updates[ $subscription['product_id'] ]['version'] ) ),
- 'status' => 'expired',
- 'icon' => 'dashicons-info',
+ 'status' => 'expired',
+ 'icon' => 'dashicons-info',
);
- $action['message'] .= ' ' . __( 'To enable this update you need to
purchase a new subscription.', 'woocommerce' );
+ $action['message'] .= ' ' . __( 'To enable this update you need to
purchase a new subscription.', 'woocommerce' );
$action['button_label'] = __( 'Purchase', 'woocommerce' );
- $action['button_url'] = $subscription['product_url'];
+ $action['button_url'] = $subscription['product_url'];
$subscription['actions'][] = $action;
} elseif ( $subscription['expired'] && ! empty( $subscription['master_user_email'] ) ) {
$action = array(
'message' => sprintf( __( 'This subscription has expired. Contact the owner to
renew the subscription to receive updates and support.', 'woocommerce' ) ),
- 'status' => 'expired',
- 'icon' => 'dashicons-info',
+ 'status' => 'expired',
+ 'icon' => 'dashicons-info',
);
$subscription['actions'][] = $action;
} elseif ( $subscription['expired'] ) {
$action = array(
- 'message' => sprintf( __( 'This subscription has expired. Please
renew to receive updates and support.', 'woocommerce' ) ),
+ 'message' => sprintf( __( 'This subscription has expired. Please
renew to receive updates and support.', 'woocommerce' ) ),
'button_label' => __( 'Renew', 'woocommerce' ),
- 'button_url' => 'https://woocommerce.com/my-account/my-subscriptions/',
- 'status' => 'expired',
- 'icon' => 'dashicons-info',
+ 'button_url' => 'https://woocommerce.com/my-account/my-subscriptions/',
+ 'status' => 'expired',
+ 'icon' => 'dashicons-info',
);
$subscription['actions'][] = $action;
@@ -218,26 +228,26 @@ class WC_Helper {
if ( $subscription['expiring'] && ! $subscription['autorenew'] ) {
$action = array(
- 'message' => __( 'Subscription is
expiring soon.', 'woocommerce' ),
+ 'message' => __( 'Subscription is
expiring soon.', 'woocommerce' ),
'button_label' => __( 'Enable auto-renew', 'woocommerce' ),
- 'button_url' => 'https://woocommerce.com/my-account/my-subscriptions/',
- 'status' => 'expired',
- 'icon' => 'dashicons-info',
+ 'button_url' => 'https://woocommerce.com/my-account/my-subscriptions/',
+ 'status' => 'expired',
+ 'icon' => 'dashicons-info',
);
$subscription['download_primary'] = false;
- $subscription['actions'][] = $action;
+ $subscription['actions'][] = $action;
} elseif ( $subscription['expiring'] ) {
$action = array(
- 'message' => sprintf( __( 'This subscription is expiring soon. Please
renew to continue receiving updates and support.', 'woocommerce' ) ),
+ 'message' => sprintf( __( 'This subscription is expiring soon. Please
renew to continue receiving updates and support.', 'woocommerce' ) ),
'button_label' => __( 'Renew', 'woocommerce' ),
- 'button_url' => 'https://woocommerce.com/my-account/my-subscriptions/',
- 'status' => 'expired',
- 'icon' => 'dashicons-info',
+ 'button_url' => 'https://woocommerce.com/my-account/my-subscriptions/',
+ 'status' => 'expired',
+ 'icon' => 'dashicons-info',
);
$subscription['download_primary'] = false;
- $subscription['actions'][] = $action;
+ $subscription['actions'][] = $action;
}
// Mark the first action primary.
@@ -260,7 +270,7 @@ class WC_Helper {
}
$data['_product_url'] = '#';
- $data['_has_update'] = false;
+ $data['_has_update'] = false;
if ( ! empty( $updates[ $data['_product_id'] ] ) ) {
$data['_has_update'] = version_compare( $updates[ $data['_product_id'] ]['version'], $data['Version'], '>' );
@@ -276,22 +286,22 @@ class WC_Helper {
if ( $data['_has_update'] ) {
$action = array(
- 'message' => sprintf( __( 'Version %s is
available. To enable this update you need to
purchase a new subscription.', 'woocommerce' ), esc_html( $updates[ $data['_product_id'] ]['version'] ) ),
+ 'message' => sprintf( __( 'Version %s is
available. To enable this update you need to
purchase a new subscription.', 'woocommerce' ), esc_html( $updates[ $data['_product_id'] ]['version'] ) ),
'button_label' => __( 'Purchase', 'woocommerce' ),
- 'button_url' => $data['_product_url'],
- 'status' => 'expired',
- 'icon' => 'dashicons-info',
+ 'button_url' => $data['_product_url'],
+ 'status' => 'expired',
+ 'icon' => 'dashicons-info',
);
$data['_actions'][] = $action;
} else {
$action = array(
/* translators: 1: subscriptions docs 2: subscriptions docs */
- 'message' => sprintf( __( 'To receive updates and support for this extension, you need to
purchase a new subscription or consolidate your extensions to one connected account by
sharing or transferring this extension to this connected account.', 'woocommerce' ), 'https://docs.woocommerce.com/document/managing-woocommerce-com-subscriptions/#section-10', 'https://docs.woocommerce.com/document/managing-woocommerce-com-subscriptions/#section-5' ),
+ 'message' => sprintf( __( 'To receive updates and support for this extension, you need to
purchase a new subscription or consolidate your extensions to one connected account by
sharing or transferring this extension to this connected account.', 'woocommerce' ), 'https://docs.woocommerce.com/document/managing-woocommerce-com-subscriptions/#section-10', 'https://docs.woocommerce.com/document/managing-woocommerce-com-subscriptions/#section-5' ),
'button_label' => __( 'Purchase', 'woocommerce' ),
- 'button_url' => $data['_product_url'],
- 'status' => 'expired',
- 'icon' => 'dashicons-info',
+ 'button_url' => $data['_product_url'],
+ 'status' => 'expired',
+ 'icon' => 'dashicons-info',
);
$data['_actions'][] = $action;
@@ -315,7 +325,7 @@ class WC_Helper {
self::_filter( $subscriptions, self::get_current_filter() );
// We have an active connection.
- include( self::get_view_filename( 'html-main.php' ) );
+ include self::get_view_filename( 'html-main.php' );
return;
}
@@ -326,14 +336,14 @@ class WC_Helper {
*/
public static function get_filters() {
$filters = array(
- 'all' => __( 'All', 'woocommerce' ),
- 'active' => __( 'Active', 'woocommerce' ),
- 'inactive' => __( 'Inactive', 'woocommerce' ),
- 'installed' => __( 'Installed', 'woocommerce' ),
+ 'all' => __( 'All', 'woocommerce' ),
+ 'active' => __( 'Active', 'woocommerce' ),
+ 'inactive' => __( 'Inactive', 'woocommerce' ),
+ 'installed' => __( 'Installed', 'woocommerce' ),
'update-available' => __( 'Update Available', 'woocommerce' ),
- 'expiring' => __( 'Expiring Soon', 'woocommerce' ),
- 'expired' => __( 'Expired', 'woocommerce' ),
- 'download' => __( 'Download', 'woocommerce' ),
+ 'expiring' => __( 'Expiring Soon', 'woocommerce' ),
+ 'expired' => __( 'Expired', 'woocommerce' ),
+ 'download' => __( 'Download', 'woocommerce' ),
);
return $filters;
@@ -374,7 +384,7 @@ class WC_Helper {
*/
public static function get_current_filter() {
$current_filter = 'all';
- $valid_filters = array_keys( self::get_filters() );
+ $valid_filters = array_keys( self::get_filters() );
if ( ! empty( $_GET['filter'] ) && in_array( $_GET['filter'], $valid_filters ) ) {
$current_filter = $_GET['filter'];
@@ -386,7 +396,7 @@ class WC_Helper {
/**
* Filter an array of subscriptions by $filter.
*
- * @param array $subscriptions The subscriptions array, passed by ref.
+ * @param array $subscriptions The subscriptions array, passed by ref.
* @param string $filter The filter.
*/
private static function _filter( &$subscriptions, $filter ) {
@@ -451,106 +461,122 @@ class WC_Helper {
*/
private static function _get_return_notices() {
$return_status = isset( $_GET['wc-helper-status'] ) ? $_GET['wc-helper-status'] : null;
- $notices = array();
+ $notices = array();
switch ( $return_status ) {
case 'activate-success':
$subscription = self::_get_subscriptions_from_product_id( absint( $_GET['wc-helper-product-id'] ) );
- $notices[] = array(
- 'type' => 'updated',
+ $notices[] = array(
+ 'type' => 'updated',
/* translators: %s: product name */
- 'message' => sprintf( __( '%s activated successfully. You will now receive updates for this product.', 'woocommerce' ),
- '
' . esc_html( $subscription['product_name'] ) . '' ),
+ 'message' => sprintf(
+ __( '%s activated successfully. You will now receive updates for this product.', 'woocommerce' ),
+ '
' . esc_html( $subscription['product_name'] ) . ''
+ ),
);
break;
case 'activate-error':
$subscription = self::_get_subscriptions_from_product_id( absint( $_GET['wc-helper-product-id'] ) );
- $notices[] = array(
- 'type' => 'error',
+ $notices[] = array(
+ 'type' => 'error',
/* translators: %s: product name */
- 'message' => sprintf( __( 'An error has occurred when activating %s. Please try again later.', 'woocommerce' ),
- '
' . esc_html( $subscription['product_name'] ) . '' ),
+ 'message' => sprintf(
+ __( 'An error has occurred when activating %s. Please try again later.', 'woocommerce' ),
+ '
' . esc_html( $subscription['product_name'] ) . ''
+ ),
);
break;
case 'deactivate-success':
$subscription = self::_get_subscriptions_from_product_id( absint( $_GET['wc-helper-product-id'] ) );
- $local = self::_get_local_from_product_id( absint( $_GET['wc-helper-product-id'] ) );
+ $local = self::_get_local_from_product_id( absint( $_GET['wc-helper-product-id'] ) );
/* translators: %s: product name */
- $message = sprintf( __( 'Subscription for %s deactivated successfully. You will no longer receive updates for this product.', 'woocommerce' ),
- '
' . esc_html( $subscription['product_name'] ) . '' );
+ $message = sprintf(
+ __( 'Subscription for %s deactivated successfully. You will no longer receive updates for this product.', 'woocommerce' ),
+ '
' . esc_html( $subscription['product_name'] ) . ''
+ );
if ( $local && is_plugin_active( $local['_filename'] ) && current_user_can( 'activate_plugins' ) ) {
- $deactivate_plugin_url = add_query_arg( array(
- 'page' => 'wc-addons',
- 'section' => 'helper',
- 'filter' => self::get_current_filter(),
- 'wc-helper-deactivate-plugin' => 1,
- 'wc-helper-product-id' => $subscription['product_id'],
- 'wc-helper-nonce' => wp_create_nonce( 'deactivate-plugin:' . $subscription['product_id'] ),
- ), admin_url( 'admin.php' ) );
+ $deactivate_plugin_url = add_query_arg(
+ array(
+ 'page' => 'wc-addons',
+ 'section' => 'helper',
+ 'filter' => self::get_current_filter(),
+ 'wc-helper-deactivate-plugin' => 1,
+ 'wc-helper-product-id' => $subscription['product_id'],
+ 'wc-helper-nonce' => wp_create_nonce( 'deactivate-plugin:' . $subscription['product_id'] ),
+ ), admin_url( 'admin.php' )
+ );
/* translators: %1$s: product name, %2$s: deactivate url */
- $message = sprintf( __( 'Subscription for %1$s deactivated successfully. You will no longer receive updates for this product.
Click here if you wish to deactivate the plugin as well.', 'woocommerce' ),
- '
' . esc_html( $subscription['product_name'] ) . '', esc_url( $deactivate_plugin_url ) );
+ $message = sprintf(
+ __( 'Subscription for %1$s deactivated successfully. You will no longer receive updates for this product.
Click here if you wish to deactivate the plugin as well.', 'woocommerce' ),
+ '
' . esc_html( $subscription['product_name'] ) . '', esc_url( $deactivate_plugin_url )
+ );
}
$notices[] = array(
'message' => $message,
- 'type' => 'updated',
+ 'type' => 'updated',
);
break;
case 'deactivate-error':
$subscription = self::_get_subscriptions_from_product_id( absint( $_GET['wc-helper-product-id'] ) );
- $notices[] = array(
- 'type' => 'error',
+ $notices[] = array(
+ 'type' => 'error',
/* translators: %s: product name */
- 'message' => sprintf( __( 'An error has occurred when deactivating the subscription for %s. Please try again later.', 'woocommerce' ),
- '
' . esc_html( $subscription['product_name'] ) . '' ),
+ 'message' => sprintf(
+ __( 'An error has occurred when deactivating the subscription for %s. Please try again later.', 'woocommerce' ),
+ '
' . esc_html( $subscription['product_name'] ) . ''
+ ),
);
break;
case 'deactivate-plugin-success':
$subscription = self::_get_subscriptions_from_product_id( absint( $_GET['wc-helper-product-id'] ) );
- $notices[] = array(
- 'type' => 'updated',
+ $notices[] = array(
+ 'type' => 'updated',
/* translators: %s: product name */
- 'message' => sprintf( __( 'The extension %s has been deactivated successfully.', 'woocommerce' ),
- '
' . esc_html( $subscription['product_name'] ) . '' ),
+ 'message' => sprintf(
+ __( 'The extension %s has been deactivated successfully.', 'woocommerce' ),
+ '
' . esc_html( $subscription['product_name'] ) . ''
+ ),
);
break;
case 'deactivate-plugin-error':
$subscription = self::_get_subscriptions_from_product_id( absint( $_GET['wc-helper-product-id'] ) );
- $notices[] = array(
- 'type' => 'error',
+ $notices[] = array(
+ 'type' => 'error',
/* translators: %1$s: product name, %2$s: plugins screen url */
- 'message' => sprintf( __( 'An error has occurred when deactivating the extension %1$s. Please proceed to the
Plugins screen to deactivate it manually.', 'woocommerce' ),
- '
' . esc_html( $subscription['product_name'] ) . '', admin_url( 'plugins.php' ) ),
+ 'message' => sprintf(
+ __( 'An error has occurred when deactivating the extension %1$s. Please proceed to the
Plugins screen to deactivate it manually.', 'woocommerce' ),
+ '
' . esc_html( $subscription['product_name'] ) . '', admin_url( 'plugins.php' )
+ ),
);
break;
case 'helper-connected':
$notices[] = array(
'message' => __( 'You have successfully connected your store to WooCommerce.com', 'woocommerce' ),
- 'type' => 'updated',
+ 'type' => 'updated',
);
break;
case 'helper-disconnected':
$notices[] = array(
'message' => __( 'You have successfully disconnected your store from WooCommerce.com', 'woocommerce' ),
- 'type' => 'updated',
+ 'type' => 'updated',
);
break;
case 'helper-refreshed':
$notices[] = array(
'message' => __( 'Authentication and subscription caches refreshed successfully.', 'woocommerce' ),
- 'type' => 'updated',
+ 'type' => 'updated',
);
break;
}
@@ -610,19 +636,23 @@ class WC_Helper {
wp_die( 'Could not verify nonce' );
}
- $redirect_uri = add_query_arg( array(
- 'page' => 'wc-addons',
- 'section' => 'helper',
- 'wc-helper-return' => 1,
- 'wc-helper-nonce' => wp_create_nonce( 'connect' ),
- ), admin_url( 'admin.php' ) );
+ $redirect_uri = add_query_arg(
+ array(
+ 'page' => 'wc-addons',
+ 'section' => 'helper',
+ 'wc-helper-return' => 1,
+ 'wc-helper-nonce' => wp_create_nonce( 'connect' ),
+ ), admin_url( 'admin.php' )
+ );
- $request = WC_Helper_API::post( 'oauth/request_token', array(
- 'body' => array(
- 'home_url' => home_url(),
- 'redirect_uri' => $redirect_uri,
- ),
- ) );
+ $request = WC_Helper_API::post(
+ 'oauth/request_token', array(
+ 'body' => array(
+ 'home_url' => home_url(),
+ 'redirect_uri' => $redirect_uri,
+ ),
+ )
+ );
$code = wp_remote_retrieve_response_code( $request );
@@ -637,11 +667,13 @@ class WC_Helper {
wp_die( 'Something went wrong' );
}
- $connect_url = add_query_arg( array(
- 'home_url' => rawurlencode( home_url() ),
- 'redirect_uri' => rawurlencode( $redirect_uri ),
- 'secret' => rawurlencode( $secret ),
- ), WC_Helper_API::url( 'oauth/authorize' ) );
+ $connect_url = add_query_arg(
+ array(
+ 'home_url' => rawurlencode( home_url() ),
+ 'redirect_uri' => rawurlencode( $redirect_uri ),
+ 'secret' => rawurlencode( $secret ),
+ ), WC_Helper_API::url( 'oauth/authorize' )
+ );
wp_redirect( esc_url_raw( $connect_url ) );
die();
@@ -669,12 +701,14 @@ class WC_Helper {
}
// Obtain an access token.
- $request = WC_Helper_API::post( 'oauth/access_token', array(
- 'body' => array(
- 'request_token' => $_GET['request_token'],
- 'home_url' => home_url(),
- ),
- ) );
+ $request = WC_Helper_API::post(
+ 'oauth/access_token', array(
+ 'body' => array(
+ 'request_token' => $_GET['request_token'],
+ 'home_url' => home_url(),
+ ),
+ )
+ );
$code = wp_remote_retrieve_response_code( $request );
@@ -689,13 +723,15 @@ class WC_Helper {
wp_die( 'Something went wrong' );
}
- WC_Helper_Options::update( 'auth', array(
- 'access_token' => $access_token['access_token'],
- 'access_token_secret' => $access_token['access_token_secret'],
- 'site_id' => $access_token['site_id'],
- 'user_id' => get_current_user_id(),
- 'updated' => time(),
- ) );
+ WC_Helper_Options::update(
+ 'auth', array(
+ 'access_token' => $access_token['access_token'],
+ 'access_token_secret' => $access_token['access_token_secret'],
+ 'site_id' => $access_token['site_id'],
+ 'user_id' => get_current_user_id(),
+ 'updated' => time(),
+ )
+ );
// Obtain the connected user info.
if ( ! self::_flush_authentication_cache() ) {
@@ -712,11 +748,15 @@ class WC_Helper {
WC_Tracker::send_tracking_data( true );
}
- wp_safe_redirect( add_query_arg( array(
- 'page' => 'wc-addons',
- 'section' => 'helper',
- 'wc-helper-status' => 'helper-connected',
- ), admin_url( 'admin.php' ) ) );
+ wp_safe_redirect(
+ add_query_arg(
+ array(
+ 'page' => 'wc-addons',
+ 'section' => 'helper',
+ 'wc-helper-status' => 'helper-connected',
+ ), admin_url( 'admin.php' )
+ )
+ );
die();
}
@@ -729,15 +769,19 @@ class WC_Helper {
wp_die( 'Could not verify nonce' );
}
- $redirect_uri = add_query_arg( array(
- 'page' => 'wc-addons',
- 'section' => 'helper',
- 'wc-helper-status' => 'helper-disconnected',
- ), admin_url( 'admin.php' ) );
+ $redirect_uri = add_query_arg(
+ array(
+ 'page' => 'wc-addons',
+ 'section' => 'helper',
+ 'wc-helper-status' => 'helper-disconnected',
+ ), admin_url( 'admin.php' )
+ );
- WC_Helper_API::post( 'oauth/invalidate_token', array(
- 'authenticated' => true,
- ) );
+ WC_Helper_API::post(
+ 'oauth/invalidate_token', array(
+ 'authenticated' => true,
+ )
+ );
WC_Helper_Options::update( 'auth', array() );
WC_Helper_Options::update( 'auth_user_data', array() );
@@ -761,12 +805,14 @@ class WC_Helper {
wp_die( 'Could not verify nonce' );
}
- $redirect_uri = add_query_arg( array(
- 'page' => 'wc-addons',
- 'section' => 'helper',
- 'filter' => self::get_current_filter(),
- 'wc-helper-status' => 'helper-refreshed',
- ), admin_url( 'admin.php' ) );
+ $redirect_uri = add_query_arg(
+ array(
+ 'page' => 'wc-addons',
+ 'section' => 'helper',
+ 'filter' => self::get_current_filter(),
+ 'wc-helper-status' => 'helper-refreshed',
+ ), admin_url( 'admin.php' )
+ );
self::_flush_authentication_cache();
self::_flush_subscriptions_cache();
@@ -781,22 +827,26 @@ class WC_Helper {
*/
private static function _helper_subscription_activate() {
$product_key = $_GET['wc-helper-product-key'];
- $product_id = absint( $_GET['wc-helper-product-id'] );
+ $product_id = absint( $_GET['wc-helper-product-id'] );
if ( empty( $_GET['wc-helper-nonce'] ) || ! wp_verify_nonce( $_GET['wc-helper-nonce'], 'activate:' . $product_key ) ) {
self::log( 'Could not verify nonce in _helper_subscription_activate' );
wp_die( 'Could not verify nonce' );
}
- $request = WC_Helper_API::post( 'activate', array(
- 'authenticated' => true,
- 'body' => json_encode( array(
- 'product_key' => $product_key,
- ) ),
- ) );
+ $request = WC_Helper_API::post(
+ 'activate', array(
+ 'authenticated' => true,
+ 'body' => json_encode(
+ array(
+ 'product_key' => $product_key,
+ )
+ ),
+ )
+ );
$activated = wp_remote_retrieve_response_code( $request ) === 200;
- $body = json_decode( wp_remote_retrieve_body( $request ), true );
+ $body = json_decode( wp_remote_retrieve_body( $request ), true );
if ( ! $activated && ! empty( $body['code'] ) && 'already_connected' == $body['code'] ) {
$activated = true;
}
@@ -808,13 +858,15 @@ class WC_Helper {
}
self::_flush_subscriptions_cache();
- $redirect_uri = add_query_arg( array(
- 'page' => 'wc-addons',
- 'section' => 'helper',
- 'filter' => self::get_current_filter(),
- 'wc-helper-status' => $activated ? 'activate-success' : 'activate-error',
- 'wc-helper-product-id' => $product_id,
- ), admin_url( 'admin.php' ) );
+ $redirect_uri = add_query_arg(
+ array(
+ 'page' => 'wc-addons',
+ 'section' => 'helper',
+ 'filter' => self::get_current_filter(),
+ 'wc-helper-status' => $activated ? 'activate-success' : 'activate-error',
+ 'wc-helper-product-id' => $product_id,
+ ), admin_url( 'admin.php' )
+ );
wp_safe_redirect( $redirect_uri );
die();
@@ -825,34 +877,40 @@ class WC_Helper {
*/
private static function _helper_subscription_deactivate() {
$product_key = $_GET['wc-helper-product-key'];
- $product_id = absint( $_GET['wc-helper-product-id'] );
+ $product_id = absint( $_GET['wc-helper-product-id'] );
if ( empty( $_GET['wc-helper-nonce'] ) || ! wp_verify_nonce( $_GET['wc-helper-nonce'], 'deactivate:' . $product_key ) ) {
self::log( 'Could not verify nonce in _helper_subscription_deactivate' );
wp_die( 'Could not verify nonce' );
}
- $request = WC_Helper_API::post( 'deactivate', array(
- 'authenticated' => true,
- 'body' => json_encode( array(
- 'product_key' => $product_key,
- ) ),
- ) );
+ $request = WC_Helper_API::post(
+ 'deactivate', array(
+ 'authenticated' => true,
+ 'body' => json_encode(
+ array(
+ 'product_key' => $product_key,
+ )
+ ),
+ )
+ );
- $code = wp_remote_retrieve_response_code( $request );
+ $code = wp_remote_retrieve_response_code( $request );
$deactivated = 200 === $code;
if ( ! $deactivated ) {
self::log( sprintf( 'Deactivate API call returned a non-200 response code (%d)', $code ) );
}
self::_flush_subscriptions_cache();
- $redirect_uri = add_query_arg( array(
- 'page' => 'wc-addons',
- 'section' => 'helper',
- 'filter' => self::get_current_filter(),
- 'wc-helper-status' => $deactivated ? 'deactivate-success' : 'deactivate-error',
- 'wc-helper-product-id' => $product_id,
- ), admin_url( 'admin.php' ) );
+ $redirect_uri = add_query_arg(
+ array(
+ 'page' => 'wc-addons',
+ 'section' => 'helper',
+ 'filter' => self::get_current_filter(),
+ 'wc-helper-status' => $deactivated ? 'deactivate-success' : 'deactivate-error',
+ 'wc-helper-product-id' => $product_id,
+ ), admin_url( 'admin.php' )
+ );
wp_safe_redirect( $redirect_uri );
die();
@@ -862,7 +920,7 @@ class WC_Helper {
* Deactivate a plugin.
*/
private static function _helper_plugin_deactivate() {
- $product_id = absint( $_GET['wc-helper-product-id'] );
+ $product_id = absint( $_GET['wc-helper-product-id'] );
$deactivated = false;
if ( empty( $_GET['wc-helper-nonce'] ) || ! wp_verify_nonce( $_GET['wc-helper-nonce'], 'deactivate-plugin:' . $product_id ) ) {
@@ -874,8 +932,12 @@ class WC_Helper {
wp_die( 'You are not allowed to manage plugins on this site.' );
}
- $local = wp_list_filter( array_merge( self::get_local_woo_plugins(),
- self::get_local_woo_themes() ), array( '_product_id' => $product_id ) );
+ $local = wp_list_filter(
+ array_merge(
+ self::get_local_woo_plugins(),
+ self::get_local_woo_themes()
+ ), array( '_product_id' => $product_id )
+ );
// Attempt to deactivate this plugin or theme.
if ( ! empty( $local ) ) {
@@ -887,13 +949,15 @@ class WC_Helper {
$deactivated = ! is_plugin_active( $local['_filename'] );
}
- $redirect_uri = add_query_arg( array(
- 'page' => 'wc-addons',
- 'section' => 'helper',
- 'filter' => self::get_current_filter(),
- 'wc-helper-status' => $deactivated ? 'deactivate-plugin-success' : 'deactivate-plugin-error',
- 'wc-helper-product-id' => $product_id,
- ), admin_url( 'admin.php' ) );
+ $redirect_uri = add_query_arg(
+ array(
+ 'page' => 'wc-addons',
+ 'section' => 'helper',
+ 'filter' => self::get_current_filter(),
+ 'wc-helper-status' => $deactivated ? 'deactivate-plugin-success' : 'deactivate-plugin-error',
+ 'wc-helper-product-id' => $product_id,
+ ), admin_url( 'admin.php' )
+ );
wp_safe_redirect( $redirect_uri );
die();
@@ -907,8 +971,12 @@ class WC_Helper {
* @return array|bool The array containing the local plugin/theme data or false.
*/
private static function _get_local_from_product_id( $product_id ) {
- $local = wp_list_filter( array_merge( self::get_local_woo_plugins(),
- self::get_local_woo_themes() ), array( '_product_id' => $product_id ) );
+ $local = wp_list_filter(
+ array_merge(
+ self::get_local_woo_plugins(),
+ self::get_local_woo_themes()
+ ), array( '_product_id' => $product_id )
+ );
if ( ! empty( $local ) ) {
return array_shift( $local );
@@ -923,7 +991,7 @@ class WC_Helper {
* first one in the list, so you can use this method to get things like extension
* name, version, etc.
*
- * @param int $product_id The product id.
+ * @param int $product_id The product id.
* @param bool $single Whether to return a single subscription or all matching a product id.
*
* @return array|bool The array containing sub data or false.
@@ -952,10 +1020,10 @@ class WC_Helper {
*/
public static function get_local_woo_plugins() {
if ( ! function_exists( 'get_plugins' ) ) {
- require_once( ABSPATH . 'wp-admin/includes/plugin.php' );
+ require_once ABSPATH . 'wp-admin/includes/plugin.php';
}
- $plugins = get_plugins();
+ $plugins = get_plugins();
$woo_plugins = array();
// Backwards compatibility for woothemes_queue_update().
@@ -964,7 +1032,7 @@ class WC_Helper {
foreach ( $GLOBALS['woothemes_queued_updates'] as $_compat_plugin ) {
$_compat[ $_compat_plugin->file ] = array(
'product_id' => $_compat_plugin->product_id,
- 'file_id' => $_compat_plugin->file_id,
+ 'file_id' => $_compat_plugin->file_id,
);
}
}
@@ -983,10 +1051,10 @@ class WC_Helper {
continue;
}
- $data['_filename'] = $filename;
- $data['_product_id'] = absint( $product_id );
- $data['_file_id'] = $file_id;
- $data['_type'] = 'plugin';
+ $data['_filename'] = $filename;
+ $data['_product_id'] = absint( $product_id );
+ $data['_file_id'] = $file_id;
+ $data['_type'] = 'plugin';
$woo_plugins[ $filename ] = $data;
}
@@ -997,7 +1065,7 @@ class WC_Helper {
* Get locally installed Woo themes.
*/
public static function get_local_woo_themes() {
- $themes = wp_get_themes();
+ $themes = wp_get_themes();
$woo_themes = array();
foreach ( $themes as $theme ) {
@@ -1008,7 +1076,7 @@ class WC_Helper {
$txt = $theme->get_stylesheet_directory() . '/theme_info.txt';
if ( is_readable( $txt ) ) {
$txt = file_get_contents( $txt );
- $txt = preg_split( "#\s#", $txt );
+ $txt = preg_split( '#\s#', $txt );
if ( count( $txt ) >= 2 ) {
$header = sprintf( '%d:%s', $txt[0], $txt[1] );
}
@@ -1025,15 +1093,15 @@ class WC_Helper {
}
$data = array(
- 'Name' => $theme->get( 'Name' ),
- 'Version' => $theme->get( 'Version' ),
- 'Woo' => $header,
+ 'Name' => $theme->get( 'Name' ),
+ 'Version' => $theme->get( 'Version' ),
+ 'Woo' => $header,
- '_filename' => $theme->get_stylesheet() . '/style.css',
+ '_filename' => $theme->get_stylesheet() . '/style.css',
'_stylesheet' => $theme->get_stylesheet(),
'_product_id' => absint( $product_id ),
- '_file_id' => $file_id,
- '_type' => 'theme',
+ '_file_id' => $file_id,
+ '_type' => 'theme',
);
$woo_themes[ $data['_filename'] ] = $data;
@@ -1054,9 +1122,11 @@ class WC_Helper {
}
// Obtain the connected user info.
- $request = WC_Helper_API::get( 'subscriptions', array(
- 'authenticated' => true,
- ) );
+ $request = WC_Helper_API::get(
+ 'subscriptions', array(
+ 'authenticated' => true,
+ )
+ );
if ( wp_remote_retrieve_response_code( $request ) !== 200 ) {
set_transient( $cache_key, array(), 15 * MINUTE_IN_SECONDS );
@@ -1095,7 +1165,7 @@ class WC_Helper {
return;
}
- $plugin = $plugins[ $filename ];
+ $plugin = $plugins[ $filename ];
$subscriptions = self::_get_subscriptions_from_product_id( $plugin['_product_id'], false );
// No valid subscriptions for this product
@@ -1126,15 +1196,19 @@ class WC_Helper {
return;
}
- $request = WC_Helper_API::post( 'activate', array(
- 'authenticated' => true,
- 'body' => json_encode( array(
- 'product_key' => $subscription['product_key'],
- ) ),
- ) );
+ $request = WC_Helper_API::post(
+ 'activate', array(
+ 'authenticated' => true,
+ 'body' => json_encode(
+ array(
+ 'product_key' => $subscription['product_key'],
+ )
+ ),
+ )
+ );
$activated = wp_remote_retrieve_response_code( $request ) === 200;
- $body = json_decode( wp_remote_retrieve_body( $request ), true );
+ $body = json_decode( wp_remote_retrieve_body( $request ), true );
if ( ! $activated && ! empty( $body['code'] ) && 'already_connected' == $body['code'] ) {
$activated = true;
}
@@ -1170,9 +1244,9 @@ class WC_Helper {
return;
}
- $plugin = $plugins[ $filename ];
+ $plugin = $plugins[ $filename ];
$subscriptions = self::_get_subscriptions_from_product_id( $plugin['_product_id'], false );
- $site_id = absint( $auth['site_id'] );
+ $site_id = absint( $auth['site_id'] );
// No valid subscriptions for this product
if ( empty( $subscriptions ) ) {
@@ -1187,12 +1261,16 @@ class WC_Helper {
continue;
}
- $request = WC_Helper_API::post( 'deactivate', array(
- 'authenticated' => true,
- 'body' => json_encode( array(
- 'product_key' => $subscription['product_key'],
- ) ),
- ) );
+ $request = WC_Helper_API::post(
+ 'deactivate', array(
+ 'authenticated' => true,
+ 'body' => json_encode(
+ array(
+ 'product_key' => $subscription['product_key'],
+ )
+ ),
+ )
+ );
if ( wp_remote_retrieve_response_code( $request ) === 200 ) {
$deactivated++;
@@ -1286,8 +1364,8 @@ class WC_Helper {
* @return string|null The update notice or null if everything is up to date.
*/
private static function _get_extensions_update_notice() {
- $plugins = self::get_local_woo_plugins();
- $updates = WC_Helper_Updater::get_update_data();
+ $plugins = self::get_local_woo_plugins();
+ $updates = WC_Helper_Updater::get_update_data();
$available = 0;
foreach ( $plugins as $data ) {
@@ -1306,8 +1384,10 @@ class WC_Helper {
}
/* translators: %1$s: helper url, %2$d: number of extensions */
- return sprintf( _n( 'Note: You currently have
%2$d paid extension which should be updated first before updating WooCommerce.', 'Note: You currently have
%2$d paid extensions which should be updated first before updating WooCommerce.', $available, 'woocommerce' ),
- admin_url( 'admin.php?page=wc-addons§ion=helper' ), $available );
+ return sprintf(
+ _n( 'Note: You currently have
%2$d paid extension which should be updated first before updating WooCommerce.', 'Note: You currently have
%2$d paid extensions which should be updated first before updating WooCommerce.', $available, 'woocommerce' ),
+ admin_url( 'admin.php?page=wc-addons§ion=helper' ), $available
+ );
}
/**
@@ -1346,9 +1426,11 @@ class WC_Helper {
* @access private
*/
public static function _flush_authentication_cache() {
- $request = WC_Helper_API::get( 'oauth/me', array(
- 'authenticated' => true,
- ) );
+ $request = WC_Helper_API::get(
+ 'oauth/me', array(
+ 'authenticated' => true,
+ )
+ );
if ( wp_remote_retrieve_response_code( $request ) !== 200 ) {
return false;
@@ -1359,10 +1441,12 @@ class WC_Helper {
return false;
}
- WC_Helper_Options::update( 'auth_user_data', array(
- 'name' => $user_data['name'],
- 'email' => $user_data['email'],
- ) );
+ WC_Helper_Options::update(
+ 'auth_user_data', array(
+ 'name' => $user_data['name'],
+ 'email' => $user_data['email'],
+ )
+ );
return true;
}
diff --git a/includes/admin/helper/views/html-main.php b/includes/admin/helper/views/html-main.php
index c3b87239090..3023a192b14 100644
--- a/includes/admin/helper/views/html-main.php
+++ b/includes/admin/helper/views/html-main.php
@@ -1,35 +1,35 @@
-
+
-
+
- $label ) : ?>
- $label ) :
+ // Don't show empty filters.
+ if ( empty( $counts[ $key ] ) ) {
+ continue;
+ }
- $url = admin_url( 'admin.php?page=wc-addons§ion=helper&filter=' . $key );
- $class_html = $current_filter === $key ? 'class="current"' : '';
+ $url = admin_url( 'admin.php?page=wc-addons§ion=helper&filter=' . $key );
+ $class_html = $current_filter === $key ? 'class="current"' : '';
?>
-
href="">
@@ -47,8 +47,9 @@