revanced-manager/lib/ui/widgets/patch_item.dart

88 lines
2.6 KiB
Dart
Raw Normal View History

2022-08-07 23:35:44 +05:30
import 'package:flutter/material.dart';
import 'package:google_fonts/google_fonts.dart';
2022-08-09 00:01:06 +01:00
// ignore: must_be_immutable
2022-08-08 00:45:52 +05:30
class PatchItem extends StatefulWidget {
2022-08-07 23:35:44 +05:30
final String name;
final String description;
final String version;
2022-08-08 00:45:52 +05:30
bool isSelected;
2022-08-07 23:35:44 +05:30
PatchItem({
Key? key,
required this.name,
required this.description,
required this.version,
required this.isSelected,
}) : super(key: key);
2022-08-08 00:45:52 +05:30
@override
State<PatchItem> createState() => _PatchItemState();
}
class _PatchItemState extends State<PatchItem> {
2022-08-07 23:35:44 +05:30
@override
Widget build(BuildContext context) {
return Container(
decoration: BoxDecoration(
2022-08-08 00:45:52 +05:30
color: const Color(0xff1B222B),
2022-08-07 23:35:44 +05:30
borderRadius: BorderRadius.circular(10),
),
padding: const EdgeInsets.symmetric(vertical: 12, horizontal: 12),
margin: const EdgeInsets.symmetric(vertical: 4, horizontal: 8),
child: Column(
children: [
Row(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
children: [
Flexible(
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Row(
crossAxisAlignment: CrossAxisAlignment.end,
children: [
Text(
2022-08-08 00:45:52 +05:30
widget.name,
2022-08-07 23:35:44 +05:30
style: GoogleFonts.inter(
fontSize: 16,
fontWeight: FontWeight.w600,
),
),
const SizedBox(width: 4),
2022-08-08 00:45:52 +05:30
Text(widget.version)
2022-08-07 23:35:44 +05:30
],
),
const SizedBox(height: 4),
Text(
2022-08-08 00:45:52 +05:30
widget.description,
2022-08-07 23:35:44 +05:30
softWrap: true,
maxLines: 3,
overflow: TextOverflow.visible,
style: GoogleFonts.roboto(
fontSize: 14,
),
),
],
),
),
Transform.scale(
scale: 1.2,
child: Checkbox(
2022-08-08 00:45:52 +05:30
value: widget.isSelected,
activeColor: Colors.blueGrey[500],
onChanged: (newValue) {
setState(() {
widget.isSelected = newValue!;
});
},
2022-08-07 23:35:44 +05:30
),
)
],
)
],
),
);
}
}