Merge pull request #4 from CMDR-Kiel42/New_buttons_and_update

New buttons and update
This commit is contained in:
CMDR-Kiel42 2019-06-30 21:49:05 +02:00 committed by GitHub
commit 00c70d3871
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 57 additions and 16 deletions

72
load.py
View File

@ -5,29 +5,50 @@ import sys
import csv
import os
from monitor import monitor
import urllib
import json
if sys.platform.startswith('linux'):
import subprocess
this = sys.modules[__name__]
this.plugin_version = "1.1.0"
this.update_available = False
this.next_stop = "No route planned"
this.route = []
this.next_wp_label = "Next waypoint: "
this.parent = None
this.save_route_path = ""
this.offset = 1
def plugin_start(plugin_dir):
# Check for newer versions
url = "https://raw.githubusercontent.com/CMDR-Kiel42/EDMC_SpanshRouter/master/version.json"
response = urllib.urlopen(url)
latest_version = response.read()
if response.code == 200 and this.plugin_version != latest_version:
this.update_available = True
this.save_route_path = os.path.join(plugin_dir, 'route.csv')
try:
# Open the last saved route
with open(this.save_route_path, 'r') as csvfile:
route_reader = csv.reader(csvfile)
this.route = [row[0] for row in route_reader]
i = 0
for row in route_reader:
this.route.append(row)
if row[1] == 'x':
this.offset = i
i+=1
this.next_stop = this.route[1]
this.route[this.offset][1] = ''
this.next_stop = this.route[this.offset][0]
copy_waypoint()
except:
print("No previously saved route.")
@ -35,8 +56,11 @@ def plugin_start(plugin_dir):
def plugin_stop():
if this.route.__len__() != 0:
# Save route for next time
if this.offset < this.route.__len__():
this.route[this.offset][1] = 'x'
with open(this.save_route_path, 'w') as csvfile:
csvfile.write('\n'.join(this.route))
writer = csv.writer(csvfile)
writer.writerows(this.route)
def update_gui():
@ -52,34 +76,39 @@ def copy_waypoint(self=None):
command = subprocess.Popen(["echo", "-n", this.next_stop], stdout=subprocess.PIPE)
subprocess.Popen(["xclip", "-selection", "c"], stdin=command.stdout)
def goto_next_waypoint(self=None):
if this.offset < this.route.__len__():
update_route()
def goto_prev_waypoint(self=None):
if this.offset > 0:
this.offset -= 2 # update_route() starts by incrementing the offset, so we can decrement by 2
update_route()
def new_route(self=None):
filename = filedialog.askopenfilename(filetypes = (("csv files", "*.csv"),)) # show an "Open" dialog box and return the path to the selected file
if filename.__len__() > 0:
this.next_route = filename
with open(filename, 'r') as csvfile:
route_reader = csv.reader(csvfile)
this.route = [row[0] for row in route_reader]
this.route = [[row[0], ''] for row in route_reader]
if monitor.system == this.route[1][0]:
del this.route[1]
# Remove the CSV header
del this.route[0]
this.next_stop = this.route[1]
this.offset = 0
this.next_stop = this.route[1][0]
copy_waypoint()
update_gui()
def update_route():
del(this.route[1])
if this.route.__len__() == 0:
this.next_stop = "No route planned"
if os.path.isfile(this.save_route_path):
os.remove(this.save_route_path)
this.offset += 1
if this.offset >= this.route.__len__():
this.next_stop = "End of the road!"
update_gui()
else:
this.next_stop = this.route[1]
this.next_stop = this.route[this.offset][0]
update_gui()
copy_waypoint(this.parent)
@ -97,13 +126,24 @@ def plugin_app(parent):
this.parent = parent
this.frame = tk.Frame(parent)
this.waypoint_prev_btn = tk.Button(this.frame, text="^")
this.waypoint_btn = tk.Button(this.frame, text=this.next_wp_label + this.next_stop)
this.waypoint_next_btn = tk.Button(this.frame, text="v")
this.upload_route_btn = tk.Button(this.frame, text="Upload new route")
this.waypoint_prev_btn.bind("<ButtonRelease-1>", goto_prev_waypoint)
this.waypoint_btn.bind("<ButtonRelease-1>", copy_waypoint)
this.waypoint_next_btn.bind("<ButtonRelease-1>", goto_next_waypoint)
this.upload_route_btn.bind("<ButtonRelease-1>", new_route)
this.waypoint_prev_btn.pack()
this.waypoint_btn.pack()
this.waypoint_next_btn.pack()
this.upload_route_btn.pack()
if this.update_available:
this.update_lbl = tk.Label(this.frame, text="SpanshRouter update available for download!")
this.update_lbl.pack()
return this.frame

1
version.json Normal file
View File

@ -0,0 +1 @@
1.1.0