adguard-home-manager/lib/screens/logs/details/log_list_tile.dart
2024-06-17 13:28:12 +02:00

74 lines
No EOL
2.1 KiB
Dart

import 'package:flutter/material.dart';
class LogListTile extends StatelessWidget {
final IconData icon;
final String title;
final String? subtitle;
final Widget? subtitleWidget;
final Widget? trailing;
final void Function()? onTap;
const LogListTile({
super.key,
required this.icon,
required this.title,
this.subtitle,
this.subtitleWidget,
this.trailing,
this.onTap,
});
@override
Widget build(BuildContext context) {
return InkWell(
onTap: onTap,
child: Padding(
padding: const EdgeInsets.symmetric(horizontal: 16, vertical: 12),
child: Row(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
children: [
Flexible(
child: Row(
children: [
Icon(
icon,
size: 24,
color: Theme.of(context).colorScheme.onSurfaceVariant,
),
const SizedBox(width: 16),
Flexible(
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Text(
title,
style: TextStyle(
fontSize: 16,
fontWeight: FontWeight.w400,
color: Theme.of(context).colorScheme.onSurface
),
),
const SizedBox(height: 3),
subtitleWidget ?? Text(
subtitle!,
style: TextStyle(
fontSize: 14,
color: Theme.of(context).listTileTheme.textColor,
),
)
],
),
),
],
),
),
if (trailing != null) ...[
const SizedBox(width: 16),
trailing!
]
],
),
),
);
}
}