From 90d5cc1077343369afb9a74dcd81466a518417dc Mon Sep 17 00:00:00 2001 From: Armin Samii Date: Fri, 15 Mar 2024 15:08:13 -0400 Subject: [PATCH 1/2] include a "#" column on candidate and CVR list --- .../brightspots/rcv/GuiConfigController.java | 43 +++++++++++++++++++ 1 file changed, 43 insertions(+) diff --git a/src/main/java/network/brightspots/rcv/GuiConfigController.java b/src/main/java/network/brightspots/rcv/GuiConfigController.java index 9fa2063cb..90dc0dd3b 100644 --- a/src/main/java/network/brightspots/rcv/GuiConfigController.java +++ b/src/main/java/network/brightspots/rcv/GuiConfigController.java @@ -44,6 +44,7 @@ import java.util.Set; import java.util.stream.Collectors; import javafx.application.Platform; +import javafx.beans.NamedArg; import javafx.beans.property.SimpleStringProperty; import javafx.concurrent.Service; import javafx.concurrent.Task; @@ -66,6 +67,7 @@ import javafx.scene.control.SelectionMode; import javafx.scene.control.Tab; import javafx.scene.control.TabPane; +import javafx.scene.control.TableCell; import javafx.scene.control.TableColumn; import javafx.scene.control.TableView; import javafx.scene.control.TextArea; @@ -80,6 +82,7 @@ import javafx.stage.DirectoryChooser; import javafx.stage.FileChooser; import javafx.stage.FileChooser.ExtensionFilter; +import javafx.util.Callback; import javafx.util.Pair; import javafx.util.StringConverter; import network.brightspots.rcv.ContestConfig.Provider; @@ -1200,6 +1203,7 @@ public LocalDate fromString(String string) { .setCellValueFactory(new PropertyValueFactory<>("treatBlankAsUndeclaredWriteIn")); tableViewCvrFiles.getSelectionModel().setSelectionMode(SelectionMode.MULTIPLE); tableViewCvrFiles.setEditable(true); + tableViewCvrFiles.getColumns().add(0, NumberTableCellFactory.createNumberColumn("#", 1)); EditableColumn[] candidateStringColumnsAndProperties = new EditableColumn[]{ new EditableColumnString(tableColumnCandidateName, "name"), @@ -1223,6 +1227,7 @@ public LocalDate fromString(String string) { tableViewCandidates.getSelectionModel().setSelectionMode(SelectionMode.MULTIPLE); tableViewCandidates.setEditable(true); + tableViewCandidates.getColumns().add(0, NumberTableCellFactory.createNumberColumn("#", 1)); // Let's also catch programming errors -- all of these properties must have corresponding // functions in order to have the PropertyValueFactory work correctly. @@ -1783,4 +1788,42 @@ public void setCellFactory() { column.setCellFactory(tc -> new EditableTableCellPopup()); } } + + private static class NumberTableCellFactory + implements Callback, TableCell> { + private final int startNumber; + + public NumberTableCellFactory(@NamedArg("startNumber") int startNumber) { + this.startNumber = startNumber; + } + + public static class NumberTableCell extends TableCell { + private final int startNumber; + + public NumberTableCell(int startNumber) { + this.startNumber = startNumber; + } + + @Override + public void updateItem(T item, boolean empty) { + super.updateItem(item, empty); + + setText(empty ? "" : Integer.toString(startNumber + getIndex())); + } + } + + @Override + public TableCell call(TableColumn param) { + return new NumberTableCell<>(startNumber); + } + + public static TableColumn createNumberColumn(String text, int startNumber) { + TableColumn column = new TableColumn<>(text); + column.setSortable(false); + column.setEditable(false); + column.setPrefWidth(25); + column.setCellFactory(new NumberTableCellFactory<>(startNumber)); + return column; + } + } } From a027eef0210295ba2d04be11af34ceb0a48b3e27 Mon Sep 17 00:00:00 2001 From: Armin Samii Date: Mon, 25 Mar 2024 16:33:15 -0400 Subject: [PATCH 2/2] add comment --- src/main/java/network/brightspots/rcv/GuiConfigController.java | 3 +++ 1 file changed, 3 insertions(+) diff --git a/src/main/java/network/brightspots/rcv/GuiConfigController.java b/src/main/java/network/brightspots/rcv/GuiConfigController.java index 90dc0dd3b..f34ce2715 100644 --- a/src/main/java/network/brightspots/rcv/GuiConfigController.java +++ b/src/main/java/network/brightspots/rcv/GuiConfigController.java @@ -1789,6 +1789,9 @@ public void setCellFactory() { } } + /** + * Adapted from https://stackoverflow.com/a/41282740/1057105 + */ private static class NumberTableCellFactory implements Callback, TableCell> { private final int startNumber;