[two_dimensional_scrollables] Add alignment to TreeView and TableView (#11353)
This PR implements declarative alignment for the content of TableView and TreeView widgets when that content is smaller than the viewport extent. Users can now use the alignment property to center or otherwise position the entire table/tree within the viewport.
Alignment correctly reverts to start for axes that exceed viewport dimensions.
Fixes flutter/flutter#170349
- TableView
- Added an alignment property of type AlignmentGeometry (defaults to Alignment.topLeft).
- Full support for both horizontal and vertical alignment.
- Supports AlignmentDirectional to correctly handle TextDirection (LTR/RTL).
- Works with pinned rows and columns, as well as reversed axis directions.
- TreeView
- Added an alignment property of type AlignmentGeometry (defaults to Alignment.topLeft).
- Caveat: Currently only supports the vertical component of the alignment. The tree remains
aligned to the horizontal "start" to maintain consistent indentation logic and avoid layout
jumps caused by dynamic, lazily-loaded node widths.
## Pre-Review Checklist
**Note**: The Flutter team is currently trialing the use of [Gemini Code Assist for GitHub](https://developers.google.com/gemini-code-assist/docs/review-github-code). Comments from the `gemini-code-assist` bot should not be taken as authoritative feedback from the Flutter team. If you find its comments useful you can update your code accordingly, but if you are unsure or disagree with the feedback, please feel free to wait for a Flutter team member's review for guidance on which automated comments should be addressed.
[^1]: Regular contributors who have demonstrated familiarity with the repository guidelines only need to comment if the PR is not auto-exempted by repo tooling.This repo is a companion repo to the main flutter repo. It contains the source code for Flutter's first-party packages (i.e., packages developed by the core Flutter team). Check the packages directory to see all packages.
These packages are also available on pub.
Please file any issues, bugs, or feature requests in the main flutter repo. Issues pertaining to this repository are labeled “package”.
If you wish to contribute a new package to the Flutter ecosystem, please see the documentation for developing packages. You can store your package source code in any GitHub repository (the present repo is only intended for packages developed by the core Flutter team). Once your package is ready you can publish to the pub repository.
If you wish to contribute a change to any of the existing packages in this repo, please review our contribution guide, and send a pull request.
These are the packages hosted in this repository: