Compare commits
	
		
			8 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| d872a39394 | |||
| 9d010d452c | |||
| 58e94e6cbd | |||
| 63e736152b | |||
| ad5d7d98c4 | |||
| d8c4680e16 | |||
| 49b6407ce6 | |||
| 9472a5537a | 
@@ -6,6 +6,16 @@ logo = logo.png
 | 
				
			|||||||
[lang]
 | 
					[lang]
 | 
				
			||||||
lang = langde
 | 
					lang = langde
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					[settings]
 | 
				
			||||||
 | 
					openpdf = 1
 | 
				
			||||||
 | 
					openmap = 0
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					[einheiten]
 | 
				
			||||||
 | 
					zeit = min
 | 
				
			||||||
 | 
					strecke = km
 | 
				
			||||||
 | 
					meter = m
 | 
				
			||||||
 | 
					speed = km/h
 | 
				
			||||||
 | 
					
 | 
				
			||||||
[db]
 | 
					[db]
 | 
				
			||||||
dbname = tourplaner
 | 
					dbname = tourplaner
 | 
				
			||||||
url =
 | 
					url =
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										46
									
								
								langde.ini
									
									
									
									
									
								
							
							
						
						
									
										46
									
								
								langde.ini
									
									
									
									
									
								
							@@ -19,7 +19,7 @@ zielpunkttitle = Tour zielpunkt
 | 
				
			|||||||
zielpunktheader = Bitte geben Sie den Zielpunkt der Tour an!
 | 
					zielpunktheader = Bitte geben Sie den Zielpunkt der Tour an!
 | 
				
			||||||
zielpunktmsg = Zielpunkt:
 | 
					zielpunktmsg = Zielpunkt:
 | 
				
			||||||
deltournoselect = ViewModel -> DelTour
 | 
					deltournoselect = ViewModel -> DelTour
 | 
				
			||||||
deltournoselectmsg = Bitte wählen Sie zuerst eine Tour aus, bevor Sie auf löschen klicken!
 | 
					deltournoselectmsg = Bitte wählen Sie zuerst eine Tour aus!
 | 
				
			||||||
exceptionstackheader = Exception stacktrace:
 | 
					exceptionstackheader = Exception stacktrace:
 | 
				
			||||||
keinelogsvorhanden = Fügen Sie erst ein Log hinzu um es anzuzeigen!
 | 
					keinelogsvorhanden = Fügen Sie erst ein Log hinzu um es anzuzeigen!
 | 
				
			||||||
datum = Datum
 | 
					datum = Datum
 | 
				
			||||||
@@ -59,4 +59,46 @@ loggegangen = Davon gegangen:
 | 
				
			|||||||
logavg = Berechnete Durchschnittliche Geschwindigkeit:
 | 
					logavg = Berechnete Durchschnittliche Geschwindigkeit:
 | 
				
			||||||
logstrecke = Entfernung:
 | 
					logstrecke = Entfernung:
 | 
				
			||||||
loghight = Höhenmeter:
 | 
					loghight = Höhenmeter:
 | 
				
			||||||
logbemerkung = Bemerkung:
 | 
					logbemerkung = Bemerkung:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					fkarte = Karte
 | 
				
			||||||
 | 
					fbeschreibung = Beschreibung
 | 
				
			||||||
 | 
					fedit = Bearbeiten
 | 
				
			||||||
 | 
					fname = Tourname
 | 
				
			||||||
 | 
					fstrecke = Berechnete Strecke
 | 
				
			||||||
 | 
					fdauer =  Berechnete Dauer
 | 
				
			||||||
 | 
					fziel = Ziel
 | 
				
			||||||
 | 
					fstart = Start
 | 
				
			||||||
 | 
					favg = Durchschnittsgeschwindigkeit
 | 
				
			||||||
 | 
					fbemerkung = Bemerkung
 | 
				
			||||||
 | 
					fdatum = Datum
 | 
				
			||||||
 | 
					fdauer = Dauer
 | 
				
			||||||
 | 
					fgegangen = Davon gegangen
 | 
				
			||||||
 | 
					fhight = Höhenmeter
 | 
				
			||||||
 | 
					fpause = Davon Pause
 | 
				
			||||||
 | 
					fstrecke = Strecke
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					keinlogselected = Kein Logeintrag ausgewählt
 | 
				
			||||||
 | 
					keinlogselectedmsg = Bitte zuerst einen Logeintrag auswählen
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					fsuche = Suchen
 | 
				
			||||||
 | 
					fopenmapsetting = Map automatisch öffnen
 | 
				
			||||||
 | 
					fopenpdfsetting = Report automatisch öffnen
 | 
				
			||||||
 | 
					flangenglisch = Englisch
 | 
				
			||||||
 | 
					flangdeutsch = Deutsch
 | 
				
			||||||
 | 
					fdatei = Datei
 | 
				
			||||||
 | 
					fbearbeiten = Bearbeiten
 | 
				
			||||||
 | 
					foptionen = Optionen
 | 
				
			||||||
 | 
					fsprache = Sprache auswählen
 | 
				
			||||||
 | 
					fhilfe = Hilfe
 | 
				
			||||||
 | 
					freposum = Erstelle Report über alle Touren
 | 
				
			||||||
 | 
					frepotour = Erstelle Report über aktuelle Tour
 | 
				
			||||||
 | 
					fbeenden = Beenden
 | 
				
			||||||
 | 
					fpunkte = ...
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					rzeitallerlogs = Gesammte Zeit aller Logs:
 | 
				
			||||||
 | 
					rstreckeallerlogs = gesammte Strecke aller Logs:
 | 
				
			||||||
 | 
					rcalzeitallerlogs = Berechnete Zeit aller Logs:
 | 
				
			||||||
 | 
					calstreckeallerloggs = Berechnete Strecke aller Touren:
 | 
				
			||||||
 | 
					rdaten = Daten
 | 
				
			||||||
 | 
					rsummrepo = Zusammengefasster Report
 | 
				
			||||||
							
								
								
									
										105
									
								
								langen.ini
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										105
									
								
								langen.ini
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,105 @@
 | 
				
			|||||||
 | 
					[langen]
 | 
				
			||||||
 | 
					achtung = ATTENTION
 | 
				
			||||||
 | 
					openbrowsererror = TourplanerController -> Browser:
 | 
				
			||||||
 | 
					browserexception = Browser Exception
 | 
				
			||||||
 | 
					browserexceptionmsg = Error at opening Browser
 | 
				
			||||||
 | 
					suchfeldleer = Search field is empty!
 | 
				
			||||||
 | 
					suchtextzuerst = Please enter search term first!
 | 
				
			||||||
 | 
					keinetourselected = No Tour selected
 | 
				
			||||||
 | 
					tournametitle = Tour name
 | 
				
			||||||
 | 
					tournameheader = Please enter a Tourname!
 | 
				
			||||||
 | 
					tournamemsg = Name:
 | 
				
			||||||
 | 
					namevergebenheader = Name is already occupied!
 | 
				
			||||||
 | 
					namevergebenmsg1 = The name '
 | 
				
			||||||
 | 
					namevergebenmsg2 = ' is already in use!
 | 
				
			||||||
 | 
					startpunkttitle = Tour start
 | 
				
			||||||
 | 
					startpunktheader = Please enter the start of the Tour
 | 
				
			||||||
 | 
					startpunktmsg = Start:
 | 
				
			||||||
 | 
					zielpunkttitle = Tour destination:
 | 
				
			||||||
 | 
					zielpunktheader = Please enter the tour destination!
 | 
				
			||||||
 | 
					zielpunktmsg = Destination:
 | 
				
			||||||
 | 
					deltournoselect = ViewModel -> DelTour
 | 
				
			||||||
 | 
					deltournoselectmsg = Please select a tour first!
 | 
				
			||||||
 | 
					exceptionstackheader = Exception stacktrace:
 | 
				
			||||||
 | 
					keinelogsvorhanden = First add a Log!
 | 
				
			||||||
 | 
					datum = Date
 | 
				
			||||||
 | 
					dauer = Duration
 | 
				
			||||||
 | 
					strecke = Distance
 | 
				
			||||||
 | 
					streckemsg = Distance of the log entry
 | 
				
			||||||
 | 
					dauermsg = Duration of the log entry
 | 
				
			||||||
 | 
					doppelpunkt = :
 | 
				
			||||||
 | 
					fktnichtimplementiert = Not implementet jet
 | 
				
			||||||
 | 
					vergessenodernochnichtsoweit = Not implementet jet
 | 
				
			||||||
 | 
					logtournotselectedmsg = Please select a tour first!
 | 
				
			||||||
 | 
					keintextimfeld = Please enter a text!
 | 
				
			||||||
 | 
					nurzahlen = Only numbers!
 | 
				
			||||||
 | 
					nurpositivezahlen = Only positiv numbers!
 | 
				
			||||||
 | 
					pause = Break
 | 
				
			||||||
 | 
					pausemsg = Duration of the break
 | 
				
			||||||
 | 
					hightmeter = Vertical meters
 | 
				
			||||||
 | 
					hightmetermsg = Vertical meters of the etape
 | 
				
			||||||
 | 
					bemerkung = Comment
 | 
				
			||||||
 | 
					bemerkungheader = Please enter a Comment, can also be empty!
 | 
				
			||||||
 | 
					tourreportvon = Tour Report from ->
 | 
				
			||||||
 | 
					tourplanervon = Tourplaner by DerGeorg
 | 
				
			||||||
 | 
					reportkeywords = Tourplaner, Tour, Report
 | 
				
			||||||
 | 
					tourplaner = Tourplaner
 | 
				
			||||||
 | 
					tour = Tour
 | 
				
			||||||
 | 
					reportvon = Report created by:
 | 
				
			||||||
 | 
					reportstart = Start of the tour:
 | 
				
			||||||
 | 
					reportziel = Destination of the tour:
 | 
				
			||||||
 | 
					reportdauercal = Calculated duration of the tour:
 | 
				
			||||||
 | 
					reportstreckecal = Calculated distance of the tour:
 | 
				
			||||||
 | 
					logs = Logs
 | 
				
			||||||
 | 
					countlog = Number of log entries:
 | 
				
			||||||
 | 
					logvom = Log from:
 | 
				
			||||||
 | 
					logdauer = Duration:
 | 
				
			||||||
 | 
					logpause = Break from that:
 | 
				
			||||||
 | 
					loggegangen = Gone away:
 | 
				
			||||||
 | 
					logavg = Calculated averrage speed:
 | 
				
			||||||
 | 
					logstrecke = Distance:
 | 
				
			||||||
 | 
					loghight = Vertical meters:
 | 
				
			||||||
 | 
					logbemerkung = Comment:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					fkarte = Map
 | 
				
			||||||
 | 
					fbeschreibung = Description
 | 
				
			||||||
 | 
					fedit = Edit
 | 
				
			||||||
 | 
					fname = Tourname
 | 
				
			||||||
 | 
					fstrecke = Calculated Distance
 | 
				
			||||||
 | 
					fdauer =  Calculated Duration
 | 
				
			||||||
 | 
					fziel = Destination
 | 
				
			||||||
 | 
					fstart = Start
 | 
				
			||||||
 | 
					favg = Average speed
 | 
				
			||||||
 | 
					fbemerkung = Comment
 | 
				
			||||||
 | 
					fdatum = Date
 | 
				
			||||||
 | 
					fdauer = Duration
 | 
				
			||||||
 | 
					fgegangen = Gone away
 | 
				
			||||||
 | 
					fhight = Vertical meters
 | 
				
			||||||
 | 
					fpause = Break from that
 | 
				
			||||||
 | 
					fstrecke = Distance
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					keinlogselected = No log selected
 | 
				
			||||||
 | 
					keinlogselectedmsg = Please select a log first!
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					fsuche = Search
 | 
				
			||||||
 | 
					fopenmapsetting = Open map automatic
 | 
				
			||||||
 | 
					fopenpdfsetting = Open report automatic
 | 
				
			||||||
 | 
					flangenglisch = English
 | 
				
			||||||
 | 
					flangdeutsch = German
 | 
				
			||||||
 | 
					fdatei = File
 | 
				
			||||||
 | 
					fbearbeiten = Edit
 | 
				
			||||||
 | 
					foptionen = Options
 | 
				
			||||||
 | 
					fsprache = Choose Language
 | 
				
			||||||
 | 
					fhilfe = Help
 | 
				
			||||||
 | 
					freposum = Generate summarize-report
 | 
				
			||||||
 | 
					frepotour = Generate tour-report
 | 
				
			||||||
 | 
					fbeenden = Quit
 | 
				
			||||||
 | 
					fpunkte = ...
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					rzeitallerlogs = Time of all logs:
 | 
				
			||||||
 | 
					rstreckeallerlogs = Distance of all logs:
 | 
				
			||||||
 | 
					rcalzeitallerlogs = Calculated time of all logs:
 | 
				
			||||||
 | 
					calstreckeallerloggs = Calculated distance  of all logs:
 | 
				
			||||||
 | 
					rdaten = Data
 | 
				
			||||||
 | 
					rsummrepo = Summary Report
 | 
				
			||||||
@@ -43,7 +43,7 @@ public class ConfigHelper {
 | 
				
			|||||||
        try {
 | 
					        try {
 | 
				
			||||||
            ini = new Wini(new File(filename));
 | 
					            ini = new Wini(new File(filename));
 | 
				
			||||||
        } catch (IOException e) {
 | 
					        } catch (IOException e) {
 | 
				
			||||||
            LogHelper.error(e.getMessage(), e.getClass().getName());
 | 
					            LogHelper.error(e);
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
        assert ini != null;
 | 
					        assert ini != null;
 | 
				
			||||||
        return ini.get(sectionName, optionName, String.class);
 | 
					        return ini.get(sectionName, optionName, String.class);
 | 
				
			||||||
@@ -56,7 +56,7 @@ public class ConfigHelper {
 | 
				
			|||||||
     * @return Den angeforderten String
 | 
					     * @return Den angeforderten String
 | 
				
			||||||
     */
 | 
					     */
 | 
				
			||||||
    public static String getLangIniString(String optionName){
 | 
					    public static String getLangIniString(String optionName){
 | 
				
			||||||
        return ConfigHelper.getIniString(ConfigHelper.getStandartLangde(), ConfigHelper.getIniString(ConfigHelper.getStandartConfig(), "lang", "lang"),optionName);
 | 
					        return ConfigHelper.getIniString(getIniString(getStandartConfig(), "lang", "lang") + ".ini", ConfigHelper.getIniString(ConfigHelper.getStandartConfig(), "lang", "lang"),optionName);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    /**
 | 
					    /**
 | 
				
			||||||
@@ -92,7 +92,7 @@ public class ConfigHelper {
 | 
				
			|||||||
            ini.put(sectionName, optionName, value);
 | 
					            ini.put(sectionName, optionName, value);
 | 
				
			||||||
            ini.store();
 | 
					            ini.store();
 | 
				
			||||||
        } catch (IOException e) {
 | 
					        } catch (IOException e) {
 | 
				
			||||||
            LogHelper.error(e.getMessage(), e.getClass().getName());
 | 
					            LogHelper.error(e);
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -31,7 +31,9 @@ public class DirectionMap {
 | 
				
			|||||||
        FileHelper.saveImage(this.map, "jpg", new File(this.file));
 | 
					        FileHelper.saveImage(this.map, "jpg", new File(this.file));
 | 
				
			||||||
        FileHelper.saveImage(this.mappdf, "jpg", new File(this.filepdf));
 | 
					        FileHelper.saveImage(this.mappdf, "jpg", new File(this.filepdf));
 | 
				
			||||||
        getDirections(start, ende);
 | 
					        getDirections(start, ende);
 | 
				
			||||||
        FileHelper.openDefault(file);
 | 
					        if(ConfigHelper.getIniInt(ConfigHelper.getStandartConfig(), "settings", "openmap") == 1) {
 | 
				
			||||||
 | 
					            FileHelper.openDefault(file);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    /**
 | 
					    /**
 | 
				
			||||||
@@ -68,7 +70,10 @@ public class DirectionMap {
 | 
				
			|||||||
     * @throws IOException Fehler beim besorgen der infos über die Tour
 | 
					     * @throws IOException Fehler beim besorgen der infos über die Tour
 | 
				
			||||||
     */
 | 
					     */
 | 
				
			||||||
    private void getDirections(String start, String ende) throws IOException {
 | 
					    private void getDirections(String start, String ende) throws IOException {
 | 
				
			||||||
 | 
					        System.out.println("LOCS: " + start + ende);
 | 
				
			||||||
        String json = HttpHelper.httpGetJsonString("https://www.mapquestapi.com/directions/v2/route?key="+ ConfigHelper.getIniString(ConfigHelper.getStandartConfig(), "map", "key")+"&from="+start+"&to="+ende+"&outFormat=json&ambiguities=ignore&routeType=fastest&doReverseGeocode=false&enhancedNarrative=false&avoidTimedConditions=false");
 | 
					        String json = HttpHelper.httpGetJsonString("https://www.mapquestapi.com/directions/v2/route?key="+ ConfigHelper.getIniString(ConfigHelper.getStandartConfig(), "map", "key")+"&from="+start+"&to="+ende+"&outFormat=json&ambiguities=ignore&routeType=fastest&doReverseGeocode=false&enhancedNarrative=false&avoidTimedConditions=false");
 | 
				
			||||||
 | 
					        System.out.println("JSON: " + json);
 | 
				
			||||||
 | 
					        System.out.println("URL https://www.mapquestapi.com/directions/v2/route?key="+ ConfigHelper.getIniString(ConfigHelper.getStandartConfig(), "map", "key")+"&from="+start+"&to="+ende+"&outFormat=json&ambiguities=ignore&routeType=fastest&doReverseGeocode=false&enhancedNarrative=false&avoidTimedConditions=false");
 | 
				
			||||||
        this.strecke = JsonHelper.getDoubleFromJson(json, "distance");
 | 
					        this.strecke = JsonHelper.getDoubleFromJson(json, "distance");
 | 
				
			||||||
        this.dauer = formatetTimeToMinutes(JsonHelper.getStingFromJson(json, "formattedTime"));
 | 
					        this.dauer = formatetTimeToMinutes(JsonHelper.getStingFromJson(json, "formattedTime"));
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										50
									
								
								src/tourplaner/business/EinheitenAdder.java
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										50
									
								
								src/tourplaner/business/EinheitenAdder.java
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,50 @@
 | 
				
			|||||||
 | 
					package tourplaner.business;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * Fügt am ende eines Strings die einheiten an
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					public class EinheitenAdder {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /**
 | 
				
			||||||
 | 
					     * Fügt meter hinzu
 | 
				
			||||||
 | 
					     * @param meter Meter als String
 | 
				
			||||||
 | 
					     * @return Meter mit einheit
 | 
				
			||||||
 | 
					     */
 | 
				
			||||||
 | 
					    public static String addMeter(String meter){
 | 
				
			||||||
 | 
					        return meter + " " +ConfigHelper.getIniString(ConfigHelper.getStandartConfig(), "einheiten", "meter");
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public static String addSpeed(String speed){
 | 
				
			||||||
 | 
					        return speed + " " + ConfigHelper.getIniString(ConfigHelper.getStandartConfig(), "einheiten", "speed");
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    
 | 
				
			||||||
 | 
					    /**
 | 
				
			||||||
 | 
					     * Fügt km hinzu
 | 
				
			||||||
 | 
					     * @param km km als String
 | 
				
			||||||
 | 
					     * @return km mit einheit
 | 
				
			||||||
 | 
					     */
 | 
				
			||||||
 | 
					    public static String addKm(String km){
 | 
				
			||||||
 | 
					        return km + " " +ConfigHelper.getIniString(ConfigHelper.getStandartConfig(), "einheiten", "strecke");
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    
 | 
				
			||||||
 | 
					    /**
 | 
				
			||||||
 | 
					     * Fügt minuten hinzu
 | 
				
			||||||
 | 
					     * @param min minuten als String
 | 
				
			||||||
 | 
					     * @return minuten mit einheit
 | 
				
			||||||
 | 
					     */
 | 
				
			||||||
 | 
					    public static String addMinuten(String min){
 | 
				
			||||||
 | 
					        return min + " " +ConfigHelper.getIniString(ConfigHelper.getStandartConfig(), "einheiten", "zeit");
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /**
 | 
				
			||||||
 | 
					     * Fügt am ende .json hinzu. Sofern es nicht schon dort ist
 | 
				
			||||||
 | 
					     * @param filename Filename ohne .json am ende
 | 
				
			||||||
 | 
					     * @return Der Filename mit .json am ende-
 | 
				
			||||||
 | 
					     */
 | 
				
			||||||
 | 
					    public static String addJson(String filename){
 | 
				
			||||||
 | 
					        if(!filename.contains(".json")){
 | 
				
			||||||
 | 
					            filename += ".json";
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        return filename;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -3,7 +3,10 @@ package tourplaner.business;
 | 
				
			|||||||
import tourplaner.data.DbConnect;
 | 
					import tourplaner.data.DbConnect;
 | 
				
			||||||
import tourplaner.object.Log;
 | 
					import tourplaner.object.Log;
 | 
				
			||||||
import tourplaner.object.Tour;
 | 
					import tourplaner.object.Tour;
 | 
				
			||||||
 | 
					import tourplaner.ui.AlertHelper;
 | 
				
			||||||
 | 
					import tourplaner.ui.ProgressBar;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import javax.swing.*;
 | 
				
			||||||
import java.io.*;
 | 
					import java.io.*;
 | 
				
			||||||
import java.util.ArrayList;
 | 
					import java.util.ArrayList;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -28,10 +31,17 @@ public class Exporter {
 | 
				
			|||||||
     * @throws IOException Fehler beim File erstellen
 | 
					     * @throws IOException Fehler beim File erstellen
 | 
				
			||||||
     */
 | 
					     */
 | 
				
			||||||
    public void doExport() throws IOException {
 | 
					    public void doExport() throws IOException {
 | 
				
			||||||
 | 
					        ProgressBar progressBar = new ProgressBar("Export...");
 | 
				
			||||||
 | 
					        int step = progressBar.getProgressSize(4, 100);
 | 
				
			||||||
        ArrayList<Tour> data = new DbConnect().getAllTouren();
 | 
					        ArrayList<Tour> data = new DbConnect().getAllTouren();
 | 
				
			||||||
        FileWriter fileWriter = new FileWriter(path + ".json");
 | 
					
 | 
				
			||||||
 | 
					        progressBar.addProgress(step);
 | 
				
			||||||
 | 
					        FileWriter fileWriter = new FileWriter(EinheitenAdder.addJson(this.path));
 | 
				
			||||||
 | 
					        progressBar.addProgress(step);
 | 
				
			||||||
        JsonHelper.getJsonFromObj(data, fileWriter);
 | 
					        JsonHelper.getJsonFromObj(data, fileWriter);
 | 
				
			||||||
 | 
					        progressBar.addProgress(step);
 | 
				
			||||||
        BufferedWriter bufferedWriter = new BufferedWriter(fileWriter);
 | 
					        BufferedWriter bufferedWriter = new BufferedWriter(fileWriter);
 | 
				
			||||||
 | 
					        progressBar.setProgress(100);
 | 
				
			||||||
        bufferedWriter.close();
 | 
					        bufferedWriter.close();
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -39,17 +49,29 @@ public class Exporter {
 | 
				
			|||||||
     * Führt den Imput aus -> File holen, Daten in db erstellen
 | 
					     * Führt den Imput aus -> File holen, Daten in db erstellen
 | 
				
			||||||
     * @throws IOException Fehler beim File öffnen
 | 
					     * @throws IOException Fehler beim File öffnen
 | 
				
			||||||
     */
 | 
					     */
 | 
				
			||||||
    public void doImport() throws IOException {
 | 
					    public void doImport() {
 | 
				
			||||||
        this.touren = JsonHelper.getTourenFromJson(new FileReader(this.path));
 | 
					        ProgressBar progressBar = new ProgressBar("Import...");
 | 
				
			||||||
        DbConnect dbConnect = new DbConnect();
 | 
					        try {
 | 
				
			||||||
        dbConnect.delAllData();
 | 
					            this.touren = JsonHelper.getTourenFromJson(new FileReader(EinheitenAdder.addJson(this.path)));
 | 
				
			||||||
        for (Tour tour:this.touren) {
 | 
					            DbConnect dbConnect = new DbConnect();
 | 
				
			||||||
            new DirectionMap(tour.getStart(), tour.getZiel(), tour.getName());
 | 
					            dbConnect.delAllData();
 | 
				
			||||||
            dbConnect.addTour(tour);
 | 
					            progressBar.addProgress(5);
 | 
				
			||||||
            ArrayList<Log> logs = tour.getLogs();
 | 
					            int size = progressBar.getProgressSize(this.touren.size() * 3, 100);
 | 
				
			||||||
            for (Log log:logs) {
 | 
					            for (Tour tour:this.touren) {
 | 
				
			||||||
                dbConnect.addLog(tour.getName(), log);
 | 
					                    new DirectionMap(tour.getStart(), tour.getZiel(), tour.getName());
 | 
				
			||||||
 | 
					                progressBar.addProgress(size);
 | 
				
			||||||
 | 
					                dbConnect.addTour(tour);
 | 
				
			||||||
 | 
					                progressBar.addProgress(size);
 | 
				
			||||||
 | 
					                ArrayList<Log> logs = tour.getLogs();
 | 
				
			||||||
 | 
					                for (Log log:logs) {
 | 
				
			||||||
 | 
					                    dbConnect.addLog(tour.getName(), log);
 | 
				
			||||||
 | 
					                }
 | 
				
			||||||
 | 
					                progressBar.addProgress(size);
 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
 | 
					        } catch (IOException e) {
 | 
				
			||||||
 | 
					            LogHelper.error(e);
 | 
				
			||||||
 | 
					            progressBar.setProgress(100);
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
 | 
					        progressBar.setProgress(100);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -3,12 +3,9 @@ package tourplaner.business;
 | 
				
			|||||||
import com.itextpdf.text.*;
 | 
					import com.itextpdf.text.*;
 | 
				
			||||||
import com.itextpdf.text.Font;
 | 
					import com.itextpdf.text.Font;
 | 
				
			||||||
import com.itextpdf.text.Image;
 | 
					import com.itextpdf.text.Image;
 | 
				
			||||||
import tourplaner.data.DbConnect;
 | 
					 | 
				
			||||||
import tourplaner.object.Log;
 | 
					import tourplaner.object.Log;
 | 
				
			||||||
import tourplaner.object.Tour;
 | 
					import tourplaner.object.Tour;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import com.itextpdf.text.pdf.PdfPCell;
 | 
					 | 
				
			||||||
import com.itextpdf.text.pdf.PdfPTable;
 | 
					 | 
				
			||||||
import com.itextpdf.text.pdf.PdfWriter;
 | 
					import com.itextpdf.text.pdf.PdfWriter;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import java.awt.*;
 | 
					import java.awt.*;
 | 
				
			||||||
@@ -53,7 +50,9 @@ public class Reporter {
 | 
				
			|||||||
        } catch (DocumentException | FileNotFoundException e) {
 | 
					        } catch (DocumentException | FileNotFoundException e) {
 | 
				
			||||||
            LogHelper.error(e.getMessage(), e.getClass().getName());
 | 
					            LogHelper.error(e.getMessage(), e.getClass().getName());
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
        FileHelper.openDefault(file);
 | 
					        if(ConfigHelper.getIniInt(ConfigHelper.getStandartConfig(), "settings", "openpdf") == 1) {
 | 
				
			||||||
 | 
					            FileHelper.openDefault(file);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    /**
 | 
					    /**
 | 
				
			||||||
@@ -76,17 +75,17 @@ public class Reporter {
 | 
				
			|||||||
                strecke += log.getStrecke();
 | 
					                strecke += log.getStrecke();
 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
        Anchor anchor = new Anchor("Zusammengefasster Report", catFont);
 | 
					        Anchor anchor = new Anchor(ConfigHelper.getLangIniString("rsummrepo"), catFont);
 | 
				
			||||||
        anchor.setName("Zusammengefasster Report");
 | 
					        anchor.setName(ConfigHelper.getLangIniString("rsummrepo"));
 | 
				
			||||||
        // Second parameter is the number of the chapter
 | 
					        // Second parameter is the number of the chapter
 | 
				
			||||||
        Chapter catPart = new Chapter(new Paragraph(anchor), 1);
 | 
					        Chapter catPart = new Chapter(new Paragraph(anchor), 1);
 | 
				
			||||||
        Paragraph subPara = new Paragraph("Daten", subFont);
 | 
					        Paragraph subPara = new Paragraph(ConfigHelper.getLangIniString("rdaten"), subFont);
 | 
				
			||||||
        Section subCatPart = catPart.addSection(subPara);
 | 
					        Section subCatPart = catPart.addSection(subPara);
 | 
				
			||||||
        subCatPart.add(new Paragraph(ConfigHelper.getLangIniString("reportvon") + System.getProperty("user.name") + ", " + new Date()));
 | 
					        subCatPart.add(new Paragraph(ConfigHelper.getLangIniString("reportvon") + " " + System.getProperty("user.name") + ", " + new Date()));
 | 
				
			||||||
        subCatPart.add(new Paragraph("Gesammte Zeit aller Logs: " + dauer));
 | 
					        subCatPart.add(new Paragraph(EinheitenAdder.addMinuten(ConfigHelper.getLangIniString("rzeitallerlogs") + " " + dauer)));
 | 
				
			||||||
        subCatPart.add(new Paragraph("gesammte Strecke aller Logs: " + strecke));
 | 
					        subCatPart.add(new Paragraph(EinheitenAdder.addKm(ConfigHelper.getLangIniString("rstreckeallerlogs") + " " + strecke)));
 | 
				
			||||||
        subCatPart.add(new Paragraph("Berechnete Zeit aller Logs: " + calDauer));
 | 
					        subCatPart.add(new Paragraph(EinheitenAdder.addMinuten(ConfigHelper.getLangIniString("rcalzeitallerlogs") + " " + calDauer)));
 | 
				
			||||||
        subCatPart.add(new Paragraph("Berechnete Strecke aller Touren: " + calStecke));
 | 
					        subCatPart.add(new Paragraph(EinheitenAdder.addKm(ConfigHelper.getLangIniString("calstreckeallerloggs") + " " + calStecke)));
 | 
				
			||||||
        document.add(catPart);
 | 
					        document.add(catPart);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -109,14 +108,16 @@ public class Reporter {
 | 
				
			|||||||
        } catch (DocumentException | FileNotFoundException e) {
 | 
					        } catch (DocumentException | FileNotFoundException e) {
 | 
				
			||||||
            LogHelper.error(e.getMessage(), e.getClass().getName());
 | 
					            LogHelper.error(e.getMessage(), e.getClass().getName());
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
        FileHelper.openDefault(file);
 | 
					        if(ConfigHelper.getIniInt(ConfigHelper.getStandartConfig(), "settings", "openpdf") == 1) {
 | 
				
			||||||
 | 
					            FileHelper.openDefault(file);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    // iText allows to add metadata to the PDF which can be viewed in your Adobe
 | 
					    // iText allows to add metadata to the PDF which can be viewed in your Adobe
 | 
				
			||||||
    // Reader
 | 
					    // Reader
 | 
				
			||||||
    // under File -> Properties
 | 
					    // under File -> Properties
 | 
				
			||||||
    private static void addMetaData(Document document, Tour tour) {
 | 
					    private static void addMetaData(Document document, Tour tour) {
 | 
				
			||||||
        document.addTitle(ConfigHelper.getLangIniString("tourreportvon") + tour.getName());
 | 
					        document.addTitle(ConfigHelper.getLangIniString("tourreportvon") + " " + tour.getName());
 | 
				
			||||||
        document.addSubject(ConfigHelper.getLangIniString("tourplanervon"));
 | 
					        document.addSubject(ConfigHelper.getLangIniString("tourplanervon"));
 | 
				
			||||||
        document.addKeywords(ConfigHelper.getLangIniString("reportkeywords"));
 | 
					        document.addKeywords(ConfigHelper.getLangIniString("reportkeywords"));
 | 
				
			||||||
        document.addAuthor(ConfigHelper.getLangIniString("tourplaner"));
 | 
					        document.addAuthor(ConfigHelper.getLangIniString("tourplaner"));
 | 
				
			||||||
@@ -138,11 +139,11 @@ public class Reporter {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
        Paragraph subPara = new Paragraph(ConfigHelper.getLangIniString("tour"), subFont);
 | 
					        Paragraph subPara = new Paragraph(ConfigHelper.getLangIniString("tour"), subFont);
 | 
				
			||||||
        Section subCatPart = catPart.addSection(subPara);
 | 
					        Section subCatPart = catPart.addSection(subPara);
 | 
				
			||||||
        subCatPart.add(new Paragraph(ConfigHelper.getLangIniString("reportvon") + System.getProperty("user.name") + ", " + new Date()));
 | 
					        subCatPart.add(new Paragraph(ConfigHelper.getLangIniString("reportvon") + " " + System.getProperty("user.name") + ", " + new Date()));
 | 
				
			||||||
        subCatPart.add(new Paragraph(ConfigHelper.getLangIniString("reportstart") + tour.getStart()));
 | 
					        subCatPart.add(new Paragraph(ConfigHelper.getLangIniString("reportstart") + " " + tour.getStart()));
 | 
				
			||||||
        subCatPart.add(new Paragraph(ConfigHelper.getLangIniString("reportziel") + tour.getZiel()));
 | 
					        subCatPart.add(new Paragraph(ConfigHelper.getLangIniString("reportziel") + " " + tour.getZiel()));
 | 
				
			||||||
        subCatPart.add(new Paragraph(ConfigHelper.getLangIniString("reportdauercal") + tour.getDauer()));
 | 
					        subCatPart.add(new Paragraph(EinheitenAdder.addMinuten(ConfigHelper.getLangIniString("reportdauercal") + " " + tour.getDauer())));
 | 
				
			||||||
        subCatPart.add(new Paragraph(ConfigHelper.getLangIniString("reportstreckecal") + tour.getStrecke()));
 | 
					        subCatPart.add(new Paragraph(EinheitenAdder.addKm(ConfigHelper.getLangIniString("reportstreckecal") + " " + tour.getStrecke())));
 | 
				
			||||||
        Paragraph emptyLine = new Paragraph();
 | 
					        Paragraph emptyLine = new Paragraph();
 | 
				
			||||||
        addEmptyLine(emptyLine, 5);
 | 
					        addEmptyLine(emptyLine, 5);
 | 
				
			||||||
        subCatPart.add(emptyLine);
 | 
					        subCatPart.add(emptyLine);
 | 
				
			||||||
@@ -164,18 +165,18 @@ public class Reporter {
 | 
				
			|||||||
        anchor = new Anchor(ConfigHelper.getLangIniString("logs"), catFont);
 | 
					        anchor = new Anchor(ConfigHelper.getLangIniString("logs"), catFont);
 | 
				
			||||||
        anchor.setName(ConfigHelper.getLangIniString("logs"));
 | 
					        anchor.setName(ConfigHelper.getLangIniString("logs"));
 | 
				
			||||||
        catPart = new Chapter(new Paragraph(anchor), 2);
 | 
					        catPart = new Chapter(new Paragraph(anchor), 2);
 | 
				
			||||||
        catPart.add(new Paragraph(ConfigHelper.getLangIniString("countlog") + logs.size()));
 | 
					        catPart.add(new Paragraph(ConfigHelper.getLangIniString("countlog") + " " + logs.size()));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        for (Log log: logs) {
 | 
					        for (Log log: logs) {
 | 
				
			||||||
            subPara = new Paragraph(ConfigHelper.getLangIniString("logvom") + log.getDatum() , subFont);
 | 
					            subPara = new Paragraph(ConfigHelper.getLangIniString("logvom") + " " + log.getDatum() , subFont);
 | 
				
			||||||
            subCatPart = catPart.addSection(subPara);
 | 
					            subCatPart = catPart.addSection(subPara);
 | 
				
			||||||
            subCatPart.add(new Paragraph(ConfigHelper.getLangIniString("logdauer") + log.getDauer()));
 | 
					            subCatPart.add(new Paragraph(EinheitenAdder.addMinuten(ConfigHelper.getLangIniString("logdauer") + " " + log.getDauer())));
 | 
				
			||||||
            subCatPart.add(new Paragraph(ConfigHelper.getLangIniString("logpause") + log.getPause()));
 | 
					            subCatPart.add(new Paragraph(EinheitenAdder.addMinuten(ConfigHelper.getLangIniString("logpause") + " " + log.getPause())));
 | 
				
			||||||
            subCatPart.add(new Paragraph(ConfigHelper.getLangIniString("loggegangen") + log.getGegangen()));
 | 
					            subCatPart.add(new Paragraph(EinheitenAdder.addMinuten(ConfigHelper.getLangIniString("loggegangen") + " " + log.getGegangen())));
 | 
				
			||||||
            subCatPart.add(new Paragraph(ConfigHelper.getLangIniString("logavg")+ log.getAvgspeed()));
 | 
					            subCatPart.add(new Paragraph(EinheitenAdder.addSpeed(ConfigHelper.getLangIniString("logavg") + " " + log.getAvgspeed())));
 | 
				
			||||||
            subCatPart.add(new Paragraph(ConfigHelper.getLangIniString("logstrecke") + log.getStrecke()));
 | 
					            subCatPart.add(new Paragraph(EinheitenAdder.addKm(ConfigHelper.getLangIniString("logstrecke") + " " + log.getStrecke())));
 | 
				
			||||||
            subCatPart.add(new Paragraph(ConfigHelper.getLangIniString("loghight") + log.getHightmeter()));
 | 
					            subCatPart.add(new Paragraph(EinheitenAdder.addMeter(ConfigHelper.getLangIniString("loghight") + " " + log.getHightmeter())));
 | 
				
			||||||
            subCatPart.add(new Paragraph(ConfigHelper.getLangIniString("logbemerkung") + log.getBemerkung()));
 | 
					            subCatPart.add(new Paragraph(ConfigHelper.getLangIniString("logbemerkung") + " " + log.getBemerkung()));
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
        // now add all this to the document
 | 
					        // now add all this to the document
 | 
				
			||||||
        document.add(catPart);
 | 
					        document.add(catPart);
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -4,6 +4,7 @@ import org.apache.log4j.Logger;
 | 
				
			|||||||
import tourplaner.data.DbConnect;
 | 
					import tourplaner.data.DbConnect;
 | 
				
			||||||
import tourplaner.object.Log;
 | 
					import tourplaner.object.Log;
 | 
				
			||||||
import tourplaner.object.Tour;
 | 
					import tourplaner.object.Tour;
 | 
				
			||||||
 | 
					import tourplaner.ui.ProgressBar;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import java.awt.*;
 | 
					import java.awt.*;
 | 
				
			||||||
import java.io.File;
 | 
					import java.io.File;
 | 
				
			||||||
@@ -39,12 +40,18 @@ public class TourPlaner{
 | 
				
			|||||||
     * @return false bei error
 | 
					     * @return false bei error
 | 
				
			||||||
     */
 | 
					     */
 | 
				
			||||||
    public static boolean editTour(String oldname, Tour tour) throws IOException {
 | 
					    public static boolean editTour(String oldname, Tour tour) throws IOException {
 | 
				
			||||||
 | 
					        ProgressBar progressBar = new ProgressBar("Edit...");
 | 
				
			||||||
 | 
					        int step = progressBar.getProgressSize(3, 100);
 | 
				
			||||||
        FileHelper.delFile(new File(getImagePath(oldname)));
 | 
					        FileHelper.delFile(new File(getImagePath(oldname)));
 | 
				
			||||||
        FileHelper.delFile(new File(getImagePdfPath(oldname)));
 | 
					        FileHelper.delFile(new File(getImagePdfPath(oldname)));
 | 
				
			||||||
 | 
					        progressBar.addProgress(step);
 | 
				
			||||||
        DirectionMap directionMap = new DirectionMap(tour.getStart(), tour.getZiel(), tour.getName());
 | 
					        DirectionMap directionMap = new DirectionMap(tour.getStart(), tour.getZiel(), tour.getName());
 | 
				
			||||||
 | 
					        progressBar.addProgress(step);
 | 
				
			||||||
        tour.setDauer(directionMap.getDauer()+"");
 | 
					        tour.setDauer(directionMap.getDauer()+"");
 | 
				
			||||||
        tour.setStrecke(directionMap.getStrecke());
 | 
					        tour.setStrecke(directionMap.getStrecke());
 | 
				
			||||||
        return new DbConnect().editTour(oldname, tour);
 | 
					        boolean ret = new DbConnect().editTour(oldname, tour);
 | 
				
			||||||
 | 
					        progressBar.setProgress(100);
 | 
				
			||||||
 | 
					        return ret;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    /**
 | 
					    /**
 | 
				
			||||||
@@ -53,20 +60,30 @@ public class TourPlaner{
 | 
				
			|||||||
     * @return false bei error
 | 
					     * @return false bei error
 | 
				
			||||||
     */
 | 
					     */
 | 
				
			||||||
    public static boolean delTour(String tourname){
 | 
					    public static boolean delTour(String tourname){
 | 
				
			||||||
 | 
					        ProgressBar progressBar = new ProgressBar("Del...");
 | 
				
			||||||
 | 
					        int step = progressBar.getProgressSize(3, 100);
 | 
				
			||||||
        FileHelper.delFile(new File(getImagePath(tourname)));
 | 
					        FileHelper.delFile(new File(getImagePath(tourname)));
 | 
				
			||||||
 | 
					        progressBar.addProgress(step);
 | 
				
			||||||
        FileHelper.delFile(new File(getImagePdfPath(tourname)));
 | 
					        FileHelper.delFile(new File(getImagePdfPath(tourname)));
 | 
				
			||||||
        return new DbConnect().delTour(tourname);
 | 
					        progressBar.addProgress(step);
 | 
				
			||||||
 | 
					        boolean ret = new DbConnect().delTour(tourname);
 | 
				
			||||||
 | 
					        progressBar.setProgress(100);
 | 
				
			||||||
 | 
					        return ret;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
    /**
 | 
					    /**
 | 
				
			||||||
     * Fügt eine Tour hinzu
 | 
					     * Fügt eine Tour hinzu
 | 
				
			||||||
     * @param newTour Neue Tour
 | 
					     * @param newTour Neue Tour
 | 
				
			||||||
     * @return false bei error
 | 
					     * @return false bei error
 | 
				
			||||||
     */
 | 
					     */
 | 
				
			||||||
    public static boolean addTour(Tour newTour) throws IOException {
 | 
					    public static boolean addTour(Tour newTour, ProgressBar progressBar) throws IOException {
 | 
				
			||||||
 | 
					        int step = progressBar.getProgressSize(2, 100);
 | 
				
			||||||
        DirectionMap directionMap = new DirectionMap(newTour.getStart(), newTour.getZiel(), newTour.getName());
 | 
					        DirectionMap directionMap = new DirectionMap(newTour.getStart(), newTour.getZiel(), newTour.getName());
 | 
				
			||||||
 | 
					        progressBar.addProgress(step);
 | 
				
			||||||
        newTour.setDauer(directionMap.getDauer()+"");
 | 
					        newTour.setDauer(directionMap.getDauer()+"");
 | 
				
			||||||
        newTour.setStrecke(directionMap.getStrecke());
 | 
					        newTour.setStrecke(directionMap.getStrecke());
 | 
				
			||||||
        return new DbConnect().addTour(newTour);
 | 
					        boolean ret = new DbConnect().addTour(newTour);
 | 
				
			||||||
 | 
					        progressBar.setProgress(100);
 | 
				
			||||||
 | 
					        return ret;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    /**
 | 
					    /**
 | 
				
			||||||
@@ -102,7 +119,9 @@ public class TourPlaner{
 | 
				
			|||||||
     * @param tourname Tourname
 | 
					     * @param tourname Tourname
 | 
				
			||||||
     */
 | 
					     */
 | 
				
			||||||
    public static void openImage(String tourname){
 | 
					    public static void openImage(String tourname){
 | 
				
			||||||
        FileHelper.openDefault(getImagePath(tourname));
 | 
					        if(ConfigHelper.getIniInt(ConfigHelper.getStandartConfig(), "settings", "openmap") == 1) {
 | 
				
			||||||
 | 
					            FileHelper.openDefault(getImagePath(tourname));
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -165,14 +184,18 @@ public class TourPlaner{
 | 
				
			|||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    /**
 | 
					    /**
 | 
				
			||||||
     * Exportiert die Daten
 | 
					     * Sucht alle touren die den gegebenen tournamen enthalten
 | 
				
			||||||
     * @param path Path zu den Daten
 | 
					     * @param tourname Name der zu suchen ist
 | 
				
			||||||
     * @throws IOException Fehler beim schreiben der Daten
 | 
					     * @return Alle touren die auf den Suchterm passen
 | 
				
			||||||
     */
 | 
					     */
 | 
				
			||||||
    public static void exportData(String path) throws IOException {
 | 
					    public static ArrayList<Tour> sucheTour(String tourname){
 | 
				
			||||||
            Exporter exporter = new Exporter(path);
 | 
					        ArrayList<Tour> touren = new ArrayList<>();
 | 
				
			||||||
            exporter.doExport();
 | 
					        getAllTours().forEach(t ->{
 | 
				
			||||||
            FileHelper.openDefault(path);
 | 
					            if(t.getName().contains(tourname)){
 | 
				
			||||||
 | 
					                touren.add(t);
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        });
 | 
				
			||||||
 | 
					        return touren;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,13 +1,13 @@
 | 
				
			|||||||
package tourplaner.data;
 | 
					package tourplaner.data;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import javafx.geometry.Pos;
 | 
					import javafx.geometry.Pos;
 | 
				
			||||||
 | 
					import tourplaner.business.LogHelper;
 | 
				
			||||||
import tourplaner.object.Log;
 | 
					import tourplaner.object.Log;
 | 
				
			||||||
import tourplaner.object.Tour;
 | 
					import tourplaner.object.Tour;
 | 
				
			||||||
 | 
					import tourplaner.ui.AlertHelper;
 | 
				
			||||||
 | 
					import tourplaner.ui.ProgressBar;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import java.sql.Connection;
 | 
					import java.sql.*;
 | 
				
			||||||
import java.sql.Date;
 | 
					 | 
				
			||||||
import java.sql.ResultSet;
 | 
					 | 
				
			||||||
import java.sql.Statement;
 | 
					 | 
				
			||||||
import java.time.LocalDate;
 | 
					import java.time.LocalDate;
 | 
				
			||||||
import java.util.ArrayList;
 | 
					import java.util.ArrayList;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -155,21 +155,38 @@ public class DbConnect {
 | 
				
			|||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    public boolean delLog(String tourname, String id){
 | 
					    public boolean delLog(String tourname, String id){
 | 
				
			||||||
        System.out.println("DELETE FROM public.log WHERE tourname = '"+tourname+"' and id = '"+id+"'");
 | 
					 | 
				
			||||||
        return PostgresHelper.executeUpdate("DELETE FROM public.log WHERE tourname = '"+tourname+"' and id = '"+id+"'");
 | 
					        return PostgresHelper.executeUpdate("DELETE FROM public.log WHERE tourname = '"+tourname+"' and id = '"+id+"'");
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    private int getTourSize() throws SQLException {
 | 
				
			||||||
 | 
					        Connection con = PostgresHelper.con();
 | 
				
			||||||
 | 
					        Statement s = con.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_UPDATABLE);
 | 
				
			||||||
 | 
					        ResultSet rs = s.executeQuery("SELECT COUNT(*) FROM tour;");
 | 
				
			||||||
 | 
					        int size =0;
 | 
				
			||||||
 | 
					        if (rs != null)
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					            rs.last();    // moves cursor to the last row
 | 
				
			||||||
 | 
					            size = rs.getInt("count"); // get row id
 | 
				
			||||||
 | 
					            con.close();
 | 
				
			||||||
 | 
					            return size;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        con.close();
 | 
				
			||||||
 | 
					        return -1;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    /**
 | 
					    /**
 | 
				
			||||||
     * Holt alle Touren aus der Datenbank
 | 
					     * Holt alle Touren aus der Datenbank
 | 
				
			||||||
     * @return Null bei fehler, sonst eine List aus den IDs
 | 
					     * @return Null bei fehler, sonst eine List aus den IDs
 | 
				
			||||||
     */
 | 
					     */
 | 
				
			||||||
    public ArrayList<Tour> getAllTouren(){
 | 
					    public ArrayList<Tour> getAllTouren() {
 | 
				
			||||||
        this.c = PostgresHelper.con();
 | 
					        this.c = PostgresHelper.con();
 | 
				
			||||||
        String tourname, mapjson, start, ziel;
 | 
					        String tourname, mapjson, start, ziel;
 | 
				
			||||||
        double dauer, strecke;
 | 
					        double dauer, strecke;
 | 
				
			||||||
 | 
					 | 
				
			||||||
        ArrayList<Tour> touren = new ArrayList<>();
 | 
					        ArrayList<Tour> touren = new ArrayList<>();
 | 
				
			||||||
 | 
					        ProgressBar progressBar = new ProgressBar("Get...");
 | 
				
			||||||
        try {
 | 
					        try {
 | 
				
			||||||
 | 
					            int tourSize = getTourSize();
 | 
				
			||||||
 | 
					            int step =  progressBar.getProgressSize(tourSize, 100);
 | 
				
			||||||
            stmt = this.c.createStatement();
 | 
					            stmt = this.c.createStatement();
 | 
				
			||||||
            ResultSet rs = stmt.executeQuery("select * from tour;");
 | 
					            ResultSet rs = stmt.executeQuery("select * from tour;");
 | 
				
			||||||
            while (rs.next()) {
 | 
					            while (rs.next()) {
 | 
				
			||||||
@@ -181,16 +198,20 @@ public class DbConnect {
 | 
				
			|||||||
                strecke = rs.getDouble("strecke");
 | 
					                strecke = rs.getDouble("strecke");
 | 
				
			||||||
                if (!tourname.isEmpty()) {
 | 
					                if (!tourname.isEmpty()) {
 | 
				
			||||||
                    touren.add(new Tour(tourname, dauer + "", mapjson, strecke, start, ziel, getLogs(tourname)));
 | 
					                    touren.add(new Tour(tourname, dauer + "", mapjson, strecke, start, ziel, getLogs(tourname)));
 | 
				
			||||||
 | 
					                    progressBar.addProgress(step);
 | 
				
			||||||
                }else {
 | 
					                }else {
 | 
				
			||||||
 | 
					                    progressBar.setProgress(100);
 | 
				
			||||||
                    return null;
 | 
					                    return null;
 | 
				
			||||||
                }
 | 
					                }
 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
 | 
					            progressBar.setProgress(100);
 | 
				
			||||||
            rs.close();
 | 
					            rs.close();
 | 
				
			||||||
            stmt.close();
 | 
					            stmt.close();
 | 
				
			||||||
            this.c.close();
 | 
					            this.c.close();
 | 
				
			||||||
            return touren;
 | 
					            return touren;
 | 
				
			||||||
        } catch (Exception e) {
 | 
					        } catch (Exception e) {
 | 
				
			||||||
            System.err.println(e.getClass().getName() + ": " + e.getMessage());
 | 
					            LogHelper.error(e);
 | 
				
			||||||
 | 
					            progressBar.setProgress(100);
 | 
				
			||||||
            return null;
 | 
					            return null;
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -20,6 +20,9 @@ public class Log {
 | 
				
			|||||||
        this.pause = pause;
 | 
					        this.pause = pause;
 | 
				
			||||||
        this.gegangen = this.dauer - this.pause;
 | 
					        this.gegangen = this.dauer - this.pause;
 | 
				
			||||||
        this.avgspeed = this.strecke / (this.gegangen);
 | 
					        this.avgspeed = this.strecke / (this.gegangen);
 | 
				
			||||||
 | 
					        if(Double.isInfinite(this.avgspeed)){
 | 
				
			||||||
 | 
					            this.avgspeed = -1;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    public String getBemerkung() {
 | 
					    public String getBemerkung() {
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -45,23 +45,30 @@
 | 
				
			|||||||
      <menus>
 | 
					      <menus>
 | 
				
			||||||
        <Menu fx:id="menueFile" mnemonicParsing="false" text="Datei">
 | 
					        <Menu fx:id="menueFile" mnemonicParsing="false" text="Datei">
 | 
				
			||||||
          <items>
 | 
					          <items>
 | 
				
			||||||
 | 
					                  <MenuItem fx:id="reportsummary" mnemonicParsing="false" onAction="#reportSum" text="Report Summary" />
 | 
				
			||||||
 | 
					                  <MenuItem fx:id="tourreport" mnemonicParsing="false" onAction="#tourReport" text="Tour Report" />
 | 
				
			||||||
            <MenuItem fx:id="beendenButton" mnemonicParsing="false" onAction="#quitApp" text="Beenden" />
 | 
					            <MenuItem fx:id="beendenButton" mnemonicParsing="false" onAction="#quitApp" text="Beenden" />
 | 
				
			||||||
          </items>
 | 
					          </items>
 | 
				
			||||||
        </Menu>
 | 
					        </Menu>
 | 
				
			||||||
        <Menu mnemonicParsing="false" text="Bearbeiten">
 | 
					        <Menu fx:id="menuebearbeiten" mnemonicParsing="false" text="Bearbeiten">
 | 
				
			||||||
               <items>
 | 
					               <items>
 | 
				
			||||||
                  <MenuItem mnemonicParsing="false" onAction="#importBtn" text="Import" />
 | 
					                  <MenuItem fx:id="menueimport" mnemonicParsing="false" onAction="#importBtn" text="Import" />
 | 
				
			||||||
                  <MenuItem mnemonicParsing="false" onAction="#exportBtn" text="Export" />
 | 
					                  <MenuItem fx:id="menueexport" mnemonicParsing="false" onAction="#exportBtn" text="Export" />
 | 
				
			||||||
                  <MenuItem mnemonicParsing="false" onAction="#reportSum" text="Report alles" />
 | 
					 | 
				
			||||||
                  <MenuItem mnemonicParsing="false" onAction="#tourReport" text="Tour Report erstellen" />
 | 
					 | 
				
			||||||
               </items>
 | 
					               </items>
 | 
				
			||||||
        </Menu>
 | 
					        </Menu>
 | 
				
			||||||
            <Menu mnemonicParsing="false" text="Optionen">
 | 
					            <Menu fx:id="menueoptionen" mnemonicParsing="false" text="Optionen">
 | 
				
			||||||
               <items>
 | 
					               <items>
 | 
				
			||||||
                  <MenuItem mnemonicParsing="false" onAction="#nimpButton" text="Keine Funktion" />
 | 
					                  <CheckMenuItem fx:id="openmap" mnemonicParsing="false" onAction="#openmapaction" text="Map automatisch öffnen" />
 | 
				
			||||||
 | 
					                  <CheckMenuItem fx:id="openpdf" mnemonicParsing="false" onAction="#openpdfaction" text="Report automatisch öffnen" />
 | 
				
			||||||
 | 
					                  <Menu fx:id="menuesprachen" mnemonicParsing="false" text="Sprache">
 | 
				
			||||||
 | 
					                    <items>
 | 
				
			||||||
 | 
					                        <RadioMenuItem fx:id="langdeutsch" mnemonicParsing="false" onAction="#onlangdeutsch" text="Deutsch" />
 | 
				
			||||||
 | 
					                        <RadioMenuItem fx:id="langenglisch" mnemonicParsing="false" onAction="#onlangenglisch" text="Englisch" />
 | 
				
			||||||
 | 
					                    </items>
 | 
				
			||||||
 | 
					                  </Menu>
 | 
				
			||||||
               </items>
 | 
					               </items>
 | 
				
			||||||
            </Menu>
 | 
					            </Menu>
 | 
				
			||||||
        <Menu mnemonicParsing="false" text="Hilfe">
 | 
					        <Menu fx:id="menuehilfe" mnemonicParsing="false" text="Hilfe">
 | 
				
			||||||
          <items>
 | 
					          <items>
 | 
				
			||||||
            <MenuItem mnemonicParsing="false" onAction="#gitWebBrowser" text="Git Repo" />
 | 
					            <MenuItem mnemonicParsing="false" onAction="#gitWebBrowser" text="Git Repo" />
 | 
				
			||||||
                  <MenuItem mnemonicParsing="false" onAction="#javaDocBrowser" text="JavaDoc" />
 | 
					                  <MenuItem mnemonicParsing="false" onAction="#javaDocBrowser" text="JavaDoc" />
 | 
				
			||||||
@@ -77,7 +84,7 @@
 | 
				
			|||||||
                  <Button fx:id="tourAdd" layoutX="58.0" mnemonicParsing="false" onAction="#addTour" text="+" />
 | 
					                  <Button fx:id="tourAdd" layoutX="58.0" mnemonicParsing="false" onAction="#addTour" text="+" />
 | 
				
			||||||
                  <Label layoutX="14.0" layoutY="4.0" text="Tours" />
 | 
					                  <Label layoutX="14.0" layoutY="4.0" text="Tours" />
 | 
				
			||||||
                  <Button fx:id="tourDel" layoutX="89.0" mnemonicParsing="false" onAction="#delTour" text="-" />
 | 
					                  <Button fx:id="tourDel" layoutX="89.0" mnemonicParsing="false" onAction="#delTour" text="-" />
 | 
				
			||||||
                  <Button layoutX="117.0" mnemonicParsing="false" onAction="#editTourBtn" text="Edit" />
 | 
					                  <Button fx:id="editTourBtn" layoutX="117.0" mnemonicParsing="false" onAction="#editTourBtn" text="Edit" />
 | 
				
			||||||
               </children></AnchorPane>
 | 
					               </children></AnchorPane>
 | 
				
			||||||
            <TextField fx:id="sucheInput" promptText="Suche..." />
 | 
					            <TextField fx:id="sucheInput" promptText="Suche..." />
 | 
				
			||||||
            <Button fx:id="sucheButton" mnemonicParsing="false" onAction="#suche" text="Suchen" />
 | 
					            <Button fx:id="sucheButton" mnemonicParsing="false" onAction="#suche" text="Suchen" />
 | 
				
			||||||
@@ -126,9 +133,9 @@
 | 
				
			|||||||
                                             <children>
 | 
					                                             <children>
 | 
				
			||||||
                                                <TableView fx:id="beschreibungTableView" maxHeight="1.7976931348623157E308" maxWidth="1.7976931348623157E308" AnchorPane.bottomAnchor="0.0" AnchorPane.leftAnchor="0.0" AnchorPane.rightAnchor="0.0" AnchorPane.topAnchor="0.0">
 | 
					                                                <TableView fx:id="beschreibungTableView" maxHeight="1.7976931348623157E308" maxWidth="1.7976931348623157E308" AnchorPane.bottomAnchor="0.0" AnchorPane.leftAnchor="0.0" AnchorPane.rightAnchor="0.0" AnchorPane.topAnchor="0.0">
 | 
				
			||||||
                                                  <columns>
 | 
					                                                  <columns>
 | 
				
			||||||
                                                    <TableColumn fx:id="nameCol" maxWidth="1.7976931348623157E308" minWidth="70.0" prefWidth="-1.0" text="Tourname" />
 | 
					                                                    <TableColumn fx:id="nameCol" minWidth="100.0" prefWidth="-1.0" text="Tourname" />
 | 
				
			||||||
                                                    <TableColumn fx:id="dauerCol" maxWidth="1.7976931348623157E308" minWidth="40.0" prefWidth="-1.0" text="Dauer" />
 | 
					                                                    <TableColumn fx:id="dauerCol" maxWidth="1.7976931348623157E308" minWidth="100.0" prefWidth="-1.0" text="Dauer" />
 | 
				
			||||||
                                                      <TableColumn fx:id="streckeCol" maxWidth="1.7976931348623157E308" minWidth="50.0" prefWidth="-1.0" text="Strecke" />
 | 
					                                                      <TableColumn fx:id="streckeCol" maxWidth="1.7976931348623157E308" minWidth="100.0" prefWidth="-1.0" text="Strecke" />
 | 
				
			||||||
                                                      <TableColumn fx:id="startCol" maxWidth="1.7976931348623157E308" minWidth="100.0" prefWidth="-1.0" text="Startpunk" />
 | 
					                                                      <TableColumn fx:id="startCol" maxWidth="1.7976931348623157E308" minWidth="100.0" prefWidth="-1.0" text="Startpunk" />
 | 
				
			||||||
                                                      <TableColumn fx:id="zielCol" maxWidth="1.7976931348623157E308" minWidth="100.0" prefWidth="-1.0" text="Zielpunkt" />
 | 
					                                                      <TableColumn fx:id="zielCol" maxWidth="1.7976931348623157E308" minWidth="100.0" prefWidth="-1.0" text="Zielpunkt" />
 | 
				
			||||||
                                                  </columns>
 | 
					                                                  </columns>
 | 
				
			||||||
@@ -166,7 +173,7 @@
 | 
				
			|||||||
                                                <Insets />
 | 
					                                                <Insets />
 | 
				
			||||||
                                             </HBox.margin>
 | 
					                                             </HBox.margin>
 | 
				
			||||||
                                          </Button>
 | 
					                                          </Button>
 | 
				
			||||||
                                          <Button mnemonicParsing="false" onAction="#editLogBtn" text="Edit" />
 | 
					                                          <Button fx:id="editBtn" mnemonicParsing="false" onAction="#editLogBtn" text="Edit" />
 | 
				
			||||||
                                       </children>
 | 
					                                       </children>
 | 
				
			||||||
                                       <padding>
 | 
					                                       <padding>
 | 
				
			||||||
                                          <Insets bottom="3.0" left="3.0" right="3.0" top="3.0" />
 | 
					                                          <Insets bottom="3.0" left="3.0" right="3.0" top="3.0" />
 | 
				
			||||||
@@ -178,14 +185,14 @@
 | 
				
			|||||||
                                 <children>
 | 
					                                 <children>
 | 
				
			||||||
                                    <TableView fx:id="logTableView" onMouseClicked="#logItemSelected" AnchorPane.bottomAnchor="0.0" AnchorPane.leftAnchor="0.0" AnchorPane.rightAnchor="0.0" AnchorPane.topAnchor="0.0">
 | 
					                                    <TableView fx:id="logTableView" onMouseClicked="#logItemSelected" AnchorPane.bottomAnchor="0.0" AnchorPane.leftAnchor="0.0" AnchorPane.rightAnchor="0.0" AnchorPane.topAnchor="0.0">
 | 
				
			||||||
                                      <columns>
 | 
					                                      <columns>
 | 
				
			||||||
                                        <TableColumn fx:id="logDatumCol" prefWidth="49.0" text="Datum" />
 | 
					                                        <TableColumn fx:id="logDatumCol" minWidth="-1.0" prefWidth="-1.0" text="Datum" />
 | 
				
			||||||
                                        <TableColumn fx:id="logDauerCol" prefWidth="126.0" text="Dauer" />
 | 
					                                        <TableColumn fx:id="logDauerCol" minWidth="-1.0" prefWidth="-1.0" text="Dauer" />
 | 
				
			||||||
                                          <TableColumn fx:id="logStreckeCol" prefWidth="240.0" text="Entfernung" />
 | 
					                                          <TableColumn fx:id="logStreckeCol" minWidth="-1.0" prefWidth="-1.0" text="Entfernung" />
 | 
				
			||||||
                                          <TableColumn fx:id="logAvgCol" prefWidth="75.0" text="AVG Geschwindigkeit" />
 | 
					                                          <TableColumn fx:id="logAvgCol" minWidth="-1.0" prefWidth="-1.0" text="AVG Geschwindigkeit" />
 | 
				
			||||||
                                          <TableColumn fx:id="logHightCol" prefWidth="75.0" text="Höhenmeter" />
 | 
					                                          <TableColumn fx:id="logHightCol" minWidth="-1.0" prefWidth="75.0" text="Höhenmeter" />
 | 
				
			||||||
                                          <TableColumn fx:id="logPauseCol" prefWidth="75.0" text="Davon Pause" />
 | 
					                                          <TableColumn fx:id="logPauseCol" minWidth="-1.0" prefWidth="-1.0" text="Davon Pause" />
 | 
				
			||||||
                                          <TableColumn fx:id="logGegangenCol" prefWidth="75.0" text="Davon Unterwegs" />
 | 
					                                          <TableColumn fx:id="logGegangenCol" minWidth="-1.0" prefWidth="-1.0" text="Davon Unterwegs" />
 | 
				
			||||||
                                          <TableColumn fx:id="logBemerkungCol" prefWidth="75.0" text="Bemerkung" />
 | 
					                                          <TableColumn fx:id="logBemerkungCol" minWidth="-1.0" prefWidth="-1.0" text="Bemerkung" />
 | 
				
			||||||
                                      </columns>
 | 
					                                      </columns>
 | 
				
			||||||
                                       <columnResizePolicy>
 | 
					                                       <columnResizePolicy>
 | 
				
			||||||
                                          <TableView fx:constant="CONSTRAINED_RESIZE_POLICY" />
 | 
					                                          <TableView fx:constant="CONSTRAINED_RESIZE_POLICY" />
 | 
				
			||||||
@@ -203,7 +210,7 @@
 | 
				
			|||||||
    </SplitPane>
 | 
					    </SplitPane>
 | 
				
			||||||
    <HBox id="HBox" alignment="CENTER_LEFT" spacing="5.0" VBox.vgrow="NEVER">
 | 
					    <HBox id="HBox" alignment="CENTER_LEFT" spacing="5.0" VBox.vgrow="NEVER">
 | 
				
			||||||
      <children>
 | 
					      <children>
 | 
				
			||||||
        <Label maxHeight="1.7976931348623157E308" maxWidth="-1.0" text="Left status" HBox.hgrow="ALWAYS">
 | 
					        <Label maxHeight="1.7976931348623157E308" maxWidth="-1.0" text="Tourplaner" HBox.hgrow="ALWAYS">
 | 
				
			||||||
          <font>
 | 
					          <font>
 | 
				
			||||||
            <Font size="11.0" fx:id="x3" />
 | 
					            <Font size="11.0" fx:id="x3" />
 | 
				
			||||||
          </font>
 | 
					          </font>
 | 
				
			||||||
@@ -212,7 +219,7 @@
 | 
				
			|||||||
          </textFill>
 | 
					          </textFill>
 | 
				
			||||||
        </Label>
 | 
					        </Label>
 | 
				
			||||||
        <AnchorPane prefHeight="-1.0" prefWidth="-1.0" HBox.hgrow="ALWAYS" />
 | 
					        <AnchorPane prefHeight="-1.0" prefWidth="-1.0" HBox.hgrow="ALWAYS" />
 | 
				
			||||||
        <Label font="$x3" maxWidth="-1.0" text="Right status" textFill="$x4" HBox.hgrow="NEVER" />
 | 
					        <Label font="$x3" maxWidth="-1.0" text="Georg Reisinger" textFill="$x4" HBox.hgrow="NEVER" />
 | 
				
			||||||
      </children>
 | 
					      </children>
 | 
				
			||||||
      <padding>
 | 
					      <padding>
 | 
				
			||||||
        <Insets bottom="3.0" left="3.0" right="3.0" top="3.0" />
 | 
					        <Insets bottom="3.0" left="3.0" right="3.0" top="3.0" />
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -10,8 +10,13 @@ import javafx.scene.layout.*;
 | 
				
			|||||||
import javafx.stage.Stage;
 | 
					import javafx.stage.Stage;
 | 
				
			||||||
import javafx.stage.WindowEvent;
 | 
					import javafx.stage.WindowEvent;
 | 
				
			||||||
import tourplaner.business.ConfigHelper;
 | 
					import tourplaner.business.ConfigHelper;
 | 
				
			||||||
 | 
					import tourplaner.business.EinheitenAdder;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import javax.swing.*;
 | 
					import javax.swing.*;
 | 
				
			||||||
 | 
					import javax.swing.border.TitledBorder;
 | 
				
			||||||
 | 
					import javax.swing.event.ChangeEvent;
 | 
				
			||||||
 | 
					import javax.swing.event.ChangeListener;
 | 
				
			||||||
 | 
					import java.awt.*;
 | 
				
			||||||
import java.io.PrintWriter;
 | 
					import java.io.PrintWriter;
 | 
				
			||||||
import java.io.StringWriter;
 | 
					import java.io.StringWriter;
 | 
				
			||||||
import java.time.LocalDate;
 | 
					import java.time.LocalDate;
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										66
									
								
								src/tourplaner/ui/ProgressBar.java
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										66
									
								
								src/tourplaner/ui/ProgressBar.java
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,66 @@
 | 
				
			|||||||
 | 
					package tourplaner.ui;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import javafx.scene.image.Image;
 | 
				
			||||||
 | 
					import tourplaner.business.ConfigHelper;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import javax.imageio.ImageIO;
 | 
				
			||||||
 | 
					import javax.swing.*;
 | 
				
			||||||
 | 
					import javax.swing.border.TitledBorder;
 | 
				
			||||||
 | 
					import java.awt.*;
 | 
				
			||||||
 | 
					import java.awt.image.BufferedImage;
 | 
				
			||||||
 | 
					import java.io.File;
 | 
				
			||||||
 | 
					import java.io.IOException;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					public class ProgressBar {
 | 
				
			||||||
 | 
					    private int status;
 | 
				
			||||||
 | 
					    private JFrame frame;
 | 
				
			||||||
 | 
					    private JProgressBar progressBar;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public ProgressBar(String title){
 | 
				
			||||||
 | 
					        this.frame = new JFrame(title);
 | 
				
			||||||
 | 
					        File pathToFile = new File(ConfigHelper.getIniString(ConfigHelper.getStandartConfig(), "start", "logo"));
 | 
				
			||||||
 | 
					        try {
 | 
				
			||||||
 | 
					            BufferedImage image = ImageIO.read(pathToFile);
 | 
				
			||||||
 | 
					            this.frame.setIconImage(image);
 | 
				
			||||||
 | 
					        } catch (IOException e) {
 | 
				
			||||||
 | 
					            e.printStackTrace();
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        this.frame.setDefaultCloseOperation(JFrame.HIDE_ON_CLOSE);
 | 
				
			||||||
 | 
					        Container content = this.frame.getContentPane();
 | 
				
			||||||
 | 
					        this.progressBar = new JProgressBar();
 | 
				
			||||||
 | 
					        this.progressBar.setValue(0);
 | 
				
			||||||
 | 
					        this.progressBar.setStringPainted(true);
 | 
				
			||||||
 | 
					        TitledBorder border = BorderFactory.createTitledBorder("Laden....");
 | 
				
			||||||
 | 
					        this.progressBar.setBorder(border);
 | 
				
			||||||
 | 
					        content.add(this.progressBar, BorderLayout.NORTH);
 | 
				
			||||||
 | 
					        this.frame.setSize(300, 100);
 | 
				
			||||||
 | 
					        this.frame.setVisible(true);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void addProgress(int add){
 | 
				
			||||||
 | 
					        this.status += add;
 | 
				
			||||||
 | 
					        this.progressBar.setValue(this.status);
 | 
				
			||||||
 | 
					        closeOnFinish();
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    private void closeOnFinish(){
 | 
				
			||||||
 | 
					        if(this.status >= 100){
 | 
				
			||||||
 | 
					            closeProgress();
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setProgress(int set){
 | 
				
			||||||
 | 
					        this.status = set;
 | 
				
			||||||
 | 
					        closeOnFinish();
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void closeProgress(){
 | 
				
			||||||
 | 
					        this.frame.setVisible(false);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public int getProgressSize(int todo, int maxLevel){
 | 
				
			||||||
 | 
					        int steps = (progressBar.getValue() - maxLevel) / todo;
 | 
				
			||||||
 | 
					        if(steps < 0) steps = steps*-1;
 | 
				
			||||||
 | 
					        return steps;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -1,10 +1,10 @@
 | 
				
			|||||||
package tourplaner.ui;
 | 
					package tourplaner.ui;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import javafx.collections.ObservableList;
 | 
					 | 
				
			||||||
import javafx.fxml.FXML;
 | 
					import javafx.fxml.FXML;
 | 
				
			||||||
import javafx.fxml.Initializable;
 | 
					import javafx.fxml.Initializable;
 | 
				
			||||||
import javafx.geometry.Orientation;
 | 
					import javafx.geometry.Orientation;
 | 
				
			||||||
import javafx.scene.control.*;
 | 
					import javafx.scene.control.*;
 | 
				
			||||||
 | 
					import javafx.scene.control.Button;
 | 
				
			||||||
import javafx.scene.control.Label;
 | 
					import javafx.scene.control.Label;
 | 
				
			||||||
import javafx.scene.control.TextField;
 | 
					import javafx.scene.control.TextField;
 | 
				
			||||||
import javafx.scene.control.cell.PropertyValueFactory;
 | 
					import javafx.scene.control.cell.PropertyValueFactory;
 | 
				
			||||||
@@ -12,20 +12,13 @@ import javafx.scene.image.ImageView;
 | 
				
			|||||||
import javafx.scene.input.MouseEvent;
 | 
					import javafx.scene.input.MouseEvent;
 | 
				
			||||||
import tourplaner.business.ConfigHelper;
 | 
					import tourplaner.business.ConfigHelper;
 | 
				
			||||||
import tourplaner.business.LogHelper;
 | 
					import tourplaner.business.LogHelper;
 | 
				
			||||||
import tourplaner.business.TourPlaner;
 | 
					 | 
				
			||||||
import tourplaner.object.Log;
 | 
					import tourplaner.object.Log;
 | 
				
			||||||
import tourplaner.object.Tour;
 | 
					import tourplaner.object.Tour;
 | 
				
			||||||
import tourplaner.viewmodels.ViewModel;
 | 
					import tourplaner.viewmodels.ViewModel;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import java.awt.*;
 | 
					 | 
				
			||||||
import java.io.IOException;
 | 
					import java.io.IOException;
 | 
				
			||||||
import java.net.URI;
 | 
					 | 
				
			||||||
import java.net.URISyntaxException;
 | 
					 | 
				
			||||||
import java.net.URL;
 | 
					import java.net.URL;
 | 
				
			||||||
import java.time.LocalDate;
 | 
					 | 
				
			||||||
import java.util.ResourceBundle;
 | 
					import java.util.ResourceBundle;
 | 
				
			||||||
import java.util.UUID;
 | 
					 | 
				
			||||||
import java.util.concurrent.atomic.AtomicReference;
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
public class TourplanerController implements Initializable {
 | 
					public class TourplanerController implements Initializable {
 | 
				
			||||||
    //VM
 | 
					    //VM
 | 
				
			||||||
@@ -42,6 +35,26 @@ public class TourplanerController implements Initializable {
 | 
				
			|||||||
    //Log -> rechts unten
 | 
					    //Log -> rechts unten
 | 
				
			||||||
    public TableView<Log> logTableView;
 | 
					    public TableView<Log> logTableView;
 | 
				
			||||||
    public TableColumn<Log, String> logDauerCol, logStreckeCol, logDatumCol, logAvgCol, logHightCol, logPauseCol, logGegangenCol, logBemerkungCol;
 | 
					    public TableColumn<Log, String> logDauerCol, logStreckeCol, logDatumCol, logAvgCol, logHightCol, logPauseCol, logGegangenCol, logBemerkungCol;
 | 
				
			||||||
 | 
					    //Menue
 | 
				
			||||||
 | 
					    public CheckMenuItem openmap, openpdf;
 | 
				
			||||||
 | 
					    public RadioMenuItem langenglisch, langdeutsch;
 | 
				
			||||||
 | 
					    private ToggleGroup langgroup;
 | 
				
			||||||
 | 
					    public Menu menueFile, menuebearbeiten, menueoptionen, menuesprachen, menuehilfe;
 | 
				
			||||||
 | 
					    public MenuItem reportsummary, tourreport, beendenButton;
 | 
				
			||||||
 | 
					    //Elemente
 | 
				
			||||||
 | 
					    public Button sucheButton, editBtn, editTourBtn;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @FXML
 | 
				
			||||||
 | 
					    private void onlangenglisch(){
 | 
				
			||||||
 | 
					        ConfigHelper.setIniString(ConfigHelper.getStandartConfig(), "lang", "lang", "langen");
 | 
				
			||||||
 | 
					        langToFxml();
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @FXML
 | 
				
			||||||
 | 
					    private void onlangdeutsch(){
 | 
				
			||||||
 | 
					        ConfigHelper.setIniString(ConfigHelper.getStandartConfig(), "lang", "lang", "langde");
 | 
				
			||||||
 | 
					        langToFxml();
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    @FXML
 | 
					    @FXML
 | 
				
			||||||
    private void tourReport(){
 | 
					    private void tourReport(){
 | 
				
			||||||
@@ -92,18 +105,18 @@ public class TourplanerController implements Initializable {
 | 
				
			|||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    private void syncTour(String selectedItem){
 | 
					    private void syncTour(String selectedItem){
 | 
				
			||||||
        beschreibungTableView.getItems().removeIf(s -> true); //Leert die Table View komplett
 | 
					        beschreibungTableView.getItems().clear(); //Leert die Table View komplett
 | 
				
			||||||
        beschreibungTableView.getItems().add(this.viewModel.getTour(selectedItem));
 | 
					        beschreibungTableView.getItems().add(this.viewModel.getTour(selectedItem));
 | 
				
			||||||
        mapImageView.setImage(this.viewModel.getImage(selectedItem));
 | 
					        mapImageView.setImage(this.viewModel.getImage(selectedItem));
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    private void syncTourNamen(){
 | 
					    private void syncTourNamen(){
 | 
				
			||||||
        TourListView.getItems().removeIf(s -> true);
 | 
					        TourListView.getItems().clear();
 | 
				
			||||||
        TourListView.setItems(this.viewModel.getTourNamen());
 | 
					        TourListView.setItems(this.viewModel.getTourNamen());
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    private void syncLogs(){
 | 
					    private void syncLogs(){
 | 
				
			||||||
        logTableView.getItems().removeIf(s -> true);
 | 
					        logTableView.getItems().clear();
 | 
				
			||||||
        logTableView.setItems(this.viewModel.getLogData());
 | 
					        logTableView.setItems(this.viewModel.getLogData());
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -114,10 +127,13 @@ public class TourplanerController implements Initializable {
 | 
				
			|||||||
     */
 | 
					     */
 | 
				
			||||||
    @FXML
 | 
					    @FXML
 | 
				
			||||||
    private void tourListSelectedItem(MouseEvent mouseEvent){
 | 
					    private void tourListSelectedItem(MouseEvent mouseEvent){
 | 
				
			||||||
 | 
					        ProgressBar progressBar = new ProgressBar("Tour auswählen...");
 | 
				
			||||||
        String selectedItem = TourListView.getSelectionModel().getSelectedItem();
 | 
					        String selectedItem = TourListView.getSelectionModel().getSelectedItem();
 | 
				
			||||||
        this.viewModel.selectTour(selectedItem);
 | 
					        this.viewModel.selectTour(selectedItem);
 | 
				
			||||||
        titleTextView.setText(selectedItem);
 | 
					        titleTextView.setText(selectedItem);
 | 
				
			||||||
 | 
					        progressBar.addProgress(10);
 | 
				
			||||||
        syncTour(selectedItem);
 | 
					        syncTour(selectedItem);
 | 
				
			||||||
 | 
					        progressBar.addProgress(10);
 | 
				
			||||||
        startCol.setCellValueFactory(new PropertyValueFactory<Tour, String>("start"));
 | 
					        startCol.setCellValueFactory(new PropertyValueFactory<Tour, String>("start"));
 | 
				
			||||||
        zielCol.setCellValueFactory(new PropertyValueFactory<Tour, String>("ziel"));
 | 
					        zielCol.setCellValueFactory(new PropertyValueFactory<Tour, String>("ziel"));
 | 
				
			||||||
        dauerCol.setCellValueFactory(new PropertyValueFactory<Tour, String>("dauer"));
 | 
					        dauerCol.setCellValueFactory(new PropertyValueFactory<Tour, String>("dauer"));
 | 
				
			||||||
@@ -126,8 +142,10 @@ public class TourplanerController implements Initializable {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
        //Log anzeigen
 | 
					        //Log anzeigen
 | 
				
			||||||
        logTableView.setPlaceholder(new Label( ConfigHelper.getLangIniString("keinelogsvorhanden")));
 | 
					        logTableView.setPlaceholder(new Label( ConfigHelper.getLangIniString("keinelogsvorhanden")));
 | 
				
			||||||
        logTableView.getItems().removeIf(s -> true);
 | 
					        logTableView.getItems().clear();
 | 
				
			||||||
 | 
					        progressBar.addProgress(10);
 | 
				
			||||||
        logTableView.setItems(this.viewModel.getLogData());
 | 
					        logTableView.setItems(this.viewModel.getLogData());
 | 
				
			||||||
 | 
					        progressBar.addProgress(10);
 | 
				
			||||||
        logDauerCol.setCellValueFactory(new PropertyValueFactory<Log, String>("dauer"));
 | 
					        logDauerCol.setCellValueFactory(new PropertyValueFactory<Log, String>("dauer"));
 | 
				
			||||||
        logStreckeCol.setCellValueFactory(new PropertyValueFactory<Log, String>("strecke"));
 | 
					        logStreckeCol.setCellValueFactory(new PropertyValueFactory<Log, String>("strecke"));
 | 
				
			||||||
        logDatumCol.setCellValueFactory(new PropertyValueFactory<Log, String>("datum"));
 | 
					        logDatumCol.setCellValueFactory(new PropertyValueFactory<Log, String>("datum"));
 | 
				
			||||||
@@ -136,8 +154,16 @@ public class TourplanerController implements Initializable {
 | 
				
			|||||||
        logPauseCol.setCellValueFactory(new PropertyValueFactory<Log, String>("pause"));
 | 
					        logPauseCol.setCellValueFactory(new PropertyValueFactory<Log, String>("pause"));
 | 
				
			||||||
        logGegangenCol.setCellValueFactory(new PropertyValueFactory<Log, String>("gegangen"));
 | 
					        logGegangenCol.setCellValueFactory(new PropertyValueFactory<Log, String>("gegangen"));
 | 
				
			||||||
        logBemerkungCol.setCellValueFactory(new PropertyValueFactory<Log, String>("bemerkung"));
 | 
					        logBemerkungCol.setCellValueFactory(new PropertyValueFactory<Log, String>("bemerkung"));
 | 
				
			||||||
 | 
					        progressBar.addProgress(10);
 | 
				
			||||||
        mapImageView.setImage(this.viewModel.getImage(this.viewModel.getSelectedTour().getName()));
 | 
					        mapImageView.setImage(this.viewModel.getImage(this.viewModel.getSelectedTour().getName()));
 | 
				
			||||||
 | 
					        if(this.viewModel.isSucheAktiv()){
 | 
				
			||||||
 | 
					            this.viewModel.setSucheAktiv(false);
 | 
				
			||||||
 | 
					            progressBar.addProgress(10);
 | 
				
			||||||
 | 
					            syncTourNamen();
 | 
				
			||||||
 | 
					            progressBar.setProgress(100);
 | 
				
			||||||
 | 
					            this.sucheInput.setText("");
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        progressBar.setProgress(100);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    /**
 | 
					    /**
 | 
				
			||||||
@@ -155,8 +181,7 @@ public class TourplanerController implements Initializable {
 | 
				
			|||||||
     */
 | 
					     */
 | 
				
			||||||
    @FXML
 | 
					    @FXML
 | 
				
			||||||
    private void addTour(){
 | 
					    private void addTour(){
 | 
				
			||||||
        this.viewModel.addTour();
 | 
					        if(this.viewModel.addTour()) this.mapImageView.setImage(this.viewModel.getImage(this.viewModel.getSelectedTour().getName()));
 | 
				
			||||||
        this.mapImageView.setImage(this.viewModel.getImage(this.viewModel.getSelectedTour().getName()));
 | 
					 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    /**
 | 
					    /**
 | 
				
			||||||
@@ -165,7 +190,7 @@ public class TourplanerController implements Initializable {
 | 
				
			|||||||
     */
 | 
					     */
 | 
				
			||||||
    @FXML
 | 
					    @FXML
 | 
				
			||||||
    private void delTour(){
 | 
					    private void delTour(){
 | 
				
			||||||
        this.beschreibungTableView.getItems().removeIf(s -> true); //löscht alles aus der tabelle
 | 
					        this.beschreibungTableView.getItems().clear(); //löscht alles aus der tabelle
 | 
				
			||||||
        this.titleTextView.setText(ConfigHelper.getLangIniString("keinetourselected"));
 | 
					        this.titleTextView.setText(ConfigHelper.getLangIniString("keinetourselected"));
 | 
				
			||||||
        this.viewModel.delTour();
 | 
					        this.viewModel.delTour();
 | 
				
			||||||
        logTableView.setPlaceholder(new Label( ConfigHelper.getLangIniString("keinetourselected")));
 | 
					        logTableView.setPlaceholder(new Label( ConfigHelper.getLangIniString("keinetourselected")));
 | 
				
			||||||
@@ -178,7 +203,10 @@ public class TourplanerController implements Initializable {
 | 
				
			|||||||
     */
 | 
					     */
 | 
				
			||||||
    @FXML
 | 
					    @FXML
 | 
				
			||||||
    private void suche(){
 | 
					    private void suche(){
 | 
				
			||||||
 | 
					        ProgressBar progressBar = new ProgressBar("Suche");
 | 
				
			||||||
        this.viewModel.suche(this.sucheInput.getText());
 | 
					        this.viewModel.suche(this.sucheInput.getText());
 | 
				
			||||||
 | 
					        progressBar.addProgress(100);
 | 
				
			||||||
 | 
					        progressBar.closeProgress();
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    /**
 | 
					    /**
 | 
				
			||||||
@@ -218,7 +246,77 @@ public class TourplanerController implements Initializable {
 | 
				
			|||||||
        TourListView.setOrientation(Orientation.VERTICAL);
 | 
					        TourListView.setOrientation(Orientation.VERTICAL);
 | 
				
			||||||
        syncTourNamen();
 | 
					        syncTourNamen();
 | 
				
			||||||
        deselectAll();
 | 
					        deselectAll();
 | 
				
			||||||
 | 
					        if(ConfigHelper.getIniInt(ConfigHelper.getStandartConfig(), "settings", "openpdf") == 1){
 | 
				
			||||||
 | 
					            this.openpdf.setSelected(true);
 | 
				
			||||||
 | 
					        }else {
 | 
				
			||||||
 | 
					            this.openpdf.setSelected(false);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        if(ConfigHelper.getIniInt(ConfigHelper.getStandartConfig(), "settings", "openmap") == 1){
 | 
				
			||||||
 | 
					            this.openmap.setSelected(true);
 | 
				
			||||||
 | 
					        }else {
 | 
				
			||||||
 | 
					            this.openmap.setSelected(false);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        this.langgroup = new ToggleGroup();
 | 
				
			||||||
 | 
					        this.langdeutsch.setToggleGroup(this.langgroup);
 | 
				
			||||||
 | 
					        this.langenglisch.setToggleGroup(this.langgroup);
 | 
				
			||||||
 | 
					        if(ConfigHelper.getIniString(ConfigHelper.getStandartConfig(), "lang", "lang").equals("langde")){
 | 
				
			||||||
 | 
					            this.langdeutsch.setSelected(true);
 | 
				
			||||||
 | 
					            this.langenglisch.setSelected(false);
 | 
				
			||||||
 | 
					        }else if(ConfigHelper.getIniString(ConfigHelper.getStandartConfig(), "lang", "lang").equals("langen")){
 | 
				
			||||||
 | 
					            this.langdeutsch.setSelected(false);
 | 
				
			||||||
 | 
					            this.langenglisch.setSelected(true);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        langToFxml();
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    private void langToFxml(){
 | 
				
			||||||
 | 
					        this.kartenTab.setText(ConfigHelper.getLangIniString("fkarte"));
 | 
				
			||||||
 | 
					        this.beschreibungTab.setText(ConfigHelper.getLangIniString("fbeschreibung"));
 | 
				
			||||||
 | 
					        this.editBtn.setText(ConfigHelper.getLangIniString("fedit"));
 | 
				
			||||||
 | 
					        this.editTourBtn.setText(ConfigHelper.getLangIniString("fedit"));
 | 
				
			||||||
 | 
					        this.nameCol.setText(ConfigHelper.getLangIniString("fname"));
 | 
				
			||||||
 | 
					        this.streckeCol.setText(ConfigHelper.getLangIniString("fstrecke"));
 | 
				
			||||||
 | 
					        this.dauerCol.setText(ConfigHelper.getLangIniString("fdauer"));
 | 
				
			||||||
 | 
					        this.zielCol.setText(ConfigHelper.getLangIniString("fziel"));
 | 
				
			||||||
 | 
					        this.startCol .setText(ConfigHelper.getLangIniString("fstart"));
 | 
				
			||||||
 | 
					        this.logAvgCol.setText(ConfigHelper.getLangIniString("favg"));
 | 
				
			||||||
 | 
					        this.logBemerkungCol.setText(ConfigHelper.getLangIniString("fbemerkung"));
 | 
				
			||||||
 | 
					        this.logDatumCol.setText(ConfigHelper.getLangIniString("fdatum"));
 | 
				
			||||||
 | 
					        this.logDauerCol.setText(ConfigHelper.getLangIniString("fdauer"));
 | 
				
			||||||
 | 
					        this.logGegangenCol.setText(ConfigHelper.getLangIniString("fgegangen"));
 | 
				
			||||||
 | 
					        this.logHightCol.setText(ConfigHelper.getLangIniString("fhight"));
 | 
				
			||||||
 | 
					        this.logPauseCol.setText(ConfigHelper.getLangIniString("fpause"));
 | 
				
			||||||
 | 
					        this.logStreckeCol.setText(ConfigHelper.getLangIniString("fstrecke"));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        this.sucheButton.setText(ConfigHelper.getLangIniString("fsuche"));
 | 
				
			||||||
 | 
					        this.openmap.setText(ConfigHelper.getLangIniString("fopenmapsetting"));
 | 
				
			||||||
 | 
					        this.openpdf.setText(ConfigHelper.getLangIniString("fopenpdfsetting"));
 | 
				
			||||||
 | 
					        this.langenglisch.setText(ConfigHelper.getLangIniString("flangenglisch"));
 | 
				
			||||||
 | 
					        this.langdeutsch.setText(ConfigHelper.getLangIniString("flangdeutsch"));
 | 
				
			||||||
 | 
					        this.menueFile.setText(ConfigHelper.getLangIniString("fdatei"));
 | 
				
			||||||
 | 
					        this.menuebearbeiten.setText(ConfigHelper.getLangIniString("fbearbeiten"));
 | 
				
			||||||
 | 
					        this.menueoptionen.setText(ConfigHelper.getLangIniString("foptionen"));
 | 
				
			||||||
 | 
					        this.menuesprachen.setText(ConfigHelper.getLangIniString("fsprache"));
 | 
				
			||||||
 | 
					        this.menuehilfe.setText(ConfigHelper.getLangIniString("fhilfe"));
 | 
				
			||||||
 | 
					        this.reportsummary.setText(ConfigHelper.getLangIniString("freposum"));
 | 
				
			||||||
 | 
					        this.tourreport.setText(ConfigHelper.getLangIniString("frepotour"));
 | 
				
			||||||
 | 
					        this.beendenButton.setText(ConfigHelper.getLangIniString("fbeenden"));
 | 
				
			||||||
 | 
					        this.sucheInput.setPromptText(ConfigHelper.getLangIniString("fsuche")+ConfigHelper.getLangIniString("fpunkte"));
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @FXML
 | 
				
			||||||
 | 
					    private void openpdfaction(){
 | 
				
			||||||
 | 
					        int selected = 0;
 | 
				
			||||||
 | 
					        if(this.openpdf.isSelected()) selected = 1;
 | 
				
			||||||
 | 
					        ConfigHelper.setIniInt(ConfigHelper.getStandartConfig(), "settings", "openpdf", selected);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @FXML
 | 
				
			||||||
 | 
					    private void openmapaction(){
 | 
				
			||||||
 | 
					        int selected = 0;
 | 
				
			||||||
 | 
					        if(this.openmap.isSelected()) selected = 1;
 | 
				
			||||||
 | 
					        ConfigHelper.setIniInt(ConfigHelper.getStandartConfig(), "settings", "openmap", selected);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    private void deselectAll(){
 | 
					    private void deselectAll(){
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -7,9 +7,9 @@ import tourplaner.business.*;
 | 
				
			|||||||
import tourplaner.ui.AlertHelper;
 | 
					import tourplaner.ui.AlertHelper;
 | 
				
			||||||
import tourplaner.object.Log;
 | 
					import tourplaner.object.Log;
 | 
				
			||||||
import tourplaner.object.Tour;
 | 
					import tourplaner.object.Tour;
 | 
				
			||||||
 | 
					import tourplaner.ui.ProgressBar;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import java.awt.*;
 | 
					import java.awt.*;
 | 
				
			||||||
import java.io.FileNotFoundException;
 | 
					 | 
				
			||||||
import java.io.IOException;
 | 
					import java.io.IOException;
 | 
				
			||||||
import java.net.URI;
 | 
					import java.net.URI;
 | 
				
			||||||
import java.net.URISyntaxException;
 | 
					import java.net.URISyntaxException;
 | 
				
			||||||
@@ -28,7 +28,8 @@ public class ViewModel {
 | 
				
			|||||||
    //Log
 | 
					    //Log
 | 
				
			||||||
    private final ObservableList<Log> logData = FXCollections.observableArrayList();
 | 
					    private final ObservableList<Log> logData = FXCollections.observableArrayList();
 | 
				
			||||||
    private Log selectedLog;
 | 
					    private Log selectedLog;
 | 
				
			||||||
 | 
					// Suche
 | 
				
			||||||
 | 
					    private boolean sucheAktiv;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    public Image getImage(String tourname){
 | 
					    public Image getImage(String tourname){
 | 
				
			||||||
@@ -78,9 +79,10 @@ public class ViewModel {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    /**
 | 
					    /**
 | 
				
			||||||
     * Input mit duplications check des Namens und ohne content im input feld
 | 
					     * Input mit duplications check des Namens und ohne content im input feld
 | 
				
			||||||
 | 
					     * @return false beim schließen
 | 
				
			||||||
     */
 | 
					     */
 | 
				
			||||||
    private void tourNameInput(){
 | 
					    private boolean tourNameInput(){
 | 
				
			||||||
        tourNameInputDuplicatCheck("", true);
 | 
					        return tourNameInputDuplicatCheck("", true);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    /**
 | 
					    /**
 | 
				
			||||||
@@ -151,24 +153,31 @@ public class ViewModel {
 | 
				
			|||||||
    /**
 | 
					    /**
 | 
				
			||||||
     * Fügt eine neue Tour hinzu
 | 
					     * Fügt eine neue Tour hinzu
 | 
				
			||||||
     */
 | 
					     */
 | 
				
			||||||
    public void addTour(){
 | 
					    public boolean addTour(){
 | 
				
			||||||
        tourNameInput();
 | 
					        if(tourNameInput()) {
 | 
				
			||||||
        tourStartInput("");
 | 
					            if(tourStartInput("")) {
 | 
				
			||||||
        tourZielInput("");
 | 
					                if (tourZielInput("")) {
 | 
				
			||||||
        if (getTour(this.neueTourName) == null) {
 | 
					                    if (getTour(this.neueTourName) == null) {
 | 
				
			||||||
            Tour newTour = new Tour(this.neueTourName, "1", "1", 0, this.neueTourStart, this.neueTourZiel);
 | 
					                        ProgressBar progressBar = new ProgressBar("Add Tour...");
 | 
				
			||||||
            tourData.add(newTour);
 | 
					                        Tour newTour = new Tour(this.neueTourName, "1", "1", 0, this.neueTourStart, this.neueTourZiel);
 | 
				
			||||||
            tourNamen.add(this.neueTourName);
 | 
					                        tourData.add(newTour);
 | 
				
			||||||
            this.selectedTour = newTour;
 | 
					                        tourNamen.add(this.neueTourName);
 | 
				
			||||||
            try {
 | 
					                        this.selectedTour = newTour;
 | 
				
			||||||
                TourPlaner.addTour(newTour);
 | 
					                        progressBar.addProgress(10);
 | 
				
			||||||
            } catch (IOException e) {
 | 
					                        try {
 | 
				
			||||||
                e.printStackTrace();
 | 
					                            TourPlaner.addTour(newTour, progressBar);
 | 
				
			||||||
            }
 | 
					                        } catch (IOException e) {
 | 
				
			||||||
        }
 | 
					                            LogHelper.error(e);
 | 
				
			||||||
 | 
					                            return false;
 | 
				
			||||||
 | 
					                        }
 | 
				
			||||||
 | 
					                    }
 | 
				
			||||||
 | 
					                }else return false;
 | 
				
			||||||
 | 
					            }else return false;
 | 
				
			||||||
 | 
					        }else return false;
 | 
				
			||||||
        this.neueTourStart = null;
 | 
					        this.neueTourStart = null;
 | 
				
			||||||
        this.neueTourZiel = null;
 | 
					        this.neueTourZiel = null;
 | 
				
			||||||
        this.neueTourName = null;
 | 
					        this.neueTourName = null;
 | 
				
			||||||
 | 
					        return true;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    private boolean keineTourSelected(){
 | 
					    private boolean keineTourSelected(){
 | 
				
			||||||
@@ -186,48 +195,59 @@ public class ViewModel {
 | 
				
			|||||||
     * Bearbeitet einen gewählten Log eintrag
 | 
					     * Bearbeitet einen gewählten Log eintrag
 | 
				
			||||||
     */
 | 
					     */
 | 
				
			||||||
    public void editLog(){
 | 
					    public void editLog(){
 | 
				
			||||||
        AtomicReference<Tour> tourAkt = new AtomicReference<>();
 | 
					        System.out.println(this.selectedLog);
 | 
				
			||||||
        AtomicReference<Log> logAkt = new AtomicReference<>();
 | 
					        if(this.selectedTour != null) {
 | 
				
			||||||
        this.tourData.forEach(tourd -> {
 | 
					            if(this.selectedLog != null) {
 | 
				
			||||||
            if(tourd.getName().equals(this.selectedTour.getName())) {
 | 
					                AtomicReference<Tour> tourAkt = new AtomicReference<>();
 | 
				
			||||||
                tourd.getLogs().forEach(log -> {
 | 
					                AtomicReference<Log> logAkt = new AtomicReference<>();
 | 
				
			||||||
                    if(this.selectedLog.getId().equals(log.getId())){
 | 
					                this.tourData.forEach(tourd -> {
 | 
				
			||||||
                        logAkt.set(log);
 | 
					                    if (tourd.getName().equals(this.selectedTour.getName())) {
 | 
				
			||||||
                        tourAkt.set(tourd);
 | 
					                        tourd.getLogs().forEach(log -> {
 | 
				
			||||||
 | 
					                            if (this.selectedLog.getId().equals(log.getId())) {
 | 
				
			||||||
 | 
					                                logAkt.set(log);
 | 
				
			||||||
 | 
					                                tourAkt.set(tourd);
 | 
				
			||||||
 | 
					                            }
 | 
				
			||||||
 | 
					                        });
 | 
				
			||||||
                    }
 | 
					                    }
 | 
				
			||||||
                });
 | 
					                });
 | 
				
			||||||
            }
 | 
					                double dauer = dauerInput(this.selectedLog.getDauer());
 | 
				
			||||||
        });
 | 
					                double strecke = -1;
 | 
				
			||||||
        double dauer = dauerInput(this.selectedLog.getDauer());
 | 
					                double pause = -1.0;
 | 
				
			||||||
        double strecke = -1;
 | 
					                double hightmeter = -1.0;
 | 
				
			||||||
        double pause = -1.0;
 | 
					                boolean bemerkung = false;
 | 
				
			||||||
        double hightmeter = -1.0;
 | 
					                LocalDate datum = null;
 | 
				
			||||||
        boolean bemerkung = false;
 | 
					                if (dauer >= 0) {
 | 
				
			||||||
        LocalDate datum = null;
 | 
					                    strecke = streckeInput(this.selectedLog.getStrecke() + "");
 | 
				
			||||||
        if (dauer >= 0) {
 | 
					                    if (strecke >= 0) {
 | 
				
			||||||
            strecke = streckeInput(this.selectedLog.getStrecke() + "");
 | 
					                        pause = pauseInput(this.selectedLog.getPause() + "");
 | 
				
			||||||
            if (strecke >= 0) {
 | 
					                        if (pause >= 0.0) {
 | 
				
			||||||
                pause = pauseInput("");
 | 
					                            hightmeter = hightmeterInput(this.selectedLog.getHightmeter() + "");
 | 
				
			||||||
                if(pause >= 0.0) {
 | 
					                            if (hightmeter >= 0.0) {
 | 
				
			||||||
                    hightmeter = hightmeterInput("");
 | 
					                                bemerkung = bemerkungInput(this.selectedLog.getBemerkung());
 | 
				
			||||||
                    if (hightmeter >= 0.0) {
 | 
					                                if (bemerkung) {
 | 
				
			||||||
                        bemerkung = bemerkungInput("");
 | 
					                                    datum = dateInput(this.selectedLog.getDatum());
 | 
				
			||||||
                        if (bemerkung) {
 | 
					                                    if (datum != null) {
 | 
				
			||||||
                            datum = dateInput(this.selectedLog.getDatum());
 | 
					                                        Log newLog = new Log(this.selectedLog.getId(), dauer, datum, strecke, this.neueBemerkung, hightmeter, pause);
 | 
				
			||||||
                            if (datum != null) {
 | 
					                                        this.logData.removeIf(ld -> ld.getId().equals(this.selectedLog.getId()));
 | 
				
			||||||
                                Log newLog = new Log(this.selectedLog.getId(), dauer, datum, strecke, this.neueBemerkung, hightmeter, pause);
 | 
					                                        this.logData.add(newLog);
 | 
				
			||||||
                                this.logData.removeIf(ld -> ld.getId().equals(this.selectedLog.getId()));
 | 
					 | 
				
			||||||
                                this.logData.add(newLog);
 | 
					 | 
				
			||||||
//                                tourAkt.get().delLog(this.selectedLog.getId());
 | 
					//                                tourAkt.get().delLog(this.selectedLog.getId());
 | 
				
			||||||
//                                tourAkt.get().addLog(newLog);
 | 
					//                                tourAkt.get().addLog(newLog);
 | 
				
			||||||
                                this.tourData.removeIf(td -> td.getName().equals(this.selectedTour.getName()));
 | 
					                                        this.tourData.removeIf(td -> td.getName().equals(this.selectedTour.getName()));
 | 
				
			||||||
                                this.tourData.add(tourAkt.get());
 | 
					                                        this.tourData.add(tourAkt.get());
 | 
				
			||||||
                                TourPlaner.editLog(this.selectedTour.getName(), newLog);
 | 
					                                        TourPlaner.editLog(this.selectedTour.getName(), newLog);
 | 
				
			||||||
 | 
					                                    }
 | 
				
			||||||
 | 
					                                }
 | 
				
			||||||
                            }
 | 
					                            }
 | 
				
			||||||
                        }
 | 
					                        }
 | 
				
			||||||
                    }
 | 
					                    }
 | 
				
			||||||
                }
 | 
					                }
 | 
				
			||||||
 | 
					            }else{
 | 
				
			||||||
 | 
					                //Kein log
 | 
				
			||||||
 | 
					                AlertHelper.warn(ConfigHelper.getLangIniString("achtung"), ConfigHelper.getLangIniString("keinlogselected"), ConfigHelper.getLangIniString("keinlogselectedmsg"));
 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
 | 
					        }else {
 | 
				
			||||||
 | 
					            //Keine Tour
 | 
				
			||||||
 | 
					                AlertHelper.warn(ConfigHelper.getLangIniString("achtung"), ConfigHelper.getLangIniString("keinetourselected"), ConfigHelper.getLangIniString("deltournoselectmsg"));
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
        this.neueBemerkung = null;
 | 
					        this.neueBemerkung = null;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
@@ -397,8 +417,8 @@ public class ViewModel {
 | 
				
			|||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    public ObservableList<Log> getLogData() {
 | 
					    public ObservableList<Log> getLogData() {
 | 
				
			||||||
        logData.removeAll();
 | 
					        logData.removeIf(s -> true);
 | 
				
			||||||
        logData.addAll(TourPlaner.getLogs(this.selectedTour.getName()));
 | 
					        if(this.selectedTour != null) logData.addAll(TourPlaner.getLogs(this.selectedTour.getName()));
 | 
				
			||||||
        return logData;
 | 
					        return logData;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -457,7 +477,7 @@ public class ViewModel {
 | 
				
			|||||||
        getTourData().forEach(s -> {
 | 
					        getTourData().forEach(s -> {
 | 
				
			||||||
            namen.add(s.getName());
 | 
					            namen.add(s.getName());
 | 
				
			||||||
        });
 | 
					        });
 | 
				
			||||||
        tourNamen.removeAll();
 | 
					        tourNamen.clear();
 | 
				
			||||||
        tourNamen.addAll(namen);
 | 
					        tourNamen.addAll(namen);
 | 
				
			||||||
        return tourNamen;
 | 
					        return tourNamen;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
@@ -479,8 +499,11 @@ public class ViewModel {
 | 
				
			|||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    public ObservableList<Tour> getTourData() {
 | 
					    public ObservableList<Tour> getTourData() {
 | 
				
			||||||
        tourData.removeAll();
 | 
					        tourData.clear();
 | 
				
			||||||
        tourData.addAll(TourPlaner.getAllTours());
 | 
					        ArrayList<Tour> touren = TourPlaner.getAllTours();
 | 
				
			||||||
 | 
					        if(touren != null) {
 | 
				
			||||||
 | 
					            tourData.addAll(touren);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
        return tourData;
 | 
					        return tourData;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -488,16 +511,18 @@ public class ViewModel {
 | 
				
			|||||||
     * Entfernt eine Tour anhand der ausgewählten Tour
 | 
					     * Entfernt eine Tour anhand der ausgewählten Tour
 | 
				
			||||||
     */
 | 
					     */
 | 
				
			||||||
    public void delTour(){
 | 
					    public void delTour(){
 | 
				
			||||||
        try {
 | 
					        if (this.selectedTour != null) {
 | 
				
			||||||
            String tourname = this.selectedTour.getName();
 | 
					            String tourname = this.selectedTour.getName();
 | 
				
			||||||
            tourData.removeIf(s -> s.getName().equals(tourname));
 | 
					            try {
 | 
				
			||||||
            tourNamen.removeIf(s -> s.equals(tourname));
 | 
					                tourData.removeIf(s -> s.getName().equals(tourname));
 | 
				
			||||||
            logData.removeIf(s -> true);
 | 
					                tourNamen.removeIf(s -> s.equals(tourname));
 | 
				
			||||||
            setSelectedTour(null);
 | 
					                logData.removeIf(s -> true);
 | 
				
			||||||
            TourPlaner.delTour(tourname);
 | 
					                TourPlaner.delTour(tourname);
 | 
				
			||||||
        }catch (NullPointerException e){
 | 
					                setSelectedTour(null);
 | 
				
			||||||
            LogHelper.error(ConfigHelper.getLangIniString("keinetourselected"),
 | 
					            } catch (NullPointerException e) {
 | 
				
			||||||
                    ConfigHelper.getLangIniString("deltournoselect"));
 | 
					                LogHelper.error(e);
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        }else {
 | 
				
			||||||
            AlertHelper.warn(ConfigHelper.getLangIniString("achtung"),
 | 
					            AlertHelper.warn(ConfigHelper.getLangIniString("achtung"),
 | 
				
			||||||
                    ConfigHelper.getLangIniString("keinetourselected"),
 | 
					                    ConfigHelper.getLangIniString("keinetourselected"),
 | 
				
			||||||
                    ConfigHelper.getLangIniString("deltournoselectmsg"));
 | 
					                    ConfigHelper.getLangIniString("deltournoselectmsg"));
 | 
				
			||||||
@@ -514,7 +539,20 @@ public class ViewModel {
 | 
				
			|||||||
                    ConfigHelper.getLangIniString("suchfeldleer"),
 | 
					                    ConfigHelper.getLangIniString("suchfeldleer"),
 | 
				
			||||||
                    ConfigHelper.getLangIniString("suchtextzuerst"));
 | 
					                    ConfigHelper.getLangIniString("suchtextzuerst"));
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
            // TODO: 19.03.2021 Suchlogik
 | 
					         ArrayList<Tour> result = TourPlaner.sucheTour(sucheInput);
 | 
				
			||||||
 | 
					        tourNamen.clear();
 | 
				
			||||||
 | 
					        for (Tour tour:result) {
 | 
				
			||||||
 | 
					            tourNamen.add(tour.getName());
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        this.sucheAktiv = true;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public boolean isSucheAktiv() {
 | 
				
			||||||
 | 
					        return sucheAktiv;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setSucheAktiv(boolean sucheAktiv) {
 | 
				
			||||||
 | 
					        this.sucheAktiv = sucheAktiv;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    /**
 | 
					    /**
 | 
				
			||||||
@@ -587,7 +625,6 @@ public class ViewModel {
 | 
				
			|||||||
     */
 | 
					     */
 | 
				
			||||||
    public void exportData(){
 | 
					    public void exportData(){
 | 
				
			||||||
        String file = AlertHelper.fileChooser("Exportiere");
 | 
					        String file = AlertHelper.fileChooser("Exportiere");
 | 
				
			||||||
        System.out.println("EXPORT: " + file);
 | 
					 | 
				
			||||||
        if(file != null){
 | 
					        if(file != null){
 | 
				
			||||||
            try {
 | 
					            try {
 | 
				
			||||||
                new Exporter(file).doExport();
 | 
					                new Exporter(file).doExport();
 | 
				
			||||||
@@ -603,15 +640,9 @@ public class ViewModel {
 | 
				
			|||||||
     */
 | 
					     */
 | 
				
			||||||
    public void importData() {
 | 
					    public void importData() {
 | 
				
			||||||
        String file = AlertHelper.fileChooser("Importiere");
 | 
					        String file = AlertHelper.fileChooser("Importiere");
 | 
				
			||||||
        System.out.println("IMPORT: " + file);
 | 
					 | 
				
			||||||
        if (file != null){
 | 
					        if (file != null){
 | 
				
			||||||
            try {
 | 
					            this.tourNamen = FXCollections.observableArrayList();
 | 
				
			||||||
                this.tourNamen = FXCollections.observableArrayList();
 | 
					            new Exporter(file).doImport();
 | 
				
			||||||
                new Exporter(file).doImport();
 | 
					 | 
				
			||||||
            } catch (IOException e) {
 | 
					 | 
				
			||||||
                AlertHelper.error("Error", "Import Error", "Fehler beim Importieren");
 | 
					 | 
				
			||||||
                LogHelper.error(e);
 | 
					 | 
				
			||||||
            }
 | 
					 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user