ComputerKeeper/main.py

111 lines
3.7 KiB
Python
Raw Normal View History

2022-08-19 02:17:43 +00:00
"""This is the main function"""
2022-08-26 02:27:35 +00:00
from copy import deepcopy
2022-08-19 02:17:43 +00:00
import PySimpleGUI as sg
2022-08-26 02:27:35 +00:00
from tinydb import TinyDB, Query
2022-08-19 02:17:43 +00:00
2022-09-30 00:57:22 +00:00
TABLE=None
WINDOW=None
2022-08-19 02:17:43 +00:00
# Define the window's contents
2022-09-09 00:44:20 +00:00
colum_lut = ["Serial Number","Brand","Grade","Name"]
layout = [[sg.Menu([['File', ['Open', 'Save', 'Add Computer','Remove Computer']]])],
2022-09-30 00:57:22 +00:00
[sg.Text("search"), sg.Input(s=(35,))],
[sg.Input(s=(19,)),sg.Input(s=(6,)),sg.Input(s=(6,)),sg.Input(s=(4,))],
[sg.Table([["word","Yes"]],colum_lut,key = "table", enable_events=True)],
2022-08-26 01:10:43 +00:00
[sg.Text("Serial Number")],
2022-08-26 02:27:35 +00:00
[sg.Input(key='Serial Number')],
2022-08-26 01:10:43 +00:00
[sg.Text("Brand")],
2022-08-26 02:27:35 +00:00
[sg.Input(key='Brand')],
2022-08-26 01:10:43 +00:00
[sg.Text("Grade")],
2022-08-26 02:27:35 +00:00
[sg.Input(key='Grade')],
2022-08-26 01:10:43 +00:00
[sg.Text("Name")],
2022-08-26 02:27:35 +00:00
[sg.Input(key='Name')],
[sg.Text(size=(40,1), key='OUTPUT')],
2022-08-26 01:10:43 +00:00
[sg.Button('Check In'), sg.Button('Check Out')]]
2022-08-19 02:17:43 +00:00
2022-08-26 02:27:35 +00:00
add_computer_layout = [[sg.Text("Serial Number")],
2022-09-07 00:23:49 +00:00
[sg.Input(key='Serial Number')],
2022-08-26 02:27:35 +00:00
[sg.Text("Brand")],
[sg.Input(key='Brand')],
[sg.Text("Grade")],
[sg.Input(key='Grade')],
[sg.Text("Name")],
[sg.Input(key='Name')],
[sg.Button('Add Computer'),]]
2022-08-19 02:17:43 +00:00
2022-09-30 00:57:22 +00:00
def double_click(event):
"""
Additional event for double-click on header
event: class event
"""
region = TABLE.identify("region", event.x, event.y)
if region == 'heading': # Only care double-clock on headings
cid = int(TABLE.identify_column(event.x)[1:])-1 # check which column clicked
WINDOW.write_event_value("-TABLE-DOUBLE-CLICK-", cid)
2022-08-19 02:17:43 +00:00
2022-08-26 02:27:35 +00:00
def add_computer():
window = sg.Window('Add Computer', deepcopy(add_computer_layout))
while True:
event, values = window.read()
if event == sg.WINDOW_CLOSED or event == 'Add Computer':
break
# Finish up by removing from the screen
window.close()
return values
2022-08-19 02:17:43 +00:00
def main():
"""Core of ComputerKeeper - The Main Application."""
2022-09-30 00:57:22 +00:00
global TABLE,WINDOW
2022-08-26 02:27:35 +00:00
db= TinyDB("./db.json")
2022-09-07 01:02:03 +00:00
Computer = []
for item in db.all():
The_Device = []
for colum in colum_lut:
The_Device.append(item[colum])
Computer.append(The_Device)
2022-08-19 02:17:43 +00:00
# Create the window
2022-09-07 01:02:03 +00:00
window = sg.Window('Window Title', layout, finalize=True)
2022-09-30 00:57:22 +00:00
WINDOW=window
2022-09-07 01:02:03 +00:00
window["table"].update(Computer)
2022-09-30 00:57:22 +00:00
table = window['table'].Widget
table.bind('<Double-1>', double_click, add='+')
TABLE=table
2022-08-19 02:17:43 +00:00
# Display and interact with the Window using an Event Loop
while True:
event, values = window.read()
# See if user wants to quit or window was closed
if event == sg.WINDOW_CLOSED or event == 'Quit':
break
2022-08-26 02:27:35 +00:00
if event == 'Add Computer':
new_computer = add_computer()
existing_table = window["table"].get()
2022-09-05 01:57:27 +00:00
existing_table.append( list(new_computer.values()))
2022-08-26 02:27:35 +00:00
window["table"].update(existing_table)
2022-09-05 01:57:27 +00:00
db.insert(new_computer)
2022-09-09 00:44:20 +00:00
elif event == 'Remove Computer':
if values["table"]:
existing_table = window["table"].get()
2022-09-26 02:15:15 +00:00
serial = existing_table.pop(values["table"][0])[0]
query = Query()
db.remove(query["Serial Number"] == serial)
2022-09-09 00:44:20 +00:00
window["table"].update(existing_table)
2022-09-30 00:57:22 +00:00
elif event == '-TABLE-DOUBLE-CLICK-':
column = values[event]
print(f'Click on column {column}')
# Sort data on the table by the value of column
# then update window['-TABLE-'].update(values=new_data)
2022-08-19 02:17:43 +00:00
# Finish up by removing from the screen
window.close()
if __name__ == "__main__":
main()