PySimpleGUI/DemoPrograms/Demo_Frame_Based_Dashboard.py

86 lines
3.9 KiB
Python
Raw Permalink Normal View History

import PySimpleGUI as sg
"""
Demo - Resizable Dashboard using Frames
This Demo Program looks similar to the one based on the Column Element.
This version has a big difference in how it was implemented and the fact that it can be resized.
It's a good example of how PySimpleGUI evolves, continuously. When the original Column-based demo
was written, none of these techniques such as expansion, were easily programmed.
Dashboard using blocks of information.
Copyright 2021 PySimpleGUI.org
"""
theme_dict = {'BACKGROUND': '#2B475D',
'TEXT': '#FFFFFF',
'INPUT': '#F2EFE8',
'TEXT_INPUT': '#000000',
'SCROLL': '#F2EFE8',
'BUTTON': ('#000000', '#C2D4D8'),
'PROGRESS': ('#FFFFFF', '#C7D5E0'),
'BORDER': 0,'SLIDER_DEPTH': 0, 'PROGRESS_DEPTH': 0}
sg.theme_add_new('Dashboard', theme_dict)
sg.theme('Dashboard')
BORDER_COLOR = '#C7D5E0'
DARK_HEADER_COLOR = '#1B2838'
BPAD_TOP = ((20,20), (20, 10))
BPAD_LEFT = ((20,10), (0, 0))
BPAD_LEFT_INSIDE = (0, (10, 0))
BPAD_RIGHT = ((10,20), (10, 0))
top_banner = [
[sg.Text('Dashboard', font='Any 20', background_color=DARK_HEADER_COLOR, enable_events=True, grab=False), sg.Push(background_color=DARK_HEADER_COLOR),
sg.Text('Wednesday 27 Oct 2021', font='Any 20', background_color=DARK_HEADER_COLOR)],
]
top = [[sg.Push(), sg.Text('Weather Could Go Here', font='Any 20'), sg.Push()],
[sg.T('This Frame has a relief while the others do not')],
[sg.T('This window is resizable (see that sizegrip in the bottom right?)')]]
block_3 = [[sg.Text('Block 3', font='Any 20')],
[sg.Input(), sg.Text('Some Text')],
[sg.T('This frame has element_justification="c"')],
[sg.Button('Go'), sg.Button('Exit')] ]
block_2 = [[sg.Text('Block 2', font='Any 20')],
[sg.T('This is some random text')],
[sg.Image(data=sg.DEFAULT_BASE64_ICON, enable_events=True)] ]
block_4 = [[sg.Text('Block 4', font='Any 20')],
[sg.T('You can move the window by grabbing this block (and the top banner)')],
[sg.T('This block is a Column Element')],
[sg.T('The others are all frames')],
[sg.T('The Frame Element, with a border_width=0\n and no title is just like a Column')],
[sg.T('Frames that have a fixed size \n handle element_justification better than Columns')]]
layout = [
[sg.Frame('', top_banner, pad=(0,0), background_color=DARK_HEADER_COLOR, expand_x=True, border_width=0, grab=True)],
[sg.Frame('', top, size=(920, 100), pad=BPAD_TOP, expand_x=True, relief=sg.RELIEF_GROOVE, border_width=3)],
[sg.Frame('', [[sg.Frame('', block_2, size=(450,150), pad=BPAD_LEFT_INSIDE, border_width=0, expand_x=True, expand_y=True, )],
[sg.Frame('', block_3, size=(450,150), pad=BPAD_LEFT_INSIDE, border_width=0, expand_x=True, expand_y=True, element_justification='c')]],
pad=BPAD_LEFT, background_color=BORDER_COLOR, border_width=0, expand_x=True, expand_y=True),
sg.Column(block_4, size=(450, 320), pad=BPAD_RIGHT, expand_x=True, expand_y=True, grab=True),],[sg.Sizegrip(background_color=BORDER_COLOR)]]
window = sg.Window('Dashboard PySimpleGUI-Style', layout, margins=(0,0), background_color=BORDER_COLOR, no_titlebar=True, resizable=True, right_click_menu=sg.MENU_RIGHT_CLICK_EDITME_VER_LOC_EXIT)
while True: # Event Loop
event, values = window.read()
print(event, values)
if event == sg.WIN_CLOSED or event == 'Exit':
break
elif event == 'Edit Me':
sg.execute_editor(__file__)
elif event == 'Version':
sg.popup_scrolled(sg.get_versions(), keep_on_top=True)
elif event == 'File Location':
sg.popup_scrolled('This Python file is:', __file__)
window.close()