Merge branch 'main' into develop
# Conflicts: # README.md # lib/core/constants.dart # lib/core/custom_theme.dart # lib/l10n/arb/app_de.arb # lib/l10n/arb/app_en.arb # lib/l10n/generated/app_localizations.dart # lib/l10n/generated/app_localizations_de.dart # lib/l10n/generated/app_localizations_en.dart # lib/presentation/views/active_game_view.dart # lib/presentation/views/create_game_view.dart # lib/presentation/views/home/active_game/graph_view.dart # lib/presentation/views/home/active_game/round_view.dart # lib/presentation/views/home/main_menu_view.dart # lib/presentation/views/home/settings_view.dart # lib/services/config_service.dart # pubspec.yaml
This commit is contained in:
141
lib/presentation/views/points_view.dart
Normal file
141
lib/presentation/views/points_view.dart
Normal file
@@ -0,0 +1,141 @@
|
|||||||
|
import 'package:cabo_counter/core/custom_theme.dart';
|
||||||
|
import 'package:cabo_counter/data/game_session.dart';
|
||||||
|
import 'package:cabo_counter/l10n/generated/app_localizations.dart';
|
||||||
|
import 'package:flutter/cupertino.dart';
|
||||||
|
import 'package:flutter/material.dart';
|
||||||
|
|
||||||
|
class PointsView extends StatefulWidget {
|
||||||
|
final GameSession gameSession;
|
||||||
|
|
||||||
|
const PointsView({super.key, required this.gameSession});
|
||||||
|
|
||||||
|
@override
|
||||||
|
State<PointsView> createState() => _PointsViewState();
|
||||||
|
}
|
||||||
|
|
||||||
|
class _PointsViewState extends State<PointsView> {
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
return CupertinoPageScaffold(
|
||||||
|
navigationBar: CupertinoNavigationBar(
|
||||||
|
middle: Text(AppLocalizations.of(context).point_overview),
|
||||||
|
previousPageTitle: AppLocalizations.of(context).back,
|
||||||
|
),
|
||||||
|
child: SingleChildScrollView(
|
||||||
|
padding: const EdgeInsets.fromLTRB(0, 100, 0, 0),
|
||||||
|
child: Padding(
|
||||||
|
padding: const EdgeInsets.symmetric(horizontal: 8.0),
|
||||||
|
child: DataTable(
|
||||||
|
dataRowMinHeight: 60,
|
||||||
|
dataRowMaxHeight: 60,
|
||||||
|
dividerThickness: 0.5,
|
||||||
|
columnSpacing: 20,
|
||||||
|
columns: [
|
||||||
|
const DataColumn(
|
||||||
|
numeric: true,
|
||||||
|
headingRowAlignment: MainAxisAlignment.center,
|
||||||
|
label: Text(
|
||||||
|
'#',
|
||||||
|
style: TextStyle(fontWeight: FontWeight.bold),
|
||||||
|
),
|
||||||
|
columnWidth: IntrinsicColumnWidth(flex: 0.5)),
|
||||||
|
...widget.gameSession.players.map(
|
||||||
|
(player) => DataColumn(
|
||||||
|
label: FittedBox(
|
||||||
|
fit: BoxFit.fill,
|
||||||
|
child: Text(
|
||||||
|
player,
|
||||||
|
style: const TextStyle(fontWeight: FontWeight.bold),
|
||||||
|
)),
|
||||||
|
headingRowAlignment: MainAxisAlignment.center,
|
||||||
|
columnWidth: const IntrinsicColumnWidth(flex: 1)),
|
||||||
|
),
|
||||||
|
],
|
||||||
|
rows: [
|
||||||
|
...List<DataRow>.generate(
|
||||||
|
widget.gameSession.roundList.length,
|
||||||
|
(roundIndex) {
|
||||||
|
final round = widget.gameSession.roundList[roundIndex];
|
||||||
|
return DataRow(
|
||||||
|
cells: [
|
||||||
|
DataCell(Align(
|
||||||
|
alignment: Alignment.center,
|
||||||
|
child: Text(
|
||||||
|
'${roundIndex + 1}',
|
||||||
|
style: const TextStyle(fontSize: 20),
|
||||||
|
),
|
||||||
|
)),
|
||||||
|
...List.generate(widget.gameSession.players.length,
|
||||||
|
(playerIndex) {
|
||||||
|
final int score = round.scores[playerIndex];
|
||||||
|
final int update = round.scoreUpdates[playerIndex];
|
||||||
|
final bool saidCabo =
|
||||||
|
round.caboPlayerIndex == playerIndex;
|
||||||
|
return DataCell(
|
||||||
|
Center(
|
||||||
|
child: Column(
|
||||||
|
mainAxisAlignment: MainAxisAlignment.center,
|
||||||
|
children: [
|
||||||
|
Container(
|
||||||
|
padding: const EdgeInsets.symmetric(
|
||||||
|
horizontal: 6, vertical: 2),
|
||||||
|
decoration: BoxDecoration(
|
||||||
|
color: update <= 0
|
||||||
|
? CustomTheme.pointLossColor
|
||||||
|
: CustomTheme.pointGainColor,
|
||||||
|
borderRadius: BorderRadius.circular(8),
|
||||||
|
),
|
||||||
|
child: Text(
|
||||||
|
'${update >= 0 ? '+' : ''}$update',
|
||||||
|
style: const TextStyle(
|
||||||
|
color: CupertinoColors.white,
|
||||||
|
fontWeight: FontWeight.bold,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
const SizedBox(height: 4),
|
||||||
|
Text('$score',
|
||||||
|
style: TextStyle(
|
||||||
|
fontWeight: saidCabo
|
||||||
|
? FontWeight.bold
|
||||||
|
: FontWeight.normal,
|
||||||
|
)),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}),
|
||||||
|
],
|
||||||
|
);
|
||||||
|
},
|
||||||
|
),
|
||||||
|
DataRow(
|
||||||
|
cells: [
|
||||||
|
const DataCell(Align(
|
||||||
|
alignment: Alignment.center,
|
||||||
|
child: Text(
|
||||||
|
'Σ',
|
||||||
|
style:
|
||||||
|
TextStyle(fontSize: 25, fontWeight: FontWeight.bold),
|
||||||
|
),
|
||||||
|
)),
|
||||||
|
...widget.gameSession.playerScores.map(
|
||||||
|
(score) => DataCell(
|
||||||
|
Center(
|
||||||
|
child: Text(
|
||||||
|
'$score',
|
||||||
|
style: const TextStyle(
|
||||||
|
fontSize: 20, fontWeight: FontWeight.bold),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user