admin_url( 'admin-ajax.php' ), 'debug' => defined( 'WP_DEBUG' ) && WP_DEBUG || defined( 'SCRIPT_DEBUG' ) && SCRIPT_DEBUG, 'home_url' => home_url(), 'mobile_browser_theme_switch' => appp_get_setting( 'mobile_browser_theme_switch' ), 'admin_theme_switch' => appp_get_setting( 'admin_theme_switch' ), 'is_appp_true' => self::is_app(), ); // Load translations load_plugin_textdomain( 'apppresser', false, dirname( plugin_basename( __FILE__ ) ) . '/languages' ); // Setup our activation and deactivation hooks register_activation_hook( __FILE__, array( $this, 'activate' ) ); register_deactivation_hook( __FILE__, array( $this, 'deactivate' ) ); // Hook in all our important pieces add_action( 'plugins_loaded', array( $this, 'includes' ) ); add_action( 'wp_enqueue_scripts', array( $this, 'frontend_scripts' ), 8 ); add_action( 'wp_head', array( $this, 'do_appp_script' ), 1 ); // remove wp version param from cordova enqueued scripts (so script loading doesn't break) // This will mean that it's harder to break caching on the cordova script add_filter( 'script_loader_src', array( $this, 'remove_query_arg' ), 9999 ); require_once( self::$inc_path . 'AppPresser_Admin_Settings.php' ); require_once( self::$inc_path . 'plugin-updater.php' ); require_once( self::$inc_path . 'AppPresser_Theme_Customizer.php' ); require_once( self::$inc_path . 'AppPresser_Ajax_Extras.php' ); $this->theme_customizer = new AppPresser_Theme_Customizer(); } /** * Manually add some vars and our script tag so that we can head off the page if need be * @since 1.0.3 */ function do_appp_script() { // Only use minified files if SCRIPT_DEBUG is off $min = defined('SCRIPT_DEBUG') && SCRIPT_DEBUG ? '' : '.min'; // If PHP can read the cookie, we'll enqueue the standard way if ( is_user_logged_in() || self::is_app() ) { wp_enqueue_script( 'appp-core', self::$js_url ."appp$min.js", null, self::VERSION ); wp_localize_script( 'appp-core', 'apppCore', self::$l10n ); return; } if ( ! self::$l10n['mobile_browser_theme_switch'] && ! self::$l10n['admin_theme_switch'] ) return; // Otherwise we want to include the script ASAP to redirect the page if need be. foreach ( self::$l10n as $key => $value ) { $l10n[$key] = html_entity_decode( (string) $value, ENT_QUOTES, 'UTF-8'); } ?> theme_switcher = new AppPresser_Theme_Switcher(); } /** * Activation hook for the plugin. * @since 1.0.0 */ function activate() { // code to execute when plugin is activated // @TODO: Define default settings upon activation } /** * Frontend scripts and styles * @since 1.0.0 */ function frontend_scripts() { // Only use minified files if SCRIPT_DEBUG is off // $min = defined('SCRIPT_DEBUG') && SCRIPT_DEBUG ? '' : '.min'; // Enqueue cordova scripts if we have an app if ( self::is_app() ) { if ( appp_is_ios() ) { wp_enqueue_script( 'cordova-core', self::$pg_url .'ios/cordova.js', null, filemtime( self::$dir_path .'pg/' . self::$pg_version . '/ios/cordova_plugins.js' ) ); } elseif ( appp_is_android() ) { wp_enqueue_script( 'cordova-core', self::$pg_url .'android/cordova.js', null, filemtime( self::$dir_path .'pg/' . self::$pg_version . '/android/cordova_plugins.js' ) ); } } } /** * Deactivation hook for the plugin. * @since 1.0.0 */ function deactivate() { // code to execute when plugin is deactivated } /** * Strip query var from enqueued cordova script * @since 1.0.3 * @param string $src URL * @return string Modified URL */ function remove_query_arg( $src ) { if ( false !== strpos( $src, 'cordova.js' ) ) $src = remove_query_arg( 'ver', $src ); return $src; } /** * Utility method for getting our plugin's settings * @since 1.0.0 * @param string $key Optional key to get a specific option * @param string $fallback Fallback option if none is found. * @return mixed Array of all options, a specific option, or false if specific option not found. */ public static function settings( $key = false, $fallback = false ) { if ( self::$settings === 'false' ) { self::$settings = get_option( self::SETTINGS_NAME ); self::$settings = empty( self::$settings ) ? array() : (array) self::$settings; } if ( $key ) { $setting = isset( self::$settings[ $key ] ) ? self::$settings[ $key ] : false; // Override value or supply fallback $return = apply_filters( 'apppresser_setting_default', $setting, $key, self::$settings, $fallback ); return $return ? $return : $fallback; } return self::$settings; } /** * Checks if WP install is displaying the NEW WordPress style (previously the MP6 plugin) * @since 1.0.0 * @return boolean Whether admin has new style */ public static function is_mp6() { global $wp_version; return version_compare( $wp_version, '3.7.9', '>' ) || is_plugin_active( 'mp6/mp6.php' ); } /** * Gets the app_is_app variable * @since 1.0.0 * @return boolean Variable value */ public static function is_app() { if ( self::$is_app !== null ) return self::$is_app; self::$is_app = isset( $_GET['appp'] ) && $_GET['appp'] == 1 || isset( $_COOKIE['AppPresser_Appp'] ) && $_COOKIE['AppPresser_Appp'] === 'true'; return self::$is_app; } } // Singleton rather than a global.. If they want access, they can use: AppPresser::get(); /** * Function wrapper for AppPresser::settings() * @since 1.0.0 * @param string $key Optional key to get a specific option * @param string $fallback Fallback option if none is found. * @return mixed Array of all options, a specific option, or false if specific option not found. */ function appp_get_setting( $key = false, $fallback = false ) { return AppPresser::settings( $key, $fallback ); }