Layout library for Python (based on Taffy, a rust-powered implementation of CSS Grid/Flexbox)
Project description
stretchable
stretchable is a layout library for Python that enables context-agnostic layout operations using CSS Block, CSS Grid and Flexbox. Possible uses include UI layouts, page layouts for reports, complex plotting layouts, etc.
It implements Python bindings for Taffy, an implementation of CSS Block, Flexbox and CSS Grid layout algorithms written in Rust. It was originally based on Stretch (hence the name), but has since migrated to use Taffy. It is multi-platform and there are distributions available for Windows, Linux and macOS.
Getting Started
stretchable is a Python package hosted on PyPI. It can be installed using pip:
python -m pip install stretchable
Building a tree of nodes and calculating the layout is as simple as:
from stretchable import Edge, Node
from stretchable.style import AUTO, PCT
# Build node tree
root = Node(
margin=20,
size=(500, 300),
).add(
Node(border=5, size=(50 * PCT, AUTO)),
Node(key="child", padding=10 * PCT, size=50 * PCT),
)
# Compute layout
root.compute_layout()
# Get the second child node
child_node = root.find("/child")
content_box = child_node.get_box(Edge.CONTENT)
print(content_box)
# Box(x=300.0, y=50.0, width=150.0, height=50.0)
For more information and details, see the documentation.
Contributing
Contributions are welcomed. Please open an issue to clarify/plan implementation details prior to starting the work.
Building
Install Rust with rustup and use maturin develop
for development and maturin build [--release]
to build.
Documentation
To build documentation use make html
(in docs/
folder) or, to use live reloading: sphinx-autobuild docs/source docs/build/html
NOTE: Sometimes, you may need to run make clean html
(in docs/
folder) to ensure that all changes are included in the built html.
Testing
Install test dependencies and invoke pytest
. Note that there are ~900 tests, the majority of which are run using Selenium with the Chrome WebDriver, and the complete test suite can take ~30 minutes to complete. Use pytest --lf
to only run the last-failed tests.
License
This work is released under the MIT license. A copy of the license is provided in the LICENSE file.
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.
Source Distributions
Built Distributions
Hashes for stretchable-1.1.0-cp38-abi3-win_arm64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 6e21c6f66a1be54d45fa11a685ffa37efb8f8f0fbacc534975cd79cdfddfafe1 |
|
MD5 | 351cb253ad933abeee4967f6b50e08ee |
|
BLAKE2b-256 | 94c208d94e3a3609b3efa9ba6b4cb138841d79c83bef8d3e5a639181553111f3 |
Hashes for stretchable-1.1.0-cp38-abi3-win_amd64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 9196d69e4ee203a87accfe2d5229c03e95956631971e0447739fdb9211bfd2ee |
|
MD5 | e44efaa249efda297a0fb30d2fdf66ba |
|
BLAKE2b-256 | 0502c3a6affe0f89ba3868c9102b94d7837d2fea5d27213577db6ae4162250ab |
Hashes for stretchable-1.1.0-cp38-abi3-win32.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 37103a0a8ab5ca9522e93639e9228e98b91dcea749703858afe8afe19d7cd282 |
|
MD5 | 2bffc369d97e7e35b951c6cdd596481f |
|
BLAKE2b-256 | c3dffd9031930967d3c17e4fe573b88ade9ada94d53c5cf4c6e59184cff7d5fa |
Hashes for stretchable-1.1.0-cp38-abi3-musllinux_1_2_x86_64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | eca55f455f6a6185f86bdb1fc7572cff092b376c941fa1628afd634be7bf35c8 |
|
MD5 | e86948957357af35c831849bc86686d9 |
|
BLAKE2b-256 | 8bfbd5111ea32baa36c63b8261b15237bef7d504751a39a1da469d2068c1c16b |
Hashes for stretchable-1.1.0-cp38-abi3-musllinux_1_2_aarch64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | c21bd492861a76e18755ec92d4393a917961c6f55275027e67b2a5db6274c6c5 |
|
MD5 | f4892c628e01ce189874e57781a42837 |
|
BLAKE2b-256 | 4a0f390495e5afa4adc7e34c23500db653b2946856128cb90d3e69e80070b853 |
Hashes for stretchable-1.1.0-cp38-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 7d37e1a7d840abdf8c28f070f2c9fc377c5d9a002bd80fd9917debd376b47fbf |
|
MD5 | 12422c0178fbf41fdd09aadd0fde7888 |
|
BLAKE2b-256 | dd5c9cf2bf7bb59f4c22d7bfe266024f6a21ada0e2c237835584f95251e44e9a |
Hashes for stretchable-1.1.0-cp38-abi3-manylinux_2_17_aarch64.manylinux2014_aarch64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 8b3e29ce113f42507f9ed3a019a81d2894e3ae47bfb17a7b57e6a760b72e5743 |
|
MD5 | 0f94f7d112a9ae262b52ca2f6bd460b8 |
|
BLAKE2b-256 | deceb207298cb96c6ce9712abe28031c62573b44f43717d17a76cd30c9f83f26 |
Hashes for stretchable-1.1.0-cp38-abi3-macosx_11_0_arm64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 0d8c6d3c06c13ddb810c8e12e645918fb32a6b219cc5ad8f6787e3eb4f6c5113 |
|
MD5 | c31d7661851c9e82589f0d3b928095df |
|
BLAKE2b-256 | 86904354f7ca79b16f333b1b8bed1e55fb86fad9cf79f7a2f274411f984788d0 |
Hashes for stretchable-1.1.0-cp38-abi3-macosx_10_12_x86_64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | a84a194c0e7664d27d23ec1ee9f1436fa702848e69b9eb102ad1490932b4a371 |
|
MD5 | 9bf2f7762f64b7719a439678730b65af |
|
BLAKE2b-256 | 0b59a605f93ec87f512345f59cce873721c045d4dff6dc5fff4e5373dd3e56cc |