m3_lightmeter/lib/screens/metering/components/exposure_pairs_list/widget_list_exposure_pairs.dart

75 lines
2.7 KiB
Dart
Raw Normal View History

2022-10-26 19:49:21 +00:00
import 'package:flutter/material.dart';
2022-12-16 08:08:12 +00:00
import 'package:lightmeter/data/models/exposure_pair.dart';
2022-10-26 19:49:21 +00:00
import 'package:lightmeter/res/dimens.dart';
import 'package:lightmeter/screens/metering/components/exposure_pairs_list/components/widget_item_list_exposure_pairs.dart';
2022-10-26 19:49:21 +00:00
class ExposurePairsList extends StatelessWidget {
2022-10-29 18:02:45 +00:00
final List<ExposurePair> exposurePairs;
2022-10-26 19:49:21 +00:00
2022-10-29 18:02:45 +00:00
const ExposurePairsList(this.exposurePairs, {super.key});
2022-10-26 19:49:21 +00:00
@override
Widget build(BuildContext context) {
return Stack(
alignment: Alignment.center,
children: [
Positioned.fill(
child: ListView.builder(
2022-10-29 18:02:45 +00:00
key: ValueKey(exposurePairs.hashCode),
padding: const EdgeInsets.symmetric(vertical: Dimens.paddingL),
2022-10-29 18:02:45 +00:00
itemCount: exposurePairs.length,
2022-12-16 21:25:08 +00:00
itemBuilder: (_, index) => Stack(
alignment: Alignment.center,
2022-10-26 19:49:21 +00:00
children: [
2022-12-16 21:25:08 +00:00
Row(
mainAxisAlignment: MainAxisAlignment.center,
children: [
Expanded(
child: Align(
alignment: Alignment.centerLeft,
child: ExposurePairsListItem(
2022-12-16 21:25:08 +00:00
exposurePairs[index].aperture,
tickOnTheLeft: false,
),
),
2022-10-26 19:49:21 +00:00
),
2022-12-16 21:25:08 +00:00
Expanded(
child: Align(
alignment: Alignment.centerLeft,
child: ExposurePairsListItem(
2022-12-16 21:25:08 +00:00
exposurePairs[index].shutterSpeed,
tickOnTheLeft: true,
),
),
),
],
2022-10-26 19:49:21 +00:00
),
2022-12-16 21:25:08 +00:00
Positioned(
top: 0,
bottom: 0,
child: LayoutBuilder(
builder: (context, constraints) => Align(
alignment: index == 0
? Alignment.bottomCenter
: (index == exposurePairs.length - 1 ? Alignment.topCenter : Alignment.center),
child: SizedBox(
height: index == 0 || index == exposurePairs.length - 1
? constraints.maxHeight / 2
: constraints.maxHeight,
child: ColoredBox(
color: Theme.of(context).colorScheme.onBackground,
child: const SizedBox(width: 1),
),
),
2022-10-26 19:49:21 +00:00
),
),
),
],
),
),
),
],
);
}
}