From b3d0580439b9a00c7eb918085de1694151066004 Mon Sep 17 00:00:00 2001
From: Kenmegne <stephanie.kenmegne@gmail.com>
Date: Thu, 18 Jun 2026 16:02:49 +0000
Subject: [PATCH] rename packages

---
 fdx_convert/src/main/java/com/megatim/fdxconvert/forms/DataFileToJsonFormController.java |  136 +++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 136 insertions(+), 0 deletions(-)

diff --git a/fdx_convert/src/main/java/com/megatim/fdxconvert/forms/DataFileToJsonFormController.java b/fdx_convert/src/main/java/com/megatim/fdxconvert/forms/DataFileToJsonFormController.java
new file mode 100644
index 0000000..fb24850
--- /dev/null
+++ b/fdx_convert/src/main/java/com/megatim/fdxconvert/forms/DataFileToJsonFormController.java
@@ -0,0 +1,136 @@
+/*
+ * Click nbfs://nbhost/SystemFileSystem/Templates/Licenses/license-default.txt to change this license
+ * Click nbfs://nbhost/SystemFileSystem/Templates/Classes/Class.java to edit this template
+ */
+package com.megatim.fdxconvert.forms;
+
+import com.megatimfx.common.annontations.Champ;
+import com.megatimfx.common.customcontrols.AbstractSelectionItem;
+import com.megatimfx.common.customcontrols.CustomFileChooser;
+import com.megatimfx.components.customdialogs.AlertMessageUtil;
+import com.megatimfx.components.customdialogs.LoadinIndicatorDialogUtil;
+import com.megatim.fdxconvert.App;
+import com.megatim.fdxconvert.controller.table.TypeFichierTable;
+import com.megatim.fdxconvert.enums.DataType;
+import com.megatim.fdxconvert.model.TypeFichier;
+import com.megatim.fdxconvert.pojo.Delimiteur;
+import com.megatim.fdxconvert.service.TypeFichierService;
+import java.net.URL;
+import java.util.Arrays;
+import java.util.HashSet;
+import java.util.ResourceBundle;
+import java.util.Set;
+import javafx.collections.FXCollections;
+import javafx.concurrent.Task;
+import javafx.fxml.FXML;
+import javafx.fxml.Initializable;
+import javafx.scene.control.CheckBox;
+import javafx.scene.control.ComboBox;
+import javafx.util.Pair;
+
+/**
+ *
+ * @author ASUS
+ */
+public class DataFileToJsonFormController implements Initializable {
+
+    @FXML
+    @Champ(mappedBy = "typeFichier", type = TypeFichier.class, update = false)
+    private AbstractSelectionItem<TypeFichier> typeFichierAbstractSelectItem;
+
+    @FXML
+    @Champ(mappedBy = "fileToConvertPath")
+    private CustomFileChooser fileToConvertFileChooser;
+
+    @FXML
+    @Champ(mappedBy = "validateurPath")
+    private CustomFileChooser validateurFileChooser;
+
+    @FXML
+    @Champ(mappedBy = "delimiteurLigne")
+    private ComboBox<Delimiteur> delimiteurLigne;
+
+    @FXML
+    @Champ(mappedBy = "delimiteurColonne")
+    private ComboBox<Delimiteur> delimiteurColonne;
+
+    @FXML
+    @Champ(mappedBy = "dataType")
+    private ComboBox<DataType> dataTypeComboBox;
+
+    @FXML
+    @Champ(mappedBy = "headerPresent", type = Boolean.class)
+    private CheckBox headerPresentCheckbox;
+
+    private final TypeFichierService typeFichierService = TypeFichierService.getInstance();
+
+    private final Set<TypeFichier> typeFichierSet = new HashSet<>();
+
+    @Override
+    public void initialize(URL location, ResourceBundle resources) {
+
+        delimiteurColonne.setPromptText("Sélectionnez un élément dans la liste");
+        delimiteurColonne.setItems(FXCollections.observableArrayList(
+                App.DELIMITEURS_COLONNE.values()
+        ));
+
+        delimiteurLigne.setPromptText("Sélectionnez un élément dans la liste");
+        delimiteurLigne.setItems(FXCollections.observableArrayList(
+                App.DELIMITEURS_LIGNE.values()
+        ));
+
+        delimiteurColonne.disableProperty().bind(dataTypeComboBox.getSelectionModel().selectedItemProperty().isNull()
+                .or(dataTypeComboBox.getSelectionModel().selectedItemProperty().isEqualTo(DataType.XLS))
+                .or(dataTypeComboBox.getSelectionModel().selectedItemProperty().isEqualTo(DataType.XLSX))
+                .or(dataTypeComboBox.getSelectionModel().selectedItemProperty().isEqualTo(DataType.JSON))
+        );
+        delimiteurLigne.disableProperty().bind(dataTypeComboBox.getSelectionModel().selectedItemProperty().isNull()
+                .or(dataTypeComboBox.getSelectionModel().selectedItemProperty().isEqualTo(DataType.XLS))
+                .or(dataTypeComboBox.getSelectionModel().selectedItemProperty().isEqualTo(DataType.XLSX))
+                .or(dataTypeComboBox.getSelectionModel().selectedItemProperty().isEqualTo(DataType.JSON))
+        );
+        headerPresentCheckbox.disableProperty().bind(dataTypeComboBox.getSelectionModel().selectedItemProperty().isEqualTo(DataType.JSON));
+
+        dataTypeComboBox.setPromptText("Sélectionnez un élément dans la liste");
+
+        dataTypeComboBox.setItems(FXCollections.observableArrayList(
+                DataType.values()
+        ));
+        typeFichierAbstractSelectItem.setTitle("Choix du type de fichier");
+        typeFichierAbstractSelectItem.setColumns(Arrays.asList(
+                TypeFichierTable.codeColumn(),
+                TypeFichierTable.libelleColumn()
+        ));
+        typeFichierAbstractSelectItem.setSearchFieldPairs(Arrays.asList(
+                new Pair<>("code", "Code"),
+                new Pair<>("libelle", "Libellé")
+        ));
+
+        initElements();
+    }
+
+    private void initElements() {
+        Task<Void> task = new Task() {
+            @Override
+            protected Object call() throws Exception {
+                typeFichierSet.clear();
+                typeFichierSet.addAll(typeFichierService.getAll());
+                return null;
+            }
+        };
+        task.setOnRunning(e -> LoadinIndicatorDialogUtil.getLoadingIndicatorDialog().show());
+        task.setOnSucceeded(e -> {
+            LoadinIndicatorDialogUtil.getLoadingIndicatorDialog().hide();
+            typeFichierAbstractSelectItem.setElements(typeFichierSet);
+        });
+        task.setOnFailed(e -> {
+            LoadinIndicatorDialogUtil.getLoadingIndicatorDialog().hide();
+            AlertMessageUtil.showAlertException(task.getException(),
+                    "Une exception s'est produite pendant le traitement", "Erreur");
+        });
+        Thread thread = new Thread(task);
+        thread.setDaemon(true);
+        thread.start();
+    }
+
+}

--
Gitblit v1.10.0