<?php
/**
* Astra Sites Compatibility for 'WooCommerce'
*
* @see https://wordpress.org/plugins/woocommerce/
*
* @package Astra Sites
* @since 1.1.4
*/
if ( ! class_exists( 'Astra_Sites_Compatibility_WooCommerce' ) ) :
/**
* WooCommerce Compatibility
*
* @since 1.1.4
*/
class Astra_Sites_Compatibility_WooCommerce {
/**
* Instance
*
* @access private
* @var object Class object.
* @since 1.1.4
*/
private static $instance;
/**
* Initiator
*
* @since 1.1.4
* @return object initialized object of class.
*/
public static function instance() {
if ( ! isset( self::$instance ) ) {
self::$instance = new self();
}
return self::$instance;
}
/**
* Constructor
*
* @since 1.1.4
*/
public function __construct() {
add_action( 'astra_sites_import_start', array( $this, 'add_attributes' ), 10, 2 );
add_action( 'astra_sites_after_plugin_activation', array( $this, 'install_wc' ), 10, 2 );
// WooCommerce product attributes registration.
if ( class_exists( 'WooCommerce' ) ) {
add_filter( 'wxr_importer.pre_process.term', array( $this, 'woocommerce_product_attributes_registration' ), 10, 1 );
add_action( 'astra_sites_import_complete', array( $this, 'update_wc_lookup_table' ) );
}
}
/**
* Add product attributes.
*
* @since 1.1.4
*
* @param string $demo_data Import data.
* @param array $demo_api_uri Demo site URL.
* @return void
*/
public function add_attributes( $demo_data = array(), $demo_api_uri = '' ) {
$attributes = ( isset( $demo_data['astra-site-options-data']['woocommerce_product_attributes'] ) ) ? $demo_data['astra-site-options-data']['woocommerce_product_attributes'] : array();
if ( ! empty( $attributes ) && function_exists( 'wc_create_attribute' ) ) {
foreach ( $attributes as $key => $attribute ) {
$args = array(
'name' => $attribute['attribute_label'],
'slug' => $attribute['attribute_name'],
'type' => $attribute['attribute_type'],
'order_by' => $attribute['attribute_orderby'],
'has_archives' => $attribute['attribute_public'],
);
$id = wc_create_attribute( $args );
}
}
}
/**
* Create default WooCommerce tables
*
* @param string $plugin_init Plugin file which is activated.
* @return void
*/
public function install_wc( $plugin_init ) {
if ( 'woocommerce/woocommerce.php' !== $plugin_init ) {
return;
}
// Create WooCommerce database tables.
if ( is_callable( '\Automattic\WooCommerce\Admin\Install::create_tables' ) ) {
\Automattic\WooCommerce\Admin\Install::create_tables();
\Automattic\WooCommerce\Admin\Install::create_events();
}
if ( is_callable( 'WC_Install::install' ) ) {
WC_Install::install();
}
}
/**
* Hook into the pre-process term filter of the content import and register the
* custom WooCommerce product attributes, so that the terms can then be imported normally.
*
* This should probably be removed once the WP importer 2.0 support is added in WooCommerce.
*
* Fixes: [WARNING] Failed to import pa_size L warnings in content import.
* Code from: woocommerce/includes/admin/class-wc-admin-importers.php (ver 2.6.9).
*
* Github issue: https://github.com/proteusthemes/one-click-demo-import/issues/71
*
* @since 3.0.0
* @param array $data The term data to import.
* @return array The unchanged term data.
*/
public function woocommerce_product_attributes_registration( $data ) {
global $wpdb;
if ( strstr( $data['taxonomy'], 'pa_' ) ) {
if ( ! taxonomy_exists( $data['taxonomy'] ) ) {
$attribute_name = wc_sanitize_taxonomy_name( str_replace( 'pa_', '', $data['taxonomy'] ) );
// Create the taxonomy.
if ( ! in_array( $attribute_name, wc_get_attribute_taxonomies(), true ) ) {
$attribute = array(
'attribute_label' => $attribute_name,
'attribute_name' => $attribute_name,
'attribute_type' => 'select',
'attribute_orderby' => 'menu_order',
'attribute_public' => 0,
);
$wpdb->insert( $wpdb->prefix . 'woocommerce_attribute_taxonomies', $attribute );
delete_transient( 'wc_attribute_taxonomies' );
}
// Register the taxonomy now so that the import works!
register_taxonomy(
$data['taxonomy'],
apply_filters( 'woocommerce_taxonomy_objects_' . $data['taxonomy'], array( 'product' ) ),
apply_filters(
'woocommerce_taxonomy_args_' . $data['taxonomy'], array(
'hierarchical' => true,
'show_ui' => false,
'query_var' => true,
'rewrite' => false,
)
)
);
}
}
return $data;
}
/**
* Update WooCommerce Lookup Table.
*
* @since 3.0.0
*
* @return void
*/
public function update_wc_lookup_table() {
if ( function_exists( 'wc_update_product_lookup_tables' ) ) {
if ( ! wc_update_product_lookup_tables_is_running() ) {
wc_update_product_lookup_tables();
}
}
}
}
/**
* Kicking this off by calling 'instance()' method
*/
Astra_Sites_Compatibility_WooCommerce::instance();
endif;