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' );
$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();
// Uncomment when we add back in the app panel
// require_once( self::$inc_path . 'body-class-meta-box.php' );
}
/**
* 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, self::VERSION );
} elseif ( appp_is_android() ) {
wp_enqueue_script( 'cordova-core', self::$pg_url .'android/cordova.js', null, self::VERSION );
}
}
}
/**
* 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 );
}