/*
* Sistema de Ouvidoria: um canal através do qual os usuários
* podem encaminhar suas reclamações, elogios e sugestões.
*
* Copyright (C) 2011 SERPRO
*
* Este programa é software livre; você pode redistribuí-lo e/ou
* modificá-lo sob os termos da Licença Pública Geral GNU, conforme
* publicada pela Free Software Foundation; tanto a versão 2 da
* Licença como (a seu critério) qualquer versão mais nova.
*
* Este programa é distribuído na expectativa de ser útil, mas SEM
* QUALQUER GARANTIA; sem mesmo a garantia implícita de
* COMERCIALIZAÇÃO ou de ADEQUAÇÃO A QUALQUER PROPÓSITO EM
* PARTICULAR. Consulte a Licença Pública Geral GNU para obter mais
* detalhes.
*
* Você deve ter recebido uma cópia da Licença Pública Geral GNU,
* sob o título "LICENCA.txt", junto com esse programa. Se não,
* acesse o Portal do Software Público Brasileiro no endereço
* http://www.softwarepublico.gov.br/ ou escreva para a Fundação do
* Software Livre (FSF) Inc., 51 Franklin St, Fifth Floor, Boston,
* MA 02111-1301, USA.
*
* Contatos através do seguinte endereço internet:
* http://www.serpro.gov.br/sistemaouvidoria/
*/
package br.gov.serpro.ouvidoria.model;
import java.sql.Timestamp;
import java.util.Collection;
import java.util.TreeSet;
import br.gov.serpro.ouvidoria.util.Utilitario;
/**
* Esta classe representa os scripts de acionamento que podem ser usados nas
* soluções de outros acionamentos.
*
* @author SERPRO
* @version $Revision: 1.1.2.3 $, $Date: 2011/10/20 19:27:38 $
* @version 0.1, Date: 2004/11/19
*/
public class Script extends PersistentObject {
private static final long serialVersionUID = 1L;
/* Requerido */
private Long id;
/* Requerido */
private String titulo;
/* Requerido */
private String descricao;
/* Não Requerido */
private String observacao;
/* Requerido */
private EstadoScript estado;
/* Requerido */
private Timestamp dataCadastramento;
/* Requerido */
private Assunto assunto;
/* Requerido */
private Collection listaAtendimento = new TreeSet();
/*
* (non-Javadoc)
*
* @see br.gov.serpro.ouvidoria.model.Identifiable#getId()
*/
public Long getId() {
return id;
}
/**
* @param id
* O id a ser atribuído.
*/
public void setId(Long id) {
this.id = id;
}
/**
* @return Retorna o título.
*/
public String getTitulo() {
return titulo;
}
/**
* @param titulo
* O título a ser atribuído.
*/
public void setTitulo(String titulo) {
if (titulo == null || titulo.length() == 0) {
throw new NullPointerException();
}
this.titulo = titulo;
}
/**
* @return Retorna o descricao.
*/
public String getDescricao() {
return descricao;
}
/**
* Retorna o Texto substituindo <code>\n\r, \n ou \r por <br/></code>;
*
* @return Retorna a descricao formatada.
*/
public String getDescricaoFormatada() {
return Utilitario.trataEnter(getDescricao());
}
/**
* @param descricao
* O descricao a ser atribuído.
*/
public void setDescricao(String texto) {
if (texto == null || texto.length() == 0) {
throw new NullPointerException();
}
this.descricao = texto;
}
/**
* @return Retorna o estado.
*/
public EstadoScript getEstado() {
return estado;
}
/**
* @param estado
* O estado a ser atribuído.
*/
public void setEstado(EstadoScript estado) {
if (estado == null) {
throw new NullPointerException();
}
this.estado = estado;
}
/**
* @return Retorna a data (e hora) de cadastramento da solução.
*/
public Timestamp getDataCadastramento() {
return dataCadastramento;
}
/**
* @param data
* A data (e hora) de cadastramento da solução.
*/
public void setDataCadastramento(Timestamp dataCadastramento) {
if (dataCadastramento == null) {
throw new NullPointerException();
}
this.dataCadastramento = dataCadastramento;
}
/**
* @return Retorna o assunto ao qual a solução se refere.
*/
public Assunto getAssunto() {
return assunto;
}
/**
* @param assunto
* O assunto ao qual a solução se refere.
*/
public void setAssunto(Assunto assunto) {
if (assunto == null) {
throw new NullPointerException();
}
this.assunto = assunto;
}
/**
* @return Retorna observacao.
*/
public String getObservacao() {
return observacao;
}
/**
* @param observacao
* observacao a ser atribuido.
*/
public void setObservacao(String observacao) {
this.observacao = observacao;
}
/**
* @return Retorna listaAtendimento.
*/
public Collection getListaAtendimento() {
return listaAtendimento;
}
/**
* @param listaAtendimento
* listaAtendimento a ser atribuido.
*/
public void setListaAtendimento(Collection listaAtendimento) {
this.listaAtendimento = listaAtendimento;
}
public int getQuantidadeAtendimentos() {
int qtd = 0;
if (this.listaAtendimento != null) {
qtd = this.listaAtendimento.size();
}
return qtd;
}
}