import 'package:flutter/material.dart'; import 'package:lightmeter/providers/equipment_profile_provider.dart'; import 'package:lightmeter/providers/films_provider.dart'; import 'package:m3_lightmeter_iap/m3_lightmeter_iap.dart'; import 'package:m3_lightmeter_resources/m3_lightmeter_resources.dart'; import 'package:mocktail/mocktail.dart'; class _MockIAPStorageService extends Mock implements IAPStorageService {} class MockIAPProviders extends StatefulWidget { final List? equipmentProfiles; final String selectedEquipmentProfileId; final List availableFilms; final List filmsInUse; final Film selectedFilm; final Widget child; const MockIAPProviders({ this.equipmentProfiles = const [], this.selectedEquipmentProfileId = '', List? availableFilms, List? filmsInUse, this.selectedFilm = const Film.other(), required this.child, super.key, }) : availableFilms = availableFilms ?? mockFilms, filmsInUse = filmsInUse ?? mockFilms; @override State createState() => _MockIAPProvidersState(); } class _MockIAPProvidersState extends State { late final _MockIAPStorageService mockIAPStorageService; @override void initState() { super.initState(); mockIAPStorageService = _MockIAPStorageService(); when(() => mockIAPStorageService.equipmentProfiles).thenReturn(widget.equipmentProfiles ?? mockEquipmentProfiles); when(() => mockIAPStorageService.selectedEquipmentProfileId).thenReturn(widget.selectedEquipmentProfileId); when(() => mockIAPStorageService.filmsInUse).thenReturn(widget.filmsInUse); when(() => mockIAPStorageService.selectedFilm).thenReturn(widget.selectedFilm); } @override Widget build(BuildContext context) { return EquipmentProfileProvider( storageService: mockIAPStorageService, child: FilmsProvider( storageService: mockIAPStorageService, availableFilms: widget.availableFilms, child: widget.child, ), ); } } const defaultEquipmentProfile = EquipmentProfile( id: '', name: '', apertureValues: ApertureValue.values, ndValues: NdValue.values, shutterSpeedValues: ShutterSpeedValue.values, isoValues: IsoValue.values, ); final mockEquipmentProfiles = [ EquipmentProfile( id: '1', name: 'Praktica + Zenitar', apertureValues: ApertureValue.values.sublist( ApertureValue.values.indexOf(const ApertureValue(1.7, StopType.half)), ApertureValue.values.indexOf(const ApertureValue(16, StopType.full)) + 1, ), ndValues: const [ NdValue(0), NdValue(2), NdValue(4), NdValue(8), ], shutterSpeedValues: ShutterSpeedValue.values.sublist( ShutterSpeedValue.values.indexOf(const ShutterSpeedValue(1000, true, StopType.full)), ShutterSpeedValue.values.indexOf(const ShutterSpeedValue(1, false, StopType.full)) + 1, ), isoValues: const [ IsoValue(50, StopType.full), IsoValue(100, StopType.full), IsoValue(200, StopType.full), IsoValue(250, StopType.third), IsoValue(400, StopType.full), IsoValue(500, StopType.third), IsoValue(800, StopType.full), IsoValue(1600, StopType.full), IsoValue(3200, StopType.full), ], lensZoom: 1.91, ), EquipmentProfile( id: '2', name: 'Praktica + Jupiter', apertureValues: ApertureValue.values.sublist( ApertureValue.values.indexOf(const ApertureValue(3.5, StopType.third)), ApertureValue.values.indexOf(const ApertureValue(22, StopType.full)) + 1, ), ndValues: const [ NdValue(0), NdValue(2), NdValue(4), NdValue(8), ], shutterSpeedValues: ShutterSpeedValue.values.sublist( ShutterSpeedValue.values.indexOf(const ShutterSpeedValue(1000, true, StopType.full)), ShutterSpeedValue.values.indexOf(const ShutterSpeedValue(1, false, StopType.full)) + 1, ), isoValues: const [ IsoValue(50, StopType.full), IsoValue(100, StopType.full), IsoValue(200, StopType.full), IsoValue(250, StopType.third), IsoValue(400, StopType.full), IsoValue(500, StopType.third), IsoValue(800, StopType.full), IsoValue(1600, StopType.full), IsoValue(3200, StopType.full), ], lensZoom: 5.02, ), ]; const mockFilms = [_MockFilm(100, 2), _MockFilm(400, 2), _MockFilm(3, 800), _MockFilm(400, 1.5)]; class _MockFilm extends Film { final double reciprocityMultiplier; const _MockFilm(int iso, this.reciprocityMultiplier) : super('Mock film $iso x$reciprocityMultiplier', iso); @override double reciprocityFormula(double t) => t * reciprocityMultiplier; }