2023-04-04 10:29:29 +02:00
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
import 'package:outbag_app/backend/room.dart';
|
|
|
|
import 'package:flutter_gen/gen_l10n/app_localizations.dart';
|
|
|
|
|
|
|
|
class ProductPicker extends StatelessWidget {
|
2023-04-04 20:28:26 +02:00
|
|
|
final List<RoomProduct> products;
|
|
|
|
final int? selected;
|
|
|
|
final bool enabled;
|
|
|
|
final Function(int?)? onSelect;
|
2023-04-04 10:29:29 +02:00
|
|
|
|
|
|
|
// hint and label may differ depending on the screen
|
2023-04-04 20:28:26 +02:00
|
|
|
final String? hint;
|
|
|
|
final String? label;
|
|
|
|
final String? help;
|
2023-04-04 10:29:29 +02:00
|
|
|
|
2023-04-04 20:28:26 +02:00
|
|
|
const ProductPicker(
|
2023-12-22 20:14:36 +01:00
|
|
|
{super.key,
|
2023-04-04 20:28:26 +02:00
|
|
|
required this.products,
|
2023-04-04 10:29:29 +02:00
|
|
|
this.selected,
|
|
|
|
this.onSelect,
|
|
|
|
this.hint,
|
2023-04-04 20:28:26 +02:00
|
|
|
this.help,
|
2023-04-04 10:29:29 +02:00
|
|
|
this.label,
|
|
|
|
this.enabled = true});
|
|
|
|
|
|
|
|
@override
|
|
|
|
Widget build(BuildContext context) {
|
|
|
|
return Padding(
|
2023-12-22 20:14:36 +01:00
|
|
|
padding: const EdgeInsets.all(8),
|
|
|
|
child: DropdownButtonFormField<int?>(
|
|
|
|
hint: hint == null ? null : Text(hint!),
|
|
|
|
decoration: InputDecoration(
|
|
|
|
label: label == null ? null : Text(label!),
|
|
|
|
border: const OutlineInputBorder(),
|
|
|
|
prefixIcon: const Icon(Icons.inventory_2),
|
|
|
|
helperText: help),
|
|
|
|
value: selected,
|
|
|
|
items: [
|
|
|
|
// "no product" entry
|
|
|
|
DropdownMenuItem<int?>(
|
|
|
|
value: null,
|
|
|
|
child: Text(AppLocalizations.of(context)!.productNameNone),
|
|
|
|
),
|
|
|
|
// other products
|
|
|
|
...products.map((product) => DropdownMenuItem<int?>(
|
|
|
|
value: product.id, child: Text(product.name)))
|
|
|
|
],
|
|
|
|
onChanged: enabled
|
|
|
|
? (pid) {
|
|
|
|
if (onSelect != null) {
|
|
|
|
onSelect!(pid);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
: null,
|
|
|
|
));
|
2023-04-04 10:29:29 +02:00
|
|
|
}
|
|
|
|
}
|