nc-photos/app/lib/widget/slideshow_dialog.dart

216 lines
6.5 KiB
Dart
Raw Normal View History

2021-09-14 23:00:24 +02:00
import 'package:flutter/material.dart';
import 'package:logging/logging.dart';
import 'package:nc_photos/app_localizations.dart';
import 'package:nc_photos/k.dart' as k;
import 'package:nc_photos/snack_bar_manager.dart';
2022-12-16 16:01:04 +01:00
import 'package:np_codegen/np_codegen.dart';
2023-08-25 17:29:27 +02:00
import 'package:np_math/np_math.dart';
import 'package:np_ui/np_ui.dart';
2022-12-08 16:39:13 +01:00
import 'package:to_string/to_string.dart';
2021-09-14 23:00:24 +02:00
2022-12-08 16:39:13 +01:00
part 'slideshow_dialog.g.dart';
@toString
2021-09-14 23:00:24 +02:00
class SlideshowConfig {
2024-07-09 19:00:24 +02:00
const SlideshowConfig({
2021-09-14 23:00:24 +02:00
required this.duration,
required this.isShuffle,
required this.isRepeat,
2022-10-16 10:48:39 +02:00
required this.isReverse,
2021-09-14 23:00:24 +02:00
});
@override
2022-12-08 16:39:13 +01:00
String toString() => _$toString();
2021-09-14 23:00:24 +02:00
/// Time where each item is shown
final Duration duration;
/// Whether to shuffle the items
final bool isShuffle;
/// Whether to repeat the slideshow after finishing
final bool isRepeat;
2022-10-16 10:48:39 +02:00
/// Whether to show the items in reverse order
final bool isReverse;
2021-09-14 23:00:24 +02:00
}
class SlideshowDialog extends StatefulWidget {
2021-09-15 08:58:06 +02:00
const SlideshowDialog({
2024-05-28 17:10:33 +02:00
super.key,
2021-09-14 23:00:24 +02:00
required this.duration,
required this.isShuffle,
required this.isRepeat,
2022-10-16 10:48:39 +02:00
required this.isReverse,
2024-05-28 17:10:33 +02:00
});
2021-09-14 23:00:24 +02:00
@override
createState() => _SlideshowDialogState();
final Duration duration;
final bool isShuffle;
final bool isRepeat;
2022-10-16 10:48:39 +02:00
final bool isReverse;
2021-09-14 23:00:24 +02:00
}
2022-12-16 16:01:04 +01:00
@npLog
2021-09-14 23:00:24 +02:00
class _SlideshowDialogState extends State<SlideshowDialog> {
@override
initState() {
super.initState();
_durationSecond = widget.duration.inSeconds % 60;
_durationMinute = widget.duration.inMinutes;
}
@override
build(BuildContext context) {
return AlertDialog(
title: Text(L10n.global().slideshowSetupDialogTitle),
content: Form(
key: _formKey,
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
mainAxisSize: MainAxisSize.min,
children: [
Text(
L10n.global().slideshowSetupDialogDurationTitle,
2023-05-26 13:45:46 +02:00
style: Theme.of(context).textTheme.titleSmall,
2021-09-14 23:00:24 +02:00
),
Row(
children: [
Flexible(
2022-07-08 16:52:18 +02:00
flex: 1,
2021-09-14 23:00:24 +02:00
child: TextFormField(
decoration: InputDecoration(
hintText: L10n.global().timeMinuteInputHint,
),
keyboardType: TextInputType.number,
validator: (value) {
if (_durationSecond == 0 && int.tryParse(value!) == 0) {
return L10n.global().dateTimeInputInvalid;
}
if (int.tryParse(value!)?.inRange(0, 59) == true) {
return null;
}
return L10n.global().dateTimeInputInvalid;
},
onSaved: (value) {
_formValue.minute = int.parse(value!);
},
onChanged: (value) {
try {
_durationMinute = int.parse(value);
} catch (_) {}
},
initialValue:
widget.duration.inMinutes.toString().padLeft(2, "0"),
),
),
const SizedBox(width: 4),
2021-09-15 08:58:06 +02:00
const Text(":"),
2021-09-14 23:00:24 +02:00
const SizedBox(width: 4),
Flexible(
2022-07-08 16:52:18 +02:00
flex: 1,
2021-09-14 23:00:24 +02:00
child: TextFormField(
decoration: InputDecoration(
hintText: L10n.global().timeSecondInputHint,
),
keyboardType: TextInputType.number,
validator: (value) {
if (_durationMinute == 0 && int.tryParse(value!) == 0) {
return L10n.global().dateTimeInputInvalid;
}
if (int.tryParse(value!)?.inRange(0, 59) == true) {
return null;
}
return L10n.global().dateTimeInputInvalid;
},
onSaved: (value) {
_formValue.second = int.parse(value!);
},
onChanged: (value) {
try {
_durationSecond = int.parse(value);
} catch (_) {}
},
initialValue: (widget.duration.inSeconds % 60)
.toString()
.padLeft(2, "0"),
),
),
],
),
SwitchFormField(
title: Text(L10n.global().slideshowSetupDialogShuffleTitle),
onSaved: (value) {
_formValue.isShuffle = value!;
},
initialValue: widget.isShuffle,
),
SwitchFormField(
title: Text(L10n.global().slideshowSetupDialogRepeatTitle),
onSaved: (value) {
_formValue.isRepeat = value!;
},
initialValue: widget.isRepeat,
),
2022-10-16 10:48:39 +02:00
SwitchFormField(
title: Text(L10n.global().slideshowSetupDialogReverseTitle),
onSaved: (value) {
_formValue.isReverse = value!;
},
initialValue: widget.isReverse,
),
2021-09-14 23:00:24 +02:00
],
),
),
actions: [
TextButton(
onPressed: () => _onOkPressed(context),
child: Text(MaterialLocalizations.of(context).okButtonLabel),
),
],
);
}
void _onOkPressed(BuildContext context) {
if (_formKey.currentState?.validate() == true) {
_formKey.currentState!.save();
if (_formValue.minute == 0 && _formValue.second == 0) {
// invalid
SnackBarManager().showSnackBar(SnackBar(
content: Text(L10n.global().dateTimeInputInvalid),
duration: k.snackBarDurationNormal,
));
return;
}
final product = SlideshowConfig(
duration: Duration(
minutes: _formValue.minute,
seconds: _formValue.second,
),
isShuffle: _formValue.isShuffle,
isRepeat: _formValue.isRepeat,
2022-10-16 10:48:39 +02:00
isReverse: _formValue.isReverse,
2021-09-14 23:00:24 +02:00
);
_log.info("[_onOkPressed] Config: $product");
Navigator.of(context).pop(product);
}
}
final _formKey = GlobalKey<FormState>();
final _formValue = _FormValue();
late int _durationSecond;
late int _durationMinute;
}
class _FormValue {
late int minute;
late int second;
late bool isShuffle;
late bool isRepeat;
2022-10-16 10:48:39 +02:00
late bool isReverse;
2021-09-14 23:00:24 +02:00
}