Данные табличной формы Yii2 не вставляются в таблицу

Для проекта мне нужно создать табличную форму для Invoice Taxes основанный на Purchase order details в Invoice форма. Когда я выбираю po_number поле добавит значение в URL и обновит pjax div с именем paticular, Я успешно сгенерировал форму, и строки также генерируются для табличной части формы и вставляются в Invoice Taxes стол, но только invoice_id а также invoice_amt вставляются.

Вот моя форма для Invoice

<div class="invoice-form">

<?php $form = ActiveForm::begin(['id' => 'dynamic-form','options' => ['enctype' => 'multipart/form-data']]);

<div class="col-md-12">

    <div class="col-md-4">
        <?= $form->field($model, 'po_number')->textInput(['readonly' => true,'maxlength' => true]) ?>
    </div>

    <div class="col-md-4">

<?= $form->field($model,'po_number')->dropDownList(
    ArrayHelper::map(purchaseorder::find()->where(['type'=> 2])->all(),'id','po'),
    ['prompt'=>'Select PO ', 'onchange' => '
        var poid;
        poid=$(this).val();  
        //alert(poid); 
        var url = "index.php?r=invoice/create&pod="+poid;
        $.pjax({url: url, container: "#particular"});
    '
    ]);     
?> 

    </div>
    <div class="col-md-4">
    <?= $form->field($model, 'invoice_no')->textInput(['maxlength' => true]) ?>

    </div>
    <div class="col-md-4"> 
    <?= $form->field($model, 'net_amt')->textInput() ?>   
    </div>
</div>

<div class="col-md-12">
    <div class="col-md-4">
    <?php
    if (isset(Yii::$app->request->queryParams['customer'])) {
        $customer= Yii::$app->request->queryParams['customer'];       
        $customers = customer::find()->where(['id'=>$customer])->all();
        $listdata =ArrayHelper::map($customers,'id','name'); 
    ?>
    <?= 
    $form->field($model,'customerid')->widget(Select2::classname(),
        [
           'data' => $listdata,
          //'data' => ArrayHelper::map(customer::find()->where(['id'=>$customer])->One(),'id','name'),
            'language' => 'english',
            'options' => ['placeholder' => 'Customer','id'=>'customer'],
            'pluginOptions' => [
            'allowClear' => true
            ],
        ]);
    ?> 

    <?php

    $serviceid= Yii::$app->request->queryParams['service'];       
    $servi = service::find()->where(['id'=>$serviceid])->all();
    $listdata =ArrayHelper::map($servi,'id','name'); 
    ?>

    <?php
    }
    else
    {
    $cust = new customer();
    $customers = customer::find()->where(['id'=>$cust->id])->all();   
    $listdata =ArrayHelper::map($customers,'id','name');  
    ?>

    <?php
    }
    ?>
    </div>
    <div class="col-md-4">
          <?= $form->field($model, 'po_desc')->textInput(['readonly' => true,'maxlength' => true]) ?>

        <?= $form->field($model, 'status')->dropDownList(['Sent'=>'Sent','On hold'=>'On hold', 'Partially Recieved'=>'Partially Recieved','Fully Paid'=>'Fully Paid']); ?>

    </div>

</div>
<div class='clearfix'></div>
<?php Pjax::begin(['id' => 'particular']) ?>
<div id=''>
<?php
    // **********************************
    // * Here the tabular form part start
    // **********************************
   if ( isset($_GET['pod']) ) {
        $id = $_GET['pod'];
        $modelPods = purchaseorderdetails::findAll(['purchaseorderid' => $id]);
    /*  $length = purchaseorderdetails::find()->where(['purchaseorderid' => $id])->count();
        $x = 0;
        foreach ( $modelPods as $pod ) {
            $tempNet[$x] = $pod->net_amt;
            $x++;
        } */
        foreach ( $modelPods as $pod ) {
        //for ( $i = 0; $i < $length; $i++ ) {
            echo '<div class="" style="border: 1px solid #ccc; border-radius: 2px; padding-top: 5px; margin-bottom:10px;">';
            foreach ( $modelTaxes as $i => $data ) {
?>
    <div class='col-md-2'>
    <?= $form->field($data, '[$i]net_amt')->textInput(['value' => $pod->net_amt]) ?>
    </div>

    <div class='col-md-1'>
    <?= $form->field($data, '[$i]ST')->textInput() ?>
    </div>

    <div class='col-md-2'>
    <?= $form->field($data, '[$i]SBC')->textInput(['maxlength' => true]) ?>
    </div>

    <div class='col-md-2'>
    <?= $form->field($data, '[$i]KKC')->textInput(['maxlength' => true]) ?>
    </div>

    <div class='col-md-1'>
    <?= $form->field($data, '[$i]Vat')->textInput() ?>
    </div>

    <div class='col-md-2'>
    <?= $form->field($data, '[$i]total')->textInput() ?>
    </div>

    <div class='col-md-2'>
    <?= $form->field($data, '[$i]invoice_amt')->textInput() ?>
    </div>

    <?php // $form->field($data, '[]invoice_id')->hiddenInput()->label(false) ?>
<?php
            }
            echo '<div class="clearfix"></div>';
            echo '</div>';
        }
    }
?>
</div>
<?php Pjax::end() ?>

<div class="form-group">
        <?= Html::submitButton($model->isNewRecord ? 'Create' : 'Update', ['class' => $model->isNewRecord ? 'btn btn-success' : 'btn btn-primary']) ?>
</div>

<?php ActiveForm::end(); ?>

А вот и контроллер

$model = new invoice(); 
    // $model_po = new purchaseorder(); 
    $modelTaxes = [new InvoiceTaxes];
if ($model->load(Yii::$app->request->post())) {
                $modelTaxes = Model::createMultiple(InvoiceTaxes::classname());
                Model::loadMultiple($modelTaxes, Yii::$app->request->post());

                $p =purchaseorder::find()->where(['id'=>$model->abc])->one();     

                $poid = $model->abc;               
                $model->poid =$poid;
                $model->type ='External';
                $model->po_date = $p->orderdate;
                $po_noo = purchaseorder::find()->where(['id'=>$model->poid])->One();
                $model->po_number =$po_noo->po;

                $valid = $model->validate();
                $valid = Model::validateMultiple($modelTaxes) && $valid;

                $count = invoice::find()->where(['invoice_no' => $model->invoice_no])->count();        
                if($count > 0) {
                    Yii::$app->getSession()->setFlash("error", "Same Invoice No. is already in used, please use another one");
                    return $this->render('create', [
                    'model' => $model,
                ]);
                } 
                if ($flag = $model->save(false)) {
                    foreach ($modelTaxes as $data) {
                        $data->invoice_id = $model->id;
                        if (! ($flag = $data->save(false))) {
                            $transaction->rollBack();
                            break;
                        }
                    }
                }
                return $this->redirect(['index']);
            } else {
                return $this->render('create', [
                    'model' => $model,

                    'modelTaxes' => (empty($modelTaxes)) ? [new InvoiceTaxes] : $modelTaxes,

                ]);
            }

1 ответ

Хорошо! Я решил свою проблему. Это был первый раз, когда я внедрял табличную форму, поэтому у меня были некоторые проблемы с ее работой. Я переписал код. Вот часть табличной формы.

// tabular form for invoice taxes
    if ( isset($_GET['pod']) ) {
        $id = $_GET['pod'];
        if ($model->isNewRecord) {
            $modelPods = purchaseorderdetails::find()->where(['purchaseorderid' => $id]);
            $length = $modelPods->count();
            $modelPods = $modelPods->all();
            $x = 0;
            foreach ( $modelPods as $pod ) {
                $tempAmt[$x] = $pod->net_amt;
                $x++;
            }
            for ( $i = 0; $i < $length; $i++ ) {
                echo '<div class="" style="border: 1px solid #ccc; border-radius: 2px; padding-top: 10px; margin-bottom:10px;">';

                foreach ( $modelTaxes as $data ) {
?>
    <div class='col-md-2'>
    <?= $form->field($data, "[$i]net_amt")->textInput(['value' => $tempAmt[$i], 'disabled' => 'true'])->label(false) ?>
    </div>

    <div class='col-md-1'>
    <?= $form->field($data, "[$i]ST")->textInput(['placeholder' => 'ST'])->label(false) ?>
    </div>

    <div class='col-md-2'>
    <?= $form->field($data, "[$i]SBC")->textInput(['maxlength' => true, 'placeholder' => 'SBC'])->label(false) ?>
    </div>

    <div class='col-md-2'>
    <?= $form->field($data, "[$i]KKC")->textInput(['maxlength' => true, 'placeholder' => 'KKC'])->label(false) ?>
    </div>

    <div class='col-md-1'>
    <?= $form->field($data, "[$i]Vat")->textInput(['placeholder' => 'Vat'])->label(false) ?>
    </div>

    <div class='col-md-2'>
    <?= $form->field($data, "[$i]total")->textInput(['placeholder' => 'Total'])->label(false) ?>
    </div>

    <div class='col-md-2'>
    <?= $form->field($data, "[$i]invoice_amt")->textInput(['placeholder' => 'Invoice Amt'])->label(false) ?>
    </div>

    <?php // $form->field($data, '[]invoice_id')->hiddenInput()->label(false) ?>
<?php
                }

                echo '<div class="clearfix"></div>';
                echo '</div>';
            }
        }
    }

А вот и код контроллера. Код контроллера смешивается с кодом модели счета.

if ($model->load(Yii::$app->request->post())) {

                // For tabular form
                $count = count(Yii::$app->request->post('InvoiceTaxes', []));
                for($i = 1; $i < $count; $i++) {
                    $modelTaxes[] = new InvoiceTaxes();
                }

                Model::loadMultiple($modelTaxes, Yii::$app->request->post());
                Model::validateMultiple($modelTaxes);
                // end tabular form part

                $p =purchaseorder::find()->where(['id'=>$model->abc])->one();     

                $poid = $model->abc;               
                $model->poid =$poid;
                $model->type ='External';
                $model->po_date = $p->orderdate;
                $po_noo = purchaseorder::find()->where(['id'=>$model->poid])->One();
                $model->po_number =$po_noo->po;

                $count = invoice::find()->where(['invoice_no' => $model->invoice_no])->count();        
                if($count > 0) {
                    Yii::$app->getSession()->setFlash("error", "Same Invoice No. is already in used, please use another one");
                    return $this->render('create', [
                    'model' => $model,
                ]);
                } 
                if ($flag = $model->save(false)) {
                    // for tabular form
                    foreach ($modelTaxes as $data) {
                        $data->invoice_id = $model->id;
                        $flag = $data->save(false);
                    // end tabular form
                        if (!($flag)) {
                            $transaction->rollBack();
                            break;
                        }
                    }
                }
Другие вопросы по тегам