Commit 5f1fc690154203b79e115dfce1a203f99f5d5e67
1 parent
b9409e99
Exists in
master
and in
7 other branches
Correção no indicador de região no mapa de referência. Remoção do programa admin…
…/php/classe_arvorede.php
Showing
18 changed files
with
2626 additions
and
1650 deletions
Show diff stats
admin/admin.db
No preview for this file type
admin/php/classe_arvore.php
| @@ -1,1274 +0,0 @@ | @@ -1,1274 +0,0 @@ | ||
| 1 | -<?php | ||
| 2 | -/* | ||
| 3 | -Title: classe_arvore.php | ||
| 4 | - | ||
| 5 | -Funções para montagem da árvore de temas | ||
| 6 | - | ||
| 7 | -Licenca: | ||
| 8 | - | ||
| 9 | -GPL2 | ||
| 10 | - | ||
| 11 | -i3Geo Interface Integrada de Ferramentas de Geoprocessamento para Internet | ||
| 12 | - | ||
| 13 | -Direitos Autorais Reservados (c) 2006 Ministério do Meio Ambiente Brasil | ||
| 14 | -Desenvolvedor: Edmar Moretti edmar.moretti@gmail.com | ||
| 15 | - | ||
| 16 | -Este programa é software livre; você pode redistribuí-lo | ||
| 17 | -e/ou modificá-lo sob os termos da Licença Pública Geral | ||
| 18 | -GNU conforme publicada pela Free Software Foundation; | ||
| 19 | - | ||
| 20 | -Este programa é distribuído na expectativa de que seja útil, | ||
| 21 | -porém, SEM NENHUMA GARANTIA; nem mesmo a garantia implícita | ||
| 22 | -de COMERCIABILIDADE OU ADEQUAÇÃO A UMA FINALIDADE ESPECÍFICA. | ||
| 23 | -Consulte a Licença Pública Geral do GNU para mais detalhes. | ||
| 24 | -Você deve ter recebido uma c�pia da Licença Pública Geral do | ||
| 25 | - GNU junto com este programa; se não, escreva para a | ||
| 26 | -Free Software Foundation, Inc., no endereço | ||
| 27 | -59 Temple Street, Suite 330, Boston, MA 02111-1307 USA. | ||
| 28 | - | ||
| 29 | -Arquivo: | ||
| 30 | - | ||
| 31 | -i3geo/admin/php/classe_arvore.php | ||
| 32 | -*/ | ||
| 33 | -/* | ||
| 34 | -Classe: Arvore | ||
| 35 | - | ||
| 36 | -Classe utilizada para compor a árvore de temas ou obter dados específicos da árvore. | ||
| 37 | - | ||
| 38 | -É utilizada por várias operações do i3Geo, principalmente pela <classe_menutemas> | ||
| 39 | -*/ | ||
| 40 | -class Arvore | ||
| 41 | -{ | ||
| 42 | - //temas com acesso restrito e que nao podem ser acessados pelo usuario que esta logado | ||
| 43 | - public $temassindevidos; | ||
| 44 | - protected $locaplic; | ||
| 45 | - //subgrupos que tem pelo menos um tema | ||
| 46 | - //public $sql_subgrupos = "select i3geoadmin_subgrupos.nome_subgrupo,i3geoadmin_n2.id_n2,i3geoadmin_n2.publicado,i3geoadmin_n2.n2_perfil from i3geoadmin_n2 LEFT JOIN i3geoadmin_subgrupos ON i3geoadmin_n2.id_subgrupo = i3geoadmin_subgrupos.id_subgrupo "; | ||
| 47 | - //grupos que tem pelo menos um sub-grupo | ||
| 48 | - //public $sql_grupos = "select i3geoadmin_grupos.nome_grupo,id_n1,id_menu,i3geoadmin_n1.publicado,n1_perfil from i3geoadmin_n1 LEFT JOIN i3geoadmin_grupos ON i3geoadmin_n1.id_grupo = i3geoadmin_grupos.id_grupo "; | ||
| 49 | - //nomes de todos os grupos | ||
| 50 | - public $sql_todosgrupos = "select * from i3geoadmin_grupos "; | ||
| 51 | - //tipo de filtro | ||
| 52 | - //ogc|download|"" | ||
| 53 | - public $filtro; | ||
| 54 | - //temas na raiz | ||
| 55 | - //public $sql_temasraiz = "select id_raiz,i3geoadmin_raiz.id_tema,nome_tema,tipoa_tema FROM i3geoadmin_raiz LEFT JOIN i3geoadmin_temas ON i3geoadmin_temas.id_tema = i3geoadmin_raiz.id_tema "; | ||
| 56 | - //todos os temas | ||
| 57 | - //public $sql_temas = "select * from i3geoadmin_temas "; | ||
| 58 | - //temas de um subgrupo | ||
| 59 | - //public $sql_temasSubgrupo = "select i3geoadmin_temas.tipoa_tema, i3geoadmin_temas.codigo_tema,i3geoadmin_temas.tags_tema,i3geoadmin_n3.id_n3,i3geoadmin_temas.nome_tema,i3geoadmin_n3.publicado,i3geoadmin_n3.n3_perfil,i3geoadmin_n3.id_tema,i3geoadmin_temas.download_tema,i3geoadmin_temas.ogc_tema from i3geoadmin_n3 LEFT JOIN i3geoadmin_temas ON i3geoadmin_n3.id_tema = i3geoadmin_temas.id_tema "; | ||
| 60 | - /* | ||
| 61 | - Function: __construct | ||
| 62 | - | ||
| 63 | - Cria um objeto Arvore | ||
| 64 | - | ||
| 65 | - Parametros: | ||
| 66 | - | ||
| 67 | - locaplic {string} - localização do i3geo no sistema de arquivos | ||
| 68 | - | ||
| 69 | - idioma {string} - default = "pt" | ||
| 70 | - */ | ||
| 71 | - function __construct($locaplic,$idioma="pt",$filtro="") | ||
| 72 | - { | ||
| 73 | - $this->locaplic = $locaplic; | ||
| 74 | - $this->filtro = $filtro; | ||
| 75 | - $dbh = ""; | ||
| 76 | - //error_reporting(0); | ||
| 77 | - | ||
| 78 | - include($locaplic."/admin/php/conexao.php"); | ||
| 79 | - | ||
| 80 | - $this->esquemaadmin = ""; | ||
| 81 | - if(!empty($esquemaadmin)){ | ||
| 82 | - $this->esquemaadmin = str_replace(".","",$esquemaadmin)."."; | ||
| 83 | - } | ||
| 84 | - if(!isset($convUTF)){ | ||
| 85 | - $convUTF = true; | ||
| 86 | - } | ||
| 87 | - $this->convUTF = $convUTF; | ||
| 88 | - $this->dbh = $dbh; | ||
| 89 | - | ||
| 90 | - $this->idioma = $idioma; | ||
| 91 | - if($idioma == "pt"){ | ||
| 92 | - $coluna = "nome_grupo"; | ||
| 93 | - } | ||
| 94 | - else{ | ||
| 95 | - $coluna = $idioma; | ||
| 96 | - } | ||
| 97 | - $this->sql_grupos = "select CASE i3geoadmin_grupos.$coluna WHEN '' THEN nome_grupo ELSE i3geoadmin_grupos.$coluna END as nome_grupo,i3geoadmin_grupos.id_grupo, id_n1,id_menu,i3geoadmin_n1.publicado,n1_perfil,ordem from ".$this->esquemaadmin."i3geoadmin_n1 LEFT JOIN ".$this->esquemaadmin."i3geoadmin_grupos ON i3geoadmin_n1.id_grupo = i3geoadmin_grupos.id_grupo "; | ||
| 98 | - if($filtro === "ogc" || $filtro === "download"){ | ||
| 99 | - //esse sql retorna tambem os grupos dos temas que estao na raiz do grupo | ||
| 100 | - $this->sql_grupos = "select DISTINCT * from (select CASE grupos.$coluna WHEN '' THEN nome_grupo ELSE grupos.$coluna END as nome_grupo,gr.id_n1,gr.id_menu,gr.publicado,gr.n1_perfil, 0 as ordem from ".$this->esquemaadmin."i3geoadmin_grupos as grupos, ".$this->esquemaadmin."i3geoadmin_n1 as gr, ".$this->esquemaadmin."i3geoadmin_n2 as sg, ".$this->esquemaadmin."i3geoadmin_n3 as t, ".$this->esquemaadmin."i3geoadmin_temas as temas where gr.id_grupo = grupos.id_grupo AND sg.id_n1 = gr.id_n1 AND t.id_n2 = sg.id_n2 AND t.id_tema = temas.id_tema AND (temas.ogc_tema NOT IN ('NAO','nao') OR temas.download_tema NOT IN ('NAO','nao') ) UNION select c.nome_grupo as nome_grupo,a.id_nivel as id_n1,a.id_menu,'SIM' as publicado,a.perfil as n1_perfil, 0 as ordem from ".$this->esquemaadmin."i3geoadmin_raiz as a, ".$this->esquemaadmin."i3geoadmin_temas as b, ".$this->esquemaadmin."i3geoadmin_grupos as c, ".$this->esquemaadmin."i3geoadmin_n1 as d where nivel = 1 AND a.id_tema = b.id_tema AND a.id_nivel = d.id_n1 AND d.id_grupo = c.id_grupo) as s "; | ||
| 101 | - } | ||
| 102 | - | ||
| 103 | - if($idioma == "pt"){ | ||
| 104 | - $coluna = "nome_subgrupo"; | ||
| 105 | - } | ||
| 106 | - else{ | ||
| 107 | - $coluna = $idioma; | ||
| 108 | - } | ||
| 109 | - $this->sql_subgrupos = "select CASE i3geoadmin_subgrupos.$coluna WHEN '' THEN nome_subgrupo ELSE i3geoadmin_subgrupos.$coluna END as nome_subgrupo,i3geoadmin_subgrupos.id_subgrupo,i3geoadmin_n2.id_n2,i3geoadmin_n2.publicado,i3geoadmin_n2.n2_perfil from ".$this->esquemaadmin."i3geoadmin_n2 LEFT JOIN ".$this->esquemaadmin."i3geoadmin_subgrupos ON i3geoadmin_n2.id_subgrupo = i3geoadmin_subgrupos.id_subgrupo "; | ||
| 110 | - | ||
| 111 | - if($idioma == "pt"){ | ||
| 112 | - $coluna = "nome_tema"; | ||
| 113 | - } | ||
| 114 | - else{ | ||
| 115 | - $coluna = $idioma; | ||
| 116 | - } | ||
| 117 | - | ||
| 118 | - $this->sql_temasraiz = "select id_nivel,ordem,codigo_tema,id_raiz,i3geoadmin_raiz.id_tema,CASE $coluna WHEN '' THEN nome_tema ELSE $coluna END as nome_tema,tipoa_tema,perfil, ogc_tema, download_tema, link_tema FROM ".$this->esquemaadmin."i3geoadmin_raiz LEFT JOIN ".$this->esquemaadmin."i3geoadmin_temas ON i3geoadmin_temas.id_tema = i3geoadmin_raiz.id_tema "; | ||
| 119 | - $this->sql_temasSubgrupo = "select i3geoadmin_temas.tipoa_tema, i3geoadmin_temas.codigo_tema,i3geoadmin_temas.tags_tema,i3geoadmin_n3.id_n3,CASE i3geoadmin_temas.$coluna WHEN '' THEN nome_tema ELSE i3geoadmin_temas.$coluna END as nome_tema,i3geoadmin_n3.publicado,i3geoadmin_n3.n3_perfil,i3geoadmin_n3.id_tema,i3geoadmin_temas.download_tema,i3geoadmin_temas.ogc_tema from ".$this->esquemaadmin."i3geoadmin_n3 LEFT JOIN ".$this->esquemaadmin."i3geoadmin_temas ON i3geoadmin_n3.id_tema = i3geoadmin_temas.id_tema "; | ||
| 120 | - | ||
| 121 | - //$this->sql_temas = "select kmz_tema,nacessos,id_tema,kml_tema,ogc_tema,download_tema,tags_tema,tipoa_tema,link_tema,desc_tema,$coluna as nome_tema,codigo_tema from i3geoadmin_temas "; | ||
| 122 | - | ||
| 123 | - $this->sql_temas = "select kmz_tema,b.soma as nacessos,id_tema,kml_tema,ogc_tema,download_tema,tags_tema,tipoa_tema,link_tema,desc_tema,CASE $coluna WHEN '' THEN nome_tema ELSE $coluna END as nome_tema,codigo_tema from ".$this->esquemaadmin."i3geoadmin_temas as a,(SELECT c.codigo_tema codigo_soma,sum( r.nacessos) as soma FROM ".$this->esquemaadmin."i3geoadmin_temas c LEFT JOIN ".$this->esquemaadmin."i3geoadmin_acessostema r ON (c.codigo_tema = r.codigo_tema) group by c.codigo_tema) as b WHERE a.codigo_tema = b.codigo_soma "; | ||
| 124 | - $this->sql_temas_combo = "select id_tema,CASE $coluna WHEN '' THEN nome_tema ELSE $coluna END as nome_tema,codigo_tema from ".$this->esquemaadmin."i3geoadmin_temas as a,(SELECT c.codigo_tema codigo_soma,sum( r.nacessos) as soma FROM ".$this->esquemaadmin."i3geoadmin_temas c LEFT JOIN ".$this->esquemaadmin."i3geoadmin_acessostema r ON (c.codigo_tema = r.codigo_tema) group by c.codigo_tema) as b WHERE a.codigo_tema = b.codigo_soma "; | ||
| 125 | - // | ||
| 126 | - //verifica se o ip atual está cadastrado como um dos editores | ||
| 127 | - //editores podem ver as coisas marcadas como não publicado | ||
| 128 | - //no sistema de administração | ||
| 129 | - // | ||
| 130 | - $this->editor = false; | ||
| 131 | - $this->editor = $this->verificaOperacaoSessao("admin/php/classe_arvore/editor"); | ||
| 132 | - $this->pubsql = " (publicado != 'NAO' or publicado is null) and "; | ||
| 133 | - if($this->editor){ | ||
| 134 | - $this->pubsql = ""; | ||
| 135 | - } | ||
| 136 | - if(!function_exists("listaTemasIndevidos")){ | ||
| 137 | - include_once(dirname(__FILE__)."/../../classesphp/funcoes_gerais.php"); | ||
| 138 | - } | ||
| 139 | - $this->temasindevidos = listaTemasIndevidos(); | ||
| 140 | - } | ||
| 141 | - function __destruct() | ||
| 142 | - { | ||
| 143 | - $this->dbh = null; | ||
| 144 | - $this->dbhw = null; | ||
| 145 | - } | ||
| 146 | - /* | ||
| 147 | - Function: validaTemas | ||
| 148 | - | ||
| 149 | - Remove de um array os temas que nao sao permitidos ao usuario atualmente logado | ||
| 150 | - */ | ||
| 151 | - function validaTemas($linhas,$id){ | ||
| 152 | - $res = array(); | ||
| 153 | - foreach($linhas as $l){ | ||
| 154 | - if(!in_array($l[$id],$this->temasindevidos)){ | ||
| 155 | - array_push($res,$l); | ||
| 156 | - } | ||
| 157 | - } | ||
| 158 | - return $res; | ||
| 159 | - } | ||
| 160 | - /* | ||
| 161 | - Function: pegaListaDeMenus | ||
| 162 | - | ||
| 163 | - Retorna a lista de menus | ||
| 164 | - | ||
| 165 | - Parametros: | ||
| 166 | - | ||
| 167 | - perfil {string} - considera apenas esse perfil | ||
| 168 | - | ||
| 169 | - Return: | ||
| 170 | - | ||
| 171 | - {array} | ||
| 172 | - */ | ||
| 173 | - function pegaListaDeMenus($perfil="",$filtraOgc="nao",$filtraDown="nao") | ||
| 174 | - { | ||
| 175 | - if($this->idioma == "pt"){ | ||
| 176 | - $coluna = "nome_menu"; | ||
| 177 | - } | ||
| 178 | - else{ | ||
| 179 | - $coluna = $this->idioma; | ||
| 180 | - } | ||
| 181 | - if($this->editor == true) | ||
| 182 | - { | ||
| 183 | - $perfil = ""; | ||
| 184 | - $sql = "SELECT publicado_menu,'' as perfil_menu,aberto,desc_menu,id_menu,CASE $coluna WHEN '' THEN nome_menu ELSE $coluna END as nome_menu from ".$this->esquemaadmin."i3geoadmin_menus order by nome_menu"; | ||
| 185 | - } | ||
| 186 | - else{ | ||
| 187 | - $sql = "SELECT publicado_menu,perfil_menu,aberto,desc_menu,id_menu,CASE $coluna WHEN '' THEN nome_menu ELSE $coluna END as nome_menu from ".$this->esquemaadmin."i3geoadmin_menus where publicado_menu != 'NAO' or publicado_menu is null order by nome_menu"; | ||
| 188 | - } | ||
| 189 | - $regs = $this->execSQL($sql); | ||
| 190 | - $resultado = array(); | ||
| 191 | - foreach($regs as $reg){ | ||
| 192 | - $a = $reg["perfil_menu"]; | ||
| 193 | - $a = str_replace(" ",",",$a); | ||
| 194 | - if ($this->verificaOcorrencia($perfil,explode(",",$a))) | ||
| 195 | - { | ||
| 196 | - $status = "fechado"; | ||
| 197 | - if(strtolower($reg["aberto"]) == "sim") | ||
| 198 | - $status = "aberto"; | ||
| 199 | - $url = ""; | ||
| 200 | - $resultado[] = array("desc"=>$this->converte($reg["desc_menu"]),"publicado"=>$reg["publicado_menu"],"nomemenu"=>$this->converte($reg["nome_menu"]),"idmenu"=>$reg["id_menu"],"arquivo"=>"","status"=>$status,"url"=>$url); | ||
| 201 | - } | ||
| 202 | - } | ||
| 203 | - return $resultado; | ||
| 204 | - } | ||
| 205 | - /* | ||
| 206 | - Function: pegaListaDeTiposGrupos | ||
| 207 | - | ||
| 208 | - Retorna a lista de grupos de um menu | ||
| 209 | - | ||
| 210 | - Parametros: | ||
| 211 | - | ||
| 212 | - id_menu {string} | ||
| 213 | - | ||
| 214 | - Return: | ||
| 215 | - | ||
| 216 | - {array} | ||
| 217 | - */ | ||
| 218 | - function pegaListaDeTiposGrupos(){ | ||
| 219 | - if($this->idioma == "pt"){ | ||
| 220 | - $coluna = "nome_grupo"; | ||
| 221 | - } | ||
| 222 | - else{ | ||
| 223 | - $coluna = $this->idioma; | ||
| 224 | - } | ||
| 225 | - $sql = "select CASE i3geoadmin_grupos.$coluna WHEN '' THEN nome_grupo ELSE i3geoadmin_grupos.$coluna END as nome_grupo, id_grupo from ".$this->esquemaadmin."i3geoadmin_grupos ORDER by nome_grupo "; | ||
| 226 | - $grupos = $this->execSQL($sql); | ||
| 227 | - return $grupos; | ||
| 228 | - } | ||
| 229 | - /* | ||
| 230 | - Function: pegaListaDeTiposSubGrupos | ||
| 231 | - | ||
| 232 | - Retorna a lista de grupos de um menu | ||
| 233 | - | ||
| 234 | - Parametros: | ||
| 235 | - | ||
| 236 | - id_menu {string} | ||
| 237 | - | ||
| 238 | - Return: | ||
| 239 | - | ||
| 240 | - {array} | ||
| 241 | - */ | ||
| 242 | - function pegaListaDeTiposSubGrupos(){ | ||
| 243 | - if($this->idioma == "pt"){ | ||
| 244 | - $coluna = "nome_subgrupo"; | ||
| 245 | - } | ||
| 246 | - else{ | ||
| 247 | - $coluna = $this->idioma; | ||
| 248 | - } | ||
| 249 | - $sql = "select CASE i3geoadmin_subgrupos.$coluna WHEN '' THEN nome_subgrupo ELSE i3geoadmin_subgrupos.$coluna END as nome_subgrupo, id_subgrupo from ".$this->esquemaadmin."i3geoadmin_subgrupos ORDER by nome_subgrupo "; | ||
| 250 | - $subgrupos = $this->execSQL($sql); | ||
| 251 | - return $subgrupos; | ||
| 252 | - } | ||
| 253 | - /* | ||
| 254 | - Function: procuraTemas | ||
| 255 | - | ||
| 256 | - Localiza temas conforme uma palavra de busca | ||
| 257 | - | ||
| 258 | - Parametros: | ||
| 259 | - | ||
| 260 | - procurar {string} - palavra de busca | ||
| 261 | - | ||
| 262 | - perfil {string} - considera apenas esse perfil | ||
| 263 | - | ||
| 264 | - Return: | ||
| 265 | - | ||
| 266 | - {array} | ||
| 267 | - */ | ||
| 268 | - function procuraTemas ($procurar,$perfil) | ||
| 269 | - { | ||
| 270 | - if($procurar != "") | ||
| 271 | - { | ||
| 272 | - $procurar = $this->removeAcentos($procurar); | ||
| 273 | - } | ||
| 274 | - $menus = $this->pegaListaDeMenus($perfil); | ||
| 275 | - $resultado = array(); | ||
| 276 | - $subgrupo = array(); | ||
| 277 | - $final = array(); | ||
| 278 | - foreach($menus as $menu) | ||
| 279 | - { | ||
| 280 | - $grupos = $this->pegaGruposMenu($menu["idmenu"]); | ||
| 281 | - foreach($grupos["grupos"] as $grupo) | ||
| 282 | - { | ||
| 283 | - $a = $grupo["n1_perfil"]; | ||
| 284 | - $a = str_replace(" ",",",$a); | ||
| 285 | - if($this->verificaOcorrencia($perfil,explode(",",$a))) | ||
| 286 | - { | ||
| 287 | - $sgrupos = $this->pegaSubgruposGrupo($menu["idmenu"],$grupo["id_n1"]); | ||
| 288 | - $temasRaizGrupo = array(); | ||
| 289 | - $temasR = $this->pegaTemasRaizGrupo($menu["idmenu"],$grupo["id_n1"]); | ||
| 290 | - foreach($temasR as $tema) | ||
| 291 | - { | ||
| 292 | - $a = $tema["perfil"]; | ||
| 293 | - $a = str_replace(" ",",",$a); | ||
| 294 | - if($this->verificaOcorrencia($perfil,explode(",",$a))) | ||
| 295 | - { | ||
| 296 | - $t = $this->pegaTema($tema["id_tema"]); | ||
| 297 | - $t = $t[0]; | ||
| 298 | - $nome = $this->removeAcentos($tema["nome_tema"]); | ||
| 299 | - $tags = $this->removeAcentos($tema["tags_tema"]); | ||
| 300 | - $tags1 = $this->removeAcentos(mb_convert_encoding($tema["tags_tema"],"ISO-8859-1","UTF-8")); | ||
| 301 | - $nome1 = $this->removeAcentos(mb_convert_encoding($tema["nome_tema"],"ISO-8859-1","UTF-8")); | ||
| 302 | - $miniatura = "nao"; | ||
| 303 | - if(file_exists($this->locaplic."/temas/miniaturas/".$t["codigo_tema"].".map.mini.png")) | ||
| 304 | - { | ||
| 305 | - $miniatura = "sim"; | ||
| 306 | - } | ||
| 307 | - $down = "sim"; | ||
| 308 | - if (strtolower($t["download_tema"]) == "nao") | ||
| 309 | - { | ||
| 310 | - $down = "nao"; | ||
| 311 | - } | ||
| 312 | - $texto = array("codigo_tema"=>$t["codigo_tema"],"miniatura"=>$miniatura,"tid"=>$t["codigo_tema"],"nome"=>$this->converte($tema["nome_tema"]),"link"=>$t["link_tema"],"download"=>$down); | ||
| 313 | - if($procurar == "") | ||
| 314 | - { | ||
| 315 | - $temasRaizGrupo[] = $texto; | ||
| 316 | - } | ||
| 317 | - else | ||
| 318 | - { | ||
| 319 | - if (stristr($nome,$procurar) || stristr($nome1,$procurar)) | ||
| 320 | - { | ||
| 321 | - $temasRaizGrupo[] = $texto; | ||
| 322 | - } | ||
| 323 | - else | ||
| 324 | - { | ||
| 325 | - if (stristr($tags,$procurar) || stristr($tags1,$procurar)) | ||
| 326 | - { | ||
| 327 | - $temasRaizGrupo[] = $texto; | ||
| 328 | - } | ||
| 329 | - } | ||
| 330 | - } | ||
| 331 | - } | ||
| 332 | - } | ||
| 333 | - foreach($sgrupos["subgrupos"] as $sgrupo) | ||
| 334 | - { | ||
| 335 | - $a = $sgrupo["n2_perfil"]; | ||
| 336 | - $a = str_replace(" ",",",$a); | ||
| 337 | - if($this->verificaOcorrencia($perfil,explode(",",$a))) | ||
| 338 | - { | ||
| 339 | - $temas = $this->pegaTemasSubGrupo($sgrupo["id_n2"]); | ||
| 340 | - foreach ($temas as $tema) | ||
| 341 | - { | ||
| 342 | - $a = $tema["n3_perfil"]; | ||
| 343 | - $a = str_replace(" ",",",$a); | ||
| 344 | - if($this->verificaOcorrencia($perfil,explode(",",$a))) | ||
| 345 | - { | ||
| 346 | - $t = $this->pegaTema($tema["id_tema"]); | ||
| 347 | - $t = $t[0]; | ||
| 348 | - $nome = $this->removeAcentos($tema["nome_tema"]); | ||
| 349 | - $tags = $this->removeAcentos($tema["tags_tema"]); | ||
| 350 | - $tags1 = $this->removeAcentos(mb_convert_encoding($tema["tags_tema"],"ISO-8859-1","UTF-8")); | ||
| 351 | - $nome1 = $this->removeAcentos(mb_convert_encoding($tema["nome_tema"],"ISO-8859-1","UTF-8")); | ||
| 352 | - $miniatura = "nao"; | ||
| 353 | - if(file_exists($this->locaplic."/temas/miniaturas/".$tema["codigo_tema"].".map.mini.png")) | ||
| 354 | - { | ||
| 355 | - $miniatura = "sim"; | ||
| 356 | - } | ||
| 357 | - $down = "sim"; | ||
| 358 | - if (strtolower($t["download_tema"]) == "nao") | ||
| 359 | - { | ||
| 360 | - $down = "nao"; | ||
| 361 | - } | ||
| 362 | - $texto = array("codigo_tema"=>$tema["codigo_tema"],"miniatura"=>$miniatura,"tid"=>$tema["codigo_tema"],"nome"=>$this->converte($tema["nome_tema"]),"link"=>$t["link_tema"],"download"=>$down); | ||
| 363 | - if($procurar == "") | ||
| 364 | - { | ||
| 365 | - $resultado[] = $texto; | ||
| 366 | - } | ||
| 367 | - else | ||
| 368 | - { | ||
| 369 | - if (stristr($nome,$procurar) || stristr($nome1,$procurar)) | ||
| 370 | - { | ||
| 371 | - $resultado[] = $texto; | ||
| 372 | - } | ||
| 373 | - else | ||
| 374 | - { | ||
| 375 | - if (stristr($tags,$procurar) || stristr($tags1,$procurar)) | ||
| 376 | - { | ||
| 377 | - $resultado[] = $texto; | ||
| 378 | - } | ||
| 379 | - } | ||
| 380 | - } | ||
| 381 | - } | ||
| 382 | - } | ||
| 383 | - } | ||
| 384 | - if (count($resultado) > 0) | ||
| 385 | - { | ||
| 386 | - $subgrupo[] = array("subgrupo"=>$this->converte($sgrupo["nome_subgrupo"]),"temas"=>$resultado); | ||
| 387 | - } | ||
| 388 | - $resultado = array(); | ||
| 389 | - } | ||
| 390 | - } | ||
| 391 | - if (count($subgrupo) > 0 || count($temasRaizGrupo) > 0) | ||
| 392 | - { | ||
| 393 | - $final[] = array("grupo"=>$this->converte($grupo["nome_grupo"]),"temas"=>$temasRaizGrupo,"subgrupos"=>$subgrupo); | ||
| 394 | - } | ||
| 395 | - $subgrupo = array(); | ||
| 396 | - } | ||
| 397 | - } | ||
| 398 | - return $final; | ||
| 399 | - } | ||
| 400 | - /* | ||
| 401 | - Function: procuraTemasEstrela | ||
| 402 | - | ||
| 403 | - Localiza temas que têm um determinado número (nível) de estrelas | ||
| 404 | - | ||
| 405 | - Parametros: | ||
| 406 | - | ||
| 407 | - nivel {numeric} - número de estrelas | ||
| 408 | - | ||
| 409 | - perfil {string} - considera apenas esse perfil | ||
| 410 | - | ||
| 411 | - Return: | ||
| 412 | - | ||
| 413 | - {array} | ||
| 414 | - */ | ||
| 415 | - function procuraTemasEstrela($nivel,$fatorestrela,$perfil) | ||
| 416 | - { | ||
| 417 | - $menus = $this->pegaListaDeMenus($perfil); | ||
| 418 | - | ||
| 419 | - $resultado = array(); | ||
| 420 | - $subgrupo = array(); | ||
| 421 | - $final = array(); | ||
| 422 | - foreach($menus as $menu) | ||
| 423 | - { | ||
| 424 | - $grupos = $this->pegaGruposMenu($menu["idmenu"]); | ||
| 425 | - foreach($grupos["grupos"] as $grupo) | ||
| 426 | - { | ||
| 427 | - $a = $grupo["n1_perfil"]; | ||
| 428 | - $a = str_replace(" ",",",$a); | ||
| 429 | - if($this->verificaOcorrencia($perfil,explode(",",$a))) | ||
| 430 | - { | ||
| 431 | - $sgrupos = $this->pegaSubgruposGrupo($menu["idmenu"],$grupo["id_n1"]); | ||
| 432 | - $temasRaizGrupo = array(); | ||
| 433 | - $temasR = $this->pegaTemasRaizGrupo($menu["idmenu"],$grupo["id_n1"]); | ||
| 434 | - foreach($temasR as $tema) | ||
| 435 | - { | ||
| 436 | - $a = $tema["perfil"]; | ||
| 437 | - $a = str_replace(" ",",",$a); | ||
| 438 | - if($this->verificaOcorrencia($perfil,explode(",",$a))) | ||
| 439 | - { | ||
| 440 | - $t = $this->pegaTema($tema["id_tema"]); | ||
| 441 | - $t = $t[0]; | ||
| 442 | - $nome = $this->removeAcentos($tema["nome_tema"]); | ||
| 443 | - $tags = $this->removeAcentos($tema["tags_tema"]); | ||
| 444 | - $tags1 = $this->removeAcentos(mb_convert_encoding($tema["tags_tema"],"ISO-8859-1","UTF-8")); | ||
| 445 | - $nome1 = $this->removeAcentos(mb_convert_encoding($tema["nome_tema"],"ISO-8859-1","UTF-8")); | ||
| 446 | - $miniatura = "nao"; | ||
| 447 | - if(file_exists($this->locaplic."/temas/miniaturas/".$t["codigo_tema"].".map.mini.png")) | ||
| 448 | - { | ||
| 449 | - $miniatura = "sim"; | ||
| 450 | - } | ||
| 451 | - $down = "sim"; | ||
| 452 | - if (strtolower($t["download_tema"]) == "nao") | ||
| 453 | - { | ||
| 454 | - $down = "nao"; | ||
| 455 | - } | ||
| 456 | - $texto = array("codigo_tema"=>$t["codigo_tema"],"miniatura"=>$miniatura,"tid"=>$t["codigo_tema"],"nome"=>$this->converte($tema["nome_tema"]),"link"=>$t["link_tema"],"download"=>$down); | ||
| 457 | - $n = intval($t["nacessos"] / $fatorestrela); | ||
| 458 | - if($n >= 5){ | ||
| 459 | - $n = 5; | ||
| 460 | - } | ||
| 461 | - | ||
| 462 | - if ($n == $nivel) | ||
| 463 | - { | ||
| 464 | - $temasRaizGrupo[] = $texto; | ||
| 465 | - } | ||
| 466 | - } | ||
| 467 | - } | ||
| 468 | - foreach($sgrupos["subgrupos"] as $sgrupo) | ||
| 469 | - { | ||
| 470 | - $a = $sgrupo["n2_perfil"]; | ||
| 471 | - $a = str_replace(" ",",",$a); | ||
| 472 | - if($this->verificaOcorrencia($perfil,explode(",",$a))) | ||
| 473 | - { | ||
| 474 | - $temas = $this->pegaTemasSubGrupo($sgrupo["id_n2"]); | ||
| 475 | - foreach ($temas as $tema) | ||
| 476 | - { | ||
| 477 | - $a = $tema["n3_perfil"]; | ||
| 478 | - $a = str_replace(" ",",",$a); | ||
| 479 | - if($this->verificaOcorrencia($perfil,explode(",",$a))) | ||
| 480 | - { | ||
| 481 | - $t = $this->pegaTema($tema["id_tema"]); | ||
| 482 | - $t = $t[0]; | ||
| 483 | - $nome = $this->removeAcentos($tema["nome_tema"]); | ||
| 484 | - $tags = $this->removeAcentos($tema["tags_tema"]); | ||
| 485 | - $tags1 = $this->removeAcentos(mb_convert_encoding($tema["tags_tema"],"ISO-8859-1","UTF-8")); | ||
| 486 | - $nome1 = $this->removeAcentos(mb_convert_encoding($tema["nome_tema"],"ISO-8859-1","UTF-8")); | ||
| 487 | - $miniatura = "nao"; | ||
| 488 | - if(file_exists($this->locaplic."/temas/miniaturas/".$tema["codigo_tema"].".map.mini.png")) | ||
| 489 | - { | ||
| 490 | - $miniatura = "sim"; | ||
| 491 | - } | ||
| 492 | - $down = "sim"; | ||
| 493 | - if (strtolower($t["download_tema"]) == "nao") | ||
| 494 | - { | ||
| 495 | - $down = "nao"; | ||
| 496 | - } | ||
| 497 | - $texto = array("codigo_tema"=>$tema["codigo_tema"],"miniatura"=>$miniatura,"tid"=>$tema["codigo_tema"],"nome"=>$this->converte($tema["nome_tema"]),"link"=>$t["link_tema"],"download"=>$down); | ||
| 498 | - $n = abs($t["nacessos"] / $fatorestrela); | ||
| 499 | - if($n >= 5){ | ||
| 500 | - $n = 5; | ||
| 501 | - } | ||
| 502 | - if ($n == $nivel) | ||
| 503 | - { | ||
| 504 | - $resultado[] = $texto; | ||
| 505 | - } | ||
| 506 | - } | ||
| 507 | - } | ||
| 508 | - } | ||
| 509 | - if (count($resultado) > 0) | ||
| 510 | - { | ||
| 511 | - $subgrupo[] = array("subgrupo"=>$this->converte($sgrupo["nome_subgrupo"]),"temas"=>$resultado); | ||
| 512 | - } | ||
| 513 | - $resultado = array(); | ||
| 514 | - } | ||
| 515 | - } | ||
| 516 | - if (count($subgrupo) > 0 || count($temasRaizGrupo) > 0) | ||
| 517 | - { | ||
| 518 | - $final[] = array("grupo"=>$this->converte($grupo["nome_grupo"]),"temas"=>$temasRaizGrupo,"subgrupos"=>$subgrupo); | ||
| 519 | - } | ||
| 520 | - $subgrupo = array(); | ||
| 521 | - } | ||
| 522 | - } | ||
| 523 | - return $final; | ||
| 524 | - } | ||
| 525 | - /* | ||
| 526 | - Function: pegaGruposMenu | ||
| 527 | - | ||
| 528 | - Retorna a lista de grupos de um menu | ||
| 529 | - | ||
| 530 | - Parametros: | ||
| 531 | - | ||
| 532 | - id_menu {string} | ||
| 533 | - | ||
| 534 | - Return: | ||
| 535 | - | ||
| 536 | - {array} | ||
| 537 | - */ | ||
| 538 | - function pegaGruposMenu($id_menu,$ordenaNome="nao"){ | ||
| 539 | - if($ordenaNome == "sim"){ | ||
| 540 | - $ordem = "nome_grupo"; | ||
| 541 | - } | ||
| 542 | - else{ | ||
| 543 | - $ordem = "ordem"; | ||
| 544 | - } | ||
| 545 | - $sqlgrupos = $this->sql_grupos."where ".$this->pubsql." id_menu='$id_menu' order by $ordem"; | ||
| 546 | - $sqlraiz = $this->sql_temasraiz."where i3geoadmin_raiz.id_menu='$id_menu' and i3geoadmin_raiz.nivel = 0 order by ordem"; | ||
| 547 | - $grupos = $this->execSQL($sqlgrupos); | ||
| 548 | - $raiz = $this->execSQL($sqlraiz); | ||
| 549 | - $raiz = $this->validaTemas($raiz,"codigo_tema"); | ||
| 550 | - return array("raiz"=>$raiz,"grupos"=>$grupos); | ||
| 551 | - } | ||
| 552 | - /* | ||
| 553 | - Function: pegaSubgruposGrupo | ||
| 554 | - | ||
| 555 | - Retorna a lista de subgrupos de um grupo | ||
| 556 | - | ||
| 557 | - Parametros: | ||
| 558 | - | ||
| 559 | - id_menu {string} | ||
| 560 | - | ||
| 561 | - id_n1 {string} - id do grupo | ||
| 562 | - | ||
| 563 | - Return: | ||
| 564 | - | ||
| 565 | - {array} | ||
| 566 | - */ | ||
| 567 | - function pegaSubgruposGrupo($id_menu,$id_n1,$ordenaNome="nao",$filtraOgc="nao",$filtraDown="nao") | ||
| 568 | - { | ||
| 569 | - if($ordenaNome == "sim"){ | ||
| 570 | - $ordem = "nome_subgrupo"; | ||
| 571 | - } | ||
| 572 | - else{ | ||
| 573 | - $ordem = "ordem"; | ||
| 574 | - } | ||
| 575 | - $f = ""; | ||
| 576 | - if($filtraOgc == "sim" || $filtraDown == "sim"){ | ||
| 577 | - $ff = array(); | ||
| 578 | - if($filtraOgc == "sim"){ | ||
| 579 | - $ff[] = " i3geoadmin_temas.ogc_tema = 'SIM' "; | ||
| 580 | - } | ||
| 581 | - if($filtraDown == "sim"){ | ||
| 582 | - $ff[] = " i3geoadmin_temas.download_tema = 'SIM' "; | ||
| 583 | - } | ||
| 584 | - $f = implode(" AND ",$ff) . " AND "; | ||
| 585 | - } | ||
| 586 | - $subgrupos = $this->execSQL($this->sql_subgrupos."where ".$this->pubsql." i3geoadmin_n2.id_n1='$id_n1' order by $ordem"); | ||
| 587 | - $raiz = $this->execSQL($this->sql_temasraiz."where $f i3geoadmin_raiz.nivel = 1 and i3geoadmin_raiz.id_nivel = $id_n1 order by ordem"); | ||
| 588 | - $raiz = $this->validaTemas($raiz,"codigo_tema"); | ||
| 589 | - return array("raiz"=>$raiz,"subgrupos"=>$subgrupos); | ||
| 590 | - } | ||
| 591 | - /* | ||
| 592 | - Function: pegaTemasRaizMenu | ||
| 593 | - | ||
| 594 | - Retorna a lista de temas da raiz de um menu | ||
| 595 | - | ||
| 596 | - Parametros: | ||
| 597 | - | ||
| 598 | - id_menu {string} | ||
| 599 | - | ||
| 600 | - Return: | ||
| 601 | - | ||
| 602 | - {array} | ||
| 603 | - */ | ||
| 604 | - function pegaTemasRaizMenu($id_menu) | ||
| 605 | - { | ||
| 606 | - $raiz = $this->execSQL($this->sql_temasraiz."where i3geoadmin_raiz.id_menu='$id_menu' and i3geoadmin_raiz.nivel = 0 order by ordem"); | ||
| 607 | - $raiz = $this->validaTemas($raiz,"codigo_tema"); | ||
| 608 | - return $raiz; | ||
| 609 | - } | ||
| 610 | - /* | ||
| 611 | - Function: pegaTemasRaizGrupo | ||
| 612 | - | ||
| 613 | - Retorna a lista de temas da raiz de um grupo | ||
| 614 | - | ||
| 615 | - Parametros: | ||
| 616 | - | ||
| 617 | - id_menu {string} | ||
| 618 | - | ||
| 619 | - id_n1 {string} - id do grupo | ||
| 620 | - | ||
| 621 | - Return: | ||
| 622 | - | ||
| 623 | - {array} | ||
| 624 | - */ | ||
| 625 | - function pegaTemasRaizGrupo($id_menu,$id_n1,$filtraOgc="nao",$filtraDown="nao") | ||
| 626 | - { | ||
| 627 | - $f = ""; | ||
| 628 | - if($filtraOgc == "sim" || $filtraDown == "sim"){ | ||
| 629 | - $ff = array(); | ||
| 630 | - if($filtraOgc == "sim"){ | ||
| 631 | - $ff[] = " i3geoadmin_temas.ogc_tema = 'SIM' "; | ||
| 632 | - } | ||
| 633 | - if($filtraDown == "sim"){ | ||
| 634 | - $ff[] = " i3geoadmin_temas.download_tema = 'SIM' "; | ||
| 635 | - } | ||
| 636 | - $f = implode(" AND ",$ff) . " AND "; | ||
| 637 | - } | ||
| 638 | - if($id_n1 == ""){ | ||
| 639 | - $raiz = $this->execSQL($this->sql_temasraiz."where $f i3geoadmin_raiz.nivel = 1 and i3geoadmin_raiz.id_nivel > 0 order by ordem"); | ||
| 640 | - } | ||
| 641 | - else { | ||
| 642 | - $raiz = $this->execSQL($this->sql_temasraiz."where $f i3geoadmin_raiz.nivel = 1 and i3geoadmin_raiz.id_nivel = $id_n1 order by ordem"); | ||
| 643 | - } | ||
| 644 | - $raiz = $this->validaTemas($raiz,"codigo_tema"); | ||
| 645 | - return $raiz; | ||
| 646 | - } | ||
| 647 | - /* | ||
| 648 | - Function: pegaTodosTemas | ||
| 649 | - | ||
| 650 | - Retorna os dados de todos os temas | ||
| 651 | - | ||
| 652 | - Return: | ||
| 653 | - | ||
| 654 | - {array} | ||
| 655 | - */ | ||
| 656 | - function pegaTodosTemas($combo=false) | ||
| 657 | - { | ||
| 658 | - if($combo == true){ | ||
| 659 | - $q = $this->execSQL($this->sql_temas_combo." ORDER BY nome_tema ASC"); | ||
| 660 | - } | ||
| 661 | - else{ | ||
| 662 | - $q = $this->execSQL($this->sql_temas." ORDER BY nome_tema ASC"); | ||
| 663 | - } | ||
| 664 | - if($q){ | ||
| 665 | - $q = $this->validaTemas($q,"codigo_tema"); | ||
| 666 | - return $q; | ||
| 667 | - } | ||
| 668 | - } | ||
| 669 | - /* | ||
| 670 | - Function: pegaTema | ||
| 671 | - | ||
| 672 | - Retorna os dados de um tema | ||
| 673 | - | ||
| 674 | - Parametros: | ||
| 675 | - | ||
| 676 | - id_tema {string} | ||
| 677 | - | ||
| 678 | - Return: | ||
| 679 | - | ||
| 680 | - {array} | ||
| 681 | - */ | ||
| 682 | - function pegaTema($id_tema) | ||
| 683 | - { | ||
| 684 | - $q = $this->execSQL($this->sql_temas." and id_tema = '$id_tema' "); | ||
| 685 | - if($q){ | ||
| 686 | - return $q; | ||
| 687 | - } | ||
| 688 | - else{ | ||
| 689 | - //caso de banco de dados antigo | ||
| 690 | - $sql = "select kmz_tema,'0' as nacessos,id_tema,kml_tema,ogc_tema,download_tema,tags_tema,tipoa_tema,link_tema,desc_tema,nome_tema,codigo_tema from ".$this->esquemaadmin."i3geoadmin_temas "; | ||
| 691 | - $q = $this->execSQL($sql." where id_tema = '$id_tema' "); | ||
| 692 | - return $q; | ||
| 693 | - } | ||
| 694 | - } | ||
| 695 | - /* | ||
| 696 | - Function: pegaTemaPorCodigo | ||
| 697 | - | ||
| 698 | - Retorna os dados de um tema buscando por codigo | ||
| 699 | - | ||
| 700 | - Parametros: | ||
| 701 | - | ||
| 702 | - codigo_tema {string} | ||
| 703 | - | ||
| 704 | - Return: | ||
| 705 | - | ||
| 706 | - {array} | ||
| 707 | - */ | ||
| 708 | - function pegaTemaPorCodigo($codigo_tema) | ||
| 709 | - { | ||
| 710 | - $q = $this->execSQL($this->sql_temas." and codigo_tema = '$codigo_tema' "); | ||
| 711 | - if($q){ | ||
| 712 | - return $q; | ||
| 713 | - } | ||
| 714 | - else{ | ||
| 715 | - //caso de banco de dados antigo | ||
| 716 | - $sql = "select kmz_tema,'0' as nacessos,id_tema,kml_tema,ogc_tema,download_tema,tags_tema,tipoa_tema,link_tema,desc_tema,nome_tema,codigo_tema from ".$this->esquemaadmin."i3geoadmin_temas "; | ||
| 717 | - $q = $this->execSQL($sql." where codigo_tema = '$codigo_tema' "); | ||
| 718 | - return $q; | ||
| 719 | - } | ||
| 720 | - } | ||
| 721 | - /* | ||
| 722 | - Function: pegaTemasSubGrupo | ||
| 723 | - | ||
| 724 | - Retorna os temas de um subgrupo | ||
| 725 | - | ||
| 726 | - Parametros: | ||
| 727 | - | ||
| 728 | - id_n2 {string} - id do subgrupo | ||
| 729 | - | ||
| 730 | - Return: | ||
| 731 | - | ||
| 732 | - {array} | ||
| 733 | - */ | ||
| 734 | - function pegaTemasSubGrupo($id_n2,$filtraOgc="nao",$filtraDown="nao") | ||
| 735 | - { | ||
| 736 | - $f = ""; | ||
| 737 | - if($filtraOgc == "sim" || $filtraDown == "sim"){ | ||
| 738 | - $ff = array(); | ||
| 739 | - if($filtraOgc == "sim"){ | ||
| 740 | - $ff[] = " i3geoadmin_temas.ogc_tema = 'SIM' "; | ||
| 741 | - } | ||
| 742 | - if($filtraDown == "sim"){ | ||
| 743 | - $ff[] = " i3geoadmin_temas.download_tema = 'SIM' "; | ||
| 744 | - } | ||
| 745 | - $f = implode(" AND ",$ff) . " AND "; | ||
| 746 | - } | ||
| 747 | - $temas = $this->execSQL($this->sql_temasSubgrupo."where $f ".$this->pubsql." i3geoadmin_n3.id_n2='$id_n2' order by ordem"); | ||
| 748 | - $temas = $this->validaTemas($temas,"codigo_tema"); | ||
| 749 | - return $temas; | ||
| 750 | - } | ||
| 751 | - /* | ||
| 752 | - Function: formataMenus | ||
| 753 | - | ||
| 754 | - Retorna os menus e temas na raiz de um menu, formatados no padrão da árvore | ||
| 755 | - | ||
| 756 | - Return: | ||
| 757 | - | ||
| 758 | - {array} | ||
| 759 | - */ | ||
| 760 | - function formataMenus(){ | ||
| 761 | - } | ||
| 762 | - /* | ||
| 763 | - Function: formataGruposMenu | ||
| 764 | - | ||
| 765 | - Retorna os grupos e temas na raiz de um menu, formatados no padrão da árvore | ||
| 766 | - | ||
| 767 | - Parametros: | ||
| 768 | - | ||
| 769 | - id_menu {string} | ||
| 770 | - | ||
| 771 | - perfil {string} | ||
| 772 | - | ||
| 773 | - listasgrupos {string} - sim|nao | ||
| 774 | - | ||
| 775 | - Return: | ||
| 776 | - | ||
| 777 | - {array} | ||
| 778 | - */ | ||
| 779 | - function formataGruposMenu ($id_menu,$perfil,$listasgrupos,$ordenaNome="nao",$filtraOgc="nao",$filtraDown="nao") | ||
| 780 | - { | ||
| 781 | - //error_reporting(0); | ||
| 782 | - $dados = $this->pegaGruposMenu($id_menu,$ordenaNome); | ||
| 783 | - $resultado = array(); | ||
| 784 | - $temasraiz = array(); | ||
| 785 | - foreach($dados["raiz"] as $temar){ | ||
| 786 | - $temasraiz[] = $this->formataTema($temar["id_tema"]); | ||
| 787 | - } | ||
| 788 | - if(count($dados["grupos"]) == 0){ | ||
| 789 | - $grupos[] = array(); | ||
| 790 | - } | ||
| 791 | - $raizgrupos = $this->pegaTemasRaizGrupo($id_menu,"",$filtraOgc,$filtraDown); | ||
| 792 | - //var_dump($raizgrupos);exit; | ||
| 793 | - foreach($dados["grupos"] as $grupo) { | ||
| 794 | - $a = $grupo["n1_perfil"]; | ||
| 795 | - $a = str_replace(" ",",",$a); | ||
| 796 | - if($this->verificaOcorrencia($perfil,explode(",",$a)) == true) | ||
| 797 | - { | ||
| 798 | - $temas = array(); | ||
| 799 | - //$raizgrupo = $this->pegaTemasRaizGrupo($id_menu,$grupo["id_n1"],$filtraOgc,$filtraDown); | ||
| 800 | - $grupodown = "nao"; | ||
| 801 | - $grupoogc = "nao"; | ||
| 802 | - foreach($raizgrupos as $tema){ | ||
| 803 | - if($tema["id_nivel"] == $grupo["id_n1"]){ | ||
| 804 | - $temas[] = $this->formataTema($tema["id_tema"]); | ||
| 805 | - } | ||
| 806 | - } | ||
| 807 | - if($temas > 0){ | ||
| 808 | - $grupodown = "sim"; | ||
| 809 | - $grupoogc = "sim"; | ||
| 810 | - } | ||
| 811 | - $subgrupos = array(); | ||
| 812 | - if($listasgrupos=="sim"){ | ||
| 813 | - $dadossubgrupos = $this->pegaSubgruposGrupo($id_menu,$grupo["id_n1"],$ordenaNome,$filtraOgc,$filtraDown); | ||
| 814 | - foreach($dadossubgrupos["subgrupos"] as $sgrupo){ | ||
| 815 | - $a = $sgrupo["n2_perfil"]; | ||
| 816 | - $a = str_replace(" ",",",$a); | ||
| 817 | - if($this->verificaOcorrencia($perfil,explode(",",$a))){ | ||
| 818 | - //verifica se existem temas que podem receber download | ||
| 819 | - $down = "nao"; | ||
| 820 | - $ogc = "nao"; | ||
| 821 | - $listaT = $this->pegaTemasSubGrupo($sgrupo["id_n2"],$filtraOgc,$filtraDown); | ||
| 822 | - foreach($listaT as $tema){ | ||
| 823 | - if(strtolower($tema["tipoa_tema"]) != "wms") | ||
| 824 | - { | ||
| 825 | - if (strtolower($tema["download_tema"]) != "nao") | ||
| 826 | - { | ||
| 827 | - $down = "sim";$grupodown = "sim"; | ||
| 828 | - } | ||
| 829 | - | ||
| 830 | - if (strtolower($tema["ogc_tema"]) != "nao") | ||
| 831 | - { | ||
| 832 | - $ogc = "sim";$grupoogc = "sim"; | ||
| 833 | - } | ||
| 834 | - } | ||
| 835 | - } | ||
| 836 | - if(count($listaT) > 0){ | ||
| 837 | - $subgrupos[] = array("id_n2"=>$sgrupo["id_n2"],"publicado"=>($sgrupo["publicado"]),"nome"=>$this->converte($sgrupo["nome_subgrupo"]),"download"=>$down,"ogc"=>$ogc); | ||
| 838 | - } | ||
| 839 | - } | ||
| 840 | - } | ||
| 841 | - } | ||
| 842 | - //evita ocorrencias vazias quando for aplicado um filtro | ||
| 843 | - if($filtraOgc == "sim" || $filtraDown == "sim"){ | ||
| 844 | - if(count($subgrupos) > 0 || count($temas) > 0){ | ||
| 845 | - $grupos[] = array("publicado"=>($grupo["publicado"]),"id_n1"=>($grupo["id_n1"]),"nome"=>$this->converte($grupo["nome_grupo"]),"ogc"=>$grupoogc,"download"=>$grupodown,"subgrupos"=>$subgrupos,"temasgrupo"=>$temas); | ||
| 846 | - } | ||
| 847 | - } | ||
| 848 | - else{ | ||
| 849 | - $grupos[] = array("publicado"=>($grupo["publicado"]),"id_n1"=>($grupo["id_n1"]),"nome"=>$this->converte($grupo["nome_grupo"]),"ogc"=>$grupoogc,"download"=>$grupodown,"subgrupos"=>$subgrupos,"temasgrupo"=>$temas); | ||
| 850 | - } | ||
| 851 | - } | ||
| 852 | - } | ||
| 853 | - $grupos[] = array("temasraiz"=>$temasraiz); | ||
| 854 | - //pega os sistemas checando os perfis | ||
| 855 | - $sistemas = array(); | ||
| 856 | - $grupos[] = array("idmenu"=>$id_menu); | ||
| 857 | - $grupos[] = array("sistemas"=>""); | ||
| 858 | - return($grupos); | ||
| 859 | - } | ||
| 860 | - /* | ||
| 861 | - Function: formataSubgruposGrupo | ||
| 862 | - | ||
| 863 | - Retorna os subgrupos e temas na raiz de um grupo, formatados no padrão da árvore | ||
| 864 | - | ||
| 865 | - Parametros: | ||
| 866 | - | ||
| 867 | - id_menu {string} | ||
| 868 | - | ||
| 869 | - id_n1 {string} - id do grupo | ||
| 870 | - | ||
| 871 | - perfil {string} | ||
| 872 | - | ||
| 873 | - Return: | ||
| 874 | - | ||
| 875 | - {array} | ||
| 876 | - */ | ||
| 877 | - function formataSubgruposGrupo ($id_menu,$id_n1,$perfil) | ||
| 878 | - { | ||
| 879 | - $dados = $this->pegaSubgruposGrupo($id_menu,$id_n1); | ||
| 880 | - $resultado = array(); | ||
| 881 | - $temasraiz = array(); | ||
| 882 | - foreach($dados["raiz"] as $temar) | ||
| 883 | - { | ||
| 884 | - $temasraiz[] = $this->formataTema($temar["id_tema"]); | ||
| 885 | - } | ||
| 886 | - if(count($dados["subgrupos"]) == 0) | ||
| 887 | - { | ||
| 888 | - $sgrupos[] = array(); | ||
| 889 | - } | ||
| 890 | - $subgrupos = array(); | ||
| 891 | - foreach($dados["subgrupos"] as $sgrupo) | ||
| 892 | - { | ||
| 893 | - $a = $sgrupo["n2_perfil"]; | ||
| 894 | - $a = str_replace(" ",",",$a); | ||
| 895 | - if ($this->verificaOcorrencia($perfil,explode(",",$a))) | ||
| 896 | - { | ||
| 897 | - $listaT = $this->pegaTemasSubGrupo($sgrupo["id_n2"]); | ||
| 898 | - $down = "nao"; | ||
| 899 | - $ogc = "nao"; | ||
| 900 | - foreach($listaT as $tema) | ||
| 901 | - { | ||
| 902 | - if(strtolower($tema["tipoa_tema"]) != "wms") | ||
| 903 | - { | ||
| 904 | - if (strtolower($tema["download_tema"]) != "nao") | ||
| 905 | - { | ||
| 906 | - $down = "sim"; | ||
| 907 | - } | ||
| 908 | - if (strtolower($tema["ogc_tema"]) != "nao") | ||
| 909 | - { | ||
| 910 | - $ogc = "sim"; | ||
| 911 | - } | ||
| 912 | - } | ||
| 913 | - } | ||
| 914 | - if(count($listaT) > 0) | ||
| 915 | - { | ||
| 916 | - $subgrupos[] = array("publicado"=>($sgrupo["publicado"]),"id_n2"=>($sgrupo["id_n2"]),"nome"=>$this->converte($sgrupo["nome_subgrupo"]),"download"=>$down,"ogc"=>$ogc,"temas"=>$listaT); | ||
| 917 | - } | ||
| 918 | - } | ||
| 919 | - } | ||
| 920 | - return (array("subgrupo"=>$subgrupos,"temasgrupo"=>$temasraiz)); | ||
| 921 | - } | ||
| 922 | - /* | ||
| 923 | - Function: formataTemasSubgrupo | ||
| 924 | - | ||
| 925 | - Retorna os temas de um subgrupo, formatados no padrão da árvore | ||
| 926 | - | ||
| 927 | - Parametros: | ||
| 928 | - | ||
| 929 | - id_n2 {string} - id do subgrupo | ||
| 930 | - | ||
| 931 | - perfil {string} | ||
| 932 | - | ||
| 933 | - Return: | ||
| 934 | - | ||
| 935 | - {array} | ||
| 936 | - */ | ||
| 937 | - function formataTemasSubgrupo($id_n2,$perfil) | ||
| 938 | - { | ||
| 939 | - $dados = $this->pegaTemasSubGrupo($id_n2); | ||
| 940 | - $temas = array(); | ||
| 941 | - foreach($dados as $tema) | ||
| 942 | - { | ||
| 943 | - $a = $tema["n3_perfil"]; | ||
| 944 | - $a = str_replace(" ",",",$a); | ||
| 945 | - if($this->verificaOcorrencia($perfil,explode(",",$a))) | ||
| 946 | - { | ||
| 947 | - $temas[] = $this->formataTema($tema["id_tema"],$tema["publicado"]); | ||
| 948 | - } | ||
| 949 | - } | ||
| 950 | - return $temas; | ||
| 951 | - } | ||
| 952 | - /* | ||
| 953 | - Function: formataTema | ||
| 954 | - | ||
| 955 | - Retorna os dados de um tema, formatados no padrão da árvore | ||
| 956 | - | ||
| 957 | - Parametros: | ||
| 958 | - | ||
| 959 | - id_tema {string} | ||
| 960 | - | ||
| 961 | - publicado {string} - SIM|NAO valor do índice "publicado" que será incluído no array de retorno | ||
| 962 | - | ||
| 963 | - Return: | ||
| 964 | - | ||
| 965 | - {array} | ||
| 966 | - */ | ||
| 967 | - function formataTema($id_tema,$publicado="SIM") | ||
| 968 | - { | ||
| 969 | - $recordset = $this->pegaTema($id_tema); | ||
| 970 | - $recordset = $recordset[0]; | ||
| 971 | - $down = "sim"; | ||
| 972 | - $ogc = "sim"; | ||
| 973 | - $link = " "; | ||
| 974 | - $kmz = "nao"; | ||
| 975 | - if (strtolower($recordset["download_tema"]) == "nao") | ||
| 976 | - { | ||
| 977 | - $down = "nao"; | ||
| 978 | - } | ||
| 979 | - if (strtolower($recordset["ogc_tema"]) == "nao") | ||
| 980 | - { | ||
| 981 | - $ogc = "nao"; | ||
| 982 | - } | ||
| 983 | - if(strtolower($recordset["tipoa_tema"]) == "wms") | ||
| 984 | - { | ||
| 985 | - $down = "nao"; | ||
| 986 | - $ogc = "nao"; | ||
| 987 | - } | ||
| 988 | - if ($recordset["link_tema"] != "") | ||
| 989 | - { | ||
| 990 | - $link = $recordset["link_tema"]; | ||
| 991 | - } | ||
| 992 | - if (strtolower($recordset["kmz_tema"]) == "sim") | ||
| 993 | - { | ||
| 994 | - $kmz = "sim"; | ||
| 995 | - } | ||
| 996 | - //codigo_tema para fins de compatibilidade | ||
| 997 | - return array("codigo_tema"=>($recordset["codigo_tema"]),"tipoa_tema"=>$recordset["tipoa_tema"],"publicado"=>$publicado,"nacessos"=>($recordset["nacessos"]),"tid"=>($recordset["codigo_tema"]),"nome"=>$this->converte($recordset["nome_tema"]),"link"=>$link,"download"=>$down,"ogc"=>$ogc,"kmz"=>$kmz); | ||
| 998 | - } | ||
| 999 | - /* | ||
| 1000 | - Function: execSQL | ||
| 1001 | - | ||
| 1002 | - Executa um SQL no banco de administração | ||
| 1003 | - | ||
| 1004 | - Parametros: | ||
| 1005 | - | ||
| 1006 | - sql {string} | ||
| 1007 | - | ||
| 1008 | - Return: | ||
| 1009 | - | ||
| 1010 | - {array} | ||
| 1011 | - */ | ||
| 1012 | - function execSQL($sql) | ||
| 1013 | - { | ||
| 1014 | - //echo "<br>".$sql; | ||
| 1015 | - //error_reporting(0); | ||
| 1016 | - $sql = str_ireplace(array("update","delete","insert","--","drop",";"),"",$sql); | ||
| 1017 | - $q = $this->dbh->query($sql,PDO::FETCH_ASSOC); | ||
| 1018 | - if($q) | ||
| 1019 | - { | ||
| 1020 | - return $q->fetchAll(); | ||
| 1021 | - } | ||
| 1022 | - else | ||
| 1023 | - {return false; | ||
| 1024 | - } | ||
| 1025 | - } | ||
| 1026 | - /* | ||
| 1027 | - Verifica se uma string ocorre em um array | ||
| 1028 | - */ | ||
| 1029 | - function verificaOcorrencia($procurar,$em) | ||
| 1030 | - { | ||
| 1031 | - if(count($em) == 1 && $em[0] == "") | ||
| 1032 | - { | ||
| 1033 | - $em = ""; | ||
| 1034 | - } | ||
| 1035 | - if($procurar == "" && $em == "") | ||
| 1036 | - { | ||
| 1037 | - return true; | ||
| 1038 | - } | ||
| 1039 | - if($em == "") | ||
| 1040 | - { | ||
| 1041 | - return true; | ||
| 1042 | - } | ||
| 1043 | - $resultado = false; | ||
| 1044 | - if($procurar != "" && $em != "") | ||
| 1045 | - { | ||
| 1046 | - foreach($em as $e) | ||
| 1047 | - { | ||
| 1048 | - $e = trim($e); | ||
| 1049 | - foreach($procurar as $p) | ||
| 1050 | - { | ||
| 1051 | - $p = trim($p); | ||
| 1052 | - if($p == $e) | ||
| 1053 | - { | ||
| 1054 | - $resultado = true; | ||
| 1055 | - } | ||
| 1056 | - } | ||
| 1057 | - } | ||
| 1058 | - } | ||
| 1059 | - return $resultado; | ||
| 1060 | - } | ||
| 1061 | - function seems_utf8($Str) { # by bmorel at ssi dot fr | ||
| 1062 | - $length = strlen($Str); | ||
| 1063 | - for ($i = 0; $i < $length; $i++) { | ||
| 1064 | - if (ord($Str[$i]) < 0x80) continue; # 0bbbbbbb | ||
| 1065 | - elseif ((ord($Str[$i]) & 0xE0) == 0xC0) $n = 1; # 110bbbbb | ||
| 1066 | - elseif ((ord($Str[$i]) & 0xF0) == 0xE0) $n = 2; # 1110bbbb | ||
| 1067 | - elseif ((ord($Str[$i]) & 0xF8) == 0xF0) $n = 3; # 11110bbb | ||
| 1068 | - elseif ((ord($Str[$i]) & 0xFC) == 0xF8) $n = 4; # 111110bb | ||
| 1069 | - elseif ((ord($Str[$i]) & 0xFE) == 0xFC) $n = 5; # 1111110b | ||
| 1070 | - else return false; # Does not match any model | ||
| 1071 | - for ($j = 0; $j < $n; $j++) { # n bytes matching 10bbbbbb follow ? | ||
| 1072 | - if ((++$i == $length) || ((ord($Str[$i]) & 0xC0) != 0x80)) | ||
| 1073 | - return false; | ||
| 1074 | - } | ||
| 1075 | - } | ||
| 1076 | - return true; | ||
| 1077 | - } | ||
| 1078 | - /** | ||
| 1079 | - * | ||
| 1080 | - * TODO Verificar ao fechar versao - verificar a acentuacao das palavras nessa funcao | ||
| 1081 | - */ | ||
| 1082 | - function removeAcentos($s) | ||
| 1083 | - { | ||
| 1084 | - $s = ereg_replace("[áàâã]","a",$s); | ||
| 1085 | - $s = ereg_replace("[ÁÀÂÃ]","A",$s); | ||
| 1086 | - $s = ereg_replace("[éèê]","e",$s); | ||
| 1087 | - $s = ereg_replace("[í]","i",$s); | ||
| 1088 | - $s = ereg_replace("[Í]","I",$s); | ||
| 1089 | - $s = ereg_replace("[ÉÈÊ]","E",$s); | ||
| 1090 | - $s = ereg_replace("[óòôõ]","o",$s); | ||
| 1091 | - $s = ereg_replace("[ÓÒÔÕ]","O",$s); | ||
| 1092 | - $s = ereg_replace("[úùû]","u",$s); | ||
| 1093 | - $s = ereg_replace("[ÚÙÛ]","U",$s); | ||
| 1094 | - $s = str_replace("ç","c",$s); | ||
| 1095 | - $s = str_replace("Ç","C",$s); | ||
| 1096 | - //$str = htmlentities($s); | ||
| 1097 | - $str = preg_replace("/(&)([a-z])([a-z]+;)/i", '$2', $s); | ||
| 1098 | - $str = preg_replace("/[^A-Z0-9]/i", ' ', $str); | ||
| 1099 | - $string = preg_replace("/\s+/i", ' ', $str); | ||
| 1100 | - | ||
| 1101 | - if (!preg_match('/[\x80-\xff]/', $string)){ | ||
| 1102 | - return $string; | ||
| 1103 | - } | ||
| 1104 | - if ($this->seems_utf8($string)) { | ||
| 1105 | - $chars = array( | ||
| 1106 | - // Decompositions for Latin-1 Supplement | ||
| 1107 | - chr(195).chr(128) => 'A', chr(195).chr(129) => 'A', | ||
| 1108 | - chr(195).chr(130) => 'A', chr(195).chr(131) => 'A', | ||
| 1109 | - chr(195).chr(132) => 'A', chr(195).chr(133) => 'A', | ||
| 1110 | - chr(195).chr(135) => 'C', chr(195).chr(136) => 'E', | ||
| 1111 | - chr(195).chr(137) => 'E', chr(195).chr(138) => 'E', | ||
| 1112 | - chr(195).chr(139) => 'E', chr(195).chr(140) => 'I', | ||
| 1113 | - chr(195).chr(141) => 'I', chr(195).chr(142) => 'I', | ||
| 1114 | - chr(195).chr(143) => 'I', chr(195).chr(145) => 'N', | ||
| 1115 | - chr(195).chr(146) => 'O', chr(195).chr(147) => 'O', | ||
| 1116 | - chr(195).chr(148) => 'O', chr(195).chr(149) => 'O', | ||
| 1117 | - chr(195).chr(150) => 'O', chr(195).chr(153) => 'U', | ||
| 1118 | - chr(195).chr(154) => 'U', chr(195).chr(155) => 'U', | ||
| 1119 | - chr(195).chr(156) => 'U', chr(195).chr(157) => 'Y', | ||
| 1120 | - chr(195).chr(159) => 's', chr(195).chr(160) => 'a', | ||
| 1121 | - chr(195).chr(161) => 'a', chr(195).chr(162) => 'a', | ||
| 1122 | - chr(195).chr(163) => 'a', chr(195).chr(164) => 'a', | ||
| 1123 | - chr(195).chr(165) => 'a', chr(195).chr(167) => 'c', | ||
| 1124 | - chr(195).chr(168) => 'e', chr(195).chr(169) => 'e', | ||
| 1125 | - chr(195).chr(170) => 'e', chr(195).chr(171) => 'e', | ||
| 1126 | - chr(195).chr(172) => 'i', chr(195).chr(173) => 'i', | ||
| 1127 | - chr(195).chr(174) => 'i', chr(195).chr(175) => 'i', | ||
| 1128 | - chr(195).chr(177) => 'n', chr(195).chr(178) => 'o', | ||
| 1129 | - chr(195).chr(179) => 'o', chr(195).chr(180) => 'o', | ||
| 1130 | - chr(195).chr(181) => 'o', chr(195).chr(182) => 'o', | ||
| 1131 | - chr(195).chr(182) => 'o', chr(195).chr(185) => 'u', | ||
| 1132 | - chr(195).chr(186) => 'u', chr(195).chr(187) => 'u', | ||
| 1133 | - chr(195).chr(188) => 'u', chr(195).chr(189) => 'y', | ||
| 1134 | - chr(195).chr(191) => 'y', | ||
| 1135 | - // Decompositions for Latin Extended-A | ||
| 1136 | - chr(196).chr(128) => 'A', chr(196).chr(129) => 'a', | ||
| 1137 | - chr(196).chr(130) => 'A', chr(196).chr(131) => 'a', | ||
| 1138 | - chr(196).chr(132) => 'A', chr(196).chr(133) => 'a', | ||
| 1139 | - chr(196).chr(134) => 'C', chr(196).chr(135) => 'c', | ||
| 1140 | - chr(196).chr(136) => 'C', chr(196).chr(137) => 'c', | ||
| 1141 | - chr(196).chr(138) => 'C', chr(196).chr(139) => 'c', | ||
| 1142 | - chr(196).chr(140) => 'C', chr(196).chr(141) => 'c', | ||
| 1143 | - chr(196).chr(142) => 'D', chr(196).chr(143) => 'd', | ||
| 1144 | - chr(196).chr(144) => 'D', chr(196).chr(145) => 'd', | ||
| 1145 | - chr(196).chr(146) => 'E', chr(196).chr(147) => 'e', | ||
| 1146 | - chr(196).chr(148) => 'E', chr(196).chr(149) => 'e', | ||
| 1147 | - chr(196).chr(150) => 'E', chr(196).chr(151) => 'e', | ||
| 1148 | - chr(196).chr(152) => 'E', chr(196).chr(153) => 'e', | ||
| 1149 | - chr(196).chr(154) => 'E', chr(196).chr(155) => 'e', | ||
| 1150 | - chr(196).chr(156) => 'G', chr(196).chr(157) => 'g', | ||
| 1151 | - chr(196).chr(158) => 'G', chr(196).chr(159) => 'g', | ||
| 1152 | - chr(196).chr(160) => 'G', chr(196).chr(161) => 'g', | ||
| 1153 | - chr(196).chr(162) => 'G', chr(196).chr(163) => 'g', | ||
| 1154 | - chr(196).chr(164) => 'H', chr(196).chr(165) => 'h', | ||
| 1155 | - chr(196).chr(166) => 'H', chr(196).chr(167) => 'h', | ||
| 1156 | - chr(196).chr(168) => 'I', chr(196).chr(169) => 'i', | ||
| 1157 | - chr(196).chr(170) => 'I', chr(196).chr(171) => 'i', | ||
| 1158 | - chr(196).chr(172) => 'I', chr(196).chr(173) => 'i', | ||
| 1159 | - chr(196).chr(174) => 'I', chr(196).chr(175) => 'i', | ||
| 1160 | - chr(196).chr(176) => 'I', chr(196).chr(177) => 'i', | ||
| 1161 | - chr(196).chr(178) => 'IJ',chr(196).chr(179) => 'ij', | ||
| 1162 | - chr(196).chr(180) => 'J', chr(196).chr(181) => 'j', | ||
| 1163 | - chr(196).chr(182) => 'K', chr(196).chr(183) => 'k', | ||
| 1164 | - chr(196).chr(184) => 'k', chr(196).chr(185) => 'L', | ||
| 1165 | - chr(196).chr(186) => 'l', chr(196).chr(187) => 'L', | ||
| 1166 | - chr(196).chr(188) => 'l', chr(196).chr(189) => 'L', | ||
| 1167 | - chr(196).chr(190) => 'l', chr(196).chr(191) => 'L', | ||
| 1168 | - chr(197).chr(128) => 'l', chr(197).chr(129) => 'L', | ||
| 1169 | - chr(197).chr(130) => 'l', chr(197).chr(131) => 'N', | ||
| 1170 | - chr(197).chr(132) => 'n', chr(197).chr(133) => 'N', | ||
| 1171 | - chr(197).chr(134) => 'n', chr(197).chr(135) => 'N', | ||
| 1172 | - chr(197).chr(136) => 'n', chr(197).chr(137) => 'N', | ||
| 1173 | - chr(197).chr(138) => 'n', chr(197).chr(139) => 'N', | ||
| 1174 | - chr(197).chr(140) => 'O', chr(197).chr(141) => 'o', | ||
| 1175 | - chr(197).chr(142) => 'O', chr(197).chr(143) => 'o', | ||
| 1176 | - chr(197).chr(144) => 'O', chr(197).chr(145) => 'o', | ||
| 1177 | - chr(197).chr(146) => 'OE',chr(197).chr(147) => 'oe', | ||
| 1178 | - chr(197).chr(148) => 'R',chr(197).chr(149) => 'r', | ||
| 1179 | - chr(197).chr(150) => 'R',chr(197).chr(151) => 'r', | ||
| 1180 | - chr(197).chr(152) => 'R',chr(197).chr(153) => 'r', | ||
| 1181 | - chr(197).chr(154) => 'S',chr(197).chr(155) => 's', | ||
| 1182 | - chr(197).chr(156) => 'S',chr(197).chr(157) => 's', | ||
| 1183 | - chr(197).chr(158) => 'S',chr(197).chr(159) => 's', | ||
| 1184 | - chr(197).chr(160) => 'S', chr(197).chr(161) => 's', | ||
| 1185 | - chr(197).chr(162) => 'T', chr(197).chr(163) => 't', | ||
| 1186 | - chr(197).chr(164) => 'T', chr(197).chr(165) => 't', | ||
| 1187 | - chr(197).chr(166) => 'T', chr(197).chr(167) => 't', | ||
| 1188 | - chr(197).chr(168) => 'U', chr(197).chr(169) => 'u', | ||
| 1189 | - chr(197).chr(170) => 'U', chr(197).chr(171) => 'u', | ||
| 1190 | - chr(197).chr(172) => 'U', chr(197).chr(173) => 'u', | ||
| 1191 | - chr(197).chr(174) => 'U', chr(197).chr(175) => 'u', | ||
| 1192 | - chr(197).chr(176) => 'U', chr(197).chr(177) => 'u', | ||
| 1193 | - chr(197).chr(178) => 'U', chr(197).chr(179) => 'u', | ||
| 1194 | - chr(197).chr(180) => 'W', chr(197).chr(181) => 'w', | ||
| 1195 | - chr(197).chr(182) => 'Y', chr(197).chr(183) => 'y', | ||
| 1196 | - chr(197).chr(184) => 'Y', chr(197).chr(185) => 'Z', | ||
| 1197 | - chr(197).chr(186) => 'z', chr(197).chr(187) => 'Z', | ||
| 1198 | - chr(197).chr(188) => 'z', chr(197).chr(189) => 'Z', | ||
| 1199 | - chr(197).chr(190) => 'z', chr(197).chr(191) => 's', | ||
| 1200 | - // Euro Sign | ||
| 1201 | - chr(226).chr(130).chr(172) => 'E', | ||
| 1202 | - // GBP (Pound) Sign | ||
| 1203 | - chr(194).chr(163) => ''); | ||
| 1204 | - $string = strtr($string, $chars); | ||
| 1205 | - } else { | ||
| 1206 | - // Assume ISO-8859-1 if not UTF-8 | ||
| 1207 | - $chars['in'] = chr(128).chr(131).chr(138).chr(142).chr(154).chr(158) | ||
| 1208 | - .chr(159).chr(162).chr(165).chr(181).chr(192).chr(193).chr(194) | ||
| 1209 | - .chr(195).chr(196).chr(197).chr(199).chr(200).chr(201).chr(202) | ||
| 1210 | - .chr(203).chr(204).chr(205).chr(206).chr(207).chr(209).chr(210) | ||
| 1211 | - .chr(211).chr(212).chr(213).chr(214).chr(216).chr(217).chr(218) | ||
| 1212 | - .chr(219).chr(220).chr(221).chr(224).chr(225).chr(226).chr(227) | ||
| 1213 | - .chr(228).chr(229).chr(231).chr(232).chr(233).chr(234).chr(235) | ||
| 1214 | - .chr(236).chr(237).chr(238).chr(239).chr(241).chr(242).chr(243) | ||
| 1215 | - .chr(244).chr(245).chr(246).chr(248).chr(249).chr(250).chr(251) | ||
| 1216 | - .chr(252).chr(253).chr(255); | ||
| 1217 | - $chars['out'] = "EfSZszYcYuAAAAAACEEEEIIIINOOOOOOUUUUYaaaaaaceeeeiiiinoooooouuuuyy"; | ||
| 1218 | - $string = strtr($string, $chars['in'], $chars['out']); | ||
| 1219 | - $double_chars['in'] = array(chr(140), chr(156), chr(198), chr(208), chr(222), chr(223), chr(230), chr(240), chr(254)); | ||
| 1220 | - $double_chars['out'] = array('OE', 'oe', 'AE', 'DH', 'TH', 'ss', 'ae', 'dh', 'th'); | ||
| 1221 | - $string = str_replace($double_chars['in'], $double_chars['out'], $string); | ||
| 1222 | - } | ||
| 1223 | - return $string; | ||
| 1224 | - } | ||
| 1225 | - function converte($texto){ | ||
| 1226 | - if($this->convUTF == true) | ||
| 1227 | - $texto = mb_convert_encoding($texto,mb_detect_encoding($texto),"UTF-8"); | ||
| 1228 | - else | ||
| 1229 | - $texto = mb_convert_encoding($texto,mb_detect_encoding($texto),"ISO-8859-1"); | ||
| 1230 | - return $texto; | ||
| 1231 | - } | ||
| 1232 | - function verificaPapelSessao($id_papel){ | ||
| 1233 | - if(!empty($_COOKIE["i3geocodigologin"])){ | ||
| 1234 | - session_write_close(); | ||
| 1235 | - session_name("i3GeoLogin"); | ||
| 1236 | - session_id($_COOKIE["i3geocodigologin"]); | ||
| 1237 | - session_start(); | ||
| 1238 | - //var_dump($_SESSION);exit; | ||
| 1239 | - if($_SESSION["usuario"] != $_COOKIE["i3geousuariologin"]){ | ||
| 1240 | - return false; | ||
| 1241 | - } | ||
| 1242 | - foreach($_SESSION["papeis"] as $p){ | ||
| 1243 | - if($p == 1 || $p == $id_papel){ | ||
| 1244 | - return true; | ||
| 1245 | - } | ||
| 1246 | - } | ||
| 1247 | - } | ||
| 1248 | - else{//caso nao exista, retorna um erro | ||
| 1249 | - return false; | ||
| 1250 | - } | ||
| 1251 | - } | ||
| 1252 | - function verificaOperacaoSessao($operacao){ | ||
| 1253 | - if($_COOKIE["i3geocodigologin"] != ""){ | ||
| 1254 | - session_write_close(); | ||
| 1255 | - session_name("i3GeoLogin"); | ||
| 1256 | - session_id($_COOKIE["i3geocodigologin"]); | ||
| 1257 | - session_start(); | ||
| 1258 | - $resultado = false; | ||
| 1259 | - //verifica se e administrador | ||
| 1260 | - foreach($_SESSION["papeis"] as $p){ | ||
| 1261 | - if($p == 1){ | ||
| 1262 | - return true; | ||
| 1263 | - } | ||
| 1264 | - } | ||
| 1265 | - if(!empty($_SESSION["operacoes"][$operacao])){ | ||
| 1266 | - $resultado = true; | ||
| 1267 | - } | ||
| 1268 | - return $resultado; | ||
| 1269 | - } else { | ||
| 1270 | - return false; | ||
| 1271 | - } | ||
| 1272 | - } | ||
| 1273 | -} | ||
| 1274 | -?> | ||
| 1275 | \ No newline at end of file | 0 | \ No newline at end of file |
| @@ -0,0 +1,1268 @@ | @@ -0,0 +1,1268 @@ | ||
| 1 | +<?php | ||
| 2 | +/* | ||
| 3 | +Title: classe_arvore.php | ||
| 4 | + | ||
| 5 | +Funções para montagem da árvore de temas | ||
| 6 | + | ||
| 7 | +Licenca: | ||
| 8 | + | ||
| 9 | +GPL2 | ||
| 10 | + | ||
| 11 | +i3Geo Interface Integrada de Ferramentas de Geoprocessamento para Internet | ||
| 12 | + | ||
| 13 | +Direitos Autorais Reservados (c) 2006 Ministério do Meio Ambiente Brasil | ||
| 14 | +Desenvolvedor: Edmar Moretti edmar.moretti@gmail.com | ||
| 15 | + | ||
| 16 | +Este programa é software livre; você pode redistribuí-lo | ||
| 17 | +e/ou modificá-lo sob os termos da Licença Pública Geral | ||
| 18 | +GNU conforme publicada pela Free Software Foundation; | ||
| 19 | + | ||
| 20 | +Este programa é distribuído na expectativa de que seja útil, | ||
| 21 | +porém, SEM NENHUMA GARANTIA; nem mesmo a garantia implícita | ||
| 22 | +de COMERCIABILIDADE OU ADEQUAÇÃO A UMA FINALIDADE ESPECÍFICA. | ||
| 23 | +Consulte a Licença Pública Geral do GNU para mais detalhes. | ||
| 24 | +Você deve ter recebido uma c�pia da Licença Pública Geral do | ||
| 25 | + GNU junto com este programa; se não, escreva para a | ||
| 26 | +Free Software Foundation, Inc., no endereço | ||
| 27 | +59 Temple Street, Suite 330, Boston, MA 02111-1307 USA. | ||
| 28 | + | ||
| 29 | +Arquivo: | ||
| 30 | + | ||
| 31 | +i3geo/classesphp/classe_arvore.php | ||
| 32 | +*/ | ||
| 33 | +/* | ||
| 34 | +Classe: Arvore | ||
| 35 | + | ||
| 36 | +Classe utilizada para compor a árvore de temas ou obter dados específicos da árvore. | ||
| 37 | + | ||
| 38 | +É utilizada por várias operações do i3Geo, principalmente pela <classe_menutemas> | ||
| 39 | +*/ | ||
| 40 | +class Arvore | ||
| 41 | +{ | ||
| 42 | + //temas com acesso restrito e que nao podem ser acessados pelo usuario que esta logado | ||
| 43 | + public $temassindevidos; | ||
| 44 | + protected $locaplic; | ||
| 45 | + //subgrupos que tem pelo menos um tema | ||
| 46 | + //public $sql_subgrupos = "select i3geoadmin_subgrupos.nome_subgrupo,i3geoadmin_n2.id_n2,i3geoadmin_n2.publicado,i3geoadmin_n2.n2_perfil from i3geoadmin_n2 LEFT JOIN i3geoadmin_subgrupos ON i3geoadmin_n2.id_subgrupo = i3geoadmin_subgrupos.id_subgrupo "; | ||
| 47 | + //grupos que tem pelo menos um sub-grupo | ||
| 48 | + //public $sql_grupos = "select i3geoadmin_grupos.nome_grupo,id_n1,id_menu,i3geoadmin_n1.publicado,n1_perfil from i3geoadmin_n1 LEFT JOIN i3geoadmin_grupos ON i3geoadmin_n1.id_grupo = i3geoadmin_grupos.id_grupo "; | ||
| 49 | + //nomes de todos os grupos | ||
| 50 | + public $sql_todosgrupos = "select * from i3geoadmin_grupos "; | ||
| 51 | + //tipo de filtro | ||
| 52 | + //ogc|download|"" | ||
| 53 | + public $filtro; | ||
| 54 | + //temas na raiz | ||
| 55 | + //public $sql_temasraiz = "select id_raiz,i3geoadmin_raiz.id_tema,nome_tema,tipoa_tema FROM i3geoadmin_raiz LEFT JOIN i3geoadmin_temas ON i3geoadmin_temas.id_tema = i3geoadmin_raiz.id_tema "; | ||
| 56 | + //todos os temas | ||
| 57 | + //public $sql_temas = "select * from i3geoadmin_temas "; | ||
| 58 | + //temas de um subgrupo | ||
| 59 | + //public $sql_temasSubgrupo = "select i3geoadmin_temas.tipoa_tema, i3geoadmin_temas.codigo_tema,i3geoadmin_temas.tags_tema,i3geoadmin_n3.id_n3,i3geoadmin_temas.nome_tema,i3geoadmin_n3.publicado,i3geoadmin_n3.n3_perfil,i3geoadmin_n3.id_tema,i3geoadmin_temas.download_tema,i3geoadmin_temas.ogc_tema from i3geoadmin_n3 LEFT JOIN i3geoadmin_temas ON i3geoadmin_n3.id_tema = i3geoadmin_temas.id_tema "; | ||
| 60 | + /* | ||
| 61 | + Function: __construct | ||
| 62 | + | ||
| 63 | + Cria um objeto Arvore | ||
| 64 | + | ||
| 65 | + Parametros: | ||
| 66 | + | ||
| 67 | + locaplic {string} - localização do i3geo no sistema de arquivos | ||
| 68 | + | ||
| 69 | + idioma {string} - default = "pt" | ||
| 70 | + */ | ||
| 71 | + function __construct($locaplic,$idioma="pt",$filtro="") | ||
| 72 | + { | ||
| 73 | + $this->locaplic = $locaplic; | ||
| 74 | + $this->filtro = $filtro; | ||
| 75 | + $dbh = ""; | ||
| 76 | + //error_reporting(0); | ||
| 77 | + | ||
| 78 | + include($locaplic."/classesphp/conexao.php"); | ||
| 79 | + | ||
| 80 | + $this->esquemaadmin = $esquemaadmin; | ||
| 81 | + $this->convUTF = $convUTF; | ||
| 82 | + $this->dbh = $dbh; | ||
| 83 | + | ||
| 84 | + $this->idioma = $idioma; | ||
| 85 | + if($idioma == "pt"){ | ||
| 86 | + $coluna = "nome_grupo"; | ||
| 87 | + } | ||
| 88 | + else{ | ||
| 89 | + $coluna = $idioma; | ||
| 90 | + } | ||
| 91 | + $this->sql_grupos = "select CASE i3geoadmin_grupos.$coluna WHEN '' THEN nome_grupo ELSE i3geoadmin_grupos.$coluna END as nome_grupo,i3geoadmin_grupos.id_grupo, id_n1,id_menu,i3geoadmin_n1.publicado,n1_perfil,ordem from ".$this->esquemaadmin."i3geoadmin_n1 LEFT JOIN ".$this->esquemaadmin."i3geoadmin_grupos ON i3geoadmin_n1.id_grupo = i3geoadmin_grupos.id_grupo "; | ||
| 92 | + if($filtro === "ogc" || $filtro === "download"){ | ||
| 93 | + //esse sql retorna tambem os grupos dos temas que estao na raiz do grupo | ||
| 94 | + $this->sql_grupos = "select DISTINCT * from (select CASE grupos.$coluna WHEN '' THEN nome_grupo ELSE grupos.$coluna END as nome_grupo,gr.id_n1,gr.id_menu,gr.publicado,gr.n1_perfil, 0 as ordem from ".$this->esquemaadmin."i3geoadmin_grupos as grupos, ".$this->esquemaadmin."i3geoadmin_n1 as gr, ".$this->esquemaadmin."i3geoadmin_n2 as sg, ".$this->esquemaadmin."i3geoadmin_n3 as t, ".$this->esquemaadmin."i3geoadmin_temas as temas where gr.id_grupo = grupos.id_grupo AND sg.id_n1 = gr.id_n1 AND t.id_n2 = sg.id_n2 AND t.id_tema = temas.id_tema AND (temas.ogc_tema NOT IN ('NAO','nao') OR temas.download_tema NOT IN ('NAO','nao') ) UNION select c.nome_grupo as nome_grupo,a.id_nivel as id_n1,a.id_menu,'SIM' as publicado,a.perfil as n1_perfil, 0 as ordem from ".$this->esquemaadmin."i3geoadmin_raiz as a, ".$this->esquemaadmin."i3geoadmin_temas as b, ".$this->esquemaadmin."i3geoadmin_grupos as c, ".$this->esquemaadmin."i3geoadmin_n1 as d where nivel = 1 AND a.id_tema = b.id_tema AND a.id_nivel = d.id_n1 AND d.id_grupo = c.id_grupo) as s "; | ||
| 95 | + } | ||
| 96 | + | ||
| 97 | + if($idioma == "pt"){ | ||
| 98 | + $coluna = "nome_subgrupo"; | ||
| 99 | + } | ||
| 100 | + else{ | ||
| 101 | + $coluna = $idioma; | ||
| 102 | + } | ||
| 103 | + $this->sql_subgrupos = "select CASE i3geoadmin_subgrupos.$coluna WHEN '' THEN nome_subgrupo ELSE i3geoadmin_subgrupos.$coluna END as nome_subgrupo,i3geoadmin_subgrupos.id_subgrupo,i3geoadmin_n2.id_n2,i3geoadmin_n2.publicado,i3geoadmin_n2.n2_perfil from ".$this->esquemaadmin."i3geoadmin_n2 LEFT JOIN ".$this->esquemaadmin."i3geoadmin_subgrupos ON i3geoadmin_n2.id_subgrupo = i3geoadmin_subgrupos.id_subgrupo "; | ||
| 104 | + | ||
| 105 | + if($idioma == "pt"){ | ||
| 106 | + $coluna = "nome_tema"; | ||
| 107 | + } | ||
| 108 | + else{ | ||
| 109 | + $coluna = $idioma; | ||
| 110 | + } | ||
| 111 | + | ||
| 112 | + $this->sql_temasraiz = "select id_nivel,ordem,codigo_tema,id_raiz,i3geoadmin_raiz.id_tema,CASE $coluna WHEN '' THEN nome_tema ELSE $coluna END as nome_tema,tipoa_tema,perfil, ogc_tema, download_tema, link_tema FROM ".$this->esquemaadmin."i3geoadmin_raiz LEFT JOIN ".$this->esquemaadmin."i3geoadmin_temas ON i3geoadmin_temas.id_tema = i3geoadmin_raiz.id_tema "; | ||
| 113 | + $this->sql_temasSubgrupo = "select i3geoadmin_temas.tipoa_tema, i3geoadmin_temas.codigo_tema,i3geoadmin_temas.tags_tema,i3geoadmin_n3.id_n3,CASE i3geoadmin_temas.$coluna WHEN '' THEN nome_tema ELSE i3geoadmin_temas.$coluna END as nome_tema,i3geoadmin_n3.publicado,i3geoadmin_n3.n3_perfil,i3geoadmin_n3.id_tema,i3geoadmin_temas.download_tema,i3geoadmin_temas.ogc_tema from ".$this->esquemaadmin."i3geoadmin_n3 LEFT JOIN ".$this->esquemaadmin."i3geoadmin_temas ON i3geoadmin_n3.id_tema = i3geoadmin_temas.id_tema "; | ||
| 114 | + | ||
| 115 | + //$this->sql_temas = "select kmz_tema,nacessos,id_tema,kml_tema,ogc_tema,download_tema,tags_tema,tipoa_tema,link_tema,desc_tema,$coluna as nome_tema,codigo_tema from i3geoadmin_temas "; | ||
| 116 | + | ||
| 117 | + $this->sql_temas = "select kmz_tema,b.soma as nacessos,id_tema,kml_tema,ogc_tema,download_tema,tags_tema,tipoa_tema,link_tema,desc_tema,CASE $coluna WHEN '' THEN nome_tema ELSE $coluna END as nome_tema,codigo_tema from ".$this->esquemaadmin."i3geoadmin_temas as a,(SELECT c.codigo_tema codigo_soma,sum( r.nacessos) as soma FROM ".$this->esquemaadmin."i3geoadmin_temas c LEFT JOIN ".$this->esquemaadmin."i3geoadmin_acessostema r ON (c.codigo_tema = r.codigo_tema) group by c.codigo_tema) as b WHERE a.codigo_tema = b.codigo_soma "; | ||
| 118 | + $this->sql_temas_combo = "select id_tema,CASE $coluna WHEN '' THEN nome_tema ELSE $coluna END as nome_tema,codigo_tema from ".$this->esquemaadmin."i3geoadmin_temas as a,(SELECT c.codigo_tema codigo_soma,sum( r.nacessos) as soma FROM ".$this->esquemaadmin."i3geoadmin_temas c LEFT JOIN ".$this->esquemaadmin."i3geoadmin_acessostema r ON (c.codigo_tema = r.codigo_tema) group by c.codigo_tema) as b WHERE a.codigo_tema = b.codigo_soma "; | ||
| 119 | + // | ||
| 120 | + //verifica se o ip atual está cadastrado como um dos editores | ||
| 121 | + //editores podem ver as coisas marcadas como não publicado | ||
| 122 | + //no sistema de administração | ||
| 123 | + // | ||
| 124 | + $this->editor = false; | ||
| 125 | + $this->editor = $this->verificaOperacaoSessao("admin/php/classe_arvore/editor"); | ||
| 126 | + $this->pubsql = " (publicado != 'NAO' or publicado is null) and "; | ||
| 127 | + if($this->editor){ | ||
| 128 | + $this->pubsql = ""; | ||
| 129 | + } | ||
| 130 | + if(!function_exists("listaTemasIndevidos")){ | ||
| 131 | + include_once(dirname(__FILE__)."/../../classesphp/funcoes_gerais.php"); | ||
| 132 | + } | ||
| 133 | + $this->temasindevidos = listaTemasIndevidos(); | ||
| 134 | + } | ||
| 135 | + function __destruct() | ||
| 136 | + { | ||
| 137 | + $this->dbh = null; | ||
| 138 | + $this->dbhw = null; | ||
| 139 | + } | ||
| 140 | + /* | ||
| 141 | + Function: validaTemas | ||
| 142 | + | ||
| 143 | + Remove de um array os temas que nao sao permitidos ao usuario atualmente logado | ||
| 144 | + */ | ||
| 145 | + function validaTemas($linhas,$id){ | ||
| 146 | + $res = array(); | ||
| 147 | + foreach($linhas as $l){ | ||
| 148 | + if(!in_array($l[$id],$this->temasindevidos)){ | ||
| 149 | + array_push($res,$l); | ||
| 150 | + } | ||
| 151 | + } | ||
| 152 | + return $res; | ||
| 153 | + } | ||
| 154 | + /* | ||
| 155 | + Function: pegaListaDeMenus | ||
| 156 | + | ||
| 157 | + Retorna a lista de menus | ||
| 158 | + | ||
| 159 | + Parametros: | ||
| 160 | + | ||
| 161 | + perfil {string} - considera apenas esse perfil | ||
| 162 | + | ||
| 163 | + Return: | ||
| 164 | + | ||
| 165 | + {array} | ||
| 166 | + */ | ||
| 167 | + function pegaListaDeMenus($perfil="",$filtraOgc="nao",$filtraDown="nao") | ||
| 168 | + { | ||
| 169 | + if($this->idioma == "pt"){ | ||
| 170 | + $coluna = "nome_menu"; | ||
| 171 | + } | ||
| 172 | + else{ | ||
| 173 | + $coluna = $this->idioma; | ||
| 174 | + } | ||
| 175 | + if($this->editor == true) | ||
| 176 | + { | ||
| 177 | + $perfil = ""; | ||
| 178 | + $sql = "SELECT publicado_menu,'' as perfil_menu,aberto,desc_menu,id_menu,CASE $coluna WHEN '' THEN nome_menu ELSE $coluna END as nome_menu from ".$this->esquemaadmin."i3geoadmin_menus order by nome_menu"; | ||
| 179 | + } | ||
| 180 | + else{ | ||
| 181 | + $sql = "SELECT publicado_menu,perfil_menu,aberto,desc_menu,id_menu,CASE $coluna WHEN '' THEN nome_menu ELSE $coluna END as nome_menu from ".$this->esquemaadmin."i3geoadmin_menus where publicado_menu != 'NAO' or publicado_menu is null order by nome_menu"; | ||
| 182 | + } | ||
| 183 | + $regs = $this->execSQL($sql); | ||
| 184 | + $resultado = array(); | ||
| 185 | + foreach($regs as $reg){ | ||
| 186 | + $a = $reg["perfil_menu"]; | ||
| 187 | + $a = str_replace(" ",",",$a); | ||
| 188 | + if ($this->verificaOcorrencia($perfil,explode(",",$a))) | ||
| 189 | + { | ||
| 190 | + $status = "fechado"; | ||
| 191 | + if(strtolower($reg["aberto"]) == "sim") | ||
| 192 | + $status = "aberto"; | ||
| 193 | + $url = ""; | ||
| 194 | + $resultado[] = array("desc"=>$this->converte($reg["desc_menu"]),"publicado"=>$reg["publicado_menu"],"nomemenu"=>$this->converte($reg["nome_menu"]),"idmenu"=>$reg["id_menu"],"arquivo"=>"","status"=>$status,"url"=>$url); | ||
| 195 | + } | ||
| 196 | + } | ||
| 197 | + return $resultado; | ||
| 198 | + } | ||
| 199 | + /* | ||
| 200 | + Function: pegaListaDeTiposGrupos | ||
| 201 | + | ||
| 202 | + Retorna a lista de grupos de um menu | ||
| 203 | + | ||
| 204 | + Parametros: | ||
| 205 | + | ||
| 206 | + id_menu {string} | ||
| 207 | + | ||
| 208 | + Return: | ||
| 209 | + | ||
| 210 | + {array} | ||
| 211 | + */ | ||
| 212 | + function pegaListaDeTiposGrupos(){ | ||
| 213 | + if($this->idioma == "pt"){ | ||
| 214 | + $coluna = "nome_grupo"; | ||
| 215 | + } | ||
| 216 | + else{ | ||
| 217 | + $coluna = $this->idioma; | ||
| 218 | + } | ||
| 219 | + $sql = "select CASE i3geoadmin_grupos.$coluna WHEN '' THEN nome_grupo ELSE i3geoadmin_grupos.$coluna END as nome_grupo, id_grupo from ".$this->esquemaadmin."i3geoadmin_grupos ORDER by nome_grupo "; | ||
| 220 | + $grupos = $this->execSQL($sql); | ||
| 221 | + return $grupos; | ||
| 222 | + } | ||
| 223 | + /* | ||
| 224 | + Function: pegaListaDeTiposSubGrupos | ||
| 225 | + | ||
| 226 | + Retorna a lista de grupos de um menu | ||
| 227 | + | ||
| 228 | + Parametros: | ||
| 229 | + | ||
| 230 | + id_menu {string} | ||
| 231 | + | ||
| 232 | + Return: | ||
| 233 | + | ||
| 234 | + {array} | ||
| 235 | + */ | ||
| 236 | + function pegaListaDeTiposSubGrupos(){ | ||
| 237 | + if($this->idioma == "pt"){ | ||
| 238 | + $coluna = "nome_subgrupo"; | ||
| 239 | + } | ||
| 240 | + else{ | ||
| 241 | + $coluna = $this->idioma; | ||
| 242 | + } | ||
| 243 | + $sql = "select CASE i3geoadmin_subgrupos.$coluna WHEN '' THEN nome_subgrupo ELSE i3geoadmin_subgrupos.$coluna END as nome_subgrupo, id_subgrupo from ".$this->esquemaadmin."i3geoadmin_subgrupos ORDER by nome_subgrupo "; | ||
| 244 | + $subgrupos = $this->execSQL($sql); | ||
| 245 | + return $subgrupos; | ||
| 246 | + } | ||
| 247 | + /* | ||
| 248 | + Function: procuraTemas | ||
| 249 | + | ||
| 250 | + Localiza temas conforme uma palavra de busca | ||
| 251 | + | ||
| 252 | + Parametros: | ||
| 253 | + | ||
| 254 | + procurar {string} - palavra de busca | ||
| 255 | + | ||
| 256 | + perfil {string} - considera apenas esse perfil | ||
| 257 | + | ||
| 258 | + Return: | ||
| 259 | + | ||
| 260 | + {array} | ||
| 261 | + */ | ||
| 262 | + function procuraTemas ($procurar,$perfil) | ||
| 263 | + { | ||
| 264 | + if($procurar != "") | ||
| 265 | + { | ||
| 266 | + $procurar = $this->removeAcentos($procurar); | ||
| 267 | + } | ||
| 268 | + $menus = $this->pegaListaDeMenus($perfil); | ||
| 269 | + $resultado = array(); | ||
| 270 | + $subgrupo = array(); | ||
| 271 | + $final = array(); | ||
| 272 | + foreach($menus as $menu) | ||
| 273 | + { | ||
| 274 | + $grupos = $this->pegaGruposMenu($menu["idmenu"]); | ||
| 275 | + foreach($grupos["grupos"] as $grupo) | ||
| 276 | + { | ||
| 277 | + $a = $grupo["n1_perfil"]; | ||
| 278 | + $a = str_replace(" ",",",$a); | ||
| 279 | + if($this->verificaOcorrencia($perfil,explode(",",$a))) | ||
| 280 | + { | ||
| 281 | + $sgrupos = $this->pegaSubgruposGrupo($menu["idmenu"],$grupo["id_n1"]); | ||
| 282 | + $temasRaizGrupo = array(); | ||
| 283 | + $temasR = $this->pegaTemasRaizGrupo($menu["idmenu"],$grupo["id_n1"]); | ||
| 284 | + foreach($temasR as $tema) | ||
| 285 | + { | ||
| 286 | + $a = $tema["perfil"]; | ||
| 287 | + $a = str_replace(" ",",",$a); | ||
| 288 | + if($this->verificaOcorrencia($perfil,explode(",",$a))) | ||
| 289 | + { | ||
| 290 | + $t = $this->pegaTema($tema["id_tema"]); | ||
| 291 | + $t = $t[0]; | ||
| 292 | + $nome = $this->removeAcentos($tema["nome_tema"]); | ||
| 293 | + $tags = $this->removeAcentos($tema["tags_tema"]); | ||
| 294 | + $tags1 = $this->removeAcentos(mb_convert_encoding($tema["tags_tema"],"ISO-8859-1","UTF-8")); | ||
| 295 | + $nome1 = $this->removeAcentos(mb_convert_encoding($tema["nome_tema"],"ISO-8859-1","UTF-8")); | ||
| 296 | + $miniatura = "nao"; | ||
| 297 | + if(file_exists($this->locaplic."/temas/miniaturas/".$t["codigo_tema"].".map.mini.png")) | ||
| 298 | + { | ||
| 299 | + $miniatura = "sim"; | ||
| 300 | + } | ||
| 301 | + $down = "sim"; | ||
| 302 | + if (strtolower($t["download_tema"]) == "nao") | ||
| 303 | + { | ||
| 304 | + $down = "nao"; | ||
| 305 | + } | ||
| 306 | + $texto = array("codigo_tema"=>$t["codigo_tema"],"miniatura"=>$miniatura,"tid"=>$t["codigo_tema"],"nome"=>$this->converte($tema["nome_tema"]),"link"=>$t["link_tema"],"download"=>$down); | ||
| 307 | + if($procurar == "") | ||
| 308 | + { | ||
| 309 | + $temasRaizGrupo[] = $texto; | ||
| 310 | + } | ||
| 311 | + else | ||
| 312 | + { | ||
| 313 | + if (stristr($nome,$procurar) || stristr($nome1,$procurar)) | ||
| 314 | + { | ||
| 315 | + $temasRaizGrupo[] = $texto; | ||
| 316 | + } | ||
| 317 | + else | ||
| 318 | + { | ||
| 319 | + if (stristr($tags,$procurar) || stristr($tags1,$procurar)) | ||
| 320 | + { | ||
| 321 | + $temasRaizGrupo[] = $texto; | ||
| 322 | + } | ||
| 323 | + } | ||
| 324 | + } | ||
| 325 | + } | ||
| 326 | + } | ||
| 327 | + foreach($sgrupos["subgrupos"] as $sgrupo) | ||
| 328 | + { | ||
| 329 | + $a = $sgrupo["n2_perfil"]; | ||
| 330 | + $a = str_replace(" ",",",$a); | ||
| 331 | + if($this->verificaOcorrencia($perfil,explode(",",$a))) | ||
| 332 | + { | ||
| 333 | + $temas = $this->pegaTemasSubGrupo($sgrupo["id_n2"]); | ||
| 334 | + foreach ($temas as $tema) | ||
| 335 | + { | ||
| 336 | + $a = $tema["n3_perfil"]; | ||
| 337 | + $a = str_replace(" ",",",$a); | ||
| 338 | + if($this->verificaOcorrencia($perfil,explode(",",$a))) | ||
| 339 | + { | ||
| 340 | + $t = $this->pegaTema($tema["id_tema"]); | ||
| 341 | + $t = $t[0]; | ||
| 342 | + $nome = $this->removeAcentos($tema["nome_tema"]); | ||
| 343 | + $tags = $this->removeAcentos($tema["tags_tema"]); | ||
| 344 | + $tags1 = $this->removeAcentos(mb_convert_encoding($tema["tags_tema"],"ISO-8859-1","UTF-8")); | ||
| 345 | + $nome1 = $this->removeAcentos(mb_convert_encoding($tema["nome_tema"],"ISO-8859-1","UTF-8")); | ||
| 346 | + $miniatura = "nao"; | ||
| 347 | + if(file_exists($this->locaplic."/temas/miniaturas/".$tema["codigo_tema"].".map.mini.png")) | ||
| 348 | + { | ||
| 349 | + $miniatura = "sim"; | ||
| 350 | + } | ||
| 351 | + $down = "sim"; | ||
| 352 | + if (strtolower($t["download_tema"]) == "nao") | ||
| 353 | + { | ||
| 354 | + $down = "nao"; | ||
| 355 | + } | ||
| 356 | + $texto = array("codigo_tema"=>$tema["codigo_tema"],"miniatura"=>$miniatura,"tid"=>$tema["codigo_tema"],"nome"=>$this->converte($tema["nome_tema"]),"link"=>$t["link_tema"],"download"=>$down); | ||
| 357 | + if($procurar == "") | ||
| 358 | + { | ||
| 359 | + $resultado[] = $texto; | ||
| 360 | + } | ||
| 361 | + else | ||
| 362 | + { | ||
| 363 | + if (stristr($nome,$procurar) || stristr($nome1,$procurar)) | ||
| 364 | + { | ||
| 365 | + $resultado[] = $texto; | ||
| 366 | + } | ||
| 367 | + else | ||
| 368 | + { | ||
| 369 | + if (stristr($tags,$procurar) || stristr($tags1,$procurar)) | ||
| 370 | + { | ||
| 371 | + $resultado[] = $texto; | ||
| 372 | + } | ||
| 373 | + } | ||
| 374 | + } | ||
| 375 | + } | ||
| 376 | + } | ||
| 377 | + } | ||
| 378 | + if (count($resultado) > 0) | ||
| 379 | + { | ||
| 380 | + $subgrupo[] = array("subgrupo"=>$this->converte($sgrupo["nome_subgrupo"]),"temas"=>$resultado); | ||
| 381 | + } | ||
| 382 | + $resultado = array(); | ||
| 383 | + } | ||
| 384 | + } | ||
| 385 | + if (count($subgrupo) > 0 || count($temasRaizGrupo) > 0) | ||
| 386 | + { | ||
| 387 | + $final[] = array("grupo"=>$this->converte($grupo["nome_grupo"]),"temas"=>$temasRaizGrupo,"subgrupos"=>$subgrupo); | ||
| 388 | + } | ||
| 389 | + $subgrupo = array(); | ||
| 390 | + } | ||
| 391 | + } | ||
| 392 | + return $final; | ||
| 393 | + } | ||
| 394 | + /* | ||
| 395 | + Function: procuraTemasEstrela | ||
| 396 | + | ||
| 397 | + Localiza temas que têm um determinado número (nível) de estrelas | ||
| 398 | + | ||
| 399 | + Parametros: | ||
| 400 | + | ||
| 401 | + nivel {numeric} - número de estrelas | ||
| 402 | + | ||
| 403 | + perfil {string} - considera apenas esse perfil | ||
| 404 | + | ||
| 405 | + Return: | ||
| 406 | + | ||
| 407 | + {array} | ||
| 408 | + */ | ||
| 409 | + function procuraTemasEstrela($nivel,$fatorestrela,$perfil) | ||
| 410 | + { | ||
| 411 | + $menus = $this->pegaListaDeMenus($perfil); | ||
| 412 | + | ||
| 413 | + $resultado = array(); | ||
| 414 | + $subgrupo = array(); | ||
| 415 | + $final = array(); | ||
| 416 | + foreach($menus as $menu) | ||
| 417 | + { | ||
| 418 | + $grupos = $this->pegaGruposMenu($menu["idmenu"]); | ||
| 419 | + foreach($grupos["grupos"] as $grupo) | ||
| 420 | + { | ||
| 421 | + $a = $grupo["n1_perfil"]; | ||
| 422 | + $a = str_replace(" ",",",$a); | ||
| 423 | + if($this->verificaOcorrencia($perfil,explode(",",$a))) | ||
| 424 | + { | ||
| 425 | + $sgrupos = $this->pegaSubgruposGrupo($menu["idmenu"],$grupo["id_n1"]); | ||
| 426 | + $temasRaizGrupo = array(); | ||
| 427 | + $temasR = $this->pegaTemasRaizGrupo($menu["idmenu"],$grupo["id_n1"]); | ||
| 428 | + foreach($temasR as $tema) | ||
| 429 | + { | ||
| 430 | + $a = $tema["perfil"]; | ||
| 431 | + $a = str_replace(" ",",",$a); | ||
| 432 | + if($this->verificaOcorrencia($perfil,explode(",",$a))) | ||
| 433 | + { | ||
| 434 | + $t = $this->pegaTema($tema["id_tema"]); | ||
| 435 | + $t = $t[0]; | ||
| 436 | + $nome = $this->removeAcentos($tema["nome_tema"]); | ||
| 437 | + $tags = $this->removeAcentos($tema["tags_tema"]); | ||
| 438 | + $tags1 = $this->removeAcentos(mb_convert_encoding($tema["tags_tema"],"ISO-8859-1","UTF-8")); | ||
| 439 | + $nome1 = $this->removeAcentos(mb_convert_encoding($tema["nome_tema"],"ISO-8859-1","UTF-8")); | ||
| 440 | + $miniatura = "nao"; | ||
| 441 | + if(file_exists($this->locaplic."/temas/miniaturas/".$t["codigo_tema"].".map.mini.png")) | ||
| 442 | + { | ||
| 443 | + $miniatura = "sim"; | ||
| 444 | + } | ||
| 445 | + $down = "sim"; | ||
| 446 | + if (strtolower($t["download_tema"]) == "nao") | ||
| 447 | + { | ||
| 448 | + $down = "nao"; | ||
| 449 | + } | ||
| 450 | + $texto = array("codigo_tema"=>$t["codigo_tema"],"miniatura"=>$miniatura,"tid"=>$t["codigo_tema"],"nome"=>$this->converte($tema["nome_tema"]),"link"=>$t["link_tema"],"download"=>$down); | ||
| 451 | + $n = intval($t["nacessos"] / $fatorestrela); | ||
| 452 | + if($n >= 5){ | ||
| 453 | + $n = 5; | ||
| 454 | + } | ||
| 455 | + | ||
| 456 | + if ($n == $nivel) | ||
| 457 | + { | ||
| 458 | + $temasRaizGrupo[] = $texto; | ||
| 459 | + } | ||
| 460 | + } | ||
| 461 | + } | ||
| 462 | + foreach($sgrupos["subgrupos"] as $sgrupo) | ||
| 463 | + { | ||
| 464 | + $a = $sgrupo["n2_perfil"]; | ||
| 465 | + $a = str_replace(" ",",",$a); | ||
| 466 | + if($this->verificaOcorrencia($perfil,explode(",",$a))) | ||
| 467 | + { | ||
| 468 | + $temas = $this->pegaTemasSubGrupo($sgrupo["id_n2"]); | ||
| 469 | + foreach ($temas as $tema) | ||
| 470 | + { | ||
| 471 | + $a = $tema["n3_perfil"]; | ||
| 472 | + $a = str_replace(" ",",",$a); | ||
| 473 | + if($this->verificaOcorrencia($perfil,explode(",",$a))) | ||
| 474 | + { | ||
| 475 | + $t = $this->pegaTema($tema["id_tema"]); | ||
| 476 | + $t = $t[0]; | ||
| 477 | + $nome = $this->removeAcentos($tema["nome_tema"]); | ||
| 478 | + $tags = $this->removeAcentos($tema["tags_tema"]); | ||
| 479 | + $tags1 = $this->removeAcentos(mb_convert_encoding($tema["tags_tema"],"ISO-8859-1","UTF-8")); | ||
| 480 | + $nome1 = $this->removeAcentos(mb_convert_encoding($tema["nome_tema"],"ISO-8859-1","UTF-8")); | ||
| 481 | + $miniatura = "nao"; | ||
| 482 | + if(file_exists($this->locaplic."/temas/miniaturas/".$tema["codigo_tema"].".map.mini.png")) | ||
| 483 | + { | ||
| 484 | + $miniatura = "sim"; | ||
| 485 | + } | ||
| 486 | + $down = "sim"; | ||
| 487 | + if (strtolower($t["download_tema"]) == "nao") | ||
| 488 | + { | ||
| 489 | + $down = "nao"; | ||
| 490 | + } | ||
| 491 | + $texto = array("codigo_tema"=>$tema["codigo_tema"],"miniatura"=>$miniatura,"tid"=>$tema["codigo_tema"],"nome"=>$this->converte($tema["nome_tema"]),"link"=>$t["link_tema"],"download"=>$down); | ||
| 492 | + $n = abs($t["nacessos"] / $fatorestrela); | ||
| 493 | + if($n >= 5){ | ||
| 494 | + $n = 5; | ||
| 495 | + } | ||
| 496 | + if ($n == $nivel) | ||
| 497 | + { | ||
| 498 | + $resultado[] = $texto; | ||
| 499 | + } | ||
| 500 | + } | ||
| 501 | + } | ||
| 502 | + } | ||
| 503 | + if (count($resultado) > 0) | ||
| 504 | + { | ||
| 505 | + $subgrupo[] = array("subgrupo"=>$this->converte($sgrupo["nome_subgrupo"]),"temas"=>$resultado); | ||
| 506 | + } | ||
| 507 | + $resultado = array(); | ||
| 508 | + } | ||
| 509 | + } | ||
| 510 | + if (count($subgrupo) > 0 || count($temasRaizGrupo) > 0) | ||
| 511 | + { | ||
| 512 | + $final[] = array("grupo"=>$this->converte($grupo["nome_grupo"]),"temas"=>$temasRaizGrupo,"subgrupos"=>$subgrupo); | ||
| 513 | + } | ||
| 514 | + $subgrupo = array(); | ||
| 515 | + } | ||
| 516 | + } | ||
| 517 | + return $final; | ||
| 518 | + } | ||
| 519 | + /* | ||
| 520 | + Function: pegaGruposMenu | ||
| 521 | + | ||
| 522 | + Retorna a lista de grupos de um menu | ||
| 523 | + | ||
| 524 | + Parametros: | ||
| 525 | + | ||
| 526 | + id_menu {string} | ||
| 527 | + | ||
| 528 | + Return: | ||
| 529 | + | ||
| 530 | + {array} | ||
| 531 | + */ | ||
| 532 | + function pegaGruposMenu($id_menu,$ordenaNome="nao"){ | ||
| 533 | + if($ordenaNome == "sim"){ | ||
| 534 | + $ordem = "nome_grupo"; | ||
| 535 | + } | ||
| 536 | + else{ | ||
| 537 | + $ordem = "ordem"; | ||
| 538 | + } | ||
| 539 | + $sqlgrupos = $this->sql_grupos."where ".$this->pubsql." id_menu='$id_menu' order by $ordem"; | ||
| 540 | + $sqlraiz = $this->sql_temasraiz."where i3geoadmin_raiz.id_menu='$id_menu' and i3geoadmin_raiz.nivel = 0 order by ordem"; | ||
| 541 | + $grupos = $this->execSQL($sqlgrupos); | ||
| 542 | + $raiz = $this->execSQL($sqlraiz); | ||
| 543 | + $raiz = $this->validaTemas($raiz,"codigo_tema"); | ||
| 544 | + return array("raiz"=>$raiz,"grupos"=>$grupos); | ||
| 545 | + } | ||
| 546 | + /* | ||
| 547 | + Function: pegaSubgruposGrupo | ||
| 548 | + | ||
| 549 | + Retorna a lista de subgrupos de um grupo | ||
| 550 | + | ||
| 551 | + Parametros: | ||
| 552 | + | ||
| 553 | + id_menu {string} | ||
| 554 | + | ||
| 555 | + id_n1 {string} - id do grupo | ||
| 556 | + | ||
| 557 | + Return: | ||
| 558 | + | ||
| 559 | + {array} | ||
| 560 | + */ | ||
| 561 | + function pegaSubgruposGrupo($id_menu,$id_n1,$ordenaNome="nao",$filtraOgc="nao",$filtraDown="nao") | ||
| 562 | + { | ||
| 563 | + if($ordenaNome == "sim"){ | ||
| 564 | + $ordem = "nome_subgrupo"; | ||
| 565 | + } | ||
| 566 | + else{ | ||
| 567 | + $ordem = "ordem"; | ||
| 568 | + } | ||
| 569 | + $f = ""; | ||
| 570 | + if($filtraOgc == "sim" || $filtraDown == "sim"){ | ||
| 571 | + $ff = array(); | ||
| 572 | + if($filtraOgc == "sim"){ | ||
| 573 | + $ff[] = " i3geoadmin_temas.ogc_tema = 'SIM' "; | ||
| 574 | + } | ||
| 575 | + if($filtraDown == "sim"){ | ||
| 576 | + $ff[] = " i3geoadmin_temas.download_tema = 'SIM' "; | ||
| 577 | + } | ||
| 578 | + $f = implode(" AND ",$ff) . " AND "; | ||
| 579 | + } | ||
| 580 | + $subgrupos = $this->execSQL($this->sql_subgrupos."where ".$this->pubsql." i3geoadmin_n2.id_n1='$id_n1' order by $ordem"); | ||
| 581 | + $raiz = $this->execSQL($this->sql_temasraiz."where $f i3geoadmin_raiz.nivel = 1 and i3geoadmin_raiz.id_nivel = $id_n1 order by ordem"); | ||
| 582 | + $raiz = $this->validaTemas($raiz,"codigo_tema"); | ||
| 583 | + return array("raiz"=>$raiz,"subgrupos"=>$subgrupos); | ||
| 584 | + } | ||
| 585 | + /* | ||
| 586 | + Function: pegaTemasRaizMenu | ||
| 587 | + | ||
| 588 | + Retorna a lista de temas da raiz de um menu | ||
| 589 | + | ||
| 590 | + Parametros: | ||
| 591 | + | ||
| 592 | + id_menu {string} | ||
| 593 | + | ||
| 594 | + Return: | ||
| 595 | + | ||
| 596 | + {array} | ||
| 597 | + */ | ||
| 598 | + function pegaTemasRaizMenu($id_menu) | ||
| 599 | + { | ||
| 600 | + $raiz = $this->execSQL($this->sql_temasraiz."where i3geoadmin_raiz.id_menu='$id_menu' and i3geoadmin_raiz.nivel = 0 order by ordem"); | ||
| 601 | + $raiz = $this->validaTemas($raiz,"codigo_tema"); | ||
| 602 | + return $raiz; | ||
| 603 | + } | ||
| 604 | + /* | ||
| 605 | + Function: pegaTemasRaizGrupo | ||
| 606 | + | ||
| 607 | + Retorna a lista de temas da raiz de um grupo | ||
| 608 | + | ||
| 609 | + Parametros: | ||
| 610 | + | ||
| 611 | + id_menu {string} | ||
| 612 | + | ||
| 613 | + id_n1 {string} - id do grupo | ||
| 614 | + | ||
| 615 | + Return: | ||
| 616 | + | ||
| 617 | + {array} | ||
| 618 | + */ | ||
| 619 | + function pegaTemasRaizGrupo($id_menu,$id_n1,$filtraOgc="nao",$filtraDown="nao") | ||
| 620 | + { | ||
| 621 | + $f = ""; | ||
| 622 | + if($filtraOgc == "sim" || $filtraDown == "sim"){ | ||
| 623 | + $ff = array(); | ||
| 624 | + if($filtraOgc == "sim"){ | ||
| 625 | + $ff[] = " i3geoadmin_temas.ogc_tema = 'SIM' "; | ||
| 626 | + } | ||
| 627 | + if($filtraDown == "sim"){ | ||
| 628 | + $ff[] = " i3geoadmin_temas.download_tema = 'SIM' "; | ||
| 629 | + } | ||
| 630 | + $f = implode(" AND ",$ff) . " AND "; | ||
| 631 | + } | ||
| 632 | + if($id_n1 == ""){ | ||
| 633 | + $raiz = $this->execSQL($this->sql_temasraiz."where $f i3geoadmin_raiz.nivel = 1 and i3geoadmin_raiz.id_nivel > 0 order by ordem"); | ||
| 634 | + } | ||
| 635 | + else { | ||
| 636 | + $raiz = $this->execSQL($this->sql_temasraiz."where $f i3geoadmin_raiz.nivel = 1 and i3geoadmin_raiz.id_nivel = $id_n1 order by ordem"); | ||
| 637 | + } | ||
| 638 | + $raiz = $this->validaTemas($raiz,"codigo_tema"); | ||
| 639 | + return $raiz; | ||
| 640 | + } | ||
| 641 | + /* | ||
| 642 | + Function: pegaTodosTemas | ||
| 643 | + | ||
| 644 | + Retorna os dados de todos os temas | ||
| 645 | + | ||
| 646 | + Return: | ||
| 647 | + | ||
| 648 | + {array} | ||
| 649 | + */ | ||
| 650 | + function pegaTodosTemas($combo=false) | ||
| 651 | + { | ||
| 652 | + if($combo == true){ | ||
| 653 | + $q = $this->execSQL($this->sql_temas_combo." ORDER BY nome_tema ASC"); | ||
| 654 | + } | ||
| 655 | + else{ | ||
| 656 | + $q = $this->execSQL($this->sql_temas." ORDER BY nome_tema ASC"); | ||
| 657 | + } | ||
| 658 | + if($q){ | ||
| 659 | + $q = $this->validaTemas($q,"codigo_tema"); | ||
| 660 | + return $q; | ||
| 661 | + } | ||
| 662 | + } | ||
| 663 | + /* | ||
| 664 | + Function: pegaTema | ||
| 665 | + | ||
| 666 | + Retorna os dados de um tema | ||
| 667 | + | ||
| 668 | + Parametros: | ||
| 669 | + | ||
| 670 | + id_tema {string} | ||
| 671 | + | ||
| 672 | + Return: | ||
| 673 | + | ||
| 674 | + {array} | ||
| 675 | + */ | ||
| 676 | + function pegaTema($id_tema) | ||
| 677 | + { | ||
| 678 | + $q = $this->execSQL($this->sql_temas." and id_tema = '$id_tema' "); | ||
| 679 | + if($q){ | ||
| 680 | + return $q; | ||
| 681 | + } | ||
| 682 | + else{ | ||
| 683 | + //caso de banco de dados antigo | ||
| 684 | + $sql = "select kmz_tema,'0' as nacessos,id_tema,kml_tema,ogc_tema,download_tema,tags_tema,tipoa_tema,link_tema,desc_tema,nome_tema,codigo_tema from ".$this->esquemaadmin."i3geoadmin_temas "; | ||
| 685 | + $q = $this->execSQL($sql." where id_tema = '$id_tema' "); | ||
| 686 | + return $q; | ||
| 687 | + } | ||
| 688 | + } | ||
| 689 | + /* | ||
| 690 | + Function: pegaTemaPorCodigo | ||
| 691 | + | ||
| 692 | + Retorna os dados de um tema buscando por codigo | ||
| 693 | + | ||
| 694 | + Parametros: | ||
| 695 | + | ||
| 696 | + codigo_tema {string} | ||
| 697 | + | ||
| 698 | + Return: | ||
| 699 | + | ||
| 700 | + {array} | ||
| 701 | + */ | ||
| 702 | + function pegaTemaPorCodigo($codigo_tema) | ||
| 703 | + { | ||
| 704 | + $q = $this->execSQL($this->sql_temas." and codigo_tema = '$codigo_tema' "); | ||
| 705 | + if($q){ | ||
| 706 | + return $q; | ||
| 707 | + } | ||
| 708 | + else{ | ||
| 709 | + //caso de banco de dados antigo | ||
| 710 | + $sql = "select kmz_tema,'0' as nacessos,id_tema,kml_tema,ogc_tema,download_tema,tags_tema,tipoa_tema,link_tema,desc_tema,nome_tema,codigo_tema from ".$this->esquemaadmin."i3geoadmin_temas "; | ||
| 711 | + $q = $this->execSQL($sql." where codigo_tema = '$codigo_tema' "); | ||
| 712 | + return $q; | ||
| 713 | + } | ||
| 714 | + } | ||
| 715 | + /* | ||
| 716 | + Function: pegaTemasSubGrupo | ||
| 717 | + | ||
| 718 | + Retorna os temas de um subgrupo | ||
| 719 | + | ||
| 720 | + Parametros: | ||
| 721 | + | ||
| 722 | + id_n2 {string} - id do subgrupo | ||
| 723 | + | ||
| 724 | + Return: | ||
| 725 | + | ||
| 726 | + {array} | ||
| 727 | + */ | ||
| 728 | + function pegaTemasSubGrupo($id_n2,$filtraOgc="nao",$filtraDown="nao") | ||
| 729 | + { | ||
| 730 | + $f = ""; | ||
| 731 | + if($filtraOgc == "sim" || $filtraDown == "sim"){ | ||
| 732 | + $ff = array(); | ||
| 733 | + if($filtraOgc == "sim"){ | ||
| 734 | + $ff[] = " i3geoadmin_temas.ogc_tema = 'SIM' "; | ||
| 735 | + } | ||
| 736 | + if($filtraDown == "sim"){ | ||
| 737 | + $ff[] = " i3geoadmin_temas.download_tema = 'SIM' "; | ||
| 738 | + } | ||
| 739 | + $f = implode(" AND ",$ff) . " AND "; | ||
| 740 | + } | ||
| 741 | + $temas = $this->execSQL($this->sql_temasSubgrupo."where $f ".$this->pubsql." i3geoadmin_n3.id_n2='$id_n2' order by ordem"); | ||
| 742 | + $temas = $this->validaTemas($temas,"codigo_tema"); | ||
| 743 | + return $temas; | ||
| 744 | + } | ||
| 745 | + /* | ||
| 746 | + Function: formataMenus | ||
| 747 | + | ||
| 748 | + Retorna os menus e temas na raiz de um menu, formatados no padrão da árvore | ||
| 749 | + | ||
| 750 | + Return: | ||
| 751 | + | ||
| 752 | + {array} | ||
| 753 | + */ | ||
| 754 | + function formataMenus(){ | ||
| 755 | + } | ||
| 756 | + /* | ||
| 757 | + Function: formataGruposMenu | ||
| 758 | + | ||
| 759 | + Retorna os grupos e temas na raiz de um menu, formatados no padrão da árvore | ||
| 760 | + | ||
| 761 | + Parametros: | ||
| 762 | + | ||
| 763 | + id_menu {string} | ||
| 764 | + | ||
| 765 | + perfil {string} | ||
| 766 | + | ||
| 767 | + listasgrupos {string} - sim|nao | ||
| 768 | + | ||
| 769 | + Return: | ||
| 770 | + | ||
| 771 | + {array} | ||
| 772 | + */ | ||
| 773 | + function formataGruposMenu ($id_menu,$perfil,$listasgrupos,$ordenaNome="nao",$filtraOgc="nao",$filtraDown="nao") | ||
| 774 | + { | ||
| 775 | + //error_reporting(0); | ||
| 776 | + $dados = $this->pegaGruposMenu($id_menu,$ordenaNome); | ||
| 777 | + $resultado = array(); | ||
| 778 | + $temasraiz = array(); | ||
| 779 | + foreach($dados["raiz"] as $temar){ | ||
| 780 | + $temasraiz[] = $this->formataTema($temar["id_tema"]); | ||
| 781 | + } | ||
| 782 | + if(count($dados["grupos"]) == 0){ | ||
| 783 | + $grupos[] = array(); | ||
| 784 | + } | ||
| 785 | + $raizgrupos = $this->pegaTemasRaizGrupo($id_menu,"",$filtraOgc,$filtraDown); | ||
| 786 | + //var_dump($raizgrupos);exit; | ||
| 787 | + foreach($dados["grupos"] as $grupo) { | ||
| 788 | + $a = $grupo["n1_perfil"]; | ||
| 789 | + $a = str_replace(" ",",",$a); | ||
| 790 | + if($this->verificaOcorrencia($perfil,explode(",",$a)) == true) | ||
| 791 | + { | ||
| 792 | + $temas = array(); | ||
| 793 | + //$raizgrupo = $this->pegaTemasRaizGrupo($id_menu,$grupo["id_n1"],$filtraOgc,$filtraDown); | ||
| 794 | + $grupodown = "nao"; | ||
| 795 | + $grupoogc = "nao"; | ||
| 796 | + foreach($raizgrupos as $tema){ | ||
| 797 | + if($tema["id_nivel"] == $grupo["id_n1"]){ | ||
| 798 | + $temas[] = $this->formataTema($tema["id_tema"]); | ||
| 799 | + } | ||
| 800 | + } | ||
| 801 | + if($temas > 0){ | ||
| 802 | + $grupodown = "sim"; | ||
| 803 | + $grupoogc = "sim"; | ||
| 804 | + } | ||
| 805 | + $subgrupos = array(); | ||
| 806 | + if($listasgrupos=="sim"){ | ||
| 807 | + $dadossubgrupos = $this->pegaSubgruposGrupo($id_menu,$grupo["id_n1"],$ordenaNome,$filtraOgc,$filtraDown); | ||
| 808 | + foreach($dadossubgrupos["subgrupos"] as $sgrupo){ | ||
| 809 | + $a = $sgrupo["n2_perfil"]; | ||
| 810 | + $a = str_replace(" ",",",$a); | ||
| 811 | + if($this->verificaOcorrencia($perfil,explode(",",$a))){ | ||
| 812 | + //verifica se existem temas que podem receber download | ||
| 813 | + $down = "nao"; | ||
| 814 | + $ogc = "nao"; | ||
| 815 | + $listaT = $this->pegaTemasSubGrupo($sgrupo["id_n2"],$filtraOgc,$filtraDown); | ||
| 816 | + foreach($listaT as $tema){ | ||
| 817 | + if(strtolower($tema["tipoa_tema"]) != "wms") | ||
| 818 | + { | ||
| 819 | + if (strtolower($tema["download_tema"]) != "nao") | ||
| 820 | + { | ||
| 821 | + $down = "sim";$grupodown = "sim"; | ||
| 822 | + } | ||
| 823 | + | ||
| 824 | + if (strtolower($tema["ogc_tema"]) != "nao") | ||
| 825 | + { | ||
| 826 | + $ogc = "sim";$grupoogc = "sim"; | ||
| 827 | + } | ||
| 828 | + } | ||
| 829 | + } | ||
| 830 | + if(count($listaT) > 0){ | ||
| 831 | + $subgrupos[] = array("id_n2"=>$sgrupo["id_n2"],"publicado"=>($sgrupo["publicado"]),"nome"=>$this->converte($sgrupo["nome_subgrupo"]),"download"=>$down,"ogc"=>$ogc); | ||
| 832 | + } | ||
| 833 | + } | ||
| 834 | + } | ||
| 835 | + } | ||
| 836 | + //evita ocorrencias vazias quando for aplicado um filtro | ||
| 837 | + if($filtraOgc == "sim" || $filtraDown == "sim"){ | ||
| 838 | + if(count($subgrupos) > 0 || count($temas) > 0){ | ||
| 839 | + $grupos[] = array("publicado"=>($grupo["publicado"]),"id_n1"=>($grupo["id_n1"]),"nome"=>$this->converte($grupo["nome_grupo"]),"ogc"=>$grupoogc,"download"=>$grupodown,"subgrupos"=>$subgrupos,"temasgrupo"=>$temas); | ||
| 840 | + } | ||
| 841 | + } | ||
| 842 | + else{ | ||
| 843 | + $grupos[] = array("publicado"=>($grupo["publicado"]),"id_n1"=>($grupo["id_n1"]),"nome"=>$this->converte($grupo["nome_grupo"]),"ogc"=>$grupoogc,"download"=>$grupodown,"subgrupos"=>$subgrupos,"temasgrupo"=>$temas); | ||
| 844 | + } | ||
| 845 | + } | ||
| 846 | + } | ||
| 847 | + $grupos[] = array("temasraiz"=>$temasraiz); | ||
| 848 | + //pega os sistemas checando os perfis | ||
| 849 | + $sistemas = array(); | ||
| 850 | + $grupos[] = array("idmenu"=>$id_menu); | ||
| 851 | + $grupos[] = array("sistemas"=>""); | ||
| 852 | + return($grupos); | ||
| 853 | + } | ||
| 854 | + /* | ||
| 855 | + Function: formataSubgruposGrupo | ||
| 856 | + | ||
| 857 | + Retorna os subgrupos e temas na raiz de um grupo, formatados no padrão da árvore | ||
| 858 | + | ||
| 859 | + Parametros: | ||
| 860 | + | ||
| 861 | + id_menu {string} | ||
| 862 | + | ||
| 863 | + id_n1 {string} - id do grupo | ||
| 864 | + | ||
| 865 | + perfil {string} | ||
| 866 | + | ||
| 867 | + Return: | ||
| 868 | + | ||
| 869 | + {array} | ||
| 870 | + */ | ||
| 871 | + function formataSubgruposGrupo ($id_menu,$id_n1,$perfil) | ||
| 872 | + { | ||
| 873 | + $dados = $this->pegaSubgruposGrupo($id_menu,$id_n1); | ||
| 874 | + $resultado = array(); | ||
| 875 | + $temasraiz = array(); | ||
| 876 | + foreach($dados["raiz"] as $temar) | ||
| 877 | + { | ||
| 878 | + $temasraiz[] = $this->formataTema($temar["id_tema"]); | ||
| 879 | + } | ||
| 880 | + if(count($dados["subgrupos"]) == 0) | ||
| 881 | + { | ||
| 882 | + $sgrupos[] = array(); | ||
| 883 | + } | ||
| 884 | + $subgrupos = array(); | ||
| 885 | + foreach($dados["subgrupos"] as $sgrupo) | ||
| 886 | + { | ||
| 887 | + $a = $sgrupo["n2_perfil"]; | ||
| 888 | + $a = str_replace(" ",",",$a); | ||
| 889 | + if ($this->verificaOcorrencia($perfil,explode(",",$a))) | ||
| 890 | + { | ||
| 891 | + $listaT = $this->pegaTemasSubGrupo($sgrupo["id_n2"]); | ||
| 892 | + $down = "nao"; | ||
| 893 | + $ogc = "nao"; | ||
| 894 | + foreach($listaT as $tema) | ||
| 895 | + { | ||
| 896 | + if(strtolower($tema["tipoa_tema"]) != "wms") | ||
| 897 | + { | ||
| 898 | + if (strtolower($tema["download_tema"]) != "nao") | ||
| 899 | + { | ||
| 900 | + $down = "sim"; | ||
| 901 | + } | ||
| 902 | + if (strtolower($tema["ogc_tema"]) != "nao") | ||
| 903 | + { | ||
| 904 | + $ogc = "sim"; | ||
| 905 | + } | ||
| 906 | + } | ||
| 907 | + } | ||
| 908 | + if(count($listaT) > 0) | ||
| 909 | + { | ||
| 910 | + $subgrupos[] = array("publicado"=>($sgrupo["publicado"]),"id_n2"=>($sgrupo["id_n2"]),"nome"=>$this->converte($sgrupo["nome_subgrupo"]),"download"=>$down,"ogc"=>$ogc,"temas"=>$listaT); | ||
| 911 | + } | ||
| 912 | + } | ||
| 913 | + } | ||
| 914 | + return (array("subgrupo"=>$subgrupos,"temasgrupo"=>$temasraiz)); | ||
| 915 | + } | ||
| 916 | + /* | ||
| 917 | + Function: formataTemasSubgrupo | ||
| 918 | + | ||
| 919 | + Retorna os temas de um subgrupo, formatados no padrão da árvore | ||
| 920 | + | ||
| 921 | + Parametros: | ||
| 922 | + | ||
| 923 | + id_n2 {string} - id do subgrupo | ||
| 924 | + | ||
| 925 | + perfil {string} | ||
| 926 | + | ||
| 927 | + Return: | ||
| 928 | + | ||
| 929 | + {array} | ||
| 930 | + */ | ||
| 931 | + function formataTemasSubgrupo($id_n2,$perfil) | ||
| 932 | + { | ||
| 933 | + $dados = $this->pegaTemasSubGrupo($id_n2); | ||
| 934 | + $temas = array(); | ||
| 935 | + foreach($dados as $tema) | ||
| 936 | + { | ||
| 937 | + $a = $tema["n3_perfil"]; | ||
| 938 | + $a = str_replace(" ",",",$a); | ||
| 939 | + if($this->verificaOcorrencia($perfil,explode(",",$a))) | ||
| 940 | + { | ||
| 941 | + $temas[] = $this->formataTema($tema["id_tema"],$tema["publicado"]); | ||
| 942 | + } | ||
| 943 | + } | ||
| 944 | + return $temas; | ||
| 945 | + } | ||
| 946 | + /* | ||
| 947 | + Function: formataTema | ||
| 948 | + | ||
| 949 | + Retorna os dados de um tema, formatados no padrão da árvore | ||
| 950 | + | ||
| 951 | + Parametros: | ||
| 952 | + | ||
| 953 | + id_tema {string} | ||
| 954 | + | ||
| 955 | + publicado {string} - SIM|NAO valor do índice "publicado" que será incluído no array de retorno | ||
| 956 | + | ||
| 957 | + Return: | ||
| 958 | + | ||
| 959 | + {array} | ||
| 960 | + */ | ||
| 961 | + function formataTema($id_tema,$publicado="SIM") | ||
| 962 | + { | ||
| 963 | + $recordset = $this->pegaTema($id_tema); | ||
| 964 | + $recordset = $recordset[0]; | ||
| 965 | + $down = "sim"; | ||
| 966 | + $ogc = "sim"; | ||
| 967 | + $link = " "; | ||
| 968 | + $kmz = "nao"; | ||
| 969 | + if (strtolower($recordset["download_tema"]) == "nao") | ||
| 970 | + { | ||
| 971 | + $down = "nao"; | ||
| 972 | + } | ||
| 973 | + if (strtolower($recordset["ogc_tema"]) == "nao") | ||
| 974 | + { | ||
| 975 | + $ogc = "nao"; | ||
| 976 | + } | ||
| 977 | + if(strtolower($recordset["tipoa_tema"]) == "wms") | ||
| 978 | + { | ||
| 979 | + $down = "nao"; | ||
| 980 | + $ogc = "nao"; | ||
| 981 | + } | ||
| 982 | + if ($recordset["link_tema"] != "") | ||
| 983 | + { | ||
| 984 | + $link = $recordset["link_tema"]; | ||
| 985 | + } | ||
| 986 | + if (strtolower($recordset["kmz_tema"]) == "sim") | ||
| 987 | + { | ||
| 988 | + $kmz = "sim"; | ||
| 989 | + } | ||
| 990 | + //codigo_tema para fins de compatibilidade | ||
| 991 | + return array("codigo_tema"=>($recordset["codigo_tema"]),"tipoa_tema"=>$recordset["tipoa_tema"],"publicado"=>$publicado,"nacessos"=>($recordset["nacessos"]),"tid"=>($recordset["codigo_tema"]),"nome"=>$this->converte($recordset["nome_tema"]),"link"=>$link,"download"=>$down,"ogc"=>$ogc,"kmz"=>$kmz); | ||
| 992 | + } | ||
| 993 | + /* | ||
| 994 | + Function: execSQL | ||
| 995 | + | ||
| 996 | + Executa um SQL no banco de administração | ||
| 997 | + | ||
| 998 | + Parametros: | ||
| 999 | + | ||
| 1000 | + sql {string} | ||
| 1001 | + | ||
| 1002 | + Return: | ||
| 1003 | + | ||
| 1004 | + {array} | ||
| 1005 | + */ | ||
| 1006 | + function execSQL($sql) | ||
| 1007 | + { | ||
| 1008 | + //echo "<br>".$sql; | ||
| 1009 | + //error_reporting(0); | ||
| 1010 | + $sql = str_ireplace(array("update","delete","insert","--","drop",";"),"",$sql); | ||
| 1011 | + $q = $this->dbh->query($sql,PDO::FETCH_ASSOC); | ||
| 1012 | + if($q) | ||
| 1013 | + { | ||
| 1014 | + return $q->fetchAll(); | ||
| 1015 | + } | ||
| 1016 | + else | ||
| 1017 | + {return false; | ||
| 1018 | + } | ||
| 1019 | + } | ||
| 1020 | + /* | ||
| 1021 | + Verifica se uma string ocorre em um array | ||
| 1022 | + */ | ||
| 1023 | + function verificaOcorrencia($procurar,$em) | ||
| 1024 | + { | ||
| 1025 | + if(count($em) == 1 && $em[0] == "") | ||
| 1026 | + { | ||
| 1027 | + $em = ""; | ||
| 1028 | + } | ||
| 1029 | + if($procurar == "" && $em == "") | ||
| 1030 | + { | ||
| 1031 | + return true; | ||
| 1032 | + } | ||
| 1033 | + if($em == "") | ||
| 1034 | + { | ||
| 1035 | + return true; | ||
| 1036 | + } | ||
| 1037 | + $resultado = false; | ||
| 1038 | + if($procurar != "" && $em != "") | ||
| 1039 | + { | ||
| 1040 | + foreach($em as $e) | ||
| 1041 | + { | ||
| 1042 | + $e = trim($e); | ||
| 1043 | + foreach($procurar as $p) | ||
| 1044 | + { | ||
| 1045 | + $p = trim($p); | ||
| 1046 | + if($p == $e) | ||
| 1047 | + { | ||
| 1048 | + $resultado = true; | ||
| 1049 | + } | ||
| 1050 | + } | ||
| 1051 | + } | ||
| 1052 | + } | ||
| 1053 | + return $resultado; | ||
| 1054 | + } | ||
| 1055 | + function seems_utf8($Str) { # by bmorel at ssi dot fr | ||
| 1056 | + $length = strlen($Str); | ||
| 1057 | + for ($i = 0; $i < $length; $i++) { | ||
| 1058 | + if (ord($Str[$i]) < 0x80) continue; # 0bbbbbbb | ||
| 1059 | + elseif ((ord($Str[$i]) & 0xE0) == 0xC0) $n = 1; # 110bbbbb | ||
| 1060 | + elseif ((ord($Str[$i]) & 0xF0) == 0xE0) $n = 2; # 1110bbbb | ||
| 1061 | + elseif ((ord($Str[$i]) & 0xF8) == 0xF0) $n = 3; # 11110bbb | ||
| 1062 | + elseif ((ord($Str[$i]) & 0xFC) == 0xF8) $n = 4; # 111110bb | ||
| 1063 | + elseif ((ord($Str[$i]) & 0xFE) == 0xFC) $n = 5; # 1111110b | ||
| 1064 | + else return false; # Does not match any model | ||
| 1065 | + for ($j = 0; $j < $n; $j++) { # n bytes matching 10bbbbbb follow ? | ||
| 1066 | + if ((++$i == $length) || ((ord($Str[$i]) & 0xC0) != 0x80)) | ||
| 1067 | + return false; | ||
| 1068 | + } | ||
| 1069 | + } | ||
| 1070 | + return true; | ||
| 1071 | + } | ||
| 1072 | + /** | ||
| 1073 | + * | ||
| 1074 | + * TODO Verificar ao fechar versao - verificar a acentuacao das palavras nessa funcao | ||
| 1075 | + */ | ||
| 1076 | + function removeAcentos($s) | ||
| 1077 | + { | ||
| 1078 | + $s = ereg_replace("[áàâã]","a",$s); | ||
| 1079 | + $s = ereg_replace("[ÁÀÂÃ]","A",$s); | ||
| 1080 | + $s = ereg_replace("[éèê]","e",$s); | ||
| 1081 | + $s = ereg_replace("[í]","i",$s); | ||
| 1082 | + $s = ereg_replace("[Í]","I",$s); | ||
| 1083 | + $s = ereg_replace("[ÉÈÊ]","E",$s); | ||
| 1084 | + $s = ereg_replace("[óòôõ]","o",$s); | ||
| 1085 | + $s = ereg_replace("[ÓÒÔÕ]","O",$s); | ||
| 1086 | + $s = ereg_replace("[úùû]","u",$s); | ||
| 1087 | + $s = ereg_replace("[ÚÙÛ]","U",$s); | ||
| 1088 | + $s = str_replace("ç","c",$s); | ||
| 1089 | + $s = str_replace("Ç","C",$s); | ||
| 1090 | + //$str = htmlentities($s); | ||
| 1091 | + $str = preg_replace("/(&)([a-z])([a-z]+;)/i", '$2', $s); | ||
| 1092 | + $str = preg_replace("/[^A-Z0-9]/i", ' ', $str); | ||
| 1093 | + $string = preg_replace("/\s+/i", ' ', $str); | ||
| 1094 | + | ||
| 1095 | + if (!preg_match('/[\x80-\xff]/', $string)){ | ||
| 1096 | + return $string; | ||
| 1097 | + } | ||
| 1098 | + if ($this->seems_utf8($string)) { | ||
| 1099 | + $chars = array( | ||
| 1100 | + // Decompositions for Latin-1 Supplement | ||
| 1101 | + chr(195).chr(128) => 'A', chr(195).chr(129) => 'A', | ||
| 1102 | + chr(195).chr(130) => 'A', chr(195).chr(131) => 'A', | ||
| 1103 | + chr(195).chr(132) => 'A', chr(195).chr(133) => 'A', | ||
| 1104 | + chr(195).chr(135) => 'C', chr(195).chr(136) => 'E', | ||
| 1105 | + chr(195).chr(137) => 'E', chr(195).chr(138) => 'E', | ||
| 1106 | + chr(195).chr(139) => 'E', chr(195).chr(140) => 'I', | ||
| 1107 | + chr(195).chr(141) => 'I', chr(195).chr(142) => 'I', | ||
| 1108 | + chr(195).chr(143) => 'I', chr(195).chr(145) => 'N', | ||
| 1109 | + chr(195).chr(146) => 'O', chr(195).chr(147) => 'O', | ||
| 1110 | + chr(195).chr(148) => 'O', chr(195).chr(149) => 'O', | ||
| 1111 | + chr(195).chr(150) => 'O', chr(195).chr(153) => 'U', | ||
| 1112 | + chr(195).chr(154) => 'U', chr(195).chr(155) => 'U', | ||
| 1113 | + chr(195).chr(156) => 'U', chr(195).chr(157) => 'Y', | ||
| 1114 | + chr(195).chr(159) => 's', chr(195).chr(160) => 'a', | ||
| 1115 | + chr(195).chr(161) => 'a', chr(195).chr(162) => 'a', | ||
| 1116 | + chr(195).chr(163) => 'a', chr(195).chr(164) => 'a', | ||
| 1117 | + chr(195).chr(165) => 'a', chr(195).chr(167) => 'c', | ||
| 1118 | + chr(195).chr(168) => 'e', chr(195).chr(169) => 'e', | ||
| 1119 | + chr(195).chr(170) => 'e', chr(195).chr(171) => 'e', | ||
| 1120 | + chr(195).chr(172) => 'i', chr(195).chr(173) => 'i', | ||
| 1121 | + chr(195).chr(174) => 'i', chr(195).chr(175) => 'i', | ||
| 1122 | + chr(195).chr(177) => 'n', chr(195).chr(178) => 'o', | ||
| 1123 | + chr(195).chr(179) => 'o', chr(195).chr(180) => 'o', | ||
| 1124 | + chr(195).chr(181) => 'o', chr(195).chr(182) => 'o', | ||
| 1125 | + chr(195).chr(182) => 'o', chr(195).chr(185) => 'u', | ||
| 1126 | + chr(195).chr(186) => 'u', chr(195).chr(187) => 'u', | ||
| 1127 | + chr(195).chr(188) => 'u', chr(195).chr(189) => 'y', | ||
| 1128 | + chr(195).chr(191) => 'y', | ||
| 1129 | + // Decompositions for Latin Extended-A | ||
| 1130 | + chr(196).chr(128) => 'A', chr(196).chr(129) => 'a', | ||
| 1131 | + chr(196).chr(130) => 'A', chr(196).chr(131) => 'a', | ||
| 1132 | + chr(196).chr(132) => 'A', chr(196).chr(133) => 'a', | ||
| 1133 | + chr(196).chr(134) => 'C', chr(196).chr(135) => 'c', | ||
| 1134 | + chr(196).chr(136) => 'C', chr(196).chr(137) => 'c', | ||
| 1135 | + chr(196).chr(138) => 'C', chr(196).chr(139) => 'c', | ||
| 1136 | + chr(196).chr(140) => 'C', chr(196).chr(141) => 'c', | ||
| 1137 | + chr(196).chr(142) => 'D', chr(196).chr(143) => 'd', | ||
| 1138 | + chr(196).chr(144) => 'D', chr(196).chr(145) => 'd', | ||
| 1139 | + chr(196).chr(146) => 'E', chr(196).chr(147) => 'e', | ||
| 1140 | + chr(196).chr(148) => 'E', chr(196).chr(149) => 'e', | ||
| 1141 | + chr(196).chr(150) => 'E', chr(196).chr(151) => 'e', | ||
| 1142 | + chr(196).chr(152) => 'E', chr(196).chr(153) => 'e', | ||
| 1143 | + chr(196).chr(154) => 'E', chr(196).chr(155) => 'e', | ||
| 1144 | + chr(196).chr(156) => 'G', chr(196).chr(157) => 'g', | ||
| 1145 | + chr(196).chr(158) => 'G', chr(196).chr(159) => 'g', | ||
| 1146 | + chr(196).chr(160) => 'G', chr(196).chr(161) => 'g', | ||
| 1147 | + chr(196).chr(162) => 'G', chr(196).chr(163) => 'g', | ||
| 1148 | + chr(196).chr(164) => 'H', chr(196).chr(165) => 'h', | ||
| 1149 | + chr(196).chr(166) => 'H', chr(196).chr(167) => 'h', | ||
| 1150 | + chr(196).chr(168) => 'I', chr(196).chr(169) => 'i', | ||
| 1151 | + chr(196).chr(170) => 'I', chr(196).chr(171) => 'i', | ||
| 1152 | + chr(196).chr(172) => 'I', chr(196).chr(173) => 'i', | ||
| 1153 | + chr(196).chr(174) => 'I', chr(196).chr(175) => 'i', | ||
| 1154 | + chr(196).chr(176) => 'I', chr(196).chr(177) => 'i', | ||
| 1155 | + chr(196).chr(178) => 'IJ',chr(196).chr(179) => 'ij', | ||
| 1156 | + chr(196).chr(180) => 'J', chr(196).chr(181) => 'j', | ||
| 1157 | + chr(196).chr(182) => 'K', chr(196).chr(183) => 'k', | ||
| 1158 | + chr(196).chr(184) => 'k', chr(196).chr(185) => 'L', | ||
| 1159 | + chr(196).chr(186) => 'l', chr(196).chr(187) => 'L', | ||
| 1160 | + chr(196).chr(188) => 'l', chr(196).chr(189) => 'L', | ||
| 1161 | + chr(196).chr(190) => 'l', chr(196).chr(191) => 'L', | ||
| 1162 | + chr(197).chr(128) => 'l', chr(197).chr(129) => 'L', | ||
| 1163 | + chr(197).chr(130) => 'l', chr(197).chr(131) => 'N', | ||
| 1164 | + chr(197).chr(132) => 'n', chr(197).chr(133) => 'N', | ||
| 1165 | + chr(197).chr(134) => 'n', chr(197).chr(135) => 'N', | ||
| 1166 | + chr(197).chr(136) => 'n', chr(197).chr(137) => 'N', | ||
| 1167 | + chr(197).chr(138) => 'n', chr(197).chr(139) => 'N', | ||
| 1168 | + chr(197).chr(140) => 'O', chr(197).chr(141) => 'o', | ||
| 1169 | + chr(197).chr(142) => 'O', chr(197).chr(143) => 'o', | ||
| 1170 | + chr(197).chr(144) => 'O', chr(197).chr(145) => 'o', | ||
| 1171 | + chr(197).chr(146) => 'OE',chr(197).chr(147) => 'oe', | ||
| 1172 | + chr(197).chr(148) => 'R',chr(197).chr(149) => 'r', | ||
| 1173 | + chr(197).chr(150) => 'R',chr(197).chr(151) => 'r', | ||
| 1174 | + chr(197).chr(152) => 'R',chr(197).chr(153) => 'r', | ||
| 1175 | + chr(197).chr(154) => 'S',chr(197).chr(155) => 's', | ||
| 1176 | + chr(197).chr(156) => 'S',chr(197).chr(157) => 's', | ||
| 1177 | + chr(197).chr(158) => 'S',chr(197).chr(159) => 's', | ||
| 1178 | + chr(197).chr(160) => 'S', chr(197).chr(161) => 's', | ||
| 1179 | + chr(197).chr(162) => 'T', chr(197).chr(163) => 't', | ||
| 1180 | + chr(197).chr(164) => 'T', chr(197).chr(165) => 't', | ||
| 1181 | + chr(197).chr(166) => 'T', chr(197).chr(167) => 't', | ||
| 1182 | + chr(197).chr(168) => 'U', chr(197).chr(169) => 'u', | ||
| 1183 | + chr(197).chr(170) => 'U', chr(197).chr(171) => 'u', | ||
| 1184 | + chr(197).chr(172) => 'U', chr(197).chr(173) => 'u', | ||
| 1185 | + chr(197).chr(174) => 'U', chr(197).chr(175) => 'u', | ||
| 1186 | + chr(197).chr(176) => 'U', chr(197).chr(177) => 'u', | ||
| 1187 | + chr(197).chr(178) => 'U', chr(197).chr(179) => 'u', | ||
| 1188 | + chr(197).chr(180) => 'W', chr(197).chr(181) => 'w', | ||
| 1189 | + chr(197).chr(182) => 'Y', chr(197).chr(183) => 'y', | ||
| 1190 | + chr(197).chr(184) => 'Y', chr(197).chr(185) => 'Z', | ||
| 1191 | + chr(197).chr(186) => 'z', chr(197).chr(187) => 'Z', | ||
| 1192 | + chr(197).chr(188) => 'z', chr(197).chr(189) => 'Z', | ||
| 1193 | + chr(197).chr(190) => 'z', chr(197).chr(191) => 's', | ||
| 1194 | + // Euro Sign | ||
| 1195 | + chr(226).chr(130).chr(172) => 'E', | ||
| 1196 | + // GBP (Pound) Sign | ||
| 1197 | + chr(194).chr(163) => ''); | ||
| 1198 | + $string = strtr($string, $chars); | ||
| 1199 | + } else { | ||
| 1200 | + // Assume ISO-8859-1 if not UTF-8 | ||
| 1201 | + $chars['in'] = chr(128).chr(131).chr(138).chr(142).chr(154).chr(158) | ||
| 1202 | + .chr(159).chr(162).chr(165).chr(181).chr(192).chr(193).chr(194) | ||
| 1203 | + .chr(195).chr(196).chr(197).chr(199).chr(200).chr(201).chr(202) | ||
| 1204 | + .chr(203).chr(204).chr(205).chr(206).chr(207).chr(209).chr(210) | ||
| 1205 | + .chr(211).chr(212).chr(213).chr(214).chr(216).chr(217).chr(218) | ||
| 1206 | + .chr(219).chr(220).chr(221).chr(224).chr(225).chr(226).chr(227) | ||
| 1207 | + .chr(228).chr(229).chr(231).chr(232).chr(233).chr(234).chr(235) | ||
| 1208 | + .chr(236).chr(237).chr(238).chr(239).chr(241).chr(242).chr(243) | ||
| 1209 | + .chr(244).chr(245).chr(246).chr(248).chr(249).chr(250).chr(251) | ||
| 1210 | + .chr(252).chr(253).chr(255); | ||
| 1211 | + $chars['out'] = "EfSZszYcYuAAAAAACEEEEIIIINOOOOOOUUUUYaaaaaaceeeeiiiinoooooouuuuyy"; | ||
| 1212 | + $string = strtr($string, $chars['in'], $chars['out']); | ||
| 1213 | + $double_chars['in'] = array(chr(140), chr(156), chr(198), chr(208), chr(222), chr(223), chr(230), chr(240), chr(254)); | ||
| 1214 | + $double_chars['out'] = array('OE', 'oe', 'AE', 'DH', 'TH', 'ss', 'ae', 'dh', 'th'); | ||
| 1215 | + $string = str_replace($double_chars['in'], $double_chars['out'], $string); | ||
| 1216 | + } | ||
| 1217 | + return $string; | ||
| 1218 | + } | ||
| 1219 | + function converte($texto){ | ||
| 1220 | + if($this->convUTF == true) | ||
| 1221 | + $texto = mb_convert_encoding($texto,mb_detect_encoding($texto),"UTF-8"); | ||
| 1222 | + else | ||
| 1223 | + $texto = mb_convert_encoding($texto,mb_detect_encoding($texto),"ISO-8859-1"); | ||
| 1224 | + return $texto; | ||
| 1225 | + } | ||
| 1226 | + function verificaPapelSessao($id_papel){ | ||
| 1227 | + if(!empty($_COOKIE["i3geocodigologin"])){ | ||
| 1228 | + session_write_close(); | ||
| 1229 | + session_name("i3GeoLogin"); | ||
| 1230 | + session_id($_COOKIE["i3geocodigologin"]); | ||
| 1231 | + session_start(); | ||
| 1232 | + //var_dump($_SESSION);exit; | ||
| 1233 | + if($_SESSION["usuario"] != $_COOKIE["i3geousuariologin"]){ | ||
| 1234 | + return false; | ||
| 1235 | + } | ||
| 1236 | + foreach($_SESSION["papeis"] as $p){ | ||
| 1237 | + if($p == 1 || $p == $id_papel){ | ||
| 1238 | + return true; | ||
| 1239 | + } | ||
| 1240 | + } | ||
| 1241 | + } | ||
| 1242 | + else{//caso nao exista, retorna um erro | ||
| 1243 | + return false; | ||
| 1244 | + } | ||
| 1245 | + } | ||
| 1246 | + function verificaOperacaoSessao($operacao){ | ||
| 1247 | + if($_COOKIE["i3geocodigologin"] != ""){ | ||
| 1248 | + session_write_close(); | ||
| 1249 | + session_name("i3GeoLogin"); | ||
| 1250 | + session_id($_COOKIE["i3geocodigologin"]); | ||
| 1251 | + session_start(); | ||
| 1252 | + $resultado = false; | ||
| 1253 | + //verifica se e administrador | ||
| 1254 | + foreach($_SESSION["papeis"] as $p){ | ||
| 1255 | + if($p == 1){ | ||
| 1256 | + return true; | ||
| 1257 | + } | ||
| 1258 | + } | ||
| 1259 | + if(!empty($_SESSION["operacoes"][$operacao])){ | ||
| 1260 | + $resultado = true; | ||
| 1261 | + } | ||
| 1262 | + return $resultado; | ||
| 1263 | + } else { | ||
| 1264 | + return false; | ||
| 1265 | + } | ||
| 1266 | + } | ||
| 1267 | +} | ||
| 1268 | +?> | ||
| 0 | \ No newline at end of file | 1269 | \ No newline at end of file |
admin/php/xxxmapas.php
| @@ -1,329 +0,0 @@ | @@ -1,329 +0,0 @@ | ||
| 1 | -<?php | ||
| 2 | -/* | ||
| 3 | -Title: mapas.php | ||
| 4 | - | ||
| 5 | -Funções utilizadas pelo editor do cadastro de mapas (links). | ||
| 6 | - | ||
| 7 | -É utilizado nas funções em AJAX da interface de edição dos links para mapas | ||
| 8 | - | ||
| 9 | -Licenca: | ||
| 10 | - | ||
| 11 | -GPL2 | ||
| 12 | - | ||
| 13 | -i3Geo Interface Integrada de Ferramentas de Geoprocessamento para Internet | ||
| 14 | - | ||
| 15 | -Direitos Autorais Reservados (c) 2006 Ministério do Meio Ambiente Brasil | ||
| 16 | -Desenvolvedor: Edmar Moretti edmar.moretti@gmail.com | ||
| 17 | - | ||
| 18 | -Este programa é software livre; você pode redistribuí-lo | ||
| 19 | -e/ou modificá-lo sob os termos da Licença Pública Geral | ||
| 20 | -GNU conforme publicada pela Free Software Foundation; | ||
| 21 | - | ||
| 22 | -Este programa é distribuído na expectativa de que seja útil, | ||
| 23 | -porém, SEM NENHUMA GARANTIA; nem mesmo a garantia implícita | ||
| 24 | -de COMERCIABILIDADE OU ADEQUAÇÃO A UMA FINALIDADE ESPECÍFICA. | ||
| 25 | -Consulte a Licença Pública Geral do GNU para mais detalhes. | ||
| 26 | -Você deve ter recebido uma cópia da Licença Pública Geral do | ||
| 27 | - GNU junto com este programa; se não, escreva para a | ||
| 28 | -Free Software Foundation, Inc., no endereço | ||
| 29 | -59 Temple Street, Suite 330, Boston, MA 02111-1307 USA. | ||
| 30 | - | ||
| 31 | -Arquivo: | ||
| 32 | - | ||
| 33 | -i3geo/admin/php/mapas.php | ||
| 34 | - | ||
| 35 | -Parametros: | ||
| 36 | - | ||
| 37 | -O parâmetro principal é "funcao", que define qual operação será executada, por exemplo, mapas.php?funcao=pegamapas. | ||
| 38 | - | ||
| 39 | -Cada operação possuí seus próprios parâmetros, que devem ser enviados também na requisição da operação. | ||
| 40 | - | ||
| 41 | -*/ | ||
| 42 | -include_once(dirname(__FILE__)."/login.php"); | ||
| 43 | -$funcoesEdicao = array( | ||
| 44 | - "ALTERARMAPA", | ||
| 45 | - "EXCLUIRMAPA", | ||
| 46 | - "SALVAMAPFILE" | ||
| 47 | -); | ||
| 48 | -if(in_array(strtoupper($funcao),$funcoesEdicao)){ | ||
| 49 | - if(verificaOperacaoSessao("admin/html/mapas") == false){ | ||
| 50 | - retornaJSON("Vc nao pode realizar essa operacao. Tente fazer login novamente.");exit; | ||
| 51 | - } | ||
| 52 | -} | ||
| 53 | -$id = $_GET["id"]; | ||
| 54 | -$id_mapa = $_GET["id_mapa"]; | ||
| 55 | -testaSafeNumerico([$id,$id_mapa]); | ||
| 56 | - | ||
| 57 | - | ||
| 58 | -//error_reporting(0); | ||
| 59 | -//faz a busca da função que deve ser executada | ||
| 60 | -switch (strtoupper($funcao)) | ||
| 61 | -{ | ||
| 62 | - /* | ||
| 63 | - Note: | ||
| 64 | - | ||
| 65 | - Valores que o parâmetro &funcao pode receber. Os parâmetros devem ser enviados na requisição em AJAX. | ||
| 66 | - */ | ||
| 67 | - /* | ||
| 68 | - Valor: PEGAMAPAS | ||
| 69 | - | ||
| 70 | - Lista os links existentes | ||
| 71 | - | ||
| 72 | - Retorno: | ||
| 73 | - | ||
| 74 | - {JSON} | ||
| 75 | - */ | ||
| 76 | - case "PEGAMAPAS": | ||
| 77 | - $semmapfile = pegaDados("SELECT id_mapa,nome_mapa,ordem_mapa,'nao' as contemmapfile from ".$esquemaadmin."i3geoadmin_mapas where mapfile = '' or mapfile is null order by ordem_mapa"); | ||
| 78 | - $commapfile = pegaDados("SELECT id_mapa,nome_mapa,ordem_mapa,'sim' as contemmapfile from ".$esquemaadmin."i3geoadmin_mapas where mapfile != '' and mapfile is not null order by ordem_mapa"); | ||
| 79 | - retornaJSON(array_merge($semmapfile,$commapfile)); | ||
| 80 | - exit; | ||
| 81 | - break; | ||
| 82 | - /* | ||
| 83 | - Valor: PEGADADOSMAPA | ||
| 84 | - | ||
| 85 | - Lista os dados de um link | ||
| 86 | - | ||
| 87 | - Parametro: | ||
| 88 | - | ||
| 89 | - id_mapa {string} | ||
| 90 | - | ||
| 91 | - Retorno: | ||
| 92 | - | ||
| 93 | - {JSON} | ||
| 94 | - */ | ||
| 95 | - case "PEGADADOSMAPA": | ||
| 96 | - $dadosMapa = pegaDados("SELECT * from ".$esquemaadmin."i3geoadmin_mapas where id_mapa =".$id_mapa); | ||
| 97 | - retornaJSON($dadosMapa); | ||
| 98 | - exit; | ||
| 99 | - break; | ||
| 100 | - /* | ||
| 101 | - Valor: ALTERARMAPA | ||
| 102 | - | ||
| 103 | - Altera os dados de um link | ||
| 104 | - | ||
| 105 | - Parametro: | ||
| 106 | - | ||
| 107 | - publicado_mapa | ||
| 108 | - | ||
| 109 | - ordem_mapa | ||
| 110 | - | ||
| 111 | - id_mapa | ||
| 112 | - | ||
| 113 | - desc_mapa | ||
| 114 | - | ||
| 115 | - ext_mapa | ||
| 116 | - | ||
| 117 | - imagem_mapa | ||
| 118 | - | ||
| 119 | - outros_mapa | ||
| 120 | - | ||
| 121 | - nome_mapa | ||
| 122 | - | ||
| 123 | - linkdireto_mapa | ||
| 124 | - | ||
| 125 | - temas_mapa | ||
| 126 | - | ||
| 127 | - ligados_mapa | ||
| 128 | - | ||
| 129 | - perfil_mapa | ||
| 130 | - | ||
| 131 | - Retorno: | ||
| 132 | - | ||
| 133 | - {JSON} | ||
| 134 | - */ | ||
| 135 | - case "ALTERARMAPA": | ||
| 136 | - $novo = alterarMapa(); | ||
| 137 | - $sql = "SELECT * from ".$esquemaadmin."i3geoadmin_mapas WHERE id_mapa = '".$novo."'"; | ||
| 138 | - retornaJSON(pegaDados($sql)); | ||
| 139 | - exit; | ||
| 140 | - break; | ||
| 141 | - /* | ||
| 142 | - Valor: EXCLUIRMAPA | ||
| 143 | - | ||
| 144 | - Exclui um link | ||
| 145 | - | ||
| 146 | - Parametro: | ||
| 147 | - | ||
| 148 | - id {string} | ||
| 149 | - | ||
| 150 | - Retorno: | ||
| 151 | - | ||
| 152 | - {JSON} | ||
| 153 | - */ | ||
| 154 | - case "EXCLUIRMAPA": | ||
| 155 | - retornaJSON(excluirMapa()); | ||
| 156 | - exit; | ||
| 157 | - break; | ||
| 158 | - /* | ||
| 159 | - Valor: SALVAMAPFILE | ||
| 160 | - | ||
| 161 | - Salva um mapfile no banco | ||
| 162 | - | ||
| 163 | - Parametro: | ||
| 164 | - | ||
| 165 | - url {string} - url de acesso a interface do mapa que iniciou o processo de salvar o mapa | ||
| 166 | - | ||
| 167 | - titulo {string} - titulo do mapa | ||
| 168 | - | ||
| 169 | - mapfile {string} - mapfile na pasta temporária | ||
| 170 | - | ||
| 171 | - Retorno: | ||
| 172 | - | ||
| 173 | - {JSON} | ||
| 174 | - */ | ||
| 175 | - case "SALVAMAPFILE": | ||
| 176 | - retornaJSON(salvaMapfile()); | ||
| 177 | - exit; | ||
| 178 | - break; | ||
| 179 | -} | ||
| 180 | -function salvaMapfile(){ | ||
| 181 | - global $esquemaadmin,$id_mapa; | ||
| 182 | - //as preferencias sao criadas via javascript e guardadas junto com o mapa | ||
| 183 | - try{ | ||
| 184 | - // | ||
| 185 | - //as configuracoes especiais do mapa, definidas nas preferencias ou em ferramentas abertas quando o mapa e salvo, | ||
| 186 | - //sao convertidas em base64 do lado do cliente | ||
| 187 | - //esses dados sao entao armazenados como tags METADATA no mapfile | ||
| 188 | - //quando o mapa e restaurado, esses valores sao recuperados | ||
| 189 | - //a string que vai no metadata segue o padrao JSON | ||
| 190 | - //o parser para reconstruir os valores e feito em javascript, no cliente | ||
| 191 | - // | ||
| 192 | - $_GET["arqmapfile"] = str_replace(".map","",$_GET["arqmapfile"]); | ||
| 193 | - $_GET["arqmapfile"] = str_replace(".","",$_GET["arqmapfile"]).".map"; | ||
| 194 | - $customizacoesinit = array(); | ||
| 195 | - if(isset($_GET["preferenciasbase64"]) || isset($_GET["geometriasbase64"]) || isset($_GET["graficosbase64"]) || isset($_GET["tabelasbase64"])){ | ||
| 196 | - $customizacoesinit[] = '"preferenciasbase64":"'.$_GET["preferenciasbase64"].'"'; | ||
| 197 | - $customizacoesinit[] = '"geometriasbase64":"'.$_GET["geometriasbase64"].'"'; | ||
| 198 | - $customizacoesinit[] = '"graficosbase64":"'.$_GET["graficosbase64"].'"'; | ||
| 199 | - $customizacoesinit[] = '"tabelasbase64":"'.$_GET["tabelasbase64"].'"'; | ||
| 200 | - $m = ms_newMapObj($_GET["arqmapfile"]); | ||
| 201 | - $m->setmetadata("CUSTOMIZACOESINIT",'{'.implode(",",$customizacoesinit).'}'); | ||
| 202 | - $m->save($_GET["arqmapfile"]); | ||
| 203 | - } | ||
| 204 | - if($_GET["ext"] && $_GET["ext"] != ""){ | ||
| 205 | - $e = explode(" ",$_GET["ext"]); | ||
| 206 | - $m = ms_newMapObj($_GET["arqmapfile"]); | ||
| 207 | - $extatual = $m->extent; | ||
| 208 | - $extatual->setextent((min($e[0],$e[2])),(min($e[1],$e[3])),(max($e[0],$e[2])),(max($e[1],$e[3]))); | ||
| 209 | - $m->save($_GET["arqmapfile"]); | ||
| 210 | - } | ||
| 211 | - $handle = fopen ($_GET["arqmapfile"], 'r'); | ||
| 212 | - $conteudo = fread ($handle, filesize ($_GET["arqmapfile"])); | ||
| 213 | - fclose ($handle); | ||
| 214 | - //$conteudo = base64_encode($conteudo); | ||
| 215 | - $conteudo = str_replace("'","_!_",$conteudo); | ||
| 216 | - $conteudo = str_replace('"',"_!!_",$conteudo); | ||
| 217 | - $conteudo = str_replace(array("<?","?>"),"",$conteudo); | ||
| 218 | - | ||
| 219 | - require_once("conexao.php"); | ||
| 220 | - if($convUTF){ | ||
| 221 | - $_GET["nome_mapa"] = utf8_encode($_GET["nome_mapa"]); | ||
| 222 | - $conteudo = utf8_encode($conteudo); | ||
| 223 | - } | ||
| 224 | - $retorna = ""; | ||
| 225 | - if(empty($id_mapa)){ | ||
| 226 | - $dataCol = array( | ||
| 227 | - "publicado_mapa" => '', | ||
| 228 | - "ordem_mapa" => 0, | ||
| 229 | - "perfil_mapa" => '', | ||
| 230 | - "desc_mapa" => '', | ||
| 231 | - "ext_mapa" => '', | ||
| 232 | - "imagem_mapa" => '', | ||
| 233 | - "linkdireto_mapa" => '', | ||
| 234 | - "outros_mapa" => '', | ||
| 235 | - "temas_mapa" => '', | ||
| 236 | - "ligados_mapa" => '', | ||
| 237 | - "nome_mapa" => '' | ||
| 238 | - ); | ||
| 239 | - $id = i3GeoAdminInsertUnico($dbhw,"i3geoadmin_mapas",$dataCol,"nome_mapa","id_mapa"); | ||
| 240 | - } | ||
| 241 | - else{ | ||
| 242 | - $id = $id_mapa; | ||
| 243 | - } | ||
| 244 | - if (filter_var($id, FILTER_VALIDATE_INT) === false){ | ||
| 245 | - return array("id"=>"","status"=>"Error!: "); | ||
| 246 | - } | ||
| 247 | - $dataCol = array( | ||
| 248 | - "mapfile" => $conteudo, | ||
| 249 | - "publicado_mapa" => "sim", | ||
| 250 | - "nome_mapa" => $_GET["nome_mapa"], | ||
| 251 | - "outros_mapa" => "&restauramapa=$id&interface=".$_GET["url"] | ||
| 252 | - ); | ||
| 253 | - i3GeoAdminUpdate($dbhw,"i3geoadmin_mapas",$dataCol, "WHERE id_mapa =".$id); | ||
| 254 | - $dbhw = null; | ||
| 255 | - $dbh = null; | ||
| 256 | - return array("id"=>$id,"status"=>"ok"); | ||
| 257 | - } | ||
| 258 | - catch (PDOException $e){ | ||
| 259 | - return array("id"=>"","status"=>"Error!: "); | ||
| 260 | - } | ||
| 261 | -} | ||
| 262 | -/* | ||
| 263 | -Altera o registro de um mapa | ||
| 264 | -*/ | ||
| 265 | -function alterarMapa(){ | ||
| 266 | - global $esquemaadmin,$id_mapa; | ||
| 267 | - //substitui a string do parametro outros | ||
| 268 | - $_GET["outros_mapa"] = str_replace("*","&",$_GET["outros_mapa"]); | ||
| 269 | - try{ | ||
| 270 | - require_once("conexao.php"); | ||
| 271 | - if($convUTF){ | ||
| 272 | - $_GET["nome_mapa"] = utf8_encode($_GET["nome_mapa"]); | ||
| 273 | - $_GET["desc_mapa"] = utf8_encode($_GET["desc_mapa"]); | ||
| 274 | - } | ||
| 275 | - $retorna = ""; | ||
| 276 | - if($id_mapa != ""){ | ||
| 277 | - $dataCol = array( | ||
| 278 | - "publicado_mapa" => $_GET["publicado_mapa"], | ||
| 279 | - "ordem_mapa" => $_GET["ordem_mapa"], | ||
| 280 | - "desc_mapa" => $_GET["desc_mapa"], | ||
| 281 | - "ext_mapa" => $_GET["ext_mapa"], | ||
| 282 | - "imagem_mapa" => $_GET["imagem_mapa"], | ||
| 283 | - "outros_mapa" => $_GET["outros_mapa"], | ||
| 284 | - "nome_mapa" => $_GET["nome_mapa"], | ||
| 285 | - "linkdireto_mapa" => $_GET["linkdireto_mapa"], | ||
| 286 | - "temas_mapa" => $_GET["temas_mapa"], | ||
| 287 | - "ligados_mapa" => $_GET["ligados_mapa"], | ||
| 288 | - "perfil_mapa" => $_GET["perfil_mapa"] | ||
| 289 | - ); | ||
| 290 | - i3GeoAdminUpdate($dbhw,"i3geoadmin_mapas",$dataCol, "WHERE id_mapa =".$id_mapa); | ||
| 291 | - $retorna = $id_mapa; | ||
| 292 | - } | ||
| 293 | - else{ | ||
| 294 | - $dataCol = array( | ||
| 295 | - "publicado_mapa" => '', | ||
| 296 | - "ordem_mapa" => 0, | ||
| 297 | - "perfil_mapa" => '', | ||
| 298 | - "desc_mapa" => '', | ||
| 299 | - "ext_mapa" => '', | ||
| 300 | - "imagem_mapa" => '', | ||
| 301 | - "linkdireto_mapa" => '', | ||
| 302 | - "outros_mapa" => '', | ||
| 303 | - "temas_mapa" => '', | ||
| 304 | - "ligados_mapa" => '', | ||
| 305 | - "nome_mapa" => '', | ||
| 306 | - "mapfile" => '' | ||
| 307 | - ); | ||
| 308 | - $id = i3GeoAdminInsertUnico($dbhw,"i3geoadmin_mapas",$dataCol,"nome_mapa","id_mapa"); | ||
| 309 | - $retorna = $id; | ||
| 310 | - } | ||
| 311 | - $dbhw = null; | ||
| 312 | - $dbh = null; | ||
| 313 | - return $retorna; | ||
| 314 | - } | ||
| 315 | - catch (PDOException $e){ | ||
| 316 | - return "Error!: "; | ||
| 317 | - } | ||
| 318 | -} | ||
| 319 | -function excluirMapa(){ | ||
| 320 | - global $id,$esquemaadmin; | ||
| 321 | - try{ | ||
| 322 | - exclui($esquemaadmin."i3geoadmin_mapas","id_mapa",$id); | ||
| 323 | - return "ok"; | ||
| 324 | - } | ||
| 325 | - catch (PDOException $e){ | ||
| 326 | - return "Error!: "; | ||
| 327 | - } | ||
| 328 | -} | ||
| 329 | -?> | ||
| 330 | \ No newline at end of file | 0 | \ No newline at end of file |
admin1/catalogo/atlas/pranchas/temas/exec.php
| @@ -62,7 +62,7 @@ switch ($funcao) { | @@ -62,7 +62,7 @@ switch ($funcao) { | ||
| 62 | if ($dados === false) { | 62 | if ($dados === false) { |
| 63 | header ( "HTTP/1.1 500 erro ao consultar banco de dados tabela de temas de uma prancha" ); | 63 | header ( "HTTP/1.1 500 erro ao consultar banco de dados tabela de temas de uma prancha" ); |
| 64 | } else { | 64 | } else { |
| 65 | - include("../../../../../admin/php/classe_arvore.php"); | 65 | + include("../../../../../classesphp/classe_arvore.php"); |
| 66 | $arvore = new Arvore($_SESSION["locaplic"]); | 66 | $arvore = new Arvore($_SESSION["locaplic"]); |
| 67 | $temas = $arvore->pegaTodosTemas(true); | 67 | $temas = $arvore->pegaTodosTemas(true); |
| 68 | \admin\php\funcoesAdmin\retornaJSON ( array("dados"=>$dados, "temas"=>$temas) ); | 68 | \admin\php\funcoesAdmin\retornaJSON ( array("dados"=>$dados, "temas"=>$temas) ); |
| @@ -77,7 +77,7 @@ switch ($funcao) { | @@ -77,7 +77,7 @@ switch ($funcao) { | ||
| 77 | header ( "HTTP/1.1 500 erro ao consultar banco de dados tabela de temas de uma prancha" ); | 77 | header ( "HTTP/1.1 500 erro ao consultar banco de dados tabela de temas de uma prancha" ); |
| 78 | } else { | 78 | } else { |
| 79 | //pega a lista de temas | 79 | //pega a lista de temas |
| 80 | - include("../../../../../admin/php/classe_arvore.php"); | 80 | + include("../../../../../classesphp/classe_arvore.php"); |
| 81 | $arvore = new Arvore($_SESSION["locaplic"]); | 81 | $arvore = new Arvore($_SESSION["locaplic"]); |
| 82 | $temas = $arvore->pegaTodosTemas(true); | 82 | $temas = $arvore->pegaTodosTemas(true); |
| 83 | \admin\php\funcoesAdmin\retornaJSON ( array("dados"=>$dados, "temas"=>$temas) ); | 83 | \admin\php\funcoesAdmin\retornaJSON ( array("dados"=>$dados, "temas"=>$temas) ); |
admin1/catalogo/mapas/exec.php
| @@ -81,7 +81,7 @@ switch ($funcao) { | @@ -81,7 +81,7 @@ switch ($funcao) { | ||
| 81 | $dbhw = null; | 81 | $dbhw = null; |
| 82 | $dbh = null; | 82 | $dbh = null; |
| 83 | // pega a lista de temas | 83 | // pega a lista de temas |
| 84 | - include ("../../../admin/php/classe_arvore.php"); | 84 | + include ("../../../classesphp/classe_arvore.php"); |
| 85 | $arvore = new Arvore($_SESSION["locaplic"]); | 85 | $arvore = new Arvore($_SESSION["locaplic"]); |
| 86 | $temas = $arvore->pegaTodosTemas(true); | 86 | $temas = $arvore->pegaTodosTemas(true); |
| 87 | \admin\php\funcoesAdmin\retornaJSON(array( | 87 | \admin\php\funcoesAdmin\retornaJSON(array( |
| @@ -103,7 +103,7 @@ switch ($funcao) { | @@ -103,7 +103,7 @@ switch ($funcao) { | ||
| 103 | $dbhw = null; | 103 | $dbhw = null; |
| 104 | $dbh = null; | 104 | $dbh = null; |
| 105 | // pega a lista de temas | 105 | // pega a lista de temas |
| 106 | - include ("../../../admin/php/classe_arvore.php"); | 106 | + include ("../../../classesphp/classe_arvore.php"); |
| 107 | $arvore = new Arvore($_SESSION["locaplic"]); | 107 | $arvore = new Arvore($_SESSION["locaplic"]); |
| 108 | $temas = $arvore->pegaTodosTemas(true); | 108 | $temas = $arvore->pegaTodosTemas(true); |
| 109 | \admin\php\funcoesAdmin\retornaJSON(array( | 109 | \admin\php\funcoesAdmin\retornaJSON(array( |
admin1/catalogo/mapfile/editor/funcoes.php
| @@ -3,7 +3,7 @@ namespace admin\catalogo\mapfile\editor; | @@ -3,7 +3,7 @@ namespace admin\catalogo\mapfile\editor; | ||
| 3 | 3 | ||
| 4 | function textoMapfile($codigo) | 4 | function textoMapfile($codigo) |
| 5 | { | 5 | { |
| 6 | - global $dbhw; | 6 | + global $dbhw, $esquemaadmin; |
| 7 | $locaplic = $_SESSION["locaplic"]; | 7 | $locaplic = $_SESSION["locaplic"]; |
| 8 | $mapfile = $locaplic . "/temas/" . $codigo . ".map"; | 8 | $mapfile = $locaplic . "/temas/" . $codigo . ".map"; |
| 9 | if (! file_exists($mapfile)) { | 9 | if (! file_exists($mapfile)) { |
admin1/catalogo/mapfile/editor/index.php
| @@ -13,6 +13,10 @@ | @@ -13,6 +13,10 @@ | ||
| 13 | // | 13 | // |
| 14 | include ("../../../php/checaLogin.php"); | 14 | include ("../../../php/checaLogin.php"); |
| 15 | \admin\php\login\checaLogin(); | 15 | \admin\php\login\checaLogin(); |
| 16 | + | ||
| 17 | + | ||
| 18 | +//$k = filter_var ( $k, FILTER_SANITIZE_STRING ); | ||
| 19 | + | ||
| 16 | //funcoes de administracao | 20 | //funcoes de administracao |
| 17 | include ($_SESSION["locaplic"]."/admin1/php/funcoesAdmin.php"); | 21 | include ($_SESSION["locaplic"]."/admin1/php/funcoesAdmin.php"); |
| 18 | // | 22 | // |
| @@ -30,6 +34,7 @@ include ("funcoes.php"); | @@ -30,6 +34,7 @@ include ("funcoes.php"); | ||
| 30 | // | 34 | // |
| 31 | include ($_SESSION["locaplic"]."/admin1/php/conexao.php"); | 35 | include ($_SESSION["locaplic"]."/admin1/php/conexao.php"); |
| 32 | /***************************************************************/ | 36 | /***************************************************************/ |
| 37 | + | ||
| 33 | define ( "ONDEI3GEO", "../../../.." ); | 38 | define ( "ONDEI3GEO", "../../../.." ); |
| 34 | include "../../../head.php"; | 39 | include "../../../head.php"; |
| 35 | $codigo = filter_var ( $_GET ["codigo"], FILTER_SANITIZE_STRING ); | 40 | $codigo = filter_var ( $_GET ["codigo"], FILTER_SANITIZE_STRING ); |
| @@ -102,7 +107,7 @@ $textoMapfile = \admin\catalogo\mapfile\editor\textoMapfile ( $codigo ); | @@ -102,7 +107,7 @@ $textoMapfile = \admin\catalogo\mapfile\editor\textoMapfile ( $codigo ); | ||
| 102 | </form> | 107 | </form> |
| 103 | <!-- para calcular a altura do textarea --> | 108 | <!-- para calcular a altura do textarea --> |
| 104 | <pre id="editortemp" style="font-size: 16px; display: block; visibility: hidden;"><?php echo $textoMapfile["texto"]; ?></pre> | 109 | <pre id="editortemp" style="font-size: 16px; display: block; visibility: hidden;"><?php echo $textoMapfile["texto"]; ?></pre> |
| 105 | - </div> | 110 | + </div> |
| 106 | </div> | 111 | </div> |
| 107 | </div> | 112 | </div> |
| 108 | 113 |
| @@ -0,0 +1,1268 @@ | @@ -0,0 +1,1268 @@ | ||
| 1 | +<?php | ||
| 2 | +/* | ||
| 3 | +Title: classe_arvore.php | ||
| 4 | + | ||
| 5 | +Funções para montagem da árvore de temas | ||
| 6 | + | ||
| 7 | +Licenca: | ||
| 8 | + | ||
| 9 | +GPL2 | ||
| 10 | + | ||
| 11 | +i3Geo Interface Integrada de Ferramentas de Geoprocessamento para Internet | ||
| 12 | + | ||
| 13 | +Direitos Autorais Reservados (c) 2006 Ministério do Meio Ambiente Brasil | ||
| 14 | +Desenvolvedor: Edmar Moretti edmar.moretti@gmail.com | ||
| 15 | + | ||
| 16 | +Este programa é software livre; você pode redistribuí-lo | ||
| 17 | +e/ou modificá-lo sob os termos da Licença Pública Geral | ||
| 18 | +GNU conforme publicada pela Free Software Foundation; | ||
| 19 | + | ||
| 20 | +Este programa é distribuído na expectativa de que seja útil, | ||
| 21 | +porém, SEM NENHUMA GARANTIA; nem mesmo a garantia implícita | ||
| 22 | +de COMERCIABILIDADE OU ADEQUAÇÃO A UMA FINALIDADE ESPECÍFICA. | ||
| 23 | +Consulte a Licença Pública Geral do GNU para mais detalhes. | ||
| 24 | +Você deve ter recebido uma c�pia da Licença Pública Geral do | ||
| 25 | + GNU junto com este programa; se não, escreva para a | ||
| 26 | +Free Software Foundation, Inc., no endereço | ||
| 27 | +59 Temple Street, Suite 330, Boston, MA 02111-1307 USA. | ||
| 28 | + | ||
| 29 | +Arquivo: | ||
| 30 | + | ||
| 31 | +classe_arvore.php | ||
| 32 | +*/ | ||
| 33 | +/* | ||
| 34 | +Classe: Arvore | ||
| 35 | + | ||
| 36 | +Classe utilizada para compor a árvore de temas ou obter dados específicos da árvore. | ||
| 37 | + | ||
| 38 | +É utilizada por várias operações do i3Geo, principalmente pela <classe_menutemas> | ||
| 39 | +*/ | ||
| 40 | +class Arvore | ||
| 41 | +{ | ||
| 42 | + //temas com acesso restrito e que nao podem ser acessados pelo usuario que esta logado | ||
| 43 | + public $temassindevidos; | ||
| 44 | + protected $locaplic; | ||
| 45 | + //subgrupos que tem pelo menos um tema | ||
| 46 | + //public $sql_subgrupos = "select i3geoadmin_subgrupos.nome_subgrupo,i3geoadmin_n2.id_n2,i3geoadmin_n2.publicado,i3geoadmin_n2.n2_perfil from i3geoadmin_n2 LEFT JOIN i3geoadmin_subgrupos ON i3geoadmin_n2.id_subgrupo = i3geoadmin_subgrupos.id_subgrupo "; | ||
| 47 | + //grupos que tem pelo menos um sub-grupo | ||
| 48 | + //public $sql_grupos = "select i3geoadmin_grupos.nome_grupo,id_n1,id_menu,i3geoadmin_n1.publicado,n1_perfil from i3geoadmin_n1 LEFT JOIN i3geoadmin_grupos ON i3geoadmin_n1.id_grupo = i3geoadmin_grupos.id_grupo "; | ||
| 49 | + //nomes de todos os grupos | ||
| 50 | + public $sql_todosgrupos = "select * from i3geoadmin_grupos "; | ||
| 51 | + //tipo de filtro | ||
| 52 | + //ogc|download|"" | ||
| 53 | + public $filtro; | ||
| 54 | + //temas na raiz | ||
| 55 | + //public $sql_temasraiz = "select id_raiz,i3geoadmin_raiz.id_tema,nome_tema,tipoa_tema FROM i3geoadmin_raiz LEFT JOIN i3geoadmin_temas ON i3geoadmin_temas.id_tema = i3geoadmin_raiz.id_tema "; | ||
| 56 | + //todos os temas | ||
| 57 | + //public $sql_temas = "select * from i3geoadmin_temas "; | ||
| 58 | + //temas de um subgrupo | ||
| 59 | + //public $sql_temasSubgrupo = "select i3geoadmin_temas.tipoa_tema, i3geoadmin_temas.codigo_tema,i3geoadmin_temas.tags_tema,i3geoadmin_n3.id_n3,i3geoadmin_temas.nome_tema,i3geoadmin_n3.publicado,i3geoadmin_n3.n3_perfil,i3geoadmin_n3.id_tema,i3geoadmin_temas.download_tema,i3geoadmin_temas.ogc_tema from i3geoadmin_n3 LEFT JOIN i3geoadmin_temas ON i3geoadmin_n3.id_tema = i3geoadmin_temas.id_tema "; | ||
| 60 | + /* | ||
| 61 | + Function: __construct | ||
| 62 | + | ||
| 63 | + Cria um objeto Arvore | ||
| 64 | + | ||
| 65 | + Parametros: | ||
| 66 | + | ||
| 67 | + locaplic {string} - localização do i3geo no sistema de arquivos | ||
| 68 | + | ||
| 69 | + idioma {string} - default = "pt" | ||
| 70 | + */ | ||
| 71 | + function __construct($locaplic,$idioma="pt",$filtro="") | ||
| 72 | + { | ||
| 73 | + $this->locaplic = $locaplic; | ||
| 74 | + $this->filtro = $filtro; | ||
| 75 | + $dbh = ""; | ||
| 76 | + //error_reporting(0); | ||
| 77 | + | ||
| 78 | + include($locaplic."/classesphp/conexao.php"); | ||
| 79 | + | ||
| 80 | + $this->esquemaadmin = $esquemaadmin; | ||
| 81 | + $this->convUTF = $convUTF; | ||
| 82 | + $this->dbh = $dbh; | ||
| 83 | + | ||
| 84 | + $this->idioma = $idioma; | ||
| 85 | + if($idioma == "pt"){ | ||
| 86 | + $coluna = "nome_grupo"; | ||
| 87 | + } | ||
| 88 | + else{ | ||
| 89 | + $coluna = $idioma; | ||
| 90 | + } | ||
| 91 | + $this->sql_grupos = "select CASE i3geoadmin_grupos.$coluna WHEN '' THEN nome_grupo ELSE i3geoadmin_grupos.$coluna END as nome_grupo,i3geoadmin_grupos.id_grupo, id_n1,id_menu,i3geoadmin_n1.publicado,n1_perfil,ordem from ".$this->esquemaadmin."i3geoadmin_n1 LEFT JOIN ".$this->esquemaadmin."i3geoadmin_grupos ON i3geoadmin_n1.id_grupo = i3geoadmin_grupos.id_grupo "; | ||
| 92 | + if($filtro === "ogc" || $filtro === "download"){ | ||
| 93 | + //esse sql retorna tambem os grupos dos temas que estao na raiz do grupo | ||
| 94 | + $this->sql_grupos = "select DISTINCT * from (select CASE grupos.$coluna WHEN '' THEN nome_grupo ELSE grupos.$coluna END as nome_grupo,gr.id_n1,gr.id_menu,gr.publicado,gr.n1_perfil, 0 as ordem from ".$this->esquemaadmin."i3geoadmin_grupos as grupos, ".$this->esquemaadmin."i3geoadmin_n1 as gr, ".$this->esquemaadmin."i3geoadmin_n2 as sg, ".$this->esquemaadmin."i3geoadmin_n3 as t, ".$this->esquemaadmin."i3geoadmin_temas as temas where gr.id_grupo = grupos.id_grupo AND sg.id_n1 = gr.id_n1 AND t.id_n2 = sg.id_n2 AND t.id_tema = temas.id_tema AND (temas.ogc_tema NOT IN ('NAO','nao') OR temas.download_tema NOT IN ('NAO','nao') ) UNION select c.nome_grupo as nome_grupo,a.id_nivel as id_n1,a.id_menu,'SIM' as publicado,a.perfil as n1_perfil, 0 as ordem from ".$this->esquemaadmin."i3geoadmin_raiz as a, ".$this->esquemaadmin."i3geoadmin_temas as b, ".$this->esquemaadmin."i3geoadmin_grupos as c, ".$this->esquemaadmin."i3geoadmin_n1 as d where nivel = 1 AND a.id_tema = b.id_tema AND a.id_nivel = d.id_n1 AND d.id_grupo = c.id_grupo) as s "; | ||
| 95 | + } | ||
| 96 | + | ||
| 97 | + if($idioma == "pt"){ | ||
| 98 | + $coluna = "nome_subgrupo"; | ||
| 99 | + } | ||
| 100 | + else{ | ||
| 101 | + $coluna = $idioma; | ||
| 102 | + } | ||
| 103 | + $this->sql_subgrupos = "select CASE i3geoadmin_subgrupos.$coluna WHEN '' THEN nome_subgrupo ELSE i3geoadmin_subgrupos.$coluna END as nome_subgrupo,i3geoadmin_subgrupos.id_subgrupo,i3geoadmin_n2.id_n2,i3geoadmin_n2.publicado,i3geoadmin_n2.n2_perfil from ".$this->esquemaadmin."i3geoadmin_n2 LEFT JOIN ".$this->esquemaadmin."i3geoadmin_subgrupos ON i3geoadmin_n2.id_subgrupo = i3geoadmin_subgrupos.id_subgrupo "; | ||
| 104 | + | ||
| 105 | + if($idioma == "pt"){ | ||
| 106 | + $coluna = "nome_tema"; | ||
| 107 | + } | ||
| 108 | + else{ | ||
| 109 | + $coluna = $idioma; | ||
| 110 | + } | ||
| 111 | + | ||
| 112 | + $this->sql_temasraiz = "select id_nivel,ordem,codigo_tema,id_raiz,i3geoadmin_raiz.id_tema,CASE $coluna WHEN '' THEN nome_tema ELSE $coluna END as nome_tema,tipoa_tema,perfil, ogc_tema, download_tema, link_tema FROM ".$this->esquemaadmin."i3geoadmin_raiz LEFT JOIN ".$this->esquemaadmin."i3geoadmin_temas ON i3geoadmin_temas.id_tema = i3geoadmin_raiz.id_tema "; | ||
| 113 | + $this->sql_temasSubgrupo = "select i3geoadmin_temas.tipoa_tema, i3geoadmin_temas.codigo_tema,i3geoadmin_temas.tags_tema,i3geoadmin_n3.id_n3,CASE i3geoadmin_temas.$coluna WHEN '' THEN nome_tema ELSE i3geoadmin_temas.$coluna END as nome_tema,i3geoadmin_n3.publicado,i3geoadmin_n3.n3_perfil,i3geoadmin_n3.id_tema,i3geoadmin_temas.download_tema,i3geoadmin_temas.ogc_tema from ".$this->esquemaadmin."i3geoadmin_n3 LEFT JOIN ".$this->esquemaadmin."i3geoadmin_temas ON i3geoadmin_n3.id_tema = i3geoadmin_temas.id_tema "; | ||
| 114 | + | ||
| 115 | + //$this->sql_temas = "select kmz_tema,nacessos,id_tema,kml_tema,ogc_tema,download_tema,tags_tema,tipoa_tema,link_tema,desc_tema,$coluna as nome_tema,codigo_tema from i3geoadmin_temas "; | ||
| 116 | + | ||
| 117 | + $this->sql_temas = "select kmz_tema,b.soma as nacessos,id_tema,kml_tema,ogc_tema,download_tema,tags_tema,tipoa_tema,link_tema,desc_tema,CASE $coluna WHEN '' THEN nome_tema ELSE $coluna END as nome_tema,codigo_tema from ".$this->esquemaadmin."i3geoadmin_temas as a,(SELECT c.codigo_tema codigo_soma,sum( r.nacessos) as soma FROM ".$this->esquemaadmin."i3geoadmin_temas c LEFT JOIN ".$this->esquemaadmin."i3geoadmin_acessostema r ON (c.codigo_tema = r.codigo_tema) group by c.codigo_tema) as b WHERE a.codigo_tema = b.codigo_soma "; | ||
| 118 | + $this->sql_temas_combo = "select id_tema,CASE $coluna WHEN '' THEN nome_tema ELSE $coluna END as nome_tema,codigo_tema from ".$this->esquemaadmin."i3geoadmin_temas as a,(SELECT c.codigo_tema codigo_soma,sum( r.nacessos) as soma FROM ".$this->esquemaadmin."i3geoadmin_temas c LEFT JOIN ".$this->esquemaadmin."i3geoadmin_acessostema r ON (c.codigo_tema = r.codigo_tema) group by c.codigo_tema) as b WHERE a.codigo_tema = b.codigo_soma "; | ||
| 119 | + // | ||
| 120 | + //verifica se o ip atual está cadastrado como um dos editores | ||
| 121 | + //editores podem ver as coisas marcadas como não publicado | ||
| 122 | + //no sistema de administração | ||
| 123 | + // | ||
| 124 | + $this->editor = false; | ||
| 125 | + $this->editor = $this->verificaOperacaoSessao("admin/php/classe_arvore/editor"); | ||
| 126 | + $this->pubsql = " (publicado != 'NAO' or publicado is null) and "; | ||
| 127 | + if($this->editor){ | ||
| 128 | + $this->pubsql = ""; | ||
| 129 | + } | ||
| 130 | + if(!function_exists("listaTemasIndevidos")){ | ||
| 131 | + include_once($locaplic."/classesphp/funcoes_gerais.php"); | ||
| 132 | + } | ||
| 133 | + $this->temasindevidos = listaTemasIndevidos(); | ||
| 134 | + } | ||
| 135 | + function __destruct() | ||
| 136 | + { | ||
| 137 | + $this->dbh = null; | ||
| 138 | + $this->dbhw = null; | ||
| 139 | + } | ||
| 140 | + /* | ||
| 141 | + Function: validaTemas | ||
| 142 | + | ||
| 143 | + Remove de um array os temas que nao sao permitidos ao usuario atualmente logado | ||
| 144 | + */ | ||
| 145 | + function validaTemas($linhas,$id){ | ||
| 146 | + $res = array(); | ||
| 147 | + foreach($linhas as $l){ | ||
| 148 | + if(!in_array($l[$id],$this->temasindevidos)){ | ||
| 149 | + array_push($res,$l); | ||
| 150 | + } | ||
| 151 | + } | ||
| 152 | + return $res; | ||
| 153 | + } | ||
| 154 | + /* | ||
| 155 | + Function: pegaListaDeMenus | ||
| 156 | + | ||
| 157 | + Retorna a lista de menus | ||
| 158 | + | ||
| 159 | + Parametros: | ||
| 160 | + | ||
| 161 | + perfil {string} - considera apenas esse perfil | ||
| 162 | + | ||
| 163 | + Return: | ||
| 164 | + | ||
| 165 | + {array} | ||
| 166 | + */ | ||
| 167 | + function pegaListaDeMenus($perfil="",$filtraOgc="nao",$filtraDown="nao") | ||
| 168 | + { | ||
| 169 | + if($this->idioma == "pt"){ | ||
| 170 | + $coluna = "nome_menu"; | ||
| 171 | + } | ||
| 172 | + else{ | ||
| 173 | + $coluna = $this->idioma; | ||
| 174 | + } | ||
| 175 | + if($this->editor == true) | ||
| 176 | + { | ||
| 177 | + $perfil = ""; | ||
| 178 | + $sql = "SELECT publicado_menu,'' as perfil_menu,aberto,desc_menu,id_menu,CASE $coluna WHEN '' THEN nome_menu ELSE $coluna END as nome_menu from ".$this->esquemaadmin."i3geoadmin_menus order by nome_menu"; | ||
| 179 | + } | ||
| 180 | + else{ | ||
| 181 | + $sql = "SELECT publicado_menu,perfil_menu,aberto,desc_menu,id_menu,CASE $coluna WHEN '' THEN nome_menu ELSE $coluna END as nome_menu from ".$this->esquemaadmin."i3geoadmin_menus where publicado_menu != 'NAO' or publicado_menu is null order by nome_menu"; | ||
| 182 | + } | ||
| 183 | + $regs = $this->execSQL($sql); | ||
| 184 | + $resultado = array(); | ||
| 185 | + foreach($regs as $reg){ | ||
| 186 | + $a = $reg["perfil_menu"]; | ||
| 187 | + $a = str_replace(" ",",",$a); | ||
| 188 | + if ($this->verificaOcorrencia($perfil,explode(",",$a))) | ||
| 189 | + { | ||
| 190 | + $status = "fechado"; | ||
| 191 | + if(strtolower($reg["aberto"]) == "sim") | ||
| 192 | + $status = "aberto"; | ||
| 193 | + $url = ""; | ||
| 194 | + $resultado[] = array("desc"=>$this->converte($reg["desc_menu"]),"publicado"=>$reg["publicado_menu"],"nomemenu"=>$this->converte($reg["nome_menu"]),"idmenu"=>$reg["id_menu"],"arquivo"=>"","status"=>$status,"url"=>$url); | ||
| 195 | + } | ||
| 196 | + } | ||
| 197 | + return $resultado; | ||
| 198 | + } | ||
| 199 | + /* | ||
| 200 | + Function: pegaListaDeTiposGrupos | ||
| 201 | + | ||
| 202 | + Retorna a lista de grupos de um menu | ||
| 203 | + | ||
| 204 | + Parametros: | ||
| 205 | + | ||
| 206 | + id_menu {string} | ||
| 207 | + | ||
| 208 | + Return: | ||
| 209 | + | ||
| 210 | + {array} | ||
| 211 | + */ | ||
| 212 | + function pegaListaDeTiposGrupos(){ | ||
| 213 | + if($this->idioma == "pt"){ | ||
| 214 | + $coluna = "nome_grupo"; | ||
| 215 | + } | ||
| 216 | + else{ | ||
| 217 | + $coluna = $this->idioma; | ||
| 218 | + } | ||
| 219 | + $sql = "select CASE i3geoadmin_grupos.$coluna WHEN '' THEN nome_grupo ELSE i3geoadmin_grupos.$coluna END as nome_grupo, id_grupo from ".$this->esquemaadmin."i3geoadmin_grupos ORDER by nome_grupo "; | ||
| 220 | + $grupos = $this->execSQL($sql); | ||
| 221 | + return $grupos; | ||
| 222 | + } | ||
| 223 | + /* | ||
| 224 | + Function: pegaListaDeTiposSubGrupos | ||
| 225 | + | ||
| 226 | + Retorna a lista de grupos de um menu | ||
| 227 | + | ||
| 228 | + Parametros: | ||
| 229 | + | ||
| 230 | + id_menu {string} | ||
| 231 | + | ||
| 232 | + Return: | ||
| 233 | + | ||
| 234 | + {array} | ||
| 235 | + */ | ||
| 236 | + function pegaListaDeTiposSubGrupos(){ | ||
| 237 | + if($this->idioma == "pt"){ | ||
| 238 | + $coluna = "nome_subgrupo"; | ||
| 239 | + } | ||
| 240 | + else{ | ||
| 241 | + $coluna = $this->idioma; | ||
| 242 | + } | ||
| 243 | + $sql = "select CASE i3geoadmin_subgrupos.$coluna WHEN '' THEN nome_subgrupo ELSE i3geoadmin_subgrupos.$coluna END as nome_subgrupo, id_subgrupo from ".$this->esquemaadmin."i3geoadmin_subgrupos ORDER by nome_subgrupo "; | ||
| 244 | + $subgrupos = $this->execSQL($sql); | ||
| 245 | + return $subgrupos; | ||
| 246 | + } | ||
| 247 | + /* | ||
| 248 | + Function: procuraTemas | ||
| 249 | + | ||
| 250 | + Localiza temas conforme uma palavra de busca | ||
| 251 | + | ||
| 252 | + Parametros: | ||
| 253 | + | ||
| 254 | + procurar {string} - palavra de busca | ||
| 255 | + | ||
| 256 | + perfil {string} - considera apenas esse perfil | ||
| 257 | + | ||
| 258 | + Return: | ||
| 259 | + | ||
| 260 | + {array} | ||
| 261 | + */ | ||
| 262 | + function procuraTemas ($procurar,$perfil) | ||
| 263 | + { | ||
| 264 | + if($procurar != "") | ||
| 265 | + { | ||
| 266 | + $procurar = $this->removeAcentos($procurar); | ||
| 267 | + } | ||
| 268 | + $menus = $this->pegaListaDeMenus($perfil); | ||
| 269 | + $resultado = array(); | ||
| 270 | + $subgrupo = array(); | ||
| 271 | + $final = array(); | ||
| 272 | + foreach($menus as $menu) | ||
| 273 | + { | ||
| 274 | + $grupos = $this->pegaGruposMenu($menu["idmenu"]); | ||
| 275 | + foreach($grupos["grupos"] as $grupo) | ||
| 276 | + { | ||
| 277 | + $a = $grupo["n1_perfil"]; | ||
| 278 | + $a = str_replace(" ",",",$a); | ||
| 279 | + if($this->verificaOcorrencia($perfil,explode(",",$a))) | ||
| 280 | + { | ||
| 281 | + $sgrupos = $this->pegaSubgruposGrupo($menu["idmenu"],$grupo["id_n1"]); | ||
| 282 | + $temasRaizGrupo = array(); | ||
| 283 | + $temasR = $this->pegaTemasRaizGrupo($menu["idmenu"],$grupo["id_n1"]); | ||
| 284 | + foreach($temasR as $tema) | ||
| 285 | + { | ||
| 286 | + $a = $tema["perfil"]; | ||
| 287 | + $a = str_replace(" ",",",$a); | ||
| 288 | + if($this->verificaOcorrencia($perfil,explode(",",$a))) | ||
| 289 | + { | ||
| 290 | + $t = $this->pegaTema($tema["id_tema"]); | ||
| 291 | + $t = $t[0]; | ||
| 292 | + $nome = $this->removeAcentos($tema["nome_tema"]); | ||
| 293 | + $tags = $this->removeAcentos($tema["tags_tema"]); | ||
| 294 | + $tags1 = $this->removeAcentos(mb_convert_encoding($tema["tags_tema"],"ISO-8859-1","UTF-8")); | ||
| 295 | + $nome1 = $this->removeAcentos(mb_convert_encoding($tema["nome_tema"],"ISO-8859-1","UTF-8")); | ||
| 296 | + $miniatura = "nao"; | ||
| 297 | + if(file_exists($this->locaplic."/temas/miniaturas/".$t["codigo_tema"].".map.mini.png")) | ||
| 298 | + { | ||
| 299 | + $miniatura = "sim"; | ||
| 300 | + } | ||
| 301 | + $down = "sim"; | ||
| 302 | + if (strtolower($t["download_tema"]) == "nao") | ||
| 303 | + { | ||
| 304 | + $down = "nao"; | ||
| 305 | + } | ||
| 306 | + $texto = array("codigo_tema"=>$t["codigo_tema"],"miniatura"=>$miniatura,"tid"=>$t["codigo_tema"],"nome"=>$this->converte($tema["nome_tema"]),"link"=>$t["link_tema"],"download"=>$down); | ||
| 307 | + if($procurar == "") | ||
| 308 | + { | ||
| 309 | + $temasRaizGrupo[] = $texto; | ||
| 310 | + } | ||
| 311 | + else | ||
| 312 | + { | ||
| 313 | + if (stristr($nome,$procurar) || stristr($nome1,$procurar)) | ||
| 314 | + { | ||
| 315 | + $temasRaizGrupo[] = $texto; | ||
| 316 | + } | ||
| 317 | + else | ||
| 318 | + { | ||
| 319 | + if (stristr($tags,$procurar) || stristr($tags1,$procurar)) | ||
| 320 | + { | ||
| 321 | + $temasRaizGrupo[] = $texto; | ||
| 322 | + } | ||
| 323 | + } | ||
| 324 | + } | ||
| 325 | + } | ||
| 326 | + } | ||
| 327 | + foreach($sgrupos["subgrupos"] as $sgrupo) | ||
| 328 | + { | ||
| 329 | + $a = $sgrupo["n2_perfil"]; | ||
| 330 | + $a = str_replace(" ",",",$a); | ||
| 331 | + if($this->verificaOcorrencia($perfil,explode(",",$a))) | ||
| 332 | + { | ||
| 333 | + $temas = $this->pegaTemasSubGrupo($sgrupo["id_n2"]); | ||
| 334 | + foreach ($temas as $tema) | ||
| 335 | + { | ||
| 336 | + $a = $tema["n3_perfil"]; | ||
| 337 | + $a = str_replace(" ",",",$a); | ||
| 338 | + if($this->verificaOcorrencia($perfil,explode(",",$a))) | ||
| 339 | + { | ||
| 340 | + $t = $this->pegaTema($tema["id_tema"]); | ||
| 341 | + $t = $t[0]; | ||
| 342 | + $nome = $this->removeAcentos($tema["nome_tema"]); | ||
| 343 | + $tags = $this->removeAcentos($tema["tags_tema"]); | ||
| 344 | + $tags1 = $this->removeAcentos(mb_convert_encoding($tema["tags_tema"],"ISO-8859-1","UTF-8")); | ||
| 345 | + $nome1 = $this->removeAcentos(mb_convert_encoding($tema["nome_tema"],"ISO-8859-1","UTF-8")); | ||
| 346 | + $miniatura = "nao"; | ||
| 347 | + if(file_exists($this->locaplic."/temas/miniaturas/".$tema["codigo_tema"].".map.mini.png")) | ||
| 348 | + { | ||
| 349 | + $miniatura = "sim"; | ||
| 350 | + } | ||
| 351 | + $down = "sim"; | ||
| 352 | + if (strtolower($t["download_tema"]) == "nao") | ||
| 353 | + { | ||
| 354 | + $down = "nao"; | ||
| 355 | + } | ||
| 356 | + $texto = array("codigo_tema"=>$tema["codigo_tema"],"miniatura"=>$miniatura,"tid"=>$tema["codigo_tema"],"nome"=>$this->converte($tema["nome_tema"]),"link"=>$t["link_tema"],"download"=>$down); | ||
| 357 | + if($procurar == "") | ||
| 358 | + { | ||
| 359 | + $resultado[] = $texto; | ||
| 360 | + } | ||
| 361 | + else | ||
| 362 | + { | ||
| 363 | + if (stristr($nome,$procurar) || stristr($nome1,$procurar)) | ||
| 364 | + { | ||
| 365 | + $resultado[] = $texto; | ||
| 366 | + } | ||
| 367 | + else | ||
| 368 | + { | ||
| 369 | + if (stristr($tags,$procurar) || stristr($tags1,$procurar)) | ||
| 370 | + { | ||
| 371 | + $resultado[] = $texto; | ||
| 372 | + } | ||
| 373 | + } | ||
| 374 | + } | ||
| 375 | + } | ||
| 376 | + } | ||
| 377 | + } | ||
| 378 | + if (count($resultado) > 0) | ||
| 379 | + { | ||
| 380 | + $subgrupo[] = array("subgrupo"=>$this->converte($sgrupo["nome_subgrupo"]),"temas"=>$resultado); | ||
| 381 | + } | ||
| 382 | + $resultado = array(); | ||
| 383 | + } | ||
| 384 | + } | ||
| 385 | + if (count($subgrupo) > 0 || count($temasRaizGrupo) > 0) | ||
| 386 | + { | ||
| 387 | + $final[] = array("grupo"=>$this->converte($grupo["nome_grupo"]),"temas"=>$temasRaizGrupo,"subgrupos"=>$subgrupo); | ||
| 388 | + } | ||
| 389 | + $subgrupo = array(); | ||
| 390 | + } | ||
| 391 | + } | ||
| 392 | + return $final; | ||
| 393 | + } | ||
| 394 | + /* | ||
| 395 | + Function: procuraTemasEstrela | ||
| 396 | + | ||
| 397 | + Localiza temas que têm um determinado número (nível) de estrelas | ||
| 398 | + | ||
| 399 | + Parametros: | ||
| 400 | + | ||
| 401 | + nivel {numeric} - número de estrelas | ||
| 402 | + | ||
| 403 | + perfil {string} - considera apenas esse perfil | ||
| 404 | + | ||
| 405 | + Return: | ||
| 406 | + | ||
| 407 | + {array} | ||
| 408 | + */ | ||
| 409 | + function procuraTemasEstrela($nivel,$fatorestrela,$perfil) | ||
| 410 | + { | ||
| 411 | + $menus = $this->pegaListaDeMenus($perfil); | ||
| 412 | + | ||
| 413 | + $resultado = array(); | ||
| 414 | + $subgrupo = array(); | ||
| 415 | + $final = array(); | ||
| 416 | + foreach($menus as $menu) | ||
| 417 | + { | ||
| 418 | + $grupos = $this->pegaGruposMenu($menu["idmenu"]); | ||
| 419 | + foreach($grupos["grupos"] as $grupo) | ||
| 420 | + { | ||
| 421 | + $a = $grupo["n1_perfil"]; | ||
| 422 | + $a = str_replace(" ",",",$a); | ||
| 423 | + if($this->verificaOcorrencia($perfil,explode(",",$a))) | ||
| 424 | + { | ||
| 425 | + $sgrupos = $this->pegaSubgruposGrupo($menu["idmenu"],$grupo["id_n1"]); | ||
| 426 | + $temasRaizGrupo = array(); | ||
| 427 | + $temasR = $this->pegaTemasRaizGrupo($menu["idmenu"],$grupo["id_n1"]); | ||
| 428 | + foreach($temasR as $tema) | ||
| 429 | + { | ||
| 430 | + $a = $tema["perfil"]; | ||
| 431 | + $a = str_replace(" ",",",$a); | ||
| 432 | + if($this->verificaOcorrencia($perfil,explode(",",$a))) | ||
| 433 | + { | ||
| 434 | + $t = $this->pegaTema($tema["id_tema"]); | ||
| 435 | + $t = $t[0]; | ||
| 436 | + $nome = $this->removeAcentos($tema["nome_tema"]); | ||
| 437 | + $tags = $this->removeAcentos($tema["tags_tema"]); | ||
| 438 | + $tags1 = $this->removeAcentos(mb_convert_encoding($tema["tags_tema"],"ISO-8859-1","UTF-8")); | ||
| 439 | + $nome1 = $this->removeAcentos(mb_convert_encoding($tema["nome_tema"],"ISO-8859-1","UTF-8")); | ||
| 440 | + $miniatura = "nao"; | ||
| 441 | + if(file_exists($this->locaplic."/temas/miniaturas/".$t["codigo_tema"].".map.mini.png")) | ||
| 442 | + { | ||
| 443 | + $miniatura = "sim"; | ||
| 444 | + } | ||
| 445 | + $down = "sim"; | ||
| 446 | + if (strtolower($t["download_tema"]) == "nao") | ||
| 447 | + { | ||
| 448 | + $down = "nao"; | ||
| 449 | + } | ||
| 450 | + $texto = array("codigo_tema"=>$t["codigo_tema"],"miniatura"=>$miniatura,"tid"=>$t["codigo_tema"],"nome"=>$this->converte($tema["nome_tema"]),"link"=>$t["link_tema"],"download"=>$down); | ||
| 451 | + $n = intval($t["nacessos"] / $fatorestrela); | ||
| 452 | + if($n >= 5){ | ||
| 453 | + $n = 5; | ||
| 454 | + } | ||
| 455 | + | ||
| 456 | + if ($n == $nivel) | ||
| 457 | + { | ||
| 458 | + $temasRaizGrupo[] = $texto; | ||
| 459 | + } | ||
| 460 | + } | ||
| 461 | + } | ||
| 462 | + foreach($sgrupos["subgrupos"] as $sgrupo) | ||
| 463 | + { | ||
| 464 | + $a = $sgrupo["n2_perfil"]; | ||
| 465 | + $a = str_replace(" ",",",$a); | ||
| 466 | + if($this->verificaOcorrencia($perfil,explode(",",$a))) | ||
| 467 | + { | ||
| 468 | + $temas = $this->pegaTemasSubGrupo($sgrupo["id_n2"]); | ||
| 469 | + foreach ($temas as $tema) | ||
| 470 | + { | ||
| 471 | + $a = $tema["n3_perfil"]; | ||
| 472 | + $a = str_replace(" ",",",$a); | ||
| 473 | + if($this->verificaOcorrencia($perfil,explode(",",$a))) | ||
| 474 | + { | ||
| 475 | + $t = $this->pegaTema($tema["id_tema"]); | ||
| 476 | + $t = $t[0]; | ||
| 477 | + $nome = $this->removeAcentos($tema["nome_tema"]); | ||
| 478 | + $tags = $this->removeAcentos($tema["tags_tema"]); | ||
| 479 | + $tags1 = $this->removeAcentos(mb_convert_encoding($tema["tags_tema"],"ISO-8859-1","UTF-8")); | ||
| 480 | + $nome1 = $this->removeAcentos(mb_convert_encoding($tema["nome_tema"],"ISO-8859-1","UTF-8")); | ||
| 481 | + $miniatura = "nao"; | ||
| 482 | + if(file_exists($this->locaplic."/temas/miniaturas/".$tema["codigo_tema"].".map.mini.png")) | ||
| 483 | + { | ||
| 484 | + $miniatura = "sim"; | ||
| 485 | + } | ||
| 486 | + $down = "sim"; | ||
| 487 | + if (strtolower($t["download_tema"]) == "nao") | ||
| 488 | + { | ||
| 489 | + $down = "nao"; | ||
| 490 | + } | ||
| 491 | + $texto = array("codigo_tema"=>$tema["codigo_tema"],"miniatura"=>$miniatura,"tid"=>$tema["codigo_tema"],"nome"=>$this->converte($tema["nome_tema"]),"link"=>$t["link_tema"],"download"=>$down); | ||
| 492 | + $n = abs($t["nacessos"] / $fatorestrela); | ||
| 493 | + if($n >= 5){ | ||
| 494 | + $n = 5; | ||
| 495 | + } | ||
| 496 | + if ($n == $nivel) | ||
| 497 | + { | ||
| 498 | + $resultado[] = $texto; | ||
| 499 | + } | ||
| 500 | + } | ||
| 501 | + } | ||
| 502 | + } | ||
| 503 | + if (count($resultado) > 0) | ||
| 504 | + { | ||
| 505 | + $subgrupo[] = array("subgrupo"=>$this->converte($sgrupo["nome_subgrupo"]),"temas"=>$resultado); | ||
| 506 | + } | ||
| 507 | + $resultado = array(); | ||
| 508 | + } | ||
| 509 | + } | ||
| 510 | + if (count($subgrupo) > 0 || count($temasRaizGrupo) > 0) | ||
| 511 | + { | ||
| 512 | + $final[] = array("grupo"=>$this->converte($grupo["nome_grupo"]),"temas"=>$temasRaizGrupo,"subgrupos"=>$subgrupo); | ||
| 513 | + } | ||
| 514 | + $subgrupo = array(); | ||
| 515 | + } | ||
| 516 | + } | ||
| 517 | + return $final; | ||
| 518 | + } | ||
| 519 | + /* | ||
| 520 | + Function: pegaGruposMenu | ||
| 521 | + | ||
| 522 | + Retorna a lista de grupos de um menu | ||
| 523 | + | ||
| 524 | + Parametros: | ||
| 525 | + | ||
| 526 | + id_menu {string} | ||
| 527 | + | ||
| 528 | + Return: | ||
| 529 | + | ||
| 530 | + {array} | ||
| 531 | + */ | ||
| 532 | + function pegaGruposMenu($id_menu,$ordenaNome="nao"){ | ||
| 533 | + if($ordenaNome == "sim"){ | ||
| 534 | + $ordem = "nome_grupo"; | ||
| 535 | + } | ||
| 536 | + else{ | ||
| 537 | + $ordem = "ordem"; | ||
| 538 | + } | ||
| 539 | + $sqlgrupos = $this->sql_grupos."where ".$this->pubsql." id_menu='$id_menu' order by $ordem"; | ||
| 540 | + $sqlraiz = $this->sql_temasraiz."where i3geoadmin_raiz.id_menu='$id_menu' and i3geoadmin_raiz.nivel = 0 order by ordem"; | ||
| 541 | + $grupos = $this->execSQL($sqlgrupos); | ||
| 542 | + $raiz = $this->execSQL($sqlraiz); | ||
| 543 | + $raiz = $this->validaTemas($raiz,"codigo_tema"); | ||
| 544 | + return array("raiz"=>$raiz,"grupos"=>$grupos); | ||
| 545 | + } | ||
| 546 | + /* | ||
| 547 | + Function: pegaSubgruposGrupo | ||
| 548 | + | ||
| 549 | + Retorna a lista de subgrupos de um grupo | ||
| 550 | + | ||
| 551 | + Parametros: | ||
| 552 | + | ||
| 553 | + id_menu {string} | ||
| 554 | + | ||
| 555 | + id_n1 {string} - id do grupo | ||
| 556 | + | ||
| 557 | + Return: | ||
| 558 | + | ||
| 559 | + {array} | ||
| 560 | + */ | ||
| 561 | + function pegaSubgruposGrupo($id_menu,$id_n1,$ordenaNome="nao",$filtraOgc="nao",$filtraDown="nao") | ||
| 562 | + { | ||
| 563 | + if($ordenaNome == "sim"){ | ||
| 564 | + $ordem = "nome_subgrupo"; | ||
| 565 | + } | ||
| 566 | + else{ | ||
| 567 | + $ordem = "ordem"; | ||
| 568 | + } | ||
| 569 | + $f = ""; | ||
| 570 | + if($filtraOgc == "sim" || $filtraDown == "sim"){ | ||
| 571 | + $ff = array(); | ||
| 572 | + if($filtraOgc == "sim"){ | ||
| 573 | + $ff[] = " i3geoadmin_temas.ogc_tema = 'SIM' "; | ||
| 574 | + } | ||
| 575 | + if($filtraDown == "sim"){ | ||
| 576 | + $ff[] = " i3geoadmin_temas.download_tema = 'SIM' "; | ||
| 577 | + } | ||
| 578 | + $f = implode(" AND ",$ff) . " AND "; | ||
| 579 | + } | ||
| 580 | + $subgrupos = $this->execSQL($this->sql_subgrupos."where ".$this->pubsql." i3geoadmin_n2.id_n1='$id_n1' order by $ordem"); | ||
| 581 | + $raiz = $this->execSQL($this->sql_temasraiz."where $f i3geoadmin_raiz.nivel = 1 and i3geoadmin_raiz.id_nivel = $id_n1 order by ordem"); | ||
| 582 | + $raiz = $this->validaTemas($raiz,"codigo_tema"); | ||
| 583 | + return array("raiz"=>$raiz,"subgrupos"=>$subgrupos); | ||
| 584 | + } | ||
| 585 | + /* | ||
| 586 | + Function: pegaTemasRaizMenu | ||
| 587 | + | ||
| 588 | + Retorna a lista de temas da raiz de um menu | ||
| 589 | + | ||
| 590 | + Parametros: | ||
| 591 | + | ||
| 592 | + id_menu {string} | ||
| 593 | + | ||
| 594 | + Return: | ||
| 595 | + | ||
| 596 | + {array} | ||
| 597 | + */ | ||
| 598 | + function pegaTemasRaizMenu($id_menu) | ||
| 599 | + { | ||
| 600 | + $raiz = $this->execSQL($this->sql_temasraiz."where i3geoadmin_raiz.id_menu='$id_menu' and i3geoadmin_raiz.nivel = 0 order by ordem"); | ||
| 601 | + $raiz = $this->validaTemas($raiz,"codigo_tema"); | ||
| 602 | + return $raiz; | ||
| 603 | + } | ||
| 604 | + /* | ||
| 605 | + Function: pegaTemasRaizGrupo | ||
| 606 | + | ||
| 607 | + Retorna a lista de temas da raiz de um grupo | ||
| 608 | + | ||
| 609 | + Parametros: | ||
| 610 | + | ||
| 611 | + id_menu {string} | ||
| 612 | + | ||
| 613 | + id_n1 {string} - id do grupo | ||
| 614 | + | ||
| 615 | + Return: | ||
| 616 | + | ||
| 617 | + {array} | ||
| 618 | + */ | ||
| 619 | + function pegaTemasRaizGrupo($id_menu,$id_n1,$filtraOgc="nao",$filtraDown="nao") | ||
| 620 | + { | ||
| 621 | + $f = ""; | ||
| 622 | + if($filtraOgc == "sim" || $filtraDown == "sim"){ | ||
| 623 | + $ff = array(); | ||
| 624 | + if($filtraOgc == "sim"){ | ||
| 625 | + $ff[] = " i3geoadmin_temas.ogc_tema = 'SIM' "; | ||
| 626 | + } | ||
| 627 | + if($filtraDown == "sim"){ | ||
| 628 | + $ff[] = " i3geoadmin_temas.download_tema = 'SIM' "; | ||
| 629 | + } | ||
| 630 | + $f = implode(" AND ",$ff) . " AND "; | ||
| 631 | + } | ||
| 632 | + if($id_n1 == ""){ | ||
| 633 | + $raiz = $this->execSQL($this->sql_temasraiz."where $f i3geoadmin_raiz.nivel = 1 and i3geoadmin_raiz.id_nivel > 0 order by ordem"); | ||
| 634 | + } | ||
| 635 | + else { | ||
| 636 | + $raiz = $this->execSQL($this->sql_temasraiz."where $f i3geoadmin_raiz.nivel = 1 and i3geoadmin_raiz.id_nivel = $id_n1 order by ordem"); | ||
| 637 | + } | ||
| 638 | + $raiz = $this->validaTemas($raiz,"codigo_tema"); | ||
| 639 | + return $raiz; | ||
| 640 | + } | ||
| 641 | + /* | ||
| 642 | + Function: pegaTodosTemas | ||
| 643 | + | ||
| 644 | + Retorna os dados de todos os temas | ||
| 645 | + | ||
| 646 | + Return: | ||
| 647 | + | ||
| 648 | + {array} | ||
| 649 | + */ | ||
| 650 | + function pegaTodosTemas($combo=false) | ||
| 651 | + { | ||
| 652 | + if($combo == true){ | ||
| 653 | + $q = $this->execSQL($this->sql_temas_combo." ORDER BY nome_tema ASC"); | ||
| 654 | + } | ||
| 655 | + else{ | ||
| 656 | + $q = $this->execSQL($this->sql_temas." ORDER BY nome_tema ASC"); | ||
| 657 | + } | ||
| 658 | + if($q){ | ||
| 659 | + $q = $this->validaTemas($q,"codigo_tema"); | ||
| 660 | + return $q; | ||
| 661 | + } | ||
| 662 | + } | ||
| 663 | + /* | ||
| 664 | + Function: pegaTema | ||
| 665 | + | ||
| 666 | + Retorna os dados de um tema | ||
| 667 | + | ||
| 668 | + Parametros: | ||
| 669 | + | ||
| 670 | + id_tema {string} | ||
| 671 | + | ||
| 672 | + Return: | ||
| 673 | + | ||
| 674 | + {array} | ||
| 675 | + */ | ||
| 676 | + function pegaTema($id_tema) | ||
| 677 | + { | ||
| 678 | + $q = $this->execSQL($this->sql_temas." and id_tema = '$id_tema' "); | ||
| 679 | + if($q){ | ||
| 680 | + return $q; | ||
| 681 | + } | ||
| 682 | + else{ | ||
| 683 | + //caso de banco de dados antigo | ||
| 684 | + $sql = "select kmz_tema,'0' as nacessos,id_tema,kml_tema,ogc_tema,download_tema,tags_tema,tipoa_tema,link_tema,desc_tema,nome_tema,codigo_tema from ".$this->esquemaadmin."i3geoadmin_temas "; | ||
| 685 | + $q = $this->execSQL($sql." where id_tema = '$id_tema' "); | ||
| 686 | + return $q; | ||
| 687 | + } | ||
| 688 | + } | ||
| 689 | + /* | ||
| 690 | + Function: pegaTemaPorCodigo | ||
| 691 | + | ||
| 692 | + Retorna os dados de um tema buscando por codigo | ||
| 693 | + | ||
| 694 | + Parametros: | ||
| 695 | + | ||
| 696 | + codigo_tema {string} | ||
| 697 | + | ||
| 698 | + Return: | ||
| 699 | + | ||
| 700 | + {array} | ||
| 701 | + */ | ||
| 702 | + function pegaTemaPorCodigo($codigo_tema) | ||
| 703 | + { | ||
| 704 | + $q = $this->execSQL($this->sql_temas." and codigo_tema = '$codigo_tema' "); | ||
| 705 | + if($q){ | ||
| 706 | + return $q; | ||
| 707 | + } | ||
| 708 | + else{ | ||
| 709 | + //caso de banco de dados antigo | ||
| 710 | + $sql = "select kmz_tema,'0' as nacessos,id_tema,kml_tema,ogc_tema,download_tema,tags_tema,tipoa_tema,link_tema,desc_tema,nome_tema,codigo_tema from ".$this->esquemaadmin."i3geoadmin_temas "; | ||
| 711 | + $q = $this->execSQL($sql." where codigo_tema = '$codigo_tema' "); | ||
| 712 | + return $q; | ||
| 713 | + } | ||
| 714 | + } | ||
| 715 | + /* | ||
| 716 | + Function: pegaTemasSubGrupo | ||
| 717 | + | ||
| 718 | + Retorna os temas de um subgrupo | ||
| 719 | + | ||
| 720 | + Parametros: | ||
| 721 | + | ||
| 722 | + id_n2 {string} - id do subgrupo | ||
| 723 | + | ||
| 724 | + Return: | ||
| 725 | + | ||
| 726 | + {array} | ||
| 727 | + */ | ||
| 728 | + function pegaTemasSubGrupo($id_n2,$filtraOgc="nao",$filtraDown="nao") | ||
| 729 | + { | ||
| 730 | + $f = ""; | ||
| 731 | + if($filtraOgc == "sim" || $filtraDown == "sim"){ | ||
| 732 | + $ff = array(); | ||
| 733 | + if($filtraOgc == "sim"){ | ||
| 734 | + $ff[] = " i3geoadmin_temas.ogc_tema = 'SIM' "; | ||
| 735 | + } | ||
| 736 | + if($filtraDown == "sim"){ | ||
| 737 | + $ff[] = " i3geoadmin_temas.download_tema = 'SIM' "; | ||
| 738 | + } | ||
| 739 | + $f = implode(" AND ",$ff) . " AND "; | ||
| 740 | + } | ||
| 741 | + $temas = $this->execSQL($this->sql_temasSubgrupo."where $f ".$this->pubsql." i3geoadmin_n3.id_n2='$id_n2' order by ordem"); | ||
| 742 | + $temas = $this->validaTemas($temas,"codigo_tema"); | ||
| 743 | + return $temas; | ||
| 744 | + } | ||
| 745 | + /* | ||
| 746 | + Function: formataMenus | ||
| 747 | + | ||
| 748 | + Retorna os menus e temas na raiz de um menu, formatados no padrão da árvore | ||
| 749 | + | ||
| 750 | + Return: | ||
| 751 | + | ||
| 752 | + {array} | ||
| 753 | + */ | ||
| 754 | + function formataMenus(){ | ||
| 755 | + } | ||
| 756 | + /* | ||
| 757 | + Function: formataGruposMenu | ||
| 758 | + | ||
| 759 | + Retorna os grupos e temas na raiz de um menu, formatados no padrão da árvore | ||
| 760 | + | ||
| 761 | + Parametros: | ||
| 762 | + | ||
| 763 | + id_menu {string} | ||
| 764 | + | ||
| 765 | + perfil {string} | ||
| 766 | + | ||
| 767 | + listasgrupos {string} - sim|nao | ||
| 768 | + | ||
| 769 | + Return: | ||
| 770 | + | ||
| 771 | + {array} | ||
| 772 | + */ | ||
| 773 | + function formataGruposMenu ($id_menu,$perfil,$listasgrupos,$ordenaNome="nao",$filtraOgc="nao",$filtraDown="nao") | ||
| 774 | + { | ||
| 775 | + //error_reporting(0); | ||
| 776 | + $dados = $this->pegaGruposMenu($id_menu,$ordenaNome); | ||
| 777 | + $resultado = array(); | ||
| 778 | + $temasraiz = array(); | ||
| 779 | + foreach($dados["raiz"] as $temar){ | ||
| 780 | + $temasraiz[] = $this->formataTema($temar["id_tema"]); | ||
| 781 | + } | ||
| 782 | + if(count($dados["grupos"]) == 0){ | ||
| 783 | + $grupos[] = array(); | ||
| 784 | + } | ||
| 785 | + $raizgrupos = $this->pegaTemasRaizGrupo($id_menu,"",$filtraOgc,$filtraDown); | ||
| 786 | + //var_dump($raizgrupos);exit; | ||
| 787 | + foreach($dados["grupos"] as $grupo) { | ||
| 788 | + $a = $grupo["n1_perfil"]; | ||
| 789 | + $a = str_replace(" ",",",$a); | ||
| 790 | + if($this->verificaOcorrencia($perfil,explode(",",$a)) == true) | ||
| 791 | + { | ||
| 792 | + $temas = array(); | ||
| 793 | + //$raizgrupo = $this->pegaTemasRaizGrupo($id_menu,$grupo["id_n1"],$filtraOgc,$filtraDown); | ||
| 794 | + $grupodown = "nao"; | ||
| 795 | + $grupoogc = "nao"; | ||
| 796 | + foreach($raizgrupos as $tema){ | ||
| 797 | + if($tema["id_nivel"] == $grupo["id_n1"]){ | ||
| 798 | + $temas[] = $this->formataTema($tema["id_tema"]); | ||
| 799 | + } | ||
| 800 | + } | ||
| 801 | + if($temas > 0){ | ||
| 802 | + $grupodown = "sim"; | ||
| 803 | + $grupoogc = "sim"; | ||
| 804 | + } | ||
| 805 | + $subgrupos = array(); | ||
| 806 | + if($listasgrupos=="sim"){ | ||
| 807 | + $dadossubgrupos = $this->pegaSubgruposGrupo($id_menu,$grupo["id_n1"],$ordenaNome,$filtraOgc,$filtraDown); | ||
| 808 | + foreach($dadossubgrupos["subgrupos"] as $sgrupo){ | ||
| 809 | + $a = $sgrupo["n2_perfil"]; | ||
| 810 | + $a = str_replace(" ",",",$a); | ||
| 811 | + if($this->verificaOcorrencia($perfil,explode(",",$a))){ | ||
| 812 | + //verifica se existem temas que podem receber download | ||
| 813 | + $down = "nao"; | ||
| 814 | + $ogc = "nao"; | ||
| 815 | + $listaT = $this->pegaTemasSubGrupo($sgrupo["id_n2"],$filtraOgc,$filtraDown); | ||
| 816 | + foreach($listaT as $tema){ | ||
| 817 | + if(strtolower($tema["tipoa_tema"]) != "wms") | ||
| 818 | + { | ||
| 819 | + if (strtolower($tema["download_tema"]) != "nao") | ||
| 820 | + { | ||
| 821 | + $down = "sim";$grupodown = "sim"; | ||
| 822 | + } | ||
| 823 | + | ||
| 824 | + if (strtolower($tema["ogc_tema"]) != "nao") | ||
| 825 | + { | ||
| 826 | + $ogc = "sim";$grupoogc = "sim"; | ||
| 827 | + } | ||
| 828 | + } | ||
| 829 | + } | ||
| 830 | + if(count($listaT) > 0){ | ||
| 831 | + $subgrupos[] = array("id_n2"=>$sgrupo["id_n2"],"publicado"=>($sgrupo["publicado"]),"nome"=>$this->converte($sgrupo["nome_subgrupo"]),"download"=>$down,"ogc"=>$ogc); | ||
| 832 | + } | ||
| 833 | + } | ||
| 834 | + } | ||
| 835 | + } | ||
| 836 | + //evita ocorrencias vazias quando for aplicado um filtro | ||
| 837 | + if($filtraOgc == "sim" || $filtraDown == "sim"){ | ||
| 838 | + if(count($subgrupos) > 0 || count($temas) > 0){ | ||
| 839 | + $grupos[] = array("publicado"=>($grupo["publicado"]),"id_n1"=>($grupo["id_n1"]),"nome"=>$this->converte($grupo["nome_grupo"]),"ogc"=>$grupoogc,"download"=>$grupodown,"subgrupos"=>$subgrupos,"temasgrupo"=>$temas); | ||
| 840 | + } | ||
| 841 | + } | ||
| 842 | + else{ | ||
| 843 | + $grupos[] = array("publicado"=>($grupo["publicado"]),"id_n1"=>($grupo["id_n1"]),"nome"=>$this->converte($grupo["nome_grupo"]),"ogc"=>$grupoogc,"download"=>$grupodown,"subgrupos"=>$subgrupos,"temasgrupo"=>$temas); | ||
| 844 | + } | ||
| 845 | + } | ||
| 846 | + } | ||
| 847 | + $grupos[] = array("temasraiz"=>$temasraiz); | ||
| 848 | + //pega os sistemas checando os perfis | ||
| 849 | + $sistemas = array(); | ||
| 850 | + $grupos[] = array("idmenu"=>$id_menu); | ||
| 851 | + $grupos[] = array("sistemas"=>""); | ||
| 852 | + return($grupos); | ||
| 853 | + } | ||
| 854 | + /* | ||
| 855 | + Function: formataSubgruposGrupo | ||
| 856 | + | ||
| 857 | + Retorna os subgrupos e temas na raiz de um grupo, formatados no padrão da árvore | ||
| 858 | + | ||
| 859 | + Parametros: | ||
| 860 | + | ||
| 861 | + id_menu {string} | ||
| 862 | + | ||
| 863 | + id_n1 {string} - id do grupo | ||
| 864 | + | ||
| 865 | + perfil {string} | ||
| 866 | + | ||
| 867 | + Return: | ||
| 868 | + | ||
| 869 | + {array} | ||
| 870 | + */ | ||
| 871 | + function formataSubgruposGrupo ($id_menu,$id_n1,$perfil) | ||
| 872 | + { | ||
| 873 | + $dados = $this->pegaSubgruposGrupo($id_menu,$id_n1); | ||
| 874 | + $resultado = array(); | ||
| 875 | + $temasraiz = array(); | ||
| 876 | + foreach($dados["raiz"] as $temar) | ||
| 877 | + { | ||
| 878 | + $temasraiz[] = $this->formataTema($temar["id_tema"]); | ||
| 879 | + } | ||
| 880 | + if(count($dados["subgrupos"]) == 0) | ||
| 881 | + { | ||
| 882 | + $sgrupos[] = array(); | ||
| 883 | + } | ||
| 884 | + $subgrupos = array(); | ||
| 885 | + foreach($dados["subgrupos"] as $sgrupo) | ||
| 886 | + { | ||
| 887 | + $a = $sgrupo["n2_perfil"]; | ||
| 888 | + $a = str_replace(" ",",",$a); | ||
| 889 | + if ($this->verificaOcorrencia($perfil,explode(",",$a))) | ||
| 890 | + { | ||
| 891 | + $listaT = $this->pegaTemasSubGrupo($sgrupo["id_n2"]); | ||
| 892 | + $down = "nao"; | ||
| 893 | + $ogc = "nao"; | ||
| 894 | + foreach($listaT as $tema) | ||
| 895 | + { | ||
| 896 | + if(strtolower($tema["tipoa_tema"]) != "wms") | ||
| 897 | + { | ||
| 898 | + if (strtolower($tema["download_tema"]) != "nao") | ||
| 899 | + { | ||
| 900 | + $down = "sim"; | ||
| 901 | + } | ||
| 902 | + if (strtolower($tema["ogc_tema"]) != "nao") | ||
| 903 | + { | ||
| 904 | + $ogc = "sim"; | ||
| 905 | + } | ||
| 906 | + } | ||
| 907 | + } | ||
| 908 | + if(count($listaT) > 0) | ||
| 909 | + { | ||
| 910 | + $subgrupos[] = array("publicado"=>($sgrupo["publicado"]),"id_n2"=>($sgrupo["id_n2"]),"nome"=>$this->converte($sgrupo["nome_subgrupo"]),"download"=>$down,"ogc"=>$ogc,"temas"=>$listaT); | ||
| 911 | + } | ||
| 912 | + } | ||
| 913 | + } | ||
| 914 | + return (array("subgrupo"=>$subgrupos,"temasgrupo"=>$temasraiz)); | ||
| 915 | + } | ||
| 916 | + /* | ||
| 917 | + Function: formataTemasSubgrupo | ||
| 918 | + | ||
| 919 | + Retorna os temas de um subgrupo, formatados no padrão da árvore | ||
| 920 | + | ||
| 921 | + Parametros: | ||
| 922 | + | ||
| 923 | + id_n2 {string} - id do subgrupo | ||
| 924 | + | ||
| 925 | + perfil {string} | ||
| 926 | + | ||
| 927 | + Return: | ||
| 928 | + | ||
| 929 | + {array} | ||
| 930 | + */ | ||
| 931 | + function formataTemasSubgrupo($id_n2,$perfil) | ||
| 932 | + { | ||
| 933 | + $dados = $this->pegaTemasSubGrupo($id_n2); | ||
| 934 | + $temas = array(); | ||
| 935 | + foreach($dados as $tema) | ||
| 936 | + { | ||
| 937 | + $a = $tema["n3_perfil"]; | ||
| 938 | + $a = str_replace(" ",",",$a); | ||
| 939 | + if($this->verificaOcorrencia($perfil,explode(",",$a))) | ||
| 940 | + { | ||
| 941 | + $temas[] = $this->formataTema($tema["id_tema"],$tema["publicado"]); | ||
| 942 | + } | ||
| 943 | + } | ||
| 944 | + return $temas; | ||
| 945 | + } | ||
| 946 | + /* | ||
| 947 | + Function: formataTema | ||
| 948 | + | ||
| 949 | + Retorna os dados de um tema, formatados no padrão da árvore | ||
| 950 | + | ||
| 951 | + Parametros: | ||
| 952 | + | ||
| 953 | + id_tema {string} | ||
| 954 | + | ||
| 955 | + publicado {string} - SIM|NAO valor do índice "publicado" que será incluído no array de retorno | ||
| 956 | + | ||
| 957 | + Return: | ||
| 958 | + | ||
| 959 | + {array} | ||
| 960 | + */ | ||
| 961 | + function formataTema($id_tema,$publicado="SIM") | ||
| 962 | + { | ||
| 963 | + $recordset = $this->pegaTema($id_tema); | ||
| 964 | + $recordset = $recordset[0]; | ||
| 965 | + $down = "sim"; | ||
| 966 | + $ogc = "sim"; | ||
| 967 | + $link = " "; | ||
| 968 | + $kmz = "nao"; | ||
| 969 | + if (strtolower($recordset["download_tema"]) == "nao") | ||
| 970 | + { | ||
| 971 | + $down = "nao"; | ||
| 972 | + } | ||
| 973 | + if (strtolower($recordset["ogc_tema"]) == "nao") | ||
| 974 | + { | ||
| 975 | + $ogc = "nao"; | ||
| 976 | + } | ||
| 977 | + if(strtolower($recordset["tipoa_tema"]) == "wms") | ||
| 978 | + { | ||
| 979 | + $down = "nao"; | ||
| 980 | + $ogc = "nao"; | ||
| 981 | + } | ||
| 982 | + if ($recordset["link_tema"] != "") | ||
| 983 | + { | ||
| 984 | + $link = $recordset["link_tema"]; | ||
| 985 | + } | ||
| 986 | + if (strtolower($recordset["kmz_tema"]) == "sim") | ||
| 987 | + { | ||
| 988 | + $kmz = "sim"; | ||
| 989 | + } | ||
| 990 | + //codigo_tema para fins de compatibilidade | ||
| 991 | + return array("codigo_tema"=>($recordset["codigo_tema"]),"tipoa_tema"=>$recordset["tipoa_tema"],"publicado"=>$publicado,"nacessos"=>($recordset["nacessos"]),"tid"=>($recordset["codigo_tema"]),"nome"=>$this->converte($recordset["nome_tema"]),"link"=>$link,"download"=>$down,"ogc"=>$ogc,"kmz"=>$kmz); | ||
| 992 | + } | ||
| 993 | + /* | ||
| 994 | + Function: execSQL | ||
| 995 | + | ||
| 996 | + Executa um SQL no banco de administração | ||
| 997 | + | ||
| 998 | + Parametros: | ||
| 999 | + | ||
| 1000 | + sql {string} | ||
| 1001 | + | ||
| 1002 | + Return: | ||
| 1003 | + | ||
| 1004 | + {array} | ||
| 1005 | + */ | ||
| 1006 | + function execSQL($sql) | ||
| 1007 | + { | ||
| 1008 | + //echo "<br>".$sql; | ||
| 1009 | + //error_reporting(0); | ||
| 1010 | + $sql = str_ireplace(array("update","delete","insert","--","drop",";"),"",$sql); | ||
| 1011 | + $q = $this->dbh->query($sql,PDO::FETCH_ASSOC); | ||
| 1012 | + if($q) | ||
| 1013 | + { | ||
| 1014 | + return $q->fetchAll(); | ||
| 1015 | + } | ||
| 1016 | + else | ||
| 1017 | + {return false; | ||
| 1018 | + } | ||
| 1019 | + } | ||
| 1020 | + /* | ||
| 1021 | + Verifica se uma string ocorre em um array | ||
| 1022 | + */ | ||
| 1023 | + function verificaOcorrencia($procurar,$em) | ||
| 1024 | + { | ||
| 1025 | + if(count($em) == 1 && $em[0] == "") | ||
| 1026 | + { | ||
| 1027 | + $em = ""; | ||
| 1028 | + } | ||
| 1029 | + if($procurar == "" && $em == "") | ||
| 1030 | + { | ||
| 1031 | + return true; | ||
| 1032 | + } | ||
| 1033 | + if($em == "") | ||
| 1034 | + { | ||
| 1035 | + return true; | ||
| 1036 | + } | ||
| 1037 | + $resultado = false; | ||
| 1038 | + if($procurar != "" && $em != "") | ||
| 1039 | + { | ||
| 1040 | + foreach($em as $e) | ||
| 1041 | + { | ||
| 1042 | + $e = trim($e); | ||
| 1043 | + foreach($procurar as $p) | ||
| 1044 | + { | ||
| 1045 | + $p = trim($p); | ||
| 1046 | + if($p == $e) | ||
| 1047 | + { | ||
| 1048 | + $resultado = true; | ||
| 1049 | + } | ||
| 1050 | + } | ||
| 1051 | + } | ||
| 1052 | + } | ||
| 1053 | + return $resultado; | ||
| 1054 | + } | ||
| 1055 | + function seems_utf8($Str) { # by bmorel at ssi dot fr | ||
| 1056 | + $length = strlen($Str); | ||
| 1057 | + for ($i = 0; $i < $length; $i++) { | ||
| 1058 | + if (ord($Str[$i]) < 0x80) continue; # 0bbbbbbb | ||
| 1059 | + elseif ((ord($Str[$i]) & 0xE0) == 0xC0) $n = 1; # 110bbbbb | ||
| 1060 | + elseif ((ord($Str[$i]) & 0xF0) == 0xE0) $n = 2; # 1110bbbb | ||
| 1061 | + elseif ((ord($Str[$i]) & 0xF8) == 0xF0) $n = 3; # 11110bbb | ||
| 1062 | + elseif ((ord($Str[$i]) & 0xFC) == 0xF8) $n = 4; # 111110bb | ||
| 1063 | + elseif ((ord($Str[$i]) & 0xFE) == 0xFC) $n = 5; # 1111110b | ||
| 1064 | + else return false; # Does not match any model | ||
| 1065 | + for ($j = 0; $j < $n; $j++) { # n bytes matching 10bbbbbb follow ? | ||
| 1066 | + if ((++$i == $length) || ((ord($Str[$i]) & 0xC0) != 0x80)) | ||
| 1067 | + return false; | ||
| 1068 | + } | ||
| 1069 | + } | ||
| 1070 | + return true; | ||
| 1071 | + } | ||
| 1072 | + /** | ||
| 1073 | + * | ||
| 1074 | + * TODO Verificar ao fechar versao - verificar a acentuacao das palavras nessa funcao | ||
| 1075 | + */ | ||
| 1076 | + function removeAcentos($s) | ||
| 1077 | + { | ||
| 1078 | + $s = ereg_replace("[áàâã]","a",$s); | ||
| 1079 | + $s = ereg_replace("[ÁÀÂÃ]","A",$s); | ||
| 1080 | + $s = ereg_replace("[éèê]","e",$s); | ||
| 1081 | + $s = ereg_replace("[í]","i",$s); | ||
| 1082 | + $s = ereg_replace("[Í]","I",$s); | ||
| 1083 | + $s = ereg_replace("[ÉÈÊ]","E",$s); | ||
| 1084 | + $s = ereg_replace("[óòôõ]","o",$s); | ||
| 1085 | + $s = ereg_replace("[ÓÒÔÕ]","O",$s); | ||
| 1086 | + $s = ereg_replace("[úùû]","u",$s); | ||
| 1087 | + $s = ereg_replace("[ÚÙÛ]","U",$s); | ||
| 1088 | + $s = str_replace("ç","c",$s); | ||
| 1089 | + $s = str_replace("Ç","C",$s); | ||
| 1090 | + //$str = htmlentities($s); | ||
| 1091 | + $str = preg_replace("/(&)([a-z])([a-z]+;)/i", '$2', $s); | ||
| 1092 | + $str = preg_replace("/[^A-Z0-9]/i", ' ', $str); | ||
| 1093 | + $string = preg_replace("/\s+/i", ' ', $str); | ||
| 1094 | + | ||
| 1095 | + if (!preg_match('/[\x80-\xff]/', $string)){ | ||
| 1096 | + return $string; | ||
| 1097 | + } | ||
| 1098 | + if ($this->seems_utf8($string)) { | ||
| 1099 | + $chars = array( | ||
| 1100 | + // Decompositions for Latin-1 Supplement | ||
| 1101 | + chr(195).chr(128) => 'A', chr(195).chr(129) => 'A', | ||
| 1102 | + chr(195).chr(130) => 'A', chr(195).chr(131) => 'A', | ||
| 1103 | + chr(195).chr(132) => 'A', chr(195).chr(133) => 'A', | ||
| 1104 | + chr(195).chr(135) => 'C', chr(195).chr(136) => 'E', | ||
| 1105 | + chr(195).chr(137) => 'E', chr(195).chr(138) => 'E', | ||
| 1106 | + chr(195).chr(139) => 'E', chr(195).chr(140) => 'I', | ||
| 1107 | + chr(195).chr(141) => 'I', chr(195).chr(142) => 'I', | ||
| 1108 | + chr(195).chr(143) => 'I', chr(195).chr(145) => 'N', | ||
| 1109 | + chr(195).chr(146) => 'O', chr(195).chr(147) => 'O', | ||
| 1110 | + chr(195).chr(148) => 'O', chr(195).chr(149) => 'O', | ||
| 1111 | + chr(195).chr(150) => 'O', chr(195).chr(153) => 'U', | ||
| 1112 | + chr(195).chr(154) => 'U', chr(195).chr(155) => 'U', | ||
| 1113 | + chr(195).chr(156) => 'U', chr(195).chr(157) => 'Y', | ||
| 1114 | + chr(195).chr(159) => 's', chr(195).chr(160) => 'a', | ||
| 1115 | + chr(195).chr(161) => 'a', chr(195).chr(162) => 'a', | ||
| 1116 | + chr(195).chr(163) => 'a', chr(195).chr(164) => 'a', | ||
| 1117 | + chr(195).chr(165) => 'a', chr(195).chr(167) => 'c', | ||
| 1118 | + chr(195).chr(168) => 'e', chr(195).chr(169) => 'e', | ||
| 1119 | + chr(195).chr(170) => 'e', chr(195).chr(171) => 'e', | ||
| 1120 | + chr(195).chr(172) => 'i', chr(195).chr(173) => 'i', | ||
| 1121 | + chr(195).chr(174) => 'i', chr(195).chr(175) => 'i', | ||
| 1122 | + chr(195).chr(177) => 'n', chr(195).chr(178) => 'o', | ||
| 1123 | + chr(195).chr(179) => 'o', chr(195).chr(180) => 'o', | ||
| 1124 | + chr(195).chr(181) => 'o', chr(195).chr(182) => 'o', | ||
| 1125 | + chr(195).chr(182) => 'o', chr(195).chr(185) => 'u', | ||
| 1126 | + chr(195).chr(186) => 'u', chr(195).chr(187) => 'u', | ||
| 1127 | + chr(195).chr(188) => 'u', chr(195).chr(189) => 'y', | ||
| 1128 | + chr(195).chr(191) => 'y', | ||
| 1129 | + // Decompositions for Latin Extended-A | ||
| 1130 | + chr(196).chr(128) => 'A', chr(196).chr(129) => 'a', | ||
| 1131 | + chr(196).chr(130) => 'A', chr(196).chr(131) => 'a', | ||
| 1132 | + chr(196).chr(132) => 'A', chr(196).chr(133) => 'a', | ||
| 1133 | + chr(196).chr(134) => 'C', chr(196).chr(135) => 'c', | ||
| 1134 | + chr(196).chr(136) => 'C', chr(196).chr(137) => 'c', | ||
| 1135 | + chr(196).chr(138) => 'C', chr(196).chr(139) => 'c', | ||
| 1136 | + chr(196).chr(140) => 'C', chr(196).chr(141) => 'c', | ||
| 1137 | + chr(196).chr(142) => 'D', chr(196).chr(143) => 'd', | ||
| 1138 | + chr(196).chr(144) => 'D', chr(196).chr(145) => 'd', | ||
| 1139 | + chr(196).chr(146) => 'E', chr(196).chr(147) => 'e', | ||
| 1140 | + chr(196).chr(148) => 'E', chr(196).chr(149) => 'e', | ||
| 1141 | + chr(196).chr(150) => 'E', chr(196).chr(151) => 'e', | ||
| 1142 | + chr(196).chr(152) => 'E', chr(196).chr(153) => 'e', | ||
| 1143 | + chr(196).chr(154) => 'E', chr(196).chr(155) => 'e', | ||
| 1144 | + chr(196).chr(156) => 'G', chr(196).chr(157) => 'g', | ||
| 1145 | + chr(196).chr(158) => 'G', chr(196).chr(159) => 'g', | ||
| 1146 | + chr(196).chr(160) => 'G', chr(196).chr(161) => 'g', | ||
| 1147 | + chr(196).chr(162) => 'G', chr(196).chr(163) => 'g', | ||
| 1148 | + chr(196).chr(164) => 'H', chr(196).chr(165) => 'h', | ||
| 1149 | + chr(196).chr(166) => 'H', chr(196).chr(167) => 'h', | ||
| 1150 | + chr(196).chr(168) => 'I', chr(196).chr(169) => 'i', | ||
| 1151 | + chr(196).chr(170) => 'I', chr(196).chr(171) => 'i', | ||
| 1152 | + chr(196).chr(172) => 'I', chr(196).chr(173) => 'i', | ||
| 1153 | + chr(196).chr(174) => 'I', chr(196).chr(175) => 'i', | ||
| 1154 | + chr(196).chr(176) => 'I', chr(196).chr(177) => 'i', | ||
| 1155 | + chr(196).chr(178) => 'IJ',chr(196).chr(179) => 'ij', | ||
| 1156 | + chr(196).chr(180) => 'J', chr(196).chr(181) => 'j', | ||
| 1157 | + chr(196).chr(182) => 'K', chr(196).chr(183) => 'k', | ||
| 1158 | + chr(196).chr(184) => 'k', chr(196).chr(185) => 'L', | ||
| 1159 | + chr(196).chr(186) => 'l', chr(196).chr(187) => 'L', | ||
| 1160 | + chr(196).chr(188) => 'l', chr(196).chr(189) => 'L', | ||
| 1161 | + chr(196).chr(190) => 'l', chr(196).chr(191) => 'L', | ||
| 1162 | + chr(197).chr(128) => 'l', chr(197).chr(129) => 'L', | ||
| 1163 | + chr(197).chr(130) => 'l', chr(197).chr(131) => 'N', | ||
| 1164 | + chr(197).chr(132) => 'n', chr(197).chr(133) => 'N', | ||
| 1165 | + chr(197).chr(134) => 'n', chr(197).chr(135) => 'N', | ||
| 1166 | + chr(197).chr(136) => 'n', chr(197).chr(137) => 'N', | ||
| 1167 | + chr(197).chr(138) => 'n', chr(197).chr(139) => 'N', | ||
| 1168 | + chr(197).chr(140) => 'O', chr(197).chr(141) => 'o', | ||
| 1169 | + chr(197).chr(142) => 'O', chr(197).chr(143) => 'o', | ||
| 1170 | + chr(197).chr(144) => 'O', chr(197).chr(145) => 'o', | ||
| 1171 | + chr(197).chr(146) => 'OE',chr(197).chr(147) => 'oe', | ||
| 1172 | + chr(197).chr(148) => 'R',chr(197).chr(149) => 'r', | ||
| 1173 | + chr(197).chr(150) => 'R',chr(197).chr(151) => 'r', | ||
| 1174 | + chr(197).chr(152) => 'R',chr(197).chr(153) => 'r', | ||
| 1175 | + chr(197).chr(154) => 'S',chr(197).chr(155) => 's', | ||
| 1176 | + chr(197).chr(156) => 'S',chr(197).chr(157) => 's', | ||
| 1177 | + chr(197).chr(158) => 'S',chr(197).chr(159) => 's', | ||
| 1178 | + chr(197).chr(160) => 'S', chr(197).chr(161) => 's', | ||
| 1179 | + chr(197).chr(162) => 'T', chr(197).chr(163) => 't', | ||
| 1180 | + chr(197).chr(164) => 'T', chr(197).chr(165) => 't', | ||
| 1181 | + chr(197).chr(166) => 'T', chr(197).chr(167) => 't', | ||
| 1182 | + chr(197).chr(168) => 'U', chr(197).chr(169) => 'u', | ||
| 1183 | + chr(197).chr(170) => 'U', chr(197).chr(171) => 'u', | ||
| 1184 | + chr(197).chr(172) => 'U', chr(197).chr(173) => 'u', | ||
| 1185 | + chr(197).chr(174) => 'U', chr(197).chr(175) => 'u', | ||
| 1186 | + chr(197).chr(176) => 'U', chr(197).chr(177) => 'u', | ||
| 1187 | + chr(197).chr(178) => 'U', chr(197).chr(179) => 'u', | ||
| 1188 | + chr(197).chr(180) => 'W', chr(197).chr(181) => 'w', | ||
| 1189 | + chr(197).chr(182) => 'Y', chr(197).chr(183) => 'y', | ||
| 1190 | + chr(197).chr(184) => 'Y', chr(197).chr(185) => 'Z', | ||
| 1191 | + chr(197).chr(186) => 'z', chr(197).chr(187) => 'Z', | ||
| 1192 | + chr(197).chr(188) => 'z', chr(197).chr(189) => 'Z', | ||
| 1193 | + chr(197).chr(190) => 'z', chr(197).chr(191) => 's', | ||
| 1194 | + // Euro Sign | ||
| 1195 | + chr(226).chr(130).chr(172) => 'E', | ||
| 1196 | + // GBP (Pound) Sign | ||
| 1197 | + chr(194).chr(163) => ''); | ||
| 1198 | + $string = strtr($string, $chars); | ||
| 1199 | + } else { | ||
| 1200 | + // Assume ISO-8859-1 if not UTF-8 | ||
| 1201 | + $chars['in'] = chr(128).chr(131).chr(138).chr(142).chr(154).chr(158) | ||
| 1202 | + .chr(159).chr(162).chr(165).chr(181).chr(192).chr(193).chr(194) | ||
| 1203 | + .chr(195).chr(196).chr(197).chr(199).chr(200).chr(201).chr(202) | ||
| 1204 | + .chr(203).chr(204).chr(205).chr(206).chr(207).chr(209).chr(210) | ||
| 1205 | + .chr(211).chr(212).chr(213).chr(214).chr(216).chr(217).chr(218) | ||
| 1206 | + .chr(219).chr(220).chr(221).chr(224).chr(225).chr(226).chr(227) | ||
| 1207 | + .chr(228).chr(229).chr(231).chr(232).chr(233).chr(234).chr(235) | ||
| 1208 | + .chr(236).chr(237).chr(238).chr(239).chr(241).chr(242).chr(243) | ||
| 1209 | + .chr(244).chr(245).chr(246).chr(248).chr(249).chr(250).chr(251) | ||
| 1210 | + .chr(252).chr(253).chr(255); | ||
| 1211 | + $chars['out'] = "EfSZszYcYuAAAAAACEEEEIIIINOOOOOOUUUUYaaaaaaceeeeiiiinoooooouuuuyy"; | ||
| 1212 | + $string = strtr($string, $chars['in'], $chars['out']); | ||
| 1213 | + $double_chars['in'] = array(chr(140), chr(156), chr(198), chr(208), chr(222), chr(223), chr(230), chr(240), chr(254)); | ||
| 1214 | + $double_chars['out'] = array('OE', 'oe', 'AE', 'DH', 'TH', 'ss', 'ae', 'dh', 'th'); | ||
| 1215 | + $string = str_replace($double_chars['in'], $double_chars['out'], $string); | ||
| 1216 | + } | ||
| 1217 | + return $string; | ||
| 1218 | + } | ||
| 1219 | + function converte($texto){ | ||
| 1220 | + if($this->convUTF == true) | ||
| 1221 | + $texto = mb_convert_encoding($texto,mb_detect_encoding($texto),"UTF-8"); | ||
| 1222 | + else | ||
| 1223 | + $texto = mb_convert_encoding($texto,mb_detect_encoding($texto),"ISO-8859-1"); | ||
| 1224 | + return $texto; | ||
| 1225 | + } | ||
| 1226 | + function verificaPapelSessao($id_papel){ | ||
| 1227 | + if(!empty($_COOKIE["i3geocodigologin"])){ | ||
| 1228 | + session_write_close(); | ||
| 1229 | + session_name("i3GeoLogin"); | ||
| 1230 | + session_id($_COOKIE["i3geocodigologin"]); | ||
| 1231 | + session_start(); | ||
| 1232 | + //var_dump($_SESSION);exit; | ||
| 1233 | + if($_SESSION["usuario"] != $_COOKIE["i3geousuariologin"]){ | ||
| 1234 | + return false; | ||
| 1235 | + } | ||
| 1236 | + foreach($_SESSION["papeis"] as $p){ | ||
| 1237 | + if($p == 1 || $p == $id_papel){ | ||
| 1238 | + return true; | ||
| 1239 | + } | ||
| 1240 | + } | ||
| 1241 | + } | ||
| 1242 | + else{//caso nao exista, retorna um erro | ||
| 1243 | + return false; | ||
| 1244 | + } | ||
| 1245 | + } | ||
| 1246 | + function verificaOperacaoSessao($operacao){ | ||
| 1247 | + if($_COOKIE["i3geocodigologin"] != ""){ | ||
| 1248 | + session_write_close(); | ||
| 1249 | + session_name("i3GeoLogin"); | ||
| 1250 | + session_id($_COOKIE["i3geocodigologin"]); | ||
| 1251 | + session_start(); | ||
| 1252 | + $resultado = false; | ||
| 1253 | + //verifica se e administrador | ||
| 1254 | + foreach($_SESSION["papeis"] as $p){ | ||
| 1255 | + if($p == 1){ | ||
| 1256 | + return true; | ||
| 1257 | + } | ||
| 1258 | + } | ||
| 1259 | + if(!empty($_SESSION["operacoes"][$operacao])){ | ||
| 1260 | + $resultado = true; | ||
| 1261 | + } | ||
| 1262 | + return $resultado; | ||
| 1263 | + } else { | ||
| 1264 | + return false; | ||
| 1265 | + } | ||
| 1266 | + } | ||
| 1267 | +} | ||
| 1268 | +?> | ||
| 0 | \ No newline at end of file | 1269 | \ No newline at end of file |
classesphp/classe_menutemas.php
| @@ -5,7 +5,7 @@ Title: classe_menutemas.php | @@ -5,7 +5,7 @@ Title: classe_menutemas.php | ||
| 5 | Manipulação dos temas do arquivo menutemas.xml ou sistema de administração | 5 | Manipulação dos temas do arquivo menutemas.xml ou sistema de administração |
| 6 | 6 | ||
| 7 | Quando o i3Geo está configurado para acessar o sistema de administração, os métodos desta classe | 7 | Quando o i3Geo está configurado para acessar o sistema de administração, os métodos desta classe |
| 8 | -passam a utilizar a classe i3geo/admin/php/classe_arvore.php | 8 | +passam a utilizar a classe i3geo/classesphp/classe_arvore.php |
| 9 | 9 | ||
| 10 | Lista temas, grupos,etc. | 10 | Lista temas, grupos,etc. |
| 11 | 11 | ||
| @@ -113,7 +113,7 @@ array | @@ -113,7 +113,7 @@ array | ||
| 113 | $locaplic = $this->locaplic; | 113 | $locaplic = $this->locaplic; |
| 114 | if(!isset($this->locaplic)) | 114 | if(!isset($this->locaplic)) |
| 115 | {return "locaplic nao foi definido";} | 115 | {return "locaplic nao foi definido";} |
| 116 | - include_once($this->locaplic."/admin/php/classe_arvore.php"); | 116 | + include_once($this->locaplic."/classesphp/classe_arvore.php"); |
| 117 | $arvore = new Arvore($this->locaplic,$this->idioma); | 117 | $arvore = new Arvore($this->locaplic,$this->idioma); |
| 118 | $resultado = $arvore->pegaListaDeMenus($this->perfil,$filtraOgc,$filtraDown); | 118 | $resultado = $arvore->pegaListaDeMenus($this->perfil,$filtraOgc,$filtraDown); |
| 119 | $final = array(); | 119 | $final = array(); |
| @@ -155,7 +155,7 @@ array | @@ -155,7 +155,7 @@ array | ||
| 155 | else | 155 | else |
| 156 | {$tipo = "gruposeraiz";} | 156 | {$tipo = "gruposeraiz";} |
| 157 | $tempm = $this->pegaListaDeMenus($filtraOgc,$filtraDown); | 157 | $tempm = $this->pegaListaDeMenus($filtraOgc,$filtraDown); |
| 158 | - include_once(dirname(__FILE__)."/../admin/php/classe_arvore.php"); | 158 | + include_once(dirname(__FILE__)."/../classesphp/classe_arvore.php"); |
| 159 | $arvore = new Arvore($this->locaplic,$this->idioma,$this->filtro); | 159 | $arvore = new Arvore($this->locaplic,$this->idioma,$this->filtro); |
| 160 | foreach($tempm as $menu) | 160 | foreach($tempm as $menu) |
| 161 | { | 161 | { |
| @@ -192,7 +192,7 @@ array | @@ -192,7 +192,7 @@ array | ||
| 192 | { | 192 | { |
| 193 | if($menu["idmenu"] == $idmenu || $idmenu == "") | 193 | if($menu["idmenu"] == $idmenu || $idmenu == "") |
| 194 | { | 194 | { |
| 195 | - include_once(dirname(__FILE__)."/../admin/php/classe_arvore.php"); | 195 | + include_once(dirname(__FILE__)."/../classesphp/classe_arvore.php"); |
| 196 | $arvore = new Arvore($this->locaplic,$this->idioma,$this->filtro); | 196 | $arvore = new Arvore($this->locaplic,$this->idioma,$this->filtro); |
| 197 | $subGrupos = $arvore->formataSubgruposGrupo($idmenu,$codgrupo,$this->perfil); | 197 | $subGrupos = $arvore->formataSubgruposGrupo($idmenu,$codgrupo,$this->perfil); |
| 198 | unset($arvore); | 198 | unset($arvore); |
| @@ -219,7 +219,7 @@ array | @@ -219,7 +219,7 @@ array | ||
| 219 | */ | 219 | */ |
| 220 | function pegaListaDeTemas($grupo,$subgrupo,$idmenu) | 220 | function pegaListaDeTemas($grupo,$subgrupo,$idmenu) |
| 221 | { | 221 | { |
| 222 | - include_once(dirname(__FILE__)."/../admin/php/classe_arvore.php"); | 222 | + include_once(dirname(__FILE__)."/../classesphp/classe_arvore.php"); |
| 223 | $arvore = new Arvore($this->locaplic,$this->idioma); | 223 | $arvore = new Arvore($this->locaplic,$this->idioma); |
| 224 | $temas = $arvore->formataTemasSubgrupo($subgrupo,$this->perfil); | 224 | $temas = $arvore->formataTemasSubgrupo($subgrupo,$this->perfil); |
| 225 | unset($arvore); | 225 | unset($arvore); |
| @@ -384,7 +384,7 @@ $procurar - String que ser&aacute; procurada. | @@ -384,7 +384,7 @@ $procurar - String que ser&aacute; procurada. | ||
| 384 | } | 384 | } |
| 385 | else | 385 | else |
| 386 | { | 386 | { |
| 387 | - include_once(dirname(__FILE__)."/../admin/php/classe_arvore.php"); | 387 | + include_once(dirname(__FILE__)."/../classesphp/classe_arvore.php"); |
| 388 | $arvore = new Arvore($this->locaplic,$this->idioma); | 388 | $arvore = new Arvore($this->locaplic,$this->idioma); |
| 389 | $temas = $arvore->procuraTemas($procurar,$this->perfil); | 389 | $temas = $arvore->procuraTemas($procurar,$this->perfil); |
| 390 | unset($arvore); | 390 | unset($arvore); |
| @@ -495,7 +495,7 @@ $procurar - String que ser&aacute; procurada. | @@ -495,7 +495,7 @@ $procurar - String que ser&aacute; procurada. | ||
| 495 | */ | 495 | */ |
| 496 | function procurartemas2($procurar) | 496 | function procurartemas2($procurar) |
| 497 | { | 497 | { |
| 498 | - include_once(dirname(__FILE__)."/../admin/php/classe_arvore.php"); | 498 | + include_once(dirname(__FILE__)."/../classesphp/classe_arvore.php"); |
| 499 | $arvore = new Arvore($this->locaplic,$this->idioma); | 499 | $arvore = new Arvore($this->locaplic,$this->idioma); |
| 500 | $temas = $arvore->procuraTemas($procurar,$this->perfil); | 500 | $temas = $arvore->procuraTemas($procurar,$this->perfil); |
| 501 | unset($arvore); | 501 | unset($arvore); |
| @@ -514,7 +514,7 @@ $fatorestrela - valor para normalizar o total de acessos com o valor da estrela | @@ -514,7 +514,7 @@ $fatorestrela - valor para normalizar o total de acessos com o valor da estrela | ||
| 514 | */ | 514 | */ |
| 515 | function procurartemasestrela($nivel,$fatorestrela) | 515 | function procurartemasestrela($nivel,$fatorestrela) |
| 516 | { | 516 | { |
| 517 | - include_once(dirname(__FILE__)."/../admin/php/classe_arvore.php"); | 517 | + include_once(dirname(__FILE__)."/../classesphp/classe_arvore.php"); |
| 518 | $arvore = new Arvore($this->locaplic,$this->idioma); | 518 | $arvore = new Arvore($this->locaplic,$this->idioma); |
| 519 | $temas = $arvore->procuraTemasEstrela($nivel,$fatorestrela,$this->perfil); | 519 | $temas = $arvore->procuraTemasEstrela($nivel,$fatorestrela,$this->perfil); |
| 520 | unset($arvore); | 520 | unset($arvore); |
classesphp/mapa_controle.php
| @@ -1744,7 +1744,7 @@ switch (strtoupper($funcao)) { | @@ -1744,7 +1744,7 @@ switch (strtoupper($funcao)) { | ||
| 1744 | * Pega a lista de todos os temas que nao possuem restricoes de acesso | 1744 | * Pega a lista de todos os temas que nao possuem restricoes de acesso |
| 1745 | */ | 1745 | */ |
| 1746 | case "PEGATODOSTEMAS": | 1746 | case "PEGATODOSTEMAS": |
| 1747 | - include ("../admin/php/classe_arvore.php"); | 1747 | + include ("../classesphp/classe_arvore.php"); |
| 1748 | $idioma = $_pg["idioma"]; | 1748 | $idioma = $_pg["idioma"]; |
| 1749 | 1749 | ||
| 1750 | $arvore = new Arvore($locaplic, $idioma); | 1750 | $arvore = new Arvore($locaplic, $idioma); |
fontetema.php
| @@ -39,7 +39,7 @@ fontetema.php?tema=bioma | @@ -39,7 +39,7 @@ fontetema.php?tema=bioma | ||
| 39 | 39 | ||
| 40 | */ | 40 | */ |
| 41 | include(dirname(__FILE__)."/ms_configura.php"); | 41 | include(dirname(__FILE__)."/ms_configura.php"); |
| 42 | -include(dirname(__FILE__)."/admin/php/classe_arvore.php"); | 42 | +include(dirname(__FILE__)."/classesphp/classe_arvore.php"); |
| 43 | 43 | ||
| 44 | include_once (dirname(__FILE__)."/classesphp/sani_request.php"); | 44 | include_once (dirname(__FILE__)."/classesphp/sani_request.php"); |
| 45 | $_GET = array_merge($_GET,$_POST); | 45 | $_GET = array_merge($_GET,$_POST); |
interface/carto_ol.htm
| @@ -20,8 +20,6 @@ | @@ -20,8 +20,6 @@ | ||
| 20 | <!-- <link rel="stylesheet" type="text/css" href="../pacotes/bootstrap-accessibility-plugin/plugins/js/bootstrap-accessibility.min.js"> --> | 20 | <!-- <link rel="stylesheet" type="text/css" href="../pacotes/bootstrap-accessibility-plugin/plugins/js/bootstrap-accessibility.min.js"> --> |
| 21 | <link rel="stylesheet" type="text/css" href="../css/default.css"> | 21 | <link rel="stylesheet" type="text/css" href="../css/default.css"> |
| 22 | <style> | 22 | <style> |
| 23 | - | ||
| 24 | - | ||
| 25 | .ol-attribution.ol-uncollapsible { | 23 | .ol-attribution.ol-uncollapsible { |
| 26 | height: 2.1em; | 24 | height: 2.1em; |
| 27 | right: 24px; | 25 | right: 24px; |
| @@ -150,14 +148,14 @@ | @@ -150,14 +148,14 @@ | ||
| 150 | <!-- configuracao para todos os botoes | 148 | <!-- configuracao para todos os botoes |
| 151 | data-idconteudo - id do DIV que contem o conteudo da guia e que sera mostrado ao ser clicado | 149 | data-idconteudo - id do DIV que contem o conteudo da guia e que sera mostrado ao ser clicado |
| 152 | --> | 150 | --> |
| 153 | - <div class="iconesGuiaMovel" data-traduzir="true" style="right:0px;border-radius:4px; padding:2px;cursor: pointer; position: absolute; top: 5px; width: auto; z-index: 5000; background-color: rgba(255,255,255,.4);"> | 151 | + <div class="iconesGuiaMovel ol-control" data-traduzir="true"> |
| 154 | <!-- ferramentas | 152 | <!-- ferramentas |
| 155 | data-idLista - id do DIV dentro de idconteudo que sera utilizado para mostrar as "pastas" que abrem o proximo nivel | 153 | data-idLista - id do DIV dentro de idconteudo que sera utilizado para mostrar as "pastas" que abrem o proximo nivel |
| 156 | data-idLinks - id do DIV dentro de idconteudo que sera utilizado para mostrar a lista de links que abre cada ferramenta | 154 | data-idLinks - id do DIV dentro de idconteudo que sera utilizado para mostrar a lista de links que abre cada ferramenta |
| 157 | data-idMigalha - id do DIV que sera utilizado para mostrar o link de retorno ao nivel anterior | 155 | data-idMigalha - id do DIV que sera utilizado para mostrar o link de retorno ao nivel anterior |
| 158 | --> | 156 | --> |
| 159 | <div data-idconteudo="guia8obj" data-idLinks="listaFerramentasLinks" data-idMigalha="migalhaFerramentas" data-idLista="listaFerramentas" onclick="i3GEO.guias.ativa('ferramentas',this)"> | 157 | <div data-idconteudo="guia8obj" data-idLinks="listaFerramentasLinks" data-idMigalha="migalhaFerramentas" data-idLista="listaFerramentas" onclick="i3GEO.guias.ativa('ferramentas',this)"> |
| 160 | - <button title="{{{iconeFerramentas}}}" class="btn btn-default iconeGuiaMovel" style="color:white;box-shadow: none;"> | 158 | + <button title="{{{iconeFerramentas}}}" class="iconeGuiaMovel" style="color:white;box-shadow: none;"> |
| 161 | <i class="material-icons">business_center</i> | 159 | <i class="material-icons">business_center</i> |
| 162 | </button> | 160 | </button> |
| 163 | </div> | 161 | </div> |
| @@ -169,7 +167,7 @@ | @@ -169,7 +167,7 @@ | ||
| 169 | do metadata existente na camada. Deixe vazio para nao ativar a operacao. | 167 | do metadata existente na camada. Deixe vazio para nao ativar a operacao. |
| 170 | --> | 168 | --> |
| 171 | <div onclick="i3GEO.guias.ativa('temas',this)" data-verificaAbrangencia="" data-idconteudo="guia1obj" data-idListaFundo="listaFundo" data-idListaDeCamadas="listaTemas" style="margin-top: 3px;"> | 169 | <div onclick="i3GEO.guias.ativa('temas',this)" data-verificaAbrangencia="" data-idconteudo="guia1obj" data-idListaFundo="listaFundo" data-idListaDeCamadas="listaTemas" style="margin-top: 3px;"> |
| 172 | - <button title="{{{iconeMapa}}}" class="btn btn-default iconeGuiaMovel" style="color:white;box-shadow: none;"> | 170 | + <button title="{{{iconeMapa}}}" class="iconeGuiaMovel" style="color:white;box-shadow: none;"> |
| 173 | <i class="material-icons"><i class="material-icons">visibility</i></i> | 171 | <i class="material-icons"><i class="material-icons">visibility</i></i> |
| 174 | </button> | 172 | </button> |
| 175 | </div> | 173 | </div> |
| @@ -183,35 +181,35 @@ | @@ -183,35 +181,35 @@ | ||
| 183 | i3GEO.catalogoMenus.IDSMENUS - (array) apenas os menus com idmenu que constem nessa lista serao mostrados. Por default e vazio. | 181 | i3GEO.catalogoMenus.IDSMENUS - (array) apenas os menus com idmenu que constem nessa lista serao mostrados. Por default e vazio. |
| 184 | --> | 182 | --> |
| 185 | <div onclick="i3GEO.guias.ativa('adiciona',this)" data-idconteudo="guia2obj" data-idMigalha="catalogoMigalha" data-idNavegacao="catalogoNavegacao" data-idCatalogo="catalogoPrincipal" data-idMenus="catalogoMenus" style="margin-top: 3px;"> | 183 | <div onclick="i3GEO.guias.ativa('adiciona',this)" data-idconteudo="guia2obj" data-idMigalha="catalogoMigalha" data-idNavegacao="catalogoNavegacao" data-idCatalogo="catalogoPrincipal" data-idMenus="catalogoMenus" style="margin-top: 3px;"> |
| 186 | - <button title="{{{iconeCatalogo}}}" class="btn btn-default iconeGuiaMovel" style="color:white;box-shadow: none;"> | 184 | + <button title="{{{iconeCatalogo}}}" class="iconeGuiaMovel" style="color:white;box-shadow: none;"> |
| 187 | <i class="material-icons">layers</i> | 185 | <i class="material-icons">layers</i> |
| 188 | </button> | 186 | </button> |
| 189 | </div> | 187 | </div> |
| 190 | <!-- legenda --> | 188 | <!-- legenda --> |
| 191 | <div onclick="i3GEO.guias.ativa('legenda',this)" data-idconteudo="guia4obj" data-idLegenda="legendaHtml" style="margin-top: 3px;"> | 189 | <div onclick="i3GEO.guias.ativa('legenda',this)" data-idconteudo="guia4obj" data-idLegenda="legendaHtml" style="margin-top: 3px;"> |
| 192 | - <button title="{{{iconeLegenda}}}" class="btn btn-default iconeGuiaMovel" style="color:white;box-shadow: none;"> | 190 | + <button title="{{{iconeLegenda}}}" class="iconeGuiaMovel" style="color:white;box-shadow: none;"> |
| 193 | <i class="material-icons">view_list</i> | 191 | <i class="material-icons">view_list</i> |
| 194 | </button> | 192 | </button> |
| 195 | </div> | 193 | </div> |
| 196 | <div class="hidden-xs hidden-sm" onclick="i3GEO.guias.ativa('dobraPagina',this)" style="margin-top: 3px;"> | 194 | <div class="hidden-xs hidden-sm" onclick="i3GEO.guias.ativa('dobraPagina',this)" style="margin-top: 3px;"> |
| 197 | - <button title="{{{trocaInterface}}}" class="btn btn-default iconeGuiaMovel" style="color:white;box-shadow: none;"> | 195 | + <button title="{{{trocaInterface}}}" class="iconeGuiaMovel" style="color:white;box-shadow: none;"> |
| 198 | <i class="material-icons">compare_arrows</i> | 196 | <i class="material-icons">compare_arrows</i> |
| 199 | </button> | 197 | </button> |
| 200 | </div> | 198 | </div> |
| 201 | <!-- Busca --> | 199 | <!-- Busca --> |
| 202 | <div onclick="i3GEO.guias.ativa('buscaRapida',this)" data-idconteudo="guia7obj" style="margin-top: 3px;"> | 200 | <div onclick="i3GEO.guias.ativa('buscaRapida',this)" data-idconteudo="guia7obj" style="margin-top: 3px;"> |
| 203 | - <button class="btn btn-default iconeGuiaMovel" style="color:white;box-shadow: none;"> | 201 | + <button class="iconeGuiaMovel" style="color:white;box-shadow: none;"> |
| 204 | <i class="material-icons">search</i> | 202 | <i class="material-icons">search</i> |
| 205 | </button> | 203 | </button> |
| 206 | </div> | 204 | </div> |
| 207 | <div onclick="i3GEO.guias.ativa('identificaBalao',this)" style="margin-top: 3px;" > | 205 | <div onclick="i3GEO.guias.ativa('identificaBalao',this)" style="margin-top: 3px;" > |
| 208 | - <button title="{{{iconeBalao}}}" class="btn btn-default iconeGuiaMovel" style="color:white;box-shadow: none;"> | 206 | + <button title="{{{iconeBalao}}}" class="iconeGuiaMovel" style="color:white;box-shadow: none;"> |
| 209 | <i class="material-icons">location_on</i> | 207 | <i class="material-icons">location_on</i> |
| 210 | </button> | 208 | </button> |
| 211 | </div> | 209 | </div> |
| 212 | <!-- A opcao de identificacao esta integrada ao balao de informacoes, mas pode aparecer aqui tambem | 210 | <!-- A opcao de identificacao esta integrada ao balao de informacoes, mas pode aparecer aqui tambem |
| 213 | <div class="hidden-xs hidden-sm" onclick="i3GEO.guias.ativa('identifica',this)" style="margin-top: 3px;"> | 211 | <div class="hidden-xs hidden-sm" onclick="i3GEO.guias.ativa('identifica',this)" style="margin-top: 3px;"> |
| 214 | - <button title="{{{iconeIdentifica}}}" class="btn btn-default iconeGuiaMovel" style="box-shadow: none;"> | 212 | + <button title="{{{iconeIdentifica}}}" class="iconeGuiaMovel" style="box-shadow: none;"> |
| 215 | <img src="../imagens/gisicons/pointer-info.png" style="cursor: pointer; padding: 3px;"> | 213 | <img src="../imagens/gisicons/pointer-info.png" style="cursor: pointer; padding: 3px;"> |
| 216 | </button> | 214 | </button> |
| 217 | </div> | 215 | </div> |
| @@ -565,6 +563,7 @@ | @@ -565,6 +563,7 @@ | ||
| 565 | //ativa o banner de inicializacao | 563 | //ativa o banner de inicializacao |
| 566 | i3GEO.janela.tempoMsg($i("i3GEOlogoMarcaTemplate").innerHTML,4000); | 564 | i3GEO.janela.tempoMsg($i("i3GEOlogoMarcaTemplate").innerHTML,4000); |
| 567 | (function() { | 565 | (function() { |
| 566 | + //parametros aplicados na criacao do arquivo mapfile | ||
| 568 | var parametrosMapa = { | 567 | var parametrosMapa = { |
| 569 | //arquivo mapfile que servira de base para a criacao do mapa. Por default, sao utilizados os arquivos existentes em i3geo/aplicmap (geral1windows, geral1,...) | 568 | //arquivo mapfile que servira de base para a criacao do mapa. Por default, sao utilizados os arquivos existentes em i3geo/aplicmap (geral1windows, geral1,...) |
| 570 | //Essa variavel pode ser definida em ms_configura tambem. Se nao estiver definida em nenhum lugar, o i3Geo tentara descobrir o arquivo adequado a ser utilizado. Voce pode utilizar essa opcao para abrir um mapa com as camadas que voce quiser, mas para evitar redundâncias, prefira o uso de &temasa | 569 | //Essa variavel pode ser definida em ms_configura tambem. Se nao estiver definida em nenhum lugar, o i3Geo tentara descobrir o arquivo adequado a ser utilizado. Voce pode utilizar essa opcao para abrir um mapa com as camadas que voce quiser, mas para evitar redundâncias, prefira o uso de &temasa |
| @@ -644,7 +643,9 @@ | @@ -644,7 +643,9 @@ | ||
| 644 | filters: [{ | 643 | filters: [{ |
| 645 | layer: "", | 644 | layer: "", |
| 646 | expression: "" | 645 | expression: "" |
| 647 | - }] | 646 | + }], |
| 647 | + //id de um mapa salvo e que sera recuperado | ||
| 648 | + restoreMapId : "" | ||
| 648 | }; | 649 | }; |
| 649 | var config = { | 650 | var config = { |
| 650 | //id do elemento HTML onde o corpo do mapa sera renderizado | 651 | //id do elemento HTML onde o corpo do mapa sera renderizado |
| @@ -661,6 +662,11 @@ | @@ -661,6 +662,11 @@ | ||
| 661 | //Endereco do servidor i3Geo. Utilizado para gerar as requisicoes AJAX | 662 | //Endereco do servidor i3Geo. Utilizado para gerar as requisicoes AJAX |
| 662 | //Por default e definido como: i3GEO.util.protocolo() + "://" + window.location.host + "/i3geo" | 663 | //Por default e definido como: i3GEO.util.protocolo() + "://" + window.location.host + "/i3geo" |
| 663 | i3GeoServer : "", | 664 | i3GeoServer : "", |
| 665 | + //opacidade default para camadas que nao sejam do tipo linha ou ponto | ||
| 666 | + //a opacidade sera aplicada ao objeto HTML e nao ao LAYER original | ||
| 667 | + //se for vazio, sera utilizado o valor definido no LAYER original | ||
| 668 | + //Nao se aplica na interface googlemaps | ||
| 669 | + layerOpacity: "", | ||
| 664 | //Funcao que sera executada apos a inicializacao do mapa | 670 | //Funcao que sera executada apos a inicializacao do mapa |
| 665 | afterStart : function(){ | 671 | afterStart : function(){ |
| 666 | $('.iconeGuiaMovel').tooltip({animation: false, trigger: "manual", placement: "left"}); | 672 | $('.iconeGuiaMovel').tooltip({animation: false, trigger: "manual", placement: "left"}); |
| @@ -761,8 +767,43 @@ | @@ -761,8 +767,43 @@ | ||
| 761 | ] | 767 | ] |
| 762 | }, | 768 | }, |
| 763 | //opcoes para o objeto view, que e uma instancia de MapOptions | 769 | //opcoes para o objeto view, que e uma instancia de MapOptions |
| 770 | + //ver https://openlayers.org/en/latest/apidoc/ol.View.html | ||
| 764 | ViewOptions : { | 771 | ViewOptions : { |
| 765 | 772 | ||
| 773 | + }, | ||
| 774 | + //botoes que sao mostrados no editor vetorial | ||
| 775 | + editorButtons : { | ||
| 776 | + 'imprimir': false, | ||
| 777 | + 'grid': false, | ||
| 778 | + 'pan' : false, | ||
| 779 | + 'zoombox' : false, | ||
| 780 | + 'zoomtot' : false, | ||
| 781 | + 'zoomin' : false, | ||
| 782 | + 'zoomout' : false, | ||
| 783 | + 'distancia' : false, | ||
| 784 | + 'area' : false, | ||
| 785 | + 'identifica' : false, | ||
| 786 | + 'linha' : true, | ||
| 787 | + 'ponto' : true, | ||
| 788 | + 'poligono' : true, | ||
| 789 | + 'texto' : true, | ||
| 790 | + 'edita' : true, | ||
| 791 | + 'listag' : true, | ||
| 792 | + 'corta' : true, | ||
| 793 | + 'apaga' : true, | ||
| 794 | + 'procura' : false, | ||
| 795 | + 'selecao' : true, | ||
| 796 | + 'selecaotudo' : true, | ||
| 797 | + 'salva' : true, | ||
| 798 | + 'ajuda' : true, | ||
| 799 | + 'propriedades' : true, | ||
| 800 | + 'fecha' : true, | ||
| 801 | + 'tools' : true, | ||
| 802 | + 'undo' : false, | ||
| 803 | + 'frente' : false, | ||
| 804 | + 'legenda' : false, | ||
| 805 | + 'rodadomouse' : true, | ||
| 806 | + 'novaaba' : false | ||
| 766 | } | 807 | } |
| 767 | }, | 808 | }, |
| 768 | //configuracoes especificas para a interface GoogleMaps | 809 | //configuracoes especificas para a interface GoogleMaps |
js/compactados/maparef_compacto.js
| 1 | -if(typeof(i3GEO)==='undefined'){var i3GEO={}}i3GEO.maparef={fatorZoomDinamico:-3,TOP:4,RIGHT:120,W:function(){var w=parseInt(i3GEO.parametros.w,10)/5;if(w<150){w=150}return parseInt(w,10)},H:function(){var h=parseInt(i3GEO.parametros.h,10)/5;if(i3GEO.maparef.W()<=150){return 150}else{return parseInt(h,10)}},inicia:function(){if(i3GEO.arvoreDeCamadas.listaLigadosDesligados()[0].length==0){i3GEO.janela.tempoMsg($trad("umaLigada"));return}var r,pos,novoel,ins,temp,moveX,moveY,escondeRef,janela;if($i("i3geo_winRef")){janela=YAHOO.i3GEO.janela.manager.find("i3geo_winRef");janela.show();janela.bringToTop();return}if(!$i("i3geo_winRef")){novoel=document.createElement("div");novoel.id="i3geo_winRef";novoel.style.display="none";novoel.style.borderColor="gray";ins="";ins+='<div class="hd" style="border:0px solid black;text-align:left;z-index:20;padding-left: 0px;padding-bottom: 3px;padding-top: 1px;">';ins+='<span id=maparefmaismenosZoom style=display:none > ';temp="javascript:if(i3GEO.maparef.fatorZoomDinamico == -1){i3GEO.maparef.fatorZoomDinamico = 1};i3GEO.maparef.fatorZoomDinamico = i3GEO.maparef.fatorZoomDinamico + 1 ;$i(\"refDinamico\").checked = true;i3GEO.maparef.atualiza();";ins+="<button onclick='"+temp+"' class='btn btn-xs' style='margin:2px;padding:2px;'><span class='material-icons'>add_circle_outline</span></button>";temp="javascript:if(i3GEO.maparef.fatorZoomDinamico == 1){i3GEO.maparef.fatorZoomDinamico = -1};i3GEO.maparef.fatorZoomDinamico = i3GEO.maparef.fatorZoomDinamico - 1 ;$i(\"refDinamico\").checked = true;i3GEO.maparef.atualiza();";ins+="<button onclick='"+temp+"' class='btn btn-xs' style='margin:2px;padding:2px;'><span class='material-icons'>remove_circle_outline</span></button>";ins+="<div style='width: 100px;display:inline-table' class='form-group label-fixed condensed'>";ins+="<div style='width: 100%;' class='input-group'>";ins+="<select class='form-control' style='background-color:#094672' id='refDinamico' onchange='javascript:i3GEO.parametros.celularef=\"\";i3GEO.maparef.atualiza()'>";ins+="<option value='mapa' >"+$trad("refMapaAtual")+"</option>";ins+="<option value='dinamico' >"+$trad("refMapaDinamico")+"</option>";ins+="</select>";ins+="</div></div></div>";ins+='<div class="bd" style="border:0px solid black;text-align:left;padding:3px;height: '+i3GEO.maparef.H()+'px;" id="mapaReferencia" onmouseover="this.onmousemove=function(exy){i3GEO.eventos.posicaoMouseMapa(exy)}" >';ins+='<img style="cursor:pointer;display:none"class="img-rounded" onload="javascript:this.style.display = \'block\'" id="imagemReferencia" src="" onclick="javascript:i3GEO.maparef.click()">';ins+='</div>';novoel.innerHTML=ins;$(novoel).css("opacity",1);document.body.appendChild(novoel)}if($i("i3geo_winRef").style.display!=="block"){$i("i3geo_winRef").style.display="block";janela=new YAHOO.widget.Panel("i3geo_winRef",{height:i3GEO.maparef.H()+47+"px",width:i3GEO.maparef.W()+6+"px",fixedcenter:false,constraintoviewport:false,underlay:"shadow",close:true,visible:true,draggable:true,modal:false,iframe:false,strings:{close:"<span class='material-icons'>cancel</span>"}});YAHOO.i3GEO.janela.manager.register(janela);janela.cfg.setProperty("effect",[{effect:YAHOO.widget.ContainerEffect.FADE,duration:0.5}]);janela.render();janela.show();try{janela.header.style.height="40px"}catch(e){};r=$i("i3geo_winRef_c");if(r){r.style.position="absolute"}pos=i3GEO.util.pegaPosicaoObjeto($i(i3GEO.Interface.IDCORPO));$i("mapaReferencia").style.height=i3GEO.maparef.H()+"px";$i("i3geo_winRef").style.border="0px solid gray";moveX=pos[0]+i3GEO.parametros.w-i3GEO.maparef.W()+3-i3GEO.maparef.RIGHT;moveY=pos[1]+i3GEO.maparef.TOP;if(i3GEO.Interface.ATUAL==="googlemaps"){moveY+=30}janela.moveTo(moveX,moveY);escondeRef=function(){$i("imagemReferencia").src="";janela.destroy()};$(janela.close).click(escondeRef);if($i("localizarxygeoProjxg")){var temp=function(){i3GEO.coordenadas.atualizaGeo(objposicaocursor.dmsx,objposicaocursor.dmsy,"localizarxygeoProj")};$("#imagemReferencia").mousemove(temp)}}i3GEO.eventos.adicionaEventos("NAVEGAMAPA",["i3GEO.maparef.atualiza()"]);this.atualiza(true);$i("i3geo_winRef_h").className="hd2"},atualiza:function(forca){if(arguments.length===0){forca=false}var tiporef,temp;temp=$i("refDinamico")?tiporef=$i("refDinamico").value:tiporef="fixo";if($i("mapaReferencia")){temp=$i("maparefmaismenosZoom");if(tiporef==="dinamico"){i3GEO.php.referenciadinamica(i3GEO.maparef.processaImagem,i3GEO.maparef.fatorZoomDinamico,tiporef,i3GEO.maparef.W(),i3GEO.maparef.H());if(temp){temp.style.display="inline-table"}}if(tiporef==="mapa"){i3GEO.php.referenciadinamica(i3GEO.maparef.processaImagem,i3GEO.maparef.fatorZoomDinamico,tiporef,i3GEO.maparef.W(),i3GEO.maparef.H());if(temp){temp.style.display="inline-table"}}}else{i3GEO.eventos.removeEventos("NAVEGAMAPA",["i3GEO.maparef.atualiza()"])}},processaImagem:function(retorno){var m,box,temp,tiporef="fixo";if((retorno.data!=="erro")&&(retorno.data!==undefined)){eval(retorno.data);i3GEO.parametros.celularef=g_celularef;i3GEO.parametros.extentref=extentref;temp=$i("imagemReferencia");if(temp){m=new Image();m.src=refimagem;temp.src=m.src}temp=$i("refDinamico");if(temp){tiporef=temp.value}if(tiporef!=="fixo"){box=$i("boxref");if(box){box.style.display="none"}return}i3GEO.maparef.atualizaBox()}},atualizaBox:function(){var box=i3GEO.maparef.criaBox(),w;i3GEO.calculo.ext2rect("boxref",i3GEO.parametros.extentref,i3GEO.parametros.mapexten,i3GEO.parametros.celularef,$i("mapaReferencia"));w=parseInt(box.style.width,10);if(w>120){box.style.display="none";return}box.style.display="block";box.style.top=parseInt(box.style.top,10)+4+"px";box.style.left=parseInt(box.style.left,10)+4+"px";if(w<3){box.style.width="3px";box.style.height="3px"}},criaBox:function(){var box=$i("boxref");if(!box){novoel=document.createElement("div");novoel.id="boxref";novoel.style.zIndex=10;novoel.style.position='absolute';novoel.style.cursor="move";novoel.style.backgroundColor="RGB(120,220,220)";novoel.style.borderWidth="3px";if(navm){novoel.style.filter='alpha(opacity=40)'}else{novoel.style.opacity=0.4}$i("mapaReferencia").appendChild(novoel);novoel.onmouseup=function(){var rect,telaminx,telamaxx,telaminy,m,x,ext;rect=$i("boxref");telaminx=parseInt(rect.style.left,10);telamaxy=parseInt(rect.style.top,10);telamaxx=telaminx+parseInt(rect.style.width,10);telaminy=telamaxy+parseInt(rect.style.height,10);m=i3GEO.calculo.tela2dd(telaminx,telaminy,i3GEO.parametros.celularef,i3GEO.parametros.extentref,"imagemReferencia");x=i3GEO.calculo.tela2dd(telamaxx,telamaxy,i3GEO.parametros.celularef,i3GEO.parametros.extentref,"imagemReferencia");ext=m[0]+" "+m[1]+" "+x[0]+" "+x[1];i3GEO.navega.zoomExt(i3GEO.configura.locaplic,i3GEO.configura.sid,"",ext)};return novoel}else{return box}},click:function(){if(i3GEO.Interface.ATUAL==="openlayers"||i3GEO.Interface.ATUAL==="googlemaps"){i3GEO.Interface[i3GEO.Interface.ATUAL].pan2ponto(objposicaocursor.ddx,objposicaocursor.ddy)}}}; | ||
| 2 | \ No newline at end of file | 1 | \ No newline at end of file |
| 2 | +if(typeof(i3GEO)==='undefined'){var i3GEO={}}i3GEO.maparef={fatorZoomDinamico:-3,TOP:4,RIGHT:120,W:function(){var w=parseInt(i3GEO.parametros.w,10)/5;if(w<150){w=150}return parseInt(w,10)},H:function(){var h=parseInt(i3GEO.parametros.h,10)/5;if(i3GEO.maparef.W()<=150){return 150}else{return parseInt(h,10)}},inicia:function(){if(i3GEO.arvoreDeCamadas.listaLigadosDesligados()[0].length==0){i3GEO.janela.tempoMsg($trad("umaLigada"));return}var r,pos,novoel,ins,temp,moveX,moveY,escondeRef,janela;if($i("i3geo_winRef")){janela=YAHOO.i3GEO.janela.manager.find("i3geo_winRef");janela.show();janela.bringToTop();return}if(!$i("i3geo_winRef")){novoel=document.createElement("div");novoel.id="i3geo_winRef";novoel.style.display="none";novoel.style.borderColor="gray";ins="";ins+='<div class="hd" style="border:0px solid black;text-align:left;z-index:20;padding-left: 0px;padding-bottom: 3px;padding-top: 1px;">';ins+='<span id=maparefmaismenosZoom style=display:none > ';temp="javascript:if(i3GEO.maparef.fatorZoomDinamico == -1){i3GEO.maparef.fatorZoomDinamico = 1};i3GEO.maparef.fatorZoomDinamico = i3GEO.maparef.fatorZoomDinamico + 1 ;$i(\"refDinamico\").checked = true;i3GEO.maparef.atualiza();";ins+="<button onclick='"+temp+"' class='btn btn-xs' style='margin:2px;padding:2px;'><span class='material-icons'>add_circle_outline</span></button>";temp="javascript:if(i3GEO.maparef.fatorZoomDinamico == 1){i3GEO.maparef.fatorZoomDinamico = -1};i3GEO.maparef.fatorZoomDinamico = i3GEO.maparef.fatorZoomDinamico - 1 ;$i(\"refDinamico\").checked = true;i3GEO.maparef.atualiza();";ins+="<button onclick='"+temp+"' class='btn btn-xs' style='margin:2px;padding:2px;'><span class='material-icons'>remove_circle_outline</span></button>";ins+="<div style='width: 100px;display:inline-table' class='form-group label-fixed condensed'>";ins+="<div style='width: 100%;' class='input-group'>";ins+="<select class='form-control' style='background-color:#094672' id='refDinamico' onchange='javascript:i3GEO.parametros.celularef=\"\";i3GEO.maparef.atualiza()'>";ins+="<option value='mapa' >"+$trad("refMapaAtual")+"</option>";ins+="<option value='dinamico' >"+$trad("refMapaDinamico")+"</option>";ins+="</select>";ins+="</div></div></div>";ins+='<div class="bd" style="border:0px solid black;text-align:left;padding:3px;height: '+i3GEO.maparef.H()+'px;" id="mapaReferencia" onmouseover="this.onmousemove=function(exy){i3GEO.eventos.posicaoMouseMapa(exy)}" >';ins+='<img style="cursor:pointer;display:none"class="img-rounded" onload="javascript:this.style.display = \'block\'" id="imagemReferencia" src="" onclick="javascript:i3GEO.maparef.click()">';ins+='</div>';novoel.innerHTML=ins;$(novoel).css("opacity",1);document.body.appendChild(novoel)}if($i("i3geo_winRef").style.display!=="block"){$i("i3geo_winRef").style.display="block";janela=new YAHOO.widget.Panel("i3geo_winRef",{height:i3GEO.maparef.H()+47+"px",width:i3GEO.maparef.W()+6+"px",fixedcenter:false,constraintoviewport:false,underlay:"shadow",close:true,visible:true,draggable:true,modal:false,iframe:false,strings:{close:"<span class='material-icons'>cancel</span>"}});YAHOO.i3GEO.janela.manager.register(janela);janela.cfg.setProperty("effect",[{effect:YAHOO.widget.ContainerEffect.FADE,duration:0.5}]);janela.render();janela.show();try{janela.header.style.height="40px"}catch(e){};r=$i("i3geo_winRef_c");if(r){r.style.position="absolute"}pos=i3GEO.util.pegaPosicaoObjeto($i(i3GEO.Interface.IDCORPO));$i("mapaReferencia").style.height=i3GEO.maparef.H()+"px";$i("i3geo_winRef").style.border="0px solid gray";moveX=pos[0]+i3GEO.parametros.w-i3GEO.maparef.W()+3-i3GEO.maparef.RIGHT;moveY=pos[1]+i3GEO.maparef.TOP;if(i3GEO.Interface.ATUAL==="googlemaps"){moveY+=30}janela.moveTo(moveX,moveY);escondeRef=function(){$i("imagemReferencia").src="";janela.destroy()};$(janela.close).click(escondeRef);if($i("localizarxygeoProjxg")){var temp=function(){i3GEO.coordenadas.atualizaGeo(objposicaocursor.dmsx,objposicaocursor.dmsy,"localizarxygeoProj")};$("#imagemReferencia").mousemove(temp)}}i3GEO.eventos.adicionaEventos("NAVEGAMAPA",["i3GEO.maparef.atualiza()"]);i3GEO.maparef.atualiza(true);$i("i3geo_winRef_h").className="hd2"},atualiza:function(forca){if(arguments.length===0){forca=false}var tiporef,temp;temp=$i("refDinamico")?tiporef=$i("refDinamico").value:tiporef="fixo";if($i("mapaReferencia")){temp=$i("maparefmaismenosZoom");if(tiporef==="dinamico"){i3GEO.php.referenciadinamica(i3GEO.maparef.processaImagem,i3GEO.maparef.fatorZoomDinamico,tiporef,i3GEO.maparef.W(),i3GEO.maparef.H());if(temp){temp.style.display="inline-table"}}if(tiporef==="mapa"){i3GEO.php.referenciadinamica(i3GEO.maparef.processaImagem,i3GEO.maparef.fatorZoomDinamico,tiporef,i3GEO.maparef.W(),i3GEO.maparef.H());if(temp){temp.style.display="inline-table"}}}else{i3GEO.eventos.removeEventos("NAVEGAMAPA",["i3GEO.maparef.atualiza()"])}},processaImagem:function(retorno){var m,box,temp,tiporef="fixo";if((retorno.data!=="erro")&&(retorno.data!==undefined)){eval(retorno.data);i3GEO.parametros.celularef=g_celularef;i3GEO.parametros.extentref=extentref;temp=$i("imagemReferencia");if(temp){m=new Image();m.src=refimagem;temp.src=m.src}temp=$i("refDinamico");if(temp){tiporef=temp.value}if(tiporef!=="fixo"){box=$i("boxref");if(box){box.style.display="none"}}i3GEO.maparef.atualizaBox()}},atualizaBox:function(){var box=i3GEO.maparef.criaBox(),w;i3GEO.calculo.ext2rect("boxref",i3GEO.parametros.extentref,i3GEO.parametros.mapexten,i3GEO.parametros.celularef,$i("mapaReferencia"));w=parseInt(box.style.width,10);if(w>120){box.style.display="none";return}box.style.display="block";box.style.top=parseInt(box.style.top,10)+4+"px";box.style.left=parseInt(box.style.left,10)+4+"px";if(w<3){box.style.width="3px";box.style.height="3px"}},criaBox:function(){var box=$i("boxref");if(!box){novoel=document.createElement("div");novoel.id="boxref";novoel.style.zIndex=10;novoel.style.position='absolute';novoel.style.cursor="move";novoel.style.backgroundColor="RGB(120,220,220)";novoel.style.borderWidth="3px";if(navm){novoel.style.filter='alpha(opacity=40)'}else{novoel.style.opacity=0.4}$i("mapaReferencia").appendChild(novoel);novoel.onmouseup=function(){var rect,telaminx,telamaxx,telaminy,m,x,ext;rect=$i("boxref");telaminx=parseInt(rect.style.left,10);telamaxy=parseInt(rect.style.top,10);telamaxx=telaminx+parseInt(rect.style.width,10);telaminy=telamaxy+parseInt(rect.style.height,10);m=i3GEO.calculo.tela2dd(telaminx,telaminy,i3GEO.parametros.celularef,i3GEO.parametros.extentref,"imagemReferencia");x=i3GEO.calculo.tela2dd(telamaxx,telamaxy,i3GEO.parametros.celularef,i3GEO.parametros.extentref,"imagemReferencia");ext=m[0]+" "+m[1]+" "+x[0]+" "+x[1];i3GEO.navega.zoomExt(i3GEO.configura.locaplic,i3GEO.configura.sid,"",ext)};return novoel}else{return box}},click:function(){if(i3GEO.Interface.ATUAL==="openlayers"||i3GEO.Interface.ATUAL==="googlemaps"){i3GEO.Interface[i3GEO.Interface.ATUAL].pan2ponto(objposicaocursor.ddx,objposicaocursor.ddy)}}}; | ||
| 3 | \ No newline at end of file | 3 | \ No newline at end of file |
js/i3geo_tudo_compacto7.js
| @@ -245,7 +245,7 @@ if(typeof(i3GEO)==='undefined'){var i3GEO={}}i3GEO.tema={TEMPORIZADORESID:{},ati | @@ -245,7 +245,7 @@ if(typeof(i3GEO)==='undefined'){var i3GEO={}}i3GEO.tema={TEMPORIZADORESID:{},ati | ||
| 245 | if(typeof(i3GEO)==='undefined'){var i3GEO={}}i3GEO.analise={pontos:{xpt:[],ypt:[]},dialogo:{markercluster:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.markercluster()","markercluster","markercluster","dependencias.php","i3GEOF.markercluster.iniciaJanelaFlutuante()")},heatmap:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.heatmap()","heatmap","heatmap","dependencias.php","i3GEOF.heatmap.iniciaJanelaFlutuante()")},saiku:function(){if(i3GEO.parametros.statusFerramentas&&i3GEO.parametros.statusFerramentas.saiku===false){i3GEO.janela.tempoMsg($trad("naoInstalado"));return}i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.saiku()","saiku","saiku")},saikuMapa:function(){if(i3GEO.parametros.statusFerramentas&&i3GEO.parametros.statusFerramentas.saiku===false){i3GEO.janela.tempoMsg($trad("naoInstalado"));return}i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.saiku()","saiku","saiku","index.js","i3GEOF.saiku.iniciaJanelaFlutuante2()")},graficoInterativo:function(){alert("depreciado. Use graficointerativo1")},graficoInterativo1:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.graficointerativo1()","graficointerativo1","graficointerativo1","dependencias.php","i3GEOF.graficointerativo1.iniciaJanelaFlutuante()")},linhaDoTempo:function(){i3GEO.janela.cria("650px","450px",i3GEO.configura.locaplic+"/ferramentas/linhadotempo/index.php","","","</div><a class='i3GeoTituloJanelaBs' target=_blank href='"+i3GEO.configura.locaplic+"/ajuda_usuario.php?idcategoria=3&idajuda=88' >Linha do tempo</a>","i3GEOF.linhaDoTempo",false,"hd","","","",true,i3GEO.configura.locaplic+"/imagens/oxygen/16x16/clock.png");i3GEO.analise.atualizaLinhaDoTempo=function(){var doc="",ifr="";try{ifr=$i("i3GEOF.linhaDoTempoi");if(navn){if(ifr){doc=ifr.contentDocument}}else{if(document.frames("i3GEOF.linhaDoTempoi")){doc=document.frames("i3GEOF.linhaDoTempoi").document}}doc.getElementById("tl")?window.parent["i3GEOF.linhaDoTempoi"].carregaDados():i3GEO.eventos.removeEventos("NAVEGAMAPA",["i3GEO.analise.atualizaLinhaDoTempo()"])}catch(e){i3GEO.eventos.removeEventos("NAVEGAMAPA",["i3GEO.analise.atualizaLinhaDoTempo()"])}};i3GEO.eventos.adicionaEventos("NAVEGAMAPA",["i3GEO.analise.atualizaLinhaDoTempo()"]);var ifr=$i("i3GEOF.linhaDoTempoi");if(ifr){ifr.style.width="100%"}},perfil:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.perfil()","perfil","perfil")},rota:function(){if(i3GEO.Interface.ATUAL!=="googlemaps"){alert("Operacao disponivel apenas na interface Google Maps");return}counterClick=1;var parametrosRota=function(overlay,latlng){var temp,janela;if(counterClick===1){counterClick++;alert("Clique o ponto de destino da rota");pontoRota1=latlng;return}if(counterClick===2){pontoRota2=latlng;counterClick=0;GEvent.removeListener(rotaEvento);janela=i3GEO.janela.cria("300px","300px","","center","","<div class='i3GeoTituloJanela'>"+$trad("x48")+"</div>");janela[2].style.overflow="auto";janela[2].style.height="300px";directions=new GDirections(i3GeoMap,janela[2]);temp=function(){$i("wdoca_corpo").innerHTML="Não foi possível criar a rota"};GEvent.addListener(directions,"error",temp);directions.load("from: "+pontoRota1.lat()+","+pontoRota1.lng()+" to: "+pontoRota2.lat()+","+pontoRota2.lng())}};rotaEvento=GEvent.addListener(i3GeoMap,"click",parametrosRota);i3GEO.janela.tempoMsg("Clique o ponto de origem da rota")},melhorcaminho:function(){if(i3GEO.parametros.statusFerramentas&&i3GEO.parametros.statusFerramentas.melhorcaminho===false){i3GEO.janela.tempoMsg($trad("naoInstalado"));return}i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.melhorcaminho()","melhorcaminho","melhorcaminho")},gradePontos:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.gradePontos()","gradepontos","gradeDePontos","dependencias.php","i3GEOF.gradeDePontos.iniciaJanelaFlutuante()")},gradePol:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.gradePol()","gradepol","gradeDePoligonos","dependencias.php","i3GEOF.gradeDePoligonos.iniciaJanelaFlutuante()")},gradeHex:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.gradeHex()","gradehex","gradeDeHex","dependencias.php","i3GEOF.gradeDeHex.iniciaJanelaFlutuante()")},analisaGeometrias:function(){i3GEO.util.dialogoFerramenta("i3GEO.tema.dialogo.tabela()","analisageometrias","analisaGeometrias","dependencias.php","i3GEOF.analisaGeometrias.iniciaJanelaFlutuante()")},pontosdistri:function(){i3GEO.parametros.r==="nao"?i3GEO.janela.tempoMsg($trad("x22")):i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.pontosdistri()","pontosdistri","pontosDistri","dependencias.php","i3GEOF.pontosDistri.iniciaJanelaFlutuante()")},pontoempoligono:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.pontoempoligono()","pontoempoligono","pontoEmPoligono","dependencias.php","i3GEOF.pontoEmPoligono.iniciaJanelaFlutuante()")},centromassa:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.centromassa()","centromassa","centromassa","dependencias.php","i3GEOF.centromassa.iniciaJanelaFlutuante()")},nptPol:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.nptpol()","nptpol","nptpol","dependencias.php","i3GEOF.nptpol.iniciaJanelaFlutuante()")},buffer:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.buffer()","buffer","buffer","dependencias.php","i3GEOF.buffer.iniciaJanelaFlutuante()")},distanciaptpt:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.distanciaptpt()","distanciaptpt","distanciaptpt","dependencias.php","i3GEOF.distanciaptpt.iniciaJanelaFlutuante()")},centroide:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.centroide()","centroide","centroide","dependencias.php","i3GEOF.centroide.iniciaJanelaFlutuante()")},dissolve:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.dissolve()","dissolve","dissolve","dependencias.php","i3GEOF.dissolve.iniciaJanelaFlutuante()")},agrupaElementos:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.agrupaElementos()","agrupaelementos","agrupaElementos","dependencias.php","i3GEOF.agrupaElementos.iniciaJanelaFlutuante()")},distancia:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.distancia()","distancia","distancia","dependencias.php","i3GEOF.distancia.iniciaJanelaFlutuante()")},area:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.area()","area","area","dependencias.php","i3GEOF.area.iniciaJanelaFlutuante()")},juntamedidasvariavel:function(tema){if(!tema){tema=i3GEO.temaAtivo}var temp=function(){i3GEOF.juntamedidasvariavel.iniciaJanelaFlutuante(tema)};i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.juntamedidasvariavel()","juntamedidasvariavel","juntamedidasvariavel","dependencias.php",temp)}}}; | 245 | if(typeof(i3GEO)==='undefined'){var i3GEO={}}i3GEO.analise={pontos:{xpt:[],ypt:[]},dialogo:{markercluster:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.markercluster()","markercluster","markercluster","dependencias.php","i3GEOF.markercluster.iniciaJanelaFlutuante()")},heatmap:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.heatmap()","heatmap","heatmap","dependencias.php","i3GEOF.heatmap.iniciaJanelaFlutuante()")},saiku:function(){if(i3GEO.parametros.statusFerramentas&&i3GEO.parametros.statusFerramentas.saiku===false){i3GEO.janela.tempoMsg($trad("naoInstalado"));return}i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.saiku()","saiku","saiku")},saikuMapa:function(){if(i3GEO.parametros.statusFerramentas&&i3GEO.parametros.statusFerramentas.saiku===false){i3GEO.janela.tempoMsg($trad("naoInstalado"));return}i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.saiku()","saiku","saiku","index.js","i3GEOF.saiku.iniciaJanelaFlutuante2()")},graficoInterativo:function(){alert("depreciado. Use graficointerativo1")},graficoInterativo1:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.graficointerativo1()","graficointerativo1","graficointerativo1","dependencias.php","i3GEOF.graficointerativo1.iniciaJanelaFlutuante()")},linhaDoTempo:function(){i3GEO.janela.cria("650px","450px",i3GEO.configura.locaplic+"/ferramentas/linhadotempo/index.php","","","</div><a class='i3GeoTituloJanelaBs' target=_blank href='"+i3GEO.configura.locaplic+"/ajuda_usuario.php?idcategoria=3&idajuda=88' >Linha do tempo</a>","i3GEOF.linhaDoTempo",false,"hd","","","",true,i3GEO.configura.locaplic+"/imagens/oxygen/16x16/clock.png");i3GEO.analise.atualizaLinhaDoTempo=function(){var doc="",ifr="";try{ifr=$i("i3GEOF.linhaDoTempoi");if(navn){if(ifr){doc=ifr.contentDocument}}else{if(document.frames("i3GEOF.linhaDoTempoi")){doc=document.frames("i3GEOF.linhaDoTempoi").document}}doc.getElementById("tl")?window.parent["i3GEOF.linhaDoTempoi"].carregaDados():i3GEO.eventos.removeEventos("NAVEGAMAPA",["i3GEO.analise.atualizaLinhaDoTempo()"])}catch(e){i3GEO.eventos.removeEventos("NAVEGAMAPA",["i3GEO.analise.atualizaLinhaDoTempo()"])}};i3GEO.eventos.adicionaEventos("NAVEGAMAPA",["i3GEO.analise.atualizaLinhaDoTempo()"]);var ifr=$i("i3GEOF.linhaDoTempoi");if(ifr){ifr.style.width="100%"}},perfil:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.perfil()","perfil","perfil")},rota:function(){if(i3GEO.Interface.ATUAL!=="googlemaps"){alert("Operacao disponivel apenas na interface Google Maps");return}counterClick=1;var parametrosRota=function(overlay,latlng){var temp,janela;if(counterClick===1){counterClick++;alert("Clique o ponto de destino da rota");pontoRota1=latlng;return}if(counterClick===2){pontoRota2=latlng;counterClick=0;GEvent.removeListener(rotaEvento);janela=i3GEO.janela.cria("300px","300px","","center","","<div class='i3GeoTituloJanela'>"+$trad("x48")+"</div>");janela[2].style.overflow="auto";janela[2].style.height="300px";directions=new GDirections(i3GeoMap,janela[2]);temp=function(){$i("wdoca_corpo").innerHTML="Não foi possível criar a rota"};GEvent.addListener(directions,"error",temp);directions.load("from: "+pontoRota1.lat()+","+pontoRota1.lng()+" to: "+pontoRota2.lat()+","+pontoRota2.lng())}};rotaEvento=GEvent.addListener(i3GeoMap,"click",parametrosRota);i3GEO.janela.tempoMsg("Clique o ponto de origem da rota")},melhorcaminho:function(){if(i3GEO.parametros.statusFerramentas&&i3GEO.parametros.statusFerramentas.melhorcaminho===false){i3GEO.janela.tempoMsg($trad("naoInstalado"));return}i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.melhorcaminho()","melhorcaminho","melhorcaminho")},gradePontos:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.gradePontos()","gradepontos","gradeDePontos","dependencias.php","i3GEOF.gradeDePontos.iniciaJanelaFlutuante()")},gradePol:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.gradePol()","gradepol","gradeDePoligonos","dependencias.php","i3GEOF.gradeDePoligonos.iniciaJanelaFlutuante()")},gradeHex:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.gradeHex()","gradehex","gradeDeHex","dependencias.php","i3GEOF.gradeDeHex.iniciaJanelaFlutuante()")},analisaGeometrias:function(){i3GEO.util.dialogoFerramenta("i3GEO.tema.dialogo.tabela()","analisageometrias","analisaGeometrias","dependencias.php","i3GEOF.analisaGeometrias.iniciaJanelaFlutuante()")},pontosdistri:function(){i3GEO.parametros.r==="nao"?i3GEO.janela.tempoMsg($trad("x22")):i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.pontosdistri()","pontosdistri","pontosDistri","dependencias.php","i3GEOF.pontosDistri.iniciaJanelaFlutuante()")},pontoempoligono:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.pontoempoligono()","pontoempoligono","pontoEmPoligono","dependencias.php","i3GEOF.pontoEmPoligono.iniciaJanelaFlutuante()")},centromassa:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.centromassa()","centromassa","centromassa","dependencias.php","i3GEOF.centromassa.iniciaJanelaFlutuante()")},nptPol:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.nptpol()","nptpol","nptpol","dependencias.php","i3GEOF.nptpol.iniciaJanelaFlutuante()")},buffer:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.buffer()","buffer","buffer","dependencias.php","i3GEOF.buffer.iniciaJanelaFlutuante()")},distanciaptpt:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.distanciaptpt()","distanciaptpt","distanciaptpt","dependencias.php","i3GEOF.distanciaptpt.iniciaJanelaFlutuante()")},centroide:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.centroide()","centroide","centroide","dependencias.php","i3GEOF.centroide.iniciaJanelaFlutuante()")},dissolve:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.dissolve()","dissolve","dissolve","dependencias.php","i3GEOF.dissolve.iniciaJanelaFlutuante()")},agrupaElementos:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.agrupaElementos()","agrupaelementos","agrupaElementos","dependencias.php","i3GEOF.agrupaElementos.iniciaJanelaFlutuante()")},distancia:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.distancia()","distancia","distancia","dependencias.php","i3GEOF.distancia.iniciaJanelaFlutuante()")},area:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.area()","area","area","dependencias.php","i3GEOF.area.iniciaJanelaFlutuante()")},juntamedidasvariavel:function(tema){if(!tema){tema=i3GEO.temaAtivo}var temp=function(){i3GEOF.juntamedidasvariavel.iniciaJanelaFlutuante(tema)};i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.juntamedidasvariavel()","juntamedidasvariavel","juntamedidasvariavel","dependencias.php",temp)}}}; |
| 246 | // | 246 | // |
| 247 | //compactados/maparef_compacto.js | 247 | //compactados/maparef_compacto.js |
| 248 | -if(typeof(i3GEO)==='undefined'){var i3GEO={}}i3GEO.maparef={fatorZoomDinamico:-3,TOP:4,RIGHT:120,W:function(){var w=parseInt(i3GEO.parametros.w,10)/5;if(w<150){w=150}return parseInt(w,10)},H:function(){var h=parseInt(i3GEO.parametros.h,10)/5;if(i3GEO.maparef.W()<=150){return 150}else{return parseInt(h,10)}},inicia:function(){if(i3GEO.arvoreDeCamadas.listaLigadosDesligados()[0].length==0){i3GEO.janela.tempoMsg($trad("umaLigada"));return}var r,pos,novoel,ins,temp,moveX,moveY,escondeRef,janela;if($i("i3geo_winRef")){janela=YAHOO.i3GEO.janela.manager.find("i3geo_winRef");janela.show();janela.bringToTop();return}if(!$i("i3geo_winRef")){novoel=document.createElement("div");novoel.id="i3geo_winRef";novoel.style.display="none";novoel.style.borderColor="gray";ins="";ins+='<div class="hd" style="border:0px solid black;text-align:left;z-index:20;padding-left: 0px;padding-bottom: 3px;padding-top: 1px;">';ins+='<span id=maparefmaismenosZoom style=display:none > ';temp="javascript:if(i3GEO.maparef.fatorZoomDinamico == -1){i3GEO.maparef.fatorZoomDinamico = 1};i3GEO.maparef.fatorZoomDinamico = i3GEO.maparef.fatorZoomDinamico + 1 ;$i(\"refDinamico\").checked = true;i3GEO.maparef.atualiza();";ins+="<button onclick='"+temp+"' class='btn btn-xs' style='margin:2px;padding:2px;'><span class='material-icons'>add_circle_outline</span></button>";temp="javascript:if(i3GEO.maparef.fatorZoomDinamico == 1){i3GEO.maparef.fatorZoomDinamico = -1};i3GEO.maparef.fatorZoomDinamico = i3GEO.maparef.fatorZoomDinamico - 1 ;$i(\"refDinamico\").checked = true;i3GEO.maparef.atualiza();";ins+="<button onclick='"+temp+"' class='btn btn-xs' style='margin:2px;padding:2px;'><span class='material-icons'>remove_circle_outline</span></button>";ins+="<div style='width: 100px;display:inline-table' class='form-group label-fixed condensed'>";ins+="<div style='width: 100%;' class='input-group'>";ins+="<select class='form-control' style='background-color:#094672' id='refDinamico' onchange='javascript:i3GEO.parametros.celularef=\"\";i3GEO.maparef.atualiza()'>";ins+="<option value='mapa' >"+$trad("refMapaAtual")+"</option>";ins+="<option value='dinamico' >"+$trad("refMapaDinamico")+"</option>";ins+="</select>";ins+="</div></div></div>";ins+='<div class="bd" style="border:0px solid black;text-align:left;padding:3px;height: '+i3GEO.maparef.H()+'px;" id="mapaReferencia" onmouseover="this.onmousemove=function(exy){i3GEO.eventos.posicaoMouseMapa(exy)}" >';ins+='<img style="cursor:pointer;display:none"class="img-rounded" onload="javascript:this.style.display = \'block\'" id="imagemReferencia" src="" onclick="javascript:i3GEO.maparef.click()">';ins+='</div>';novoel.innerHTML=ins;$(novoel).css("opacity",1);document.body.appendChild(novoel)}if($i("i3geo_winRef").style.display!=="block"){$i("i3geo_winRef").style.display="block";janela=new YAHOO.widget.Panel("i3geo_winRef",{height:i3GEO.maparef.H()+47+"px",width:i3GEO.maparef.W()+6+"px",fixedcenter:false,constraintoviewport:false,underlay:"shadow",close:true,visible:true,draggable:true,modal:false,iframe:false,strings:{close:"<span class='material-icons'>cancel</span>"}});YAHOO.i3GEO.janela.manager.register(janela);janela.cfg.setProperty("effect",[{effect:YAHOO.widget.ContainerEffect.FADE,duration:0.5}]);janela.render();janela.show();try{janela.header.style.height="40px"}catch(e){};r=$i("i3geo_winRef_c");if(r){r.style.position="absolute"}pos=i3GEO.util.pegaPosicaoObjeto($i(i3GEO.Interface.IDCORPO));$i("mapaReferencia").style.height=i3GEO.maparef.H()+"px";$i("i3geo_winRef").style.border="0px solid gray";moveX=pos[0]+i3GEO.parametros.w-i3GEO.maparef.W()+3-i3GEO.maparef.RIGHT;moveY=pos[1]+i3GEO.maparef.TOP;if(i3GEO.Interface.ATUAL==="googlemaps"){moveY+=30}janela.moveTo(moveX,moveY);escondeRef=function(){$i("imagemReferencia").src="";janela.destroy()};$(janela.close).click(escondeRef);if($i("localizarxygeoProjxg")){var temp=function(){i3GEO.coordenadas.atualizaGeo(objposicaocursor.dmsx,objposicaocursor.dmsy,"localizarxygeoProj")};$("#imagemReferencia").mousemove(temp)}}i3GEO.eventos.adicionaEventos("NAVEGAMAPA",["i3GEO.maparef.atualiza()"]);this.atualiza(true);$i("i3geo_winRef_h").className="hd2"},atualiza:function(forca){if(arguments.length===0){forca=false}var tiporef,temp;temp=$i("refDinamico")?tiporef=$i("refDinamico").value:tiporef="fixo";if($i("mapaReferencia")){temp=$i("maparefmaismenosZoom");if(tiporef==="dinamico"){i3GEO.php.referenciadinamica(i3GEO.maparef.processaImagem,i3GEO.maparef.fatorZoomDinamico,tiporef,i3GEO.maparef.W(),i3GEO.maparef.H());if(temp){temp.style.display="inline-table"}}if(tiporef==="mapa"){i3GEO.php.referenciadinamica(i3GEO.maparef.processaImagem,i3GEO.maparef.fatorZoomDinamico,tiporef,i3GEO.maparef.W(),i3GEO.maparef.H());if(temp){temp.style.display="inline-table"}}}else{i3GEO.eventos.removeEventos("NAVEGAMAPA",["i3GEO.maparef.atualiza()"])}},processaImagem:function(retorno){var m,box,temp,tiporef="fixo";if((retorno.data!=="erro")&&(retorno.data!==undefined)){eval(retorno.data);i3GEO.parametros.celularef=g_celularef;i3GEO.parametros.extentref=extentref;temp=$i("imagemReferencia");if(temp){m=new Image();m.src=refimagem;temp.src=m.src}temp=$i("refDinamico");if(temp){tiporef=temp.value}if(tiporef!=="fixo"){box=$i("boxref");if(box){box.style.display="none"}return}i3GEO.maparef.atualizaBox()}},atualizaBox:function(){var box=i3GEO.maparef.criaBox(),w;i3GEO.calculo.ext2rect("boxref",i3GEO.parametros.extentref,i3GEO.parametros.mapexten,i3GEO.parametros.celularef,$i("mapaReferencia"));w=parseInt(box.style.width,10);if(w>120){box.style.display="none";return}box.style.display="block";box.style.top=parseInt(box.style.top,10)+4+"px";box.style.left=parseInt(box.style.left,10)+4+"px";if(w<3){box.style.width="3px";box.style.height="3px"}},criaBox:function(){var box=$i("boxref");if(!box){novoel=document.createElement("div");novoel.id="boxref";novoel.style.zIndex=10;novoel.style.position='absolute';novoel.style.cursor="move";novoel.style.backgroundColor="RGB(120,220,220)";novoel.style.borderWidth="3px";if(navm){novoel.style.filter='alpha(opacity=40)'}else{novoel.style.opacity=0.4}$i("mapaReferencia").appendChild(novoel);novoel.onmouseup=function(){var rect,telaminx,telamaxx,telaminy,m,x,ext;rect=$i("boxref");telaminx=parseInt(rect.style.left,10);telamaxy=parseInt(rect.style.top,10);telamaxx=telaminx+parseInt(rect.style.width,10);telaminy=telamaxy+parseInt(rect.style.height,10);m=i3GEO.calculo.tela2dd(telaminx,telaminy,i3GEO.parametros.celularef,i3GEO.parametros.extentref,"imagemReferencia");x=i3GEO.calculo.tela2dd(telamaxx,telamaxy,i3GEO.parametros.celularef,i3GEO.parametros.extentref,"imagemReferencia");ext=m[0]+" "+m[1]+" "+x[0]+" "+x[1];i3GEO.navega.zoomExt(i3GEO.configura.locaplic,i3GEO.configura.sid,"",ext)};return novoel}else{return box}},click:function(){if(i3GEO.Interface.ATUAL==="openlayers"||i3GEO.Interface.ATUAL==="googlemaps"){i3GEO.Interface[i3GEO.Interface.ATUAL].pan2ponto(objposicaocursor.ddx,objposicaocursor.ddy)}}}; | 248 | +if(typeof(i3GEO)==='undefined'){var i3GEO={}}i3GEO.maparef={fatorZoomDinamico:-3,TOP:4,RIGHT:120,W:function(){var w=parseInt(i3GEO.parametros.w,10)/5;if(w<150){w=150}return parseInt(w,10)},H:function(){var h=parseInt(i3GEO.parametros.h,10)/5;if(i3GEO.maparef.W()<=150){return 150}else{return parseInt(h,10)}},inicia:function(){if(i3GEO.arvoreDeCamadas.listaLigadosDesligados()[0].length==0){i3GEO.janela.tempoMsg($trad("umaLigada"));return}var r,pos,novoel,ins,temp,moveX,moveY,escondeRef,janela;if($i("i3geo_winRef")){janela=YAHOO.i3GEO.janela.manager.find("i3geo_winRef");janela.show();janela.bringToTop();return}if(!$i("i3geo_winRef")){novoel=document.createElement("div");novoel.id="i3geo_winRef";novoel.style.display="none";novoel.style.borderColor="gray";ins="";ins+='<div class="hd" style="border:0px solid black;text-align:left;z-index:20;padding-left: 0px;padding-bottom: 3px;padding-top: 1px;">';ins+='<span id=maparefmaismenosZoom style=display:none > ';temp="javascript:if(i3GEO.maparef.fatorZoomDinamico == -1){i3GEO.maparef.fatorZoomDinamico = 1};i3GEO.maparef.fatorZoomDinamico = i3GEO.maparef.fatorZoomDinamico + 1 ;$i(\"refDinamico\").checked = true;i3GEO.maparef.atualiza();";ins+="<button onclick='"+temp+"' class='btn btn-xs' style='margin:2px;padding:2px;'><span class='material-icons'>add_circle_outline</span></button>";temp="javascript:if(i3GEO.maparef.fatorZoomDinamico == 1){i3GEO.maparef.fatorZoomDinamico = -1};i3GEO.maparef.fatorZoomDinamico = i3GEO.maparef.fatorZoomDinamico - 1 ;$i(\"refDinamico\").checked = true;i3GEO.maparef.atualiza();";ins+="<button onclick='"+temp+"' class='btn btn-xs' style='margin:2px;padding:2px;'><span class='material-icons'>remove_circle_outline</span></button>";ins+="<div style='width: 100px;display:inline-table' class='form-group label-fixed condensed'>";ins+="<div style='width: 100%;' class='input-group'>";ins+="<select class='form-control' style='background-color:#094672' id='refDinamico' onchange='javascript:i3GEO.parametros.celularef=\"\";i3GEO.maparef.atualiza()'>";ins+="<option value='mapa' >"+$trad("refMapaAtual")+"</option>";ins+="<option value='dinamico' >"+$trad("refMapaDinamico")+"</option>";ins+="</select>";ins+="</div></div></div>";ins+='<div class="bd" style="border:0px solid black;text-align:left;padding:3px;height: '+i3GEO.maparef.H()+'px;" id="mapaReferencia" onmouseover="this.onmousemove=function(exy){i3GEO.eventos.posicaoMouseMapa(exy)}" >';ins+='<img style="cursor:pointer;display:none"class="img-rounded" onload="javascript:this.style.display = \'block\'" id="imagemReferencia" src="" onclick="javascript:i3GEO.maparef.click()">';ins+='</div>';novoel.innerHTML=ins;$(novoel).css("opacity",1);document.body.appendChild(novoel)}if($i("i3geo_winRef").style.display!=="block"){$i("i3geo_winRef").style.display="block";janela=new YAHOO.widget.Panel("i3geo_winRef",{height:i3GEO.maparef.H()+47+"px",width:i3GEO.maparef.W()+6+"px",fixedcenter:false,constraintoviewport:false,underlay:"shadow",close:true,visible:true,draggable:true,modal:false,iframe:false,strings:{close:"<span class='material-icons'>cancel</span>"}});YAHOO.i3GEO.janela.manager.register(janela);janela.cfg.setProperty("effect",[{effect:YAHOO.widget.ContainerEffect.FADE,duration:0.5}]);janela.render();janela.show();try{janela.header.style.height="40px"}catch(e){};r=$i("i3geo_winRef_c");if(r){r.style.position="absolute"}pos=i3GEO.util.pegaPosicaoObjeto($i(i3GEO.Interface.IDCORPO));$i("mapaReferencia").style.height=i3GEO.maparef.H()+"px";$i("i3geo_winRef").style.border="0px solid gray";moveX=pos[0]+i3GEO.parametros.w-i3GEO.maparef.W()+3-i3GEO.maparef.RIGHT;moveY=pos[1]+i3GEO.maparef.TOP;if(i3GEO.Interface.ATUAL==="googlemaps"){moveY+=30}janela.moveTo(moveX,moveY);escondeRef=function(){$i("imagemReferencia").src="";janela.destroy()};$(janela.close).click(escondeRef);if($i("localizarxygeoProjxg")){var temp=function(){i3GEO.coordenadas.atualizaGeo(objposicaocursor.dmsx,objposicaocursor.dmsy,"localizarxygeoProj")};$("#imagemReferencia").mousemove(temp)}}i3GEO.eventos.adicionaEventos("NAVEGAMAPA",["i3GEO.maparef.atualiza()"]);i3GEO.maparef.atualiza(true);$i("i3geo_winRef_h").className="hd2"},atualiza:function(forca){if(arguments.length===0){forca=false}var tiporef,temp;temp=$i("refDinamico")?tiporef=$i("refDinamico").value:tiporef="fixo";if($i("mapaReferencia")){temp=$i("maparefmaismenosZoom");if(tiporef==="dinamico"){i3GEO.php.referenciadinamica(i3GEO.maparef.processaImagem,i3GEO.maparef.fatorZoomDinamico,tiporef,i3GEO.maparef.W(),i3GEO.maparef.H());if(temp){temp.style.display="inline-table"}}if(tiporef==="mapa"){i3GEO.php.referenciadinamica(i3GEO.maparef.processaImagem,i3GEO.maparef.fatorZoomDinamico,tiporef,i3GEO.maparef.W(),i3GEO.maparef.H());if(temp){temp.style.display="inline-table"}}}else{i3GEO.eventos.removeEventos("NAVEGAMAPA",["i3GEO.maparef.atualiza()"])}},processaImagem:function(retorno){var m,box,temp,tiporef="fixo";if((retorno.data!=="erro")&&(retorno.data!==undefined)){eval(retorno.data);i3GEO.parametros.celularef=g_celularef;i3GEO.parametros.extentref=extentref;temp=$i("imagemReferencia");if(temp){m=new Image();m.src=refimagem;temp.src=m.src}temp=$i("refDinamico");if(temp){tiporef=temp.value}if(tiporef!=="fixo"){box=$i("boxref");if(box){box.style.display="none"}}i3GEO.maparef.atualizaBox()}},atualizaBox:function(){var box=i3GEO.maparef.criaBox(),w;i3GEO.calculo.ext2rect("boxref",i3GEO.parametros.extentref,i3GEO.parametros.mapexten,i3GEO.parametros.celularef,$i("mapaReferencia"));w=parseInt(box.style.width,10);if(w>120){box.style.display="none";return}box.style.display="block";box.style.top=parseInt(box.style.top,10)+4+"px";box.style.left=parseInt(box.style.left,10)+4+"px";if(w<3){box.style.width="3px";box.style.height="3px"}},criaBox:function(){var box=$i("boxref");if(!box){novoel=document.createElement("div");novoel.id="boxref";novoel.style.zIndex=10;novoel.style.position='absolute';novoel.style.cursor="move";novoel.style.backgroundColor="RGB(120,220,220)";novoel.style.borderWidth="3px";if(navm){novoel.style.filter='alpha(opacity=40)'}else{novoel.style.opacity=0.4}$i("mapaReferencia").appendChild(novoel);novoel.onmouseup=function(){var rect,telaminx,telamaxx,telaminy,m,x,ext;rect=$i("boxref");telaminx=parseInt(rect.style.left,10);telamaxy=parseInt(rect.style.top,10);telamaxx=telaminx+parseInt(rect.style.width,10);telaminy=telamaxy+parseInt(rect.style.height,10);m=i3GEO.calculo.tela2dd(telaminx,telaminy,i3GEO.parametros.celularef,i3GEO.parametros.extentref,"imagemReferencia");x=i3GEO.calculo.tela2dd(telamaxx,telamaxy,i3GEO.parametros.celularef,i3GEO.parametros.extentref,"imagemReferencia");ext=m[0]+" "+m[1]+" "+x[0]+" "+x[1];i3GEO.navega.zoomExt(i3GEO.configura.locaplic,i3GEO.configura.sid,"",ext)};return novoel}else{return box}},click:function(){if(i3GEO.Interface.ATUAL==="openlayers"||i3GEO.Interface.ATUAL==="googlemaps"){i3GEO.Interface[i3GEO.Interface.ATUAL].pan2ponto(objposicaocursor.ddx,objposicaocursor.ddy)}}}; |
| 249 | // | 249 | // |
| 250 | //compactados/ajuda_compacto.js | 250 | //compactados/ajuda_compacto.js |
| 251 | if(typeof(i3GEO)==='undefined'){var i3GEO={}}i3GEO.ajuda={abreDoc:function(url){if(!url){url="/documentacao/index.html"}window.open(i3GEO.configura.locaplic+url)},redesSociais:function(){i3GEO.janela.cria("400px","400px",i3GEO.configura.locaplic+"/ferramentas/redessociais/index.php","","","<div class='i3GeoTituloJanela'>"+$trad("u5c")+"</div>",i3GEO.util.generateId("redes"))},ferramenta:function(idajuda){var url=i3GEO.configura.locaplic+"/ferramentas/ajuda_usuario.php?"+"&idajuda="+idajuda;$.get(url).done(function(data){var json=jQuery.parseJSON(data);var texto=json[i3GEO.idioma.ATUAL];var titulo=json["titulo"][i3GEO.idioma.ATUAL];i3GEO.janela.closeMsg(texto)}).fail(function(){return})}}; | 251 | if(typeof(i3GEO)==='undefined'){var i3GEO={}}i3GEO.ajuda={abreDoc:function(url){if(!url){url="/documentacao/index.html"}window.open(i3GEO.configura.locaplic+url)},redesSociais:function(){i3GEO.janela.cria("400px","400px",i3GEO.configura.locaplic+"/ferramentas/redessociais/index.php","","","<div class='i3GeoTituloJanela'>"+$trad("u5c")+"</div>",i3GEO.util.generateId("redes"))},ferramenta:function(idajuda){var url=i3GEO.configura.locaplic+"/ferramentas/ajuda_usuario.php?"+"&idajuda="+idajuda;$.get(url).done(function(data){var json=jQuery.parseJSON(data);var texto=json[i3GEO.idioma.ATUAL];var titulo=json["titulo"][i3GEO.idioma.ATUAL];i3GEO.janela.closeMsg(texto)}).fail(function(){return})}}; |
js/i3geo_tudo_compacto7.js.php
| @@ -245,7 +245,7 @@ if(typeof(i3GEO)==='undefined'){var i3GEO={}}i3GEO.tema={TEMPORIZADORESID:{},ati | @@ -245,7 +245,7 @@ if(typeof(i3GEO)==='undefined'){var i3GEO={}}i3GEO.tema={TEMPORIZADORESID:{},ati | ||
| 245 | if(typeof(i3GEO)==='undefined'){var i3GEO={}}i3GEO.analise={pontos:{xpt:[],ypt:[]},dialogo:{markercluster:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.markercluster()","markercluster","markercluster","dependencias.php","i3GEOF.markercluster.iniciaJanelaFlutuante()")},heatmap:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.heatmap()","heatmap","heatmap","dependencias.php","i3GEOF.heatmap.iniciaJanelaFlutuante()")},saiku:function(){if(i3GEO.parametros.statusFerramentas&&i3GEO.parametros.statusFerramentas.saiku===false){i3GEO.janela.tempoMsg($trad("naoInstalado"));return}i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.saiku()","saiku","saiku")},saikuMapa:function(){if(i3GEO.parametros.statusFerramentas&&i3GEO.parametros.statusFerramentas.saiku===false){i3GEO.janela.tempoMsg($trad("naoInstalado"));return}i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.saiku()","saiku","saiku","index.js","i3GEOF.saiku.iniciaJanelaFlutuante2()")},graficoInterativo:function(){alert("depreciado. Use graficointerativo1")},graficoInterativo1:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.graficointerativo1()","graficointerativo1","graficointerativo1","dependencias.php","i3GEOF.graficointerativo1.iniciaJanelaFlutuante()")},linhaDoTempo:function(){i3GEO.janela.cria("650px","450px",i3GEO.configura.locaplic+"/ferramentas/linhadotempo/index.php","","","</div><a class='i3GeoTituloJanelaBs' target=_blank href='"+i3GEO.configura.locaplic+"/ajuda_usuario.php?idcategoria=3&idajuda=88' >Linha do tempo</a>","i3GEOF.linhaDoTempo",false,"hd","","","",true,i3GEO.configura.locaplic+"/imagens/oxygen/16x16/clock.png");i3GEO.analise.atualizaLinhaDoTempo=function(){var doc="",ifr="";try{ifr=$i("i3GEOF.linhaDoTempoi");if(navn){if(ifr){doc=ifr.contentDocument}}else{if(document.frames("i3GEOF.linhaDoTempoi")){doc=document.frames("i3GEOF.linhaDoTempoi").document}}doc.getElementById("tl")?window.parent["i3GEOF.linhaDoTempoi"].carregaDados():i3GEO.eventos.removeEventos("NAVEGAMAPA",["i3GEO.analise.atualizaLinhaDoTempo()"])}catch(e){i3GEO.eventos.removeEventos("NAVEGAMAPA",["i3GEO.analise.atualizaLinhaDoTempo()"])}};i3GEO.eventos.adicionaEventos("NAVEGAMAPA",["i3GEO.analise.atualizaLinhaDoTempo()"]);var ifr=$i("i3GEOF.linhaDoTempoi");if(ifr){ifr.style.width="100%"}},perfil:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.perfil()","perfil","perfil")},rota:function(){if(i3GEO.Interface.ATUAL!=="googlemaps"){alert("Operacao disponivel apenas na interface Google Maps");return}counterClick=1;var parametrosRota=function(overlay,latlng){var temp,janela;if(counterClick===1){counterClick++;alert("Clique o ponto de destino da rota");pontoRota1=latlng;return}if(counterClick===2){pontoRota2=latlng;counterClick=0;GEvent.removeListener(rotaEvento);janela=i3GEO.janela.cria("300px","300px","","center","","<div class='i3GeoTituloJanela'>"+$trad("x48")+"</div>");janela[2].style.overflow="auto";janela[2].style.height="300px";directions=new GDirections(i3GeoMap,janela[2]);temp=function(){$i("wdoca_corpo").innerHTML="Não foi possível criar a rota"};GEvent.addListener(directions,"error",temp);directions.load("from: "+pontoRota1.lat()+","+pontoRota1.lng()+" to: "+pontoRota2.lat()+","+pontoRota2.lng())}};rotaEvento=GEvent.addListener(i3GeoMap,"click",parametrosRota);i3GEO.janela.tempoMsg("Clique o ponto de origem da rota")},melhorcaminho:function(){if(i3GEO.parametros.statusFerramentas&&i3GEO.parametros.statusFerramentas.melhorcaminho===false){i3GEO.janela.tempoMsg($trad("naoInstalado"));return}i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.melhorcaminho()","melhorcaminho","melhorcaminho")},gradePontos:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.gradePontos()","gradepontos","gradeDePontos","dependencias.php","i3GEOF.gradeDePontos.iniciaJanelaFlutuante()")},gradePol:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.gradePol()","gradepol","gradeDePoligonos","dependencias.php","i3GEOF.gradeDePoligonos.iniciaJanelaFlutuante()")},gradeHex:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.gradeHex()","gradehex","gradeDeHex","dependencias.php","i3GEOF.gradeDeHex.iniciaJanelaFlutuante()")},analisaGeometrias:function(){i3GEO.util.dialogoFerramenta("i3GEO.tema.dialogo.tabela()","analisageometrias","analisaGeometrias","dependencias.php","i3GEOF.analisaGeometrias.iniciaJanelaFlutuante()")},pontosdistri:function(){i3GEO.parametros.r==="nao"?i3GEO.janela.tempoMsg($trad("x22")):i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.pontosdistri()","pontosdistri","pontosDistri","dependencias.php","i3GEOF.pontosDistri.iniciaJanelaFlutuante()")},pontoempoligono:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.pontoempoligono()","pontoempoligono","pontoEmPoligono","dependencias.php","i3GEOF.pontoEmPoligono.iniciaJanelaFlutuante()")},centromassa:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.centromassa()","centromassa","centromassa","dependencias.php","i3GEOF.centromassa.iniciaJanelaFlutuante()")},nptPol:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.nptpol()","nptpol","nptpol","dependencias.php","i3GEOF.nptpol.iniciaJanelaFlutuante()")},buffer:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.buffer()","buffer","buffer","dependencias.php","i3GEOF.buffer.iniciaJanelaFlutuante()")},distanciaptpt:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.distanciaptpt()","distanciaptpt","distanciaptpt","dependencias.php","i3GEOF.distanciaptpt.iniciaJanelaFlutuante()")},centroide:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.centroide()","centroide","centroide","dependencias.php","i3GEOF.centroide.iniciaJanelaFlutuante()")},dissolve:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.dissolve()","dissolve","dissolve","dependencias.php","i3GEOF.dissolve.iniciaJanelaFlutuante()")},agrupaElementos:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.agrupaElementos()","agrupaelementos","agrupaElementos","dependencias.php","i3GEOF.agrupaElementos.iniciaJanelaFlutuante()")},distancia:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.distancia()","distancia","distancia","dependencias.php","i3GEOF.distancia.iniciaJanelaFlutuante()")},area:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.area()","area","area","dependencias.php","i3GEOF.area.iniciaJanelaFlutuante()")},juntamedidasvariavel:function(tema){if(!tema){tema=i3GEO.temaAtivo}var temp=function(){i3GEOF.juntamedidasvariavel.iniciaJanelaFlutuante(tema)};i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.juntamedidasvariavel()","juntamedidasvariavel","juntamedidasvariavel","dependencias.php",temp)}}}; | 245 | if(typeof(i3GEO)==='undefined'){var i3GEO={}}i3GEO.analise={pontos:{xpt:[],ypt:[]},dialogo:{markercluster:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.markercluster()","markercluster","markercluster","dependencias.php","i3GEOF.markercluster.iniciaJanelaFlutuante()")},heatmap:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.heatmap()","heatmap","heatmap","dependencias.php","i3GEOF.heatmap.iniciaJanelaFlutuante()")},saiku:function(){if(i3GEO.parametros.statusFerramentas&&i3GEO.parametros.statusFerramentas.saiku===false){i3GEO.janela.tempoMsg($trad("naoInstalado"));return}i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.saiku()","saiku","saiku")},saikuMapa:function(){if(i3GEO.parametros.statusFerramentas&&i3GEO.parametros.statusFerramentas.saiku===false){i3GEO.janela.tempoMsg($trad("naoInstalado"));return}i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.saiku()","saiku","saiku","index.js","i3GEOF.saiku.iniciaJanelaFlutuante2()")},graficoInterativo:function(){alert("depreciado. Use graficointerativo1")},graficoInterativo1:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.graficointerativo1()","graficointerativo1","graficointerativo1","dependencias.php","i3GEOF.graficointerativo1.iniciaJanelaFlutuante()")},linhaDoTempo:function(){i3GEO.janela.cria("650px","450px",i3GEO.configura.locaplic+"/ferramentas/linhadotempo/index.php","","","</div><a class='i3GeoTituloJanelaBs' target=_blank href='"+i3GEO.configura.locaplic+"/ajuda_usuario.php?idcategoria=3&idajuda=88' >Linha do tempo</a>","i3GEOF.linhaDoTempo",false,"hd","","","",true,i3GEO.configura.locaplic+"/imagens/oxygen/16x16/clock.png");i3GEO.analise.atualizaLinhaDoTempo=function(){var doc="",ifr="";try{ifr=$i("i3GEOF.linhaDoTempoi");if(navn){if(ifr){doc=ifr.contentDocument}}else{if(document.frames("i3GEOF.linhaDoTempoi")){doc=document.frames("i3GEOF.linhaDoTempoi").document}}doc.getElementById("tl")?window.parent["i3GEOF.linhaDoTempoi"].carregaDados():i3GEO.eventos.removeEventos("NAVEGAMAPA",["i3GEO.analise.atualizaLinhaDoTempo()"])}catch(e){i3GEO.eventos.removeEventos("NAVEGAMAPA",["i3GEO.analise.atualizaLinhaDoTempo()"])}};i3GEO.eventos.adicionaEventos("NAVEGAMAPA",["i3GEO.analise.atualizaLinhaDoTempo()"]);var ifr=$i("i3GEOF.linhaDoTempoi");if(ifr){ifr.style.width="100%"}},perfil:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.perfil()","perfil","perfil")},rota:function(){if(i3GEO.Interface.ATUAL!=="googlemaps"){alert("Operacao disponivel apenas na interface Google Maps");return}counterClick=1;var parametrosRota=function(overlay,latlng){var temp,janela;if(counterClick===1){counterClick++;alert("Clique o ponto de destino da rota");pontoRota1=latlng;return}if(counterClick===2){pontoRota2=latlng;counterClick=0;GEvent.removeListener(rotaEvento);janela=i3GEO.janela.cria("300px","300px","","center","","<div class='i3GeoTituloJanela'>"+$trad("x48")+"</div>");janela[2].style.overflow="auto";janela[2].style.height="300px";directions=new GDirections(i3GeoMap,janela[2]);temp=function(){$i("wdoca_corpo").innerHTML="Não foi possível criar a rota"};GEvent.addListener(directions,"error",temp);directions.load("from: "+pontoRota1.lat()+","+pontoRota1.lng()+" to: "+pontoRota2.lat()+","+pontoRota2.lng())}};rotaEvento=GEvent.addListener(i3GeoMap,"click",parametrosRota);i3GEO.janela.tempoMsg("Clique o ponto de origem da rota")},melhorcaminho:function(){if(i3GEO.parametros.statusFerramentas&&i3GEO.parametros.statusFerramentas.melhorcaminho===false){i3GEO.janela.tempoMsg($trad("naoInstalado"));return}i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.melhorcaminho()","melhorcaminho","melhorcaminho")},gradePontos:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.gradePontos()","gradepontos","gradeDePontos","dependencias.php","i3GEOF.gradeDePontos.iniciaJanelaFlutuante()")},gradePol:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.gradePol()","gradepol","gradeDePoligonos","dependencias.php","i3GEOF.gradeDePoligonos.iniciaJanelaFlutuante()")},gradeHex:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.gradeHex()","gradehex","gradeDeHex","dependencias.php","i3GEOF.gradeDeHex.iniciaJanelaFlutuante()")},analisaGeometrias:function(){i3GEO.util.dialogoFerramenta("i3GEO.tema.dialogo.tabela()","analisageometrias","analisaGeometrias","dependencias.php","i3GEOF.analisaGeometrias.iniciaJanelaFlutuante()")},pontosdistri:function(){i3GEO.parametros.r==="nao"?i3GEO.janela.tempoMsg($trad("x22")):i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.pontosdistri()","pontosdistri","pontosDistri","dependencias.php","i3GEOF.pontosDistri.iniciaJanelaFlutuante()")},pontoempoligono:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.pontoempoligono()","pontoempoligono","pontoEmPoligono","dependencias.php","i3GEOF.pontoEmPoligono.iniciaJanelaFlutuante()")},centromassa:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.centromassa()","centromassa","centromassa","dependencias.php","i3GEOF.centromassa.iniciaJanelaFlutuante()")},nptPol:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.nptpol()","nptpol","nptpol","dependencias.php","i3GEOF.nptpol.iniciaJanelaFlutuante()")},buffer:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.buffer()","buffer","buffer","dependencias.php","i3GEOF.buffer.iniciaJanelaFlutuante()")},distanciaptpt:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.distanciaptpt()","distanciaptpt","distanciaptpt","dependencias.php","i3GEOF.distanciaptpt.iniciaJanelaFlutuante()")},centroide:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.centroide()","centroide","centroide","dependencias.php","i3GEOF.centroide.iniciaJanelaFlutuante()")},dissolve:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.dissolve()","dissolve","dissolve","dependencias.php","i3GEOF.dissolve.iniciaJanelaFlutuante()")},agrupaElementos:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.agrupaElementos()","agrupaelementos","agrupaElementos","dependencias.php","i3GEOF.agrupaElementos.iniciaJanelaFlutuante()")},distancia:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.distancia()","distancia","distancia","dependencias.php","i3GEOF.distancia.iniciaJanelaFlutuante()")},area:function(){i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.area()","area","area","dependencias.php","i3GEOF.area.iniciaJanelaFlutuante()")},juntamedidasvariavel:function(tema){if(!tema){tema=i3GEO.temaAtivo}var temp=function(){i3GEOF.juntamedidasvariavel.iniciaJanelaFlutuante(tema)};i3GEO.util.dialogoFerramenta("i3GEO.analise.dialogo.juntamedidasvariavel()","juntamedidasvariavel","juntamedidasvariavel","dependencias.php",temp)}}}; |
| 246 | // | 246 | // |
| 247 | //compactados/maparef_compacto.js | 247 | //compactados/maparef_compacto.js |
| 248 | -if(typeof(i3GEO)==='undefined'){var i3GEO={}}i3GEO.maparef={fatorZoomDinamico:-3,TOP:4,RIGHT:120,W:function(){var w=parseInt(i3GEO.parametros.w,10)/5;if(w<150){w=150}return parseInt(w,10)},H:function(){var h=parseInt(i3GEO.parametros.h,10)/5;if(i3GEO.maparef.W()<=150){return 150}else{return parseInt(h,10)}},inicia:function(){if(i3GEO.arvoreDeCamadas.listaLigadosDesligados()[0].length==0){i3GEO.janela.tempoMsg($trad("umaLigada"));return}var r,pos,novoel,ins,temp,moveX,moveY,escondeRef,janela;if($i("i3geo_winRef")){janela=YAHOO.i3GEO.janela.manager.find("i3geo_winRef");janela.show();janela.bringToTop();return}if(!$i("i3geo_winRef")){novoel=document.createElement("div");novoel.id="i3geo_winRef";novoel.style.display="none";novoel.style.borderColor="gray";ins="";ins+='<div class="hd" style="border:0px solid black;text-align:left;z-index:20;padding-left: 0px;padding-bottom: 3px;padding-top: 1px;">';ins+='<span id=maparefmaismenosZoom style=display:none > ';temp="javascript:if(i3GEO.maparef.fatorZoomDinamico == -1){i3GEO.maparef.fatorZoomDinamico = 1};i3GEO.maparef.fatorZoomDinamico = i3GEO.maparef.fatorZoomDinamico + 1 ;$i(\"refDinamico\").checked = true;i3GEO.maparef.atualiza();";ins+="<button onclick='"+temp+"' class='btn btn-xs' style='margin:2px;padding:2px;'><span class='material-icons'>add_circle_outline</span></button>";temp="javascript:if(i3GEO.maparef.fatorZoomDinamico == 1){i3GEO.maparef.fatorZoomDinamico = -1};i3GEO.maparef.fatorZoomDinamico = i3GEO.maparef.fatorZoomDinamico - 1 ;$i(\"refDinamico\").checked = true;i3GEO.maparef.atualiza();";ins+="<button onclick='"+temp+"' class='btn btn-xs' style='margin:2px;padding:2px;'><span class='material-icons'>remove_circle_outline</span></button>";ins+="<div style='width: 100px;display:inline-table' class='form-group label-fixed condensed'>";ins+="<div style='width: 100%;' class='input-group'>";ins+="<select class='form-control' style='background-color:#094672' id='refDinamico' onchange='javascript:i3GEO.parametros.celularef=\"\";i3GEO.maparef.atualiza()'>";ins+="<option value='mapa' >"+$trad("refMapaAtual")+"</option>";ins+="<option value='dinamico' >"+$trad("refMapaDinamico")+"</option>";ins+="</select>";ins+="</div></div></div>";ins+='<div class="bd" style="border:0px solid black;text-align:left;padding:3px;height: '+i3GEO.maparef.H()+'px;" id="mapaReferencia" onmouseover="this.onmousemove=function(exy){i3GEO.eventos.posicaoMouseMapa(exy)}" >';ins+='<img style="cursor:pointer;display:none"class="img-rounded" onload="javascript:this.style.display = \'block\'" id="imagemReferencia" src="" onclick="javascript:i3GEO.maparef.click()">';ins+='</div>';novoel.innerHTML=ins;$(novoel).css("opacity",1);document.body.appendChild(novoel)}if($i("i3geo_winRef").style.display!=="block"){$i("i3geo_winRef").style.display="block";janela=new YAHOO.widget.Panel("i3geo_winRef",{height:i3GEO.maparef.H()+47+"px",width:i3GEO.maparef.W()+6+"px",fixedcenter:false,constraintoviewport:false,underlay:"shadow",close:true,visible:true,draggable:true,modal:false,iframe:false,strings:{close:"<span class='material-icons'>cancel</span>"}});YAHOO.i3GEO.janela.manager.register(janela);janela.cfg.setProperty("effect",[{effect:YAHOO.widget.ContainerEffect.FADE,duration:0.5}]);janela.render();janela.show();try{janela.header.style.height="40px"}catch(e){};r=$i("i3geo_winRef_c");if(r){r.style.position="absolute"}pos=i3GEO.util.pegaPosicaoObjeto($i(i3GEO.Interface.IDCORPO));$i("mapaReferencia").style.height=i3GEO.maparef.H()+"px";$i("i3geo_winRef").style.border="0px solid gray";moveX=pos[0]+i3GEO.parametros.w-i3GEO.maparef.W()+3-i3GEO.maparef.RIGHT;moveY=pos[1]+i3GEO.maparef.TOP;if(i3GEO.Interface.ATUAL==="googlemaps"){moveY+=30}janela.moveTo(moveX,moveY);escondeRef=function(){$i("imagemReferencia").src="";janela.destroy()};$(janela.close).click(escondeRef);if($i("localizarxygeoProjxg")){var temp=function(){i3GEO.coordenadas.atualizaGeo(objposicaocursor.dmsx,objposicaocursor.dmsy,"localizarxygeoProj")};$("#imagemReferencia").mousemove(temp)}}i3GEO.eventos.adicionaEventos("NAVEGAMAPA",["i3GEO.maparef.atualiza()"]);this.atualiza(true);$i("i3geo_winRef_h").className="hd2"},atualiza:function(forca){if(arguments.length===0){forca=false}var tiporef,temp;temp=$i("refDinamico")?tiporef=$i("refDinamico").value:tiporef="fixo";if($i("mapaReferencia")){temp=$i("maparefmaismenosZoom");if(tiporef==="dinamico"){i3GEO.php.referenciadinamica(i3GEO.maparef.processaImagem,i3GEO.maparef.fatorZoomDinamico,tiporef,i3GEO.maparef.W(),i3GEO.maparef.H());if(temp){temp.style.display="inline-table"}}if(tiporef==="mapa"){i3GEO.php.referenciadinamica(i3GEO.maparef.processaImagem,i3GEO.maparef.fatorZoomDinamico,tiporef,i3GEO.maparef.W(),i3GEO.maparef.H());if(temp){temp.style.display="inline-table"}}}else{i3GEO.eventos.removeEventos("NAVEGAMAPA",["i3GEO.maparef.atualiza()"])}},processaImagem:function(retorno){var m,box,temp,tiporef="fixo";if((retorno.data!=="erro")&&(retorno.data!==undefined)){eval(retorno.data);i3GEO.parametros.celularef=g_celularef;i3GEO.parametros.extentref=extentref;temp=$i("imagemReferencia");if(temp){m=new Image();m.src=refimagem;temp.src=m.src}temp=$i("refDinamico");if(temp){tiporef=temp.value}if(tiporef!=="fixo"){box=$i("boxref");if(box){box.style.display="none"}return}i3GEO.maparef.atualizaBox()}},atualizaBox:function(){var box=i3GEO.maparef.criaBox(),w;i3GEO.calculo.ext2rect("boxref",i3GEO.parametros.extentref,i3GEO.parametros.mapexten,i3GEO.parametros.celularef,$i("mapaReferencia"));w=parseInt(box.style.width,10);if(w>120){box.style.display="none";return}box.style.display="block";box.style.top=parseInt(box.style.top,10)+4+"px";box.style.left=parseInt(box.style.left,10)+4+"px";if(w<3){box.style.width="3px";box.style.height="3px"}},criaBox:function(){var box=$i("boxref");if(!box){novoel=document.createElement("div");novoel.id="boxref";novoel.style.zIndex=10;novoel.style.position='absolute';novoel.style.cursor="move";novoel.style.backgroundColor="RGB(120,220,220)";novoel.style.borderWidth="3px";if(navm){novoel.style.filter='alpha(opacity=40)'}else{novoel.style.opacity=0.4}$i("mapaReferencia").appendChild(novoel);novoel.onmouseup=function(){var rect,telaminx,telamaxx,telaminy,m,x,ext;rect=$i("boxref");telaminx=parseInt(rect.style.left,10);telamaxy=parseInt(rect.style.top,10);telamaxx=telaminx+parseInt(rect.style.width,10);telaminy=telamaxy+parseInt(rect.style.height,10);m=i3GEO.calculo.tela2dd(telaminx,telaminy,i3GEO.parametros.celularef,i3GEO.parametros.extentref,"imagemReferencia");x=i3GEO.calculo.tela2dd(telamaxx,telamaxy,i3GEO.parametros.celularef,i3GEO.parametros.extentref,"imagemReferencia");ext=m[0]+" "+m[1]+" "+x[0]+" "+x[1];i3GEO.navega.zoomExt(i3GEO.configura.locaplic,i3GEO.configura.sid,"",ext)};return novoel}else{return box}},click:function(){if(i3GEO.Interface.ATUAL==="openlayers"||i3GEO.Interface.ATUAL==="googlemaps"){i3GEO.Interface[i3GEO.Interface.ATUAL].pan2ponto(objposicaocursor.ddx,objposicaocursor.ddy)}}}; | 248 | +if(typeof(i3GEO)==='undefined'){var i3GEO={}}i3GEO.maparef={fatorZoomDinamico:-3,TOP:4,RIGHT:120,W:function(){var w=parseInt(i3GEO.parametros.w,10)/5;if(w<150){w=150}return parseInt(w,10)},H:function(){var h=parseInt(i3GEO.parametros.h,10)/5;if(i3GEO.maparef.W()<=150){return 150}else{return parseInt(h,10)}},inicia:function(){if(i3GEO.arvoreDeCamadas.listaLigadosDesligados()[0].length==0){i3GEO.janela.tempoMsg($trad("umaLigada"));return}var r,pos,novoel,ins,temp,moveX,moveY,escondeRef,janela;if($i("i3geo_winRef")){janela=YAHOO.i3GEO.janela.manager.find("i3geo_winRef");janela.show();janela.bringToTop();return}if(!$i("i3geo_winRef")){novoel=document.createElement("div");novoel.id="i3geo_winRef";novoel.style.display="none";novoel.style.borderColor="gray";ins="";ins+='<div class="hd" style="border:0px solid black;text-align:left;z-index:20;padding-left: 0px;padding-bottom: 3px;padding-top: 1px;">';ins+='<span id=maparefmaismenosZoom style=display:none > ';temp="javascript:if(i3GEO.maparef.fatorZoomDinamico == -1){i3GEO.maparef.fatorZoomDinamico = 1};i3GEO.maparef.fatorZoomDinamico = i3GEO.maparef.fatorZoomDinamico + 1 ;$i(\"refDinamico\").checked = true;i3GEO.maparef.atualiza();";ins+="<button onclick='"+temp+"' class='btn btn-xs' style='margin:2px;padding:2px;'><span class='material-icons'>add_circle_outline</span></button>";temp="javascript:if(i3GEO.maparef.fatorZoomDinamico == 1){i3GEO.maparef.fatorZoomDinamico = -1};i3GEO.maparef.fatorZoomDinamico = i3GEO.maparef.fatorZoomDinamico - 1 ;$i(\"refDinamico\").checked = true;i3GEO.maparef.atualiza();";ins+="<button onclick='"+temp+"' class='btn btn-xs' style='margin:2px;padding:2px;'><span class='material-icons'>remove_circle_outline</span></button>";ins+="<div style='width: 100px;display:inline-table' class='form-group label-fixed condensed'>";ins+="<div style='width: 100%;' class='input-group'>";ins+="<select class='form-control' style='background-color:#094672' id='refDinamico' onchange='javascript:i3GEO.parametros.celularef=\"\";i3GEO.maparef.atualiza()'>";ins+="<option value='mapa' >"+$trad("refMapaAtual")+"</option>";ins+="<option value='dinamico' >"+$trad("refMapaDinamico")+"</option>";ins+="</select>";ins+="</div></div></div>";ins+='<div class="bd" style="border:0px solid black;text-align:left;padding:3px;height: '+i3GEO.maparef.H()+'px;" id="mapaReferencia" onmouseover="this.onmousemove=function(exy){i3GEO.eventos.posicaoMouseMapa(exy)}" >';ins+='<img style="cursor:pointer;display:none"class="img-rounded" onload="javascript:this.style.display = \'block\'" id="imagemReferencia" src="" onclick="javascript:i3GEO.maparef.click()">';ins+='</div>';novoel.innerHTML=ins;$(novoel).css("opacity",1);document.body.appendChild(novoel)}if($i("i3geo_winRef").style.display!=="block"){$i("i3geo_winRef").style.display="block";janela=new YAHOO.widget.Panel("i3geo_winRef",{height:i3GEO.maparef.H()+47+"px",width:i3GEO.maparef.W()+6+"px",fixedcenter:false,constraintoviewport:false,underlay:"shadow",close:true,visible:true,draggable:true,modal:false,iframe:false,strings:{close:"<span class='material-icons'>cancel</span>"}});YAHOO.i3GEO.janela.manager.register(janela);janela.cfg.setProperty("effect",[{effect:YAHOO.widget.ContainerEffect.FADE,duration:0.5}]);janela.render();janela.show();try{janela.header.style.height="40px"}catch(e){};r=$i("i3geo_winRef_c");if(r){r.style.position="absolute"}pos=i3GEO.util.pegaPosicaoObjeto($i(i3GEO.Interface.IDCORPO));$i("mapaReferencia").style.height=i3GEO.maparef.H()+"px";$i("i3geo_winRef").style.border="0px solid gray";moveX=pos[0]+i3GEO.parametros.w-i3GEO.maparef.W()+3-i3GEO.maparef.RIGHT;moveY=pos[1]+i3GEO.maparef.TOP;if(i3GEO.Interface.ATUAL==="googlemaps"){moveY+=30}janela.moveTo(moveX,moveY);escondeRef=function(){$i("imagemReferencia").src="";janela.destroy()};$(janela.close).click(escondeRef);if($i("localizarxygeoProjxg")){var temp=function(){i3GEO.coordenadas.atualizaGeo(objposicaocursor.dmsx,objposicaocursor.dmsy,"localizarxygeoProj")};$("#imagemReferencia").mousemove(temp)}}i3GEO.eventos.adicionaEventos("NAVEGAMAPA",["i3GEO.maparef.atualiza()"]);i3GEO.maparef.atualiza(true);$i("i3geo_winRef_h").className="hd2"},atualiza:function(forca){if(arguments.length===0){forca=false}var tiporef,temp;temp=$i("refDinamico")?tiporef=$i("refDinamico").value:tiporef="fixo";if($i("mapaReferencia")){temp=$i("maparefmaismenosZoom");if(tiporef==="dinamico"){i3GEO.php.referenciadinamica(i3GEO.maparef.processaImagem,i3GEO.maparef.fatorZoomDinamico,tiporef,i3GEO.maparef.W(),i3GEO.maparef.H());if(temp){temp.style.display="inline-table"}}if(tiporef==="mapa"){i3GEO.php.referenciadinamica(i3GEO.maparef.processaImagem,i3GEO.maparef.fatorZoomDinamico,tiporef,i3GEO.maparef.W(),i3GEO.maparef.H());if(temp){temp.style.display="inline-table"}}}else{i3GEO.eventos.removeEventos("NAVEGAMAPA",["i3GEO.maparef.atualiza()"])}},processaImagem:function(retorno){var m,box,temp,tiporef="fixo";if((retorno.data!=="erro")&&(retorno.data!==undefined)){eval(retorno.data);i3GEO.parametros.celularef=g_celularef;i3GEO.parametros.extentref=extentref;temp=$i("imagemReferencia");if(temp){m=new Image();m.src=refimagem;temp.src=m.src}temp=$i("refDinamico");if(temp){tiporef=temp.value}if(tiporef!=="fixo"){box=$i("boxref");if(box){box.style.display="none"}}i3GEO.maparef.atualizaBox()}},atualizaBox:function(){var box=i3GEO.maparef.criaBox(),w;i3GEO.calculo.ext2rect("boxref",i3GEO.parametros.extentref,i3GEO.parametros.mapexten,i3GEO.parametros.celularef,$i("mapaReferencia"));w=parseInt(box.style.width,10);if(w>120){box.style.display="none";return}box.style.display="block";box.style.top=parseInt(box.style.top,10)+4+"px";box.style.left=parseInt(box.style.left,10)+4+"px";if(w<3){box.style.width="3px";box.style.height="3px"}},criaBox:function(){var box=$i("boxref");if(!box){novoel=document.createElement("div");novoel.id="boxref";novoel.style.zIndex=10;novoel.style.position='absolute';novoel.style.cursor="move";novoel.style.backgroundColor="RGB(120,220,220)";novoel.style.borderWidth="3px";if(navm){novoel.style.filter='alpha(opacity=40)'}else{novoel.style.opacity=0.4}$i("mapaReferencia").appendChild(novoel);novoel.onmouseup=function(){var rect,telaminx,telamaxx,telaminy,m,x,ext;rect=$i("boxref");telaminx=parseInt(rect.style.left,10);telamaxy=parseInt(rect.style.top,10);telamaxx=telaminx+parseInt(rect.style.width,10);telaminy=telamaxy+parseInt(rect.style.height,10);m=i3GEO.calculo.tela2dd(telaminx,telaminy,i3GEO.parametros.celularef,i3GEO.parametros.extentref,"imagemReferencia");x=i3GEO.calculo.tela2dd(telamaxx,telamaxy,i3GEO.parametros.celularef,i3GEO.parametros.extentref,"imagemReferencia");ext=m[0]+" "+m[1]+" "+x[0]+" "+x[1];i3GEO.navega.zoomExt(i3GEO.configura.locaplic,i3GEO.configura.sid,"",ext)};return novoel}else{return box}},click:function(){if(i3GEO.Interface.ATUAL==="openlayers"||i3GEO.Interface.ATUAL==="googlemaps"){i3GEO.Interface[i3GEO.Interface.ATUAL].pan2ponto(objposicaocursor.ddx,objposicaocursor.ddy)}}}; |
| 249 | // | 249 | // |
| 250 | //compactados/ajuda_compacto.js | 250 | //compactados/ajuda_compacto.js |
| 251 | if(typeof(i3GEO)==='undefined'){var i3GEO={}}i3GEO.ajuda={abreDoc:function(url){if(!url){url="/documentacao/index.html"}window.open(i3GEO.configura.locaplic+url)},redesSociais:function(){i3GEO.janela.cria("400px","400px",i3GEO.configura.locaplic+"/ferramentas/redessociais/index.php","","","<div class='i3GeoTituloJanela'>"+$trad("u5c")+"</div>",i3GEO.util.generateId("redes"))},ferramenta:function(idajuda){var url=i3GEO.configura.locaplic+"/ferramentas/ajuda_usuario.php?"+"&idajuda="+idajuda;$.get(url).done(function(data){var json=jQuery.parseJSON(data);var texto=json[i3GEO.idioma.ATUAL];var titulo=json["titulo"][i3GEO.idioma.ATUAL];i3GEO.janela.closeMsg(texto)}).fail(function(){return})}}; | 251 | if(typeof(i3GEO)==='undefined'){var i3GEO={}}i3GEO.ajuda={abreDoc:function(url){if(!url){url="/documentacao/index.html"}window.open(i3GEO.configura.locaplic+url)},redesSociais:function(){i3GEO.janela.cria("400px","400px",i3GEO.configura.locaplic+"/ferramentas/redessociais/index.php","","","<div class='i3GeoTituloJanela'>"+$trad("u5c")+"</div>",i3GEO.util.generateId("redes"))},ferramenta:function(idajuda){var url=i3GEO.configura.locaplic+"/ferramentas/ajuda_usuario.php?"+"&idajuda="+idajuda;$.get(url).done(function(data){var json=jQuery.parseJSON(data);var texto=json[i3GEO.idioma.ATUAL];var titulo=json["titulo"][i3GEO.idioma.ATUAL];i3GEO.janela.closeMsg(texto)}).fail(function(){return})}}; |
js/maparef.js
| @@ -207,7 +207,7 @@ i3GEO.maparef = | @@ -207,7 +207,7 @@ i3GEO.maparef = | ||
| 207 | } | 207 | } |
| 208 | } | 208 | } |
| 209 | i3GEO.eventos.adicionaEventos("NAVEGAMAPA",["i3GEO.maparef.atualiza()"]); | 209 | i3GEO.eventos.adicionaEventos("NAVEGAMAPA",["i3GEO.maparef.atualiza()"]); |
| 210 | - this.atualiza(true); | 210 | + i3GEO.maparef.atualiza(true); |
| 211 | $i("i3geo_winRef_h").className = "hd2"; | 211 | $i("i3geo_winRef_h").className = "hd2"; |
| 212 | }, | 212 | }, |
| 213 | /** | 213 | /** |
| @@ -287,6 +287,7 @@ i3GEO.maparef = | @@ -287,6 +287,7 @@ i3GEO.maparef = | ||
| 287 | m.src = refimagem; | 287 | m.src = refimagem; |
| 288 | temp.src = m.src; | 288 | temp.src = m.src; |
| 289 | } | 289 | } |
| 290 | + | ||
| 290 | temp = $i("refDinamico"); | 291 | temp = $i("refDinamico"); |
| 291 | if (temp) { | 292 | if (temp) { |
| 292 | tiporef = temp.value; | 293 | tiporef = temp.value; |
| @@ -296,7 +297,6 @@ i3GEO.maparef = | @@ -296,7 +297,6 @@ i3GEO.maparef = | ||
| 296 | if (box) { | 297 | if (box) { |
| 297 | box.style.display = "none"; | 298 | box.style.display = "none"; |
| 298 | } | 299 | } |
| 299 | - return; | ||
| 300 | } | 300 | } |
| 301 | i3GEO.maparef.atualizaBox(); | 301 | i3GEO.maparef.atualizaBox(); |
| 302 | } | 302 | } |
| @@ -308,6 +308,9 @@ i3GEO.maparef = | @@ -308,6 +308,9 @@ i3GEO.maparef = | ||
| 308 | * | 308 | * |
| 309 | */ | 309 | */ |
| 310 | atualizaBox : function() { | 310 | atualizaBox : function() { |
| 311 | + if (typeof (console) !== 'undefined') | ||
| 312 | + console.info("i3GEO.maparef.atualizaBox()"); | ||
| 313 | + | ||
| 311 | var box = i3GEO.maparef.criaBox(), w; | 314 | var box = i3GEO.maparef.criaBox(), w; |
| 312 | // | 315 | // |
| 313 | // aplica ao box um novo tamanho | 316 | // aplica ao box um novo tamanho |
| @@ -317,7 +320,8 @@ i3GEO.maparef = | @@ -317,7 +320,8 @@ i3GEO.maparef = | ||
| 317 | i3GEO.parametros.extentref, | 320 | i3GEO.parametros.extentref, |
| 318 | i3GEO.parametros.mapexten, | 321 | i3GEO.parametros.mapexten, |
| 319 | i3GEO.parametros.celularef, | 322 | i3GEO.parametros.celularef, |
| 320 | - $i("mapaReferencia")); | 323 | + $i("mapaReferencia") |
| 324 | + ); | ||
| 321 | w = parseInt(box.style.width, 10); | 325 | w = parseInt(box.style.width, 10); |
| 322 | if (w > 120) { | 326 | if (w > 120) { |
| 323 | box.style.display = "none"; | 327 | box.style.display = "none"; |
| @@ -332,6 +336,9 @@ i3GEO.maparef = | @@ -332,6 +336,9 @@ i3GEO.maparef = | ||
| 332 | } | 336 | } |
| 333 | }, | 337 | }, |
| 334 | criaBox : function() { | 338 | criaBox : function() { |
| 339 | + if (typeof (console) !== 'undefined') | ||
| 340 | + console.info("i3GEO.maparef.criaBox()"); | ||
| 341 | + | ||
| 335 | var box = $i("boxref"); | 342 | var box = $i("boxref"); |
| 336 | if (!box) { | 343 | if (!box) { |
| 337 | novoel = document.createElement("div"); | 344 | novoel = document.createElement("div"); |
temas/_lbairros.map
| 1 | MAP | 1 | MAP |
| 2 | - FONTSET "/var/www/i3geo/symbols/fontes.txt" | ||
| 3 | - SYMBOLSET "/var/www/i3geo/symbols/simbolosv6.sym" | 2 | + FONTSET "/var/www/i3geo/symbols/fontes.txt" |
| 3 | + SYMBOLSET "/var/www/i3geo/symbols/simbolosv6.sym" | ||
| 4 | LAYER | 4 | LAYER |
| 5 | CONNECTION "i3geosaude" | 5 | CONNECTION "i3geosaude" |
| 6 | CONNECTIONTYPE POSTGIS | 6 | CONNECTIONTYPE POSTGIS |
| 7 | - DATA "the_geom from (select gid, st_setsrid(the_geom,4326) as the_geom,co_bairro,no_bairro,no_distr,no_municip from i3geo_metaestat.bairros/*FW*//*FW*/) as foo using unique co_bairro using srid=4326" | 7 | + DATA "the_geom from (select gid, st_setsrid(the_geom,4326) as the_geom,co_bairro,no_bairro,no_distr,no_municip from i3geo_metaestat.bairros ) as foo using unique co_bairro using srid=4326" |
| 8 | METADATA | 8 | METADATA |
| 9 | "TIP" "no_bairro,id" | 9 | "TIP" "no_bairro,id" |
| 10 | "cache" "sim" | 10 | "cache" "sim" |
| 11 | - "olopacity" "" | ||
| 12 | "CLASSE" "SIM" | 11 | "CLASSE" "SIM" |
| 13 | "permitekmz" "SIM" | 12 | "permitekmz" "SIM" |
| 14 | - "gmopacity" "" | ||
| 15 | - "gmstatus" "" | ||
| 16 | "ITENSDESC" "id,Código bairro,Nome,Distrito,Município" | 13 | "ITENSDESC" "id,Código bairro,Nome,Distrito,Município" |
| 17 | "EDITAVEL" "NAO" | 14 | "EDITAVEL" "NAO" |
| 18 | - "arquivotemaoriginal" "" | ||
| 19 | - "olstatus" "" | ||
| 20 | - "nomeoriginal" "" | ||
| 21 | "wkttip" "SIM" | 15 | "wkttip" "SIM" |
| 22 | "permitedownload" "SIM" | 16 | "permitedownload" "SIM" |
| 23 | - "FILTROORIGINAL" "" | ||
| 24 | "permitecomentario" "NAO" | 17 | "permitecomentario" "NAO" |
| 25 | - "DATAORIGINAL" "" | ||
| 26 | "escondido" "NAO" | 18 | "escondido" "NAO" |
| 27 | "download" "SIM" | 19 | "download" "SIM" |
| 28 | "ITENS" "gid,co_bairro,no_bairro,no_distr,no_municip" | 20 | "ITENS" "gid,co_bairro,no_bairro,no_distr,no_municip" |
| @@ -49,6 +41,4 @@ MAP | @@ -49,6 +41,4 @@ MAP | ||
| 49 | TITLE "" | 41 | TITLE "" |
| 50 | END # CLASS | 42 | END # CLASS |
| 51 | END # LAYER | 43 | END # LAYER |
| 52 | - | ||
| 53 | END # MAP | 44 | END # MAP |
| 54 | - |