it-swarm.it

Come ajaxify inviare il modulo web in Drupal 7?

Ho provato a modificare il rendering del modulo web usando hook_form_alter() e hook_node_view() in un modulo personalizzato in modo da poter aggiungere '#ajax' da qualche parte.

Qualcuno ha già avuto qualche esperienza di lavoro con webform e ajax su D6 o D7? Immagino che la logica sarebbe la stessa per D6 e D7, quindi solo le modifiche all'implementazione.

8

Ajax Module funziona per me in Drupal 6.

Per Drupal 7:

function mymodule_form_alter(&$form, &$form_state, $form_id) {
      // see if webform_client_form_ is in the form_id
      if(strstr($form_id, 'webform_client_form_')) {
        // get the nid so we can use it in the wrapper value
        $nid = $form['#node']->nid;
        // add the ajax properties to the submit button
        $form['actions']['submit']['#ajax'] = array(
          'callback' => 'mymodule_webform_js_submit',
          'wrapper' => 'webform-client-form-' . $nid,
          'method' => 'replace',
          'effect' => 'fade',
        );
      }
    }

function mymodule_webform_js_submit($form, $form_state) {
      // define the $sid variable (submission id from webform)
      $sid = $form_state['values']['details']['sid'];
      // if we have a sid then we know the form was properly submitted, otherwise, we'll just return the existing $form array
      if ($sid) {
        // first we have to load up the webform node object
        $node = node_load($form_state['values']['details']['nid']);
        // create an array up with the confirmation message, retreived from the webform node
        $confirmation = array(
          '#type' => 'markup',
          '#markup' => check_markup($node->webform['confirmation'], $node->webform['confirmation_format'], '', TRUE),
        );
        // return the confirmation message
        return $confirmation;
      }
      else {
        // return the form
        return $form;
      }
    }
8
Matthew Woodard

Uno dei modi più semplici se stai cercando di ajaxify solo un particolare modulo sarà quello di aggiungere jquery form plugin . È piuttosto semplice.

Aggiungi il codice seguente alla tua funzione di pre-elaborazione della pagina nel file template.php.

  1. Per prima cosa aggiungi il plugin jquery con il codice qui sotto.

    drupal_add_js (drupal_get_path ('theme', 'your_theme'). "/js/jquery.form.js");

  2. Quindi aggiungi il codice seguente, sostituisci #your_form_ID con ID modulo tuo

    drupal_add_js ('

                (function($){ 
    $(document).ready(function() { 
    
                $("#your_form_ID").ajaxForm(function() { 
                    alert("Thank you for your comment!"); 
                }); 
    });     }(jQuery));;
    
           ', 'inline');
    

Questo è tutto ciò che hai fatto. Forse vuoi considerare di caricare gli script solo le pagine che ti servono.

0
esafwan