Metadata-Version: 2.1
Name: textual-universal-directorytree
Version: 1.0.2
Summary: A Textual Directory Tree for all File Systems
Project-URL: Documentation, https://github.com/juftin/textual-universal-directorytree#readme
Project-URL: Issues, https://github.com/juftin/textual-universal-directorytree/issues
Project-URL: Source, https://github.com/juftin/textual-universal-directorytree
Author-email: Justin Flannery <justin.flannery@juftin.com>
License-Expression: MIT
License-File: LICENSE.txt
Keywords: fsspec,plugin,textual,tui
Classifier: Development Status :: 4 - Beta
Classifier: Programming Language :: Python
Classifier: Programming Language :: Python :: 3.8
Classifier: Programming Language :: Python :: 3.9
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Requires-Python: <4.0,>=3.8
Requires-Dist: textual>=0.27.0
Requires-Dist: universal-pathlib<=0.0.24,>=0.0.23
Provides-Extra: remote
Requires-Dist: adlfs; extra == 'remote'
Requires-Dist: aiohttp; extra == 'remote'
Requires-Dist: gcsfs; extra == 'remote'
Requires-Dist: paramiko; extra == 'remote'
Requires-Dist: requests>=2; extra == 'remote'
Requires-Dist: s3fs; extra == 'remote'
Description-Content-Type: text/markdown

# Textual Universal Directory Tree

A [Textual](https://textual.textualize.io/) plugin to make the
[DirectoryTree](https://textual.textualize.io/widgets/directory_tree/)
widget compatible with filesystems other than local.

![](docs/screenshots/test_github_screenshot.svg)

## Installation

```shell
pip install textual-universal-directorytree
```

### Extra Dependencies

Some filesystems require additional dependencies to be installed.
The `remote` extra includes all the known optional dependencies. See the
[Filesystems Supported](#filesystems-supported) section for more information.

```shell
pip install "textual-universal-directorytree[remote]"
```

## Usage

The below example shows how to use `textual-universal-directorytree` in a Textual app.
It uses the GitHub filesystem to display the contents of the textual GitHub repository.
It requires the `requests` library to be installed.

```python
from rich.syntax import Syntax
from textual import on
from textual.app import App, ComposeResult
from textual.containers import Horizontal, VerticalScroll
from textual.widgets import Footer, Header, Static

from textual_universal_directorytree import UniversalDirectoryTree


class UniversalDirectoryTreeApp(App):
    """
    The power of upath and fsspec in a Textual app
    """

    BINDINGS = [
        ("q", "quit", "Quit"),
    ]

    def __init__(self, *args, path: str, **kwargs):
        super().__init__(*args, **kwargs)
        self.universal_path = path

    def compose(self) -> ComposeResult:
        yield Header()
        self.directory_tree = UniversalDirectoryTree(path=self.universal_path)
        self.file_content = Static()
        yield Horizontal(self.directory_tree, VerticalScroll(self.file_content))
        yield Footer()

    @on(UniversalDirectoryTree.FileSelected)
    def handle_file_selected(
            self, message: UniversalDirectoryTree.FileSelected
    ) -> None:
        """
        Do something with the selected file.

        Objects returned by the FileSelected event are upath.UPath objects and
        they are compatible with the familiar pathlib.Path API built into Python.
        """
        selected_file_path = message.path
        file_content = selected_file_path.read_text(errors="replace")
        lexer = Syntax.guess_lexer(path=str(selected_file_path))
        code = Syntax(code=file_content, lexer=lexer)
        self.file_content.update(code)
```

Run the above app in your terminal:

```python
python -m textual_universal_directorytree github://juftin:textual-universal-directorytree@main/
```

## Filesystems Supported

`textual-universal-directorytree` leverages [fsspec](https://github.com/fsspec/filesystem_spec) and
[universal_pathlib](https://github.com/fsspec/universal_pathlib) to enable compatibility with
local and remote filesystems.

In some cases you need to install a filesystem-specific library
to enable compatibility with that filesystem. For example, to enable compatibility with AWS S3 you must
install [s3fs](https://github.com/fsspec/s3fs) which is an `fsspec` implementation for S3.

The following filesystems are known to be supported by `textual-universal-directorytree`, but it's possible
that [others filesystems](https://filesystem-spec.readthedocs.io/en/latest/api.html#other-known-implementations)
are supported as well and just haven't been tested. If you find a filesystem that works, please open an issue.

| File System     | Format                            | Optional Dependencies                            |
| --------------- | --------------------------------- | ------------------------------------------------ |
| Local           | `path/to/file`                    | None                                             |
| Local           | `file://path/to/file`             | None                                             |
| AWS S3          | `s3://bucket/path`                | [s3fs](https://github.com/fsspec/s3fs)           |
| AWS S3          | `s3a://bucket/path`               | [s3fs](https://github.com/fsspec/s3fs)           |
| Google GCS      | `gs://bucket/path`                | [gcsfs](https://github.com/fsspec/gcsfs)         |
| Azure Data Lake | `adl://bucket/path`               | [adlfs](https://github.com/fsspec/adlfs)         |
| Azure Blob      | `abfs://bucket/path`              | [adlfs](https://github.com/fsspec/adlfs)         |
| Azure Blob      | `az://bucket/path`                | [adlfs](https://github.com/fsspec/adlfs)         |
| GitHub          | `github://owner:repo@branch`      | [requests](https://github.com/requests/requests) |
| GitHub          | `github://owner:repo@branch/path` | [requests](https://github.com/requests/requests) |
| SSH             | `ssh://user@host:port/path`       | [paramiko](https://github.com/paramiko/paramiko) |
| SFTP            | `sftp://user@host:port/path`      | [paramiko](https://github.com/paramiko/paramiko) |

## License

`textual-universal-directorytree` is distributed under the terms of the [MIT](https://spdx.org/licenses/MIT.html)
license.
