CakePHP - Использование group by для печати заголовков таблицы - PullRequest
0 голосов
/ 02 февраля 2012

У меня есть список задач модели, и каждый элемент списка задач принадлежит элементу службы.

В моем контроллере списка задач:

function index() {
  $this->Tasklist->recursive = 0;
  $this->set('tasklists', $this->Tasklist->find('all', array(
    'order' => array(
      'Service.name' => 'ASC',
      'Tasklist.name' => 'ASC'
    )
  )));
}

Соответствующая часть моего простого индекса Просмотр:

<?php foreach ($tasklists as $tasklist): ?>
    <tr>
      <td><?php echo $tasklist['Tasklist']['id']; ?></td>
      <td><?php echo $tasklist['Tasklist']['name']; ?></td>
      <td>
      <?php echo $this->Html->link($tasklist['Service']['name'], array('controller' => 'services', 'action' => 'view', $tasklist['Service']['id'])); ?>
      </td>
      <td><?php echo $tasklist['Tasklist']['created']; ?></td>
      <td><?php echo $tasklist['Tasklist']['modified']; ?></td>
      <td>
      <?php echo $this->Html->link(__('Edit', true), array('action' => 'edit', $tasklist['Tasklist']['id']), array('class' => 'button edit')); ?>
      </td>
    </tr>
<?php endforeach; ?>

Вместо того, чтобы печатать имя Сервиса в каждой строке таблицы, я хотел бы напечатать его в виде списка задач, сгруппированных под каждым:

<tr>
      <th colspan="5"><?php echo $this->Html->link($tasklist['Service']['name'], array('controller' => 'services', 'action' => 'view', $tasklist['Service']['id'])); ?></th>
</tr>
<tr>
      <td><?php echo $tasklist['Tasklist']['id']; ?></td>
      <td><?php echo $tasklist['Tasklist']['name']; ?></td>
      <td><?php echo $tasklist['Tasklist']['created']; ?></td>
      <td><?php echo $tasklist['Tasklist']['modified']; ?></td>
      <td>
      <?php echo $this->Html->link(__('Edit', true), array('action' => 'edit', $tasklist['Tasklist']['id']), array('class' => 'button edit')); ?>
      </td>
</tr>

Я экспериментировал с использованием параметра group в моем контроллере и вложенным foreach на мой взгляд, но не могу заставить его работать.

1 Ответ

1 голос
/ 03 февраля 2012

Я бы сделал это так

   $current_service = '';
    <?php foreach ($tasklists as $tasklist): ?>
    <?php if($current_service != $tasklist['Service']['name']): ?>
    <tr>
          <th colspan="5"><?php echo $this->Html->link($tasklist['Service']['name'], array('controller' => 'services', 'action' => 'view', $tasklist['Service']['id'])); ?></th>
    </tr>
    <?php $current_service = $tasklist['Service']['name']; ?>
    <?php endif; ?>
    <tr>
          <td><?php echo $tasklist['Tasklist']['id']; ?></td>
          <td><?php echo $tasklist['Tasklist']['name']; ?></td>
          <td><?php echo $tasklist['Tasklist']['created']; ?></td>
          <td><?php echo $tasklist['Tasklist']['modified']; ?></td>
          <td>
          <?php echo $this->Html->link(__('Edit', true), array('action' => 'edit', $tasklist['Tasklist']['id']), array('class' => 'button edit')); ?>
          </td>
    </tr>

    <?php endforeach; ?>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...