<?php

/**
 * This is the model class for table "retiro.periodicidad_retiro_parcial".
 *
 * The followings are the available columns in table 'retiro.periodicidad_retiro_parcial':
 * @property string $id_conf_retiro_parcial
 * @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
 */
class PeriodicidadRetiroParcial 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_retiro_parcial';
	}

	/**
	 * @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_retiro_parcial, 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', 'numerical', 'integerOnly'=>true),
			array('monto_ofertado', 'length', 'max'=>8),
			array('blnborrado, id_usuario, publicar, fecha_registro, dia,cantidad_peticiones', 'safe'),
			// The following rule is used by search().
			// @todo Please remove those attributes that should not be searched.
			array('id_conf_retiro_parcial, id_periodicidad, cantidad_peticiones, monto_ofertado, blnborrado, id_usuario, publicar, fecha_registro', '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(
		);
	}

	/**
	 * @return array customized attribute labels (name=>label)
	 */
	public function attributeLabels()
	{
		return array(
			'id_conf_retiro_parcial' => 'Id Conf Retiro Parcial',
			'id_periodicidad' => 'Id Periodicidad',
			'cantidad_peticiones' => 'Cantidad Peticiones',
			'monto_ofertado' => 'Monto Ofertado',
			'blnborrado' => 'Blnborrado',
			'id_usuario' => 'Id Usuario',
			'publicar' => 'Publicar',
			'fecha_registro' => 'Fecha Registro',
		);
	}
        public function validarDatos()
	{
                if($this->dia != 0 && $this->cantidad_peticiones==''){
                    $this->addError('cantidad_peticiones','Cantidad de peticiones no puede ser nulo');
                }
                if($this->dia ==0)
                    $this->cantidad_peticiones=NULL;


	}

	/**
	 * 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_retiro_parcial',$this->id_conf_retiro_parcial,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);

		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 PeriodicidadRetiroParcial the static model class
	 */
	public static function model($className=__CLASS__)
	{
		return parent::model($className);
	}
}
