Descrição

O wpforms_process_validate_richtext dispara a validação na ação Texto rico campo do formulário quando o formulário é submetido.

Parâmetros

$field_id
(int) ID do campo.
$field_submit
(array) Valor de campo original em bruto/não higienizado apresentado para o campo.
$form_data
(matriz) Definições/dados de formulários processados, preparados para serem utilizados posteriormente.

Fonte

wpforms/includes/fields/class-base.php

Mais informações

A ação é aplicada a uma matriz para Texto rico campo de formulário. Esta função pode ser utilizada para todos os campos de formulário do_action( wpforms_process_validate_{$field_type}, $field_id, $field_submit, $form_data ).

Por exemplo, para utilizar isto para um Correio eletrónico o campo, utiliza-se do_action( wpforms_process_validate_email, $field_id, $field_submit, $form_data ).

É importante notar que os valores de campo não são higienizados até mais tarde no processamento, em wpforms_process_format_{$field_type}.o

Exemplos

Pode utilizar esta ação para procurar no Rich Text uma lista de palavras que gostaria de bloquear o envio do formulário, como palavrões, ou pode utilizar esta ação para procurar determinadas palavras que desencadeariam outra ação, como a definição de um valor num campo oculto do formulário que pode ser filtrado a partir de entradas.

Neste exemplo, vamos procurar por qualquer profanação neste campo. Se houver algum palavrão, o formulário apresentará um erro e não será enviado.

/*
 * Check the paragraph text field for profanity.
 *
 * @link https://wpforms.com/developers/wpforms_process_validate_richtext/
 *
 * @param int     $field_id        Field ID.
 * @param array   $field_submit    Unsanitized field value submitted for the field.
 * @param array   $form_data       Form data and settings.
*/

    // Optional, you can limit to specific forms. Below, we restrict output to form #3382.
    if ( absint( $form_data[ 'id' ] ) !== 3382 ) {
        return $field_id;
    }

function wpf_dev_profanity_filter_rich_text( $field_id, $field_submit, $form_data ) {
    //Create your list of profanity words separated by commas
    $blocked_words = array( 
        'badword1', 
        'badword2'
    );
 
    foreach( $blocked_words as $word ) {
        if(strpos($field_submit, $word) !== FALSE ) {
            wpforms()->process->errors[ $form_data[ 'id' ] ][ $field_id ] = esc_html__( 'No profanity allowed.', 'wpforms' );
            return;
        }
    }
 
}
 
add_action( 'wpforms_process_validate_richtext', 'wpf_dev_profanity_filter_rich_text', 10, 3 );

Artigos de referência