xworkmate-app/lib/widgets/top_bar.dart

56 lines
1.5 KiB
Dart

import 'package:flutter/material.dart';
class TopBar extends StatelessWidget {
const TopBar({
super.key,
required this.title,
required this.subtitle,
this.trailing,
});
final String title;
final String subtitle;
final Widget? trailing;
@override
Widget build(BuildContext context) {
return LayoutBuilder(
builder: (context, constraints) {
final compact = constraints.maxWidth < 760;
if (compact) {
return Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Text(title, style: Theme.of(context).textTheme.headlineSmall),
const SizedBox(height: 8),
Text(subtitle, style: Theme.of(context).textTheme.bodyMedium),
if (trailing != null) ...[const SizedBox(height: 16), trailing!],
],
);
}
return Row(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Expanded(
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Text(title, style: Theme.of(context).textTheme.headlineSmall),
const SizedBox(height: 8),
Text(subtitle, style: Theme.of(context).textTheme.bodyMedium),
],
),
),
if (trailing != null) ...[
const SizedBox(width: 24),
Flexible(child: trailing!),
],
],
);
},
);
}
}