Drupal 8以编程方式创建具有多个提交按钮的自定义表单

时间:2017-02-01 14:02:34

标签: drupal-8

我有一个自定义的Drupal 8表单,它显示了一个用户列表和一个" check"每个用户的按钮。

单击复选按钮时,提交处理程序需要确定哪些用户"检查"单击按钮。

我已经尝试过以下方式,但它总是返回最后一个元素的id而不是正确的元素。

这是Drupal Core Form API中的错误吗?

还有其他办法吗?我愿意接受建议!

这只是一个例子。我实际上要做的是显示属于特定公司'的用户列表。节点。在该列表中,有一个'从公司删除'每个用户的按钮。

http://pastebin.com/us2YFcjr

<?php

namespace Drupal\form_multi_submit\Form;

use Drupal\Core\Form\FormBase;
use Drupal\Core\Form\FormStateInterface;
use Drupal\user\Entity\User;

class MultiSubmitForm extends FormBase {

  public function getFormId() {
    return 'MultiSubmitForm';
  }

  public function buildForm(array $form, FormStateInterface $form_state) {

    // Get all users from database
    $ids = \Drupal::entityQuery('user')
      ->condition('status', 1)
      ->execute();
    $users = User::loadMultiple($ids);

    // Set form table header
    $form['users'] = array (
      '#type' => 'table',
      '#header' => array('ID', 'Remove'),
    );


    // Loop through all users
    foreach ($users as $user) {

      // Show user ID
      $form['users'][$user->id()]['id'] = array(
        '#type' => 'label',
        '#title' => $user->id(),
      );

      // Show button for each user
      $form['users'][$user->id()]['removememberbutton']['dummyNode'] = array(
        '#type' => 'submit',
        '#value' => 'Check',
        '#submit' => array([$this, 'removeMember']),
      );
    }

    return $form;
  }


  // Submit handler
  public function removeMember(array &$form, FormStateInterface $form_state) {
    $userid = $form_state->getTriggeringElement()['#array_parents'][1];
    drupal_set_message($userid, 'status');
  }

  public function validateForm(array &$form, FormStateInterface $form_state) {
    // Nothing to do here.
  }

  public function submitForm(array &$form, FormStateInterface $form_state) {
    // Nothing to do here.
  }

}

1 个答案:

答案 0 :(得分:3)

Drupal认为按钮的#value与同一个按钮相同,除非它们有不同的#name

所以我所要做的就是在我的按钮上添加一个唯一的#name,以使其正常工作:

.product {
position:relative;
width:300px;
height:200px;
padding: 10px;
overflow:visible;
}

.menu {
position:absolute;
width:200px;
height:400px;
padding: 10px;
}

https://www.drupal.org/node/1342066#comment-11904090