PySimpleGUI/PySimpleGUIWeb
MikeTheWatchGuy 03e6310834 Mass update for Window Layout Change 2019-04-11 18:20:26 -04:00
..
Demo Programs Release 0.18.0, Updated Demo Programs 2019-03-15 10:03:43 -04:00
PySimpleGUIWeb.py Mass update for Window Layout Change 2019-04-11 18:20:26 -04:00
readme.md Release 0.21.0 2019-04-10 18:42:05 -04:00

readme.md

pysimplegui_logo

Downloads

Awesome Meter

Python Version

Python Version

PySimpleGUIWeb

PySimpleGUI running in your web browser!

Your source code will work on tkinter, Qt, WxPython and now in a browser (thanks to Remi)

Check out repl.it, the new way to run your PySimpleGUI code in a browser!

Primary PySimpleGUI Documentation

To get instructions on how use PySimpleGUI's APIs, please reference the main documentation. This Readme is for information specific to the Web port of PySimpleGUI.

What is PySimpleGUIWeb?

PySimpleGUIWeb enables you to run your PySimpleGUI programs in your web browser. It utilizes a package called Remi to achieve this amazing package.

Engineering Pre-Release

Be aware you are running a "Pre-Rlease" version of PySimpleGUIWeb. This means sh*t doesn't work in many places. This also means that you get to have fun with the many things that DO work and that are being added to every week.

Announcements of Latest Developments

Having trouble? Visit the GitHub site and log an Issue.

Installation

Installation is quite simple:

pip install pysimpleguiweb

Should this not work, you can copy and paste the file PySimpleGUIWeb.py into your application folder.

Using PySimpleGUIWeb

There are a lot of examples in the PySimpleGUI Cookbook as well as on the GitHub site. At the moment very few will work due to the limited number of features of the 0.1.0 release. It shouldn't be too long before they'll work.

To use PySimpleGUIWeb you need to import it: import PySimpleGUIWeb as sg

From there follow the code examples in the Cookbook and the Demo Programs. The only difference in those programs is the import statement. The remainder of the code should work without modification.

Requirements

PySimpleGUIWeb is based on the Remi project. You will need to install Remi prior to running PySimpleGUIWeb:

pip install remi

You can learn more about Remi on its homepage.

https://github.com/dddomodossola/remi

PySimpleGUIWeb runs only on Python 3. Legacy Python (2.7) is not supported.

What Works

  • Text Element
  • Input Text Element
  • Button Element
  • Combobox Element
  • Checkbox Element
  • Listbox Element
  • Spinner Element (sorta... numbers 0 to 100 only now)
  • Column Element
  • Image Element
  • Multiline Input Element
  • Multiline Output Element
  • Output Element (redirect STDOUT)
  • Table Element (yes, tables! even if limited)
  • Window background color
  • Element padding
  • Read with timeout
  • Read with timeout = 0
  • Popup Windows
  • Multiple windows
  • Update methods for many of the elements (Text is 100% complete), others have some of their parameters working.

Running online using repl.it

This is something truly unique and amazing. You can run your PySimpleGUI code in a web browser on a computer, phone, tablet without having Python installed on that computer. Through the magic of repl.it and Remi you can run PySimpleGUI code anywhere you can run a browser. Not only that, but you can embed these programs into web pages. In fact, this markdown document has one of these programs embedded in it.

Here is where the iframe is inserted. You may not see the page in some instances (like on GitHub).

Here's your sample program:

Release Notes:

0.1.0 PySimpleGUIWeb 22-Jan-2019

  • Initial release
  • Text Element
  • Input Text Element
  • Button Element
  • Window class

0.2.0 PySimpleGUIWeb 23-Jan-2019

Day 2 of development brings fonts, sizes, and colors...

  • For all elements (Text, Input Text, Button):
    • Font family
    • Font size
    • Text Color
    • Background Color
    • Disable
    • Size
  • Button Color
  • Read timeouts (zero, non-zero, None/pend)
  • Window close
  • Window background color

0.3.0 PySimpleGUIWeb 24-Jan-2019

  • Checkbox Element
  • Combobox Element
  • Listbox Element
  • Element padding for all elements

0.4.0 PySimpleGUIWeb 26-Jan-2019

Functioning Elements

  • Text
  • Single line text input
  • Multiline Input
  • Multiline Output
  • Listbox
  • Combobox
  • Checkbox
  • Slider
  • Spinner (numbers only...hardcoded to 0 to 100)

New features

  • Tooltips for all elements (so cool this works)
  • Input Text events
  • Text clicked event
  • Listbox selected event
  • Combobox selected event
  • Checkbox Update
  • Disable parameter for all elements
  • Window.Close shuts down the server
  • Enabled exceptions during packing operation
  • New test harness exercises all element types

0.5.0 PySimpleGUIWeb 1-Feb-2019

  • New default font size. Was Helvetica 10, now Helvetica 15
  • InputText Element single character events working! (Finally)
  • Listbox simple Update (values only)
  • Column Element! New!
  • Column element experimental justification setting doesn't work yet
  • Element background colors now picked up from container, not top level window
  • Autosize Text
  • Autosize Button Text

0.6.0 PySimpleGUIWeb 3-Feb-2019

  • Changed Remi port to 0 so will always get a new free port

0.7.0 PySimpleGUIWeb 3-Feb-2019

  • Completed InputText.Update method so that more demos can be run

0.8.0 PySimpleGUIWeb 8-Feb-2019

  • Popup support!
  • Support for multiple windows

0.9.0 PySimpleGUIWeb 14-Feb-2019

  • Support for Window.Hide, Window.UnHide (better multi-window support)

0.9.1 PySimpleGUIWeb

  • Emergency release due to some code to do scrolling of multiline not being right and sometimes crashed programs

0.10.0 PySimpleGUIWeb 16-Feb-2019

  • Completed Text.Update method. Can now change:
    • Text
    • Font family & size
    • Background color
    • Text Color
    • Visibility
  • Completed Button.Update with exception of images
  • Completed Spin.Update with except of range. This element still pretty crippled
  • Completed Slider.Update - Can update value, visibility, disabled, but not the range
  • Image Element!
  • Events for Image Element
  • Image.Update to change image

0.11.0 PySimpleGUIWeb 25-Feb-2019

  • Slider - Can update range using .Update method
  • NEW Window paramters that allow control over all Remi startup settings
  • New Window paramters and default values:
    • web_debug=False
    • web_ip='0.0.0.0'
    • web_port=0
    • web_start_broswer=True
    • web_update_interval=.00001
  • Can set the Window backaground image (sorta works sometimes)
    • Struggling to get the "resources" settings understood so can work with files
    • I have a ways to go

0.12.0 PySimpleGUIWeb 28-Feb-2019

  • Combo.Update now fully functional

0.13.0 PySimpleGUIWeb 5-Mar-2019

  • Added new parameter to Window - web_multiple_instance
    • Like other Window web parameters, this value is passsed Remi upon start
    • The default value is TRUE (Previously I think default was False by Remi)
    • Was made as a result of comment on repl.it.

0.15.0 PySimpleGUIWeb 5-Mar-2019

  • Made the multiple_instance parameter FALSE by default (was messing up badly with True)

0.16.0 13-Mar-2019

  • TABLES!
    • The bare minimum, basic tables are supported
    • Things like alternating colors are not done
    • Enabling Events DOES work so that you can get immediate clicks
    • Value returned is a list of 1ength 1 and contains the value of the cell that was clicked
  • Removed use of CloseButton from Popups

0.17.0 14-Mar-2019

  • More Table features supported
    • Option to display row numbers
    • New parameter row_header_text
    • Can turn on / off displaying row numbers
    • enable_events
    • text_color
    • Font
    • Can get the value of the item clicked using Table.SelectedItem. Can be coded as window.Element('table').SelectedItem

0.18.0 15-Mar-2019

  • Hotfix for bug that causes Popups / secondary windows to crash
  • Table gets starting_row_num parameter

0.19.0 23-Mar-2019 PySimpleGUIWeb

  • do_not_clear defaults to TRUE! for Input and Multiline Input/output
  • a few type hints

0.20.0 07-Apr-2019 PySimpleGUIWeb

  • Output Element WORKS!! Can re-route stdout to window
  • Added Idle function to Remi MyApp for stdout re-route (thanks Davide!!)
  • New Shortcuts:
    • I = InputText
    • B = Btn = Butt = Button
  • Removed temp size in Multiline setup
  • Button - convert button text passed in into a string
  • Added support for base64 Images in Image.Update but it's not working! Don't use!
  • Changed web_update_interval=.0000001 from 0 (YIKES I HOPE SOMETHING DIDN'T BREAK!)

0.21.0 10-Apr-2019 PySimpleGUIWeb

  • If disable_close parameter set in Window call, then Remi will not disconnect when browser closed. Great for reconnecting.

Design

Author

Mike B.

License

GNU Lesser General Public License (LGPL 3) +

Acknowledgments