only show details pane, when cache is selected

This commit is contained in:
2016-08-28 21:53:13 +02:00
parent ca88df9926
commit 142133b647
2 changed files with 71 additions and 71 deletions

View File

@@ -26,10 +26,8 @@
package de.geofroggerfx.ui.details; package de.geofroggerfx.ui.details;
import com.lynden.gmapsfx.GoogleMapView; import com.lynden.gmapsfx.GoogleMapView;
import com.lynden.gmapsfx.MapComponentInitializedListener;
import com.lynden.gmapsfx.javascript.object.*; import com.lynden.gmapsfx.javascript.object.*;
import de.geofroggerfx.application.SessionContext; import de.geofroggerfx.application.SessionContext;
import de.geofroggerfx.application.SessionContextListener;
import de.geofroggerfx.model.Attribute; import de.geofroggerfx.model.Attribute;
import de.geofroggerfx.model.Cache; import de.geofroggerfx.model.Cache;
import de.geofroggerfx.model.Log; import de.geofroggerfx.model.Log;
@@ -68,6 +66,9 @@ public class DetailsController extends FXMLController {
@Autowired @Autowired
private SessionContext sessionContext; private SessionContext sessionContext;
@FXML
private BorderPane detailsPane;
@FXML @FXML
private Label cacheName; private Label cacheName;
@@ -107,45 +108,38 @@ public class DetailsController extends FXMLController {
@Override @Override
public void initialize(URL location, ResourceBundle resources) { public void initialize(URL location, ResourceBundle resources) {
detailsPane.setVisible(false);
setCacheListener(); setCacheListener();
initializeMap(); initializeMap();
setLogLinkButton(); setLogLinkButton();
} }
private void setCacheListener() { private void setCacheListener() {
sessionContext.addListener(CURRENT_CACHE, new SessionContextListener() { sessionContext.addListener(CURRENT_CACHE, () -> fillContent());
@Override
public void sessionContextChanged() {
fillContent();
}
});
} }
private void initializeMap() { private void initializeMap() {
mapView.addMapInializedListener(new MapComponentInitializedListener() { mapView.addMapInializedListener(() -> {
@Override //Set the initial properties of the map.
public void mapInitialized() { MapOptions mapOptions = new MapOptions();
//Set the initial properties of the map. mapOptions.center(new LatLong(47.6097, -122.3331))
MapOptions mapOptions = new MapOptions(); .mapType(MapTypeIdEnum.ROADMAP)
mapOptions.center(new LatLong(47.6097, -122.3331)) .overviewMapControl(false)
.mapType(MapTypeIdEnum.ROADMAP) .panControl(false)
.overviewMapControl(false) .rotateControl(false)
.panControl(false) .scaleControl(false)
.rotateControl(false) .streetViewControl(false)
.scaleControl(false) .zoomControl(false)
.streetViewControl(false) .zoom(12);
.zoomControl(false)
.zoom(12);
map = mapView.createMap(mapOptions); map = mapView.createMap(mapOptions);
LatLong latLong = new LatLong(49.045458, 9.189835); LatLong latLong = new LatLong(49.045458, 9.189835);
MarkerOptions options = new MarkerOptions(); MarkerOptions options = new MarkerOptions();
options.position(latLong); options.position(latLong);
marker = new Marker(options); marker = new Marker(options);
map.addMarker(marker); map.addMarker(marker);
map.setCenter(latLong); map.setCenter(latLong);
}
}); });
} }
@@ -232,48 +226,54 @@ public class DetailsController extends FXMLController {
private void fillContent() { private void fillContent() {
Cache cache = (Cache) sessionContext.getData(CURRENT_CACHE); Cache cache = (Cache) sessionContext.getData(CURRENT_CACHE);
cacheName.setText(cache.getName());
cacheDifficulty.setText(getStarsAsString(cache.getDifficulty()));
cacheTerrain.setText(getStarsAsString(cache.getTerrain()));
String shortDescription = cache.getShortDescription(); if (cache != null) {
if (!cache.getLongDescriptionHtml()) { detailsPane.setVisible(true);
shortDescription = shortDescription.replaceAll("\n","</br>"); cacheName.setText(cache.getName());
cacheDifficulty.setText(getStarsAsString(cache.getDifficulty()));
cacheTerrain.setText(getStarsAsString(cache.getTerrain()));
String shortDescription = cache.getShortDescription();
if (!cache.getLongDescriptionHtml()) {
shortDescription = shortDescription.replaceAll("\n", "</br>");
}
String longDescription = cache.getLongDescription();
if (!cache.getLongDescriptionHtml()) {
longDescription = longDescription.replaceAll("\n", "</br>");
}
String description = "<html><body><p>" + shortDescription + "</p><p>" + longDescription + "</p></body></html>";
final WebEngine webEngine = this.description.getEngine();
webEngine.loadContent(description);
attributeList.getChildren().clear();
for (Attribute attribute : cache.getAttributes()) {
attributeList.getChildren().add(MaterialDesignIconFactory.get().createIcon(GeocachingIcons.getIcon(attribute)));
}
logList.getChildren().clear();
int maxRow = Math.min(4, cache.getLogs().size());
for (int row = 0; row < maxRow; row++) {
setLogIcon(row);
setLogText(row, cache.getLogs().get(row));
}
LatLong latLong = new LatLong(cache.getMainWayPoint().getLatitude(), cache.getMainWayPoint().getLongitude());
MarkerOptions options = new MarkerOptions();
options.position(latLong);
options.title(cache.getMainWayPoint().getName());
map.removeMarker(marker);
marker.setTitle(cache.getMainWayPoint().getName());
marker = new Marker(options);
map.addMarker(marker);
map.setCenter(latLong);
mapView.requestLayout();
} else {
detailsPane.setVisible(false);
} }
String longDescription = cache.getLongDescription();
if (!cache.getLongDescriptionHtml()) {
longDescription = longDescription.replaceAll("\n","</br>");
}
String description = "<html><body><p>"+shortDescription+"</p><p>"+longDescription+"</p></body></html>";
final WebEngine webEngine = this.description.getEngine();
webEngine.loadContent(description);
attributeList.getChildren().clear();
for (Attribute attribute: cache.getAttributes()) {
attributeList.getChildren().add(MaterialDesignIconFactory.get().createIcon(GeocachingIcons.getIcon(attribute)));
}
logList.getChildren().clear();
int maxRow = Math.min(4, cache.getLogs().size());
for (int row=0; row<maxRow; row++) {
setLogIcon(row);
setLogText(row, cache.getLogs().get(row));
}
LatLong latLong = new LatLong(cache.getMainWayPoint().getLatitude(), cache.getMainWayPoint().getLongitude());
MarkerOptions options = new MarkerOptions();
options.position(latLong);
options.title(cache.getMainWayPoint().getName());
map.removeMarker(marker);
marker.setTitle(cache.getMainWayPoint().getName());
marker = new Marker(options);
map.addMarker(marker);
map.setCenter(latLong);
mapView.requestLayout();
} }
private void setLogIcon(int row) { private void setLogIcon(int row) {

View File

@@ -8,7 +8,7 @@
<?import javafx.scene.layout.*?> <?import javafx.scene.layout.*?>
<?import javafx.scene.web.WebView?> <?import javafx.scene.web.WebView?>
<?import java.net.URL?> <?import java.net.URL?>
<BorderPane layoutX="10.0" layoutY="10.0" maxHeight="-Infinity" maxWidth="-Infinity" minHeight="600" minWidth="400" style="-fx-background-color: #ffffff;" AnchorPane.bottomAnchor="0.0" AnchorPane.leftAnchor="0.0" AnchorPane.rightAnchor="0.0" AnchorPane.topAnchor="0.0" xmlns="http://javafx.com/javafx/8.0.40" xmlns:fx="http://javafx.com/fxml/1"> <BorderPane fx:id="detailsPane" layoutX="10.0" layoutY="10.0" maxHeight="-Infinity" maxWidth="-Infinity" minHeight="600" minWidth="400" style="-fx-background-color: #ffffff;" AnchorPane.bottomAnchor="0.0" AnchorPane.leftAnchor="0.0" AnchorPane.rightAnchor="0.0" AnchorPane.topAnchor="0.0" xmlns="http://javafx.com/javafx/8.0.40" xmlns:fx="http://javafx.com/fxml/1">
<right> <right>
<VBox minWidth="200.0" prefHeight="200.0" spacing="8.0" BorderPane.alignment="CENTER"> <VBox minWidth="200.0" prefHeight="200.0" spacing="8.0" BorderPane.alignment="CENTER">
<children> <children>