mirror of
https://github.com/foss42/apidash.git
synced 2025-05-21 08:16:29 +08:00
64 lines
1.5 KiB
Dart
64 lines
1.5 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", 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();
|
|
}
|
|
}
|