<?php

/**
 * This is the model class for table "sidcai_cambio_moneda".
 *
 * The followings are the available columns in table 'sidcai_cambio_moneda':
 * @property integer $camo_codigo_pk
 * @property string $camo_nombre
 * @property string $camo_simbolo
 * @property boolean $camo_habilitado
 */
class SidcaiCambioMoneda extends CActiveRecord{
	/**
	 * @return string the associated database table name
	 */
	public function tableName(){
		return 'sidcai_cambio_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(
				'camo_nombre, camo_simbolo', 
				'required',
				'message' => 'Este campo es requerido.'
			),
			array(
				'camo_nombre, camo_simbolo', 
				'filter', 
				'filter' => 'trim'
			),
			array(
				'camo_nombre', 
				'length', 
				'min' => 4,
				'tooShort' => 'Mínimo 4 caracteres.',
				'max' => 25,
				'tooLong' => 'Máximo 25 caracteres.',
			),
			array(
				'camo_simbolo', 
				'length', 
				'min' => 1,
				'tooShort' => 'Mínimo 1 caracteres.',
				'max' => 6,
				'tooLong' => 'Máximo 6 caracteres.',
			),
			array(
				'camo_nombre', 
				'unique', 
				'attributeName' => 'camo_nombre',
				'className' => 'SidcaiCambioMoneda',
				'message' => '{value} ya se encuentra registrado.',
				'on' => 'agregar'
			),
			array(
				'camo_simbolo', 
				'unique', 
				'attributeName' => 'camo_simbolo',
				'className' => 'SidcaiCambioMoneda',
				'message' => '{value} ya se encuentra registrado.',
				'on' => 'agregar'
			),
			array(
				'camo_nombre',
				'existeNombre',
				'on' => 'modificar'
			),
			array(
				'camo_simbolo',
				'existeSimbolo',
				'on' => 'modificar'
			),
			array(
				'camo_habilitado', 
				'safe'
			),
		);
	}

	/**
	 * @return array customized attribute labels (name=>label)
	 */
	public function attributeLabels(){
		return array(
			'camo_codigo_pk' => 'Código',
			'camo_nombre' => 'Nombre',
			'camo_simbolo' => 'Simbolo',
			'camo_habilitado' => 'Habilitado',
		);
	}

	/**
	 * 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 SidcaiCambioMoneda 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 = SidcaiCambioMoneda::model()->findByPk($this->camo_codigo_pk);
		$nuevo = SidcaiCambioMoneda::model()->find('camo_nombre = :camo_nombre', array(':camo_nombre' =>$this->camo_nombre ));

		if($nuevo != null){
			if($nuevo->camo_codigo_pk != $original->camo_codigo_pk)
				$this->addError('camo_nombre', $this->camo_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 = SidcaiCambioMoneda::model()->findByPk($this->camo_codigo_pk);
		$nuevo = SidcaiCambioMoneda::model()->find('camo_simbolo = :camo_simbolo', array(':camo_simbolo' =>$this->camo_simbolo ));

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

	public static function getMonedas(){
		$monedas = SidcaiCambioMoneda::model()->findAll('camo_habilitado = :camo_habilitado', array(':camo_habilitado' => true));

		return CHtml::listData($monedas, 'camo_codigo_pk', 'camo_nombre');
	}
}
