add change user config and export full log
This commit is contained in:
		
							parent
							
								
									41bc71c75c
								
							
						
					
					
						commit
						161e6d398f
					
				| @ -15,6 +15,34 @@ db = {} | ||||
| db["users"] = {} | ||||
| db["logs"] = {} | ||||
| 
 | ||||
| ## define FG colours | ||||
| DBLK = "|00" | ||||
| DBLU = "|01" | ||||
| DGRN = "|02" | ||||
| DCYN = "|03" | ||||
| DRED = "|04" | ||||
| DMAG = "|05" | ||||
| DYEL = "|06" | ||||
| DGRY = "|07" | ||||
| LBLK = "|08" | ||||
| LBLU = "|09" | ||||
| LGRN = "|10" | ||||
| LCYN = "|11" | ||||
| LRED = "|12" | ||||
| LMAG = "|13" | ||||
| LYEL = "|14" | ||||
| LGRY = "|15" | ||||
| 
 | ||||
| ## define BG colours | ||||
| BBLK = "|16" | ||||
| BBLU = "|17" | ||||
| BGRE = "|18" | ||||
| BCYN = "|19" | ||||
| BRED = "|20" | ||||
| BMAG = "|21" | ||||
| BBRN = "|22" | ||||
| BGRY = "|23" | ||||
| 
 | ||||
| def initScreen() : | ||||
|   writeln("|CL|07") | ||||
| 
 | ||||
| @ -52,7 +80,7 @@ def showTitle(): | ||||
| def init(): | ||||
|   write('|CL') | ||||
|   showTitle() | ||||
|   writeln("="*79) | ||||
|   writeln(" "+"="*78) | ||||
| 
 | ||||
| def mainMenu(): | ||||
|   init() | ||||
| @ -60,9 +88,10 @@ def mainMenu(): | ||||
|   opts = { | ||||
|     '1': 'View your logbook entries', | ||||
|     '2': 'Add a logbook entry', | ||||
|     '3': 'Edit a logbook entry', | ||||
|     '4': 'Delete a logbook entry', | ||||
|     'X': 'Quit back to the BBS' | ||||
|     '3': 'Delete a logbook entry', | ||||
|     'C': 'Change your user config', | ||||
|     'X': 'Export/Download your entire log (CSV)', | ||||
|     'Q': 'Quit back to the BBS' | ||||
|   } | ||||
|    | ||||
|   writeln("") | ||||
| @ -78,44 +107,68 @@ def mainMenu(): | ||||
|   #writeln(str(cfg)) | ||||
|   write(ind + "|15Choose: ") | ||||
| 
 | ||||
|   ch = onekey(chr(13) + '1234X', False) | ||||
|   ch = onekey(chr(13) + '123CXQ', False) | ||||
|   write("|CR") | ||||
| 
 | ||||
|   if ch == 'X': | ||||
|   if ch == 'Q': | ||||
|     finished = "yes" | ||||
|   if ch == '1': | ||||
|     viewLogBook() | ||||
|   if ch == '2': | ||||
|     addLogBook() | ||||
|   if ch == '3': | ||||
|     editLogBook() | ||||
|   if ch == '4': | ||||
|     delLogBook() | ||||
|   if ch == 'C': | ||||
|     checkConfig("RESET") | ||||
|   if ch == 'X': | ||||
|     exportLogBook() | ||||
|   if ch == 'Y': | ||||
|     exportScoreboard() | ||||
| 
 | ||||
|   return finished | ||||
| 
 | ||||
| def isNull() : | ||||
|   writeln("|04No input|13. |12Aborted|07|CR|PA") | ||||
|   return False | ||||
| 
 | ||||
| def addLogBook() : | ||||
|   global db | ||||
|   global handle | ||||
|   #writeln(str(db)) | ||||
|   #writeln("|PA") | ||||
|   ts = calendar.timegm(time.gmtime()) | ||||
|   now = datetime.now().strftime('%Y%m%d%H%M%S') | ||||
|   now = datetime.now().strftime('%Y-%m-%d %H:%M') | ||||
|   writeln("|CL") | ||||
|   write("Enter the date for this log entry (YYYYMMDDHHMMSS): ") | ||||
|   getDate = getstr(10,14,14,now) | ||||
| 
 | ||||
|   write("Enter the date for this log entry (YYYY-MM-DD HH:MM): ") | ||||
|   getDate = getstr(1,16,16,now) | ||||
|   if not getDate : | ||||
|     return isNull() | ||||
| 
 | ||||
|   write("Enter the call-sign of the person you made contact with: ") | ||||
|   getCall = getstr(2,10,10,"") | ||||
|   getCall = getstr(2,10,10,db["users"][handle]["callsign"]) | ||||
|   if not getCall : | ||||
|     return isNull() | ||||
| 
 | ||||
|   write("Enter the observed signal IN from "+getCall+" (0=poor to 5=excellent): ") | ||||
|   getInSig = getstr(10,1,1,"") | ||||
|   if not getInSig : | ||||
|     return isNull() | ||||
| 
 | ||||
|   write("Enter the reported signal OUT to "+getCall+" (0=poor to 5=excellent): ") | ||||
|   getOutSig = getstr(10,1,1,"") | ||||
|   if not getOutSig : | ||||
|     return isNull() | ||||
| 
 | ||||
|   write("Enter "+getCall+"'s full name is it was given: ") | ||||
|   getName = getstr(3,20,20,"") | ||||
|   if not getName : | ||||
|     return isNull() | ||||
| 
 | ||||
|   write("Enter any notes for this contact: ") | ||||
|   getNotes = getstr(1,40,255,"") | ||||
|   if not getNotes : | ||||
|     return isNull() | ||||
| 
 | ||||
|   writeln("|CLHere's what you put:") | ||||
|   writeln("") | ||||
| @ -145,29 +198,34 @@ def addLogBook() : | ||||
|   if ch == 'N' : | ||||
|     writeln("Aborted") | ||||
|     writeln("|PA") | ||||
|    | ||||
| 
 | ||||
| def editLogBook() : | ||||
|   pass | ||||
| 
 | ||||
| def delLogBook() : | ||||
|   global db | ||||
|   global handle | ||||
|   writeln("|CL") | ||||
|   found = False | ||||
|   for LOG in sorted(db["logs"], reverse=True) : | ||||
|     if db["logs"][LOG]["reportedBy"] == handle : | ||||
|       found = True | ||||
|       writeln(LOG+" ") | ||||
|   write("|CREnter the date of the entry to delete: ") | ||||
|   getDate = getstr(10,15,15,"") | ||||
|   if getDate : | ||||
|     if getDate in db["logs"] : | ||||
|       del db["logs"][getDate] | ||||
|       saveDB() | ||||
|       writeln("Deleted: "+getDate) | ||||
|       writeln("|PA") | ||||
|     else : | ||||
|        writeln("No log entry with that date, please check and try again.") | ||||
|        writeln("|PA") | ||||
|   if found : | ||||
|     writeln("|CL") | ||||
|     write("|CREnter the date of the entry to delete: ") | ||||
|     getDate = getstr(1,16,16,"") | ||||
|     if getDate : | ||||
|       if getDate in db["logs"] : | ||||
|         del db["logs"][getDate] | ||||
|         saveDB() | ||||
|         writeln("Deleted: "+getDate) | ||||
|         writeln("|PA") | ||||
|       else : | ||||
|          writeln("No log entry with that date, please check and try again.") | ||||
|          writeln("|PA") | ||||
|   else: | ||||
|     writeln("") | ||||
|     writeln("No records to delete. Aborted.".center(71)) | ||||
|     gotoxy(1,23) | ||||
|     writeln("|PA") | ||||
| 
 | ||||
| 
 | ||||
| def viewLogBook() : | ||||
| @ -175,13 +233,19 @@ def viewLogBook() : | ||||
|   global handle | ||||
| 
 | ||||
|   found = False | ||||
|   num = 0 | ||||
| 
 | ||||
|   writeln("|CL|CR") | ||||
|   writeln(" "+"Date".ljust(15)+"Callsign".ljust(10)+"Name".ljust(22)+"Sig IN".ljust(8)+"Sig OUT".ljust(8)+"Notes".ljust(15)) | ||||
|   writeln(" "+"="*78) | ||||
|   writeln(" "+LCYN+"Date".ljust(20)+LGRN+"Callsign".ljust(10)+LYEL+"Name".ljust(20)+LBLU+"Sig IN".ljust(8)+LMAG+"Sig OUT".ljust(8)+LGRY+"Notes".ljust(12)) | ||||
|   writeln(" "+LBLK+"="*78+DGRY) | ||||
|   for LOG in sorted(db["logs"], reverse=True) : | ||||
|     if db["logs"][LOG]["reportedBy"] == handle : | ||||
|       found = True | ||||
|       num += 1 | ||||
|       if num % 2 == 0 : | ||||
|         BG = BBLU | ||||
|       else : | ||||
|         BG = BBLK | ||||
|       contactCall = str(db["logs"][LOG]["contactCall"]) | ||||
|       observedSig = str(db["logs"][LOG]["observedSig"]) | ||||
|       yourSig = str(db["logs"][LOG]["yourSig"]) | ||||
| @ -193,14 +257,46 @@ def viewLogBook() : | ||||
|       else : | ||||
|         notesAvailable = "N/A" | ||||
| 
 | ||||
|       writeln(" "+LOG.ljust(15)+contactCall.ljust(10)+theirName.ljust(22)+observedSig.center(8)+yourSig.center(8)+notesAvailable.ljust(15)) | ||||
|       writeln(BG+" "+LCYN+LOG.ljust(20)+LGRN+contactCall.ljust(10)+LYEL+theirName.ljust(20)+LBLU+observedSig.center(8)+LMAG+yourSig.center(8)+LGRY+notesAvailable.ljust(12)+BBLK) | ||||
|   writeln("") | ||||
|   #writeln(str(db["logs"])) | ||||
|   if not found : | ||||
|     writeln("No log entries added yet") | ||||
|     writeln(" No log entries added yet|CR") | ||||
|   gotoxy(1,23) | ||||
|   writeln("|PA")     | ||||
| 
 | ||||
| def checkConfig() : | ||||
| def exportLogBook() : | ||||
|   global db | ||||
|   global handle | ||||
| 
 | ||||
|   callsign = db["users"][handle]["callsign"] | ||||
|   tempFile = script_path+"/"+"mL-ham_logbook_"+callsign.lower()+".csv" | ||||
|   fHandle = open(tempFile, "a") | ||||
|   fHandle.write("Date,Callsign,Name,Sig IN,Sig OUT,Notes\n") | ||||
|   found = False | ||||
| 
 | ||||
|   for LOG in sorted(db["logs"], reverse=False) : | ||||
|     if db["logs"][LOG]["reportedBy"] == handle : | ||||
|       found = True | ||||
|       contactCall = str(db["logs"][LOG]["contactCall"]) | ||||
|       observedSig = str(db["logs"][LOG]["observedSig"]) | ||||
|       yourSig = str(db["logs"][LOG]["yourSig"]) | ||||
|       theirName = str(db["logs"][LOG]["theirName"]) | ||||
|       notes = str(db["logs"][LOG]["notes"]) | ||||
|       fHandle.write(LOG+","+contactCall+","+observedSig+","+yourSig+","+theirName+","+notes+"\n") | ||||
|   fHandle.close() | ||||
|   menucmd('F3',tempFile) | ||||
|   os.remove(tempFile) | ||||
|   writeln("File exported") | ||||
|   writeln("|PA")    | ||||
|        | ||||
| 
 | ||||
| def checkConfig(S = None) : | ||||
|   if S : | ||||
|     if S.upper() == "RESET" : | ||||
|       if handle in db["users"] : | ||||
|         del db["users"][handle] | ||||
| 
 | ||||
|   if handle not in db["users"] : | ||||
|     db["users"][handle] = {} | ||||
|     isok = False | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 MeaTLoTioN
						MeaTLoTioN