<?php

class AporteVoluntarioDiferidoController 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','adminAD'),
				'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 AporteVoluntarioDiferido;

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

		if(isset($_POST['AporteVoluntarioDiferido']))
		{
			$model->attributes=$_POST['AporteVoluntarioDiferido'];
			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='update';
                $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['AporteVoluntarioDiferido']))
		{
			$model->attributes=$_POST['AporteVoluntarioDiferido'];
            if ($model->id_estatus_avd == 5 && ! $activa) {
                Yii::app()->user->setFlash('error', 'No posee planillas liquidadas, para realizar esta acción.');
                $this->refresh();
            }

            if (($model->id_estatus_avd == 2 || $model->id_estatus_avd == 5) && $activa) {
                Yii::app()->user->setFlash('error', 'No pude asignar este estatus, ya que el asociado tiene planilla activa.');
                $this->refresh();
            }
                        
            if ($activa == false) {
                
                if ($model->id_estatus_avd == 6) {
                	
                	Yii::app()->user->setFlash('error', "No posee una planilla activa para actualizar al estatus Aportante Activo!");
                    $this->refresh();
                }
            } 
                        #########
                        if($model->id_estatus_avd==3 || $model->id_estatus_avd==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_estatus_avd==3||$model->id_estatus_avd==4)
                                                 {
                                                    /*$asociado=  Asociado::model()->find('cedula=:ci AND blnborrado=FALSE',array(':ci'=>$modelAsociado->cedula));
                                                    if($asociado)$modelAsociado=$asociado;*/
                                                    $modelAsociado->dirhabitacion='';
                                                    $modelAsociado->id_estatus=1;
                                                    
                                                    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 AporteVoluntario('carga_masiva_guardado');
                                                        
                                                        $modelAporte->id_asociado=$modelAsociado->idasociado;
                                                        $modelAporte->id_txt_integrado=$model->id_txt;
                                                        $modelAporte->id_aportante=$model->aportante;
                                                        $modelAporte->monto_cargado=$model->monto;
                                                        $unidad=  Unidad::model()->findByPk($model->area);
                                                        $modelAporte->id_unidad=$unidad->idunidad;
                                                        $modelAporte->id_usuario=Yii::app()->user->id;
                                                        if (! is_null($modelAsociado)) {
                                                            $modelAporte->opcion_retiro = $modelAsociado->aporte_voluntario;
                                                            $cuenta = AsociadoCuentaBanco::getCuentaPrincipal($modelAsociado->idasociado);

                                                            if ($modelAporte->opcion_retiro == 2 && ! is_null($cuenta)) {
                                                                $modelAporte->id_banco_asociado = $cuenta->id_banco;
                                                                $modelAporte->cuenta_destino = $cuenta->cuenta_bancaria;
                                                            }
                                                        }
                                                        $modelAporte->aplicarComisionAdministrativa();

                                                        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_estatus_avd==6){

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

				                                	if (!empty($consulta)) {
				                                		
				                                		$modelAporte= new AporteVoluntario('carga_masiva_guardado');

				                                        $modelAporte->id_asociado=$consulta->idasociado;
                                                        $modelAporte->id_txt_integrado=$model->id_txt;
                                                        $modelAporte->id_aportante=$model->aportante;
                                                        $modelAporte->monto_cargado=$model->monto;
                                                        $unidad=  Unidad::model()->findByPk($model->area);
                                                        $modelAporte->id_unidad=$unidad->idunidad;
                                                        $modelAporte->id_usuario=Yii::app()->user->id;
                                                        if (! is_null($modelAsociado)) {
                                                            $modelAporte->opcion_retiro = $modelAsociado->aporte_voluntario;
                                                            $cuenta = AsociadoCuentaBanco::getCuentaPrincipal($modelAsociado->idasociado);

                                                            if ($modelAporte->opcion_retiro == 2 && ! is_null($cuenta)) {
                                                                $modelAporte->id_banco_asociado = $cuenta->id_banco;
                                                                $modelAporte->cuenta_destino = $cuenta->cuenta_bancaria;
                                                            }
                                                        }
                                                        $modelAporte->aplicarComisionAdministrativa();

				                                        if($modelAporte->save()){
				                                              $model->blnborrado=true;
				                                              $model->save(false);                                                              
				                                        }
    				                                } else {

    			                                		Yii::app()->user->setFlash('error', "Este asociado no posee una planilla activa");
    	                    							$this->refresh();
    			                                	}
                                                }
                                                 
                                        $countDiferidos= AporteVoluntarioDiferido::model()->count('id_txt=:idTxt AND id_estatus_avd=: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(); 
                                                    
                                                }    
                                            
                                            }
                                        
                                        }
                                        else {
                                            echo 'no guardo';exit;
                                            
                                        }
                                        $transaction->commit(); #Ejecuta todas las operaciones
                                        $this->redirect(array('adminAD','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));
                                }
                                
				
                        }
                        
                        #########
                        
//			if($model->save())
//				$this->redirect(array('adminAD','id'=>$model->id_txt));
		}

		$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
			$model=$this->loadModel($id);
                        $model->blnborrado=TRUE;
                        $transaction=Yii::app()->db->beginTransaction();
                    try
                    {
                        if($model->save())
                            {
                                $modeltxt= DatosTxtIntegrado::model()->findByPk($model->id_txt);
                                $modeltxt->total_aportes=$modeltxt->total_aportes-$model->monto;
                                if($modeltxt->save(FALSE))$transaction->commit();
                            
                            }
                    }catch (Exception $ex) {
                        $transaction->rollback();
                        Yii::app()->user->setFlash('error', "ocurrio un error durante el proceso, se revirtieron todos los cambios");
                         }
                    
			// 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('AporteVoluntarioDiferido');
		$this->render('index',array(
			'dataProvider'=>$dataProvider,
		));
	}

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

		$this->render('admin',array(
			'model'=>$model,
		));
	}
        
        public function actionAdminAD($id)
	{
		$model=new AporteVoluntarioDiferido('search');
                $modelDatosTxt=DatosTxtIntegrado::model()->findByPk($id);
		$model->unsetAttributes();  // clear any default values
		if(isset($_GET['AporteVoluntarioDiferido']))
			$model->attributes=$_GET['AporteVoluntarioDiferido'];

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

	/**
	 * 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=AporteVoluntarioDiferido::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-voluntario-diferido-form')
		{
			echo CActiveForm::validate($model);
			Yii::app()->end();
		}
	}
}
