From 293b99e344180c3ca506266a8c482b88d66b144c Mon Sep 17 00:00:00 2001 From: Luma Date: Tue, 3 Oct 2023 23:25:46 +0200 Subject: [PATCH 01/11] upgrade to powsybl 2023.3.0 Signed-off-by: Luma --- ...metersBean.java => SldParametersBean.java} | 151 ++++++++++-------- 1 file changed, 81 insertions(+), 70 deletions(-) rename diagram-viewer/src/main/java/com/powsybl/diagram/viewer/sld/{LayoutParametersBean.java => SldParametersBean.java} (64%) diff --git a/diagram-viewer/src/main/java/com/powsybl/diagram/viewer/sld/LayoutParametersBean.java b/diagram-viewer/src/main/java/com/powsybl/diagram/viewer/sld/SldParametersBean.java similarity index 64% rename from diagram-viewer/src/main/java/com/powsybl/diagram/viewer/sld/LayoutParametersBean.java rename to diagram-viewer/src/main/java/com/powsybl/diagram/viewer/sld/SldParametersBean.java index a84527a..08de8f1 100644 --- a/diagram-viewer/src/main/java/com/powsybl/diagram/viewer/sld/LayoutParametersBean.java +++ b/diagram-viewer/src/main/java/com/powsybl/diagram/viewer/sld/SldParametersBean.java @@ -7,8 +7,10 @@ */ package com.powsybl.diagram.viewer.sld; +import com.powsybl.sld.SldParameters; import com.powsybl.sld.layout.*; import com.powsybl.sld.library.ComponentTypeName; +import com.powsybl.sld.svg.SvgParameters; import javafx.beans.property.*; import javafx.beans.value.ChangeListener; @@ -17,7 +19,7 @@ /** * @author Thomas Adam */ -public class LayoutParametersBean { +public class SldParametersBean { private final BooleanProperty useName = new SimpleBooleanProperty(); @@ -78,34 +80,34 @@ public class LayoutParametersBean { private final ObjectPropertyfeederInfosIntraMargin = new SimpleObjectProperty<>(); - public LayoutParametersBean(Property diagramPaddingTopBottom, - Property diagramPaddingLeftRight, - Property voltagePaddingTopBottom, - Property voltagePaddingLeftRight, - Property busbarVerticalSpace, - Property busbarHorizontalSpace, - Property cellWidth, - Property externCellHeight, - Property internCellHeight, - Property stackHeight, - BooleanProperty showGrid, - BooleanProperty showInternalNodes, - BooleanProperty drawStraightWires, - BooleanProperty disconnectorsOnBus, - Property scaleFactor, - BooleanProperty avoidSVGComponentsDuplication, - BooleanProperty adaptCellHeightToContent, - Property minSpaceBetweenComponents, - Property minimumExternCellHeight, - Property busBarAlignment, - BooleanProperty centerLabel, - BooleanProperty labelDiagonal, - Property angleLabel, - BooleanProperty addNodesInfos, - BooleanProperty feederInfoSymmetry, - Property spaceForFeederInfos, - Property feederInfosOuterMargin, - Property feederInfosIntraMargin) { + public SldParametersBean(Property diagramPaddingTopBottom, + Property diagramPaddingLeftRight, + Property voltagePaddingTopBottom, + Property voltagePaddingLeftRight, + Property busbarVerticalSpace, + Property busbarHorizontalSpace, + Property cellWidth, + Property externCellHeight, + Property internCellHeight, + Property stackHeight, + BooleanProperty showGrid, + BooleanProperty showInternalNodes, + BooleanProperty drawStraightWires, + BooleanProperty disconnectorsOnBus, + Property scaleFactor, + BooleanProperty avoidSVGComponentsDuplication, + BooleanProperty adaptCellHeightToContent, + Property minSpaceBetweenComponents, + Property minimumExternCellHeight, + Property busBarAlignment, + BooleanProperty centerLabel, + BooleanProperty labelDiagonal, + Property angleLabel, + BooleanProperty addNodesInfos, + BooleanProperty feederInfoSymmetry, + Property spaceForFeederInfos, + Property feederInfosOuterMargin, + Property feederInfosIntraMargin) { // bind this.diagramPaddingTopBottom.bindBidirectional(diagramPaddingTopBottom); this.diagramPaddingTopBottom.bindBidirectional(diagramPaddingTopBottom); @@ -138,37 +140,43 @@ public LayoutParametersBean(Property diagramPaddingTopBottom, this.feederInfosIntraMargin.bindBidirectional(feederInfosIntraMargin); // Initialize - LayoutParameters defaultParameters = new LayoutParameters() - .setShowGrid(true) + SldParameters sldParameters = new SldParameters(); + LayoutParameters defaultLayoutParameters = sldParameters.getLayoutParameters(); + SvgParameters defaultSvgParameters = sldParameters.getSvgParameters(); + defaultSvgParameters + .setShowGrid(true); + defaultLayoutParameters .setAdaptCellHeightToContent(true); - diagramPaddingTopBottom.setValue(defaultParameters.getDiagramPadding().getTop()); - diagramPaddingLeftRight.setValue(defaultParameters.getDiagramPadding().getLeft()); - voltagePaddingTopBottom.setValue(defaultParameters.getVoltageLevelPadding().getTop()); - voltagePaddingLeftRight.setValue(defaultParameters.getVoltageLevelPadding().getLeft()); - busbarVerticalSpace.setValue(defaultParameters.getVerticalSpaceBus()); - busbarHorizontalSpace.setValue(defaultParameters.getHorizontalBusPadding()); - cellWidth.setValue(defaultParameters.getCellWidth()); - externCellHeight.setValue(defaultParameters.getExternCellHeight()); - internCellHeight.setValue(defaultParameters.getInternCellHeight()); - stackHeight.setValue(defaultParameters.getStackHeight()); - showGrid.setValue(defaultParameters.isShowGrid()); - showInternalNodes.setValue(defaultParameters.isShowInternalNodes()); - drawStraightWires.setValue(defaultParameters.isDrawStraightWires()); - disconnectorsOnBus.setValue(defaultParameters.getComponentsOnBusbars().equals(List.of(ComponentTypeName.DISCONNECTOR))); - scaleFactor.setValue(defaultParameters.getScaleFactor()); - avoidSVGComponentsDuplication.setValue(defaultParameters.isAvoidSVGComponentsDuplication()); - adaptCellHeightToContent.setValue(defaultParameters.isAdaptCellHeightToContent()); - minSpaceBetweenComponents.setValue(defaultParameters.getMinSpaceBetweenComponents()); - minimumExternCellHeight.setValue(defaultParameters.getMinExternCellHeight()); - busBarAlignment.setValue(defaultParameters.getBusbarsAlignment()); - centerLabel.setValue(defaultParameters.isLabelCentered()); - labelDiagonal.setValue(defaultParameters.isLabelDiagonal()); - angleLabel.setValue(defaultParameters.getAngleLabelShift()); - addNodesInfos.setValue(defaultParameters.isAddNodesInfos()); - feederInfoSymmetry.setValue(defaultParameters.isFeederInfoSymmetry()); - spaceForFeederInfos.setValue(defaultParameters.getSpaceForFeederInfos()); - feederInfosOuterMargin.setValue(defaultParameters.getFeederInfosOuterMargin()); - feederInfosIntraMargin.setValue(defaultParameters.getFeederInfosIntraMargin()); + diagramPaddingTopBottom.setValue(defaultLayoutParameters.getDiagramPadding().getTop()); + diagramPaddingLeftRight.setValue(defaultLayoutParameters.getDiagramPadding().getLeft()); + voltagePaddingTopBottom.setValue(defaultLayoutParameters.getVoltageLevelPadding().getTop()); + voltagePaddingLeftRight.setValue(defaultLayoutParameters.getVoltageLevelPadding().getLeft()); + busbarVerticalSpace.setValue(defaultLayoutParameters.getVerticalSpaceBus()); + busbarHorizontalSpace.setValue(defaultLayoutParameters.getHorizontalBusPadding()); + cellWidth.setValue(defaultLayoutParameters.getCellWidth()); + externCellHeight.setValue(defaultLayoutParameters.getExternCellHeight()); + internCellHeight.setValue(defaultLayoutParameters.getInternCellHeight()); + stackHeight.setValue(defaultLayoutParameters.getStackHeight()); + disconnectorsOnBus.setValue(defaultLayoutParameters.getComponentsOnBusbars().equals(List.of(ComponentTypeName.DISCONNECTOR))); + adaptCellHeightToContent.setValue(defaultLayoutParameters.isAdaptCellHeightToContent()); + minSpaceBetweenComponents.setValue(defaultLayoutParameters.getMinSpaceBetweenComponents()); + minimumExternCellHeight.setValue(defaultLayoutParameters.getMinExternCellHeight()); + busBarAlignment.setValue(defaultLayoutParameters.getBusbarsAlignment()); + + spaceForFeederInfos.setValue(defaultLayoutParameters.getSpaceForFeederInfos()); + scaleFactor.setValue(defaultLayoutParameters.getCgmesScaleFactor()); + + showGrid.setValue(defaultSvgParameters.isShowGrid()); + showInternalNodes.setValue(defaultSvgParameters.isShowInternalNodes()); + drawStraightWires.setValue(defaultSvgParameters.isDrawStraightWires()); + avoidSVGComponentsDuplication.setValue(defaultSvgParameters.isAvoidSVGComponentsDuplication()); + centerLabel.setValue(defaultSvgParameters.isLabelCentered()); + labelDiagonal.setValue(defaultSvgParameters.isLabelDiagonal()); + angleLabel.setValue(defaultSvgParameters.getAngleLabelShift()); + addNodesInfos.setValue(defaultSvgParameters.isAddNodesInfos()); + feederInfoSymmetry.setValue(defaultSvgParameters.isFeederInfoSymmetry()); + feederInfosOuterMargin.setValue(defaultSvgParameters.getFeederInfosOuterMargin()); + feederInfosIntraMargin.setValue(defaultSvgParameters.getFeederInfosIntraMargin()); } public void bind(BooleanProperty useName) { @@ -208,8 +216,9 @@ public void addListener(ChangeListener changeListener) { this.feederInfosIntraMargin.addListener(changeListener); } - public LayoutParameters getLayoutParameters(String diagramName) { - return new LayoutParameters() + public SldParameters getParameters(String diagramName) { + SldParameters sldParameters = new SldParameters(); + sldParameters.getLayoutParameters() .setDiagrammPadding(diagramPaddingLeftRight.get(), diagramPaddingTopBottom.get(), diagramPaddingLeftRight.get(), @@ -218,34 +227,36 @@ public LayoutParameters getLayoutParameters(String diagramName) { voltagePaddingTopBottom.get(), voltagePaddingLeftRight.get(), voltagePaddingTopBottom.get()) - .setUseName(useName.get()) - .setDiagramName(diagramName) + .setCgmesUseNames(useName.get()) + .setCgmesDiagramName(diagramName) .setVerticalSpaceBus(busbarVerticalSpace.get()) .setHorizontalBusPadding(busbarHorizontalSpace.get()) .setCellWidth(cellWidth.get()) .setExternCellHeight(externCellHeight.get()) .setInternCellHeight(internCellHeight.get()) .setStackHeight(stackHeight.get()) - .setShowGrid(showGrid.get()) - .setShowInternalNodes(showInternalNodes.get()) - .setDrawStraightWires(drawStraightWires.get()) .setComponentsOnBusbars(disconnectorsOnBus.get() ? List.of(ComponentTypeName.DISCONNECTOR) : Collections.emptyList()) - .setScaleFactor(scaleFactor.get()) - .setAvoidSVGComponentsDuplication(avoidSVGComponentsDuplication.get()) + .setCgmesScaleFactor(scaleFactor.get()) .setAdaptCellHeightToContent(adaptCellHeightToContent.get()) .setMinSpaceBetweenComponents(minSpaceBetweenComponents.get()) .setMinExternCellHeight(minimumExternCellHeight.get()) .setBusbarsAlignment(busBarAlignment.get()) + .setSpaceForFeederInfos(spaceForFeederInfos.get()); + sldParameters.getSvgParameters() + .setShowGrid(showGrid.get()) + .setShowInternalNodes(showInternalNodes.get()) + .setDrawStraightWires(drawStraightWires.get()) + .setAvoidSVGComponentsDuplication(avoidSVGComponentsDuplication.get()) .setLabelCentered(centerLabel.get()) .setLabelDiagonal(labelDiagonal.get()) .setAngleLabelShift(angleLabel.get()) .setAddNodesInfos(addNodesInfos.get()) .setFeederInfoSymmetry(feederInfoSymmetry.get()) - .setSpaceForFeederInfos(spaceForFeederInfos.get()) .setFeederInfosOuterMargin(feederInfosOuterMargin.get()) .setFeederInfosIntraMargin(feederInfosIntraMargin.get()) // Forced values - .setCssLocation(LayoutParameters.CssLocation.INSERTED_IN_SVG) + .setCssLocation(SvgParameters.CssLocation.INSERTED_IN_SVG) .setSvgWidthAndHeightAdded(true); + return sldParameters; } } From 8e5be1392e21f731562b507041c778051e6cf918 Mon Sep 17 00:00:00 2001 From: Luma Date: Tue, 3 Oct 2023 23:28:52 +0200 Subject: [PATCH 02/11] upgrade to powsybl 2023.3.0 Signed-off-by: Luma --- diagram-viewer/pom.xml | 2 +- .../com/powsybl/diagram/viewer/Model.java | 2 +- .../nad/NetworkAreaDiagramController.java | 23 ++++++++++--------- .../viewer/nad/NetworkAreaDiagramModel.java | 8 +++---- .../sld/SingleLineDiagramController.java | 19 ++++----------- .../viewer/sld/SingleLineDiagramModel.java | 15 ++++++------ 6 files changed, 30 insertions(+), 39 deletions(-) diff --git a/diagram-viewer/pom.xml b/diagram-viewer/pom.xml index 2be067f..4cd9671 100644 --- a/diagram-viewer/pom.xml +++ b/diagram-viewer/pom.xml @@ -43,7 +43,7 @@ 4.13.1 17 17 - 2023.2.0 + 2023.3.0 diff --git a/diagram-viewer/src/main/java/com/powsybl/diagram/viewer/Model.java b/diagram-viewer/src/main/java/com/powsybl/diagram/viewer/Model.java index 6297369..7eb243f 100644 --- a/diagram-viewer/src/main/java/com/powsybl/diagram/viewer/Model.java +++ b/diagram-viewer/src/main/java/com/powsybl/diagram/viewer/Model.java @@ -28,7 +28,7 @@ public Model(BooleanProperty showNames, NetworkAreaDiagramModel nadModel, Single this.nadModel = nadModel; this.sldModel = sldModel; this.nadModel.getSvgParametersBean().bind(showNames); - this.sldModel.getLayoutParametersBean().bind(showNames); + this.sldModel.getSldParametersBean().bind(showNames); } public void setNetwork(Network network) { diff --git a/diagram-viewer/src/main/java/com/powsybl/diagram/viewer/nad/NetworkAreaDiagramController.java b/diagram-viewer/src/main/java/com/powsybl/diagram/viewer/nad/NetworkAreaDiagramController.java index 1792f54..78f5481 100644 --- a/diagram-viewer/src/main/java/com/powsybl/diagram/viewer/nad/NetworkAreaDiagramController.java +++ b/diagram-viewer/src/main/java/com/powsybl/diagram/viewer/nad/NetworkAreaDiagramController.java @@ -14,7 +14,9 @@ import com.powsybl.iidm.network.Network; import com.powsybl.iidm.network.Substation; import com.powsybl.iidm.network.VoltageLevel; +import com.powsybl.nad.NadParameters; import com.powsybl.nad.NetworkAreaDiagram; +import com.powsybl.nad.build.iidm.VoltageLevelFilter; import javafx.concurrent.Service; import javafx.concurrent.Task; import javafx.fxml.FXML; @@ -24,6 +26,7 @@ import java.io.IOException; import java.io.StringWriter; import java.util.List; +import java.util.function.Predicate; import java.util.stream.Collectors; /** @@ -54,13 +57,11 @@ protected Task createTask() { return new Task<>() { @Override protected String call() { - NetworkAreaDiagram nad = getNetworkAreaDiagram(network, model, container); - nad.draw(writer, - model.getSvgParameters(), - model.getLayoutParameters(), - model.getStyleProvider(network), - model.getLabelProvider(network), - model.getLayoutFactory()); + Predicate vls = getVoltageLevelFilter(network, model, container); + NadParameters nadParameters = new NadParameters(); + nadParameters.setLayoutParameters(model.getLayoutParameters()); + nadParameters.setSvgParameters(model.getSvgParameters()); + NetworkAreaDiagram.draw(network, writer, nadParameters, vls); return writer.toString(); } }; @@ -75,15 +76,15 @@ protected String call() { nadService.start(); } - private static NetworkAreaDiagram getNetworkAreaDiagram(Network network, NetworkAreaDiagramModel model, Container container) { + private static Predicate getVoltageLevelFilter(Network network, NetworkAreaDiagramModel model, Container container) { switch (container.getContainerType()) { case NETWORK: - return new NetworkAreaDiagram((Network) container); + return VoltageLevelFilter.NO_FILTER; case SUBSTATION: List vls = ((Substation) container).getVoltageLevelStream().map(VoltageLevel::getId).collect(Collectors.toList()); - return new NetworkAreaDiagram(network, vls, model.getDepth()); + return VoltageLevelFilter.createVoltageLevelsDepthFilter(network, vls, model.getDepth()); case VOLTAGE_LEVEL: - return new NetworkAreaDiagram(network, container.getId(), model.getDepth()); + return VoltageLevelFilter.createVoltageLevelDepthFilter(network, container.getId(), model.getDepth()); default: throw new AssertionError(); } diff --git a/diagram-viewer/src/main/java/com/powsybl/diagram/viewer/nad/NetworkAreaDiagramModel.java b/diagram-viewer/src/main/java/com/powsybl/diagram/viewer/nad/NetworkAreaDiagramModel.java index 2046e79..152294f 100644 --- a/diagram-viewer/src/main/java/com/powsybl/diagram/viewer/nad/NetworkAreaDiagramModel.java +++ b/diagram-viewer/src/main/java/com/powsybl/diagram/viewer/nad/NetworkAreaDiagramModel.java @@ -30,7 +30,7 @@ public class NetworkAreaDiagramModel extends DiagramModel { private static final String TOPOLOGICAL_STYLE_PROVIDER = "Topological"; // Layout Parameters - private final LayoutParametersBean layoutParameters; + private final LayoutParametersBean layoutParametersBean; // SVG Parameters private final SvgParametersBean svgParameters; @@ -67,7 +67,7 @@ public NetworkAreaDiagramModel(ReadOnlyObjectProperty depth, this.layoutFactory.bind(layout); // Layout parameters - layoutParameters = new LayoutParametersBean(textNodesIncluded, springRepulsionFactor); + layoutParametersBean = new LayoutParametersBean(textNodesIncluded, springRepulsionFactor); // SVG parameters svgParameters = new SvgParametersBean(infoAlongEdge, @@ -91,7 +91,7 @@ public SvgParameters getSvgParameters() { } public LayoutParameters getLayoutParameters() { - return layoutParameters.getLayoutParameters(); + return layoutParametersBean.getLayoutParameters(); } public LabelProvider getLabelProvider(Network network) { @@ -114,6 +114,6 @@ public SvgParametersBean getSvgParametersBean() { public void addListener(ChangeListener changeListener) { svgParameters.addListener(changeListener); - layoutParameters.addListener(changeListener); + layoutParametersBean.addListener(changeListener); } } diff --git a/diagram-viewer/src/main/java/com/powsybl/diagram/viewer/sld/SingleLineDiagramController.java b/diagram-viewer/src/main/java/com/powsybl/diagram/viewer/sld/SingleLineDiagramController.java index 982421b..8069f6b 100644 --- a/diagram-viewer/src/main/java/com/powsybl/diagram/viewer/sld/SingleLineDiagramController.java +++ b/diagram-viewer/src/main/java/com/powsybl/diagram/viewer/sld/SingleLineDiagramController.java @@ -11,9 +11,7 @@ import com.powsybl.diagram.viewer.common.ContainerResult; import com.powsybl.iidm.network.*; import com.powsybl.sld.SingleLineDiagram; -import com.powsybl.sld.layout.LayoutParameters; -import com.powsybl.sld.svg.DefaultDiagramLabelProvider; -import com.powsybl.sld.svg.DiagramLabelProvider; +import com.powsybl.sld.SldParameters; import com.powsybl.sld.svg.styles.StyleProvider; import javafx.beans.property.StringProperty; import javafx.concurrent.Service; @@ -86,22 +84,13 @@ protected ContainerResult call() { StringWriter metadataWriter = new StringWriter(); StringWriter jsonWriter = new StringWriter()) { - LayoutParameters diagramLayoutParameters = model.getLayoutParameters(); - - DiagramLabelProvider initProvider = new DefaultDiagramLabelProvider(network, - model.getComponentLibrary(), - diagramLayoutParameters); + SldParameters sldParameters = model.getSldParameters(); + sldParameters.setComponentLibrary(model.getComponentLibrary()); SingleLineDiagram.draw(network, container.getId(), svgWriter, metadataWriter, - diagramLayoutParameters, - model.getComponentLibrary(), - model.getSubstationLayoutFactory(), - model.getVoltageLevelLayoutFactory(), - initProvider, - model.getStyleProvider(network), - ""); + sldParameters); svgWriter.flush(); metadataWriter.flush(); diff --git a/diagram-viewer/src/main/java/com/powsybl/diagram/viewer/sld/SingleLineDiagramModel.java b/diagram-viewer/src/main/java/com/powsybl/diagram/viewer/sld/SingleLineDiagramModel.java index f4ffdbb..2c28011 100644 --- a/diagram-viewer/src/main/java/com/powsybl/diagram/viewer/sld/SingleLineDiagramModel.java +++ b/diagram-viewer/src/main/java/com/powsybl/diagram/viewer/sld/SingleLineDiagramModel.java @@ -9,6 +9,7 @@ import com.powsybl.diagram.viewer.common.DiagramModel; import com.powsybl.iidm.network.Network; +import com.powsybl.sld.SldParameters; import com.powsybl.sld.cgmes.dl.iidm.extensions.NetworkDiagramData; import com.powsybl.sld.cgmes.layout.CgmesSubstationLayoutFactory; import com.powsybl.sld.cgmes.layout.CgmesVoltageLevelLayoutFactory; @@ -44,7 +45,7 @@ public class SingleLineDiagramModel extends DiagramModel { private static final String CGMES_VOLTAGELEVEL_LAYOUT = "CGMES"; // Layout Parameters - private final LayoutParametersBean layoutParameters; + private final SldParametersBean sldParametersBean; // Component library provider private final ObservableList componentLibraries = FXCollections.observableArrayList(); @@ -151,7 +152,7 @@ public SingleLineDiagramModel(// Providers this.topologicalStyleProvider.bindBidirectional(topologicalStyleProvider); // Layout Parameters - this.layoutParameters = new LayoutParametersBean(diagramPaddingTopBottom, + this.sldParametersBean = new SldParametersBean(diagramPaddingTopBottom, diagramPaddingLeftRight, voltagePaddingTopBottom, voltagePaddingLeftRight, @@ -216,7 +217,7 @@ public void updateFrom(Network network) { } public void addListener(ChangeListener changeListener) { - layoutParameters.addListener(changeListener); + sldParametersBean.addListener(changeListener); voltageLevelLayoutFactory.addListener(changeListener); } @@ -255,12 +256,12 @@ public SubstationLayoutFactory getSubstationLayoutFactory() { return currentSubstationLayoutFactory.get(); } - public LayoutParameters getLayoutParameters() { - return layoutParameters.getLayoutParameters(currentCgmesDLDiagramName.get()); + public SldParameters getSldParameters() { + return sldParametersBean.getParameters(currentCgmesDLDiagramName.get()); } - public LayoutParametersBean getLayoutParametersBean() { - return layoutParameters; + public SldParametersBean getSldParametersBean() { + return sldParametersBean; } public ObservableList getComponentLibraries() { From 9ea7af8080c496a7c2b1412eb049e06a69a05703 Mon Sep 17 00:00:00 2001 From: Luma Date: Tue, 3 Oct 2023 23:40:08 +0200 Subject: [PATCH 03/11] Update maven.yml to use java 17 Signed-off-by: Luma --- .github/workflows/maven.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/maven.yml b/.github/workflows/maven.yml index 2c46c84..99f5e5f 100644 --- a/.github/workflows/maven.yml +++ b/.github/workflows/maven.yml @@ -16,11 +16,11 @@ jobs: - name: Checkout sources uses: actions/checkout@v2.3.4 - - name: Set up JDK 11 + - name: Set up JDK 17 uses: actions/setup-java@v2 with: distribution: 'zulu' - java-version: 11 + java-version: 17 - name: Build diagram viewer with Maven run: mvn --file diagram-viewer --batch-mode -P jacoco,checks package From 8d0853dcf48f5653d221c97402fcfa44b5af324c Mon Sep 17 00:00:00 2001 From: Luma Date: Tue, 3 Oct 2023 23:40:57 +0200 Subject: [PATCH 04/11] upgrade to java 17 and powsybl parent 15 Signed-off-by: Luma --- diagram-viewer/pom.xml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/diagram-viewer/pom.xml b/diagram-viewer/pom.xml index 4cd9671..b6889fe 100644 --- a/diagram-viewer/pom.xml +++ b/diagram-viewer/pom.xml @@ -15,7 +15,7 @@ com.powsybl powsybl-parent - 4 + 15 @@ -35,7 +35,7 @@ UTF-8 - 11 + 17 19.0.2.1 0.0.8 2.0.7 From f24096738e1d3ef64c74751b39cdf1ec334dac08 Mon Sep 17 00:00:00 2001 From: Sophie Frasnedo Date: Thu, 5 Oct 2023 11:53:27 +0200 Subject: [PATCH 05/11] Split up SvgParameters and LayoutParameters for single-line-diagram related code Signed-off-by: Sophie Frasnedo --- .../com/powsybl/diagram/viewer/Model.java | 2 +- ...ersBean.java => LayoutParametersBean.java} | 129 +----------------- .../viewer/sld/SingleLineDiagramModel.java | 57 ++++---- .../sld/SingleLineDiagramViewController.java | 12 +- .../diagram/viewer/sld/SvgParametersBean.java | 113 +++++++++++++++ .../src/main/resources/sld/view.fxml | 26 ++-- 6 files changed, 173 insertions(+), 166 deletions(-) rename diagram-viewer/src/main/java/com/powsybl/diagram/viewer/sld/{SldParametersBean.java => LayoutParametersBean.java} (60%) create mode 100644 diagram-viewer/src/main/java/com/powsybl/diagram/viewer/sld/SvgParametersBean.java diff --git a/diagram-viewer/src/main/java/com/powsybl/diagram/viewer/Model.java b/diagram-viewer/src/main/java/com/powsybl/diagram/viewer/Model.java index 7eb243f..642d5e9 100644 --- a/diagram-viewer/src/main/java/com/powsybl/diagram/viewer/Model.java +++ b/diagram-viewer/src/main/java/com/powsybl/diagram/viewer/Model.java @@ -28,7 +28,7 @@ public Model(BooleanProperty showNames, NetworkAreaDiagramModel nadModel, Single this.nadModel = nadModel; this.sldModel = sldModel; this.nadModel.getSvgParametersBean().bind(showNames); - this.sldModel.getSldParametersBean().bind(showNames); + this.sldModel.getSvgParametersBean().bind(showNames); } public void setNetwork(Network network) { diff --git a/diagram-viewer/src/main/java/com/powsybl/diagram/viewer/sld/SldParametersBean.java b/diagram-viewer/src/main/java/com/powsybl/diagram/viewer/sld/LayoutParametersBean.java similarity index 60% rename from diagram-viewer/src/main/java/com/powsybl/diagram/viewer/sld/SldParametersBean.java rename to diagram-viewer/src/main/java/com/powsybl/diagram/viewer/sld/LayoutParametersBean.java index 08de8f1..e942909 100644 --- a/diagram-viewer/src/main/java/com/powsybl/diagram/viewer/sld/SldParametersBean.java +++ b/diagram-viewer/src/main/java/com/powsybl/diagram/viewer/sld/LayoutParametersBean.java @@ -19,68 +19,27 @@ /** * @author Thomas Adam */ -public class SldParametersBean { +public class LayoutParametersBean { - private final BooleanProperty useName = new SimpleBooleanProperty(); - - // Layout Parameters private final ObjectProperty diagramPaddingTopBottom = new SimpleObjectProperty<>(); - private final ObjectProperty diagramPaddingLeftRight = new SimpleObjectProperty<>(); - private final ObjectProperty voltagePaddingTopBottom = new SimpleObjectProperty<>(); - private final ObjectProperty voltagePaddingLeftRight = new SimpleObjectProperty<>(); - private final ObjectProperty busbarVerticalSpace = new SimpleObjectProperty<>(); - private final ObjectProperty busbarHorizontalSpace = new SimpleObjectProperty<>(); - private final ObjectProperty cellWidth = new SimpleObjectProperty<>(); - private final ObjectProperty externCellHeight = new SimpleObjectProperty<>(); - private final ObjectProperty internCellHeight = new SimpleObjectProperty<>(); - private final ObjectProperty stackHeight = new SimpleObjectProperty<>(); - - private final BooleanProperty showGrid = new SimpleBooleanProperty(); - - private final BooleanProperty showInternalNodes = new SimpleBooleanProperty(); - - private final BooleanProperty drawStraightWires = new SimpleBooleanProperty(); - private final BooleanProperty disconnectorsOnBus = new SimpleBooleanProperty(); - private final ObjectProperty scaleFactor = new SimpleObjectProperty<>(); - - private final BooleanProperty avoidSVGComponentsDuplication = new SimpleBooleanProperty(); - private final BooleanProperty adaptCellHeightToContent = new SimpleBooleanProperty(); - private final ObjectPropertyminSpaceBetweenComponents = new SimpleObjectProperty<>(); - private final ObjectPropertyminimumExternCellHeight = new SimpleObjectProperty<>(); - private final ObjectProperty busBarAlignment = new SimpleObjectProperty<>(); - - private final BooleanProperty centerLabel = new SimpleBooleanProperty(); - - private final BooleanProperty labelDiagonal = new SimpleBooleanProperty(); - - private final ObjectPropertyangleLabel = new SimpleObjectProperty<>(); - - private final BooleanProperty addNodesInfos = new SimpleBooleanProperty(); - - private final BooleanProperty feederInfoSymmetry = new SimpleBooleanProperty(); - private final ObjectPropertyspaceForFeederInfos = new SimpleObjectProperty<>(); - private final ObjectPropertyfeederInfosOuterMargin = new SimpleObjectProperty<>(); - - private final ObjectPropertyfeederInfosIntraMargin = new SimpleObjectProperty<>(); - - public SldParametersBean(Property diagramPaddingTopBottom, + public LayoutParametersBean(Property diagramPaddingTopBottom, Property diagramPaddingLeftRight, Property voltagePaddingTopBottom, Property voltagePaddingLeftRight, @@ -90,24 +49,13 @@ public SldParametersBean(Property diagramPaddingTopBottom, Property externCellHeight, Property internCellHeight, Property stackHeight, - BooleanProperty showGrid, - BooleanProperty showInternalNodes, - BooleanProperty drawStraightWires, BooleanProperty disconnectorsOnBus, Property scaleFactor, - BooleanProperty avoidSVGComponentsDuplication, BooleanProperty adaptCellHeightToContent, Property minSpaceBetweenComponents, Property minimumExternCellHeight, Property busBarAlignment, - BooleanProperty centerLabel, - BooleanProperty labelDiagonal, - Property angleLabel, - BooleanProperty addNodesInfos, - BooleanProperty feederInfoSymmetry, - Property spaceForFeederInfos, - Property feederInfosOuterMargin, - Property feederInfosIntraMargin) { + Property spaceForFeederInfos) { // bind this.diagramPaddingTopBottom.bindBidirectional(diagramPaddingTopBottom); this.diagramPaddingTopBottom.bindBidirectional(diagramPaddingTopBottom); @@ -120,33 +68,18 @@ public SldParametersBean(Property diagramPaddingTopBottom, this.externCellHeight.bindBidirectional(externCellHeight); this.internCellHeight.bindBidirectional(internCellHeight); this.stackHeight.bindBidirectional(stackHeight); - this.showGrid.bindBidirectional(showGrid); - this.showInternalNodes.bindBidirectional(showInternalNodes); - this.drawStraightWires.bindBidirectional(drawStraightWires); this.disconnectorsOnBus.bindBidirectional(disconnectorsOnBus); this.scaleFactor.bindBidirectional(scaleFactor); - this.avoidSVGComponentsDuplication.bindBidirectional(avoidSVGComponentsDuplication); this.adaptCellHeightToContent.bindBidirectional(adaptCellHeightToContent); this.minSpaceBetweenComponents.bindBidirectional(minSpaceBetweenComponents); this.minimumExternCellHeight.bindBidirectional(minimumExternCellHeight); this.busBarAlignment.bindBidirectional(busBarAlignment); - this.centerLabel.bindBidirectional(centerLabel); - this.labelDiagonal.bindBidirectional(labelDiagonal); - this.angleLabel.bindBidirectional(angleLabel); - this.addNodesInfos.bindBidirectional(addNodesInfos); - this.feederInfoSymmetry.bindBidirectional(feederInfoSymmetry); this.spaceForFeederInfos.bindBidirectional(spaceForFeederInfos); - this.feederInfosOuterMargin.bindBidirectional(feederInfosOuterMargin); - this.feederInfosIntraMargin.bindBidirectional(feederInfosIntraMargin); // Initialize - SldParameters sldParameters = new SldParameters(); - LayoutParameters defaultLayoutParameters = sldParameters.getLayoutParameters(); - SvgParameters defaultSvgParameters = sldParameters.getSvgParameters(); - defaultSvgParameters - .setShowGrid(true); - defaultLayoutParameters + LayoutParameters defaultLayoutParameters = new LayoutParameters() .setAdaptCellHeightToContent(true); + diagramPaddingTopBottom.setValue(defaultLayoutParameters.getDiagramPadding().getTop()); diagramPaddingLeftRight.setValue(defaultLayoutParameters.getDiagramPadding().getLeft()); voltagePaddingTopBottom.setValue(defaultLayoutParameters.getVoltageLevelPadding().getTop()); @@ -162,29 +95,11 @@ public SldParametersBean(Property diagramPaddingTopBottom, minSpaceBetweenComponents.setValue(defaultLayoutParameters.getMinSpaceBetweenComponents()); minimumExternCellHeight.setValue(defaultLayoutParameters.getMinExternCellHeight()); busBarAlignment.setValue(defaultLayoutParameters.getBusbarsAlignment()); - spaceForFeederInfos.setValue(defaultLayoutParameters.getSpaceForFeederInfos()); scaleFactor.setValue(defaultLayoutParameters.getCgmesScaleFactor()); - - showGrid.setValue(defaultSvgParameters.isShowGrid()); - showInternalNodes.setValue(defaultSvgParameters.isShowInternalNodes()); - drawStraightWires.setValue(defaultSvgParameters.isDrawStraightWires()); - avoidSVGComponentsDuplication.setValue(defaultSvgParameters.isAvoidSVGComponentsDuplication()); - centerLabel.setValue(defaultSvgParameters.isLabelCentered()); - labelDiagonal.setValue(defaultSvgParameters.isLabelDiagonal()); - angleLabel.setValue(defaultSvgParameters.getAngleLabelShift()); - addNodesInfos.setValue(defaultSvgParameters.isAddNodesInfos()); - feederInfoSymmetry.setValue(defaultSvgParameters.isFeederInfoSymmetry()); - feederInfosOuterMargin.setValue(defaultSvgParameters.getFeederInfosOuterMargin()); - feederInfosIntraMargin.setValue(defaultSvgParameters.getFeederInfosIntraMargin()); - } - - public void bind(BooleanProperty useName) { - this.useName.bind(useName); } public void addListener(ChangeListener changeListener) { - this.useName.addListener(changeListener); this.diagramPaddingTopBottom.addListener(changeListener); this.diagramPaddingTopBottom.addListener(changeListener); this.diagramPaddingLeftRight.addListener(changeListener); @@ -196,29 +111,17 @@ public void addListener(ChangeListener changeListener) { this.externCellHeight.addListener(changeListener); this.internCellHeight.addListener(changeListener); this.stackHeight.addListener(changeListener); - this.showGrid.addListener(changeListener); - this.showInternalNodes.addListener(changeListener); - this.drawStraightWires.addListener(changeListener); this.disconnectorsOnBus.addListener(changeListener); this.scaleFactor.addListener(changeListener); - this.avoidSVGComponentsDuplication.addListener(changeListener); this.adaptCellHeightToContent.addListener(changeListener); this.minSpaceBetweenComponents.addListener(changeListener); this.minimumExternCellHeight.addListener(changeListener); this.busBarAlignment.addListener(changeListener); - this.centerLabel.addListener(changeListener); - this.labelDiagonal.addListener(changeListener); - this.angleLabel.addListener(changeListener); - this.addNodesInfos.addListener(changeListener); - this.feederInfoSymmetry.addListener(changeListener); this.spaceForFeederInfos.addListener(changeListener); - this.feederInfosOuterMargin.addListener(changeListener); - this.feederInfosIntraMargin.addListener(changeListener); } - public SldParameters getParameters(String diagramName) { - SldParameters sldParameters = new SldParameters(); - sldParameters.getLayoutParameters() + public LayoutParameters getLayoutParameters() { + return new LayoutParameters() .setDiagrammPadding(diagramPaddingLeftRight.get(), diagramPaddingTopBottom.get(), diagramPaddingLeftRight.get(), @@ -227,8 +130,6 @@ public SldParameters getParameters(String diagramName) { voltagePaddingTopBottom.get(), voltagePaddingLeftRight.get(), voltagePaddingTopBottom.get()) - .setCgmesUseNames(useName.get()) - .setCgmesDiagramName(diagramName) .setVerticalSpaceBus(busbarVerticalSpace.get()) .setHorizontalBusPadding(busbarHorizontalSpace.get()) .setCellWidth(cellWidth.get()) @@ -242,21 +143,5 @@ public SldParameters getParameters(String diagramName) { .setMinExternCellHeight(minimumExternCellHeight.get()) .setBusbarsAlignment(busBarAlignment.get()) .setSpaceForFeederInfos(spaceForFeederInfos.get()); - sldParameters.getSvgParameters() - .setShowGrid(showGrid.get()) - .setShowInternalNodes(showInternalNodes.get()) - .setDrawStraightWires(drawStraightWires.get()) - .setAvoidSVGComponentsDuplication(avoidSVGComponentsDuplication.get()) - .setLabelCentered(centerLabel.get()) - .setLabelDiagonal(labelDiagonal.get()) - .setAngleLabelShift(angleLabel.get()) - .setAddNodesInfos(addNodesInfos.get()) - .setFeederInfoSymmetry(feederInfoSymmetry.get()) - .setFeederInfosOuterMargin(feederInfosOuterMargin.get()) - .setFeederInfosIntraMargin(feederInfosIntraMargin.get()) - // Forced values - .setCssLocation(SvgParameters.CssLocation.INSERTED_IN_SVG) - .setSvgWidthAndHeightAdded(true); - return sldParameters; } } diff --git a/diagram-viewer/src/main/java/com/powsybl/diagram/viewer/sld/SingleLineDiagramModel.java b/diagram-viewer/src/main/java/com/powsybl/diagram/viewer/sld/SingleLineDiagramModel.java index 2c28011..938eeda 100644 --- a/diagram-viewer/src/main/java/com/powsybl/diagram/viewer/sld/SingleLineDiagramModel.java +++ b/diagram-viewer/src/main/java/com/powsybl/diagram/viewer/sld/SingleLineDiagramModel.java @@ -35,21 +35,14 @@ public class SingleLineDiagramModel extends DiagramModel { private static final String UNKNOWN_ITEM = "???"; - private static final String HORIZONTAL_SUBSTATION_LAYOUT = "Horizontal"; - private static final String VERTICAL_SUBSTATION_LAYOUT = "Vertical"; - private static final String CGMES_SUBSTATION_LAYOUT = "CGMES"; - private static final String SMART_VOLTAGELEVEL_LAYOUT = "Smart"; - private static final String AUTO_EXTENSIONS_VOLTAGELEVEL_LAYOUT = "Auto extensions"; - private static final String AUTO_WITHOUT_EXTENSIONS_CLUSTERING_VOLTAGELEVEL_LAYOUT = "Auto without extensions Clustering"; - private static final String RANDOM_VOLTAGELEVEL_LAYOUT = "Random"; - private static final String CGMES_VOLTAGELEVEL_LAYOUT = "CGMES"; + // LayoutParameters + private final LayoutParametersBean layoutParametersBean; - // Layout Parameters - private final SldParametersBean sldParametersBean; + // SvgParameters + private final SvgParametersBean svgParametersBean; // Component library provider private final ObservableList componentLibraries = FXCollections.observableArrayList(); - private final ObjectProperty currentComponentLibrary = new SimpleObjectProperty<>(); // Style provider @@ -61,23 +54,28 @@ public class SingleLineDiagramModel extends DiagramModel { private final BooleanProperty highlightStyleProvider = new SimpleBooleanProperty(); private final BooleanProperty topologicalStyleProvider = new SimpleBooleanProperty(); + private static final String SMART_VOLTAGELEVEL_LAYOUT = "Smart"; + private static final String AUTO_EXTENSIONS_VOLTAGELEVEL_LAYOUT = "Auto extensions"; + private static final String AUTO_WITHOUT_EXTENSIONS_CLUSTERING_VOLTAGELEVEL_LAYOUT = "Auto without extensions Clustering"; + private static final String RANDOM_VOLTAGELEVEL_LAYOUT = "Random"; + private static final String CGMES_VOLTAGELEVEL_LAYOUT = "CGMES"; + // VoltageLevel layout provider private final Map nameToVoltageLevelLayoutFactoryMap = new TreeMap<>(); // ordered - private final ObservableList voltageLevelLayouts = FXCollections.observableArrayList(); - private final VoltageLevelLayoutFactoryBean voltageLevelLayoutFactory; + private static final String HORIZONTAL_SUBSTATION_LAYOUT = "Horizontal"; + private static final String VERTICAL_SUBSTATION_LAYOUT = "Vertical"; + private static final String CGMES_SUBSTATION_LAYOUT = "CGMES"; + // Substation layout provider private final Map nameToSubstationLayoutFactoryMap = new TreeMap<>(); // ordered - private final ObservableList substationLayouts = FXCollections.observableArrayList(); - private final ObjectProperty currentSubstationLayoutFactory = new SimpleObjectProperty<>(); // CGMES-DL names private final ObservableList cgmesDLDiagramNames = FXCollections.observableArrayList(); - private final StringProperty currentCgmesDLDiagramName = new SimpleStringProperty(); public SingleLineDiagramModel(// Providers @@ -110,22 +108,24 @@ public SingleLineDiagramModel(// Providers Property externCellHeight, Property internCellHeight, Property stackHeight, - BooleanProperty showGrid, - BooleanProperty showInternalNodes, - BooleanProperty drawStraightWires, BooleanProperty disconnectorsOnBus, Property scaleFactor, - BooleanProperty avoidSVGComponentsDuplication, BooleanProperty adaptCellHeightToContent, Property minSpaceBetweenComponents, Property minimumExternCellHeight, Property busBarAlignment, + Property spaceForFeederInfos, + //SvgParameters + BooleanProperty useName, + BooleanProperty showGrid, + BooleanProperty showInternalNodes, + BooleanProperty drawStraightWires, BooleanProperty centerLabel, BooleanProperty labelDiagonal, Property angleLabel, BooleanProperty addNodesInfos, BooleanProperty feederInfoSymmetry, - Property spaceForFeederInfos, + BooleanProperty avoidSVGComponentsDuplication, Property feederInfosOuterMargin, Property feederInfosIntraMargin ) { @@ -151,8 +151,8 @@ public SingleLineDiagramModel(// Providers this.highlightStyleProvider.bindBidirectional(highlightStyleProvider); this.topologicalStyleProvider.bindBidirectional(topologicalStyleProvider); - // Layout Parameters - this.sldParametersBean = new SldParametersBean(diagramPaddingTopBottom, + // LayoutParameters + this.layoutParametersBean = new LayoutParametersBean(diagramPaddingTopBottom, diagramPaddingLeftRight, voltagePaddingTopBottom, voltagePaddingLeftRight, @@ -162,22 +162,23 @@ public SingleLineDiagramModel(// Providers externCellHeight, internCellHeight, stackHeight, - showGrid, - showInternalNodes, - drawStraightWires, disconnectorsOnBus, scaleFactor, - avoidSVGComponentsDuplication, adaptCellHeightToContent, minSpaceBetweenComponents, minimumExternCellHeight, busBarAlignment, + spaceForFeederInfos); + // SvgParameters + this.svgParametersBean = new SvgParametersBean(showGrid, + showInternalNodes, + drawStraightWires, + avoidSVGComponentsDuplication, centerLabel, labelDiagonal, angleLabel, addNodesInfos, feederInfoSymmetry, - spaceForFeederInfos, feederInfosOuterMargin, feederInfosIntraMargin); } diff --git a/diagram-viewer/src/main/java/com/powsybl/diagram/viewer/sld/SingleLineDiagramViewController.java b/diagram-viewer/src/main/java/com/powsybl/diagram/viewer/sld/SingleLineDiagramViewController.java index afaf685..c610fe7 100644 --- a/diagram-viewer/src/main/java/com/powsybl/diagram/viewer/sld/SingleLineDiagramViewController.java +++ b/diagram-viewer/src/main/java/com/powsybl/diagram/viewer/sld/SingleLineDiagramViewController.java @@ -210,22 +210,24 @@ private void initialize() { externCellHeightSpinner.getValueFactory().valueProperty(), internCellHeightSpinner.getValueFactory().valueProperty(), stackHeightSpinner.getValueFactory().valueProperty(), - showGridCheckBox.selectedProperty(), - showInternalNodesCheckBox.selectedProperty(), - drawStraightWiresCheckBox.selectedProperty(), disconnectorsOnBusCheckBox.selectedProperty(), scaleFactorSpinner.getValueFactory().valueProperty(), - avoidSVGComponentsDuplicationCheckBox.selectedProperty(), adaptCellHeightToContentCheckBox.selectedProperty(), minSpaceBetweenComponentsSpinner.getValueFactory().valueProperty(), minimumExternCellHeightSpinner.getValueFactory().valueProperty(), busBarAlignmentChoice.valueProperty(), + spaceForFeederInfosSpinner.getValueFactory().valueProperty(), + + //SvgParameters + showGridCheckBox.selectedProperty(), + showInternalNodesCheckBox.selectedProperty(), + drawStraightWiresCheckBox.selectedProperty(), centerLabelCheckBox.selectedProperty(), labelDiagonalCheckBox.selectedProperty(), angleLabelSpinner.getValueFactory().valueProperty(), addNodesInfosCheckBox.selectedProperty(), feederInfoSymmetryCheckBox.selectedProperty(), - spaceForFeederInfosSpinner.getValueFactory().valueProperty(), + avoidSVGComponentsDuplicationCheckBox.selectedProperty(), feederInfosOuterMarginSpinner.getValueFactory().valueProperty(), feederInfosIntraMarginSpinner.getValueFactory().valueProperty() ); diff --git a/diagram-viewer/src/main/java/com/powsybl/diagram/viewer/sld/SvgParametersBean.java b/diagram-viewer/src/main/java/com/powsybl/diagram/viewer/sld/SvgParametersBean.java new file mode 100644 index 0000000..4781915 --- /dev/null +++ b/diagram-viewer/src/main/java/com/powsybl/diagram/viewer/sld/SvgParametersBean.java @@ -0,0 +1,113 @@ +/** + * Copyright (c) 2023, RTE (http://www.rte-france.com) + * This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. + * SPDX-License-Identifier: MPL-2.0 + */ +package com.powsybl.diagram.viewer.sld; + +import com.powsybl.sld.svg.SvgParameters; +import javafx.beans.property.*; +import javafx.beans.value.ChangeListener; + +import java.util.*; + +/** + * @author Sophie Frasnedo + */ +public class SvgParametersBean { + + private final BooleanProperty useName = new SimpleBooleanProperty(); + private final BooleanProperty showGrid = new SimpleBooleanProperty(); + private final BooleanProperty showInternalNodes = new SimpleBooleanProperty(); + private final BooleanProperty drawStraightWires = new SimpleBooleanProperty(); + private final BooleanProperty avoidSVGComponentsDuplication = new SimpleBooleanProperty(); + private final BooleanProperty centerLabel = new SimpleBooleanProperty(); + private final BooleanProperty labelDiagonal = new SimpleBooleanProperty(); + private final ObjectPropertyangleLabel = new SimpleObjectProperty<>(); + private final BooleanProperty addNodesInfos = new SimpleBooleanProperty(); + private final BooleanProperty feederInfoSymmetry = new SimpleBooleanProperty(); + private final ObjectPropertyfeederInfosOuterMargin = new SimpleObjectProperty<>(); + private final ObjectPropertyfeederInfosIntraMargin = new SimpleObjectProperty<>(); + + public SvgParametersBean(BooleanProperty showGrid, + BooleanProperty showInternalNodes, + BooleanProperty drawStraightWires, + BooleanProperty avoidSVGComponentsDuplication, + BooleanProperty centerLabel, + BooleanProperty labelDiagonal, + Property angleLabel, + BooleanProperty addNodesInfos, + BooleanProperty feederInfoSymmetry, + Property feederInfosOuterMargin, + Property feederInfosIntraMargin) { + // bind + this.showGrid.bindBidirectional(showGrid); + this.showInternalNodes.bindBidirectional(showInternalNodes); + this.drawStraightWires.bindBidirectional(drawStraightWires); + this.avoidSVGComponentsDuplication.bindBidirectional(avoidSVGComponentsDuplication); + this.centerLabel.bindBidirectional(centerLabel); + this.labelDiagonal.bindBidirectional(labelDiagonal); + this.angleLabel.bindBidirectional(angleLabel); + this.addNodesInfos.bindBidirectional(addNodesInfos); + this.feederInfoSymmetry.bindBidirectional(feederInfoSymmetry); + this.feederInfosOuterMargin.bindBidirectional(feederInfosOuterMargin); + this.feederInfosIntraMargin.bindBidirectional(feederInfosIntraMargin); + + // Initialize + SvgParameters defaultSvgParameters = new SvgParameters() + .setshowGrid(true); + + useName.setValue(defaultSvgParameters.isUseName()); + showGrid.setValue(defaultSvgParameters.isShowGrid()); + showInternalNodes.setValue(defaultSvgParameters.isShowInternalNodes()); + drawStraightWires.setValue(defaultSvgParameters.isDrawStraightWires()); + avoidSVGComponentsDuplication.setValue(defaultSvgParameters.isAvoidSVGComponentsDuplication()); + centerLabel.setValue(defaultSvgParameters.isLabelCentered()); + labelDiagonal.setValue(defaultSvgParameters.isLabelDiagonal()); + angleLabel.setValue(defaultSvgParameters.getAngleLabelShift()); + addNodesInfos.setValue(defaultSvgParameters.isAddNodesInfos()); + feederInfoSymmetry.setValue(defaultSvgParameters.isFeederInfoSymmetry()); + feederInfosOuterMargin.setValue(defaultSvgParameters.getFeederInfosOuterMargin()); + feederInfosIntraMargin.setValue(defaultSvgParameters.getFeederInfosIntraMargin()); + } + + public void bind(BooleanProperty useName) { + this.useName.bindBidirectional(useName); + } + + public void addListener(ChangeListener changeListener) { + this.useName.addListener(changeListener); + this.showGrid.addListener(changeListener); + this.showInternalNodes.addListener(changeListener); + this.drawStraightWires.addListener(changeListener); + this.avoidSVGComponentsDuplication.addListener(changeListener); + this.centerLabel.addListener(changeListener); + this.labelDiagonal.addListener(changeListener); + this.angleLabel.addListener(changeListener); + this.addNodesInfos.addListener(changeListener); + this.feederInfoSymmetry.addListener(changeListener); + this.feederInfosOuterMargin.addListener(changeListener); + this.feederInfosIntraMargin.addListener(changeListener); + } + + public SvgParameters getSvgParameters(String diagramName) { + return new SvgParameters() + .setShowGrid(showGrid.get()) + .setShowInternalNodes(showInternalNodes.get()) + .setDrawStraightWires(drawStraightWires.get()) + .setAvoidSVGComponentsDuplication(avoidSVGComponentsDuplication.get()) + .setLabelCentered(centerLabel.get()) + .setLabelDiagonal(labelDiagonal.get()) + .setAngleLabelShift(angleLabel.get()) + .setAddNodesInfos(addNodesInfos.get()) + .setFeederInfoSymmetry(feederInfoSymmetry.get()) + .setFeederInfosOuterMargin(feederInfosOuterMargin.get()) + .setFeederInfosIntraMargin(feederInfosIntraMargin.get()) + .setDiagramName(diagramName) + // Forced values + .setCssLocation(SvgParameters.CssLocation.INSERTED_IN_SVG) + .setSvgWidthAndHeightAdded(true); + } +} diff --git a/diagram-viewer/src/main/resources/sld/view.fxml b/diagram-viewer/src/main/resources/sld/view.fxml index b92f79a..3575059 100644 --- a/diagram-viewer/src/main/resources/sld/view.fxml +++ b/diagram-viewer/src/main/resources/sld/view.fxml @@ -138,9 +138,6 @@ - - -