?php/**The file that defines the core plugin class A class definition that includes attributes and functions used across both the public-facing side of the site and the admin area. @link isvp.fr @since 1.0.0 @package Xcomm @subpackage Xcomm/includes */ /**The core plugin class. This is used to define internationalization, admin-specific hooks, and public-facing site hooks. Also maintains the unique identifier of this plugin as well as the current version of the plugin. @since 1.0.0 @package Xcomm @subpackage Xcomm/includes @author Vincent PERRIOT */ class Xcomm { /**The loader that's responsible for maintaining and registering all hooks that power the plugin. @since 1.0.0 @access protected @var Xcomm_Loader $loader Maintains and registers all hooks for the plugin. */ protected $loader; /**The unique identifier of this plugin. @since 1.0.0 @access protected @var string $plugin_name The string used to uniquely identify this plugin. */ protected $plugin_name; /**The current version of the plugin. @since 1.0.0 @access protected @var string $version The current version of the plugin. */ protected $version; /**Define the core functionality of the plugin. Set the plugin name and the plugin version that can be used throughout the plugin. Load the dependencies, define the locale, and set the hooks for the admin area and the public-facing side of the site. @since 1.0.0 */ public function __construct() { if (defined('XCOMM_VERSION')) { $this->version = XCOMM_VERSION; } else { $this->version = '1.0.0'; } $this->plugin_name = 'xcomm'; $this->load_dependencies(); $this->set_locale(); $this->define_admin_hooks(); $this->define_public_hooks(); #add_filter('woocommerce_product_data_store_cpt_get_products_query', 'handle_custom_query_var', 10, 2); } /**Load the required dependencies for this plugin. Include the following files that make up the plugin: Xcomm_Loader. Orchestrates the hooks of the plugin. Xcomm_i18n. Defines internationalization functionality. Xcomm_Admin. Defines all hooks for the admin area. Xcomm_Public. Defines all hooks for the public side of the site. Create an instance of the loader which will be used to register the hooks with WordPress. @since 1.0.0 @access private */ private function load_dependencies() { /**The class responsible for orchestrating the actions and filters of the core plugin. */ require_once plugin_dir_path(dirname(__FILE__)) . 'includes/class-xcomm-loader.php'; /**The class responsible for defining internationalization functionality of the plugin. */ require_once plugin_dir_path(dirname(__FILE__)) . 'includes/class-xcomm-i18n.php'; /**The class responsible for defining all actions that occur in the admin area. */ require_once plugin_dir_path(dirname(__FILE__)) . 'admin/class-xcomm-admin.php'; /**The class responsible for defining all actions that occur in the public-facing side of the site. */ require_once plugin_dir_path(dirname(__FILE__)) . 'public/class-xcomm-public.php'; $this->loader = new Xcomm_Loader(); } /**Define the locale for this plugin for internationalization. Uses the Xcomm_i18n class in order to set the domain and to register the hook with WordPress. @since 1.0.0 @access private */ private function set_locale() { $plugin_i18n = new Xcomm_i18n(); $this->loader->add_action('plugins_loaded', $plugin_i18n, 'load_plugin_textdomain'); } /**Register all of the hooks related to the admin area functionality of the plugin. @since 1.0.0 @access private */ private function define_admin_hooks() { $plugin_admin = new Xcomm_Admin($this->get_plugin_name(), $this->get_version()); $this->loader->add_action('admin_enqueue_scripts', $plugin_admin, 'enqueue_styles'); $this->loader->add_action('admin_enqueue_scripts', $plugin_admin, 'enqueue_scripts'); $this->loader->add_action( 'woocommerce_product_options_advanced', $plugin_admin, 'product_meta_xcommfield' ); $this->loader->add_action( 'woocommerce_process_product_meta', $plugin_admin, ' add_custom_product_xcomm_field_save' ); $this->loader->add_action('woocommerce_variation_options_pricing', $plugin_admin, 'variations_meta_xcommfield', 10, 3); $this->loader->add_action('woocommerce_save_product_variation', $plugin_admin, 'add_custom_variation_xcomm_field_save', 10, 2); #$this->loader->add_filter('woocommerce_available_variation', $plugin_admin, 'load_custom_variation_xcomm_settings_fields'); $this->loader->add_action('woocommerce_order_status_completed', $plugin_admin, 'xcomm_sendSale'); //META SEARCH $this->loader->add_filter('parse_query', $plugin_admin, 'ba_admin_posts_filter'); $this->loader->add_action('restrict_manage_posts', $plugin_admin, 'ba_admin_posts_filter_restrict_manage_posts'); } /**Register all of the hooks related to the public-facing functionality of the plugin. @since 1.0.0 @access private */ private function define_public_hooks() { $plugin_public = new Xcomm_Public($this->get_plugin_name(), $this->get_version()); $this->loader->add_action('wp_enqueue_scripts', $plugin_public, 'enqueue_styles'); $this->loader->add_action('wp_enqueue_scripts', $plugin_public, 'enqueue_scripts'); $this->loader->add_filter('woocommerce_rest_products_query', $plugin_public, 'filter_xcomm_ref', 10, 2); #$this->loader->add_filter('woocommerce_product_data_store_cpt_get_products_query', $plugin_public, 'handle_custom_query_var', 10, 2); $this->loader->add_action('post_action_xcommTest', $plugin_public, 'xcomm_processTest'); $this->loader->add_action('admin_post_nopriv_xcommCatalog', $plugin_public, 'xcomm_processCatalog'); $this->loader->add_action('woocommerce_order_status_completed', $plugin_public, 'xcomm_sendSale'); $this->loader->add_action('rest_api_init', $plugin_public, 'xcomm_processApi'); } /**Run the loader to execute all of the hooks with WordPress. @since 1.0.0 */ public function run() { $this->loader->run(); } /**The name of the plugin used to uniquely identify it within the context of WordPress and to define internationalization functionality. @since 1.0.0 @return string The name of the plugin. */ public function get_plugin_name() { return $this->plugin_name; } /**The reference to the class that orchestrates the hooks with the plugin. @since 1.0.0 @return Xcomm_Loader Orchestrates the hooks of the plugin. */ public function get_loader() { return $this->loader; } /**Retrieve the version number of the plugin. @since 1.0.0 @return string The version number of the plugin. */ public function get_version() { return $this->version; } }