<?php

/**
 * This is the model class for table "retiro.periodicidad_liquidacion".
 *
 * The followings are the available columns in table 'retiro.periodicidad_liquidacion':
 * @property string $id_conf_liquidacion
 * @property string $id_periodicidad
 * @property integer $cantidad_peticiones
 * @property string $monto_ofertado
 * @property boolean $blnborrado
 * @property string $id_usuario
 * @property boolean $publicar
 * @property string $fecha_registro
 * @property integer $dia
 * @property integer $id
 *
 * The followings are the available model relations:
 * @property ConfLiquidacion $idConfLiquidacion
 * @property Periodicidad $idPeriodicidad
 */
class PeriodicidadLiquidacion extends CActiveRecord
{
    public $nombreDia = array("Domingo","Lunes","Martes","Mi&eacute;rcoles","Jueves","Viernes","S&aacute;bado"),$numeroDia;
	/**
	 * @return string the associated database table name
	 */
	public function tableName()
	{
		return 'retiro.periodicidad_liquidacion';
	}

	/**
	 * @return array validation rules for model attributes.
	 */
	public function rules()
	{
		// NOTE: you should only define rules for those attributes that
		// will receive user inputs.
		return array(
			//array('id_conf_liquidacion, id_periodicidad', 'required'),
                        array('monto_ofertado','required','on'=>'Monto'),
                        array('cantidad_peticiones','required','on'=>'Semanal'),
                        array('dia','validarDatos','on'=>'Diarias'),
                        array('monto_ofertado', 'match',  //PARA VALIDAR CAMPOS CON FORMATO MONEDA
					'pattern' => '/^[0-9]\d{0,2}(\.[0-9]\d{2,2})*(\,\d{1,2})?$/',
 					'message' => 'El valor del campo debe tener un formato 100.000,00',),    
                    
                    
			//array('cantidad_peticiones, dia', 'numerical', 'integerOnly'=>true),
			array('monto_ofertado', 'length', 'max'=>8),
			array('blnborrado, id_usuario, publicar, fecha_registro,cantidad_peticiones', 'safe'),
			// The following rule is used by search().
			// @todo Please remove those attributes that should not be searched.
			array('id_conf_liquidacion, id_periodicidad, cantidad_peticiones, monto_ofertado, blnborrado, id_usuario, publicar, fecha_registro, dia, id', 'safe', 'on'=>'search'),
		);
	}

	/**
	 * @return array relational rules.
	 */
	public function relations()
	{
		// NOTE: you may need to adjust the relation name and the related
		// class name for the relations automatically generated below.
		return array(
			'idConfLiquidacion' => array(self::BELONGS_TO, 'ConfLiquidacion', 'id_conf_liquidacion'),
			'idPeriodicidad' => array(self::BELONGS_TO, 'Periodicidad', 'id_periodicidad'),
		);
	}

        public function validarDatos()
	{
                if($this->dia != 0 && $this->cantidad_peticiones==''){
                    $this->addError('cantidad_peticiones','Cantidad de peticiones no puede ser nulo');
                }


	}
	/**
	 * @return array customized attribute labels (name=>label)
	 */
	public function attributeLabels()
	{
		return array(
			'id_conf_liquidacion' => 'Id Conf Liquidacion',
			'id_periodicidad' => 'Id Periodicidad',
			'cantidad_peticiones' => 'Cantidad Peticiones',
			'monto_ofertado' => 'Monto Ofertado',
			'blnborrado' => 'Blnborrado',
			'id_usuario' => 'Id Usuario',
			'publicar' => 'Publicar',
			'fecha_registro' => 'Fecha Registro',
			'dia' => 'Dia',
			'id' => 'ID',
		);
	}

	/**
	 * Retrieves a list of models based on the current search/filter conditions.
	 *
	 * Typical usecase:
	 * - Initialize the model fields with values from filter form.
	 * - Execute this method to get CActiveDataProvider instance which will filter
	 * models according to data in model fields.
	 * - Pass data provider to CGridView, CListView or any similar widget.
	 *
	 * @return CActiveDataProvider the data provider that can return the models
	 * based on the search/filter conditions.
	 */
	public function search()
	{
		// @todo Please modify the following code to remove attributes that should not be searched.

		$criteria=new CDbCriteria;

		$criteria->compare('id_conf_liquidacion',$this->id_conf_liquidacion,true);
		$criteria->compare('id_periodicidad',$this->id_periodicidad,true);
		$criteria->compare('cantidad_peticiones',$this->cantidad_peticiones);
		$criteria->compare('monto_ofertado',$this->monto_ofertado,true);
		$criteria->compare('blnborrado',$this->blnborrado);
		$criteria->compare('id_usuario',$this->id_usuario,true);
		$criteria->compare('publicar',$this->publicar);
		$criteria->compare('fecha_registro',$this->fecha_registro,true);
		$criteria->compare('dia',$this->dia);
		$criteria->compare('id',$this->id);

		return new CActiveDataProvider($this, array(
			'criteria'=>$criteria,
		));
	}

        public function beforeSave(){            
//            $this->monto_solicitado =  str_replace('.', '', $this->monto_solicitado);
//            $this->monto_solicitado=str_replace(',', '.', $this->monto_solicitado);
            $this->monto_ofertado =  str_replace('.', '', $this->monto_ofertado);
            $this->monto_ofertado=str_replace(',', '.', $this->monto_ofertado);
            if($this->cantidad_peticiones=='')
                $this->cantidad_peticiones= NULL;
            if($this->monto_ofertado=='')
                 $this->monto_ofertado= NULL;
            
            return parent::beforeSave();
        }
	/**
	 * Returns the static model of the specified AR class.
	 * Please note that you should have this exact method in all your CActiveRecord descendants!
	 * @param string $className active record class name.
	 * @return PeriodicidadLiquidacion the static model class
	 */
	public static function model($className=__CLASS__)
	{
		return parent::model($className);
	}
}
