Merge pull request #3815 from PySimpleGUI/Dev-latest

Dev latest
This commit is contained in:
PySimpleGUI 2021-01-19 13:34:54 -05:00 committed by GitHub
commit 560fa24e1f
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 59 additions and 8 deletions

View File

@ -1,5 +1,5 @@
#!/usr/bin/python3 #!/usr/bin/python3
version = __version__ = "4.34.0 Released 18-Jan-2021" version = __version__ = "4.34.0.1 Unreleased\nSDK Help Expanded to init & update parms"
__version__ = version.split()[0] # For PEP 396 and PEP 345 __version__ = version.split()[0] # For PEP 396 and PEP 345
@ -393,6 +393,7 @@ DEFAULT_SCROLLBAR_COLOR = None
# DEFAULT_PROGRESS_BAR_COLOR = (BLUES[0], BLUES[0]) # a nice green progress bar # DEFAULT_PROGRESS_BAR_COLOR = (BLUES[0], BLUES[0]) # a nice green progress bar
# DEFAULT_PROGRESS_BAR_COLOR = (PURPLES[1],PURPLES[0]) # a nice purple progress bar # DEFAULT_PROGRESS_BAR_COLOR = (PURPLES[1],PURPLES[0]) # a nice purple progress bar
# A transparent button is simply one that matches the background # A transparent button is simply one that matches the background
# TRANSPARENT_BUTTON = 'This constant has been depricated. You must set your button background = background it is on for it to be transparent appearing' # TRANSPARENT_BUTTON = 'This constant has been depricated. You must set your button background = background it is on for it to be transparent appearing'
@ -18128,9 +18129,43 @@ def main_sdk_help():
element_classes = Element.__subclasses__() element_classes = Element.__subclasses__()
element_names = {element.__name__: element for element in element_classes} element_names = {element.__name__: element for element in element_classes}
element_names['Window'] = Window element_names['Window'] = Window
element_classes.append(Window)
element_arg_default_dict, element_arg_default_dict_update = {}, {}
vars3 = [m for m in inspect.getmembers(sys.modules[__name__])] vars3 = [m for m in inspect.getmembers(sys.modules[__name__])]
# layout = [[Text('PySimpleGUI Element Reference', font='Any 12')]]
for element in element_classes:
# Build info about init method
args = inspect.getargspec(element.__init__).args[1:]
defaults = inspect.getargspec(element.__init__).defaults
# print('------------- {element}----------')
# print(args)
# print(defaults)
if len(args) != len(defaults):
diff = len(args) - len(defaults)
defaults = ('NO DEFAULT',)*diff + defaults
args_defaults = []
for i, a in enumerate(args):
args_defaults.append((a, defaults[i]))
element_arg_default_dict[element.__name__] = args_defaults
# Build info about update method
try:
args = inspect.getargspec(element.update).args[1:]
defaults = inspect.getargspec(element.update).defaults
if args is None or defaults is None:
element_arg_default_dict_update[element.__name__] = (('',''),)
continue
if len(args) != len(defaults):
diff = len(args) - len(defaults)
defaults = ('NO DEFAULT',)*diff + defaults
args_defaults = []
for i, a in enumerate(args):
args_defaults.append((a, defaults[i]))
element_arg_default_dict_update[element.__name__] = args_defaults if len(args_defaults) else (('',''),)
except Exception as e:
pass
button_col = Col([[B(e, pad=(0, 0), size=(22, 1), font='Courier 10')] for e in sorted(element_names.keys())]) button_col = Col([[B(e, pad=(0, 0), size=(22, 1), font='Courier 10')] for e in sorted(element_names.keys())])
layout = [vtop([button_col, Multiline(size=(100, 46), key='-ML-', write_only=True, reroute_stdout=True, font='Courier 10')])] layout = [vtop([button_col, Multiline(size=(100, 46), key='-ML-', write_only=True, reroute_stdout=True, font='Courier 10')])]
layout += [[CBox('Summary Only', k='-SUMMARY-')]] layout += [[CBox('Summary Only', k='-SUMMARY-')]]
@ -18146,14 +18181,16 @@ def main_sdk_help():
window['-ML-'].update('') window['-ML-'].update('')
if not values['-SUMMARY-']: if not values['-SUMMARY-']:
elem = element_names[event] elem = element_names[event]
print(help(elem)) ml.print(help(elem))
# print the aliases for the class # print the aliases for the class
print('\n--- Shortcut Aliases for Class ---') ml.print('\n--- Shortcut Aliases for Class ---')
for v in vars3: for v in vars3:
if elem == v[1] and elem.__name__ != v[0]: if elem == v[1] and elem.__name__ != v[0]:
print(v[0]) print(v[0])
ml.print('\n--- Init Parms ---')
else: else:
elem = element_names[event] elem = element_names[event]
element_methods = [m[0] for m in inspect.getmembers(Element, inspect.isfunction) if not m[0].startswith('_') and not m[0][0].isupper()] element_methods = [m[0] for m in inspect.getmembers(Element, inspect.isfunction) if not m[0].startswith('_') and not m[0][0].isupper()]
methods = inspect.getmembers(elem, inspect.isfunction) methods = inspect.getmembers(elem, inspect.isfunction)
methods = [m[0] for m in methods if not m[0].startswith('_') and not m[0][0].isupper()] methods = [m[0] for m in methods if not m[0].startswith('_') and not m[0][0].isupper()]
@ -18162,13 +18199,24 @@ def main_sdk_help():
properties = inspect.getmembers(elem, lambda o: isinstance(o, property)) properties = inspect.getmembers(elem, lambda o: isinstance(o, property))
properties = [p[0] for p in properties if not p[0].startswith('_')] properties = [p[0] for p in properties if not p[0].startswith('_')]
ml.print('Methods', background_color='red', text_color='white') ml.print('--- Methods ---', background_color='red', text_color='white')
ml.print('\n'.join(methods)) ml.print('\n'.join(methods))
ml.print('Properties', background_color='red', text_color='white') ml.print('--- Properties ---', background_color='red', text_color='white')
ml.print('\n'.join(properties)) ml.print('\n'.join(properties))
if issubclass(elem, Element): if issubclass(elem, Element):
ml.print('Methods Unique to This Element', background_color='red', text_color='white') ml.print('Methods Unique to This Element', background_color='red', text_color='white')
ml.print('\n'.join(unique_methods)) ml.print('\n'.join(unique_methods))
ml.print('========== Init Parms ==========', background_color='#FFFF00', text_color='black')
elem_text_name = event
for parm, default in element_arg_default_dict[elem_text_name]:
ml.print('{:18}'.format(parm), end=' = ')
ml.print(default, end = ',\n')
if elem_text_name in element_arg_default_dict_update:
ml.print('========== Update Parms ==========', background_color='#FFFF00', text_color='black')
for parm, default in element_arg_default_dict_update[elem_text_name]:
ml.print('{:18}'.format(parm), end=' = ')
ml.print(default, end = ',\n')
ml.set_vscroll_position(0) # scroll to top of multoline
window.close() window.close()
@ -18500,6 +18548,9 @@ if __name__ == '__main__':
if len(sys.argv) > 1 and sys.argv[1] == 'upgrade': if len(sys.argv) > 1 and sys.argv[1] == 'upgrade':
_upgrade_gui() _upgrade_gui()
exit(0) exit(0)
elif len(sys.argv) > 1 and sys.argv[1] == 'help':
main_sdk_help()
exit(0)
main() main()
exit(0) exit(0)

View File

@ -2758,7 +2758,7 @@ layout = [ [sg.Text('Text area', key='_TEXT_')],
[sg.Input(key='_URL_')], [sg.Input(key='_URL_')],
[sg.Button('Chrome'), sg.Button('Exit')]] [sg.Button('Chrome'), sg.Button('Exit')]]
window = sg.Window('Window Title', layuout) window = sg.Window('Window Title', layout)
while True: # Event Loop while True: # Event Loop
event, values = window.read() event, values = window.read()