mirror of
https://github.com/foss42/apidash.git
synced 2025-05-25 18:27:02 +08:00
68 lines
1.8 KiB
Dart
68 lines
1.8 KiB
Dart
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<DashboardSplitView> {
|
|
final MultiSplitViewController _controller = MultiSplitViewController(
|
|
areas: [
|
|
Area(id: "sidebar", min: 220, size: 250, max: 300), // Absolute values
|
|
Area(id: "main", min: 600),
|
|
// Area(id: "sidebar", flex: 0.3, min: 0.25), // Flex values
|
|
// Area(id: "main", flex: 0.7, 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,
|
|
sizeOverflowPolicy: SizeOverflowPolicy.shrinkFirst,
|
|
sizeUnderflowPolicy: SizeUnderflowPolicy.stretchLast,
|
|
builder: (context, area) {
|
|
return switch (area.id) {
|
|
"sidebar" => widget.sidebarWidget,
|
|
"main" => widget.mainWidget,
|
|
_ => Container(),
|
|
};
|
|
},
|
|
),
|
|
);
|
|
}
|
|
|
|
@override
|
|
void dispose() {
|
|
_controller.dispose();
|
|
super.dispose();
|
|
}
|
|
}
|