EN · DE · RU · FR · ES

#3135: TreeTable.java

projectforge-wicket/src/main/java/org/projectforge/web/tree/TreeTable.java Clase Java, projectforge-wicket/src/main/java/org/projectforge/web/tree/TreeTable.java 298 líneas · 183 código · 93 comentarios · 22 en blanco
Propósito: Archivo fuente: projectforge/web/tree/TreeTable.java. TreeTable.java es parte de la aplicación de gestión de proyectos de código abierto ProjectForge.

Fuente (primeras 100 líneas)

/////////////////////////////////////////////////////////////////////////////
//
// Project ProjectForge Community Edition
//         www.projectforge.org
//
// Copyright (C) 2001-2026 Micromata GmbH, Germany (www.micromata.com)
//
// ProjectForge tiene doble licencia.
//
// Esta edición comunitaria es software libre; puedes redistribuirla y/o
// modificarla bajo los términos de la Licencia Pública General GNU publicada
// por la Free Software Foundation; versión 3 de la Licencia.
//
// Esta edición comunitaria se distribuye con la esperanza de que sea útil,
// pero SIN NINGUNA GARANTÍA; sin siquiera la garantía implícita de
// COMERCIABILIDAD o IDONEIDAD PARA UN PROPÓSITO PARTICULAR. Consulte la Licencia General
// Pública de GNU para más detalles.
//
// Deberías haber recibido una copia de la Licencia Pública General GNU junto
// con este programa; si no, visita http://www.gnu.org/licenses/.
//
/////////////////////////////////////////////////////////////////////////////

package org.projectforge.web.tree;

import java.io.Serializable;
import java.util.*;

/**
 * Un TreeTable es una vista de árbol realmente agradable cuyas entradas se mostrarán como filas de tabla HTML. La funcionalidad de este árbol es como la de un administrador
 * de archivos con vista de árbol. Es mucho más de lo que parece el código fuente ;-) <br>
 * Atención: Esta implementación de un árbol no es segura para hilos, porque las modificaciones las realizará un solo hilo.
 * @see TreeTableNode
 */
public abstract class TreeTable<T extends TreeTableNode> implements Serializable
{
  private static final long serialVersionUID = -8178813483140004622L;

  /** El nodo raíz. */
  protected T root;

  /**
   * Todos los nodos abiertos se registrarán con sus hashIds en un HashSet, de modo que después de recargar los datos se pueda restaurar el historial de nodos abiertos.
   */
  private Set<Serializable> openedNodes = new HashSet<Serializable>();

  /** Para encontrar más rápido los nodos contenedores por hashId. */
  protected Map<Serializable, T> allNodes = new HashMap<Serializable, T>();

  /**
   * @return Verdadero, si al menos se proporciona el nodo raíz.
   */
  public boolean isInitialized()
  {
    return this.root != null;
  }

  /**
   * Obtiene los nodos como lista. Por primera vez, solo se mostrarán los hijos de nivel superior. Después, el usuario podrá abrir y cerrar algunas entradas
   * como en una vista de árbol de un administrador de archivos.
   */
  @SuppressWarnings("unchecked")
  public List<T> getNodeList(TreeTableFilter<TreeTableNode> filter)
  {
    List<T> nodes = new ArrayList<T>();
    if (root == null) {
      return null;
    }
    SortedSet<T> children = (SortedSet<T>) root.getChildren();
    if (children != null) {
      for (T node : children) {
        node.buildNodeList((List<TreeTableNode>) nodes, 0, filter);
      }
    }
    return nodes;
  }

  /**
   * Obtiene todos los nodos disponibles como lista.
   */
  public List<T> getAllNodes()
  {
    return getNodeList(null);
  }

  /**
   * Llamado después de que el usuario haya hecho clic en el icono de carpeta / carpeta abierta.
   * @param hashId El hashID del nodo para el cual se liberó el evento.
   * @param eventKey Si es "open", entonces el nodo se abrirá si ya está cerrado; de lo contrario, el nodo se abrirá si ya está cerrado.
   * @return TreeNode encontrado por hashId, de lo contrario nulo.
   */
  public TreeTableNode setOpenedStatusOfNode(String eventKey, Serializable hashId)
  {
    if ("explore".equals(eventKey) == true) {
      return setOpenedStatusOfNode(TreeTableEvent.EXPLORE, hashId);
    } else if ("implore".equals(eventKey) == true) {
      return setOpenedStatusOfNode(TreeTableEvent.IMPLORE, hashId);
    } else if ("open".equals(eventKey) == true) {
      return setOpenedStatusOfNode(TreeTableEvent.OPEN, hashId);
    } else {

Historial Git

868d6abb7 2025 -> 2026
63081666f Encabezados de archivos fuente: 2024-> 2025.
b6092df09 Copyright 2023 -> 2024
ab45d51fa Copyright 2001-2022 -> 2001-2023.
5f7ef41b8 Copyright 2021 -> 2022

868d6abb7

2025 -> 2026
868d6abb75cd191a892911ac8e45058932cf9074
diff --git a/projectforge-wicket/src/main/java/org/projectforge/web/tree/TreeTable.java b/projectforge-wicket/src/main/java/org/projectforge/web/tree/TreeTable.java
index 25359ff2b..138987be9 100644
--- a/projectforge-wicket/src/main/java/org/projectforge/web/tree/TreeTable.java
+++ b/projectforge-wicket/src/main/java/org/projectforge/web/tree/TreeTable.java
@@ -3,7 +3,7 @@
 // Project ProjectForge Community Edition
 //         www.projectforge.org
 //
-// Copyright (C) 2001-2025 Micromata GmbH, Germany (www.micromata.com)
+// Copyright (C) 2001-2026 Micromata GmbH, Germany (www.micromata.com)
 //
 // ProjectForge tiene doble licencia.
 //

63081666f

Encabezados de archivos fuente: 2024-> 2025.
63081666f620fb87315f01b817e560e0b2f6a33a
diff --git a/projectforge-wicket/src/main/java/org/projectforge/web/tree/TreeTable.java b/projectforge-wicket/src/main/java/org/projectforge/web/tree/TreeTable.java
index 8e8261956..25359ff2b 100644
--- a/projectforge-wicket/src/main/java/org/projectforge/web/tree/TreeTable.java
+++ b/projectforge-wicket/src/main/java/org/projectforge/web/tree/TreeTable.java
@@ -3,7 +3,7 @@
 // Project ProjectForge Community Edition
 //         www.projectforge.org
 //
-// Copyright (C) 2001-2024 Micromata GmbH, Germany (www.micromata.com)
+// Copyright (C) 2001-2025 Micromata GmbH, Germany (www.micromata.com)
 //
 // ProjectForge tiene doble licencia.
 //

b6092df09

Copyright 2023 -> 2024
b6092df0927c4a3b161e888445f31dcab57493f2
diff --git a/projectforge-wicket/src/main/java/org/projectforge/web/tree/TreeTable.java b/projectforge-wicket/src/main/java/org/projectforge/web/tree/TreeTable.java
index 61329cc9d..8e8261956 100644
--- a/projectforge-wicket/src/main/java/org/projectforge/web/tree/TreeTable.java
+++ b/projectforge-wicket/src/main/java/org/projectforge/web/tree/TreeTable.java
@@ -3,7 +3,7 @@
 // Project ProjectForge Community Edition
 //         www.projectforge.org
 //
-// Copyright (C) 2001-2023 Micromata GmbH, Germany (www.micromata.com)
+// Copyright (C) 2001-2024 Micromata GmbH, Germany (www.micromata.com)
 //
 // ProjectForge tiene doble licencia.
 //

ab45d51fa

Copyright 2001-2022 -> 2001-2023.
ab45d51fa419ede6174b31d69987f96d4b841ff9
diff --git a/projectforge-wicket/src/main/java/org/projectforge/web/tree/TreeTable.java b/projectforge-wicket/src/main/java/org/projectforge/web/tree/TreeTable.java
index 389c1e9fa..61329cc9d 100644
--- a/projectforge-wicket/src/main/java/org/projectforge/web/tree/TreeTable.java
+++ b/projectforge-wicket/src/main/java/org/projectforge/web/tree/TreeTable.java
@@ -3,7 +3,7 @@
 // Project ProjectForge Community Edition
 //         www.projectforge.org
 //
-// Copyright (C) 2001-2022 Micromata GmbH, Germany (www.micromata.com)
+// Copyright (C) 2001-2023 Micromata GmbH, Germany (www.micromata.com)
 //
 // ProjectForge tiene doble licencia.
 //

5f7ef41b8

Copyright 2021 -> 2022
5f7ef41b8cbbf29b1bff094f0c0b708dcaecb19e
diff --git a/projectforge-wicket/src/main/java/org/projectforge/web/tree/TreeTable.java b/projectforge-wicket/src/main/java/org/projectforge/web/tree/TreeTable.java
index 241fdfc4c..389c1e9fa 100644
--- a/projectforge-wicket/src/main/java/org/projectforge/web/tree/TreeTable.java
+++ b/projectforge-wicket/src/main/java/org/projectforge/web/tree/TreeTable.java
@@ -3,7 +3,7 @@
 // Project ProjectForge Community Edition
 //         www.projectforge.org
 //
-// Copyright (C) 2001-2021 Micromata GmbH, Germany (www.micromata.com)
+// Copyright (C) 2001-2022 Micromata GmbH, Germany (www.micromata.com)
 //
 // ProjectForge tiene doble licencia.
 //