2017-07-26 14:57:52 +03:00
|
|
|
<?php
|
|
|
|
|
// Exit if accessed directly.
|
|
|
|
|
if ( ! defined( 'ABSPATH' ) ) exit;
|
|
|
|
|
|
|
|
|
|
if ( ! class_exists( 'UM_Functions' ) ) {
|
|
|
|
|
|
|
|
|
|
class UM_Functions {
|
|
|
|
|
|
|
|
|
|
var $options;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @var array variable for Flags
|
|
|
|
|
*/
|
|
|
|
|
var $screenload_flags;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function __construct() {
|
|
|
|
|
|
|
|
|
|
$this->init_variables();
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* What type of request is this?
|
|
|
|
|
*
|
|
|
|
|
* @param string $type String containing name of request type (ajax, frontend, cron or admin)
|
|
|
|
|
*
|
|
|
|
|
* @return bool
|
|
|
|
|
*/
|
|
|
|
|
public function is_request( $type ) {
|
|
|
|
|
switch ( $type ) {
|
|
|
|
|
case 'admin' :
|
|
|
|
|
return is_admin();
|
|
|
|
|
case 'ajax' :
|
|
|
|
|
return defined( 'DOING_AJAX' );
|
|
|
|
|
case 'cron' :
|
|
|
|
|
return defined( 'DOING_CRON' );
|
|
|
|
|
case 'frontend' :
|
|
|
|
|
return ( ! is_admin() || defined( 'DOING_AJAX' ) ) && ! defined( 'DOING_CRON' );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Get ajax routed URL
|
|
|
|
|
*
|
|
|
|
|
* @param string $route
|
|
|
|
|
* @param string $method
|
|
|
|
|
*
|
|
|
|
|
* @return string
|
|
|
|
|
*/
|
|
|
|
|
public function get_ajax_route( $route, $method ) {
|
|
|
|
|
|
|
|
|
|
$route = str_replace( array( '\\', '/' ), '!', $route );
|
|
|
|
|
$ip = isset( $_SERVER['REMOTE_ADDR'] ) ? $_SERVER['REMOTE_ADDR'] : '';
|
|
|
|
|
$nonce = wp_create_nonce( $ip . get_current_user_id() . $route . $method );
|
|
|
|
|
|
|
|
|
|
if ( is_admin() ) {
|
|
|
|
|
$url = add_query_arg( array(
|
|
|
|
|
'action' => 'um_router',
|
|
|
|
|
'um_action' => 'route',
|
|
|
|
|
'um_resource' => $route,
|
|
|
|
|
'um_method' => $method,
|
|
|
|
|
'um_verify' => $nonce
|
|
|
|
|
), get_admin_url( null, 'admin-ajax.php' ) );
|
|
|
|
|
} else if ( get_option( 'permalink_structure' ) ) {
|
2017-12-08 12:53:50 +02:00
|
|
|
$url = get_home_url( null, 'um-api/route/' . $route . '/' . $method . '/' . $nonce );
|
2017-07-26 14:57:52 +03:00
|
|
|
} else {
|
|
|
|
|
$url = add_query_arg( array(
|
|
|
|
|
'um_page' => 'api',
|
|
|
|
|
'um_action' => 'route',
|
|
|
|
|
'um_resource' => $route,
|
|
|
|
|
'um_method' => $method,
|
|
|
|
|
'um_verify' => $nonce
|
2017-12-08 12:53:50 +02:00
|
|
|
), get_home_url() );
|
2017-07-26 14:57:52 +03:00
|
|
|
}
|
|
|
|
|
return $url;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Set variables
|
|
|
|
|
*/
|
|
|
|
|
function init_variables() {
|
|
|
|
|
$this->options = get_option( 'um_options' );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Help Tip displaying
|
|
|
|
|
*
|
|
|
|
|
* Function for render/displaying UltimateMember help tip
|
|
|
|
|
*
|
|
|
|
|
* @since 2.0.0
|
|
|
|
|
*
|
|
|
|
|
* @param string $tip Help tip text
|
|
|
|
|
* @param bool $allow_html Allow sanitized HTML if true or escape
|
|
|
|
|
* @param bool $echo Return HTML or echo
|
|
|
|
|
* @return string
|
|
|
|
|
*/
|
|
|
|
|
function tooltip( $tip, $allow_html = false, $echo = true ) {
|
|
|
|
|
if ( $allow_html ) {
|
|
|
|
|
|
|
|
|
|
$tip = htmlspecialchars( wp_kses( html_entity_decode( $tip ), array(
|
|
|
|
|
'br' => array(),
|
|
|
|
|
'em' => array(),
|
|
|
|
|
'strong' => array(),
|
|
|
|
|
'small' => array(),
|
|
|
|
|
'span' => array(),
|
|
|
|
|
'ul' => array(),
|
|
|
|
|
'li' => array(),
|
|
|
|
|
'ol' => array(),
|
|
|
|
|
'p' => array(),
|
|
|
|
|
) ) );
|
|
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
$tip = esc_attr( $tip );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
ob_start(); ?>
|
|
|
|
|
|
|
|
|
|
<span class="um_tooltip dashicons dashicons-editor-help" title="<?php echo $tip ?>"></span>
|
|
|
|
|
|
|
|
|
|
<?php if ( $echo ) {
|
|
|
|
|
ob_get_flush();
|
|
|
|
|
return '';
|
|
|
|
|
} else {
|
|
|
|
|
return ob_get_clean();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
2017-08-11 14:21:42 +03:00
|
|
|
|
2017-09-06 09:03:24 +03:00
|
|
|
function excluded_taxonomies() {
|
|
|
|
|
$taxes = array(
|
|
|
|
|
'nav_menu',
|
|
|
|
|
'link_category',
|
|
|
|
|
'post_format',
|
|
|
|
|
);
|
|
|
|
|
|
2018-03-02 09:55:49 +02:00
|
|
|
/**
|
|
|
|
|
* UM hook
|
|
|
|
|
*
|
|
|
|
|
* @type filter
|
|
|
|
|
* @title um_excluded_taxonomies
|
|
|
|
|
* @description Exclude taxonomies for UM
|
|
|
|
|
* @input_vars
|
|
|
|
|
* [{"var":"$taxes","type":"array","desc":"Taxonomies keys"}]
|
|
|
|
|
* @change_log
|
|
|
|
|
* ["Since: 2.0"]
|
|
|
|
|
* @usage
|
|
|
|
|
* <?php add_filter( 'um_excluded_taxonomies', 'function_name', 10, 1 ); ?>
|
|
|
|
|
* @example
|
|
|
|
|
* <?php
|
|
|
|
|
* add_filter( 'um_excluded_taxonomies', 'my_excluded_taxonomies', 10, 1 );
|
|
|
|
|
* function my_excluded_taxonomies( $taxes ) {
|
|
|
|
|
* // your code here
|
|
|
|
|
* return $taxes;
|
|
|
|
|
* }
|
|
|
|
|
* ?>
|
|
|
|
|
*/
|
2017-09-06 09:03:24 +03:00
|
|
|
return apply_filters( 'um_excluded_taxonomies', $taxes );
|
2017-08-11 14:21:42 +03:00
|
|
|
}
|
|
|
|
|
|
2017-12-11 09:53:38 +02:00
|
|
|
|
2017-10-24 17:20:03 +03:00
|
|
|
/**
|
|
|
|
|
* Output templates
|
|
|
|
|
*
|
|
|
|
|
* @access public
|
|
|
|
|
* @param string $template_name
|
2017-11-01 13:08:28 +02:00
|
|
|
* @param string $basename (default: '')
|
2017-10-24 17:20:03 +03:00
|
|
|
* @param array $t_args (default: array())
|
|
|
|
|
* @param bool $echo
|
|
|
|
|
*
|
|
|
|
|
* @return string|void
|
|
|
|
|
*/
|
|
|
|
|
function get_template( $template_name, $basename = '', $t_args = array(), $echo = false ) {
|
|
|
|
|
if ( ! empty( $t_args ) && is_array( $t_args ) ) {
|
|
|
|
|
extract( $t_args );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$path = '';
|
|
|
|
|
if( $basename ) {
|
|
|
|
|
$array = explode( '/', trim( $basename, '/' ) );
|
|
|
|
|
$path = $array[0];
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$located = $this->locate_template( $template_name, $path );
|
|
|
|
|
if ( ! file_exists( $located ) ) {
|
|
|
|
|
_doing_it_wrong( __FUNCTION__, sprintf( '<code>%s</code> does not exist.', $located ), '2.1' );
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
2018-03-02 09:55:49 +02:00
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* UM hook
|
|
|
|
|
*
|
|
|
|
|
* @type filter
|
|
|
|
|
* @title um_get_template
|
|
|
|
|
* @description Change template location
|
|
|
|
|
* @input_vars
|
|
|
|
|
* [{"var":"$located","type":"string","desc":"template Located"},
|
|
|
|
|
* {"var":"$template_name","type":"string","desc":"Template Name"},
|
|
|
|
|
* {"var":"$path","type":"string","desc":"Template Path at server"},
|
|
|
|
|
* {"var":"$t_args","type":"array","desc":"Template Arguments"}]
|
|
|
|
|
* @change_log
|
|
|
|
|
* ["Since: 2.0"]
|
|
|
|
|
* @usage add_filter( 'um_get_template', 'function_name', 10, 4 );
|
|
|
|
|
* @example
|
|
|
|
|
* <?php
|
|
|
|
|
* add_filter( 'um_get_template', 'my_get_template', 10, 4 );
|
|
|
|
|
* function my_get_template( $located, $template_name, $path, $t_args ) {
|
|
|
|
|
* // your code here
|
|
|
|
|
* return $located;
|
|
|
|
|
* }
|
|
|
|
|
* ?>
|
|
|
|
|
*/
|
2017-10-24 17:20:03 +03:00
|
|
|
$located = apply_filters( 'um_get_template', $located, $template_name, $path, $t_args );
|
|
|
|
|
|
|
|
|
|
ob_start();
|
2018-03-02 09:55:49 +02:00
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* UM hook
|
|
|
|
|
*
|
|
|
|
|
* @type action
|
|
|
|
|
* @title um_before_template_part
|
|
|
|
|
* @description Make some action before include template file
|
|
|
|
|
* @input_vars
|
|
|
|
|
* [{"var":"$template_name","type":"string","desc":"Template Name"},
|
|
|
|
|
* {"var":"$path","type":"string","desc":"Template Path at server"},
|
|
|
|
|
* {"var":"$located","type":"string","desc":"template Located"},
|
|
|
|
|
* {"var":"$t_args","type":"array","desc":"Template Arguments"}]
|
|
|
|
|
* @change_log
|
|
|
|
|
* ["Since: 2.0"]
|
|
|
|
|
* @usage add_action( 'um_before_template_part', 'function_name', 10, 4 );
|
|
|
|
|
* @example
|
|
|
|
|
* <?php
|
|
|
|
|
* add_action( 'um_before_template_part', 'my_before_template_part', 10, 4 );
|
|
|
|
|
* function my_before_template_part( $template_name, $path, $located, $t_args ) {
|
|
|
|
|
* // your code here
|
|
|
|
|
* }
|
|
|
|
|
* ?>
|
|
|
|
|
*/
|
2017-10-24 17:20:03 +03:00
|
|
|
do_action( 'um_before_template_part', $template_name, $path, $located, $t_args );
|
|
|
|
|
include( $located );
|
2018-03-02 09:55:49 +02:00
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* UM hook
|
|
|
|
|
*
|
|
|
|
|
* @type action
|
2018-03-09 10:42:08 +02:00
|
|
|
* @title um_after_template_part
|
2018-03-02 09:55:49 +02:00
|
|
|
* @description Make some action after include template file
|
|
|
|
|
* @input_vars
|
|
|
|
|
* [{"var":"$template_name","type":"string","desc":"Template Name"},
|
|
|
|
|
* {"var":"$path","type":"string","desc":"Template Path at server"},
|
|
|
|
|
* {"var":"$located","type":"string","desc":"template Located"},
|
|
|
|
|
* {"var":"$t_args","type":"array","desc":"Template Arguments"}]
|
|
|
|
|
* @change_log
|
|
|
|
|
* ["Since: 2.0"]
|
|
|
|
|
* @usage add_action( 'um_after_template_part', 'function_name', 10, 4 );
|
|
|
|
|
* @example
|
|
|
|
|
* <?php
|
|
|
|
|
* add_action( 'um_after_template_part', 'my_after_template_part', 10, 4 );
|
|
|
|
|
* function my_after_template_part( $template_name, $path, $located, $t_args ) {
|
|
|
|
|
* // your code here
|
|
|
|
|
* }
|
|
|
|
|
* ?>
|
|
|
|
|
*/
|
2017-10-24 17:20:03 +03:00
|
|
|
do_action( 'um_after_template_part', $template_name, $path, $located, $t_args );
|
|
|
|
|
$html = ob_get_clean();
|
|
|
|
|
|
|
|
|
|
if ( ! $echo ) {
|
|
|
|
|
return $html;
|
|
|
|
|
} else {
|
|
|
|
|
echo $html;
|
2017-12-11 09:53:38 +02:00
|
|
|
return;
|
2017-10-24 17:20:03 +03:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Locate a template and return the path for inclusion.
|
|
|
|
|
*
|
|
|
|
|
* @access public
|
|
|
|
|
* @param string $template_name
|
|
|
|
|
* @param string $path (default: '')
|
|
|
|
|
* @return string
|
|
|
|
|
*/
|
|
|
|
|
function locate_template( $template_name, $path = '' ) {
|
|
|
|
|
// check if there is template at theme folder
|
|
|
|
|
$template = locate_template( array(
|
|
|
|
|
trailingslashit( 'ultimate-member/' . $path ) . $template_name
|
|
|
|
|
) );
|
|
|
|
|
|
|
|
|
|
if( !$template ) {
|
|
|
|
|
if( $path ) {
|
2017-10-25 17:11:58 +03:00
|
|
|
$template = trailingslashit( trailingslashit( WP_PLUGIN_DIR ) . $path );
|
2017-10-24 17:20:03 +03:00
|
|
|
} else {
|
2017-10-25 17:11:58 +03:00
|
|
|
$template = trailingslashit( um_path );
|
2017-10-24 17:20:03 +03:00
|
|
|
}
|
2017-10-25 17:11:58 +03:00
|
|
|
$template .= 'templates/' . $template_name;
|
2017-10-24 17:20:03 +03:00
|
|
|
}
|
2018-03-02 09:55:49 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* UM hook
|
|
|
|
|
*
|
|
|
|
|
* @type filter
|
|
|
|
|
* @title um_locate_template
|
|
|
|
|
* @description Change template locate
|
|
|
|
|
* @input_vars
|
|
|
|
|
* [{"var":"$template","type":"string","desc":"Template locate"},
|
|
|
|
|
* {"var":"$template_name","type":"string","desc":"Template Name"},
|
|
|
|
|
* {"var":"$path","type":"string","desc":"Template Path at server"}]
|
|
|
|
|
* @change_log
|
|
|
|
|
* ["Since: 2.0"]
|
|
|
|
|
* @usage add_filter( 'um_locate_template', 'function_name', 10, 3 );
|
|
|
|
|
* @example
|
|
|
|
|
* <?php
|
|
|
|
|
* add_filter( 'um_locate_template', 'my_locate_template', 10, 3 );
|
|
|
|
|
* function my_locate_template( $template, $template_name, $path ) {
|
|
|
|
|
* // your code here
|
|
|
|
|
* return $template;
|
|
|
|
|
* }
|
|
|
|
|
* ?>
|
|
|
|
|
*/
|
2017-10-24 17:20:03 +03:00
|
|
|
return apply_filters( 'um_locate_template', $template, $template_name, $path );
|
|
|
|
|
}
|
|
|
|
|
|
2017-07-26 14:57:52 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|