Search code examples
phpjqueryajaxyiicjuidialog

EJuiDateTimePicker/CJuiDateTimePicker not working inside a CJuiDialog


This seemed to be asked before but applying such answers did not gave me the solution. I have a create form which records the payments of the clients. It works just fine until I tried to transfer it inside a CJuiDialog in another view. In my create.php:

<?php
    /* @var $this PaymentsController */
    /* @var $model Payments */

    $this->breadcrumbs=array(
        'Payments'=>array('index'),
        'Create',
    );

    $this->menu=array(
        array('label'=>'List Payments', 'url'=>array('index')),
        array('label'=>'Manage Payments', 'url'=>array('admin')),
    );

 ?>

<h4 class="text-success">Payments <span class="glyphicon glyphicon-tag"></span></h4>
<hr>
<?php $this->renderPartial('_form', array('model'=>$model)); ?>

And this is how i put the datetimepicker in my _form.php:

<div class="row">
    <?php echo $form->labelEx($model,'payment_date'); ?>
    <?php 

        $this->widget('EJuiDateTimePicker',array(
            'model'=>$model, //Model object
            'attribute'=>'payment_date', //attribute name
            //'dateFormat'=>'dd-mm-yy',
            'value'=>date('MM-dd-yy H:i:s'),
            'mode'=>'datetime', //use "time","date" or "datetime" (default)
            'language'=>'en-GB',
            'options'=>array(

            'dateFormat'=>'yy-mm-dd',
             ) // jquery plugin options
            ));
    ?>      
    <?php echo $form->error($model,'payment_date'); ?>
</div>

and in my actionCreate controller:

public function actionCreate($id, $bal)
{
    $model=new Payments;
    $model->contract_id = $id;
    // Uncomment the following line if AJAX validation is needed
     $this->performAjaxValidation($model);

    if(isset($_POST['Payments']))
    {

        $_POST['Payments']['remaining_balance'] = $bal - $_POST['Payments']['down_payment'];
        $_POST['Payments']['paid_thru'] = $_POST['Payments']['account_id'];
        $balance = $_POST['Payments']['remaining_balance'];
        $model->attributes=$_POST['Payments'];
        if($model->save())
            {
                $model->updateBalance($id, $balance);
                $this->redirect(array('servicecontract/view','id'=>$id));
            }
    }

    $this->renderPartial('create',array(
        'model'=>$model, 'contr'=>$id,
    ),false, true);
}

and this is how I implement the CJuiDialog in my view.php:

        <?php
        echo CHtml::ajaxLink(
        "Make Payments", //link label
        Yii::app()->createUrl( 'tcfunecareModule/payments/create'),
        array( // ajaxOptions
            'type' => 'GET',
            'success' => "function( data )
                {
                    //alert( data );
                    $('#mydialog').dialog('open');
                    $('#dlg-content').html(data);
                }",
            'data' => array( 'id' => $model->contract_id, 'bal'=>$model->contract_balance)
        ),
        array('class'=>'btn btn-info pull-right')
        );
    ?>
        <?php $this->beginWidget('zii.widgets.jui.CJuiDialog', array(
        'id' => "mydialog",
        'options' => array(
        'autoOpen' => false,
        'width' => 'auto',
        'height' => 'auto',
        //'show'=>'fade-in',
        'hide'=>'fade',
        'modal' => true,
        'open'=> 'js:function(event, ui) { $(".ui-dialog-titlebar").hide(); }',
        'buttons' => array(
                Yii::t('app', 'Close') => 'js:function() {$(this).dialog("close");}',
        ),
        )));
     ?>
        <div id="dlg-content" style="dispay:none;"></div>
     <?php 
        $this->endWidget('zii.widgets.jui.CJuiDialog');
     ?>

The EJuiDateTimePicker works fine when create.php is being run in an entire page. But when I render it inside the CJuiDialog, it is not working. What should I do?


Solution

  • Hey in case someone will happen to encounter the same problem. I have here the solution. In your controller:

    if (Yii::app()->request->isAjaxRequest) {
            Yii::app()->clientScript->scriptMap['jquery.js'] = false;
            yii::app()->clientScript->scriptMap['jquery-ui.min.js'] = false;
            $this->renderPartial('create',array(
            'model'=>$model,'contr_id'=>$id,
        ),false,true);}
    

    Just set those two in false and you're good to go.