Unverified Commit 0fdc4e88 authored by Jenn Magder's avatar Jenn Magder Committed by GitHub

Revert "Remove a dynamic that is no longer necessary (and the TODO for it) (#80294)" (#80326)

This reverts commit 12ec7dc8.
parent fbf3c4e4
...@@ -55,7 +55,8 @@ enum KeyEventResult { ...@@ -55,7 +55,8 @@ enum KeyEventResult {
/// ///
/// Returns a [KeyEventResult] that describes how, and whether, the key event /// Returns a [KeyEventResult] that describes how, and whether, the key event
/// was handled. /// was handled.
typedef FocusOnKeyCallback = KeyEventResult Function(FocusNode node, RawKeyEvent event); // TODO(gspencergoog): Convert this from dynamic to KeyEventResult once migration is complete.
typedef FocusOnKeyCallback = dynamic Function(FocusNode node, RawKeyEvent event);
/// An attachment point for a [FocusNode]. /// An attachment point for a [FocusNode].
/// ///
...@@ -1673,18 +1674,33 @@ class FocusManager with DiagnosticableTreeMixin, ChangeNotifier { ...@@ -1673,18 +1674,33 @@ class FocusManager with DiagnosticableTreeMixin, ChangeNotifier {
bool handled = false; bool handled = false;
for (final FocusNode node in <FocusNode>[_primaryFocus!, ..._primaryFocus!.ancestors]) { for (final FocusNode node in <FocusNode>[_primaryFocus!, ..._primaryFocus!.ancestors]) {
if (node.onKey != null) { if (node.onKey != null) {
final KeyEventResult result = node.onKey!(node, event); // TODO(gspencergoog): Convert this from dynamic to KeyEventResult once migration is complete.
switch (result) { final dynamic result = node.onKey!(node, event);
case KeyEventResult.handled: assert(
result is bool || result is KeyEventResult,
'Value returned from onKey handler must be a non-null bool or KeyEventResult, not ${result.runtimeType}',
);
if (result is KeyEventResult) {
switch (result) {
case KeyEventResult.handled:
assert(_focusDebug('Node $node handled key event $event.'));
handled = true;
break;
case KeyEventResult.skipRemainingHandlers:
assert(_focusDebug('Node $node stopped key event propagation: $event.'));
handled = false;
break;
case KeyEventResult.ignored:
continue;
}
} else if (result is bool){
if (result) {
assert(_focusDebug('Node $node handled key event $event.')); assert(_focusDebug('Node $node handled key event $event.'));
handled = true; handled = true;
break; break;
case KeyEventResult.skipRemainingHandlers: } else {
assert(_focusDebug('Node $node stopped key event propagation: $event.'));
handled = false;
break;
case KeyEventResult.ignored:
continue; continue;
}
} }
break; break;
} }
......
...@@ -1596,7 +1596,7 @@ void main() { ...@@ -1596,7 +1596,7 @@ void main() {
bool? keyEventHandled; bool? keyEventHandled;
await tester.pumpWidget( await tester.pumpWidget(
Focus( Focus(
onKey: (_, __) => KeyEventResult.ignored, // This one does nothing. onKey: (_, __) => true, // This one does nothing.
focusNode: focusNode, focusNode: focusNode,
child: Container(key: key1), child: Container(key: key1),
), ),
...@@ -1611,7 +1611,7 @@ void main() { ...@@ -1611,7 +1611,7 @@ void main() {
Focus( Focus(
onKey: (FocusNode node, RawKeyEvent event) { // The updated handler handles the key. onKey: (FocusNode node, RawKeyEvent event) { // The updated handler handles the key.
keyEventHandled = true; keyEventHandled = true;
return KeyEventResult.handled; return true;
}, },
focusNode: focusNode, focusNode: focusNode,
child: Container(key: key1), child: Container(key: key1),
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment