summaryrefslogtreecommitdiff
path: root/src/main/java/sevenUnits/newGUI/UnitConversionView.java
diff options
context:
space:
mode:
authorAdrien Hopkins <ahopk127@my.yorku.ca>2021-12-15 17:52:43 -0500
committerAdrien Hopkins <ahopk127@my.yorku.ca>2021-12-16 10:02:10 -0500
commit4f754b0bc136b972607aa1b39f2358bd98dc4e1c (patch)
treec5c81ef152c011fec2c2f1d6b3c916c5cc6ca93e /src/main/java/sevenUnits/newGUI/UnitConversionView.java
parent9c30c3ad4d4658964e2bb2bb5be6c2eebbfbe8af (diff)
Designed the API for a new GUI
Currently "supports" unit conversion, expression conversion and settings loading
Diffstat (limited to 'src/main/java/sevenUnits/newGUI/UnitConversionView.java')
-rw-r--r--src/main/java/sevenUnits/newGUI/UnitConversionView.java97
1 files changed, 97 insertions, 0 deletions
diff --git a/src/main/java/sevenUnits/newGUI/UnitConversionView.java b/src/main/java/sevenUnits/newGUI/UnitConversionView.java
new file mode 100644
index 0000000..dafd461
--- /dev/null
+++ b/src/main/java/sevenUnits/newGUI/UnitConversionView.java
@@ -0,0 +1,97 @@
+/**
+ * Copyright (C) 2021 Adrien Hopkins
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License
+ * along with this program. If not, see <https://www.gnu.org/licenses/>.
+ */
+package sevenUnits.newGUI;
+
+import java.util.List;
+import java.util.Optional;
+import java.util.OptionalDouble;
+
+import sevenUnits.unit.BaseDimension;
+import sevenUnits.unit.Unit;
+import sevenUnits.unit.UnitValue;
+import sevenUnits.utils.NamedObjectProduct;
+import sevenUnits.utils.ObjectProduct;
+
+/**
+ * A View that supports single unit-based conversion
+ *
+ * @author Adrien Hopkins
+ * @since 2021-12-15
+ */
+public interface UnitConversionView extends View {
+ /**
+ * @return unit to convert <em>from</em>
+ * @since 2021-12-15
+ */
+ Optional<Unit> getFromSelection();
+
+ /**
+ * @return value to convert between the units
+ * @since 2021-12-15
+ */
+ OptionalDouble getInputValue();
+
+ /**
+ * @return selected dimension
+ * @since 2021-12-15
+ */
+ Optional<ObjectProduct<BaseDimension>> getSelectedDimension();
+
+ /**
+ * @return unit to convert <em>to</em>
+ * @since 2021-12-15
+ */
+ Optional<Unit> getToSelection();
+
+ /**
+ * Sets the available dimensions for filtering.
+ *
+ * @param dimensions dimensions to use
+ * @since 2021-12-15
+ */
+ void setDimensions(List<NamedObjectProduct<BaseDimension>> dimensions);
+
+ /**
+ * Sets the available units to convert from. {@link #getFromSelection} is not
+ * required to use one of these units; this method is to be used for views
+ * that allow the user to select units from a list.
+ *
+ * @param units units to convert from
+ * @since 2021-12-15
+ */
+ void setFromUnits(List<? extends Unit> units);
+
+ /**
+ * Sets the available units to convert to. {@link #getToSelection} is not
+ * required to use one of these units; this method is to be used for views
+ * that allow the user to select units from a list.
+ *
+ * @param units units to convert to
+ * @since 2021-12-15
+ */
+ void setToUnits(List<? extends Unit> units);
+
+ /**
+ * Shows the output of a unit conversion.
+ *
+ * @param input unit value before conversion, as obtained from the view
+ * @param output unit value after conversion
+ * @throws NullPointerException if either argument is null
+ * @since 2021-12-15
+ */
+ void showUnitConversionOutput(UnitValue input, UnitValue output);
+}