Resumo da IA
Descrição
O wpforms_process_validate_richtext dispara a validação na ação Rich Text campo do formulário quando o formulário é enviado.
Parâmetros
- $field_id
- (int) ID do campo.
- $field_submit
- (array) Valor de campo original bruto/não higienizado enviado para o campo.
- $form_data
- (array) Configurações/dados de formulários processados, preparados para serem usados posteriormente.
Fonte
wpforms/includes/fields/class-base.php
Mais informações
A ação é aplicada a uma matriz para Rich Text campo de formulário. Essa função pode ser usada para todos os campos de formulário do_action( wpforms_process_validate_{$field_type}, $field_id, $field_submit, $form_data ).
Por exemplo, para usar isso em um E-mail o campo, você usaria do_action( wpforms_process_validate_email, $field_id, $field_submit, $form_data ).
É importante observar que os valores de campo não são higienizados até o final do processamento, em wpforms_process_format_{$field_type}.o
Exemplos
Você pode usar essa ação para examinar o Rich Text em busca de uma lista de palavras que gostaria de bloquear o envio do formulário, como palavrões, ou pode usar essa ação para procurar determinadas palavras que acionariam outra ação, como a definição de um valor em um campo oculto no formulário, que pode ser filtrado a partir de entradas.
Neste exemplo, vamos procurar por qualquer profanação nesse campo. Se houver algum palavrão, o formulário exibirá 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 );