plugin_name = 'amp-customizer'; $this->version = '1.0.0'; $this->load_dependencies(); $this->set_locale(); $this->define_admin_hooks(); $this->define_public_hooks(); } /** * Load the required dependencies for this plugin. * * Include the following files that make up the plugin: * * - Amp_Customizer_Loader. Orchestrates the hooks of the plugin. * - Amp_Customizer_i18n. Defines internationalization functionality. * - Amp_Customizer_Admin. Defines all hooks for the admin area. * - Amp_Customizer_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-amp-customizer-loader.php'; /** * The class responsible for defining internationalization functionality * of the plugin. */ require_once plugin_dir_path( dirname( __FILE__ ) ) . 'includes/class-amp-customizer-i18n.php'; /** * The class responsible for defining all actions that occur in the admin area. */ require_once plugin_dir_path( dirname( __FILE__ ) ) . 'admin/class-amp-customizer-admin.php'; /** * The class responsible for defining all actions that occur in the admin posts area. */ require_once plugin_dir_path( dirname( __FILE__ ) ) . 'admin/class-amp-customizer-admin-posts.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-amp-customizer-public.php'; $this->loader = new Amp_Customizer_Loader(); } /** * Define the locale for this plugin for internationalization. * * Uses the Amp_Customizer_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 Amp_Customizer_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 Amp_Customizer_Admin( $this->get_plugin_name(), $this->get_version() ); $plugin_admin_posts = new Amp_Customizer_Admin_Posts( $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( 'admin_menu', $plugin_admin, 'amp_add_options_page' ); $this->loader->add_action( 'admin_init', $plugin_admin, 'amp_register_settings' ); $this->loader->add_action( 'add_meta_boxes', $plugin_admin_posts, 'amp_register_meta_boxes' ); $this->loader->add_action( 'save_post', $plugin_admin_posts, 'amp_save_post_meta', 10, 2 ); $this->loader->add_action( 'amp_post_template_head', $plugin_admin_posts, 'amp_redirect_to_original_on_hide' ); $this->loader->add_filter( 'amp_frontend_show_canonical', $plugin_admin_posts, 'amp_remove_canonical' ); } /** * 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 Amp_Customizer_Public( $this->get_plugin_name(), $this->get_version() ); $this->loader->add_action( 'pre_amp_render_post', $plugin_public, 'check_settings_callbacks' ); $this->loader->add_action( 'amp_post_template_css', $plugin_public, 'custom_css_styles' ); } /** * 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 Amp_Customizer_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; } }