fluffychat/lib/pangea/analytics_details_popup/construct_xp_progress_bar.dart
ggurdin 3537cd5fd4
feat: add language indicators to analytics database entries (#5692)
* feat: add language indicators to analytics database entries

* better handling for database reinit

* don't clear database is last update not set
2026-02-13 15:06:21 -05:00

79 lines
2.7 KiB
Dart

import 'dart:math';
import 'package:flutter/material.dart';
import 'package:collection/collection.dart';
import 'package:fluffychat/config/app_config.dart';
import 'package:fluffychat/pangea/analytics_misc/analytics_constants.dart';
import 'package:fluffychat/pangea/analytics_misc/construct_use_model.dart';
import 'package:fluffychat/pangea/analytics_summary/animated_progress_bar.dart';
import 'package:fluffychat/pangea/constructs/construct_identifier.dart';
import 'package:fluffychat/pangea/constructs/construct_level_enum.dart';
import 'package:fluffychat/widgets/matrix.dart';
class ConstructXPProgressBar extends StatelessWidget {
final ConstructIdentifier construct;
const ConstructXPProgressBar({required this.construct, super.key});
@override
Widget build(BuildContext context) {
final categories = ConstructLevelEnum.values.sorted(
(a, b) => a.xpNeeded.compareTo(b.xpNeeded),
);
final analyticsService = Matrix.of(context).analyticsDataService;
final l2 =
MatrixState.pangeaController.userController.userL2?.langCodeShort;
return StreamBuilder(
stream: analyticsService.updateDispatcher.constructUpdateStream.stream,
builder: (context, snapshot) {
return FutureBuilder(
future: l2 != null
? analyticsService.getConstructUse(construct, l2)
: Future.value(
ConstructUses(
uses: [],
constructType: construct.type,
lemma: construct.lemma,
category: construct.category,
),
),
builder: (context, snapshot) {
final points = snapshot.data?.points ?? 0;
final progress = min(1.0, points / AnalyticsConstants.xpForFlower);
final level =
snapshot.data?.constructLevel ?? ConstructLevelEnum.seeds;
const iconSize = 40.0;
return Column(
spacing: 8.0,
children: [
Row(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
children: [
...categories.map(
(c) => Opacity(
opacity: level == c ? 1.0 : 0.4,
child: c.icon(iconSize),
),
),
],
),
AnimatedProgressBar(
height: 20.0,
widthPercent: progress,
barColor: AppConfig.goldLight,
backgroundColor: Theme.of(
context,
).colorScheme.secondaryContainer,
),
],
);
},
);
},
);
}
}