<?php

class AporteFondoDiferidoController extends Controller
{
	/**
	 * @var string the default layout for the views. Defaults to '//layouts/column2', meaning
	 * using two-column layout. See 'protected/views/layouts/column2.php'.
	 */
	public $layout='//layouts/column2';

	/**
	 * @return array action filters
	 */
	public function filters()
	{
		return array(
			'accessControl', // perform access control for CRUD operations
                        'postOnly + delete',
                        array('CrugeAccessControlFilter')
		);
	}

	/**
	 * Specifies the access control rules.
	 * This method is used by the 'accessControl' filter.
	 * @return array access control rules
	 */
	public function accessRules()
	{
		return array(
			array('allow',  // allow all users to perform 'index' and 'view' actions
				'actions'=>array('index','view'),
				'users'=>array('*'),
			),
			array('allow', // allow authenticated user to perform 'create' and 'update' actions
				'actions'=>array('create','update'),
				'users'=>array('@'),
			),
			array('allow', // allow admin user to perform 'admin' and 'delete' actions
				'actions'=>array('admin','delete'),
				'users'=>array('admin'),
			),
			array('deny',  // deny all users
				'users'=>array('*'),
			),
		);
	}

	/**
	 * Displays a particular model.
	 * @param integer $id the ID of the model to be displayed
	 */
	public function actionView($id)
	{
		$this->render('view',array(
			'model'=>$this->loadModel($id),
		));
	}

	/**
	 * Creates a new model.
	 * If creation is successful, the browser will be redirected to the 'view' page.
	 */
	public function actionCreate()
	{
		$model=new AporteFondoDiferido;

		// Uncomment the following line if AJAX validation is needed
		// $this->performAjaxValidation($model);

		if(isset($_POST['AporteFondoDiferido']))
		{
			$model->attributes=$_POST['AporteFondoDiferido'];
			if($model->save())
				$this->redirect(array('view','id'=>$model->id));
		}

		$this->render('create',array(
			'model'=>$model,
		));
	}

	/**
	 * Updates a particular model.
	 * If update is successful, the browser will be redirected to the 'view' page.
	 * @param integer $id the ID of the model to be updated
	 */
	public function actionUpdate($id)
	{
		$model=$this->loadModel($id);
		$model->scenario='asociado_cmaf';
        $modelAsociado= new Asociado('sin_validacion');
        $modelAsociado->cedula = $model->cedula;
        $planillas= Asociado::model()->findAll('cedula=:ci',array(':ci'=>$model->cedula));
        $activa = false;
        foreach ($planillas as $key => $value) {
         	if ($value->id_estatus==1) {
           		$activa = true;
         	}
        }

		// Uncomment the following line if AJAX validation is needed
		// $this->performAjaxValidation($model);

		if(isset($_POST['AporteFondoDiferido']))
		{ //echo "<pre>";print_r($_POST);exit;
			$model->attributes=$_POST['AporteFondoDiferido'];

            if ($model->id_status==2) {
                if (Asociado::model()->count('cedula=:ci and (id_estatus=1 or id_estatus=2)', array(':ci' => $model->cedula)) == 0) {
                    Yii::app()->user->setFlash('error', 'Debe poseer una planilla activa o liquidada, para definirlo como "No asociado".');
                    $this->refresh();
                }
            }

			if ($activa == false) {
                
                if ($model->id_status == 6) {
                	
                	Yii::app()->user->setFlash('error', "No posee una planilla activa para actualizar al estatus Aportante Activo!");
                    $this->refresh();
                }
            }

            if($model->id_status==3 || $model->id_status==4)$modelAsociado->scenario='planilla_cmao';
            $modelAsociado->attributes=$_POST['Asociado'];
            if($model->validate()&&$modelAsociado->validate()){
                $transaction=Yii::app()->db->beginTransaction();
                    try
                    {
                            if($model->save()){
                                 if($model->id_status==3||$model->id_status==4) 
                                     {
                                        $asociado=  Asociado::model()->find('cedula=:ci AND blnborrado=FALSE',array(':ci'=>$modelAsociado->cedula));
                                        if($asociado)$modelAsociado=$asociado;
                                        $modelAsociado->dirhabitacion='';
                                        $modelAsociado->clvcreado_por=Yii::app()->user->id;
                                        if($modelAsociado->save())
                                            {$ex=0;
                                            $modelUsuario=CrugeUserI::model()->find('cedula=:ci',array(':ci'=>$modelAsociado->cedula));
                                            if(!$modelUsuario){$modelUsuario= new CrugeUserI;$ex++;}
                                            $modelUsuario->cedula=$modelAsociado->cedula;
                                            $modelUsuario->nombres=$modelAsociado->nombre;
                                            $modelUsuario->apellidos=$modelAsociado->apellidos;
                                            $modelUsuario->username=$modelAsociado->cedula;
                                            $modelUsuario->password=md5($modelAsociado->cedula);
                                            $modelUsuario->state=1;
                                                        								// la establece como "Activada"
                                            if($modelUsuario->save())
                                                {
                                                if($ex>0)
                                                Yii::app()->user->rbac->assign("usuario_asociado", $modelUsuario->primaryKey);
                                                }
                                                        
                                            $modelAporte= new AporteFondo('carga_masiva_guardado');
                                                        
                                            $modelAporte->id_asociado=$modelAsociado->idasociado;
                                            $modelAporte->id_txt=$model->id_txt;
                                            $modelAporte->aporte=$model->aporte_asociado;
                                            $modelAporte->id_tnomina=$model->t_nomina;
                                            $modelAporte->id_taporte=$model->aporte_asociado;

                                            $tipo_aporte = AporteFondo::model()->find('id_txt=:txt', array(':txt'=>$model->id_txt));
                                            if($tipo_aporte)$modelAporte->id_taporte=$tipo_aporte->id_taporte;

                                            //$tipoNomina= TipoNomina::model()->find('codigo_nomina=:cod',array(':cod'=>$model->t_nomina));

                                            //if($tipoNomina)$modelAporte->id_tnomina=$tipoNomina->id;
                                            $modelAporte->fecha_aporte=$model->idTxt->fecha_aporte;

                                            $unidad=  Unidad::model()->findByPk($model->unidad);
                                            if($unidad)$modelAporte->id_unidad=$unidad->idunidad;
                                            $modelAporte->id_user=Yii::app()->user->id;
                                            if($modelAporte->save())
                                                {
                                                  $model->blnborrado=true;
                                                  $model->save(false); 
                                                              
                                                }
                                            $modelEstatus = new AsociadoEstatus();
                                            $modelEstatus->idasociado = $modelAsociado->idasociado;
                                            $modelEstatus->id_estatus_asociado = 1;
                                            $modelEstatus->fecha_movimiento = $modelAsociado->fechaingreso;
                                            $modelEstatus->save();
                                                        
                                        } 


                                     }

                                if($model->id_status==6){

                                	$consulta = Asociado::model()->find('cedula=:ci and id_estatus=1', array('ci'=>$model->cedula));

                                	if (!empty($consulta)) {
                                		
                                		$modelAporte= new AporteFondo('carga_masiva_guardado');
                                                        
                                        $modelAporte->id_asociado=$consulta->idasociado;
                                        $modelAporte->id_txt=$model->id_txt;
                                        $modelAporte->aporte=$model->aporte_asociado;
                                        $modelAporte->id_tnomina=$model->t_nomina;
                                        $modelAporte->id_taporte=$model->aporte_asociado;

                                        $tipo_aporte = AporteFondo::model()->find('id_txt=:txt', array(':txt'=>$model->id_txt));
                                        if($tipo_aporte)
                                        	$modelAporte->id_taporte=$tipo_aporte->id_taporte;

                                            //$tipoNomina= TipoNomina::model()->find('codigo_nomina=:cod',array(':cod'=>$model->t_nomina));

                                            //if($tipoNomina)$modelAporte->id_tnomina=$tipoNomina->id;
                                        $modelAporte->fecha_aporte=$model->idTxt->fecha_aporte;

                                        $unidad=  Unidad::model()->findByPk($model->unidad);

                                        if($unidad)
                                        	$modelAporte->id_unidad=$unidad->idunidad;
                                        $modelAporte->id_user=Yii::app()->user->id;

                                        if($modelAporte->save()){
                                              $model->blnborrado=true;
                                              $model->save(false);                                                              
                                        }
                                	}
                                }
                                                 
                            $countDiferidos= AporteFondoDiferido::model()->count('id_txt=:idTxt AND id_status=:id ',array(':idTxt'=>$model->id_txt,':id'=>1));   
                            if($countDiferidos==0)
                                {
                                    EstatusTxtIntegrado::model()->updateAll(array('actual'=>FALSE),'id_datos_txt_integrado=:id',array(':id'=>$model->id_txt));

                                    $status=EstatusTxtIntegrado::model()->find('id_estatus_txt=:idEstatus AND id_datos_txt_integrado=:idTxt',array(':idEstatus'=>1,':idTxt'=>$model->id_txt));

                                    if($status)
                                        {
                                          $status->actual=TRUE;  
                                          $status->save();  
                                        }
                                    else {
                                                    
                                    $modelEstatusTxt= new EstatusTxtIntegrado;
                                    $modelEstatusTxt->id_estatus_txt=1;
                                    $modelEstatusTxt->id_datos_txt_integrado=$model->id_txt;
                                    $modelEstatusTxt->actual=TRUE;
                                    $modelEstatusTxt->save(); 
                                                    
                                    }    
                                            
                                }
                                        
                            }
                            $transaction->commit(); #Ejecuta todas las operaciones
                            $this->redirect(array('/aportes/datosTxtIntegrado/viewCmaf','id'=>$model->id_txt));
                    }
                    catch(Exception $e)
                    {
                       $transaction->rollback();
                       Yii::app()->user->setFlash('error', "Ocurrio un error durante el guardado, se han revertido todos los cambios");
                       $this->redirect(array('update','id'=>$model->id));
                    }
                                
				
            }
		}

		$this->render('update',array(
			'model'=>$model,
			'modelAsociado'=>$modelAsociado,
			'planillas'=>$planillas,
		));
	}

	/**
	 * Deletes a particular model.
	 * If deletion is successful, the browser will be redirected to the 'admin' page.
	 * @param integer $id the ID of the model to be deleted
	 */
	public function actionDelete($id)
	{
		if(Yii::app()->request->isPostRequest)
		{
			// we only allow deletion via POST request
			$this->loadModel($id)->delete();

			// if AJAX request (triggered by deletion via admin grid view), we should not redirect the browser
			if(!isset($_GET['ajax']))
				$this->redirect(isset($_POST['returnUrl']) ? $_POST['returnUrl'] : array('admin'));
		}
		else
			throw new CHttpException(400,'Invalid request. Please do not repeat this request again.');
	}

	/**
	 * Lists all models.
	 */
	public function actionIndex()
	{
		$dataProvider=new CActiveDataProvider('AporteFondoDiferido');
		$this->render('index',array(
			'dataProvider'=>$dataProvider,
		));
	}

	/**
	 * Manages all models.
	 */
	public function actionAdmin()
	{
		$model=new AporteFondoDiferido('search');
		$model->unsetAttributes();  // clear any default values
		if(isset($_GET['AporteFondoDiferido']))
			$model->attributes=$_GET['AporteFondoDiferido'];

		$this->render('admin',array(
			'model'=>$model,
		));
	}

	/**
	 * Returns the data model based on the primary key given in the GET variable.
	 * If the data model is not found, an HTTP exception will be raised.
	 * @param integer the ID of the model to be loaded
	 */
	public function loadModel($id)
	{
		$model=AporteFondoDiferido::model()->findByPk($id);
		if($model===null)
			throw new CHttpException(404,'The requested page does not exist.');
		return $model;
	}

	/**
	 * Performs the AJAX validation.
	 * @param CModel the model to be validated
	 */
	protected function performAjaxValidation($model)
	{
		if(isset($_POST['ajax']) && $_POST['ajax']==='aporte-fondo-diferido-form')
		{
			echo CActiveForm::validate($model);
			Yii::app()->end();
		}
	}
}
