/* * 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.ArrayList; import java.util.Collection; import java.util.Collections; import java.util.Comparator; import java.util.Iterator; import java.util.List; import java.util.TreeSet; /** * Funcionalidade Esta classe representa as funcionalidades do sistema. * * @author SERPRO * @version $Revision: 1.1.2.3 $, $Date: 2011/10/20 17:07:44 $ * @version 0.1, Date: 2004/11/19 */ public class Funcionalidade extends PersistentObject { private static final long serialVersionUID = 1L; /* Requerido */ private Long id; /* Requerido */ private String descricao; /* Requerido */ private Timestamp dataCadastramento; private Boolean geraHistorico; private Boolean itemMenu; private Boolean necessarioLogin; private Integer ordemItemMenu; private String path; private String imageWidth; private String pathImageHi; private String pathImageLo; private Funcionalidade itemPai; private Collection listaSubItem = 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 descricao. */ public String getDescricao() { return descricao; } /** * @param descricao * descricao a ser atribuido. */ public void setDescricao(String descricao) { if (descricao == null || descricao.length() == 0) { throw new NullPointerException(); } this.descricao = descricao; } /** * @return Retorna geraHistorico. */ public Boolean getGeraHistorico() { return this.geraHistorico; } /** * @param geraHistorico * geraHistorico a ser atribuido. */ public void setGeraHistorico(Boolean geraHistorico) { this.geraHistorico = geraHistorico; } /** * @return Retorna itemMenu. */ public Boolean getItemMenu() { return this.itemMenu; } /** * @param itemMenu * itemMenu a ser atribuido. */ public void setItemMenu(Boolean itemMenu) { this.itemMenu = itemMenu; } /** * @return Retorna dataCadastramento. */ public Timestamp getDataCadastramento() { return this.dataCadastramento; } /** * @param dataCadastramento * dataCadastramento a ser atribuido. */ public void setDataCadastramento(Timestamp dataCadastramento) { if (dataCadastramento == null) { throw new NullPointerException(); } this.dataCadastramento = dataCadastramento; } /** * @return Retorna listaSubItem. */ public Collection getListaSubItem() { return this.listaSubItem; } /** * @param listaSubItem * listaSubItem a ser atribuido. */ public void setListaSubItem(Collection listaSubItem) { this.listaSubItem = listaSubItem; } /** * @return Retorna path. */ public String getPath() { return this.path; } /** * @param path * path a ser atribuido. */ public void setPath(String path) { this.path = path; } /** * * @return */ public Funcionalidade getItemPai() { return this.itemPai; } /** * * @param itemPai */ public void setItemPai(Funcionalidade itemPai) { this.itemPai = itemPai; } /** * @return Retorna ordemItemMenu. */ public Integer getOrdemItemMenu() { return this.ordemItemMenu; } /** * @param ordemItemMenu * ordemItemMenu a ser atribuido. */ public void setOrdemItemMenu(Integer ordemItemMenu) { this.ordemItemMenu = ordemItemMenu; } /** * @return Retorna necessarioLogin. */ public Boolean getNecessarioLogin() { return this.necessarioLogin; } /** * @param necessarioLogin * necessarioLogin a ser atribuido. */ public void setNecessarioLogin(Boolean necessarioLogin) { this.necessarioLogin = necessarioLogin; } public List getListaSubItemMenu(Funcionario funcionario) { List listaRetorno = new ArrayList(); Iterator iter; Funcionalidade funcionalidade; iter = this.getListaSubItem().iterator(); while (iter.hasNext()) { funcionalidade = (Funcionalidade) iter.next(); if (funcionalidade.getItemMenu().booleanValue() && funcionario.getListaFuncionalidade().contains( funcionalidade)) { listaRetorno.add(funcionalidade); } } class FuncionalidadeComparator implements Comparator { public final int compare(Object a, Object b) { return (((Funcionalidade) a).getOrdemItemMenu()) .compareTo((((Funcionalidade) b).getOrdemItemMenu())); } // end compare } // end class StringComparator Collections.sort(listaRetorno, new FuncionalidadeComparator()); return listaRetorno; } /** * @return Retorna pathImageHi. */ public String getPathImageHi() { return pathImageHi; } /** * @param pathImageHi * pathImageHi a ser atribuido. */ public void setPathImageHi(String pathImage) { this.pathImageHi = pathImage; } /** * @return Retorna pathImageLo. */ public String getPathImageLo() { return pathImageLo; } /** * @param pathImageLo * pathImageLo a ser atribuido. */ public void setPathImageLo(String pathImageLo) { this.pathImageLo = pathImageLo; } /** * @return Retorna imageWidth. */ public String getImageWidth() { return imageWidth; } /** * @param imageWidth * imageWidth a ser atribuido. */ public void setImageWidth(String imageWidth) { this.imageWidth = imageWidth; } }