Version Description
- Feature: Added option to display Elementor sections and widgets to logged out users
- Fix: Position of password strength on the reset password form
- Fix: An issue with the password reset shortcode generating invalid HTML in a case
Download this release
Release Info
Developer | raster02 |
Plugin | User registration & user profile – Profile Builder |
Version | 3.5.3 |
Comparing to | |
See all releases |
Code changes from version 3.5.2 to 3.5.3
- admin/basic-info.php +1 -1
- assets/css/style-front-end.css +16 -7
- assets/misc/elementor/class-elementor.php +2 -0
- assets/misc/elementor/widgets/class-pb-widget-base.php +13 -1
- assets/misc/elementor/widgets/class-pb-widget-ul.php +192 -0
- features/content-restriction/class-elementor-content-restriction.php +26 -0
- front-end/class-formbuilder.php +4 -4
- front-end/recover.php +7 -6
- index.php +2 -2
- readme.txt +6 -1
- translation/profile-builder-de_DE.mo +0 -0
- translation/profile-builder-de_DE.po +3 -4
admin/basic-info.php
CHANGED
@@ -28,7 +28,7 @@ function wppb_basic_info_content() {
|
|
28 |
?>
|
29 |
<div class="wrap wppb-wrap wppb-info-wrap">
|
30 |
<div class="wppb-badge <?php echo esc_attr( $version ); ?>"><span><?php printf( esc_html__( 'Version %s', 'profile-builder' ), esc_html( PROFILE_BUILDER_VERSION ) ); ?></span></div>
|
31 |
-
<h1><?php
|
32 |
<p class="wppb-info-text"><?php printf( esc_html__( 'The best way to add front-end registration, edit profile and login forms.', 'profile-builder' ) ); ?></p>
|
33 |
<hr />
|
34 |
<?php
|
28 |
?>
|
29 |
<div class="wrap wppb-wrap wppb-info-wrap">
|
30 |
<div class="wppb-badge <?php echo esc_attr( $version ); ?>"><span><?php printf( esc_html__( 'Version %s', 'profile-builder' ), esc_html( PROFILE_BUILDER_VERSION ) ); ?></span></div>
|
31 |
+
<h1><?php echo wp_kses_post( sprintf( __( '<strong>Profile Builder </strong> %s', 'profile-builder' ), esc_html( $version ) ) ); ?></h1>
|
32 |
<p class="wppb-info-text"><?php printf( esc_html__( 'The best way to add front-end registration, edit profile and login forms.', 'profile-builder' ) ); ?></p>
|
33 |
<hr />
|
34 |
<?php
|
assets/css/style-front-end.css
CHANGED
@@ -384,18 +384,25 @@ label[for=blog-privacy]{
|
|
384 |
--------------------------------------------------------------*/
|
385 |
|
386 |
.wppb-error,
|
387 |
-
.wppb-warning
|
|
|
|
|
388 |
padding: 6px 9px;
|
389 |
margin: 0 auto 25px;
|
390 |
display: block;
|
391 |
width: 100%;
|
|
|
|
|
|
|
|
|
392 |
box-sizing: border-box;
|
393 |
background: #ffebe8;
|
394 |
border: 1px solid #C00;
|
395 |
}
|
396 |
|
397 |
.wppb-error,
|
398 |
-
.wppb-warning
|
|
|
399 |
color:#222222 !important;
|
400 |
}
|
401 |
|
@@ -414,8 +421,14 @@ label[for=blog-privacy]{
|
|
414 |
text-decoration: underline;
|
415 |
}
|
416 |
|
|
|
|
|
|
|
|
|
|
|
|
|
417 |
.wppb-required{
|
418 |
-
|
419 |
}
|
420 |
|
421 |
.wppb-required,
|
@@ -424,10 +437,6 @@ label[for=blog-privacy]{
|
|
424 |
}
|
425 |
|
426 |
.wppb-success {
|
427 |
-
padding: 6px 9px;
|
428 |
-
margin: 0 auto 25px;
|
429 |
-
display: block;
|
430 |
-
width: 100%;
|
431 |
box-sizing: border-box;
|
432 |
background: #e7f7d3;
|
433 |
border: 1px solid #6c3;
|
384 |
--------------------------------------------------------------*/
|
385 |
|
386 |
.wppb-error,
|
387 |
+
.wppb-warning,
|
388 |
+
.wppb-notice,
|
389 |
+
.wppb-success {
|
390 |
padding: 6px 9px;
|
391 |
margin: 0 auto 25px;
|
392 |
display: block;
|
393 |
width: 100%;
|
394 |
+
}
|
395 |
+
|
396 |
+
.wppb-error,
|
397 |
+
.wppb-warning {
|
398 |
box-sizing: border-box;
|
399 |
background: #ffebe8;
|
400 |
border: 1px solid #C00;
|
401 |
}
|
402 |
|
403 |
.wppb-error,
|
404 |
+
.wppb-warning,
|
405 |
+
.wppb-notice {
|
406 |
color:#222222 !important;
|
407 |
}
|
408 |
|
421 |
text-decoration: underline;
|
422 |
}
|
423 |
|
424 |
+
.wppb-notice {
|
425 |
+
box-sizing: border-box;
|
426 |
+
background: #ccc;
|
427 |
+
border: 1px solid #666;
|
428 |
+
}
|
429 |
+
|
430 |
.wppb-required{
|
431 |
+
color: red;
|
432 |
}
|
433 |
|
434 |
.wppb-required,
|
437 |
}
|
438 |
|
439 |
.wppb-success {
|
|
|
|
|
|
|
|
|
440 |
box-sizing: border-box;
|
441 |
background: #e7f7d3;
|
442 |
border: 1px solid #6c3;
|
assets/misc/elementor/class-elementor.php
CHANGED
@@ -51,6 +51,7 @@ class PB_Elementor {
|
|
51 |
require_once(__DIR__ . '/widgets/class-pb-widget-l.php');
|
52 |
require_once(__DIR__ . '/widgets/class-pb-widget-rp.php');
|
53 |
require_once(__DIR__ . '/widgets/class-pb-widget-rf.php');
|
|
|
54 |
}
|
55 |
|
56 |
/**
|
@@ -63,6 +64,7 @@ class PB_Elementor {
|
|
63 |
\Elementor\Plugin::instance()->widgets_manager->register_widget_type( new PB_Elementor_Login_Widget() );
|
64 |
\Elementor\Plugin::instance()->widgets_manager->register_widget_type( new PB_Elementor_Recover_Password_Widget() );
|
65 |
\Elementor\Plugin::instance()->widgets_manager->register_widget_type( new PB_Elementor_Register_Widget() );
|
|
|
66 |
}
|
67 |
|
68 |
public function add_category( $elements_manager ) {
|
51 |
require_once(__DIR__ . '/widgets/class-pb-widget-l.php');
|
52 |
require_once(__DIR__ . '/widgets/class-pb-widget-rp.php');
|
53 |
require_once(__DIR__ . '/widgets/class-pb-widget-rf.php');
|
54 |
+
require_once(__DIR__ . '/widgets/class-pb-widget-ul.php');
|
55 |
}
|
56 |
|
57 |
/**
|
64 |
\Elementor\Plugin::instance()->widgets_manager->register_widget_type( new PB_Elementor_Login_Widget() );
|
65 |
\Elementor\Plugin::instance()->widgets_manager->register_widget_type( new PB_Elementor_Recover_Password_Widget() );
|
66 |
\Elementor\Plugin::instance()->widgets_manager->register_widget_type( new PB_Elementor_Register_Widget() );
|
67 |
+
\Elementor\Plugin::instance()->widgets_manager->register_widget_type( new PB_Elementor_User_Listing_Widget() );
|
68 |
}
|
69 |
|
70 |
public function add_category( $elements_manager ) {
|
assets/misc/elementor/widgets/class-pb-widget-base.php
CHANGED
@@ -263,7 +263,7 @@ abstract class PB_Elementor_Widget extends \Elementor\Widget_Base {
|
|
263 |
*/
|
264 |
protected function render_widget( $form_type ){
|
265 |
|
266 |
-
if (!($form_type === 'rf' || $form_type === 'epf' || $form_type === 'l' || $form_type === 'rp')) {
|
267 |
return;
|
268 |
}
|
269 |
|
@@ -316,6 +316,18 @@ abstract class PB_Elementor_Widget extends \Elementor\Widget_Base {
|
|
316 |
case 'rp':
|
317 |
include_once( WPPB_PLUGIN_DIR.'/front-end/recover.php' );
|
318 |
return wppb_front_end_password_recovery();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
319 |
}
|
320 |
}
|
321 |
}
|
263 |
*/
|
264 |
protected function render_widget( $form_type ){
|
265 |
|
266 |
+
if (!($form_type === 'rf' || $form_type === 'epf' || $form_type === 'l' || $form_type === 'rp' || $form_type === 'ul')) {
|
267 |
return;
|
268 |
}
|
269 |
|
316 |
case 'rp':
|
317 |
include_once( WPPB_PLUGIN_DIR.'/front-end/recover.php' );
|
318 |
return wppb_front_end_password_recovery();
|
319 |
+
case 'ul':
|
320 |
+
include_once( WPPB_PLUGIN_DIR.'/add-ons/user-listing/userlisting.php' );
|
321 |
+
$atts = [
|
322 |
+
'name' => $settings['pb_name'] === '' ? 'userlisting' : $settings['pb_name'],
|
323 |
+
'single' => $settings['pb_single'] === 'yes',
|
324 |
+
'meta_key' => $settings['pb_meta_key'],
|
325 |
+
'meta_value' => $settings['pb_meta_value'],
|
326 |
+
'include' => $settings['pb_include'],
|
327 |
+
'exclude' => $settings['pb_exclude'],
|
328 |
+
'id' => $settings['pb_id'],
|
329 |
+
];
|
330 |
+
return wppb_user_listing_shortcode( $atts );
|
331 |
}
|
332 |
}
|
333 |
}
|
assets/misc/elementor/widgets/class-pb-widget-ul.php
ADDED
@@ -0,0 +1,192 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
<?php
|
2 |
+
|
3 |
+
// Exit if accessed directly
|
4 |
+
if ( ! defined( 'ABSPATH' ) ) exit;
|
5 |
+
|
6 |
+
require_once "class-pb-widget-base.php";
|
7 |
+
|
8 |
+
/**
|
9 |
+
* Elementor widget for our wppb-list-users shortcode
|
10 |
+
*/
|
11 |
+
class PB_Elementor_User_Listing_Widget extends PB_Elementor_Widget {
|
12 |
+
|
13 |
+
public function __construct($data = [], $args = null) {
|
14 |
+
parent::__construct($data, $args);
|
15 |
+
|
16 |
+
wp_register_script('wppb-userlisting-js', WPPB_PLUGIN_URL . '/add-ons/user-listing/userlisting.js', array('jquery', 'jquery-touch-punch'), PROFILE_BUILDER_VERSION, true);
|
17 |
+
wp_localize_script( 'wppb-userlisting-js', 'wppb_userlisting_obj', array( 'pageSlug' => wppb_get_users_pagination_slug() ) );
|
18 |
+
wp_register_style('wppb-ul-slider-css', WPPB_PLUGIN_URL . '/add-ons/user-listing/jquery-ui-slider.min.css', array(), PROFILE_BUILDER_VERSION );
|
19 |
+
//wp_register_script('jquery-ui-slider');
|
20 |
+
|
21 |
+
}
|
22 |
+
|
23 |
+
public function get_script_depends() {
|
24 |
+
if ( file_exists(WPPB_PLUGIN_DIR . '/add-ons/user-listing/userlisting.php') ) {
|
25 |
+
return [
|
26 |
+
'wppb-userlisting-js',
|
27 |
+
'jquery-ui-slider',
|
28 |
+
];
|
29 |
+
}
|
30 |
+
return [];
|
31 |
+
}
|
32 |
+
|
33 |
+
public function get_style_depends() {
|
34 |
+
$styles = [];
|
35 |
+
if ( file_exists(WPPB_PLUGIN_DIR . '/add-ons/user-listing/userlisting.php') ) {
|
36 |
+
$styles = [
|
37 |
+
'wppb-ul-slider-css',
|
38 |
+
];
|
39 |
+
}
|
40 |
+
return $styles;
|
41 |
+
}
|
42 |
+
|
43 |
+
/**
|
44 |
+
* Get widget name.
|
45 |
+
*
|
46 |
+
*/
|
47 |
+
public function get_name() {
|
48 |
+
return 'wppb-list-users';
|
49 |
+
}
|
50 |
+
|
51 |
+
/**
|
52 |
+
* Get widget title.
|
53 |
+
*
|
54 |
+
*/
|
55 |
+
public function get_title() {
|
56 |
+
return __( 'User Listing', 'profile-builder' );
|
57 |
+
}
|
58 |
+
|
59 |
+
/**
|
60 |
+
* Get widget icon.
|
61 |
+
* to-do
|
62 |
+
*/
|
63 |
+
public function get_icon() {
|
64 |
+
return 'eicon-post-list';
|
65 |
+
}
|
66 |
+
|
67 |
+
/**
|
68 |
+
* Register widget controls.
|
69 |
+
*
|
70 |
+
*/
|
71 |
+
protected function _register_controls() {
|
72 |
+
|
73 |
+
$this->start_controls_section(
|
74 |
+
'pb_user_listing_settings',
|
75 |
+
array(
|
76 |
+
'label' => __( 'Listing Settings', 'profile-builder' ),
|
77 |
+
'tab' => \Elementor\Controls_Manager::TAB_CONTENT,
|
78 |
+
)
|
79 |
+
);
|
80 |
+
|
81 |
+
$this->add_control(
|
82 |
+
'pb_name',
|
83 |
+
array(
|
84 |
+
'label' => __( 'Name', 'profile-builder' ),
|
85 |
+
'type' => \Elementor\Controls_Manager::TEXT,
|
86 |
+
'placeholder' => __( 'Enter Name', 'profile-builder' ),
|
87 |
+
'default' => 'userlisting',
|
88 |
+
)
|
89 |
+
);
|
90 |
+
|
91 |
+
$this->add_control(
|
92 |
+
'pb_single',
|
93 |
+
array(
|
94 |
+
'label' => __('Single', 'profile-builder'),
|
95 |
+
'type' => \Elementor\Controls_Manager::SWITCHER,
|
96 |
+
'label_on' => __('Yes', 'profile-builder'),
|
97 |
+
'label_off' => __('No', 'profile-builder'),
|
98 |
+
'return_value' => 'yes',
|
99 |
+
'default' => '',
|
100 |
+
)
|
101 |
+
);
|
102 |
+
|
103 |
+
$this->add_control(
|
104 |
+
'pb_meta_key',
|
105 |
+
array(
|
106 |
+
'label' => __( 'Meta Key', 'profile-builder' ),
|
107 |
+
'type' => \Elementor\Controls_Manager::TEXT,
|
108 |
+
'placeholder' => __( 'Enter Meta Key', 'profile-builder' ),
|
109 |
+
'default' => '',
|
110 |
+
'condition' => [
|
111 |
+
'pb_single' => '',
|
112 |
+
],
|
113 |
+
)
|
114 |
+
);
|
115 |
+
|
116 |
+
$this->add_control(
|
117 |
+
'pb_meta_value',
|
118 |
+
array(
|
119 |
+
'label' => __( 'Meta Value', 'profile-builder' ),
|
120 |
+
'type' => \Elementor\Controls_Manager::TEXT,
|
121 |
+
'placeholder' => __( 'Enter Meta Value', 'profile-builder' ),
|
122 |
+
'default' => '',
|
123 |
+
'condition' => [
|
124 |
+
'pb_single' => '',
|
125 |
+
'pb_meta_key!' => '',
|
126 |
+
],
|
127 |
+
)
|
128 |
+
);
|
129 |
+
|
130 |
+
$this->add_control(
|
131 |
+
'pb_include',
|
132 |
+
array(
|
133 |
+
'label' => __( 'Include', 'profile-builder' ),
|
134 |
+
'type' => \Elementor\Controls_Manager::TEXT,
|
135 |
+
'placeholder' => __( 'Enter User IDs', 'profile-builder' ),
|
136 |
+
'default' => '',
|
137 |
+
'condition' => [
|
138 |
+
'pb_single' => '',
|
139 |
+
],
|
140 |
+
)
|
141 |
+
);
|
142 |
+
|
143 |
+
$this->add_control(
|
144 |
+
'pb_exclude',
|
145 |
+
array(
|
146 |
+
'label' => __( 'Exclude', 'profile-builder' ),
|
147 |
+
'type' => \Elementor\Controls_Manager::TEXT,
|
148 |
+
'placeholder' => __( 'Enter User IDs', 'profile-builder' ),
|
149 |
+
'default' => '',
|
150 |
+
'condition' => [
|
151 |
+
'pb_single' => '',
|
152 |
+
],
|
153 |
+
)
|
154 |
+
);
|
155 |
+
|
156 |
+
$this->add_control(
|
157 |
+
'pb_id',
|
158 |
+
array(
|
159 |
+
'label' => __( 'ID', 'profile-builder' ),
|
160 |
+
'type' => \Elementor\Controls_Manager::TEXT,
|
161 |
+
'placeholder' => __( 'Enter User ID', 'profile-builder' ),
|
162 |
+
'default' => '',
|
163 |
+
'condition' => [
|
164 |
+
'pb_single' => 'yes',
|
165 |
+
],
|
166 |
+
)
|
167 |
+
);
|
168 |
+
|
169 |
+
$this->end_controls_section();
|
170 |
+
}
|
171 |
+
|
172 |
+
/**
|
173 |
+
* Render widget output in the front-end.
|
174 |
+
*
|
175 |
+
*/
|
176 |
+
protected function render() {
|
177 |
+
$output = $this->render_widget( 'ul' );
|
178 |
+
echo $output; // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
|
179 |
+
|
180 |
+
// check if the form is being displayed in the Elementor editor
|
181 |
+
$is_elementor_edit_mode = false;
|
182 |
+
if( class_exists ( '\Elementor\Plugin' ) ){
|
183 |
+
$is_elementor_edit_mode = \Elementor\Plugin::$instance->editor->is_edit_mode();
|
184 |
+
}
|
185 |
+
|
186 |
+
if ($is_elementor_edit_mode && !empty($output)) {
|
187 |
+
echo '
|
188 |
+
';
|
189 |
+
}
|
190 |
+
}
|
191 |
+
|
192 |
+
}
|
features/content-restriction/class-elementor-content-restriction.php
CHANGED
@@ -90,14 +90,33 @@ class WPPB_Elementor {
|
|
90 |
'label' => __( 'Restrict to logged in users', 'profile-builder' ),
|
91 |
'type' => Controls_Manager::SWITCHER,
|
92 |
'description' => __( 'Allow only logged in users to see this content.', 'profile-builder' ),
|
|
|
|
|
|
|
|
|
93 |
)
|
94 |
);
|
95 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
96 |
$element->add_control(
|
97 |
'wppb_restriction_user_roles_heading', array(
|
98 |
'label' => __( 'Restrict by User Roles', 'profile-builder' ),
|
99 |
'type' => Controls_Manager::HEADING,
|
100 |
'separator' => 'before',
|
|
|
|
|
|
|
101 |
)
|
102 |
);
|
103 |
|
@@ -108,6 +127,9 @@ class WPPB_Elementor {
|
|
108 |
'multiple' => 'true',
|
109 |
'label_block' => 'true',
|
110 |
'description' => __( 'Allow users which have the specified role to see this content.', 'profile-builder' ),
|
|
|
|
|
|
|
111 |
)
|
112 |
);
|
113 |
|
@@ -194,6 +216,10 @@ class WPPB_Elementor {
|
|
194 |
public function is_hidden( $element ) {
|
195 |
$settings = $element->get_settings();
|
196 |
|
|
|
|
|
|
|
|
|
197 |
if( !empty( $settings['wppb_restriction_user_roles'] ) && is_user_logged_in() ) {
|
198 |
|
199 |
$user_data = get_userdata( get_current_user_id() );
|
90 |
'label' => __( 'Restrict to logged in users', 'profile-builder' ),
|
91 |
'type' => Controls_Manager::SWITCHER,
|
92 |
'description' => __( 'Allow only logged in users to see this content.', 'profile-builder' ),
|
93 |
+
'default' => '',
|
94 |
+
'condition' => array(
|
95 |
+
'wppb_restriction_loggedout_users!' => 'yes'
|
96 |
+
)
|
97 |
)
|
98 |
);
|
99 |
|
100 |
+
$element->add_control(
|
101 |
+
'wppb_restriction_loggedout_users', array(
|
102 |
+
'label' => __( 'Restrict to logged out users', 'profile-builder' ),
|
103 |
+
'type' => Controls_Manager::SWITCHER,
|
104 |
+
'description' => __( 'Allow only logged out users to see this content.', 'profile-builder' ),
|
105 |
+
'default' => '',
|
106 |
+
'condition' => array(
|
107 |
+
'wppb_restriction_loggedin_users!' => 'yes'
|
108 |
+
)
|
109 |
+
)
|
110 |
+
);
|
111 |
+
|
112 |
$element->add_control(
|
113 |
'wppb_restriction_user_roles_heading', array(
|
114 |
'label' => __( 'Restrict by User Roles', 'profile-builder' ),
|
115 |
'type' => Controls_Manager::HEADING,
|
116 |
'separator' => 'before',
|
117 |
+
'condition' => array(
|
118 |
+
'wppb_restriction_loggedout_users!' => 'yes'
|
119 |
+
)
|
120 |
)
|
121 |
);
|
122 |
|
127 |
'multiple' => 'true',
|
128 |
'label_block' => 'true',
|
129 |
'description' => __( 'Allow users which have the specified role to see this content.', 'profile-builder' ),
|
130 |
+
'condition' => array(
|
131 |
+
'wppb_restriction_loggedout_users!' => 'yes'
|
132 |
+
)
|
133 |
)
|
134 |
);
|
135 |
|
216 |
public function is_hidden( $element ) {
|
217 |
$settings = $element->get_settings();
|
218 |
|
219 |
+
if( is_user_logged_in() && $settings['wppb_restriction_loggedout_users'] === 'yes' ) {
|
220 |
+
return true;
|
221 |
+
}
|
222 |
+
|
223 |
if( !empty( $settings['wppb_restriction_user_roles'] ) && is_user_logged_in() ) {
|
224 |
|
225 |
$user_data = get_userdata( get_current_user_id() );
|
front-end/class-formbuilder.php
CHANGED
@@ -448,13 +448,13 @@ class Profile_Builder_Form_Creator{
|
|
448 |
do_action( 'wppb_form_args_before_output', $this->args );
|
449 |
$this->args = apply_filters( 'wppb_filter_form_args_before_output', $this->args );
|
450 |
|
451 |
-
echo
|
452 |
echo $this->wppb_output_form_fields( $_REQUEST, $field_check_errors, $this->args['form_fields'] ); /* phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped */ /* properly escaped when created */
|
453 |
-
echo
|
454 |
|
455 |
-
echo
|
456 |
$this->wppb_add_send_credentials_checkbox( $_REQUEST, $this->args['form_type'] );
|
457 |
-
echo
|
458 |
|
459 |
$wppb_form_submit_extra_attr = apply_filters( 'wppb_form_submit_extra_attr', '', $this->args['form_type'], $this->args['ID'] );
|
460 |
?>
|
448 |
do_action( 'wppb_form_args_before_output', $this->args );
|
449 |
$this->args = apply_filters( 'wppb_filter_form_args_before_output', $this->args );
|
450 |
|
451 |
+
echo apply_filters( 'wppb_before_form_fields', '<ul>', $this->args['form_type'], $this->args['ID'] ); /* phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped */
|
452 |
echo $this->wppb_output_form_fields( $_REQUEST, $field_check_errors, $this->args['form_fields'] ); /* phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped */ /* properly escaped when created */
|
453 |
+
echo apply_filters( 'wppb_after_form_fields', '</ul>', $this->args['form_type'], $this->args['ID'], $_REQUEST ); /* phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped */
|
454 |
|
455 |
+
echo apply_filters( 'wppb_before_send_credentials_checkbox', '<ul>', $this->args['form_type'], $this->args['ID'] ); /* phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped */
|
456 |
$this->wppb_add_send_credentials_checkbox( $_REQUEST, $this->args['form_type'] );
|
457 |
+
echo apply_filters( 'wppb_after_send_credentials_checkbox', '</ul>', $this->args['form_type'] ); /* phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped */
|
458 |
|
459 |
$wppb_form_submit_extra_attr = apply_filters( 'wppb_form_submit_extra_attr', '', $this->args['form_type'], $this->args['ID'] );
|
460 |
?>
|
front-end/recover.php
CHANGED
@@ -76,7 +76,9 @@ function wppb_create_recover_password_form( $user, $post_data ){
|
|
76 |
<li class="wppb-form-field passw1">
|
77 |
<label for="passw1">'. esc_html( $password_label ) .'</label>
|
78 |
<input class="password" name="passw1" type="password" id="passw1" value="" autocomplete="off" title="'. esc_attr( wppb_password_length_text() ).'" '. apply_filters( 'wppb_recover_password_extra_attr', '', esc_html( $password_label ), 'password' ) .' />
|
79 |
-
<span class="wppb-description-delimiter">'. wppb_password_length_text() .' '. wppb_password_strength_description() .'</span>
|
|
|
|
|
80 |
</li><!-- .passw1 -->
|
81 |
<input type="hidden" name="userData" value="'. esc_attr( $user->ID ).'"/>
|
82 |
<li class="wppb-form-field passw2">
|
@@ -84,9 +86,6 @@ function wppb_create_recover_password_form( $user, $post_data ){
|
|
84 |
<input class="password" name="passw2" type="password" id="passw2" value="" autocomplete="off" '. apply_filters( 'wppb_recover_password_extra_attr', '', esc_html( $repeat_password_label ), 'repeat_password' ) .' />
|
85 |
</li><!-- .passw2 -->';
|
86 |
|
87 |
-
/* if we have active the password strength checker */
|
88 |
-
$recover_inputPassword .= wppb_password_strength_checker_html();
|
89 |
-
|
90 |
echo apply_filters( 'wppb_recover_password_form_input', $recover_inputPassword, $passw_one, $passw_two, $user->ID ); //phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
|
91 |
?>
|
92 |
</ul>
|
@@ -334,13 +333,15 @@ function wppb_front_end_password_recovery(){
|
|
334 |
}
|
335 |
}elseif ( !email_exists( $username_email ) ){
|
336 |
// check reCAPTCHA
|
337 |
-
$
|
338 |
|
339 |
// if there is no reCAPTCHA error show the invalid email address error
|
340 |
-
if( $
|
341 |
$warning = __('The email address entered wasn\'t found in the database!', 'profile-builder').'<br/>'.__('Please check that you entered the correct email address.', 'profile-builder');
|
342 |
$warning = apply_filters('wppb_recover_password_sent_message2', $warning);
|
343 |
$output .= '<p class="wppb-warning">'.$warning.'</p>';
|
|
|
|
|
344 |
}
|
345 |
}
|
346 |
}
|
76 |
<li class="wppb-form-field passw1">
|
77 |
<label for="passw1">'. esc_html( $password_label ) .'</label>
|
78 |
<input class="password" name="passw1" type="password" id="passw1" value="" autocomplete="off" title="'. esc_attr( wppb_password_length_text() ).'" '. apply_filters( 'wppb_recover_password_extra_attr', '', esc_html( $password_label ), 'password' ) .' />
|
79 |
+
<span class="wppb-description-delimiter">'. wppb_password_length_text() .' '. wppb_password_strength_description() .'</span>'.
|
80 |
+
/* if we have active the password strength checker */
|
81 |
+
wppb_password_strength_checker_html().'
|
82 |
</li><!-- .passw1 -->
|
83 |
<input type="hidden" name="userData" value="'. esc_attr( $user->ID ).'"/>
|
84 |
<li class="wppb-form-field passw2">
|
86 |
<input class="password" name="passw2" type="password" id="passw2" value="" autocomplete="off" '. apply_filters( 'wppb_recover_password_extra_attr', '', esc_html( $repeat_password_label ), 'repeat_password' ) .' />
|
87 |
</li><!-- .passw2 -->';
|
88 |
|
|
|
|
|
|
|
89 |
echo apply_filters( 'wppb_recover_password_form_input', $recover_inputPassword, $passw_one, $passw_two, $user->ID ); //phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
|
90 |
?>
|
91 |
</ul>
|
333 |
}
|
334 |
}elseif ( !email_exists( $username_email ) ){
|
335 |
// check reCAPTCHA
|
336 |
+
$warning = wppb_password_recovery_warning( '', 'wppb_recover_password_displayed_message1' );
|
337 |
|
338 |
// if there is no reCAPTCHA error show the invalid email address error
|
339 |
+
if( $warning === '' ) {
|
340 |
$warning = __('The email address entered wasn\'t found in the database!', 'profile-builder').'<br/>'.__('Please check that you entered the correct email address.', 'profile-builder');
|
341 |
$warning = apply_filters('wppb_recover_password_sent_message2', $warning);
|
342 |
$output .= '<p class="wppb-warning">'.$warning.'</p>';
|
343 |
+
} else {
|
344 |
+
$output .= $warning;
|
345 |
}
|
346 |
}
|
347 |
}
|
index.php
CHANGED
@@ -3,7 +3,7 @@
|
|
3 |
Plugin Name: Profile Builder
|
4 |
Plugin URI: https://www.cozmoslabs.com/wordpress-profile-builder/
|
5 |
Description: Login, registration and edit profile shortcodes for the front-end. Also you can choose what fields should be displayed or add new (custom) ones both in the front-end and in the dashboard.
|
6 |
-
Version: 3.5.
|
7 |
Author: Cozmoslabs
|
8 |
Author URI: https://www.cozmoslabs.com/
|
9 |
Text Domain: profile-builder
|
@@ -70,7 +70,7 @@ function wppb_free_plugin_init() {
|
|
70 |
*
|
71 |
*
|
72 |
*/
|
73 |
-
define('PROFILE_BUILDER_VERSION', '3.5.
|
74 |
define('WPPB_PLUGIN_DIR', plugin_dir_path(__FILE__));
|
75 |
define('WPPB_PLUGIN_URL', plugin_dir_url(__FILE__));
|
76 |
define('WPPB_PLUGIN_BASENAME', plugin_basename(__FILE__));
|
3 |
Plugin Name: Profile Builder
|
4 |
Plugin URI: https://www.cozmoslabs.com/wordpress-profile-builder/
|
5 |
Description: Login, registration and edit profile shortcodes for the front-end. Also you can choose what fields should be displayed or add new (custom) ones both in the front-end and in the dashboard.
|
6 |
+
Version: 3.5.3
|
7 |
Author: Cozmoslabs
|
8 |
Author URI: https://www.cozmoslabs.com/
|
9 |
Text Domain: profile-builder
|
70 |
*
|
71 |
*
|
72 |
*/
|
73 |
+
define('PROFILE_BUILDER_VERSION', '3.5.3' );
|
74 |
define('WPPB_PLUGIN_DIR', plugin_dir_path(__FILE__));
|
75 |
define('WPPB_PLUGIN_URL', plugin_dir_url(__FILE__));
|
76 |
define('WPPB_PLUGIN_BASENAME', plugin_basename(__FILE__));
|
readme.txt
CHANGED
@@ -4,7 +4,7 @@ Donate link: http://www.cozmoslabs.com/wordpress-profile-builder/
|
|
4 |
Tags: user registration, user profile, registration, profile, user registration form, user fields, edit profile, user custom fields, front-end login, front-end edit profile, front-end user registration, email confirmation, login form, content restriction, restrict content
|
5 |
Requires at least: 3.1
|
6 |
Tested up to: 5.8.0
|
7 |
-
Stable tag: 3.5.
|
8 |
License: GPLv2 or later
|
9 |
License URI: http://www.gnu.org/licenses/gpl-2.0.html
|
10 |
|
@@ -176,6 +176,11 @@ This plugin adds/removes user fields in the front-end. Both default and extra pr
|
|
176 |
15. Edit or Add New User Role
|
177 |
|
178 |
== Changelog ==
|
|
|
|
|
|
|
|
|
|
|
179 |
= 3.5.2 =
|
180 |
* Fix: Fatal Error when logging in
|
181 |
|
4 |
Tags: user registration, user profile, registration, profile, user registration form, user fields, edit profile, user custom fields, front-end login, front-end edit profile, front-end user registration, email confirmation, login form, content restriction, restrict content
|
5 |
Requires at least: 3.1
|
6 |
Tested up to: 5.8.0
|
7 |
+
Stable tag: 3.5.3
|
8 |
License: GPLv2 or later
|
9 |
License URI: http://www.gnu.org/licenses/gpl-2.0.html
|
10 |
|
176 |
15. Edit or Add New User Role
|
177 |
|
178 |
== Changelog ==
|
179 |
+
= 3.5.3 =
|
180 |
+
* Feature: Added option to display Elementor sections and widgets to logged out users
|
181 |
+
* Fix: Position of password strength on the reset password form
|
182 |
+
* Fix: An issue with the password reset shortcode generating invalid HTML in a case
|
183 |
+
|
184 |
= 3.5.2 =
|
185 |
* Fix: Fatal Error when logging in
|
186 |
|
translation/profile-builder-de_DE.mo
CHANGED
Binary file
|
translation/profile-builder-de_DE.po
CHANGED
@@ -2,12 +2,12 @@
|
|
2 |
# This file is distributed under the same license as the Profile Builder package.
|
3 |
msgid ""
|
4 |
msgstr ""
|
5 |
-
"PO-Revision-Date:
|
6 |
"MIME-Version: 1.0\n"
|
7 |
"Content-Type: text/plain; charset=UTF-8\n"
|
8 |
"Content-Transfer-Encoding: 8bit\n"
|
9 |
"Plural-Forms: nplurals=2; plural=n != 1;\n"
|
10 |
-
"X-Generator: Poedit
|
11 |
"Project-Id-Version: Profile Builder\n"
|
12 |
"POT-Creation-Date: \n"
|
13 |
"Last-Translator: \n"
|
@@ -3311,7 +3311,7 @@ msgid "displays all users except the ones you specified the user_id for"
|
|
3311 |
msgstr "Zeigt alle Benutzer an, außer diejenigen, denen du eine user_id gegeben hast."
|
3312 |
|
3313 |
#: profile-builder-2.0/features/functions.php:566
|
3314 |
-
msgid "Minimum length of %d characters"
|
3315 |
msgstr "Mindestlänge: %d Zeichen"
|
3316 |
|
3317 |
#: profile-builder-2.0/front-end/class-formbuilder.php:146
|
@@ -5605,4 +5605,3 @@ msgstr "Du findest es im Menü vom Profile Builder"
|
|
5605 |
#: profile-builder-2.0/modules/user-listing/userlisting.php:2565
|
5606 |
msgid "No results found!"
|
5607 |
msgstr "Es wurden keine Ergebnisse gefunden!"
|
5608 |
-
|
2 |
# This file is distributed under the same license as the Profile Builder package.
|
3 |
msgid ""
|
4 |
msgstr ""
|
5 |
+
"PO-Revision-Date: 2021-08-12 14:26+0300\n"
|
6 |
"MIME-Version: 1.0\n"
|
7 |
"Content-Type: text/plain; charset=UTF-8\n"
|
8 |
"Content-Transfer-Encoding: 8bit\n"
|
9 |
"Plural-Forms: nplurals=2; plural=n != 1;\n"
|
10 |
+
"X-Generator: Poedit 3.0\n"
|
11 |
"Project-Id-Version: Profile Builder\n"
|
12 |
"POT-Creation-Date: \n"
|
13 |
"Last-Translator: \n"
|
3311 |
msgstr "Zeigt alle Benutzer an, außer diejenigen, denen du eine user_id gegeben hast."
|
3312 |
|
3313 |
#: profile-builder-2.0/features/functions.php:566
|
3314 |
+
msgid "Minimum length of %d characters."
|
3315 |
msgstr "Mindestlänge: %d Zeichen"
|
3316 |
|
3317 |
#: profile-builder-2.0/front-end/class-formbuilder.php:146
|
5605 |
#: profile-builder-2.0/modules/user-listing/userlisting.php:2565
|
5606 |
msgid "No results found!"
|
5607 |
msgstr "Es wurden keine Ergebnisse gefunden!"
|
|