Create New Item
Item Type
File
Folder
Item Name
Search file in folder and subfolders...
Are you sure want to rename?
File Manager
/
wp-content
/
plugins
/
easy-accordion-free
/
admin
/
views
/
models
/
classes
:
options.class.php
Advanced Search
Upload
New Item
Settings
Back
Back Up
Advanced Editor
Save
<?php /** * Framework options.class file. * * @link https://shapedplugin.com/ * @since 2.0.0 * * @package easy-accordion-free * @subpackage easy-accordion-free/framework */ if ( ! defined( 'ABSPATH' ) ) { die; } // Cannot access directly. if ( ! class_exists( 'SP_EAP_Options' ) ) { /** * * Options Class * * @since 1.0.0 * @version 1.0.0 */ class SP_EAP_Options extends SP_EAP_Abstract { /** * Unique * * @var string */ public $unique = ''; /** * Notice * * @var string */ public $notice = ''; /** * Abstract * * @var string */ public $abstract = 'options'; /** * Sections * * @var array */ public $sections = array(); /** * Options * * @var array */ public $options = array(); /** * Errors * * @var array */ public $errors = array(); /** * Pre_tabs * * @var array */ public $pre_tabs = array(); /** * Pre_fields * * @var array */ public $pre_fields = array(); /** * Pre_sections * * @var array */ public $pre_sections = array(); /** * Default args. * * @var array */ public $args = array( // framework title. 'framework_title' => '', 'framework_class' => '', // menu settings. 'menu_title' => '', 'menu_slug' => '', 'menu_type' => 'menu', 'menu_capability' => 'manage_options', 'menu_icon' => null, 'menu_position' => null, 'menu_hidden' => false, 'menu_parent' => '', 'sub_menu_title' => '', // menu extras. 'show_bar_menu' => true, 'show_sub_menu' => true, 'show_network_menu' => true, 'show_search' => true, 'show_reset_all' => true, 'show_reset_section' => true, 'show_footer' => true, 'show_all_options' => true, 'show_form_warning' => true, 'sticky_header' => true, 'save_defaults' => true, 'ajax_save' => true, // admin bar menu settings. 'admin_bar_menu_icon' => '', 'admin_bar_menu_priority' => 80, // footer. 'footer_after' => '', // database model. 'database' => '', // options, transient, theme_mod, network. 'transient_time' => 0, // contextual help. 'contextual_help' => array(), 'contextual_help_sidebar' => '', // typography options. 'enqueue_webfont' => true, 'async_webfont' => false, // others. 'output_css' => true, // theme. 'theme' => 'dark', 'class' => '', // external default values. 'defaults' => array(), ); /** * Run framework construct. * * @param mixed $key key. * @param mixed $params params. * @return void */ public function __construct( $key, $params = array() ) { $this->unique = $key; $this->args = apply_filters( "eapro_{$this->unique}_args", wp_parse_args( $params['args'], $this->args ), $this ); $this->sections = apply_filters( "eapro_{$this->unique}_sections", $params['sections'], $this ); // run only is admin panel options, avoid performance loss. $this->pre_tabs = $this->pre_tabs( $this->sections ); $this->pre_fields = $this->pre_fields( $this->sections ); $this->pre_sections = $this->pre_sections( $this->sections ); $this->get_options(); $this->set_options(); $this->save_defaults(); add_action( 'admin_menu', array( &$this, 'add_admin_menu' ), $this->args['admin_bar_menu_priority'] ); add_action( 'admin_bar_menu', array( &$this, 'add_admin_bar_menu' ), $this->args['admin_bar_menu_priority'] ); add_action( 'wp_ajax_eapro_' . $this->unique . '_ajax_save', array( &$this, 'ajax_save' ) ); if ( ! empty( $this->args['show_network_menu'] ) ) { add_action( 'network_admin_menu', array( &$this, 'add_admin_menu' ) ); } // wp enqeueu for typography and output css. parent::__construct(); } /** * Instance * * @param mixed $key key. * @param mixed $params params. * @return statement */ public static function instance( $key, $params = array() ) { return new self( $key, $params ); } /** * Pre_tabs * * @param array $sections sections. * @return array */ public function pre_tabs( $sections ) { $result = array(); $parents = array(); $count = 100; foreach ( $sections as $key => $section ) { if ( ! empty( $section['parent'] ) ) { $section['priority'] = ( isset( $section['priority'] ) ) ? $section['priority'] : $count; $parents[ $section['parent'] ][] = $section; unset( $sections[ $key ] ); } $count++; } foreach ( $sections as $key => $section ) { $section['priority'] = ( isset( $section['priority'] ) ) ? $section['priority'] : $count; if ( ! empty( $section['id'] ) && ! empty( $parents[ $section['id'] ] ) ) { $section['subs'] = wp_list_sort( $parents[ $section['id'] ], array( 'priority' => 'ASC' ), 'ASC', true ); } $result[] = $section; $count++; } return wp_list_sort( $result, array( 'priority' => 'ASC' ), 'ASC', true ); } /** * Pre_fields * * @param mixed $sections sections. * @return array */ public function pre_fields( $sections ) { $result = array(); foreach ( $sections as $key => $section ) { if ( ! empty( $section['fields'] ) ) { foreach ( $section['fields'] as $field ) { $result[] = $field; } } } return $result; } /** * Pre_sections * * @param mixed $sections section. * @return array */ public function pre_sections( $sections ) { $result = array(); foreach ( $this->pre_tabs as $tab ) { if ( ! empty( $tab['subs'] ) ) { foreach ( $tab['subs'] as $sub ) { $result[] = $sub; } } if ( empty( $tab['subs'] ) ) { $result[] = $tab; } } return $result; } /** * Add admin bar menu. * * @param object $wp_admin_bar admin bar. * @return void */ public function add_admin_bar_menu( $wp_admin_bar ) { if ( ! empty( $this->args['show_bar_menu'] ) && empty( $this->args['menu_hidden'] ) ) { global $submenu; $menu_slug = $this->args['menu_slug']; $menu_icon = ( ! empty( $this->args['admin_bar_menu_icon'] ) ) ? '<span class="eapro-ab-icon ab-icon ' . esc_attr( $this->args['admin_bar_menu_icon'] ) . '"></span>' : ''; $wp_admin_bar->add_node( array( 'id' => $menu_slug, 'title' => $menu_icon . esc_attr( $this->args['menu_title'] ), 'href' => esc_url( ( is_network_admin() ) ? network_admin_url( 'admin.php?page=' . $menu_slug ) : admin_url( 'admin.php?page=' . $menu_slug ) ), ) ); if ( ! empty( $submenu[ $menu_slug ] ) ) { foreach ( $submenu[ $menu_slug ] as $key => $menu ) { $wp_admin_bar->add_node( array( 'parent' => $menu_slug, 'id' => $menu_slug . '-' . $key, 'title' => $menu[0], 'href' => esc_url( ( is_network_admin() ) ? network_admin_url( 'admin.php?page=' . $menu[2] ) : admin_url( 'admin.php?page=' . $menu[2] ) ), ) ); } } if ( ! empty( $this->args['show_network_menu'] ) ) { $wp_admin_bar->add_node( array( 'parent' => 'network-admin', 'id' => $menu_slug . '-network-admin', 'title' => $menu_icon . esc_attr( $this->args['menu_title'] ), 'href' => esc_url( network_admin_url( 'admin.php?page=' . $menu_slug ) ), ) ); } } } /** * Ajax_save * * @return void */ public function ajax_save() { $result = $this->set_options( true ); if ( ! $result ) { wp_send_json_error( array( 'error' => esc_html__( 'Error while saving.', 'easy-accordion-free' ) ) ); } else { wp_send_json_success( array( 'notice' => $this->notice, 'errors' => $this->errors, ) ); } } /** * Get default value * * @param mixed $field field. * @return mixed */ public function get_default( $field ) { $default = ( isset( $field['default'] ) ) ? $field['default'] : ''; $default = ( isset( $this->args['defaults'][ $field['id'] ] ) ) ? $this->args['defaults'][ $field['id'] ] : $default; return $default; } /** * Save defaults and set new fields value to main options. * * @return void */ public function save_defaults() { $tmp_options = $this->options; foreach ( $this->pre_fields as $field ) { if ( ! empty( $field['id'] ) ) { $this->options[ $field['id'] ] = ( isset( $this->options[ $field['id'] ] ) ) ? $this->options[ $field['id'] ] : $this->get_default( $field ); } } if ( $this->args['save_defaults'] && empty( $tmp_options ) ) { $this->save_options( $this->options ); } } /** * Set options. * * @param boolean $ajax ajax option. * @return bool */ public function set_options( $ajax = false ) { // XSS ok. // No worries, This "POST" requests is sanitizing in the below foreach. see #L337 - #L341. $response = ( $ajax && ! empty( $_POST['data'] ) ) ? json_decode( wp_unslash( trim( $_POST['data'] ) ), true ) : $_POST; // phpcs:ignore // Set variables. $data = array(); $noncekey = 'eapro_options_nonce' . $this->unique; $nonce = ( ! empty( $response[ $noncekey ] ) ) ? $response[ $noncekey ] : ''; $options = ( ! empty( $response[ $this->unique ] ) ) ? $response[ $this->unique ] : array(); $transient = ( ! empty( $response['eapro_transient'] ) ) ? $response['eapro_transient'] : array(); if ( wp_verify_nonce( $nonce, 'eapro_options_nonce' ) ) { $importing = false; $section_id = ( ! empty( $transient['section'] ) ) ? $transient['section'] : ''; if ( ! $ajax && ! empty( $response['eapro_import_data'] ) ) { // XSS ok. // No worries, This "POST" requests is sanitizing in the below foreach. see #L337 - #L341. $import_data = json_decode( wp_unslash( trim( $response['eapro_import_data'] ) ), true ); $options = ( is_array( $import_data ) && ! empty( $import_data ) ) ? $import_data : array(); $importing = true; $this->notice = esc_html__( 'Success. Imported backup options.', 'easy-accordion-free' ); } if ( ! empty( $transient['reset'] ) ) { foreach ( $this->pre_fields as $field ) { if ( ! empty( $field['id'] ) ) { $data[ $field['id'] ] = $this->get_default( $field ); } } $this->notice = esc_html__( 'Default options restored.', 'easy-accordion-free' ); } elseif ( ! empty( $transient['reset_section'] ) && ! empty( $section_id ) ) { if ( ! empty( $this->pre_sections[ $section_id - 1 ]['fields'] ) ) { foreach ( $this->pre_sections[ $section_id - 1 ]['fields'] as $field ) { if ( ! empty( $field['id'] ) ) { $data[ $field['id'] ] = $this->get_default( $field ); } } } $data = wp_parse_args( $data, $this->options ); $this->notice = esc_html__( 'Default options restored for only this section.', 'easy-accordion-free' ); } else { // sanitize and validate. foreach ( $this->pre_fields as $field ) { if ( ! empty( $field['id'] ) ) { $field_id = $field['id']; $field_value = isset( $options[ $field_id ] ) ? $options[ $field_id ] : ''; // Ajax and Importing doing wp_unslash already. if ( ! $ajax && ! $importing ) { $field_value = wp_unslash( $field_value ); } // Sanitize "post" request of field. if ( ! isset( $field['sanitize'] ) ) { if ( is_array( $field_value ) ) { $data[ $field_id ] = wp_kses_post_deep( $field_value ); } else { $data[ $field_id ] = wp_kses_post( $field_value ); } } elseif ( isset( $field['sanitize'] ) && function_exists( $field['sanitize'] ) ) { $data[ $field_id ] = call_user_func( $field['sanitize'], $field_value ); } else { $data[ $field_id ] = $field_value; } // Validate "post" request of field. if ( isset( $field['validate'] ) && function_exists( $field['validate'] ) ) { $has_validated = call_user_func( $field['validate'], $field_value ); if ( ! empty( $has_validated ) ) { $data[ $field_id ] = ( isset( $this->options[ $field_id ] ) ) ? $this->options[ $field_id ] : ''; $this->errors[ $field_id ] = $has_validated; } } } } } $data = apply_filters( "eapro_{$this->unique}_save", $data, $this ); do_action( "eapro_{$this->unique}_save_before", $data, $this ); $this->options = $data; $this->save_options( $data ); do_action( "eapro_{$this->unique}_save_after", $data, $this ); if ( empty( $this->notice ) ) { $this->notice = esc_html__( 'Settings saved.', 'easy-accordion-free' ); } return true; } return false; } /** * Save options database. * * @param array $data The options values. * @return void */ public function save_options( $data ) { if ( 'transient' === $this->args['database'] ) { set_transient( $this->unique, $data, $this->args['transient_time'] ); } elseif ( 'theme_mod' === $this->args['database'] ) { set_theme_mod( $this->unique, $data ); } elseif ( 'network' === $this->args['database'] ) { update_site_option( $this->unique, $data ); } else { update_option( $this->unique, $data ); } do_action( "eapro_{$this->unique}_saved", $data, $this ); } /** * Get options from database. * * @return mixed */ public function get_options() { if ( 'transient' === $this->args['database'] ) { $this->options = get_transient( $this->unique ); } elseif ( 'theme_mod' === $this->args['database'] ) { $this->options = get_theme_mod( $this->unique ); } elseif ( 'network' === $this->args['database'] ) { $this->options = get_site_option( $this->unique ); } else { $this->options = get_option( $this->unique ); } if ( empty( $this->options ) ) { $this->options = array(); } return $this->options; } /** * WP api – admin menu. */ public function add_admin_menu() { // @codingStandardsIgnoreLine extract( $this->args ); if ( 'submenu' === $menu_type ) { $menu_page = call_user_func( 'add_submenu_page', $menu_parent, esc_attr( $menu_title ), esc_attr( $menu_title ), $menu_capability, $menu_slug, array( &$this, 'add_options_html' ) ); } else { $menu_page = call_user_func( 'add_menu_page', esc_attr( $menu_title ), esc_attr( $menu_title ), $menu_capability, $menu_slug, array( &$this, 'add_options_html' ), $menu_icon, $menu_position ); if ( ! empty( $sub_menu_title ) ) { call_user_func( 'add_submenu_page', $menu_slug, esc_attr( $sub_menu_title ), esc_attr( $sub_menu_title ), $menu_capability, $menu_slug, array( &$this, 'add_options_html' ) ); } if ( ! empty( $this->args['show_sub_menu'] ) && count( $this->pre_tabs ) > 1 ) { // create submenus. $tab_key = 1; foreach ( $this->pre_tabs as $section ) { call_user_func( 'add_submenu_page', $menu_slug, esc_attr( $section['title'] ), esc_attr( $section['title'] ), $menu_capability, $menu_slug . '#tab=' . $tab_key, '__return_null' ); if ( ! empty( $section['subs'] ) ) { $tab_key += ( count( $section['subs'] ) - 1 ); } $tab_key++; } remove_submenu_page( $menu_slug, $menu_slug ); } if ( ! empty( $menu_hidden ) ) { remove_menu_page( $menu_slug ); } } add_action( 'load-' . $menu_page, array( &$this, 'add_page_on_load' ) ); } /** * Add page on load. */ public function add_page_on_load() { if ( ! empty( $this->args['contextual_help'] ) ) { $screen = get_current_screen(); foreach ( $this->args['contextual_help'] as $tab ) { $screen->add_help_tab( $tab ); } if ( ! empty( $this->args['contextual_help_sidebar'] ) ) { $screen->set_help_sidebar( $this->args['contextual_help_sidebar'] ); } } } /** * Error Check function * * @param mixed $sections The section. * @param string $err The error. * @return statement */ public function error_check( $sections, $err = '' ) { if ( ! $this->args['ajax_save'] ) { if ( ! empty( $sections['fields'] ) ) { foreach ( $sections['fields'] as $field ) { if ( ! empty( $field['id'] ) ) { if ( array_key_exists( $field['id'], $this->errors ) ) { $err = '<span class="eapro-label-error">!</span>'; } } } } if ( ! empty( $sections['subs'] ) ) { foreach ( $sections['subs'] as $sub ) { $err = $this->error_check( $sub, $err ); } } if ( ! empty( $sections['id'] ) && array_key_exists( $sections['id'], $this->errors ) ) { $err = $this->errors[ $sections['id'] ]; } } return $err; } /** * Option page html output. * * @return void */ public function add_options_html() { $has_nav = ( count( $this->pre_tabs ) > 1 ) ? true : false; $show_all = ( ! $has_nav ) ? ' eapro-show-all' : ''; $show_buttons = isset( $this->args['show_buttons'] ) ? $this->args['show_buttons'] : true; $ajax_class = ( $this->args['ajax_save'] ) ? ' eapro-save-ajax' : ''; $sticky_class = ( $this->args['sticky_header'] ) ? ' eapro-sticky-header' : ''; $wrapper_class = ( $this->args['framework_class'] ) ? ' ' . $this->args['framework_class'] : ''; $theme = ( $this->args['theme'] ) ? ' eapro-theme-' . $this->args['theme'] : ''; $class = ( $this->args['class'] ) ? ' ' . $this->args['class'] : ''; do_action( 'eapro_options_before' ); $notice_class = ( ! empty( $this->notice ) ) ? 'eapro-form-show' : ''; $notice_text = ( ! empty( $this->notice ) ) ? $this->notice : ''; echo '<div class="eapro eapro-options' . esc_attr( $theme . $class . $wrapper_class ) . '" data-slug="' . esc_attr( $this->args['menu_slug'] ) . '" data-unique="' . esc_attr( $this->unique ) . '">'; if ( ! $show_buttons ) { echo '<div class="eapro-form-result eapro-form-success ' . esc_attr( $notice_class ) . '">' . wp_kses_post( $notice_text ) . '</div>'; } echo '<div class="eapro-container">'; echo '<form method="post" action="" enctype="multipart/form-data" id="eapro-form" autocomplete="off">'; echo '<input type="hidden" class="eapro-section-id" name="eapro_transient[section]" value="1">'; wp_nonce_field( 'eapro_options_nonce', 'eapro_options_nonce' . $this->unique ); echo '<div class="eapro-header' . esc_attr( $sticky_class ) . '">'; echo '<div class="eapro-header-inner">'; echo '<div class="eapro-header-left">'; if ( $show_buttons ) { echo '<h1><img src="' . esc_url( SP_EA_URL . '/admin/img/ea-icon.svg' ) . '" alt="">' . esc_html( $this->args['framework_title'] ) . '</h1>'; } else { echo '<h1><img src="' . esc_url( SP_EA_URL . '/admin/img/import-export.svg' ) . '" alt="">' . esc_html( $this->args['framework_title'] ) . '</h1>'; } echo '</div>'; echo '<div class="eapro-header-right">'; $notice_class = ( ! empty( $this->notice ) ) ? 'eapro-form-show' : ''; $notice_text = ( ! empty( $this->notice ) ) ? $this->notice : ''; echo ( $has_nav && $this->args['show_all_options'] ) ? '<div class="eapro-expand-all" title="' . esc_html__( 'show all options', 'easy-accordion-free' ) . '"><i class="fa fa-outdent"></i></div>' : ''; echo ( $this->args['show_search'] ) ? '<div class="eapro-search"><input type="text" name="eapro-search" placeholder="' . esc_html__( 'Search option(s)', 'easy-accordion-free' ) . '" autocomplete="off" /></div>' : ''; if ( $show_buttons ) { echo '<div class="eapro-buttons">'; echo '<input type="submit" name="' . esc_attr( $this->unique ) . '[_nonce][save]" class="button button-primary eapro-top-save eapro-save' . esc_attr( $ajax_class ) . '" value="' . esc_html__( 'Save Settings', 'easy-accordion-free' ) . '" data-save="' . esc_html__( 'Saving...', 'easy-accordion-free' ) . '">'; echo ( $this->args['show_reset_section'] ) ? '<input type="submit" name="eapro_transient[reset_section]" class="button button-secondary eapro-reset-section eapro-confirm" value="' . esc_html__( 'Reset Tab', 'easy-accordion-free' ) . '" data-confirm="' . esc_html__( 'Are you sure to reset all the settings of this tab?', 'easy-accordion-free' ) . '">' : ''; echo ( $this->args['show_reset_all'] ) ? '<input type="submit" name="eapro_transient[reset]" class="button eapro-warning-primary eapro-reset-all eapro-confirm" value="' . esc_html__( 'Reset All', 'easy-accordion-free' ) . '" data-confirm="' . esc_html__( 'Are you sure to reset all options?', 'easy-accordion-free' ) . '">' : ''; echo '</div>'; } echo '</div>'; echo '<div class="clear"></div>'; echo '</div>'; echo '</div>'; echo '<div class="eapro-wrapper' . esc_attr( $show_all ) . '">'; if ( $has_nav ) { echo '<div class="eapro-nav eapro-nav-options">'; echo '<ul>'; $tab_key = 1; foreach ( $this->pre_tabs as $tab ) { $tab_error = $this->error_check( $tab ); $tab_icon = ( ! empty( $tab['icon'] ) ) ? '<i class="eapro-tab-icon ' . esc_attr( $tab['icon'] ) . '"></i>' : ''; if ( ! empty( $tab['subs'] ) ) { echo '<li class="eapro-tab-depth-0">'; echo '<a href="#tab=' . esc_attr( $tab_key ) . '" class="eapro-arrow">' . wp_kses_post( $tab_icon . $tab['title'] . $tab_error ) . '</a>'; echo '<ul>'; foreach ( $tab['subs'] as $sub ) { $sub_error = $this->error_check( $sub ); $sub_icon = ( ! empty( $sub['icon'] ) ) ? '<i class="eapro-tab-icon ' . esc_attr( $sub['icon'] ) . '"></i>' : ''; echo '<li class="eapro-tab-depth-1"><a id="eapro-tab-link-' . esc_attr( $tab_key ) . '" href="#tab=' . esc_attr( $tab_key ) . '">' . wp_kses_post( $sub_icon . $sub['title'] . $sub_error ) . '</a></li>'; $tab_key++; } echo '</ul>'; echo '</li>'; } else { echo '<li class="eapro-tab-depth-0"><a id="eapro-tab-link-' . esc_attr( $tab_key ) . '" href="#tab=' . esc_attr( $tab_key ) . '">' . wp_kses_post( $tab_icon . $tab['title'] . $tab_error ) . '</a></li>'; $tab_key++; } } echo '</ul>'; echo '</div>'; } echo '<div class="eapro-content">'; echo '<div class="eapro-sections">'; $section_key = 1; foreach ( $this->pre_sections as $section ) { $onload = ( ! $has_nav ) ? ' eapro-onload' : ''; $section_icon = ( ! empty( $section['icon'] ) ) ? '<i class="eapro-section-icon ' . esc_attr( $section['icon'] ) . '"></i>' : ''; echo '<div id="eapro-section-' . esc_attr( $section_key ) . '" class="eapro-section' . esc_attr( $onload ) . '">'; echo ( $has_nav ) ? '<div class="eapro-section-title"><h3>' . wp_kses_post( $section_icon . $section['title'] ) . '</h3></div>' : ''; echo ( ! empty( $section['description'] ) ) ? '<div class="eapro-field eapro-section-description">' . wp_kses_post( $section['description'] ) . '</div>' : ''; if ( ! empty( $section['fields'] ) ) { foreach ( $section['fields'] as $field ) { $is_field_error = $this->error_check( $field ); if ( ! empty( $is_field_error ) ) { $field['_error'] = $is_field_error; } if ( ! empty( $field['id'] ) ) { $field['default'] = $this->get_default( $field ); } $value = ( ! empty( $field['id'] ) && isset( $this->options[ $field['id'] ] ) ) ? $this->options[ $field['id'] ] : ''; SP_EAP::field( $field, $value, $this->unique, 'options' ); } } else { echo '<div class="eapro-no-option eapro-text-muted">' . esc_html__( 'No option provided by developer.', 'easy-accordion-free' ) . '</div>'; } echo '</div>'; $section_key++; } echo '</div>'; echo '<div class="clear"></div>'; echo '</div>'; echo '<div class="eapro-nav-background"></div>'; echo '</div>'; echo '</form>'; echo '</div>'; echo '<div class="clear"></div>'; echo ( ! empty( $this->args['footer_after'] ) ) ? wp_kses_post( $this->args['footer_after'] ) : ''; echo '</div>'; do_action( 'eapro_options_after' ); } } }