/* Title: Gráfico tema Inclui gráficos em cada elemento de um tema tendo como fonte a tabela de atributos. É criado um novo tema no mapa com os gráficos. Abre uma janela com várias opções e lista de itens para os gráficos. O tema que será utilizado é o que estiver armazenado na variável global i3GEO.temaAtivo Arquivo: i3geo/ferramentas/graficotema/index.js.php Licenca: GPL2 i3Geo Interface Integrada de Ferramentas de Geoprocessamento para Internet Direitos Autorais Reservados (c) 2006 Ministério do Meio Ambiente Brasil Desenvolvedor: Edmar Moretti edmar.moretti@gmail.com 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; Este programa é distribuído na expectativa de que seja útil, porém, SEM NENHUMA GARANTIA; nem mesmo a garantia implícita de COMERCIABILIDADE OU ADEQUAÇÃO A UMA FINALIDADE ESPECÍFICA. Consulte a Licença Pública Geral do GNU para mais detalhes. Você deve ter recebido uma cópia da Licença Pública Geral do GNU junto com este programa; se não, escreva para a Free Software Foundation, Inc., no endereço 59 Temple Street, Suite 330, Boston, MA 02111-1307 USA. */ if(typeof(i3GEOF) === 'undefined'){ var i3GEOF = {}; } /* Classe: i3GEOF.graficoTema */ i3GEOF.graficoTema = { propriedades : { mesmoTema : false }, tema : i3GEO.temaAtivo, /* Variavel: aguarde Estilo do objeto DOM com a imagem de aguarde existente no cabeçalho da janela. */ aguarde: "", /* Para efeitos de compatibilidade antes da versão 4.7 que não tinha dicionário */ criaJanelaFlutuante: function(){ i3GEOF.graficoTema.iniciaDicionario(); }, /** * Template no formato mustache. E preenchido na carga do javascript com o programa dependencias.php */ MUSTACHE : "", MUSTACHELISTA : "", /** * Susbtitutos para o template */ mustacheHash : function() { var dicionario = i3GEO.idioma.objetoIdioma(i3GEOF.graficoTema.dicionario); return dicionario; }, /* Function: iniciaDicionario Carrega o dicionário e chama a função que inicia a ferramenta O Javascript é carregado com o id i3GEOF.nomedaferramenta.dicionario_script */ iniciaDicionario: function(){ if(typeof(i3GEOF.graficoTema.dicionario) === 'undefined'){ i3GEO.util.scriptTag( i3GEO.configura.locaplic+"/ferramentas/graficotema/dicionario.js", "i3GEOF.graficoTema.iniciaJanelaFlutuante()", "i3GEOF.graficoTema.dicionario_script" ); } else{ i3GEOF.graficoTema.iniciaJanelaFlutuante(); } }, /* Function: inicia Inicia a ferramenta. É chamado por criaJanelaFlutuante Parametro: iddiv {String} - id do div que receberá o conteudo HTML da ferramenta */ inicia: function(iddiv){ if(i3GEOF.graficoTema.MUSTACHE == ""){ var t1 = i3GEO.configura.locaplic + "/ferramentas/graficotema/template_mst.html", t2 = i3GEO.configura.locaplic + "/ferramentas/graficotema/templateLista_mst.html"; $.when( $.get(t1),$.get(t2) ).done(function(r1,r2) { i3GEOF.graficoTema.MUSTACHE = r1[0]; i3GEOF.graficoTema.MUSTACHELISTA = r2[0]; i3GEOF.graficoTema.inicia(iddiv); }).fail(function() { i3GEO.janela.closeMsg($trad("erroTpl")); return; }); return; } if(i3GEOF.graficoTema.tema === ""){ //$i(iddiv).innerHTML = ""; return; } try{ $i(iddiv).innerHTML = i3GEOF.graficoTema.html(); if (!$i("i3GEOFgraficotemaComboCabecaSel")) { i3GEO.janela.comboCabecalhoTemasBs("i3GEOFgraficotemaComboCabeca","i3GEOFgraficotemaComboCabecaSel","graficoTema","ligadosComTabela",function(evt){ var botao = evt.target; if (botao) { if (botao.value != "") { i3GEO.mapa.ativaTema(botao.value); i3GEOF.graficoTema.tema = botao.value; $i(iddiv).innerHTML = ""; i3GEOF.graficoTema.inicia(iddiv); } else { //$i(iddiv).innerHTML = ""; } } }); } i3GEO.guias.mostraGuiaFerramenta("i3GEOgraficotemaguia1","i3GEOgraficotemaguia"); //eventos das guias $i("i3GEOgraficotemaguia1").onclick = function() {i3GEO.guias.mostraGuiaFerramenta("i3GEOgraficotemaguia1","i3GEOgraficotemaguia");}; $i("i3GEOgraficotemaguia2").onclick = function() {i3GEO.guias.mostraGuiaFerramenta("i3GEOgraficotemaguia2","i3GEOgraficotemaguia");}; // //pega a lista de itens e chama a função de montagem das opções de escolha // i3GEO.php.listaItensTema(i3GEOF.graficoTema.montaListaItens,i3GEOF.graficoTema.tema); } catch(erro){i3GEO.janela.tempoMsg(erro);} i3GEO.util.aplicaAquarela("i3GEOgraficotemaguia2obj"); }, /* Function: html Gera o código html para apresentação das opções da ferramenta Retorno: String com o código html */ html:function() { var ins = Mustache.render(i3GEOF.graficoTema.MUSTACHE, i3GEOF.graficoTema.mustacheHash()); return ins; }, /* Function: iniciaJanelaFlutuante Cria a janela flutuante para controle da ferramenta. */ iniciaJanelaFlutuante: function(propriedades){ if(propriedades){ i3GEOF.graficoTema.propriedades = propriedades; } var janela,divid,temp,titulo; if($i("i3GEOF.graficoTema")){ i3GEOF.graficoTema.inicia("i3GEOF.graficoTema_corpo"); return; } //cria a janela flutuante titulo = ""+$trad("t37a")+""; janela = i3GEO.janela.cria( "400px", "330px", "", "", "", titulo, "i3GEOF.graficoTema", false, "hd", "", "", "", true, "", "", "", "", "40" ); divid = janela[2].id; i3GEOF.graficoTema.aguarde = $i("i3GEOF.graficoTema_imagemCabecalho").style; $i("i3GEOF.graficoTema_corpo").style.backgroundColor = "white"; i3GEOF.graficoTema.inicia(divid); }, /* Function: montaListaItens Monta a lista de itens que poderão ser escolhidos para compor o mapa. A lista é inserida no elemento html com id "i3GEOgraficotemalistai" */ montaListaItens: function(retorno){ var ins,i,n, temp = {}, mustache = []; try{ ins = []; ins.push("