Descrizione

L'azione wpforms_process_validate_text esegue la validazione sul campo modulo Testo a riga singola quando il modulo viene inviato.

Parametri

$field_id
(int) ID del campo.
$field_submit
(array) Valore originale non sanificato inviato per il campo.
$form_data
(array) Impostazioni/dati del modulo elaborati, preparati per l'uso successivo.

Origine

wpforms/includes/fields/class-base.php

Maggiori Informazioni

L'azione viene applicata a un array per il campo modulo Testo a riga singola. Questa funzione può essere utilizzata per tutti i campi modulo do_action( wpforms_process_validate_{$field_type}, $field_id, $field_submit, $form_data ).

Ad esempio, per utilizzarla per un campo Email, useresti do_action( wpforms_process_validate_email, $field_id, $field_submit, $form_data ).

È importante notare che i valori dei campi non vengono sanificati fino a più tardi nel processo, in wpforms_process_format_{$field_type}.

Per una maggiore sicurezza, è fortemente consigliato utilizzare la validazione lato server anziché fare affidamento esclusivamente su JavaScript. È possibile utilizzare l'hook wpforms_process_validate_{$field_type} per validare diversi tipi di campi. Ad esempio, utilizzare wpforms_process_validate_email per un campo Email. Assicurati di applicare la tua validazione prima dell'hook wpforms_process_format_{$field_type}, poiché è in quel momento che i dati vengono sanificati.

Esempi

È possibile utilizzare questa azione per scansionare il Testo a riga singola per qualsiasi cosa si desideri convalidare prima dell'invio del modulo.

In questo esempio, cercheremo volgarità in questo campo. Se ci sono volgarità, il modulo visualizzerà un errore e non verrà inviato.

/*
 * Check the single line text field for profanity.
 *
 * @link https://wpforms.com/developers/wpforms_process_validate_text/
 *
 * @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.
*/

function wpf_dev_profanity_filter_single_text( $field_id, $field_submit, $form_data ) {

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

    //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_text', 'wpf_dev_profanity_filter_single_text', 10, 3 );

Articoli di riferimento