Files
PiliPlus/lib/pages/rank/view.dart
2026-02-07 09:28:02 +08:00

68 lines
1.9 KiB
Dart

import 'package:PiliPlus/common/widgets/flutter/vertical_tabs.dart';
import 'package:PiliPlus/models/common/rank_type.dart';
import 'package:PiliPlus/pages/rank/controller.dart';
import 'package:PiliPlus/pages/rank/zone/view.dart';
import 'package:flutter/material.dart';
import 'package:get/get.dart';
class RankPage extends StatefulWidget {
const RankPage({super.key});
@override
State<RankPage> createState() => _RankPageState();
}
class _RankPageState extends State<RankPage>
with AutomaticKeepAliveClientMixin {
final RankController _rankController = Get.put(RankController());
@override
bool get wantKeepAlive => true;
@override
Widget build(BuildContext context) {
super.build(context);
final theme = Theme.of(context);
return Row(
children: [
_buildTab(theme),
Expanded(
child: TabBarView(
physics: const NeverScrollableScrollPhysics(),
controller: _rankController.tabController,
children: RankType.values
.map(
(item) => ZonePage(
rid: item.rid,
seasonType: item.seasonType,
),
)
.toList(),
),
),
],
);
}
Widget _buildTab(ThemeData theme) {
return VerticalTabBar(
dividerWidth: 0,
isScrollable: true,
indicatorWeight: 3,
indicatorSize: .tab,
controller: _rankController.tabController,
padding: .only(bottom: MediaQuery.paddingOf(context).bottom + 105),
tabs: RankType.values.map((e) => VerticalTab(text: e.label)).toList(),
onTap: (index) {
if (!_rankController.tabController.indexIsChanging) {
_rankController.animateToTop();
} else {
_rankController
..tabIndex.value = index
..tabController.animateTo(index);
}
},
);
}
}