2019-01-22 16:44:14 +00:00
![pysimplegui_logo ](https://user-images.githubusercontent.com/13696193/43165867-fe02e3b2-8f62-11e8-9fd0-cc7c86b11772.png )
2019-01-26 19:44:47 +00:00
![Downloads ](http://pepy.tech/badge/pysimpleguiweb )
2019-01-22 16:44:14 +00:00
2019-01-26 19:44:28 +00:00
![Awesome Meter ](https://img.shields.io/badge/Awesome_meter-10,000-yellow.svg )
2019-01-22 16:44:14 +00:00
![Python Version ](https://img.shields.io/badge/Python-3.x-yellow.svg )
2019-03-15 14:03:43 +00:00
![Python Version ](https://img.shields.io/badge/PySimpleGUIWeb_-0.18.0-orange.svg?longCache=true&style=for-the-badge )
2019-01-22 16:44:14 +00:00
# PySimpleGUIWeb
2019-01-26 19:42:55 +00:00
PySimpleGUI running in your web browser!
2019-01-26 19:44:28 +00:00
Your source code will work on tkinter, Qt, WxPython and now in a browser (thanks to Remi)
2019-01-22 16:44:14 +00:00
2019-02-01 23:17:40 +00:00
Check out [repl.it ](https://repl.it/@PySimpleGUI/PySimpleGUIWeb-Demos ), the new way to run your PySimpleGUI code in a browser!
2019-01-22 16:44:14 +00:00
## Primary PySimpleGUI Documentation
To get instructions on how use PySimpleGUI's APIs, please reference the [main documentation ](http://www.PySimpleGUI.org ).
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.
2019-01-26 19:34:40 +00:00
2019-02-28 16:29:47 +00:00
## 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.
2019-01-22 16:44:14 +00:00
[Announcements of Latest Developments ](https://github.com/MikeTheWatchGuy/PySimpleGUI/issues/142 )
2019-02-28 16:29:47 +00:00
2019-01-22 16:44:14 +00:00
Having trouble? Visit the [GitHub site ](http://www.PySimpleGUI.com ) and log an Issue.
2019-02-28 16:29:47 +00:00
2019-01-22 16:52:45 +00:00
## 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.
2019-01-26 19:42:55 +00:00
## Using PySimpleGUIWeb
2019-01-22 16:52:45 +00:00
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`
2019-01-26 19:42:55 +00:00
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.
2019-01-22 16:52:45 +00:00
## 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
2019-01-26 19:34:40 +00:00
PySimpleGUIWeb runs only on Python 3. Legacy Python (2.7) is not supported.
2019-01-22 16:52:45 +00:00
2019-01-26 19:36:13 +00:00
2019-01-22 16:44:14 +00:00
## What Works
2019-01-23 23:49:05 +00:00
* Text Element
* Input Text Element
* Button Element
2019-01-24 07:38:12 +00:00
* Combobox Element
* Checkbox Element
* Listbox Element
2019-02-01 23:12:28 +00:00
* Spinner Element (sorta... numbers 0 to 100 only now)
* Column Element
2019-02-16 21:52:04 +00:00
* Image Element
2019-03-15 02:29:09 +00:00
* Multiline Input Element
* Multiline Output Element
* Table Element (yes, tables! even if limited)
2019-01-24 07:38:53 +00:00
* Window background color
* Element padding
* Read with timeout
* Read with timeout = 0
2019-02-14 23:50:21 +00:00
* Popup Windows
* Multiple windows
2019-02-16 21:53:36 +00:00
* Update methods for many of the elements (Text is 100% complete), others have some of their parameters working.
2019-01-22 16:44:14 +00:00
2019-01-29 19:59:38 +00:00
# Running online using repl.it
2019-02-01 23:15:33 +00:00
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.
2019-02-01 23:16:08 +00:00
Here is where the iframe is inserted. You may not see the page in some instances (like on GitHub).
Here's your sample program:
2019-01-29 19:59:38 +00:00
< iframe height = "400px" width = "100%" src = "https://repl.it/@PySimpleGUI/PySimpleGUIWeb-Demos?lite=true" scrolling = "no" frameborder = "no" allowtransparency = "true" allowfullscreen = "true" sandbox = "allow-forms allow-pointer-lock allow-popups allow-same-origin allow-scripts allow-modals" > < / iframe >
2019-01-22 16:44:14 +00:00
# Release Notes:
2019-01-23 23:49:05 +00:00
## 0.1.0 PySimpleGUIWeb 22-Jan-2019
2019-01-22 16:44:14 +00:00
* Initial release
* Text Element
* Input Text Element
* Button Element
* Window class
2019-01-23 23:49:05 +00:00
## 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
2019-01-24 07:38:12 +00:00
## 0.3.0 PySimpleGUIWeb 24-Jan-2019
* Checkbox Element
* Combobox Element
* Listbox Element
* Element padding for all elements
2019-01-26 19:34:40 +00:00
## 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
2019-01-24 07:38:12 +00:00
2019-02-01 23:12:28 +00:00
## 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
2019-01-23 23:49:05 +00:00
2019-02-03 16:33:16 +00:00
## 0.6.0 PySimpleGUIWeb 3-Feb-2019
* Changed Remi port to 0 so will always get a new free port
2019-02-04 00:54:00 +00:00
## 0.7.0 PySimpleGUIWeb 3-Feb-2019
* Completed `InputText.Update` method so that more demos can be run
2019-02-12 21:21:36 +00:00
## 0.8.0 PySimpleGUIWeb 8-Feb-2019
* Popup support!
* Support for multiple windows
2019-02-14 23:50:21 +00:00
## 0.9.0 PySimpleGUIWeb 14-Feb-2019
* Support for Window.Hide, Window.UnHide (better multi-window support)
2019-02-16 21:52:04 +00:00
## 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
2019-02-25 19:57:32 +00:00
## 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
2019-02-28 16:29:47 +00:00
## 0.12.0 PySimpleGUIWeb 28-Feb-2019
* Combo.Update now fully functional
2019-02-16 21:52:04 +00:00
2019-02-03 16:33:16 +00:00
2019-03-05 15:54:33 +00:00
## 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.
2019-03-05 16:17:01 +00:00
## 0.15.0 PySimpleGUIWeb 5-Mar-2019
2019-03-05 15:54:33 +00:00
2019-03-05 16:17:01 +00:00
* Made the multiple_instance parameter FALSE by default (was messing up badly with True)
2019-03-05 15:54:33 +00:00
2019-03-15 02:25:01 +00:00
## 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
2019-03-15 14:03:43 +00:00
## 0.18.0 15-Mar-2019
* Hotfix for bug that causes Popups / secondary windows to crash
* Table gets `starting_row_num` parameter
2019-03-15 02:25:01 +00:00
2019-01-22 16:44:14 +00:00
# Design
# Author
Mike B.
# License
GNU Lesser General Public License (LGPL 3) +
# Acknowledgments
2019-01-24 07:38:12 +00:00
<!-- stackedit_data:
2019-02-16 21:53:36 +00:00
eyJoaXN0b3J5IjpbLTExNjY3MTk5MTcsNDc1ODY1Njc2LC0xMD
U3MTAzNjQzLDEyMTMzNTI2MzYsLTExNjA2ODQzMzldfQ==
2019-01-24 07:38:12 +00:00
-->