Unverified Commit 9d688313 authored by Justin McCandless's avatar Justin McCandless Committed by GitHub

Remove unused context parameter (#124254)

Tidying up the spell check API.
parent 39becb77
...@@ -45,7 +45,6 @@ class CupertinoSpellCheckSuggestionsToolbar extends StatelessWidget { ...@@ -45,7 +45,6 @@ class CupertinoSpellCheckSuggestionsToolbar extends StatelessWidget {
/// Builds the button items for the toolbar based on the available /// Builds the button items for the toolbar based on the available
/// spell check suggestions. /// spell check suggestions.
static List<ContextMenuButtonItem>? buildButtonItems( static List<ContextMenuButtonItem>? buildButtonItems(
BuildContext context,
EditableTextState editableTextState, EditableTextState editableTextState,
) { ) {
// Determine if composing region is misspelled. // Determine if composing region is misspelled.
...@@ -58,8 +57,9 @@ class CupertinoSpellCheckSuggestionsToolbar extends StatelessWidget { ...@@ -58,8 +57,9 @@ class CupertinoSpellCheckSuggestionsToolbar extends StatelessWidget {
return null; return null;
} }
if (spanAtCursorIndex.suggestions.isEmpty) { if (spanAtCursorIndex.suggestions.isEmpty) {
assert(debugCheckHasCupertinoLocalizations(context)); assert(debugCheckHasCupertinoLocalizations(editableTextState.context));
final CupertinoLocalizations localizations = CupertinoLocalizations.of(context); final CupertinoLocalizations localizations =
CupertinoLocalizations.of(editableTextState.context);
return <ContextMenuButtonItem>[ return <ContextMenuButtonItem>[
ContextMenuButtonItem( ContextMenuButtonItem(
onPressed: () {}, onPressed: () {},
......
...@@ -802,7 +802,7 @@ class CupertinoTextField extends StatefulWidget { ...@@ -802,7 +802,7 @@ class CupertinoTextField extends StatefulWidget {
EditableTextState editableTextState, EditableTextState editableTextState,
) { ) {
final List<ContextMenuButtonItem>? buttonItems = final List<ContextMenuButtonItem>? buttonItems =
CupertinoSpellCheckSuggestionsToolbar.buildButtonItems(context, editableTextState); CupertinoSpellCheckSuggestionsToolbar.buildButtonItems(editableTextState);
if (buttonItems == null || buttonItems.isEmpty){ if (buttonItems == null || buttonItems.isEmpty){
return const SizedBox.shrink(); return const SizedBox.shrink();
......
...@@ -62,7 +62,6 @@ class SpellCheckSuggestionsToolbar extends StatelessWidget { ...@@ -62,7 +62,6 @@ class SpellCheckSuggestionsToolbar extends StatelessWidget {
/// Builds the button items for the toolbar based on the available /// Builds the button items for the toolbar based on the available
/// spell check suggestions. /// spell check suggestions.
static List<ContextMenuButtonItem>? buildButtonItems( static List<ContextMenuButtonItem>? buildButtonItems(
BuildContext context,
EditableTextState editableTextState, EditableTextState editableTextState,
) { ) {
// Determine if composing region is misspelled. // Determine if composing region is misspelled.
......
...@@ -816,7 +816,7 @@ class TextField extends StatefulWidget { ...@@ -816,7 +816,7 @@ class TextField extends StatefulWidget {
final Offset anchor = final Offset anchor =
SpellCheckSuggestionsToolbar.getToolbarAnchor(editableTextState.contextMenuAnchors); SpellCheckSuggestionsToolbar.getToolbarAnchor(editableTextState.contextMenuAnchors);
final List<ContextMenuButtonItem>? buttonItems = final List<ContextMenuButtonItem>? buttonItems =
SpellCheckSuggestionsToolbar.buildButtonItems(context, editableTextState); SpellCheckSuggestionsToolbar.buildButtonItems(editableTextState);
if (buttonItems == null){ if (buttonItems == null){
return const SizedBox.shrink(); return const SizedBox.shrink();
......
// Copyright 2014 The Flutter Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
import 'package:flutter/cupertino.dart';
import 'package:flutter/services.dart';
import 'package:flutter_test/flutter_test.dart';
void main() {
TestWidgetsFlutterBinding.ensureInitialized();
testWidgets('buildButtonItems builds a "No Replacements Found" button when no suggestions', (WidgetTester tester) async {
await tester.pumpWidget(
CupertinoApp(
home: _FakeEditableText(),
),
);
final _FakeEditableTextState editableTextState =
tester.state(find.byType(_FakeEditableText));
final List<ContextMenuButtonItem>? buttonItems =
CupertinoSpellCheckSuggestionsToolbar.buildButtonItems(editableTextState);
expect(buttonItems, isNotNull);
expect(buttonItems!.length, 1);
expect(buttonItems.first.label, 'No Replacements Found');
});
}
class _FakeEditableText extends EditableText {
_FakeEditableText() : super(
controller: TextEditingController(),
focusNode: FocusNode(),
backgroundCursorColor: CupertinoColors.white,
cursorColor: CupertinoColors.white,
style: const TextStyle(),
);
@override
_FakeEditableTextState createState() => _FakeEditableTextState();
}
class _FakeEditableTextState extends EditableTextState {
@override
TextEditingValue get currentTextEditingValue => TextEditingValue.empty;
@override
SuggestionSpan? findSuggestionSpanAtCursorIndex(int cursorIndex) {
return const SuggestionSpan(
TextRange(
start: 0,
end: 0,
),
<String>[],
);
}
}
...@@ -4,6 +4,7 @@ ...@@ -4,6 +4,7 @@
import 'package:flutter/cupertino.dart' show CupertinoTextSelectionToolbar; import 'package:flutter/cupertino.dart' show CupertinoTextSelectionToolbar;
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:flutter/services.dart';
import 'package:flutter_test/flutter_test.dart'; import 'package:flutter_test/flutter_test.dart';
// Vertical position at which to anchor the toolbar for testing. // Vertical position at which to anchor the toolbar for testing.
...@@ -85,4 +86,29 @@ void main() { ...@@ -85,4 +86,29 @@ void main() {
final double toolbarY = tester.getTopLeft(findSpellCheckSuggestionsToolbar()).dy; final double toolbarY = tester.getTopLeft(findSpellCheckSuggestionsToolbar()).dy;
expect(toolbarY, equals(expectedToolbarY)); expect(toolbarY, equals(expectedToolbarY));
}); });
test('buildButtonItems builds only a delete button when no suggestions', () {
final _FakeEditableTextState editableTextState = _FakeEditableTextState();
final List<ContextMenuButtonItem>? buttonItems =
SpellCheckSuggestionsToolbar.buildButtonItems(editableTextState);
expect(buttonItems, hasLength(1));
expect(buttonItems!.first.type, ContextMenuButtonType.delete);
});
}
class _FakeEditableTextState extends EditableTextState {
@override
TextEditingValue get currentTextEditingValue => TextEditingValue.empty;
@override
SuggestionSpan? findSuggestionSpanAtCursorIndex(int cursorIndex) {
return const SuggestionSpan(
TextRange(
start: 0,
end: 0,
),
<String>[],
);
}
} }
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