Skip to main content

FileDrop widget for Textual, easily drag and drop files into your terminal apps.

Project description

textual-filedrop

textual-filedrop

Add filedrop support to your Textual apps, easily drag and drop files into your terminal apps.

Tested on Windows and macOS.

Nerd Font is required to display file icons.

Install

pip install textual-filedrop

or

git clone https://github.com/agmmnn/textual-filedrop.git
cd textual-filedrop
poetry install

Note

Since version 0.10.0 Textual supports bubble for the paste event (Textualize/textual#1434). So if the terminal where your app is running treats the file drag and drop as a paste event, you can catch it yourself with the on_paste function without widget.

Usage

getfiles

getfiles returns an object containing the path, filename, extension and icon of the files.

from textual_filedrop import getfiles

class MyApp(App):
...
    def on_paste(self, event) -> None:
        files = getfiles(event)
        print(files)

FileDrop Widget

As long as the FileDrop widget is in focus, it will give the information of the dragged files and render the file names with their icons on the screen.

from textual_filedrop import FileDrop
# add FileDrop widget to your app
yield FileDrop(id="filedrop")
# focus the widget
self.query_one("#filedrop").focus()
# when the files are dropped
def on_file_drop_dropped(self, message: FileDrop.Dropped) -> None:
    path = message.path
    filepaths = message.filepaths
    filenames = message.filenames
    filesobj = message.filesobj
    print(path, filepaths, filenames, filesobj)


# output: path, [filepaths], [filenames], [filesobj]

You can find more examples here.

Examples

subdomain_lister.py

Drag and drop the subdomain list files and see the results as a tree list.

subdomain_lister

fullscreen.py

Fullscreen example, will show the results in the textual console.

hidden.py

As long as focus is on, the FileDrop widget will be active even if it is not visible on the screen.

without_widget.py

An example that renders the object with the information of the dragged files returned from the getfiles function to the screen with rich.json.

Dev

poetry install

textual console
poetry run textual run --dev examples/subdomain_lister.py

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

textual_filedrop-0.3.5.tar.gz (7.7 kB view details)

Uploaded Source

Built Distribution

textual_filedrop-0.3.5-py3-none-any.whl (7.8 kB view details)

Uploaded Python 3

File details

Details for the file textual_filedrop-0.3.5.tar.gz.

File metadata

  • Download URL: textual_filedrop-0.3.5.tar.gz
  • Upload date:
  • Size: 7.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.3.2 CPython/3.11.2 Windows/10

File hashes

Hashes for textual_filedrop-0.3.5.tar.gz
Algorithm Hash digest
SHA256 3afadb2e913827a230307776cedfcd3b40c5654c9e9c56b72f1fddba641587ac
MD5 62b8b167a0ae160db5f60353f298b87c
BLAKE2b-256 9b1673864d6c1f182c96b3186e5d9328d2251fcdb4241d1e5d57d3027e8957f1

See more details on using hashes here.

File details

Details for the file textual_filedrop-0.3.5-py3-none-any.whl.

File metadata

File hashes

Hashes for textual_filedrop-0.3.5-py3-none-any.whl
Algorithm Hash digest
SHA256 98d6751a37a363566927e628c1f1d47b013dfbe5ff189906366cbea0e6d16c6d
MD5 4d32093f0ff061a430321819df179daf
BLAKE2b-256 e7d5848201ba230a52ea02c7907e620b4c649ee45d2d18f485d919311e51ae00

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page