*/ class Alcud { /** * The loader that's responsible for maintaining and registering all hooks that power * the plugin. * * @since 1.0.0 * @access protected * @var Plugin_Name_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 Dashboard and * the public-facing side of the site. * * @since 1.0.0 */ public function __construct() { $this->plugin_name = 'alcud'; $this->version = '1.0.0'; $this->load_dependencies(); $this->set_locale(); $this->define_admin_hooks(); $this->define_public_hooks(); add_shortcode( 'alcud', array( $this, 'alcud_handler' ) ); } /** * Load the required dependencies for this plugin. * * Include the following files that make up the plugin: * * - Plugin_Name_Loader. Orchestrates the hooks of the plugin. * - Plugin_Name_i18n. Defines internationalization functionality. * - Plugin_Name_Admin. Defines all hooks for the dashboard. * - Plugin_Name_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-alcud-loader.php'; /** * The class responsible for defining internationalization functionality * of the plugin. */ require_once plugin_dir_path( dirname( __FILE__ ) ) . 'includes/class-alcud-i18n.php'; /** * The class responsible for defining all actions that occur in the Dashboard. */ require_once plugin_dir_path( dirname( __FILE__ ) ) . 'admin/class-alcud-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-alcud-public.php'; $this->loader = new Alcud_Loader(); } /** * Define the locale for this plugin for internationalization. * * Uses the Plugin_Name_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 Alcud_i18n(); $plugin_i18n->set_domain( $this->get_plugin_name() ); $this->loader->add_action( 'plugins_loaded', $plugin_i18n, 'load_plugin_textdomain' ); } /** * Register all of the hooks related to the dashboard functionality * of the plugin. * * @since 1.0.0 * @access private */ private function define_admin_hooks() { $plugin_admin = new Alcud_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' ); // loading admin menu hooks $this->loader->add_action( 'admin_menu', $plugin_admin, 'add_plugin_admin_menu' ); $this->loader->add_action( 'wp_ajax_add_details', $plugin_admin, 'action_add_details' ); $this->loader->add_action( 'wp_ajax_select_widget', $plugin_admin, 'action_select_widget' ); } /** * 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 Alcud_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' ); } /** * 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 Plugin_Name_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; } public function alcud_handler( $atts ){ $a = shortcode_atts( array( 'design' => '', 'title' => '' ), $atts ); $images = plugin_dir_path( dirname( __FILE__ ) ) . 'shortcodes/images'; global $wpdb; $table_name = $wpdb->prefix . "alcud"; $detail = $wpdb->get_row( "SELECT * FROM $table_name WHERE id = 1"); $business_name = ""; $contact_person = ""; $email_address = ""; $contact_number = ""; $address = ""; $open_hours = ""; $note = ""; if($detail){ $business_name = $detail->business_name; $contact_person = $detail->contact_person; $email_address = $detail->email_address; $contact_number = $detail->contact_number; $address = $detail->address; $open_hours = $detail->open_hours; $note = $detail->note; } $alcud_string = ""; // TODO: Here is where you manipulate your widget's values based on their input fields if($a['design'] == "simple"){ $title = $a['title']; $alcud_string .= "
"; ob_start(); include( plugin_dir_path( dirname( __FILE__ ) ) . 'shortcodes/alcud-shortcodes.php' ); $alcud_string .= ob_get_clean(); $alcud_string .= "
"; } if($a['design'] == "flat"){ $alcud_string .= "
"; ob_start(); include( plugin_dir_path( dirname( __FILE__ ) ) . 'shortcodes/alcud-shortcode-flat.php' ); $alcud_string .= ob_get_clean(); $alcud_string .= "
"; } return $alcud_string; } }