From 23a46b4be35277e06ec89f48730eeb694e686be8 Mon Sep 17 00:00:00 2001
From: Kenmegne <stephanie.kenmegne@gmail.com>
Date: Thu, 18 Jun 2026 15:40:06 +0000
Subject: [PATCH] add fdx-commons and fdx-consultation

---
 fdx-consultation/fdxconsultation-model/src/main/java/com/megatim/fdxconsultation/model/stats/TableConfiguration.java |  101 ++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 101 insertions(+), 0 deletions(-)

diff --git a/fdx-consultation/fdxconsultation-model/src/main/java/com/megatim/fdxconsultation/model/stats/TableConfiguration.java b/fdx-consultation/fdxconsultation-model/src/main/java/com/megatim/fdxconsultation/model/stats/TableConfiguration.java
new file mode 100644
index 0000000..791030b
--- /dev/null
+++ b/fdx-consultation/fdxconsultation-model/src/main/java/com/megatim/fdxconsultation/model/stats/TableConfiguration.java
@@ -0,0 +1,101 @@
+package com.megatim.fdxconsultation.model.stats;
+
+import com.megatim.fdxcommons.model.search.CriteriaEntitySearch;
+import com.megatim.fdxconsultation.model.base.BaseEntity;
+import com.megatim.fdxcommons.model.enumeration.FonctionAggregation;
+import com.megatim.fdxconsultation.model.enums.TypeResultatConfiguration;
+import java.io.Serializable;
+import java.util.HashSet;
+import java.util.Objects;
+import java.util.Set;
+import javax.persistence.CascadeType;
+import javax.persistence.Entity;
+import javax.persistence.EnumType;
+import javax.persistence.Enumerated;
+import javax.persistence.FetchType;
+import javax.persistence.GeneratedValue;
+import javax.persistence.GenerationType;
+import javax.persistence.Id;
+import javax.persistence.JoinColumn;
+import javax.persistence.ManyToOne;
+import javax.persistence.OneToMany;
+import javax.persistence.OneToOne;
+import javax.persistence.SequenceGenerator;
+import javax.validation.constraints.NotEmpty;
+import javax.validation.constraints.NotNull;
+import lombok.Getter;
+import lombok.NoArgsConstructor;
+import lombok.Setter;
+
+/**
+ *
+ * @author ASUS
+ */
+@Getter
+@Setter
+@Entity
+@NoArgsConstructor
+public class TableConfiguration extends BaseEntity implements Serializable {
+
+    @Id
+    @SequenceGenerator(name = "SEQ_TABLE_CONF",
+            sequenceName = "SEQ_TABLE_CONF",
+            allocationSize = 1,
+            initialValue = 1)
+    @GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "SEQ_TABLE_CONF")
+    private Long id;
+
+    @NotEmpty(message = "Le libellé est obligatoire")
+    private String libelle;
+
+    @OneToOne(cascade = CascadeType.ALL)
+    @JoinColumn(name = "targeted_column_id", referencedColumnName = "id")
+    private TableauBordColumn targetedColumn;
+
+    @OneToMany(mappedBy = "tableConfiguration", cascade = CascadeType.ALL)
+    private Set<TableauBordColumn> groupingColumns = new HashSet<>();
+
+    @Enumerated(EnumType.STRING)
+    @NotNull(message = "La fonction d'aggrégation est obligatoire")
+    private FonctionAggregation fonctionAggregation;
+
+    @Enumerated(EnumType.STRING)
+    @CriteriaEntitySearch(libelle = "Type de Résultat")
+    private TypeResultatConfiguration typeResultatConfiguration;
+
+    @ManyToOne
+    @JoinColumn(name = "tableaubord_id", referencedColumnName = "id")
+    private TableauBord tableauBord;
+
+    @OneToOne(cascade = CascadeType.ALL)
+    @JoinColumn(name = "criterion_id", referencedColumnName = "id")
+    private CriteriaEntityPersisted criterion;
+
+    private String color = "#527ccc";
+
+    @OneToOne(cascade = CascadeType.ALL, fetch = FetchType.EAGER)
+    @JoinColumn(name = "fonctionAggCriterion_id", referencedColumnName = "id")
+    private FonctionAggregationCriterion fonctionAggregationCriterion;
+
+    @Override
+    public int hashCode() {
+        int hash = 3;
+        hash = 71 * hash + Objects.hashCode(this.libelle);
+        return hash;
+    }
+
+    @Override
+    public boolean equals(Object obj) {
+        if (this == obj) {
+            return true;
+        }
+        if (obj == null) {
+            return false;
+        }
+        if (getClass() != obj.getClass()) {
+            return false;
+        }
+        final TableConfiguration other = (TableConfiguration) obj;
+        return Objects.equals(this.libelle, other.libelle);
+    }
+}

--
Gitblit v1.10.0