import 'package:flutter/material.dart'; import 'package:multi_split_view/multi_split_view.dart'; import 'package:apidash/consts.dart'; class DashboardSplitView extends StatefulWidget { const DashboardSplitView({ super.key, required this.sidebarWidget, required this.mainWidget, }); final Widget sidebarWidget; final Widget mainWidget; @override DashboardSplitViewState createState() => DashboardSplitViewState(); } class DashboardSplitViewState extends State { final MultiSplitViewController _controller = MultiSplitViewController( areas: [ Area(id: "sidebar", size: 250, min: 200), Area(id: "main", min: 0.7), ], ); @override void initState() { super.initState(); } @override Widget build(BuildContext context) { return MultiSplitViewTheme( data: MultiSplitViewThemeData( dividerThickness: 3, dividerPainter: DividerPainters.background( color: Theme.of(context).colorScheme.surfaceContainerHighest, highlightedColor: Theme.of(context).colorScheme.outline.withOpacity( kHintOpacity, ), animationEnabled: false, ), ), child: MultiSplitView( controller: _controller, builder: (context, area) { return switch (area.id) { "sidebar" => widget.sidebarWidget, "main" => widget.mainWidget, _ => Container(), }; }, ), ); } @override void dispose() { _controller.dispose(); super.dispose(); } }