revanced-manager/lib/ui/widgets/shared/application_item.dart

139 lines
4.3 KiB
Dart
Raw Normal View History

import 'dart:typed_data';
2022-08-01 13:30:06 +02:00
import 'package:flutter/material.dart';
2022-08-07 01:37:12 +02:00
import 'package:flutter_i18n/flutter_i18n.dart';
import 'package:revanced_manager/ui/widgets/installerView/custom_material_button.dart';
import 'package:revanced_manager/ui/widgets/shared/custom_card.dart';
import 'package:expandable/expandable.dart';
import 'package:timeago/timeago.dart';
2022-08-01 13:30:06 +02:00
2022-09-15 21:19:11 +02:00
class ApplicationItem extends StatefulWidget {
final Uint8List icon;
2022-08-01 13:30:06 +02:00
final String name;
final DateTime patchDate;
final List<String> changelog;
final bool isUpdatableApp;
2022-08-18 16:33:33 +02:00
final Function() onPressed;
2022-08-01 13:30:06 +02:00
2022-08-01 20:15:55 +02:00
const ApplicationItem({
2022-08-01 13:30:06 +02:00
Key? key,
required this.icon,
2022-08-01 13:30:06 +02:00
required this.name,
required this.patchDate,
2022-08-17 18:07:00 +02:00
required this.changelog,
required this.isUpdatableApp,
2022-08-01 14:24:05 +02:00
required this.onPressed,
2022-08-01 13:30:06 +02:00
}) : super(key: key);
2022-09-15 21:19:11 +02:00
@override
State<ApplicationItem> createState() => _ApplicationItemState();
}
class _ApplicationItemState extends State<ApplicationItem>
with TickerProviderStateMixin {
late AnimationController _animationController;
@override
initState() {
super.initState();
_animationController = AnimationController(
vsync: this,
duration: const Duration(milliseconds: 300),
);
}
@override
void dispose() {
_animationController.dispose();
super.dispose();
}
2022-08-01 13:30:06 +02:00
@override
Widget build(BuildContext context) {
2022-09-15 21:19:11 +02:00
ExpandableController expController = ExpandableController();
return ExpandablePanel(
2022-09-15 21:19:11 +02:00
controller: expController,
theme: const ExpandableThemeData(
2022-09-15 21:19:11 +02:00
inkWellBorderRadius: BorderRadius.all(Radius.circular(16)),
tapBodyToCollapse: false,
tapBodyToExpand: false,
tapHeaderToExpand: false,
hasIcon: false,
animationDuration: Duration(milliseconds: 450),
),
header: CustomCard(
child: Row(
children: <Widget>[
SizedBox(
2022-09-17 10:02:49 +02:00
width: 40,
child: Image.memory(widget.icon, height: 40, width: 40),
),
const SizedBox(width: 4),
2022-09-17 10:02:49 +02:00
Padding(
padding: const EdgeInsets.only(left: 15.0),
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: <Widget>[
Text(
widget.name,
style: const TextStyle(
fontSize: 16,
fontWeight: FontWeight.w500,
),
),
Text(format(widget.patchDate)),
],
),
),
const Spacer(),
2022-09-17 10:02:49 +02:00
Padding(
padding: const EdgeInsets.only(right: 5.0),
child: RotationTransition(
turns: Tween(begin: 0.0, end: 0.50).animate(_animationController),
child: IconButton(
onPressed: () {
expController.toggle();
_animationController.isCompleted
? _animationController.reverse()
: _animationController.forward();
},
icon: const Icon(Icons.arrow_drop_down),
),
2022-09-15 21:19:11 +02:00
),
),
2022-09-05 14:43:13 +02:00
Column(
mainAxisAlignment: MainAxisAlignment.center,
crossAxisAlignment: CrossAxisAlignment.end,
children: <Widget>[
CustomMaterialButton(
2022-09-15 21:19:11 +02:00
label: widget.isUpdatableApp
2022-09-05 14:43:13 +02:00
? I18nText('applicationItem.patchButton')
: I18nText('applicationItem.infoButton'),
2022-09-15 21:19:11 +02:00
onPressed: widget.onPressed,
2022-09-05 14:43:13 +02:00
),
],
),
],
2022-08-01 13:30:06 +02:00
),
),
collapsed: const Text(''),
expanded: Padding(
2022-09-17 10:02:49 +02:00
padding: const EdgeInsets.symmetric(vertical: 16.0, horizontal: 16.0),
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: <Widget>[
I18nText(
'applicationItem.changelogLabel',
child: const Text(
'',
style: TextStyle(fontWeight: FontWeight.w700),
),
),
const SizedBox(height: 4),
2022-09-15 21:19:11 +02:00
Text('\u2022 ${widget.changelog.join('\n\u2022 ')}'),
],
2022-08-07 01:37:12 +02:00
),
2022-08-01 13:30:06 +02:00
),
);
}
}