import 'package:flutter/material.dart'; import 'package:lightmeter/generated/l10n.dart'; import 'package:lightmeter/res/dimens.dart'; typedef StringAdapter = String Function(BuildContext context, T value); class DialogSwitch extends StatefulWidget { final IconData icon; final String title; final String? description; final Map values; final StringAdapter titleAdapter; final StringAdapter? subtitleAdapter; final ValueChanged> onSave; const DialogSwitch({ required this.icon, required this.title, this.description, required this.values, required this.titleAdapter, this.subtitleAdapter, required this.onSave, super.key, }); @override State> createState() => _DialogSwitchState(); } class _DialogSwitchState extends State> { late final Map _features = Map.from(widget.values); @override Widget build(BuildContext context) { return AlertDialog( icon: Icon(widget.icon), titlePadding: Dimens.dialogIconTitlePadding, title: Text(widget.title), contentPadding: EdgeInsets.zero, content: SizedBox( width: double.maxFinite, child: Column( mainAxisSize: MainAxisSize.min, children: [ if (widget.description != null) ...[ Padding( padding: const EdgeInsets.symmetric(horizontal: Dimens.paddingL), child: Text(widget.description!), ), const SizedBox(height: Dimens.grid16) ], ListView( shrinkWrap: true, children: _features.entries .map( (entry) => SwitchListTile( contentPadding: EdgeInsets.symmetric(horizontal: Dimens.dialogTitlePadding.left), title: Text(widget.titleAdapter(context, entry.key)), subtitle: widget.subtitleAdapter != null ? Text( widget.subtitleAdapter!.call(context, entry.key), style: Theme.of(context).listTileTheme.subtitleTextStyle, ) : null, value: _features[entry.key]!, onChanged: (value) { setState(() { _features.update(entry.key, (_) => value); }); }, ), ) .toList(), ), ], ), ), actionsPadding: Dimens.dialogActionsPadding, actions: [ TextButton( onPressed: Navigator.of(context).pop, child: Text(S.of(context).cancel), ), TextButton( onPressed: () { widget.onSave(_features); Navigator.of(context).pop(); }, child: Text(S.of(context).save), ), ], ); } }