indexTyped<Data, Tree extends IndexedTreeNode<Data> > static method
- Key? key,
- required TreeNodeWidgetBuilder<
Tree> builder, - required Tree tree,
- ExpansionBehavior expansionBehavior = ExpansionBehavior.none,
- Indentation? indentation,
- AutoScrollController? scrollController,
- ExpansionIndicatorBuilder? expansionIndicatorBuilder,
- ValueSetter<
Tree> ? onItemTap, - EdgeInsetsGeometry? padding,
- bool showRootNode = true,
- bool focusToNewNode = true,
- TreeReadyCallback<
Data, Tree> ? onTreeReady,
Use the typed constructor if you are extending the IndexedTreeNode instead
of directly wrapping the data in the IndexedTreeNode.
Using the SliverTreeView.indexTyped allows the builder
to return the correctly
typed Tree
object.
This alternate implementation of SliverTreeView uses an IndexedNode internally, which is based on the List data structure for maintaining the children states. The IndexedNode allows indexed based operations like insertion and removal of items at index positions. This allows for movement, addition and removal of child nodes based on indices. The complexity for accessing child nodes in SliverTreeView.indexed is simply O(node_level ^ children).
The main advantage of using a SliverTreeView over the TreeView is that it can be easily used with others slivers in a CustomScrollView, which means that you can easily implement a fancy animated list. The slivers are lazy loaded by default, so it can be easily mixed with other widgets without any loss of performance.
The complexity for accessing child nodes in SliverTreeView.indexed is simply O(node_level ^ children).
** See code in example/lib/samples/sliver_treeview/sliver_treeview_custom_object_sample.dart **
See also:
- If you do not require index based operations, the more performant and efficient SliverTreeView.simpleTyped instead.
- If you are wrapping the data directly in the IndexedTreeNode instead of extending the IndexedTreeNode, then you can also use the simpler TreeView.indexed.
Implementation
static SliverTreeView<Data, Tree>
indexTyped<Data, Tree extends IndexedTreeNode<Data>>({
Key? key,
required TreeNodeWidgetBuilder<Tree> builder,
required final Tree tree,
ExpansionBehavior expansionBehavior = ExpansionBehavior.none,
Indentation? indentation,
AutoScrollController? scrollController,
ExpansionIndicatorBuilder? expansionIndicatorBuilder,
ValueSetter<Tree>? onItemTap,
EdgeInsetsGeometry? padding,
bool showRootNode = true,
bool focusToNewNode = true,
TreeReadyCallback<Data, Tree>? onTreeReady,
}) =>
SliverTreeView._(
key: key,
builder: builder,
tree: tree,
expansionBehavior: expansionBehavior,
indentation: indentation,
expansionIndicatorBuilder:
expansionIndicatorBuilder ?? _defExpansionIndicatorBuilder,
scrollController: scrollController,
onItemTap: onItemTap,
padding: padding,
showRootNode: showRootNode,
onTreeReady: onTreeReady,
focusToNewNode: focusToNewNode,
);