CakePHP 3.x обновляет несколько строк - PullRequest
0 голосов
/ 26 апреля 2018

У меня есть таблица AssetsAssignations, с сотнями строк. В некоторых случаях пользователю необходимо выбрать много строк с помощью флажка и изменить «статус» для всех них вместе.

В моем контроллере у меня есть эта функция

public function editMultiple()
{
    $assetStatuses = $this->AssetsAssignations->AssetStatuses->find('list');
    $this->paginate = [
        'contain' => ['Assets', 'AssetStatuses', 'Clients', 'Rooms'],
        'sortWhitelist' => [
            'Assets.model_number',
            'Assets.serial_number',
            'AssetStatuses.name',
            'Clients.last_name',
            'Rooms.name',
            ]
    ];

    $assetsAssignations = $this->request->data;

    $assetsAssignations_ids = array();

    foreach($assetsAssignations as $a){
        $assetsAssignations_ids[$a['id']] = $a['id'];
        $this->AssetsAssignations->updateAll(

            array('AssetAssignation.id' => $assetsAssignations_ids)
        );
        $this->Session->setFlash(__('Statsus is updated for the selcted entries!'));
    }            
    debug($assetsAssignations);

    $query = $this->AssetsAssignations->find()
        ->contain(['Assets', 'AssetStatuses', 'Clients', 'Rooms']);
    $filter = $this->Filter->prg($query);
    $assetsAssignations = $this->paginate($filter, ['maxLimit' => 10000, 'limit' => 10000]);        

    $this->set(compact('assetsAssignations', 'assetStatuses'));
    $this->set('_serialize', ['assetsAssignations']);
}

В моем edit_multiple.ctp я использую JavaScript для фильтрации данных. И я поставил этот код:

<table class="hoverTable dataTable">
        <thead>
                <tr>
                    <th>Select</th><th>Model Number</th><th>Serial Number</th><th>Room</th><th>Client</th><th>Status</th>
                </tr>
        </thead>
        </thead>
                    <?php foreach ($assetsAssignations as $assetsAssignation): ?>
                    <tr>
                        <td><input name="data[AssetsAssignations][id][]" value="<?= $assetsAssignation->id ?>" id="AssetsAssignationsId1" type="checkbox"></td>
                        <td><?= $assetsAssignation->has('asset') ? $assetsAssignation->asset->model_number : '' ?></td>
                        <td><?= $assetsAssignation->has('asset') ? $assetsAssignation->asset->serial_number : '' ?></td>
                        <td><?= $assetsAssignation->has('room') ? $assetsAssignation->room->name : '' ?></td>
                        <td><?= $assetsAssignation->has('client') ? $assetsAssignation->client->last_name . ', ' . $assetsAssignation->client->first_name: '' ?></td>
                        <td><?= $assetsAssignation->has('asset_status') ? $assetsAssignation->asset_status->name : '' ?></td>
                    </tr>
                    <?php endforeach; ?>
    </table>
    <legend><?= __('') ?></legend>
    </div>
        <?= $this->Form->create($assetsAssignation) ?>
    <fieldset>
        <div class="row">
            <div class="col-xs-3"><?= $this->Form->input('asset_status_id', ['options' => $assetStatuses, 'empty' => true, 'label' => __('Change Status To')]) ?></div>
        </div>
    </fieldset>
    <?= $this->Form->button(__('Submit')) ?>
    <?= $this->Form->end() ?>

Когда я отлаживаю результат, проверяя 3 записи, я получаю это:

[
'data' => [
    'AssetsAssignations' => [
        'id' => [
            (int) 0 => '411',
            (int) 1 => '413',
            (int) 2 => '415'
        ]
    ]
],
'asset_status_id' => '3'

]

У меня вопрос: как передать выбранные идентификаторы строк кнопке «Отправить» после установки флажков?

Заранее спасибо.

Ответы [ 2 ]

0 голосов
/ 11 июня 2018

Исходя из того, что предложила @Arilia, это помогло мне. В моем контроллере, функция, я положил это:

    $this->request->data;
    $data = $this->request->data;
    debug($data);

    if($this->request->is(['patch', 'post', 'put'])) 
    {
        $ids = $this->request->data('data.AssetsAssignations.id');
        $asset_status_id = $this->request->data('asset_status_id');

        $this->AssetsAssignations->updateAll(
            ['asset_status_id ' => $asset_status_id ],
            ['id IN' => $ids]
        );

    }

На мой взгляд, я поставил это:

<td><input type="checkbox" name="data[AssetsAssignations][id][]" value="<?= $assetsAssignation->id ?>" id="ApplicationId1" ></td>
0 голосов
/ 27 апреля 2018

Я думаю, что вы хотите сделать что-то вроде

if($this->request->is('post')
{
    $ids = $this->request->data('data.AssetsAssignations.id');
    $asset_status_id = $this->request->data('asset_status_id');

    $this->AssetsAssignations->updateAll(
        ['asset_status_id ' => $asset_status_id ]
        ['id IN' => $ids]
    );

}
...