* @example * */ $base_uri = apply_filters( 'um_emoji_base_uri', 'https://s.w.org/images/core/emoji/' ); $this->emoji[':)'] = $base_uri . '72x72/1f604.png'; $this->emoji[':smiley:'] = $base_uri . '72x72/1f603.png'; $this->emoji[':D'] = $base_uri . '72x72/1f600.png'; $this->emoji[':$'] = $base_uri . '72x72/1f60a.png'; $this->emoji[':relaxed:'] = $base_uri . '72x72/263a.png'; $this->emoji[';)'] = $base_uri . '72x72/1f609.png'; $this->emoji[':heart_eyes:'] = $base_uri . '72x72/1f60d.png'; $this->emoji[':kissing_heart:'] = $base_uri . '72x72/1f618.png'; $this->emoji[':kissing_closed_eyes:'] = $base_uri . '72x72/1f61a.png'; $this->emoji[':kissing:'] = $base_uri . '72x72/1f617.png'; $this->emoji[':kissing_smiling_eyes:'] = $base_uri . '72x72/1f619.png'; $this->emoji[';P'] = $base_uri . '72x72/1f61c.png'; $this->emoji[':P'] = $base_uri . '72x72/1f61b.png'; $this->emoji[':stuck_out_tongue_closed_eyes:'] = $base_uri . '72x72/1f61d.png'; $this->emoji[':flushed:'] = $base_uri . '72x72/1f633.png'; $this->emoji[':grin:'] = $base_uri . '72x72/1f601.png'; $this->emoji[':pensive:'] = $base_uri . '72x72/1f614.png'; $this->emoji[':relieved:'] = $base_uri . '72x72/1f60c.png'; $this->emoji[':unamused'] = $base_uri . '72x72/1f612.png'; $this->emoji[':('] = $base_uri . '72x72/1f61e.png'; $this->emoji[':persevere:'] = $base_uri . '72x72/1f623.png'; $this->emoji[":'("] = $base_uri . '72x72/1f622.png'; $this->emoji[':joy:'] = $base_uri . '72x72/1f602.png'; $this->emoji[':sob:'] = $base_uri . '72x72/1f62d.png'; $this->emoji[':sleepy:'] = $base_uri . '72x72/1f62a.png'; $this->emoji[':disappointed_relieved:'] = $base_uri . '72x72/1f625.png'; $this->emoji[':cold_sweat:'] = $base_uri . '72x72/1f630.png'; $this->emoji[':sweat_smile:'] = $base_uri . '72x72/1f605.png'; $this->emoji[':sweat:'] = $base_uri . '72x72/1f613.png'; $this->emoji[':weary:'] = $base_uri . '72x72/1f629.png'; $this->emoji[':tired_face:'] = $base_uri . '72x72/1f62b.png'; $this->emoji[':fearful:'] = $base_uri . '72x72/1f628.png'; $this->emoji[':scream:'] = $base_uri . '72x72/1f631.png'; $this->emoji[':angry:'] = $base_uri . '72x72/1f620.png'; $this->emoji[':rage:'] = $base_uri . '72x72/1f621.png'; $this->emoji[':triumph'] = $base_uri . '72x72/1f624.png'; $this->emoji[':confounded:'] = $base_uri . '72x72/1f616.png'; $this->emoji[':laughing:'] = $base_uri . '72x72/1f606.png'; $this->emoji[':yum:'] = $base_uri . '72x72/1f60b.png'; $this->emoji[':mask:'] = $base_uri . '72x72/1f637.png'; $this->emoji[':cool:'] = $base_uri . '72x72/1f60e.png'; $this->emoji[':sleeping:'] = $base_uri . '72x72/1f634.png'; $this->emoji[':dizzy_face:'] = $base_uri . '72x72/1f635.png'; $this->emoji[':astonished:'] = $base_uri . '72x72/1f632.png'; $this->emoji[':worried:'] = $base_uri . '72x72/1f61f.png'; $this->emoji[':frowning:'] = $base_uri . '72x72/1f626.png'; $this->emoji[':anguished:'] = $base_uri . '72x72/1f627.png'; $this->emoji[':smiling_imp:'] = $base_uri . '72x72/1f608.png'; $this->emoji[':imp:'] = $base_uri . '72x72/1f47f.png'; $this->emoji[':open_mouth:'] = $base_uri . '72x72/1f62e.png'; $this->emoji[':grimacing:'] = $base_uri . '72x72/1f62c.png'; $this->emoji[':neutral_face:'] = $base_uri . '72x72/1f610.png'; $this->emoji[':confused:'] = $base_uri . '72x72/1f615.png'; $this->emoji[':hushed:'] = $base_uri . '72x72/1f62f.png'; $this->emoji[':no_mouth:'] = $base_uri . '72x72/1f636.png'; $this->emoji[':innocent:'] = $base_uri . '72x72/1f607.png'; $this->emoji[':smirk:'] = $base_uri . '72x72/1f60f.png'; $this->emoji[':expressionless:'] = $base_uri . '72x72/1f611.png'; } /** * Conditional logout form * * @param array $args * * @return array */ function display_logout_form( $args ) { if ( is_user_logged_in() && isset( $args['mode'] ) && $args['mode'] == 'login' ) { if ( isset( UM()->user()->preview ) && UM()->user()->preview ) { return $args; } if ( get_current_user_id() != um_user( 'ID' ) ) { um_fetch_user( get_current_user_id() ); } $args['template'] = 'logout'; } return $args; } /** * Filter shortcode args * * @param array $args * * @return array */ function parse_shortcode_args( $args ) { if ( $this->message_mode == true ) { if ( ! empty( $_REQUEST['um_role'] ) ) { $args['template'] = 'message'; $roleID = sanitize_key( $_REQUEST['um_role'] ); $role = UM()->roles()->role_data( $roleID ); if ( ! empty( $role ) && ! empty( $role['status'] ) ) { $message_key = $role['status'] . '_message'; $this->custom_message = ! empty( $role[ $message_key ] ) ? $this->convert_user_tags( stripslashes( $role[ $message_key ] ) ) : ''; } } } foreach ( $args as $k => $v ) { $args[ $k ] = maybe_unserialize( $args[ $k ] ); } return $args; } /** * Emoji support * * @param $content * * @return mixed|string */ function emotize( $content ) { $content = stripslashes( $content ); foreach ( $this->emoji as $code => $val ) { $regex = str_replace(array('(', ')'), array("\\" . '(', "\\" . ')'), $code); $content = preg_replace('/(' . $regex . ')(\s|$)/', '' . $code . '$2', $content); } return $content; } /** * Remove wpautop filter for post content if it's UM core page */ function is_um_page() { if ( is_ultimatemember() ) { remove_filter( 'the_content', 'wpautop' ); } } /** * Extend body classes. * * @param array $classes * * @return array */ public function body_class( $classes ) { $array = UM()->config()->permalinks; if ( ! $array ) { return $classes; } foreach ( $array as $slug => $info ) { if ( um_is_core_page( $slug ) ) { $classes[] = 'um-page'; $classes[] = 'um-page-' . $slug; if ( is_user_logged_in() ) { $classes[] = 'um-page-loggedin'; } else { $classes[] = 'um-page-loggedout'; } } } if ( um_is_core_page( 'user' ) && um_is_user_himself() ) { $classes[] = 'um-own-profile'; } return $classes; } /** * Retrieve core login form * * @return int */ function core_login_form() { $forms = get_posts(array('post_type' => 'um_form', 'posts_per_page' => 1, 'meta_key' => '_um_core', 'meta_value' => 'login')); $form_id = isset( $forms[0]->ID ) ? $forms[0]->ID: 0; return $form_id; } /** * Load a compatible template * * @param $tpl */ function load_template( $tpl ) { $loop = ( $this->loop ) ? $this->loop : array(); if ( isset( $this->set_args ) && is_array( $this->set_args ) ) { $args = $this->set_args; unset( $args['file'], $args['theme_file'], $args['tpl'] ); $args = apply_filters( 'um_template_load_args', $args, $tpl ); /* * This use of extract() cannot be removed. There are many possible ways that * templates could depend on variables that it creates existing, and no way to * detect and deprecate it. * * Passing the EXTR_SKIP flag is the safest option, ensuring globals and * function variables cannot be overwritten. */ // phpcs:ignore WordPress.PHP.DontExtract.extract_extract extract( $args, EXTR_SKIP ); } $file = UM_PATH . "templates/{$tpl}.php"; $theme_file = get_stylesheet_directory() . "/ultimate-member/templates/{$tpl}.php"; if ( file_exists( $theme_file ) ) { $file = $theme_file; } if ( file_exists( $file ) ) { // Avoid Directory Traversal vulnerability by the checking the realpath. // Templates can be situated only in the get_stylesheet_directory() or plugindir templates. $real_file = wp_normalize_path( realpath( $file ) ); if ( 0 === strpos( $real_file, wp_normalize_path( UM_PATH . "templates" . DIRECTORY_SEPARATOR ) ) || 0 === strpos( $real_file, wp_normalize_path( get_stylesheet_directory() . DIRECTORY_SEPARATOR . 'ultimate-member' . DIRECTORY_SEPARATOR . 'templates' . DIRECTORY_SEPARATOR ) ) ) { include $file; } } } /** * Add class based on shortcode * * @param $mode * @param array $args * * @return mixed|string|void */ function get_class($mode, $args = array()) { $classes = 'um-' . $mode; if (is_admin()) { $classes .= ' um-in-admin'; } if (isset(UM()->form()->errors) && UM()->form()->errors) { $classes .= ' um-err'; } if ( true === UM()->fields()->editing ) { $classes .= ' um-editing'; } if ( true === UM()->fields()->viewing ) { $classes .= ' um-viewing'; } if (isset($args['template']) && $args['template'] != $args['mode']) { $classes .= ' um-' . $args['template']; } /** * UM hook * * @type filter * @title um_form_official_classes__hook * @description Change official form classes * @input_vars * [{"var":"$classes","type":"string","desc":"Classes string"}] * @change_log * ["Since: 2.0"] * @usage * * @example * */ $classes = apply_filters( 'um_form_official_classes__hook', $classes ); return $classes; } /** * Logged-in only content * * @param array $args * @param string $content * * @return string */ public function um_loggedin( $args = array(), $content = '' ) { $args = shortcode_atts( array( 'lock_text' => __( 'This content has been restricted to logged-in users only. Please login to view this content.', 'ultimate-member' ), 'show_lock' => 'yes', ), $args, 'um_loggedin' ); if ( ! is_user_logged_in() ) { // Hide content for not logged-in users. Maybe display locked content notice. if ( 'no' === $args['show_lock'] ) { return ''; } $args['lock_text'] = $this->convert_locker_tags( $args['lock_text'] ); return UM()->get_template( 'login-to-view.php', '', $args ); } $prepared_content = wp_kses( apply_shortcodes( $this->convert_locker_tags( wpautop( $content ) ) ), UM()->get_allowed_html( 'templates' ) ); /** * Filters prepared inner content via Ultimate Member handlers in [um_loggedin] shortcode. * * @since 2.8.7 * @hook um_loggedin_inner_content * * @param {string} $prepared_content Prepared inner content via Ultimate Member handlers. * @param {string} $content Original inner content. * * @return {string} Prepared inner content. * * @example Change inner content with own handlers. * function my_um_loggedin_inner_content( $prepared_content, $content ) { * $prepared_content = esc_html( $content ); * return $prepared_content; * } * add_filter( 'um_loggedin_inner_content', 'my_um_loggedin_inner_content', 10, 2 ); */ return apply_filters( 'um_loggedin_inner_content', $prepared_content, $content ); } /** * Logged-out only content * * @param array $args * @param string $content * * @return string */ public function um_loggedout( $args = array(), $content = '' ) { if ( is_user_logged_in() ) { // Hide for logged-in users return ''; } return apply_shortcodes( $this->convert_locker_tags( wpautop( $content ) ) ); } /** * Display post author's link to UM User Profile. * * @since 2.8.2 * * Example 1: [um_author_profile_link] current post author User Profile URL * Example 2: [um_author_profile_link title="User profile" user_id="29"] * Example 3: [um_author_profile_link title="User profile" user_id="29"]Visit Author Profile[/um_author_profile_link] * Example 4: [um_author_profile_link raw="1"] for result like http://localhost:8000/user/janedoe/ * * @param array $attr { * Attributes of the shortcode. * * @type string $class A link class. * @type string $title A link text. * @type int $user_id User ID. Author ID if empty. * @type bool $raw Get raw URL or link layout. `false` by default. * } * @param string $content * @return string Profile link HTML or profile link URL if the link text is empty. */ public function author_profile_link( $attr = array(), $content = '' ) { $default_user_id = 0; if ( is_singular() ) { $default_user_id = get_post()->post_author; } elseif ( is_author() ) { $default_user_id = get_the_author_meta( 'ID' ); } $defaults_atts = array( 'class' => 'um-link um-profile-link', 'title' => __( 'Go to profile', 'ultimate-member' ), 'user_id' => $default_user_id, 'raw' => false, ); $atts = shortcode_atts( $defaults_atts, $attr, 'um_author_profile_link' ); if ( empty( $atts['user_id'] ) ) { return ''; } $user_id = absint( $atts['user_id'] ); $url = um_user_profile_url( $user_id ); if ( empty( $url ) ) { return ''; } if ( ! empty( $atts['raw'] ) ) { return $url; } $title = ! empty( $atts['title'] ) ? $atts['title'] : __( 'Go to profile', 'ultimate-member' ); $link_html = empty( $content ) ? $title : $content; return '' . wp_kses_post( $link_html ) . ''; } /** * @param array $args * * @return string */ function ultimatemember_login( $args = array() ) { global $wpdb; $args = ! empty( $args ) ? $args : array(); $default_login = $wpdb->get_var( "SELECT pm.post_id FROM {$wpdb->postmeta} pm LEFT JOIN {$wpdb->postmeta} pm2 ON( pm.post_id = pm2.post_id AND pm2.meta_key = '_um_is_default' ) WHERE pm.meta_key = '_um_mode' AND pm.meta_value = 'login' AND pm2.meta_value = '1'" ); $args['form_id'] = $default_login; $shortcode_attrs = ''; foreach ( $args as $key => $value ) { $shortcode_attrs .= " {$key}=\"{$value}\""; } if ( version_compare( get_bloginfo('version'),'5.4', '<' ) ) { return do_shortcode( "[ultimatemember {$shortcode_attrs} /]" ); } else { return apply_shortcodes( "[ultimatemember {$shortcode_attrs} /]" ); } } /** * @param array $args * * @return string */ function ultimatemember_register( $args = array() ) { global $wpdb; $args = ! empty( $args ) ? $args : array(); $default_register = $wpdb->get_var( "SELECT pm.post_id FROM {$wpdb->postmeta} pm LEFT JOIN {$wpdb->postmeta} pm2 ON( pm.post_id = pm2.post_id AND pm2.meta_key = '_um_is_default' ) WHERE pm.meta_key = '_um_mode' AND pm.meta_value = 'register' AND pm2.meta_value = '1'" ); $args['form_id'] = $default_register; $shortcode_attrs = ''; foreach ( $args as $key => $value ) { $shortcode_attrs .= " {$key}=\"{$value}\""; } if ( version_compare( get_bloginfo('version'),'5.4', '<' ) ) { return do_shortcode( "[ultimatemember {$shortcode_attrs} /]" ); } else { return apply_shortcodes( "[ultimatemember {$shortcode_attrs} /]" ); } } /** * @param array $args * * @return string */ function ultimatemember_profile( $args = array() ) { global $wpdb; $args = ! empty( $args ) ? $args : array(); $default_profile = $wpdb->get_var( "SELECT pm.post_id FROM {$wpdb->postmeta} pm LEFT JOIN {$wpdb->postmeta} pm2 ON( pm.post_id = pm2.post_id AND pm2.meta_key = '_um_is_default' ) WHERE pm.meta_key = '_um_mode' AND pm.meta_value = 'profile' AND pm2.meta_value = '1'" ); $args['form_id'] = $default_profile; $shortcode_attrs = ''; foreach ( $args as $key => $value ) { $shortcode_attrs .= " {$key}=\"{$value}\""; } if ( version_compare( get_bloginfo('version'),'5.4', '<' ) ) { return do_shortcode( "[ultimatemember {$shortcode_attrs} /]" ); } else { return apply_shortcodes( "[ultimatemember {$shortcode_attrs} /]" ); } } /** * @param array $args * * @return string */ function ultimatemember_directory( $args = array() ) { global $wpdb; $args = ! empty( $args ) ? $args : array(); $default_directory = $wpdb->get_var( "SELECT pm.post_id FROM {$wpdb->postmeta} pm LEFT JOIN {$wpdb->postmeta} pm2 ON( pm.post_id = pm2.post_id AND pm2.meta_key = '_um_is_default' ) WHERE pm.meta_key = '_um_mode' AND pm.meta_value = 'directory' AND pm2.meta_value = '1'" ); $args['form_id'] = $default_directory; $shortcode_attrs = ''; foreach ( $args as $key => $value ) { $shortcode_attrs .= " {$key}=\"{$value}\""; } if ( version_compare( get_bloginfo('version'),'5.4', '<' ) ) { return do_shortcode( "[ultimatemember {$shortcode_attrs} /]" ); } else { return apply_shortcodes( "[ultimatemember {$shortcode_attrs} /]" ); } } /** * Shortcode * * @param array $args * * @return string */ public function ultimatemember( $args = array() ) { // There is possible to use 'shortcode_atts_ultimatemember' filter for getting customized `$args`. $args = shortcode_atts( array( 'form_id' => '', 'is_block' => false, ), $args, 'ultimatemember' ); // Sanitize shortcode arguments. $args['form_id'] = ! empty( $args['form_id'] ) ? absint( $args['form_id'] ) : ''; $args['is_block'] = (bool) $args['is_block']; $form_post = get_post( $args['form_id'] ); // Invalid post ID. Maybe post doesn't exist. if ( empty( $form_post ) ) { return ''; } // Invalid post type. It can be only `um_form` or `um_directory` $post_types = array( 'um_form' ); if ( UM()->options()->get( 'members_page' ) ) { $post_types[] = 'um_directory'; } if ( ! in_array( $form_post->post_type, $post_types, true ) ) { return ''; } /** * Filters variable for enable singleton shortcode loading on the same page. * Note: Set it to `false` if you don't need to render the same form twice or more on the same page. * * @since 2.6.8 * @since 2.6.9 $disable argument set to `true` by default * * @hook um_ultimatemember_shortcode_disable_singleton * * @param {bool} $disable Disabled singleton. By default, it's `true`. * @param {array} $args Shortcode arguments. * * @return {bool} Disabled singleton or not. * * @example Turn off ability to use ultimatemember shortcode twice. * add_filter( 'um_ultimatemember_shortcode_disable_singleton', '__return_false' ); */ $disable_singleton_shortcode = apply_filters( 'um_ultimatemember_shortcode_disable_singleton', true, $args ); if ( false === $disable_singleton_shortcode ) { if ( isset( $args['form_id'] ) ) { $id = $args['form_id']; if ( isset( $this->forms_exist[ $id ] ) && true === $this->forms_exist[ $id ] ) { return ''; } $this->forms_exist[ $id ] = true; } } return $this->load( $args ); } /** * Load a module with global function * * @param $args * * @return string */ public function load( $args ) { $defaults = array(); $args = wp_parse_args( $args, $defaults ); // When to not continue. if ( ! array_key_exists( 'form_id', $args ) ) { return ''; } $this->form_id = $args['form_id']; if ( empty( $this->form_id ) ) { return ''; } $this->form_status = get_post_status( $this->form_id ); if ( 'publish' !== $this->form_status ) { return ''; } UM()->fields()->set_id = absint( $this->form_id ); // get data into one global array $post_data = UM()->query()->post_data( $this->form_id ); $args = array_merge( $args, $post_data ); ob_start(); /** * Filters arguments for loading Ultimate Member shortcodes. * * @since 1.3.x * @hook um_pre_args_setup * * @param {array} $args Data for loading shortcode. * * @return {array} Data for loading shortcode. * * @example Change arguments on load shortcode. * function my_pre_args_setup( $args ) { * // your code here * return $args; * } * add_filter( 'um_pre_args_setup', 'my_pre_args_setup' ); */ $args = apply_filters( 'um_pre_args_setup', $args ); if ( ! isset( $args['template'] ) ) { $args['template'] = ''; } if ( isset( $post_data['template'] ) && $post_data['template'] !== $args['template'] ) { $args['template'] = $post_data['template']; } if ( ! $this->template_exists( $args['template'] ) ) { $args['template'] = $post_data['mode']; } if ( ! isset( $post_data['template'] ) ) { $post_data['template'] = $post_data['mode']; } if ( 'directory' === $args['mode'] ) { wp_enqueue_script( 'um_members' ); wp_enqueue_style( 'um_members' ); } if ( 'directory' !== $args['mode'] ) { $args = array_merge( $post_data, $args ); if ( empty( $args['use_custom_settings'] ) ) { $args = array_merge( $args, $this->get_css_args( $args ) ); } else { $args = array_merge( $this->get_css_args( $args ), $args ); } } /** * Filters change arguments on load shortcode. * * @since 1.3.x * @hook um_shortcode_args_filter * * @param {array} $args Shortcode arguments. * * @return {array} Shortcode arguments. * * @example Change arguments on load shortcode. * function my_shortcode_args( $args ) { * // your code here * return $args; * } * add_filter( 'um_shortcode_args_filter', 'my_shortcode_args' ); */ $args = apply_filters( 'um_shortcode_args_filter', $args ); if ( ! array_key_exists( 'mode', $args ) || ! array_key_exists( 'template', $args ) ) { ob_get_clean(); return ''; } $mode = $args['mode']; // Not display on admin preview. if ( empty( $_POST['act_id'] ) || 'um_admin_preview_form' !== sanitize_key( $_POST['act_id'] ) ) { // phpcs:ignore WordPress.Security.NonceVerification /** * Filters the ability to show registration form for the logged-in users. * Set it to true for displaying registration form for the logged-in users. * * @since 2.1.20 * @hook um_registration_for_loggedin_users * * @param {bool} $show Show registration form for the logged-in users. By default, it's false * @param {array} $args Shortcode arguments. * * @return {bool} Show registration form for the logged-in users. * * @example Show registration form for the logged-in users for all UM registration forms on your website. * add_filter( 'um_registration_for_loggedin_users', '__return_true' ); */ $enable_loggedin_registration = apply_filters( 'um_registration_for_loggedin_users', false, $args ); if ( ! $enable_loggedin_registration && 'register' === $mode && is_user_logged_in() ) { ob_get_clean(); return __( 'You are already registered.', 'ultimate-member' ); } } if ( 'profile' === $mode && ! empty( $args['is_block'] ) && ! is_user_logged_in() ) { ob_get_clean(); return ''; } // For profiles only. if ( 'profile' === $mode && um_profile_id() ) { // Set requested user if it's not setup from permalinks (for not profile page in edit mode). if ( ! um_get_requested_user() ) { um_set_requested_user( um_profile_id() ); } if ( ! empty( $args['use_custom_settings'] ) && ! empty( $args['role'] ) ) { // Option "Apply custom settings to this form". Option "Make this profile form role-specific". // Show the first Profile Form with role selected, don't show profile forms below the page with other role-specific setting. if ( empty( $this->profile_role ) ) { $current_user_roles = UM()->roles()->get_all_user_roles( um_profile_id() ); if ( empty( $current_user_roles ) ) { ob_get_clean(); return ''; } if ( is_array( $args['role'] ) ) { if ( ! count( array_intersect( $args['role'], $current_user_roles ) ) ) { ob_get_clean(); return ''; } } elseif ( ! in_array( $args['role'], $current_user_roles, true ) ) { ob_get_clean(); return ''; } $this->profile_role = $args['role']; } elseif ( $this->profile_role !== $args['role'] ) { ob_get_clean(); return ''; } } } $content = apply_filters( 'um_force_shortcode_render', false, $args ); if ( false !== $content ) { ob_get_clean(); return $content; } /** * Fires before loading form shortcode. * * Note: $mode can be 'profile', 'login', 'register', 'account'. * * @since 1.3.x * @hook um_pre_{$mode}_shortcode * * @param {array} $args Form shortcode arguments. * * @example Make any custom action before loading a registration form shortcode. * function my_pre_register_shortcode( $args ) { * // your code here * } * add_action( 'um_pre_register_shortcode', 'my_pre_register_shortcode' ); * @example Make any custom action before loading a login form shortcode. * function my_pre_login_shortcode( $args ) { * // your code here * } * add_action( 'um_pre_login_shortcode', 'my_pre_login_shortcode' ); * @example Make any custom action before loading a password reset form shortcode. * function my_pre_password_shortcode( $args ) { * // your code here * } * add_action( 'um_pre_password_shortcode', 'my_pre_password_shortcode' ); * @example Make any custom action before loading a profile form shortcode. * function my_pre_profile_shortcode( $args ) { * // your code here * } * add_action( 'um_pre_profile_shortcode', 'my_pre_profile_shortcode' ); * @example Make any custom action before loading an account form shortcode. * function my_pre_account_shortcode( $args ) { * // your code here * } * add_action( 'um_pre_account_shortcode', 'my_pre_account_shortcode' ); */ do_action( "um_pre_{$mode}_shortcode", $args ); /** * Fires before loading form shortcode. * * @since 1.3.x * @hook um_before_form_is_loaded * * @param {array} $args Form shortcode arguments. * * @example Make any custom action before loading UM form shortcode. * function my_pre_shortcode( $args ) { * // your code here * } * add_action( 'um_before_form_is_loaded', 'my_pre_shortcode', 10, 1 ); */ do_action( 'um_before_form_is_loaded', $args ); /** * Fires before loading a form shortcode. * * @since 1.3.x * @todo Deprecate since 2.7.0. Use `um_pre_{$mode}_shortcode` or `um_before_form_is_loaded` instead. * @hook um_before_{$mode}_form_is_loaded * * @param {array} $args Form shortcode arguments. */ do_action( "um_before_{$mode}_form_is_loaded", $args ); $this->template_load( $args['template'], $args ); $this->dynamic_css( $args ); if ( 'logout' === $mode || um_get_requested_user() ) { um_reset_user(); } /** * Fires after load shortcode content. * * @since 2.0 * @hook um_after_everything_output * * @param {array} $args Form shortcode arguments. * * @example Make any custom action after load shortcode content. * function my_pre_shortcode() { * // your code here * } * add_action( 'um_after_everything_output', 'my_pre_shortcode', 10 ); */ do_action( 'um_after_everything_output' ); return ob_get_clean(); } /** * Get dynamic CSS args * * @param $args * @return array */ public function get_css_args( $args ) { $arr = um_styling_defaults( $args['mode'] ); $arr = array_merge( $arr, array( 'form_id' => $args['form_id'], 'mode' => $args['mode'], ) ); return $arr; } /** * Load dynamic CSS. * * @param array $args * * @return string */ public function dynamic_css( $args = array() ) { /** * Filters for disable global dynamic CSS. It's false by default, set it to true to disable. * * @since 2.0 * @hook um_disable_dynamic_global_css * * @param {bool} $disable Disable global CSS. * * @return {bool} Disable global CSS. * * @example Turn off enqueue of global dynamic CSS. * add_filter( 'um_disable_dynamic_global_css', '__return_true' ); */ $disable_css = apply_filters( 'um_disable_dynamic_global_css', false ); if ( $disable_css ) { return ''; } if ( empty( $args['form_id'] ) ) { return ''; } include_once UM_PATH . 'assets/dynamic_css/dynamic-global.php'; if ( array_key_exists( 'mode', $args ) && in_array( $args['mode'], array( 'profile', 'directory' ), true ) ) { $file = UM_PATH . 'assets/dynamic_css/dynamic-' . $args['mode'] . '.php'; if ( file_exists( $file ) ) { include_once $file; } } return ''; } /** * Loads a template file * * @param $template * @param array $args */ public function template_load( $template, $args = array() ) { if ( is_array( $args ) ) { $this->set_args = $args; } $this->load_template( $template ); } /** * Checks if a template file exists * * @param $template * * @return bool */ function template_exists($template) { $file = UM_PATH . 'templates/' . $template . '.php'; $theme_file = get_stylesheet_directory() . '/ultimate-member/templates/' . $template . '.php'; if (file_exists($theme_file) || file_exists($file)) { return true; } return false; } /** * Get File Name without path and extension * * @param $file * * @return mixed|string */ function get_template_name( $file ) { $file = basename( $file ); $file = preg_replace( '/\\.[^.\\s]{3,4}$/', '', $file ); return $file; } /** * Get Templates * * @param null $excluded * * @return mixed */ function get_templates( $excluded = null ) { if ( $excluded ) { $array[ $excluded ] = __( 'Default Template', 'ultimate-member' ); } $paths[] = glob( UM_PATH . 'templates/' . '*.php' ); if ( file_exists( get_stylesheet_directory() . '/ultimate-member/templates/' ) ) { $paths[] = glob( get_stylesheet_directory() . '/ultimate-member/templates/' . '*.php' ); } if ( isset( $paths ) && ! empty( $paths ) ) { foreach ( $paths as $k => $files ) { if ( isset( $files ) && ! empty( $files ) ) { foreach ( $files as $file ) { $clean_filename = $this->get_template_name( $file ); if ( 0 === strpos( $clean_filename, $excluded ) ) { $source = file_get_contents( $file ); $tokens = @\token_get_all( $source ); $comment = array( T_COMMENT, // All comments since PHP5 T_DOC_COMMENT, // PHPDoc comments ); foreach ( $tokens as $token ) { if ( in_array( $token[0], $comment ) && strstr( $token[1], '/* Template:' ) && $clean_filename != $excluded ) { $txt = $token[1]; $txt = str_replace( '/* Template: ', '', $txt ); $txt = str_replace( ' */', '', $txt ); $array[ $clean_filename ] = $txt; } } } } } } } return $array; } /** * Get Shortcode for given form ID * * @param $post_id * * @return string */ function get_shortcode( $post_id ) { $shortcode = '[ultimatemember form_id="' . $post_id . '"]'; return $shortcode; } /** * Get Shortcode for given form ID * * @param $post_id * * @return string */ function get_default_shortcode( $post_id ) { $mode = UM()->query()->get_attr( 'mode', $post_id ); switch ( $mode ) { case 'login': $shortcode = '[ultimatemember_login]'; break; case 'profile': $shortcode = '[ultimatemember_profile]'; break; case 'register': $shortcode = '[ultimatemember_register]'; break; case 'directory': $shortcode = '[ultimatemember_directory]'; break; } return $shortcode; } /** * Convert access lock tags * * @param $str * * @return mixed|string */ public function convert_locker_tags( $str ) { add_filter( 'um_template_tags_patterns_hook', array( &$this, 'add_placeholder' ) ); add_filter( 'um_template_tags_replaces_hook', array( &$this, 'add_replace_placeholder' ) ); return um_convert_tags( $str, array(), false ); } /** * Convert user tags in a string * * @param string $str * * @return string */ public function convert_user_tags( $str ) { $pattern_array = array( '{first_name}', '{last_name}', '{display_name}', '{user_avatar_small}', '{username}', '{nickname}', '{user_email}', ); /** * Filters the user placeholders patterns. * * @since 1.3.x * @hook um_allowed_user_tags_patterns * * @param {array} $patterns User Placeholders. * * @return {array} User Placeholders. * * @example Add the `{user_description}` placeholder. * function my_allowed_user_tags( $patterns ) { * $patterns[] = '{user_description}'; * return $patterns; * } * add_filter( 'um_allowed_user_tags_patterns', 'my_allowed_user_tags' ); */ $pattern_array = apply_filters( 'um_allowed_user_tags_patterns', $pattern_array ); foreach ( $pattern_array as $pattern ) { if ( preg_match( $pattern, $str ) ) { $value = ''; $usermeta = str_replace( array( '{', '}' ), '', $pattern ); if ( is_user_logged_in() ) { if ( 'user_avatar_small' === $usermeta ) { $value = get_avatar( um_user( 'ID' ), 40 ); } elseif ( um_user( $usermeta ) ) { $value = um_user( $usermeta ); } if ( 'username' === $usermeta ) { $value = um_user( 'user_login' ); } if ( 'nickname' === $usermeta ) { $value = um_profile( 'nickname' ); } if ( 'user_email' === $usermeta ) { $value = um_user( 'user_email' ); } /** * Filters the user placeholders value of pattern for logged-in user. * * @since 1.3.x * @hook um_profile_tag_hook__{$usermeta} * * @param {string} $value User meta field value. * @param {int} $id User ID. * * @return {string} User meta field value. * * @example Add the replacement value for `{user_description}` placeholder. * function my_user_description( $value, $user_id ) { * $value = get_user_meta( $user_id, 'user_description', true ); * return $value; * } * add_filter( 'um_profile_tag_hook__user_description', 'my_user_description', 10, 2 ); */ $value = apply_filters( "um_profile_tag_hook__{$usermeta}", $value, um_user( 'ID' ) ); } else { /** * Filters the user placeholders value of pattern for not logged-in user. * * @since 2.6.11 * @hook um_profile_nopriv_tag_hook__{$usermeta} * * @param {string} $value User meta field value. * * @return {string} User meta field value. * * @example Add the replacement value for `{user_description}` placeholder for not logged-in user. * function my_nopriv_user_description( $value ) { * $value = ! empty( $_GET['user_description'] ) ? sanitize_text_field( $_GET['user_description'] ) : ''; * return $value; * } * add_filter( 'um_profile_nopriv_tag_hook__user_description', 'my_nopriv_user_description' ); */ $value = apply_filters( "um_profile_nopriv_tag_hook__{$usermeta}", $value ); } $str = preg_replace( '/' . $pattern . '/', $value, $str ); } } return $str; } /** * Shortcode: Show custom content to specific role * * Show content to specific roles * [um_show_content roles='member'] [/um_show_content] * You can add multiple target roles, just use ',' e.g. [um_show_content roles='member,candidates,pets'] * * Hide content from specific roles * [um_show_content not='contributors'] [/um_show_content] * You can add multiple target roles, just use ',' e.g. [um_show_content roles='member,candidates,pets'] * * @param array $atts * @param string $content * @return string */ public function um_shortcode_show_content_for_role( $atts = array(), $content = '' ) { global $user_ID; if ( ! is_user_logged_in() ) { return ''; } $a = shortcode_atts( array( 'roles' => '', 'not' => '', 'is_profile' => false, ), $atts, 'um_show_content' ); if ( $a['is_profile'] ) { um_fetch_user( um_profile_id() ); } else { um_fetch_user( $user_ID ); } $current_user_roles = um_user( 'roles' ); if ( ! empty( $a['not'] ) && ! empty( $a['roles'] ) ) { return apply_shortcodes( $this->convert_locker_tags( $content ) ); } if ( ! empty( $a['not'] ) ) { $not_in_roles = explode( ',', $a['not'] ); if ( is_array( $not_in_roles ) && ( empty( $current_user_roles ) || count( array_intersect( $current_user_roles, $not_in_roles ) ) <= 0 ) ) { return apply_shortcodes( $this->convert_locker_tags( $content ) ); } } else { $roles = explode( ',', $a['roles'] ); if ( ! empty( $current_user_roles ) && is_array( $roles ) && count( array_intersect( $current_user_roles, $roles ) ) > 0 ) { return apply_shortcodes( $this->convert_locker_tags( $content ) ); } } return ''; } /** * @param array $args * @param string $content * * @return string */ public function ultimatemember_searchform( $args = array(), $content = '' ) { if ( ! UM()->options()->get( 'members_page' ) ) { return ''; } $member_directory_ids = array(); $page_id = UM()->config()->permalinks['members']; if ( ! empty( $page_id ) ) { $member_directory_ids = UM()->member_directory()->get_member_directory_id( $page_id ); } if ( empty( $member_directory_ids ) ) { return ''; } //current user priority role $priority_user_role = false; if ( is_user_logged_in() ) { $priority_user_role = UM()->roles()->get_priority_user_role( get_current_user_id() ); } $query = array(); foreach ( $member_directory_ids as $directory_id ) { $directory_data = UM()->query()->post_data( $directory_id ); if ( isset( $directory_data['roles_can_search'] ) ) { $directory_data['roles_can_search'] = maybe_unserialize( $directory_data['roles_can_search'] ); } $show_search = empty( $directory_data['roles_can_search'] ) || ( ! empty( $priority_user_role ) && in_array( $priority_user_role, $directory_data['roles_can_search'] ) ); if ( empty( $directory_data['search'] ) || ! $show_search ) { continue; } $hash = UM()->member_directory()->get_directory_hash( $directory_id ); $query[ 'search_' . $hash ] = ! empty( $_GET[ 'search_' . $hash ] ) ? sanitize_text_field( $_GET[ 'search_' . $hash ] ) : ''; } if ( empty( $query ) ) { return ''; } $search_value = array_values( $query ); $t_args = array( 'query' => $query, 'search_value' => $search_value[0], 'members_page' => um_get_core_page( 'members' ), ); return UM()->get_template( 'searchform.php', '', $t_args ); } /** * UM Placeholders for login referrer * * @param array $placeholders * * @return array */ public function add_placeholder( $placeholders ) { $placeholders[] = '{login_referrer}'; return $placeholders; } /** * UM Replace Placeholders for login referrer * * @param array $replace_placeholders * * @return array */ public function add_replace_placeholder( $replace_placeholders ) { $replace_placeholders[] = um_dynamic_login_page_redirect(); return $replace_placeholders; } } }