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

143 lines
4.4 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/shared/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: Padding(
padding: const EdgeInsets.only(bottom: 16.0),
child: CustomCard(
onTap: () {
expController.toggle();
_animationController.isCompleted
? _animationController.reverse()
: _animationController.forward();
},
child: Row(
children: <Widget>[
SizedBox(
width: 40,
child: Image.memory(widget.icon, height: 40, width: 40),
),
const SizedBox(width: 4),
Padding(
padding: const EdgeInsets.only(left: 15.0),
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: <Widget>[
Text(
widget.name.length > 9
? '${widget.name.substring(0, 9)}...'
: widget.name,
style: const TextStyle(
fontSize: 16,
fontWeight: FontWeight.w500,
),
2022-09-17 10:02:49 +02:00
),
Text(format(widget.patchDate)),
],
),
),
const Spacer(),
RotationTransition(
turns:
Tween(begin: 0.0, end: 0.50).animate(_animationController),
child: const Padding(
padding: EdgeInsets.all(8.0),
child: Icon(Icons.arrow_drop_down),
),
),
Column(
mainAxisAlignment: MainAxisAlignment.center,
crossAxisAlignment: CrossAxisAlignment.end,
children: <Widget>[
CustomMaterialButton(
label: widget.isUpdatableApp
? I18nText('applicationItem.patchButton')
: I18nText('applicationItem.infoButton'),
onPressed: widget.onPressed,
),
],
),
],
),
2022-08-01 13:30:06 +02:00
),
),
2022-09-19 18:55:44 +02:00
collapsed: const SizedBox(),
expanded: Padding(
padding: const EdgeInsets.all(16.0).copyWith(top: 0.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
),
);
}
}