<?php

class AporteOrdinarioDiferidoController 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 AporteOrdinarioDiferido;

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

		if(isset($_POST['AporteOrdinarioDiferido']))
		{
			$model->attributes=$_POST['AporteOrdinarioDiferido'];
			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_cmao';
        $modelAsociado= new Asociado('sin_validacion');
        $modelAsociado->cedula = $model->cedula;
        $planillas= Asociado::model()->findAll('cedula=:ci', [':ci'=>$model->cedula]);
        $activa = false;
        $egresoEmpresa = false;
        $liquidada = false;

        foreach ($planillas as $key => $value) {
            if ($value->id_estatus==1) {
                $activa = true;
            }

            if ($value->id_estatus == 2) {
                $liquidada = true;
            }

            if ($value->id_estatus == 4) {
                $egresoEmpresa = true;
            }
        }

        if (isset($_POST['AporteOrdinarioDiferido'])) {
            $model->attributes=$_POST['AporteOrdinarioDiferido'];

            if (in_array($model->id_estatus_aod, [2, 5]) && $activa) {
                Yii::app()->user->setFlash('error', 'No pude asignar este estatus, ya que el asociado tiene planilla activa.');
                $this->refresh();
            }

            if ($activa == false && ! $egresoEmpresa && $model->id_estatus_aod == 6) {
                Yii::app()->user->setFlash('error', 'No posee una planilla activa para actualizar a este estatus');
                $this->refresh();
            }

            if ($model->id_estatus_aod == 2 && $liquidada) {
                Yii::app()->user->setFlash('error', 'El asociado tiene una planilla liquidada.');
                $this->refresh();
            }

            if (in_array($model->id_estatus_aod, [3, 4])) {
                $modelAsociado->scenario = 'planilla_cmao';
            }

            if ($model->id_estatus_aod == 2) {
                $modelAsociado->scenario = 'definicion_no_asociados';
            }

            $modelAsociado->attributes=$_POST['Asociado'];
            if ($model->validate() && $modelAsociado->validate()) {
                $transaction = Yii::app()->db->beginTransaction();
                try {
                    $model->extra = null;
                    if ($model->id_estatus_aod == 2) {
                        $model->extra = json_encode([
                            'razon_social' => $modelAsociado->nombre_apellido,
                            'id_tipo_persona' => $modelAsociado->id_tipo_persona,
                            'cedula' => $modelAsociado->cedula,
                            'id_banco' => $modelAsociado->id_banco,
                            'numero_cuenta' => $modelAsociado->numero_cuenta,
                            'correoelectronico' => $modelAsociado->correoelectronico,
                        ]);
                    }

                    if ($model->save()) {
                        if ($model->id_estatus_aod == 3 || $model->id_estatus_aod == 4) {
                            $modelAsociado->dirhabitacion='';
                            $modelAsociado->clvcreado_por=Yii::app()->user->id;
                            if ($modelAsociado->save()) {
                                $ex=0;
                                $modelUsuario=CrugeUserI::model()->find('cedula=:ci', [':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;
                                if ($modelUsuario->save()) {
                                    if ($ex>0) {
                                        Yii::app()->user->rbac->assign("usuario_asociado", $modelUsuario->primaryKey);
                                    }
                                }

                                $modelAporte= new AporteOrdinario('carga_masiva_guardado');
                                $modelAporte->id_asociado=$modelAsociado->idasociado;
                                $modelAporte->id_txt=$model->id_txt;
                                $modelAporte->aporte_patrono=$model->aporte_patrono;
                                $modelAporte->aporte_asociado=$model->aporte_asociado;
                                $modelAporte->sueldo_base=$model->sueldo;
                                $modelAporte->p_patrono=$model->p_patrono;
                                $modelAporte->p_asociado=$model->p_asociado;
                                $tipoNomina= TipoNomina::model()->find('codigo_nomina=:cod', [':cod'=>$model->tipo_nomina]);
                                if ($tipoNomina) {
                                    $modelAporte->id_tipo_nomina=$tipoNomina->id;
                                }

                                $modelAporte->fecha_aporte=$model->idTxt->fecha_aporte;
                                $unidad=  Unidad::model()->findByPk($model->unidad);
                                $modelAporte->id_unidad=$unidad->idunidad;
                                $modelAporte->id_usuario=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_estatus_aod == 6 && $egresoEmpresa) {
                            $consulta = Asociado::model()->find('cedula=:ci and id_estatus=4', ['ci' => $model->cedula]);

                            if (empty($consulta)) {
                                Yii::app()->user->setFlash('error', 'Este asociado no posee una planilla activa');
                                $this->refresh();
                            }

                            $modelAporte = new AporteOrdinario('carga_masiva_guardado');
                            $modelAporte->id_asociado = $consulta->idasociado;
                            $modelAporte->id_txt = $model->id_txt;
                            $modelAporte->aporte_patrono = $model->aporte_patrono;
                            $modelAporte->aporte_asociado = $model->aporte_asociado;
                            $modelAporte->sueldo_base = $model->sueldo;
                            $modelAporte->p_patrono = $model->p_patrono;
                            $modelAporte->p_asociado = $model->p_asociado;

                            $tipoNomina = TipoNomina::model()->find('codigo_nomina=:cod', [':cod' => $model->tipo_nomina]);
                            if ($tipoNomina) {
                                $modelAporte->id_tipo_nomina = $tipoNomina->id;
                            }

                            $modelAporte->fecha_aporte = $model->idTxt->fecha_aporte;
                            $unidad = Unidad::model()->findByPk($model->unidad);
                            $modelAporte->id_unidad = $unidad->idunidad;
                            $modelAporte->id_usuario = Yii::app()->user->id;

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

                        if ($model->id_estatus_aod == 6 && ! $egresoEmpresa) {
                            $consulta = Asociado::model()->find('cedula=:ci and id_estatus=1', ['ci'=>$model->cedula]);

                            if (! empty($consulta)) {
                                $modelAporte= new AporteOrdinario('carga_masiva_guardado');
                                $modelAporte->id_asociado=$consulta->idasociado;
                                $modelAporte->id_txt=$model->id_txt;
                                $modelAporte->aporte_patrono=$model->aporte_patrono;
                                $modelAporte->aporte_asociado=$model->aporte_asociado;
                                $modelAporte->sueldo_base=$model->sueldo;
                                $modelAporte->p_patrono=$model->p_patrono;
                                $modelAporte->p_asociado=$model->p_asociado;
                                $tipoNomina= TipoNomina::model()->find('codigo_nomina=:cod', [':cod'=>$model->tipo_nomina]);
                                if ($tipoNomina) {
                                    $modelAporte->id_tipo_nomina=$tipoNomina->id;
                                }
                                $modelAporte->fecha_aporte=$model->idTxt->fecha_aporte;
                                $unidad=  Unidad::model()->findByPk($model->unidad);
                                $modelAporte->id_unidad=$unidad->idunidad;
                                $modelAporte->id_usuario=Yii::app()->user->id;

                                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= AporteOrdinarioDiferido::model()->count('id_txt=:idTxt AND id_estatus_aod=:id ', [':idTxt'=>$model->id_txt,':id'=>1]);
                        if ($countDiferidos==0) {
                            EstatusTxtIntegrado::model()->updateAll(['actual'=>false], 'id_datos_txt_integrado=:id', [':id'=>$model->id_txt]);
                            $status=EstatusTxtIntegrado::model()->find('id_estatus_txt=:idEstatus AND id_datos_txt_integrado=:idTxt', [':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();
                    $this->redirect(['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(['update','id'=>$model->id]);
                }
            }
        }

        $this->render('update', [
            '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('AporteOrdinarioDiferido');
		$this->render('index',array(
			'dataProvider'=>$dataProvider,
		));
	}

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

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

    public function actionAdminAD($id)
    {
        $model = new AporteOrdinarioDiferido('search');
        $modelDatosTxt = DatosTxtIntegrado::model()->findByPk($id);
        $model->unsetAttributes();

        if (isset($_GET['AporteOrdinarioDiferido'])) {
            $model->attributes = $_GET['AporteOrdinarioDiferido'];
        }

        $this->render('admin', [
            'model' => $model,
            'modelDatosTxt' => $modelDatosTxt,
            'modelAsociado' => new Asociado('sin_validacion'),
        ]);
    }

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