summaryrefslogtreecommitdiffstats
path: root/admin/WebConsole/includes/arbol.php
blob: 7bfca904cadbb1039dd4ac4c4ec821225fee164f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
<?php
/** @file includes/arbol.php
 *  Funciones auxiliares para pintar árboles de nodos en el frame izquierdo
 */

/**
 * Devuelve un array de grupos de nodos. Ordenados por tipos de nodos y grupo
 *
 * @param[tipo_nodo] str tipo de elemento a mostrar en el árbol (aulas, imagenes, ...)
 * @return array de grupos.
 */
function grupos_arbol($tipo_nodo) {
        global $cmd;
        global $idcentro;

        $grupos_hijos=Array();
	$sql="";
	$num_tipo="";

	switch ($tipo_nodo){
	    case 'aulas':
		global $AMBITO_GRUPOSAULAS;
		$num_tipo=$AMBITO_GRUPOSAULAS;
                break; 
	    case 'componenteshardware':
		global $AMBITO_GRUPOSCOMPONENTESHARD;
		$num_tipo=$AMBITO_GRUPOSCOMPONENTESHARD;
                break; 
	    case 'componentessoftware':
		global $AMBITO_GRUPOSCOMPONENTESSOFT;
		$num_tipo=$AMBITO_GRUPOSCOMPONENTESSOFT;
                break; 
	    case 'imagenes':
		$num_tipo="70, 71, 72";
                break; 
	    case 'menus':
		global $AMBITO_GRUPOSMENUS;
		$num_tipo=$AMBITO_GRUPOSMENUS;
                break; 
	    case 'ordenadores':
		$sql="SELECT gruposordenadores.idgrupo AS id, nombregrupoordenador AS nombre,
                            gruposordenadores.idaula AS conjuntoid, gruposordenadores.grupoid AS grupopadre
                       FROM gruposordenadores
                 INNER JOIN aulas
                      WHERE gruposordenadores.idaula=aulas.idaula AND idcentro=$idcentro
                   ORDER BY conjuntoid, gruposordenadores.grupoid;";
                break; 
	    case 'perfileshardware':
		global $AMBITO_GRUPOSPERFILESHARD;
		$num_tipo=$AMBITO_GRUPOSPERFILESHARD;
                break; 
	    case 'perfilessoftware':
		global $AMBITO_GRUPOSPERFILESSOFT;
		$num_tipo=$AMBITO_GRUPOSPERFILESSOFT;
                break; 
	    case 'perfilessoftwareincremental':
		global $AMBITO_GRUPOSSOFTINCREMENTAL;
		$num_tipo=$AMBITO_GRUPOSSOFTINCREMENTAL;
                break; 
	    case 'procedimientos':
		global $AMBITO_GRUPOSPROCEDIMIENTOS;
		$num_tipo=$AMBITO_GRUPOSPROCEDIMIENTOS;
                break; 
	    case 'repositorios':
		global $AMBITO_GRUPOSREPOSITORIOS;
		$num_tipo=$AMBITO_GRUPOSREPOSITORIOS;
                break; 
	    case 'tareas':
		global $AMBITO_GRUPOSTAREAS;
		$num_tipo=$AMBITO_GRUPOSTAREAS;
                break; 
	}
        if ($sql == "" && $num_tipo != "") {
		$sql="SELECT idgrupo AS id, nombregrupo AS nombre, grupos.grupoid AS grupopadre, tipo AS conjuntoid
                       FROM grupos
                      WHERE idcentro=$idcentro AND tipo IN ($num_tipo)
                   ORDER BY tipo, grupopadre, grupoid;";
	}
	if ($sql == "")	return ($grupos_hijos);

        $rs=new Recordset;
        $cmd->texto=$sql;
        $rs->Comando=&$cmd;
        if (!$rs->Abrir()) return($grupos_hijos);

        $rs->Primero();
        $oldgrupopadre=0;
        $num=-1;
        while (!$rs->EOF){
                $grupopadre=$rs->campos["grupopadre"];
                $nombre=$rs->campos["nombre"];

                $id=$rs->campos["id"];
                $conjuntoid=$rs->campos["conjuntoid"];
		// El tipo de grupo de imagenes son 70, 71 y 72 correspondiendo al tipo de imagen 1, 2 y 3
		if ($tipo_nodo == "imagenes") $conjuntoid-=69;

                if ($oldgrupopadre != $grupopadre) {
                        $oldgrupopadre=$grupopadre;
                        // Cuando cambio de grupo pongo el orden del array a cero
                        $num=0;
                } else {
                        $num++;
                }
                $grupos_hijos[$conjuntoid][$grupopadre][$num]["id"] = $id;
                $grupos_hijos[$conjuntoid][$grupopadre][$num]["nombre"] = $nombre;

                $rs->Siguiente();
        }
        $rs->Cerrar();
        return ($grupos_hijos);

}

/**
 * Construye la parte del árbol correspondiente a un grupo de nodos: lista sus nodos y sus grupos hijos.
 *
 * @param[tipo_nodo] str tipo de elemento que muestra el árbol
 * @param[idgrupo]   int identificados del grupo que se está listando
 * @param[nivel]     int nivel de profundidad del árbol
 * @param[orden]     int orden dentro del nivel del árbol
 * @param[nodos]     array nodos
 * @param[grupos]    array grupos de nodos
 * @return           orden de la lista del último elemento listado
 */
function lista_grupo_arbol($tipo_nodo, $tipo, $idgrupo, $nivel, $orden, $nodos, $grupos){
	/* Al cargar la página sólo se muestra el primer nivel del árbol. */
	$class=($nivel==1)? "": 'class="interior"';
        $nivel=$nivel+1;
	if ($tipo_nodo == "aulas") {
	    global $ordenadores;
	    global $grp_ordenadores;
	    global $idaulas;
	}
        echo "\n".'    <ul '.$class." >\n";
        // si existen grupos hijos del actual creo la lista con la función listaGrupo.
        if (isset ($grupos[$tipo][$idgrupo])){
            foreach ($grupos[$tipo][$idgrupo] as $hijo) {
                $orden=$orden+1;
		echo '      <li id="grupo_'.$hijo["id"].'"><input type="checkbox" name="list" id="nivel'.$nivel.'-'.$orden.'">
			      <label oncontextmenu="ocultar_menu(); mostrar_menu(event,'. $tipo.', '.$hijo["id"].', \'menu-grupo-'.$tipo.'\');return false;" for="nivel'.$nivel.'-'.$orden.'">
                                 <img class="menu_icono" src="../images/iconos/carpeta.gif">'.$hijo["nombre"].'
                              </label>'."\n";

		$orden++;
                $orden=lista_grupo_arbol($tipo_nodo, $tipo, $hijo["id"], $nivel, $orden, $nodos, $grupos);
            }
            echo "      </li>"."\n";
        }
        // Creo la lista de las nodos dentro del grupo (si existen).
        if (isset ($nodos[$tipo][$idgrupo])){
            foreach ($nodos[$tipo][$idgrupo] as $nodo){
		if ($tipo_nodo == "aulas"){
		    // Incluyo input para que se pueda abrir el nodo
		    echo '      <li id="'.$tipo_nodo.'_'.$nodo["id"].'">
				    <input type="checkbox" name="list" id="nivel'.$nivel.'-'.$orden.'">
				    <label oncontextmenu="ocultar_menu(); mostrar_menu(event,'. $tipo.', '.$nodo["id"].', \'menu-'.$tipo.'\');return false;" for="nivel'.$nivel.'-'.$orden.'">
					<img class="menu_icono" src="../images/iconos/imagen.gif"> '.$nodo["descripcion"].'
				    </label>'."\n" ;

		    // Listo grupo de ordenadores
		    lista_grupo_arbol("ordenadores",$nodo["id"],0, $nivel, $orden,$ordenadores,$grp_ordenadores);
		} else {
		    echo '      <li id="'.$tipo_nodo.'_'.$nodo["id"].'" oncontextmenu="ocultar_menu(); mostrar_menu(event,'. $tipo.', '.$nodo["id"].', \'menu-'.$tipo.'\');return false;">
				    <a href="#r"> <img class="menu_icono" src="../images/iconos/imagen.gif"> '.$nodo["descripcion"].'</a>';
		}
                echo "      </li>"."\n";
            }
        }
        echo "    </ul>"."\n";
        return($orden);
}


/**
 * Construye la parte del árbol correspondiente al raíz. Si los nodos son de distintos tipos muestra también el primer nivel (ej: procedimientos y tareas).
 *
 * @param[tipo_nodo] str tipo de elemento a mostrar en el árbol (aulas, imagenes, ...)
 * @param[nodos] array nodos a mostrar
 * @param[grupos] array grupos de nodos a mostrar
 * @return Escribe la raíz del árbol de nodos y el primer nivel.
 */
function lista_raiz_arbol ($tipo_nodo, $nodos, $grupos){
        global $TbMsg;
        global $NUM_TIPOS_IMAGENES;
        $orden=0;
	if ($tipo_nodo == "aulas") {
	    // Definimos variables para mostrar ordenadores
	    global $ordenadores;
	    global $grp_ordenadores;
	    $ordenadores=nodos_arbol("ordenadores");
	    $grp_ordenadores=grupos_arbol("ordenadores");
	}
        echo '<ul id="menu_arbol">'."\n";
	$keys=array_keys($nodos);
	if (count($keys) == 1) {
	    $tipo= array_keys($nodos)[0];
	    echo '  <li><input type="checkbox" name="list" id="nivel1-1">
			<label for="nivel1-1" oncontextmenu="ocultar_menu(); mostrar_menu(event, '. $tipo.', 0, \'menu-tipo-'.$tipo.'\');return false;">
			    <img class="menu-icono" src="../images/iconos/imagenes.gif"> Inicio árbol
			</label>'."\n";
	    lista_grupo_arbol($tipo_nodo, $keys[0], 0, 1, $orden, $nodos, $grupos);
	} else {
            echo '  <li><input type="checkbox" name="list" id="nivel1-1"><label for="nivel1-1"><img class="menu-icono" src="../images/iconos/imagenes.gif"> Inicio árbol </label>'."\n";
	    foreach ($keys as $tipo) {
                // Recorremos los grupos hijos desde el cero
                echo '    <ul>'."\n";
                echo '       <li id="grupo_'.$tipo.'_0" >
				  <input type="checkbox" name="list" id="nivel2-'.$tipo.'">
				  <label oncontextmenu="ocultar_menu(); mostrar_menu(event, '. $tipo.', 0, \'menu-tipo-'.$tipo.'\');return false;" for="nivel2-'.$tipo.'">
					<img class="menu-icono" src="../images/iconos/carpeta.gif"> Falta nombre del tipo: '.$tipo.'
				  </label>'."\n";
                $orden=lista_grupo_arbol($tipo_nodo, $tipo, 0, 2, $orden, $nodos, $grupos);
                $orden=$orden+1;
                echo '       </li>'."\n";
                echo '    </ul>'."\n";
	    }
        }
        echo "  </li>"."\n";
        echo "</ul>"."\n";
}



/*
 * Descripción: Devuelve un array de nodos ordenados por el grupo al que pertenecen.
 *
 * @param[tipo_nodo] str tipo de elemento a mostrar en el árbol (aulas, imagenes, ...)
 * @return           Array de nodos
 * @note             Existen nodos clasificados por tipos. Para los no tienen tipos se usa un único tipo = 1
 * @note             Si no existen nodos se devuelve un array $nodo[$int_tipo_nodo]=Array();. Para que se muestre en el árbol.
 */
function nodos_arbol($tipo_nodo){
        global $TbMsg;
        global $cmd;
        global $idcentro;
	//$nodos= Array();

	switch ($tipo_nodo){
	    case 'aulas':
		global $AMBITO_GRUPOSAULAS;
		$num_tipo=$AMBITO_GRUPOSAULAS;
		$sql="SELECT idaula AS id, nombreaula AS nombre, grupoid, '$AMBITO_GRUPOSAULAS' AS conjuntoid
			FROM  aulas
                      WHERE idcentro=$idcentro ORDER BY conjuntoid, grupoid;";
                break; 
	    case 'comandos':
		$num_tipo=1;
		$sql="SELECT idcomando AS id, descripcion AS nombre, urlimg,
			    '1' AS conjuntoid, '0' AS grupoid
			FROM comandos
		       WHERE activo=1 ORDER BY conjuntoid, grupoid;";
                break; 
	    case 'componenteshardware':
		global $AMBITO_GRUPOSCOMPONENTESHARD;
		$num_tipo=$AMBITO_GRUPOSCOMPONENTESHARD;
		$sql="SELECT hardwares.idhardware AS id, hardwares.descripcion AS nombre,
			     tipohardwares.urlimg, '$AMBITO_GRUPOSCOMPONENTESHARD' AS conjuntoid, grupoid
		        FROM hardwares INNER JOIN tipohardwares
		       WHERE hardwares.idtipohardware=tipohardwares.idtipohardware AND idcentro=$idcentro
                    ORDER BY conjuntoid, grupoid;";
                break; 
	    case 'componentessoftware':
		global $AMBITO_GRUPOSCOMPONENTESSOFT;
		$num_tipo=$AMBITO_GRUPOSCOMPONENTESSOFT;
		$sql="SELECT softwares.idsoftware AS id, softwares.descripcion AS nombre,
			     tiposoftwares.urlimg, '$AMBITO_GRUPOSCOMPONENTESSOFT' AS conjuntoid, grupoid
                        FROM softwares INNER JOIN tiposoftwares
		       WHERE softwares.idtiposoftware=tiposoftwares.idtiposoftware AND idcentro=$idcentro
		     ORDER BY conjuntoid, grupoid;";
                break; 
	    case 'imagenes':
		$num_tipo=1;
		$sql="SELECT DISTINCT imagenes.idimagen AS id ,imagenes.descripcion AS nombre,
			              imagenes.tipo AS conjuntoid, imagenes.grupoid,
                             IF(imagenes.idrepositorio=0,basica.idrepositorio,imagenes.idrepositorio)  AS repo
                        FROM imagenes
                   LEFT JOIN imagenes AS basica  ON imagenes.imagenid=basica.idimagen
                       WHERE imagenes.idcentro=$idcentro ORDER BY conjuntoid, grupoid;";
                break; 
	    case 'menus':
		global $AMBITO_GRUPOSMENUS;
		$num_tipo=$AMBITO_GRUPOSMENUS;
		$sql="SELECT idmenu AS id, descripcion AS nombre, '$AMBITO_GRUPOSMENUS' AS conjuntoid, grupoid
			FROM menus  
		       WHERE idcentro=$idcentro ORDER BY conjuntoid, grupoid;";
                break; 
	    case 'ordenadores':
		$sql="SELECT idordenador AS id, nombreordenador AS nombre,
                             ordenadores.idaula AS conjuntoid, ordenadores.grupoid
                        FROM ordenadores
                  INNER JOIN aulas
                       WHERE ordenadores.idaula=aulas.idaula AND idcentro=$idcentro
                    ORDER BY conjuntoid, grupoid;";
                break; 
	    case 'perfileshardware':
		global $AMBITO_GRUPOSPERFILESHARD;
		$num_tipo=$AMBITO_GRUPOSPERFILESHARD;
		$sql="SELECT idperfilhard AS id, descripcion AS nombre,
			     '$AMBITO_GRUPOSPERFILESHARD' AS conjuntoid, grupoid
			FROM perfileshard
		       WHERE idcentro=$idcentro
                   ORDER BY conjuntoid, grupoid;";
                break; 
	    case 'perfilessoftware':
		global $AMBITO_GRUPOSPERFILESSOFT;
		$num_tipo=$AMBITO_GRUPOSPERFILESSOFT;
		$sql="SELECT idperfilsoft AS id, descripcion AS nombre,
			     '$AMBITO_GRUPOSPERFILESSOFT' AS conjuntoid, grupoid
			FROM perfilessoft
		       WHERE idcentro=$idcentro
                   ORDER BY conjuntoid, grupoid;";
                break; 
	    case 'procedimientos':
		global $AMBITO_GRUPOSPROCEDIMIENTOS;
		$num_tipo=$AMBITO_GRUPOSPROCEDIMIENTOS;
		$sql="SELECT idprocedimiento AS id, descripcion AS nombre, '$AMBITO_GRUPOSPROCEDIMIENTOS' AS conjuntoid, grupoid
		        FROM procedimientos
		       WHERE idcentro=$idcentro ORDER BY conjuntoid, grupoid;";
                break; 
	    case 'repositorios':
		global $AMBITO_GRUPOSREPOSITORIOS;
		$num_tipo=$AMBITO_GRUPOSREPOSITORIOS;
		$sql="SELECT idrepositorio AS id, nombrerepositorio AS nombre, '$AMBITO_GRUPOSREPOSITORIOS' AS conjuntoid, grupoid
	    	        FROM repositorios
		       WHERE idcentro=$idcentro ORDER BY conjuntoid, grupoid;";
                break; 
	    case 'tareas':
		global $AMBITO_GRUPOSTAREAS;
		$num_tipo=$AMBITO_GRUPOSTAREAS;
		$sql="SELECT idtarea AS id, descripcion AS nombre, '$AMBITO_GRUPOSTAREAS' AS conjuntoid, grupoid
                        FROM tareas 
		       WHERE idcentro=$idcentro ORDER BY conjuntoid, grupoid;";
                break; 
	    case 'tiposhardware':
		$num_tipo=1;
		$sql="SELECT idtipohardware AS id, descripcion AS nombre, urlimg, nemonico,
			     '1' AS conjuntoid, '0' AS grupoid
                        FROM tipohardwares
		    ORDER BY conjuntoid, grupoid;";
                break; 
	    case 'tipossoftware':
		$num_tipo=1;
		$sql="SELECT idtiposoftware AS id, descripcion AS nombre, urlimg,
			     '1' AS conjuntoid, '0' AS grupoid
                        FROM tiposoftwares
		    ORDER BY conjuntoid, grupoid;";
                break; 
	}
	
        $nodos[$num_tipo]=Array();
        $rs=new Recordset;
        $cmd->texto=$sql;

        $rs->Comando=&$cmd;
        if (!$rs->Abrir()) return($nodos);

        $rs->Primero();
        $ordenNodo=-1;
	$oldgrupoid=(isset($rs->campos["grupoid"]))? $rs->campos["grupoid"] : 0;
	while (!$rs->EOF){
		$conjuntoid=$rs->campos["conjuntoid"];
                $id=$rs->campos["id"];
                $descripcion=$rs->campos["nombre"];
                // Las nodos de un grupo son un array. Cuando cambio de grupo pongo el orden a cero:
                $grupoid=(isset($rs->campos["grupoid"]))? $rs->campos["grupoid"] : 0;
                if ($oldgrupoid != $grupoid) {
                        $oldgrupoid=$grupoid;
                        $ordenNodo=0;
                } else {
                        $ordenNodo=$ordenNodo+1;
                }

                $nodos[$conjuntoid][$grupoid][$ordenNodo]["descripcion"]=$descripcion;
                $nodos[$conjuntoid][$grupoid][$ordenNodo]["id"]=$id;
                $rs->Siguiente();
        }

        $rs->Cerrar();
        return($nodos);
}