<?php

/**
 * This is the model class for table "sidcai_moneda".
 *
 * The followings are the available columns in table 'sidcai_moneda':
 * @property integer $mone_codigo_pk
 * @property string $mone_nombre
 * @property string $mone_simbolo
 * @property integer $mone_division
 * @property string $mone_fechainicio
 * @property string $mone_fechafin
 */
class SidcaiMoneda extends CActiveRecord{
	/**
	 * @return string the associated database table name
	 */
	public function tableName(){
		return 'sidcai_moneda';
	}

	/**
	 * @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(
				'mone_nombre, mone_simbolo, mone_division, mone_fechainicio', 
				'required',
				'message' => 'Este campo es requerido.'
			),
			array(
				'mone_nombre, mone_simbolo, mone_division, mone_fechainicio', 
				'filter', 
				'filter' => 'trim'
			),
			array(
				'mone_division', 
				'numerical', 
				'integerOnly' => true,
				'message' => 'Solo se permite números enteros.'
			),
			array(
				'mone_nombre', 
				'length', 
				'min' => 4,
				'tooShort' => 'Mínimo 4 caracteres.',
				'max' => 25,
				'tooLong' => 'Máximo 25 caracteres.',
			),
			array(
				'mone_simbolo', 
				'length', 
				'min' => 2,
				'tooShort' => 'Mínimo 2 caracteres.',
				'max' => 6,
				'tooLong' => 'Máximo 6 caracteres.',
			),
			array(
				'mone_division', 
				'compare', 
				'compareValue' => '0',
				'operator' => '!=', 
				'message' => 'El valor tiene que ser mayor a 1.'
			),
			array(
				'mone_division',
				'length',
				'min' => 1,
				'tooShort' => 'Mínimo 1 digito',
				'max' => 10,
				'tooLong' => 'Máximo 10 digitos.'
			),
			array(
				'mone_fechafin',
				'compararFecha'
			),
			array(
				'mone_nombre', 
				'unique', 
				'attributeName' => 'mone_nombre',
				'className' => 'SidcaiMoneda',
				'message' => '{value} ya se encuentra registrado.',
				'on' => 'agregar'
			),
			array(
				'mone_simbolo', 
				'unique', 
				'attributeName' => 'mone_simbolo',
				'className' => 'SidcaiMoneda',
				'message' => '{value} ya se encuentra registrado.',
				'on' => 'agregar'
			),
			array(
				'mone_nombre',
				'existeNombre',
				'on' => 'modificar'
			),
			array(
				'mone_simbolo',
				'existeSimbolo',
				'on' => 'modificar'
			),
			array(
				'mone_fechafin', 
				'safe'
			),
		);
	}

	/**
	 * @return array customized attribute labels (name=>label)
	 */
	public function attributeLabels(){
		return array(
			'mone_codigo_pk' => 'Código',
			'mone_nombre' => 'Nombre',
			'mone_simbolo' => 'Simbolo',
			'mone_division' => 'Division',
			'mone_fechainicio' => 'Fecha inicio',
			'mone_fechafin' => 'Fecha fin',
		);
	}

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

	/* Si el nombre que está guardado en la Base de Datos es distinto al que se quiere editar que compruebe que no exista otro registro con el mismo nombre. */
	public function existeNombre(){
		$original = SidcaiMoneda::model()->findByPk($this->mone_codigo_pk);
		$nuevo = SidcaiMoneda::model()->find('mone_nombre = :mone_nombre', array(':mone_nombre' =>$this->mone_nombre ));

		if($nuevo != null){
			if($nuevo->mone_codigo_pk != $original->mone_codigo_pk)
				$this->addError('mone_nombre', $this->mone_nombre. ' ya se encuentra registrado.');
		}
	}

	/* Si el simbolo que está guardado en la Base de Datos es distinto al que se quiere editar que compruebe que no exista otro registro con el mismo simbolo. */
	public function existeSimbolo(){
		$original = SidcaiMoneda::model()->findByPk($this->mone_codigo_pk);
		$nuevo = SidcaiMoneda::model()->find('mone_simbolo = :mone_simbolo', array(':mone_simbolo' =>$this->mone_simbolo ));

		if($nuevo != null){
			if($nuevo->mone_codigo_pk != $original->mone_codigo_pk)
				$this->addError('mone_simbolo', $this->mone_simbolo. ' ya se encuentra registrado.');
		}
	}

	/* Comprueba que la fecha fin no sea mayor que la fecha de inicio. */
	public function compararFecha(){
		if($this->mone_fechafin != "" && $this->mone_fechainicio != ""){
			$fecha_inicio = strtotime(str_replace("/", "-", $this->mone_fechainicio));
			$fecha_fin = strtotime(str_replace("/", "-", $this->mone_fechafin));

			if($fecha_inicio > $fecha_fin)
				$this->addError('mone_fechafin', 'La fecha de cierre no puede ser menor que '.$this->mone_fechainicio);
		}
	}
}
