d4t_formulas/lib/ai/unit_dropdown.dart
Álvaro González 3c22dc06f5 feat: show unit symbol and name in dropdown options
Co-authored-by: aider (openrouter/deepseek/deepseek-r1:free) <aider@aider.chat>
2025-09-14 16:59:20 +02:00

40 lines
1.3 KiB
Dart

import 'package:flutter/material.dart';
import '../../formula_models.dart';
import '../../corpus.dart';
class UnitDropdown extends StatelessWidget {
final UnitCorpus corpus;
final VariableSpec variable;
final String? selectedUnit;
final ValueChanged<String?> onUnitChanged;
const UnitDropdown({
super.key,
required this.corpus,
required this.variable,
required this.selectedUnit,
required this.onUnitChanged,
});
@override
Widget build(BuildContext context) {
final unitNames = corpus.unitsOfSameMagnitude(variable.unit);
final availableUnits = unitNames.map((name) => corpus.get(name)).toList();
return DropdownButton<String>(
value: selectedUnit ?? variable.unit,
selectedItemBuilder: (context) => availableUnits.map((unit) => Text(unit.symbol)).toList(),
icon: const Icon(Icons.arrow_drop_down),
elevation: 16,
style: TextStyle(color: Theme.of(context).colorScheme.primary, fontSize: 14),
underline: Container(height: 1, color: Theme.of(context).dividerColor),
onChanged: onUnitChanged,
items: availableUnits.map<DropdownMenuItem<String>>((UnitSpec unit) {
return DropdownMenuItem<String>(
value: unit.name,
child: Text("${unit.symbol} - ${unit.name}", style: const TextStyle(fontSize: 14)),
);
}).toList(),
);
}
}