hooks();
}
/**
* Register hooks.
*
* @since 1.6.2
*/
public function hooks() {
add_action( 'wpforms_frontend_output', [ $this, 'render' ], 15, 5 );
}
/**
* Return function to render the honeypot.
*
* @since 1.6.2
*
* @param array $form_data Form data and settings.
*/
public function render( $form_data ) {
if (
empty( $form_data['settings']['honeypot'] ) ||
'1' !== $form_data['settings']['honeypot']
) {
return;
}
$names = [ 'Name', 'Phone', 'Comment', 'Message', 'Email', 'Website' ];
echo '
';
echo ''; // phpcs:ignore
echo ''; // phpcs:ignore
echo '
';
}
/**
* Validate honeypot.
*
* @since 1.6.2
*
* @param array $form_data Form data.
* @param array $fields Fields.
* @param array $entry Form entry.
*
* @return bool|string False or an string with the error.
*/
public function validate( array $form_data, array $fields, array $entry ) {
$honeypot = false;
if (
! empty( $form_data['settings']['honeypot'] ) &&
'1' === $form_data['settings']['honeypot'] &&
! empty( $entry['hp'] )
) {
$honeypot = esc_html__( 'WPForms honeypot field triggered.', 'wpforms-lite' );
}
// If we get passed an empty fields array, but we have the data in our form data, use it.
if ( empty( $fields ) && isset( $form_data['fields'] ) ) {
$fields = $form_data['fields'];
}
return apply_filters( 'wpforms_process_honeypot', $honeypot, $fields, $entry, $form_data );
}
}