updateEditingValue method Null safety

  1. @override
void updateEditingValue(
  1. TextEditingValue value
)
override

Requests that this client update its editing state to the given value.

The new value is treated as user input and thus may subject to input formatting.

Implementation

@override
void updateEditingValue(TextEditingValue value) {
  // Since we still have to support keyboard select, this is the best place
  // to disable text updating.
  if (!_shouldCreateInputConnection) {
    return;
  }
  if (widget.readOnly) {
    // In the read-only case, we only care about selection changes, and reject
    // everything else.
    value = _value.copyWith(selection: value.selection);
  }
  _lastKnownRemoteTextEditingValue = value;
  value = _handleSpecialTextSpan(value);
  if (value == _value) {
    // This is possible, for example, when the numeric keyboard is input,
    // the engine will notify twice for the same value.
    // Track at https://github.com/flutter/flutter/issues/65811
    return;
  }

  if (value.text == _value.text && value.composing == _value.composing) {
    // `selection` is the only change.
    _handleSelectionChanged(value.selection, SelectionChangedCause.keyboard);
  } else {
    hideToolbar();
    _currentPromptRectRange = null;

    if (_hasInputConnection) {
      _showCaretOnScreen();
      if (widget.obscureText && value.text.length == _value.text.length + 1) {
        _obscureShowCharTicksPending = _kObscureShowLatestCharCursorTicks;
        _obscureLatestCharIndex = _value.selection.baseOffset;
      }
    }

    _formatAndSetValue(value);
  }
  if (_hasInputConnection) {
    // To keep the cursor from blinking while typing, we want to restart the
    // cursor timer every time a new character is typed.
    _stopCursorTimer(resetCharTicks: false);
    _startCursorTimer();
  }
}