GUI library for browser-based desktop applications
Project description
WDOM is a python GUI library for browser-based desktop applications. WDOM controls HTML elements (DOM) on browser from python, as if it is a GUI element. APIs are same as DOM or browser JavaScript, but of course, you can write logic codes in python.
This library includes web-server (tornado/aiohttp), but is not intended to be used as a web framework, please use for Desktop GUI Applications.
Disclaimer
WDOM is in the early development stage, and may contain many bugs. All APIs are not stable, and may be changed in future release.
Features
Pure python implementation
APIs based on DOM specification
Not need to learn new special classes/methods for GUI
Implemented DOM features are listed in Wiki page
Theming with CSS frameworks (see ScreenShots on Wiki)
JavaScript codes are executable on browser
Testable with browsers and Selenium WebDriver
Licensed under MIT licence
Requirements
Python 3.4.4+ and any modern-browsers are required. Also supports Electron and PyQt’s webkit browsers. IE is not supported, but most of features will work with IE11 (but not recomended).
Installation
Install by pip:
pip install wdom
Or, install latest version from github:
pip install git+http://github.com/miyakogi/wdom
As WDOM depends on tornado web framework, it will be installed automatically. Optionally supports aiohttp, which is a web framework natively supports asyncio and is partly written in C. Using aiohttp will result in better performance. If you want to use WDOM with aiohttp, install it with pip:
pip install aiohttp
Any configurations are not required; when aiohttp is available, WDOM will use it automatically.
Example
Simple example:
import asyncio
from wdom.document import get_document
from wdom.server import start_server, stop_server
if __name__ == '__main__':
document = get_document()
h1 = document.createElement('h1')
h1.textContent = 'Hello, WDOM'
document.body.appendChild(h1)
start_server()
try:
asyncio.get_event_loop().run_forever()
except KeyboardInterrupt:
stop_server()
Execute this code and access http://localhost:8888 by browser. "Hello, WDOM" will shown on the browser. To stop process, press CTRL+C.
As you can see, methods of WDOM (document.createElement and document.body.appendChild) are very similar to browser JavaScript.
WDOM provides some new DOM APIs (e.g. append for appending child) and some tag classes to easily generate elements:
import asyncio
from wdom.tag import H1
from wdom.document import get_document
from wdom.server import start_server, stop_server
if __name__ == '__main__':
document = get_document()
h1 = H1()
h1.textContent = 'Hello, WDOM'
document.body.append(h1)
start_server()
try:
asyncio.get_event_loop().run_forever()
except KeyboardInterrupt:
stop_server()
Of course, WDOM can handle events:
import asyncio
from wdom.tag import H1
from wdom.server import start_server, stop_server
from wdom.document import get_document
if __name__ == '__main__':
document = get_document()
h1 = H1('Hello, WDOM', parent=document.body)
def rev_text(event):
h1.textContent = h1.textContent[::-1]
h1.addEventListener('click', rev_text)
start_server()
try:
asyncio.get_event_loop().run_forever()
except KeyboardInterrupt:
stop_server()
When string "Hello, WDOM" is clicked, it will be flipped.
Making components with python class:
import asyncio
from wdom.tag import Div, H1, Input
from wdom.server import start_server, stop_server
from wdom.document import get_document
class MyApp(Div):
def __init__(self, *args, **kwargs):
super().__init__(*args, **kwargs)
self.text = H1('Hello', parent=self)
self.textbox = Input(parent=self, placeholder='input here...')
self.textbox.addEventListener('input', self.update)
def update(self, event):
self.text.textContent = event.target.value
# or, you can write as below
# self.text.textContent = self.textbox.value
if __name__ == '__main__':
document = get_document()
document.body.append(MyApp())
start_server()
try:
asyncio.get_event_loop().run_forever()
except KeyboardInterrupt:
stop_server()
WDOM package includes some tiny examples. From command line, try:
python -m wdom.exapmles.rev_text python -m wdom.exapmles.data_binding python -m wdom.exapmles.timer
Source codes of these examples will be found in wdom/examples.
Theming with CSS Frameworks
WDOM is CSS friendly, and provides easy way to theme your app with CSS frameworks. For example, use bootstrap3:
import asyncio
from wdom.themes import bootstrap3
from wdom.themes.bootstrap3 import Button, PrimaryButton, DangerButton
from wdom.server import start_server, stop_server
from wdom.document import get_document
if __name__ == '__main__':
document = get_document()
document.register_theme(bootstrap3)
document.body.append(
Button('Button'), PrimaryButton('Primary'), DangerButton('Danger')
)
start_server()
try:
asyncio.get_event_loop().run_forever()
except KeyboardInterrupt:
stop_server()
Differences are:
import tag classes from wdom.themes.[theme_name] instead of wdom.tag
register theme-module by document.register_theme(theme_module)
If you want to more easily change themes (or, css frameworks), try command-line option --theme. wdom.themes.default module is switched by --theme option.
For example, in the above code, change bootstrap3 to default. And execute the code with --theme theme_name option (see below).
Currently, WDOM bundles 20+ CSS frameworks by default, and they are listed in Wiki with screenshots. In each theme module, only primitive HTML elements (typographies, buttons, form components, tables, and grids) are defined, but complex elements like navigations or tabs are not defined.
If your favourite CSS framework is not included, please let me know on Issues, or write its wrapper module and send PR.
Of course you can use your original css. See Loading Static Contents -> Local Resource section in the User Guide.
Contributing
Contributions are welcome!!
If you find any bug, or have any comments, please don’t hesitate to report to Issues on GitHub. All your comments are welcome!
More Documents
Please see User Guide.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.