mirror of
https://github.com/GitJournal/GitJournal.git
synced 2025-09-10 13:08:24 +08:00
99 lines
2.3 KiB
Dart
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),
|
|
],
|
|
),
|
|
);
|
|
}
|
|
}
|