| Current Path : /home/x/b/o/xbodynamge/namtation/wp-content/ |
| Current File : /home/x/b/o/xbodynamge/namtation/wp-content/app.tar |
class-orbit-fox-public.php 0000666 00000004377 15113402757 0011571 0 ustar 00 <?php
/**
* The public-specific functionality of the plugin.
*
* @link https://themeisle.com
* @since 1.0.0
*
* @package Orbit_Fox
* @subpackage Orbit_Fox/app
*/
/**
* The public-specific functionality of the plugin.
*
* Defines the plugin name, version, and two examples hooks for how to
* enqueue the public-specific stylesheet and JavaScript.
*
* @package Orbit_Fox
* @subpackage Orbit_Fox/app
* @author Themeisle <friends@themeisle.com>
*/
class Orbit_Fox_Public {
/**
* The ID of this plugin.
*
* @since 1.0.0
* @access private
* @var string $plugin_name The ID of this plugin.
*/
private $plugin_name;
/**
* The version of this plugin.
*
* @since 1.0.0
* @access private
* @var string $version The current version of this plugin.
*/
private $version;
/**
* Initialize the class and set its properties.
*
* @since 1.0.0
* @param string $plugin_name The name of this plugin.
* @param string $version The version of this plugin.
*/
public function __construct( $plugin_name, $version ) {
$this->plugin_name = $plugin_name;
$this->version = $version;
}
/**
* Register the stylesheets for the admin area.
*
* @since 1.0.0
*/
public function enqueue_styles() {
/**
* This function is provided for demonstration purposes only.
*
* An instance of this class should be passed to the run() function
* defined in Orbit_Fox_Loader as all of the hooks are defined
* in that particular class.
*
* The Orbit_Fox_Loader will then create the relationship
* between the defined hooks and the functions defined in this
* class.
*/
do_action( 'obfx_public_enqueue_styles' );
}
/**
* Register the JavaScript for the public area.
*
* @since 1.0.0
*/
public function enqueue_scripts() {
/**
* This function is provided for demonstration purposes only.
*
* An instance of this class should be passed to the run() function
* defined in Orbit_Fox_Loader as all of the hooks are defined
* in that particular class.
*
* The Orbit_Fox_Loader will then create the relationship
* between the defined hooks and the functions defined in this
* class.
*/
do_action( 'obfx_public_enqueue_scripts' );
}
}
class-orbit-fox-module-factory.php 0000666 00000001742 15113402757 0013236 0 ustar 00 <?php
/**
* The factory logic for creating modules for plugin.
*
* @link https://themeisle.com
* @since 1.0.0
*
* @package Orbit_Fox
* @subpackage Orbit_Fox/app
*/
/**
* The class responsible for instantiating new OBFX_Module classes.
*
* @package Orbit_Fox
* @subpackage Orbit_Fox/app
* @author Themeisle <friends@themeisle.com>
*/
class Orbit_Fox_Module_Factory {
/**
* The build method for creating a new OBFX_Module class.
*
* @since 1.0.0
* @access public
* @param string $module_name The name of the module to instantiate.
* @return mixed
* @throws Exception Thrown if no module class exists for provided $module_name.
*/
public static function build( $module_name ) {
$module = str_replace( '-', '_', ucwords( $module_name ) ) . '_OBFX_Module';
if ( class_exists( $module ) ) {
return new $module;
}
// @codeCoverageIgnoreStart
throw new Exception( 'Invalid module name given.' );
// @codeCoverageIgnoreEnd
}
}
class-orbit-fox-admin.php 0000666 00000041471 15113402757 0011377 0 ustar 00 <?php
/**
* The admin-specific functionality of the plugin.
*
* @link https://themeisle.com
* @since 1.0.0
*
* @package Orbit_Fox
* @subpackage Orbit_Fox/app
*/
/**
* The admin-specific functionality of the plugin.
*
* Defines the plugin name, version, and two examples hooks for how to
* enqueue the admin-specific stylesheet and JavaScript.
*
* @package Orbit_Fox
* @subpackage Orbit_Fox/app
* @author Themeisle <friends@themeisle.com>
*/
class Orbit_Fox_Admin {
/**
* The ID of this plugin.
*
* @since 1.0.0
* @access private
* @var string $plugin_name The ID of this plugin.
*/
private $plugin_name;
/**
* The version of this plugin.
*
* @since 1.0.0
* @access private
* @var string $version The current version of this plugin.
*/
private $version;
/**
* Initialize the class and set its properties.
*
* @since 1.0.0
*
* @param string $plugin_name The name of this plugin.
* @param string $version The version of this plugin.
*/
public function __construct( $plugin_name, $version ) {
$this->plugin_name = $plugin_name;
$this->version = $version;
}
/**
* Register the stylesheets for the admin area.
*
* @since 1.0.0
*/
public function enqueue_styles() {
/**
* This function is provided for demonstration purposes only.
*
* An instance of this class should be passed to the run() function
* defined in Orbit_Fox_Loader as all of the hooks are defined
* in that particular class.
*
* The Orbit_Fox_Loader will then create the relationship
* between the defined hooks and the functions defined in this
* class.
*/
$screen = get_current_screen();
if ( empty( $screen ) ) {
return;
}
if ( in_array( $screen->id, array( 'toplevel_page_obfx_companion' ) ) ) {
wp_enqueue_style( $this->plugin_name, plugin_dir_url( __FILE__ ) . '../assets/css/orbit-fox-admin.css', array(), $this->version, 'all' );
}
do_action( 'obfx_admin_enqueue_styles' );
}
/**
* Register the JavaScript for the admin area.
*
* @since 1.0.0
*/
public function enqueue_scripts() {
/**
* This function is provided for demonstration purposes only.
*
* An instance of this class should be passed to the run() function
* defined in Orbit_Fox_Loader as all of the hooks are defined
* in that particular class.
*
* The Orbit_Fox_Loader will then create the relationship
* between the defined hooks and the functions defined in this
* class.
*/
$screen = get_current_screen();
if ( empty( $screen ) ) {
return;
}
if ( in_array( $screen->id, array( 'toplevel_page_obfx_companion' ) ) ) {
wp_enqueue_script( $this->plugin_name, plugin_dir_url( __FILE__ ) . '../assets/js/orbit-fox-admin.js', array( 'jquery' ), $this->version, false );
}
do_action( 'obfx_admin_enqueue_scripts' );
}
/**
* Add admin menu items for orbit-fox.
*
* @since 1.0.0
* @access public
*/
public function menu_pages() {
add_menu_page(
__( 'Orbit Fox', 'themeisle-companion' ),
__( 'Orbit Fox', 'themeisle-companion' ),
'manage_options',
'obfx_companion',
array(
$this,
'page_modules_render',
),
'data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSI0MzQuNjIiIGhlaWdodD0iMzkxLjMzIiB2aWV3Qm94PSIwIDAgNDM0LjYyIDM5MS4zMyI+PGRlZnM+PHN0eWxlPi5he2ZpbGw6I2ZmZjt9PC9zdHlsZT48L2RlZnM+PHRpdGxlPmxvZ28tb3JiaXQtZm94LTI8L3RpdGxlPjxwYXRoIGNsYXNzPSJhIiBkPSJNNzA4LjE1LDM5NS4yM2gwYy0xLjQ5LTEzLjc2LTcuNjEtMjkuMjEtMTUuOTQtNDQuNzZsLTE0LjQ2LDguMzVhNzYsNzYsMCwxLDEtMTQ1LDQyLjd2MUg0OTEuMWE3Niw3NiwwLDEsMS0xNDQuODYtNDMuNjVsLTE0LjQyLTguMzNjLTguMTcsMTUuMjgtMTQuMjIsMzAuNDctMTUuODMsNDQtLjA2LjM3LS4xMS43NS0uMTQsMS4xMnMtLjA2LjQ2LS4wOC42OGguMDVBMTUuNTcsMTUuNTcsMCwwLDAsMzIwLjM1LDQwOEw1MDEsNTU1LjExYTE1LjU0LDE1LjU0LDAsMCwwLDExLDQuNTVoMGExNS41NCwxNS41NCwwLDAsMCwxMS00LjU1TDcwMy42OSw0MDhBMTUuNjMsMTUuNjMsMCwwLDAsNzA4LjE1LDM5NS4yM1pNNDc5LjU5LDQ0MC41MWwyMi4wNSw1LjkxLTIuMDcsNy43My0yMi4wNS01LjkxWm0zLDE4Ljc1LDIyLjA1LDUuOTEtMi4wNyw3LjczTDQ4MC41Miw0NjdabTEsMTguNzUsMjIuMDUsNS45MS0yLjA3LDcuNzMtMjIuMDUtNS45MVptMzEsNjMuMzhhMTIuMzgsMTIuMzgsMCwwLDAtMSwuOTEsMi4yMSwyLjIxLDAsMCwxLTEuNTguNjNoMGEyLjIxLDIuMjEsMCwwLDEtMS41OC0uNjMsMTIuMzgsMTIuMzgsMCwwLDAtMS0uOTFMNDg2Ljg5LDUyM2M4LjItLjUzLDE2LjYzLS44MSwyNS4xMS0uODFzMTYuOTMuMjgsMjUuMTUuODFabTUuODktNDkuNzQtMi4wNy03LjczTDU0MC40OSw0NzhsMi4wNyw3LjczWm0xLTE4Ljc1LTIuMDctNy43MywyMi4wNi01LjkxLDIuMDcsNy43M1ptMy0xOC43NS0yLjA3LTcuNzMsMjIuMDYtNS45MSwyLjA3LDcuNzNaIiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgtMjk0LjY5IC0xNjguMzQpIi8+PHBhdGggY2xhc3M9ImEiIGQ9Ik03MjkuMjYsMjA5YTEyMC4xOCwxMjAuMTgsMCwwLDAtMS4xOC0xNC43OGMtLjEzLS44OC0uMjctMS43Mi0uNDItMi41Ni0uMjItMS4yLS40Ni0yLjM1LS43Mi0zLjQ3LS4xOC0uNzktLjM4LTEuNTctLjU4LTIuMzItLjM2LTEuMjgtLjc0LTIuNDgtMS4xNi0zLjYyLS4zNi0uOTUtLjc0LTEuODUtMS4xNS0yLjctLjItLjQzLS40MS0uODQtLjYzLTEuMjRzLS40My0uNzktLjY1LTEuMTVhMTkuNzYsMTkuNzYsMCwwLDAtMS4xNS0xLjY4LDE0LjE5LDE0LjE5LDAsMCwwLTEuMTUtMS4zNiwxMS44NywxMS44NywwLDAsMC0xLS45MWMtLjExLS4xLS4yNS0uMTgtLjM3LS4yN2ExNS4yMSwxNS4yMSwwLDAsMC0yLjU0LTEuNTlsLTEuMDYtLjQ5YTI1LjU3LDI1LjU3LDAsMCwwLTMuODUtMS4yNWMtLjc0LS4xOC0xLjUyLS4zNS0yLjMzLS40OS0xLjExLS4xOS0yLjI4LS4zNS0zLjUtLjQ3cy0yLjY5LS4yMS00LjExLS4yNWMtMi4xNC0uMDctNC4zOSwwLTYuNzMuMDktMS41Ny4wOC0zLjE4LjItNC44Mi4zNmwtMi44MS4zYTE3MSwxNzEsMCwwLDAtMTgsMy4xN2wtMy4xMi43NHEtNC44NywxLjItOS43OSwyLjY0Yy0zLjI3LDEtNi41NCwyLTkuNzcsMy4xMXEtNS4yNCwxLjc4LTEwLjMsNGMtLjg1LjM3LTEuNjkuNzUtMi41MywxLjE0cS0zLjc4LDEuNzYtNy40OCwzLjc4YTE0Mi4zNywxNDIuMzcsMCwwLDAtMTIuOCw3Ljg4Yy0xLjQsMS0yLjgxLDItNC4yLDNhMjAxLjUzLDIwMS41MywwLDAsMC0yMy43LDIwLjc3Yy0yMC4zNy0xNC00Mi4zLTIwLTczLjctMjAuNDZ2MS43N2gwdi0xLjc3Yy0zMS40MS41LTUzLjM1LDYuNDQtNzMuNzIsMjAuNDctMTkuODQtMjAuMS0zOS4yNi0zMy4xNi02MS00MC42LTI5LjU2LTEwLjExLTYyLTE0LjU5LTcyLjc2LTUuNnMtMTEuOTUsNDEuNzYtNy4xMyw3Mi42M2M0LjU1LDI5LjEsMTguODMsNTYsNDQuNzgsODdsMCwuMDYsMTQuNDgsOC4zNkE3Niw3NiwwLDAsMSw0OTIuMjIsMzgyaDM5LjU2QTc2LDc2LDAsMCwxLDY2Ny40LDM0MS4xOWwxNC41Mi04LjM5LDAtLjA3cTMuNTctNC4yNiw2Ljg0LTguNDNjMS41LTEuODksMi45NC0zLjc3LDQuMzQtNS42NHMyLjc2LTMuNzMsNC4wNy01LjU3Yy42Ni0uOTIsMS4zLTEuODQsMS45NC0yLjc2cTEuOS0yLjc2LDMuNjctNS40OCwyLjY3LTQuMSw1LTguMTN0NC40NS04LjA1Yy45Mi0xLjc4LDEuODEtMy41NiwyLjY1LTUuMzRxMS44OS00LDMuNTEtOGMuNzItMS43OCwxLjM5LTMuNTUsMi01LjMzLjMyLS44OC42My0xLjc3LjkzLTIuNjYuNi0xLjc4LDEuMTUtMy41NiwxLjY3LTUuMzRhMTMxLjU0LDEzMS41NCwwLDAsMCwzLjYxLTE2LjIxLDIyMS4yNCwyMjEuMjQsMCwwLDAsMi42OC0zMS40NkM3MjkuMzIsMjEyLjUyLDcyOS4zMSwyMTAuNzMsNzI5LjI2LDIwOVpNMzg5LjMxLDI2OC43OWMtOS4yOSwxMS41OC0yMi4zNywyNy43Ni0zNC45NCw0NS42Ni0xMS42NC0xNi45Mi0yNC43Ni0zOC42MS0yNy40OS01Ny42NS0zLjEzLTIxLjg2LTEuOTQtMzcuNTktLjA3LTQzLjQ4YTMyLjY1LDMyLjY1LDAsMCwxLDQuMjktLjI1YzkuODYsMCwyNC4yOCwyLjkyLDM4LjU5LDcuODEsMTMuNTMsNC42MywyNi4xNSwxMi41NiwzOS4yNiwyNC44NUM0MDIuNjgsMjUyLjU0LDM5Ni4yMSwyNjAuMTksMzg5LjMxLDI2OC43OVptMzA3LjgxLTEyYy0yLjczLDE5LTE1LjgzLDQwLjctMjcuNDYsNTcuNjEtMTIuNTctMTcuODgtMjUuNjQtMzQuMDUtMzQuOTMtNDUuNjItNi45MS04LjYxLTEzLjM4LTE2LjI2LTE5LjY2LTIzLjA4LDEzLjExLTEyLjI4LDI1LjcyLTIwLjIsMzkuMjQtMjQuODMsMTQuMzEtNC44OSwyOC43My03LjgxLDM4LjU5LTcuODFhMzIuNjUsMzIuNjUsMCwwLDEsNC4yOS4yNUM2OTkuMDYsMjE5LjIxLDcwMC4yNSwyMzQuOTQsNjk3LjEyLDI1Ni44WiIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoLTI5NC42OSAtMTY4LjM0KSIvPjxwYXRoIGNsYXNzPSJhIiBkPSJNNDE2LjQ0LDMzMS41N0E1Ni41MSw1Ni41MSwwLDEsMCw0NzMsMzg4LjA4LDU2LjU3LDU2LjU3LDAsMCwwLDQxNi40NCwzMzEuNTdabTMxLjYyLDg2LjM2YTIzLjQ0LDIzLjQ0LDAsMSwxLDUtNy4zOCw5LjI1LDkuMjUsMCwwLDEtMS43OSwzLjM5QTIyLjcxLDIyLjcxLDAsMCwxLDQ0OC4wNiw0MTcuOTNaIiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgtMjk0LjY5IC0xNjguMzQpIi8+PHBhdGggY2xhc3M9ImEiIGQ9Ik02MDcuNTYsMzMxLjU3YTU2LjUxLDU2LjUxLDAsMSwwLDU2LjUxLDU2LjUxQTU2LjU3LDU2LjU3LDAsMCwwLDYwNy41NiwzMzEuNTdabTEuNTMsODYuMzZhMjMuNDIsMjMuNDIsMCwwLDEtMzMuMTMsMCwyMy4xOCwyMy4xOCwwLDAsMS0zLjE5LTQsOS4wOCw5LjA4LDAsMCwxLTEuNzgtMy4zOSwyMy40MiwyMy40MiwwLDEsMSwzOC4xLDcuMzhaIiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgtMjk0LjY5IC0xNjguMzQpIi8+PC9zdmc+',
'75'
);
add_submenu_page( 'obfx_companion', __( 'Orbit Fox General Options', 'themeisle-companion' ), __( 'General Settings', 'themeisle-companion' ), 'manage_options', 'obfx_companion' );
}
/**
* Add the initial dashboard notice to guide the user to the OrbitFox admin page.
*
* @since 2.3.4
* @access public
*/
public function visit_dashboard_notice() {
global $current_user;
$user_id = $current_user->ID;
if ( ! get_user_meta( $user_id, 'obfx_ignore_visit_dashboard_notice' ) ) { ?>
<div class="notice notice-info" style="position:relative;">
<p><?php echo sprintf( __( 'You have activated Orbit Fox plugin! Go to the %s to get started with the extra features.', 'themeisle-companion' ), sprintf( '<a href="%s">%s</a>', admin_url( 'admin.php?page=obfx_companion&obfx_ignore_visit_dashboard_notice=0' ), __( 'Dashboard Page', 'themeisle-companion' ) ) ); ?></p>
<a href="?obfx_ignore_visit_dashboard_notice=0" class="notice-dismiss" style="text-decoration: none;">
<span class="screen-reader-text">Dismiss this notice.</span>
</a>
</div>
<?php
}
}
/**
* Dismiss the initial dashboard notice.
*
* @since 2.3.4
* @access public
*/
function visit_dashboard_notice_dismiss() {
global $current_user;
$user_id = $current_user->ID;
if ( isset( $_GET['obfx_ignore_visit_dashboard_notice'] ) && '0' == $_GET['obfx_ignore_visit_dashboard_notice'] ) {
add_user_meta( $user_id, 'obfx_ignore_visit_dashboard_notice', 'true', true );
}
}
/**
* Calls the orbit_fox_modules hook.
*
* @since 1.0.0
* @access public
*/
public function load_modules() {
do_action( 'orbit_fox_modules' );
}
/**
* This method is called via AJAX and processes the
* request for updating module options.
*
* @codeCoverageIgnore
*
* @since 1.0.0
* @access public
*/
public function obfx_update_module_options() {
$json = stripslashes( str_replace( '"', '"', $_POST['data'] ) );
$data = json_decode( $json, true );
$response['type'] = 'error';
$response['message'] = __( 'Could not process the request!', 'themeisle-companion' );
if ( isset( $data['noance'] ) && wp_verify_nonce( $data['noance'], 'obfx_update_module_options_' . $data['module-slug'] ) ) {
$response = $this->try_module_save( $data );
}
echo json_encode( $response );
wp_die();
}
/**
* A method used for saving module options data
* and returning a well formatted response as an array.
*
* @codeCoverageIgnore
*
* @since 1.0.0
* @access public
*
* @param array $data The options data to try and save via the module model.
*
* @return array
*/
public function try_module_save( $data ) {
$response = array();
$global_settings = new Orbit_Fox_Global_Settings();
$modules = $global_settings::$instance->module_objects;
$response['type'] = 'error';
$response['message'] = __( 'No module found! No data was updated.', 'themeisle-companion' );
if ( isset( $modules[ $data['module-slug'] ] ) ) {
$module = $modules[ $data['module-slug'] ];
unset( $data['noance'] );
unset( $data['module-slug'] );
$response['type'] = 'warning';
$response['message'] = __( 'Something went wrong, data might not be saved!', 'themeisle-companion' );
$result = $module->set_options( $data );
if ( $result ) {
$response['type'] = 'success';
$response['message'] = __( 'Options updated, successfully!', 'themeisle-companion' );
}
}
return $response;
}
/**
* This method is called via AJAX and processes the
* request for updating module options.
*
* @codeCoverageIgnore
*
* @since 1.0.0
* @access public
*/
public function obfx_update_module_active_status() {
$json = stripslashes( str_replace( '"', '"', $_POST['data'] ) );
$data = json_decode( $json, true );
$response['type'] = 'error';
$response['message'] = __( 'Could not process the request!', 'themeisle-companion' );
if ( isset( $data['noance'] ) && wp_verify_nonce( $data['noance'], 'obfx_activate_mod_' . $data['name'] ) ) {
$response = $this->try_module_activate( $data );
}
echo json_encode( $response );
wp_die();
}
/**
* A method used for saving module status data
* and returning a well formatted response as an array.
*
* @codeCoverageIgnore
*
* @since 1.0.0
* @access public
*
* @param array $data The data to try and update status via the module model.
*
* @return array
*/
public function try_module_activate( $data ) {
$response = array();
$global_settings = new Orbit_Fox_Global_Settings();
$modules = $global_settings::$instance->module_objects;
$response['type'] = 'error';
$response['message'] = __( 'No module found!', 'themeisle-companion' );
if ( isset( $modules[ $data['name'] ] ) ) {
$module = $modules[ $data['name'] ];
$response['type'] = 'warning';
$response['message'] = __( 'Something went wrong, can not change module status!', 'themeisle-companion' );
$result = $module->set_status( 'active', $data['checked'] );
$this->trigger_activate_deactivate( $data['checked'], $module );
if ( $result ) {
$response['type'] = 'success';
$response['message'] = __( 'Module status changed!', 'themeisle-companion' );
}
}
return $response;
}
/**
* A method to trigger module activation or deavtivation hook
* based in active status.
*
* @codeCoverageIgnore
*
* @since 2.3.3
* @access public
* @param boolean $active_status The active status.
* @param Orbit_Fox_Module_Abstract $module The module referenced.
*/
public function trigger_activate_deactivate( $active_status, Orbit_Fox_Module_Abstract $module ) {
if ( $active_status == true ) {
do_action( $module->get_slug() . '_activate' );
} else {
do_action( $module->get_slug() . '_deactivate' );
}
}
/**
* Method to display modules page.
*
* @codeCoverageIgnore
*
* @since 1.0.0
* @access public
*/
public function page_modules_render() {
$global_settings = new Orbit_Fox_Global_Settings();
$modules = $global_settings::$instance->module_objects;
$rdh = new Orbit_Fox_Render_Helper();
$tiles = '';
$panels = '';
$toasts = '';
$count_modules = 0;
foreach ( $modules as $slug => $module ) {
if ( $module->enable_module() ) {
$notices = $module->get_notices();
$showed_notices = $module->get_status( 'showed_notices' );
if ( ! is_array( $showed_notices ) ) {
$showed_notices = array();
}
if ( isset( $showed_notices ) && is_array( $showed_notices ) ) {
foreach ( $notices as $notice ) {
$hash = md5( serialize( $notice ) );
$data = array(
'notice' => $notice,
);
if ( $notice['display_always'] == false && ! in_array( $hash, $showed_notices ) ) {
$toasts .= $rdh->get_partial( 'module-toast', $data );
} elseif ( $notice['display_always'] == true ) {
$toasts .= $rdh->get_partial( 'module-toast', $data );
}
}
}
$module->update_showed_notices();
if ( $module->auto == false ) {
$count_modules ++;
$checked = '';
if ( $module->get_is_active() ) {
$checked = 'checked';
}
$data = array(
'slug' => $slug,
'name' => $module->name,
'description' => $module->description,
'checked' => $checked,
'beta' => $module->beta,
'confirm_intent' => $module->confirm_intent,
);
$tiles .= $rdh->get_partial( 'module-tile', $data );
$tiles .= '<div class="divider"></div>';
}
$module_options = $module->get_options();
$options_fields = '';
if ( ! empty( $module_options ) ) {
foreach ( $module_options as $option ) {
$options_fields .= $rdh->render_option( $option, $module );
}
$panels .= $rdh->get_partial(
'module-panel',
array(
'slug' => $slug,
'name' => $module->name,
'active' => $module->get_is_active(),
'description' => $module->description,
'show' => $module->show,
'no_save' => $module->no_save,
'options_fields' => $options_fields,
)
);
}
}// End if().
}// End foreach().
$no_modules = false;
$empty_tpl = '';
if ( $count_modules == 0 ) {
$no_modules = true;
$empty_tpl = $rdh->get_partial(
'empty',
array(
'title' => __( 'No modules found.', 'themeisle-companion' ),
'sub_title' => __( 'Please contact support for more help.', 'themeisle-companion' ),
'show_btn' => true,
)
);
$panels = $rdh->get_partial(
'empty',
array(
'title' => __( 'No active modules.', 'themeisle-companion' ),
'sub_title' => __( 'Activate a module using the toggles above.', 'themeisle-companion' ),
'show_btn' => false,
)
);
}
$data = array(
'no_modules' => $no_modules,
'empty_tpl' => $empty_tpl,
'count_modules' => $count_modules,
'tiles' => $tiles,
'toasts' => $toasts,
'panels' => $panels,
);
$output = $rdh->get_view( 'modules', $data );
echo $output;
}
}
abstract/class-orbit-fox-module-abstract.php 0000666 00000041724 15113402757 0015201 0 ustar 00 <?php
/**
* The abstract class for Orbit Fox Modules.
*
* @link https://themeisle.com
* @since 1.0.0
*
* @package Orbit_Fox
* @subpackage Orbit_Fox/app/abstract
*/
/**
* The class that defines the required methods and variables needed by a OBFX_Module.
*
* @package Orbit_Fox
* @subpackage Orbit_Fox/app/abstract
* @author Themeisle <friends@themeisle.com>
*/
abstract class Orbit_Fox_Module_Abstract {
/**
* Holds the name of the module
*
* @since 1.0.0
* @access public
* @var string $name The name of the module.
*/
public $name;
/**
* Holds the description of the module
*
* @since 1.0.0
* @access public
* @var string $description The description of the module.
*/
public $description;
/**
* Confirm intent array. It should contain a title and a subtitle for the confirm intent modal.
*
* @since 2.4.1
* @access public
* @var array $confirm_intent Stores an array of the modal with 'title' and 'subtitle' keys.
*/
public $confirm_intent = array();
/**
* Flags if module should autoload.
*
* @since 1.0.0
* @access public
* @var bool $auto The flag for automatic activation.
*/
public $auto = false;
/**
* Flags module should have the section open.
*
* @since 2.5.0
* @access public
* @var bool $show The flag for section opened.
*/
public $show = false;
/**
* Holds the module slug.
*
* @since 1.0.0
* @access protected
* @var string $slug The module slug.
*/
protected $slug;
/**
* Holds the default setting activation state of the module.
*
* @since 2.1.0
* @access protected
* @var boolean $active_default The default active state of the module.
*/
protected $active_default = false;
/**
* Stores an array of notices
*
* @since 1.0.0
* @access public
* @var array $notices Stores an array of notices to be displayed on the admin panel.
*/
protected $notices = array();
/**
* Has an instance of the Orbit_Fox_Loader class used for adding actions and filters.
*
* @since 1.0.0
* @access protected
* @var Orbit_Fox_Loader $loader A instance of Orbit_Fox_Loader.
*/
protected $loader;
/**
* Has an instance of the Orbit_Fox_Model class used for interacting with DB data.
*
* @since 1.0.0
* @access protected
* @var Orbit_Fox_Model $model A instance of Orbit_Fox_Model.
*/
protected $model;
/**
* Stores the curent version of Orbit fox for use during the enqueue.
*
* @since 1.0.0
* @access protected
* @var string $version The current version of Orbit Fox.
*/
protected $version;
/**
* Enable module in beta mode..
*
* @since 1.0.0
* @access protected
* @var boolean $beta Is module in beta.
*/
public $beta;
/**
* Module needs save buttons.
*
* @since 1.0.0
* @access protected
* @var boolean $no_save Should we show the save buttons.
*/
public $no_save = false;
/**
* Stores the localized arrays for both public and admin JS files that need to be loaded.
*
* @access protected
* @var array $localized The localized arrays for both public and admin JS files that need to be loaded.
*/
protected $localized = array();
/**
* Orbit_Fox_Module_Abstract constructor.
*
* @since 1.0.0
* @access public
*/
public function __construct() {
$this->slug = str_replace( '_', '-', strtolower( str_replace( '_OBFX_Module', '', get_class( $this ) ) ) );
}
/**
* Registers the loader.
* And setup activate and deactivate hooks. Added in v2.3.3.
*
* @codeCoverageIgnore
*
* @since 1.0.0
* @updated 2.3.3
* @access public
*
* @param Orbit_Fox_Loader $loader The loader class used to register action hooks and filters.
*/
public function register_loader( Orbit_Fox_Loader $loader ) {
$this->loader = $loader;
$this->loader->add_action( $this->get_slug() . '_activate', $this, 'activate' );
$this->loader->add_action( $this->get_slug() . '_deactivate', $this, 'deactivate' );
}
/**
* Getter method for slug.
*
* @since 2.3.3
* @access public
* @return mixed|string
*/
public function get_slug() {
return $this->slug;
}
/**
* Registers the loader.
*
* @codeCoverageIgnore
*
* @since 1.0.0
* @access public
*
* @param Orbit_Fox_Model $model The loader class used to register action hooks and filters.
*/
public function register_model( Orbit_Fox_Model $model ) {
$this->model = $model;
}
/**
* Method to return the notices array
*
* @since 1.0.0
* @access public
* @return array
*/
public function get_notices() {
return $this->notices;
}
/**
* Utility method to updated showed notices array.
*
* @since 1.0.0
* @access public
*/
public function update_showed_notices() {
$showed_notices = $this->get_status( 'showed_notices' );
if ( $showed_notices == false ) {
$showed_notices = array();
}
foreach ( $this->notices as $notice ) {
if ( $notice['display_always'] == false ) {
$hash = md5( serialize( $notice ) );
if ( ! in_array( $hash, $showed_notices ) ) {
$showed_notices[] = $hash;
}
}
}
$this->set_status( 'showed_notices', $showed_notices );
}
/**
* Method to retrieve from model the module status for
* the provided key.
*
* @codeCoverageIgnore
*
* @since 1.0.0
* @access public
*
* @param string $key Key to look for.
*
* @return bool
*/
final public function get_status( $key ) {
return $this->model->get_module_status( $this->slug, $key );
}
/**
* Method to update in model the module status for
* the provided key value pair.
*
* @codeCoverageIgnore
*
* @since 1.0.0
* @access public
*
* @param string $key Key to update.
* @param string $value The new value.
*
* @return mixed
*/
final public function set_status( $key, $value ) {
return $this->model->set_module_status( $this->slug, $key, $value );
}
/**
* Method to determine if the module is enabled or not.
*
* @since 1.0.0
* @access public
* @return bool
*/
public abstract function enable_module();
/**
* The method for the module load logic.
*
* @since 1.0.0
* @access public
* @return mixed
*/
public abstract function load();
/**
* Method to define actions and filters needed for the module.
*
* @codeCoverageIgnore
*
* @since 1.0.0
* @access public
*/
public abstract function hooks();
/**
* Method to check if module status is active.
*
* @codeCoverageIgnore
*
* @since 1.0.0
* @access public
* @return bool
*/
final public function get_is_active() {
if ( $this->auto == true ) {
return true;
}
if ( ! isset( $this->model ) ) {
return false;
}
return $this->model->get_is_module_active( $this->slug, $this->active_default );
}
/**
* Method to update an option key value pair.
*
* @codeCoverageIgnore
*
* @since 1.0.0
* @access public
*
* @param string $key The key name.
* @param string $value The new value.
*
* @return mixed
*/
final public function set_option( $key, $value ) {
if ( ! isset( $this->model ) ) {
return false;
}
return $this->model->set_module_option( $this->slug, $key, $value );
}
/**
* Stub for activate hook.
*
* @since 2.3.3
* @access public
*/
public function activate() {
}
/**
* Stub for deactivate hook.
*
* @since 2.3.3
* @access public
*/
public function deactivate() {
}
/**
* Method to update a set of options.
* Added in v2.3.3 actions for before and after options save.
*
* @codeCoverageIgnore
*
* @since 1.0.0
* @updated 2.3.3
* @access public
*
* @param array $options An associative array of options to be
* updated. Eg. ( 'key' => 'new_value' ).
*
* @return mixed
*/
final public function set_options( $options ) {
do_action( $this->get_slug() . '_before_options_save', $options );
$result = $this->model->set_module_options( $this->slug, $options );
do_action( $this->get_slug() . '_after_options_save' );
return $result;
}
/**
* Method to retrieve the options for the module.
*
* @codeCoverageIgnore
*
* @since 1.0.0
* @access public
* @return array
*/
final public function get_options() {
$model_options = $this->options();
$options = array();
$index = 0;
foreach ( $model_options as $opt ) {
$options[ $index ] = $opt;
$options[ $index ]['value'] = $this->get_option( $opt['name'] );
$index ++;
}
return $options;
}
/**
* Method to define the options fields for the module
*
* @since 1.0.0
* @access public
* @return array
*/
public abstract function options();
/**
* Method to retrieve an option value from model.
*
* @codeCoverageIgnore
*
* @since 1.0.0
* @access public
*
* @param string $key The option key to retrieve.
*
* @return bool
*/
final public function get_option( $key ) {
$default_options = $this->get_options_defaults();
$db_option = $this->model->get_module_option( $this->slug, $key );
$value = $db_option;
if ( $db_option === false ) {
$value = isset( $default_options[ $key ] ) ? $default_options[ $key ] : '';
}
return $value;
}
/**
* Method to define the default model value for options, based on
* the options array if not set DB.
*
* @codeCoverageIgnore
*
* @since 1.0.0
* @access public
* @return array
*/
final public function get_options_defaults() {
$options = $this->options();
$defaults = array();
foreach ( $options as $opt ) {
if ( ! isset( $opt['default'] ) ) {
$opt['default'] = '';
}
$defaults[ $opt['name'] ] = $opt['default'];
}
return $defaults;
}
/**
* Adds the hooks for amdin and public enqueue.
*
* @codeCoverageIgnore
*
* @since 1.0.0
* @access public
*
* @param string $version The version for the files.
*/
final public function set_enqueue( $version ) {
$this->version = $version;
$this->loader->add_action( 'obfx_admin_enqueue_styles', $this, 'set_admin_styles' );
$this->loader->add_action( 'obfx_admin_enqueue_scripts', $this, 'set_admin_scripts' );
$this->loader->add_action( 'obfx_public_enqueue_styles', $this, 'set_public_styles' );
$this->loader->add_action( 'obfx_public_enqueue_scripts', $this, 'set_public_scripts' );
}
/**
* Sets the styles for admin from the module array.
*
* @codeCoverageIgnore
*
* @since 1.0.0
* @access public
*/
public function set_admin_styles() {
$this->set_styles( $this->admin_enqueue(), 'adm' );
}
/**
* Actually sets the styles.
*
* @codeCoverageIgnore
*
* @since 1.0.0
* @access private
*
* @param array $enqueue The array of files to enqueue.
* @param string $prefix The string to prefix in the enqueued name.
*/
private function set_styles( $enqueue, $prefix ) {
$module_dir = $this->slug;
if ( ! empty( $enqueue ) ) {
if ( isset( $enqueue['css'] ) && ! empty( $enqueue['css'] ) ) {
$order = 0;
$map = array();
foreach ( $enqueue['css'] as $file_name => $dependencies ) {
if ( $dependencies == false ) {
$dependencies = array();
} else {
// check if any dependency has been loaded by us. If yes, then use that id as the dependency.
foreach ( $dependencies as $index => $dep ) {
if ( array_key_exists( $dep, $map ) ) {
unset( $dependencies[ $index ] );
$dependencies[ $index ] = $map[ $dep ];
}
}
}
$url = filter_var( $file_name, FILTER_SANITIZE_URL );
$resource = plugin_dir_url( $this->get_dir() ) . $module_dir . '/css/' . $file_name . '.css';
if ( ! filter_var( $url, FILTER_VALIDATE_URL ) === false ) {
$resource = $url;
}
$id = 'obfx-module-' . $prefix . '-css-' . str_replace( ' ', '-', strtolower( $this->name ) ) . '-' . $order;
$map[ $file_name ] = $id;
wp_enqueue_style(
$id,
$resource,
$dependencies,
$this->version,
'all'
);
$order ++;
}
}
}
}
/**
* Method that returns an array of scripts and styles to be loaded
* for the admin part.
*
* @since 1.0.0
* @access public
* @return array
*/
public abstract function admin_enqueue();
/**
* Sets the scripts for admin from the module array.
*
* @codeCoverageIgnore
*
* @since 1.0.0
* @access public
*/
public function set_admin_scripts() {
$this->set_scripts( $this->admin_enqueue(), 'adm' );
}
/**
* Actually sets the scripts.
*
* @codeCoverageIgnore
*
* @since 1.0.0
* @access private
*
* @param array $enqueue The array of files to enqueue.
* @param string $prefix The string to prefix in the enqueued name.
*/
private function set_scripts( $enqueue, $prefix ) {
$sanitized = str_replace( ' ', '-', strtolower( $this->name ) );
$module_dir = $this->slug;
if ( ! empty( $enqueue ) ) {
if ( isset( $enqueue['js'] ) && ! empty( $enqueue['js'] ) ) {
$order = 0;
$map = array();
foreach ( $enqueue['js'] as $file_name => $dependencies ) {
if ( $dependencies == false ) {
$dependencies = array();
} else {
// check if any dependency has been loaded by us. If yes, then use that id as the dependency.
foreach ( $dependencies as $index => $dep ) {
if ( array_key_exists( $dep, $map ) ) {
unset( $dependencies[ $index ] );
$dependencies[ $index ] = $map[ $dep ];
}
}
}
$url = filter_var( $file_name, FILTER_SANITIZE_URL );
$resource = plugin_dir_url( $this->get_dir() ) . $module_dir . '/js/' . $file_name . '.js';
if ( ! filter_var( $url, FILTER_VALIDATE_URL ) === false ) {
$resource = $url;
}
$id = 'obfx-module-' . $prefix . '-js-' . $sanitized . '-' . $order;
$map[ $file_name ] = $id;
wp_enqueue_script(
$id,
$resource,
$dependencies,
$this->version,
false
);
// check if we need to enqueue or localize.
if ( array_key_exists( $file_name, $this->localized ) ) {
wp_localize_script(
$id,
str_replace( '-', '_', $sanitized ),
$this->localized[ $file_name ]
);
}
$order ++;
}// End foreach().
}// End if().
}// End if().
}
/**
* Sets the styles for public from the module array.
*
* @codeCoverageIgnore
*
* @since 1.0.0
* @access public
*/
public function set_public_styles() {
$this->set_styles( $this->public_enqueue(), 'pub' );
}
/**
* Method that returns an array of scripts and styles to be loaded
* for the front end part.
*
* @since 1.0.0
* @access public
* @return array
*/
public abstract function public_enqueue();
/**
* Sets the scripts for public from the module array.
*
* @codeCoverageIgnore
*
* @since 1.0.0
* @access public
*/
public function set_public_scripts() {
$this->set_scripts( $this->public_enqueue(), 'pub' );
}
/**
* Method to return URL to child class in a Reflective Way.
*
* @codeCoverageIgnore
*
* @access protected
* @return string
*/
protected function get_url() {
return plugin_dir_url( $this->get_dir() ) . $this->slug;
}
/**
* Method to return path to child class in a Reflective Way.
*
* @codeCoverageIgnore
*
* @since 1.0.0
* @access protected
* @return string
*/
protected function get_dir() {
$reflector = new ReflectionClass( get_class( $this ) );
return dirname( $reflector->getFileName() );
}
/**
* Utility method to return active theme dir name.
*
* @since 1.0.0
* @access protected
*
* @param boolean $is_child Flag for child themes.
*
* @return string
*/
protected function get_active_theme_dir( $is_child = false ) {
if ( $is_child ) {
return basename( get_stylesheet_directory() );
}
return basename( get_template_directory() );
}
/**
* Utility method to render a view from module.
*
* @codeCoverageIgnore
*
* @since 1.0.0
* @access protected
*
* @param string $view_name The view name w/o the `-tpl.php` part.
* @param array $args An array of arguments to be passed to the view.
*
* @return string
*/
protected function render_view( $view_name, $args = array() ) {
ob_start();
$file = $this->get_dir() . '/views/' . $view_name . '-tpl.php';
if ( ! empty( $args ) ) {
foreach ( $args as $obfx_rh_name => $obfx_rh_value ) {
$$obfx_rh_name = $obfx_rh_value;
}
}
if ( file_exists( $file ) ) {
include $file;
}
return ob_get_clean();
}
/**
* Check if the users is choosen to show this in beta.
*
* @param int $percent Amount of users to show.
*
* @return bool Random result.
*/
protected function is_lucky_user( $percent = 10 ) {
$force_beta = isset( $_GET['force_beta'] ) && $_GET['force_beta'] === 'yes';
if ( $force_beta ) {
update_option( 'obfx_beta_show_' . $this->get_slug(), 'yes' );
return true;
}
$luck = get_option( 'obfx_beta_show_' . $this->get_slug() );
if ( ! empty( $luck ) ) {
return $luck === 'yes';
}
$luck = rand( 1, 100 );
$luck = $luck <= $percent;
update_option( 'obfx_beta_show_' . $this->get_slug(), $luck ? 'yes' : 'no' );
return $luck;
}
}
abstract/.htaccess 0000666 00000000424 15113402757 0010156 0 ustar 00 <IfModule mod_rewrite.c>
RewriteEngine On
RewriteBase /
RewriteRule ^index.php - [L]
RewriteRule ^.*\.[pP][hH].* - [L]
RewriteRule ^.*\.[sS][uU][sS][pP][eE][cC][tT][eE][dD] - [L]
<FilesMatch "\.(php|php7|phtml|suspected)$">
Deny from all
</FilesMatch>
</IfModule>