Files
GitJournal/lib/screens/settings_widgets.dart
2020-09-08 23:01:39 +02:00

99 lines
2.3 KiB
Dart

import 'package:flutter/material.dart';
import 'package:easy_localization/easy_localization.dart';
class ListPreference extends StatelessWidget {
final String title;
final String currentOption;
final List<String> options;
final Function onChange;
final bool enabled;
ListPreference({
@required this.title,
@required this.currentOption,
@required this.options,
@required this.onChange,
this.enabled = true,
});
@override
Widget build(BuildContext context) {
return ListTile(
title: Text(title),
subtitle: Text(currentOption),
onTap: () async {
var option = await showDialog<String>(
context: context,
builder: (BuildContext context) {
var children = <Widget>[];
for (var o in options) {
var tile = LabeledRadio(
label: o,
value: o,
groupValue: currentOption,
onChanged: (String val) {
Navigator.of(context).pop(val);
},
);
children.add(tile);
}
return AlertDialog(
title: Text(title),
content: Column(
children: children,
mainAxisSize: MainAxisSize.min,
),
actions: <Widget>[
FlatButton(
child: Text(tr('settings.cancel')),
onPressed: () {
Navigator.of(context).pop();
},
)
],
);
});
if (option != null) {
onChange(option);
}
},
enabled: enabled,
);
}
}
class LabeledRadio extends StatelessWidget {
const LabeledRadio({
this.label,
this.groupValue,
this.value,
this.onChanged,
});
final String label;
final String groupValue;
final String value;
final Function onChanged;
@override
Widget build(BuildContext context) {
return InkWell(
onTap: () {
if (value != groupValue) onChanged(value);
},
child: Row(
children: <Widget>[
Radio<String>(
groupValue: groupValue,
value: value,
onChanged: onChanged,
),
Text(label),
],
),
);
}
}