ente/lib/ui/notification/update/change_log_page.dart

133 lines
4.3 KiB
Dart
Raw Normal View History

2022-11-09 08:06:10 +00:00
import 'package:flutter/material.dart';
import "package:photos/generated/l10n.dart";
import 'package:photos/services/update_service.dart';
2022-11-09 08:06:10 +00:00
import 'package:photos/theme/ente_theme.dart';
import 'package:photos/ui/components/buttons/button_widget.dart';
2022-11-09 09:45:56 +00:00
import 'package:photos/ui/components/divider_widget.dart';
2022-12-17 04:59:15 +00:00
import 'package:photos/ui/components/models/button_type.dart';
2022-11-09 08:06:10 +00:00
import 'package:photos/ui/components/title_bar_title_widget.dart';
import 'package:photos/ui/notification/update/change_log_entry.dart';
class ChangeLogPage extends StatefulWidget {
const ChangeLogPage({
Key? key,
}) : super(key: key);
@override
State<ChangeLogPage> createState() => _ChangeLogPageState();
}
class _ChangeLogPageState extends State<ChangeLogPage> {
@override
void initState() {
super.initState();
}
@override
Widget build(BuildContext context) {
final enteColorScheme = getEnteColorScheme(context);
return Scaffold(
appBar: null,
body: Container(
color: enteColorScheme.backgroundElevated,
child: Column(
mainAxisAlignment: MainAxisAlignment.center,
children: [
const SizedBox(
height: 36,
),
2022-11-23 07:54:02 +00:00
Container(
alignment: Alignment.centerLeft,
child: const Padding(
padding: EdgeInsets.symmetric(horizontal: 16.0),
child: TitleBarTitleWidget(
title: "What's new",
2022-11-09 08:06:10 +00:00
),
),
),
2022-11-23 07:54:02 +00:00
const SizedBox(
height: 24,
),
2022-11-09 08:06:10 +00:00
Expanded(child: _getChangeLog()),
2022-11-09 09:45:56 +00:00
const DividerWidget(
dividerType: DividerType.solid,
),
2022-11-09 08:06:10 +00:00
SafeArea(
child: Padding(
2022-11-09 09:45:56 +00:00
padding: const EdgeInsets.only(
left: 16.0,
right: 16,
top: 16,
bottom: 8,
),
2022-11-09 08:06:10 +00:00
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
2022-12-17 04:59:15 +00:00
ButtonWidget(
buttonType: ButtonType.trailingIconPrimary,
buttonSize: ButtonSize.large,
labelText: S.of(context).continueLabel,
2022-12-17 04:59:15 +00:00
icon: Icons.arrow_forward_outlined,
onTap: () async {
await UpdateService.instance.hideChangeLog();
if (mounted && Navigator.of(context).canPop()) {
Navigator.of(context).pop();
}
},
),
const SizedBox(
height: 8,
2022-11-09 08:06:10 +00:00
),
2023-11-28 05:16:37 +00:00
ButtonWidget(
buttonType: ButtonType.trailingIconSecondary,
buttonSize: ButtonSize.large,
labelText: S.of(context).rateTheApp,
icon: Icons.favorite_rounded,
iconColor: enteColorScheme.primary500,
onTap: () async {
await UpdateService.instance.launchReviewUrl();
},
),
2022-11-09 08:06:10 +00:00
const SizedBox(height: 8),
],
),
),
),
],
),
),
);
}
Widget _getChangeLog() {
final scrollController = ScrollController();
final List<ChangeLogEntry> items = [];
2023-04-16 05:57:42 +00:00
items.add(
ChangeLogEntry(
2023-11-17 08:10:24 +00:00
"Explore with the new Search Tab ✨",
2023-11-17 11:03:50 +00:00
'Introducing a dedicated search tab with distinct sections for effortless discovery.\n'
'\nYou can now discover items that come under different Locations, Moments, Contacts, Photo descriptions, Albums and File types with ease.\n',
),
);
2023-06-02 04:59:38 +00:00
2022-11-09 08:06:10 +00:00
return Container(
padding: const EdgeInsets.only(left: 16),
child: Scrollbar(
controller: scrollController,
thumbVisibility: true,
thickness: 2.0,
child: ListView.builder(
2022-11-23 15:52:34 +00:00
physics: const BouncingScrollPhysics(),
2022-11-09 08:06:10 +00:00
itemBuilder: (context, index) {
return Padding(
padding: const EdgeInsets.only(right: 16.0),
child: ChangeLogEntryWidget(entry: items[index]),
);
},
itemCount: items.length,
),
),
);
}
}