Skip to content
This repository was archived by the owner on Feb 25, 2025. It is now read-only.

Fix iOS password autofill prompt dismissal causes layout to resize #50364

Merged
merged 1 commit into from
Feb 5, 2024

Conversation

TahaTesser
Copy link
Member

fixes Save password prompt dismiss is pushing UI up and down

Code sample

expand to view the code sample
import 'package:flutter/material.dart';

void main() => runApp(const MyApp());

class MyApp extends StatelessWidget {
  const MyApp({super.key});

  @override
  Widget build(BuildContext context) {
    return const MaterialApp(
      debugShowCheckedModeBanner: false,
      home: HomePage(),
    );
  }
}

class HomePage extends StatefulWidget {
  const HomePage({super.key});

  @override
  State<HomePage> createState() => _HomePageState();
}

class _HomePageState extends State<HomePage> {
  final TextEditingController controller1 = TextEditingController();
  final TextEditingController controller2 = TextEditingController();

  @override
  void dispose() {
    controller1.dispose();
    controller2.dispose();
    super.dispose();
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold( // Replace Scaffold with Material to fix glitch.
      body: Center(
        child: Column(
          mainAxisSize: MainAxisSize.min,
          children: <Widget>[
            const Text('Login (Without Scaffold)'),
            AutofillGroup(
              child: Column(
                children: <Widget>[
                  TextField(
                    controller: controller1,
                    autofillHints: const <String>[AutofillHints.username],
                  ),
                  TextField(
                    controller: controller2,
                    autofillHints: const <String>[AutofillHints.password],
                  ),
                ],
              ),
            ),
          ],
        ),
      ),
    );
  }
}

Before

RPReplay_Final1707164728.mov

After

RPReplay_Final1707164662.mov

Pre-launch Checklist

  • I read the Contributor Guide and followed the process outlined there for submitting PRs.
  • I read the Tree Hygiene wiki page, which explains my responsibilities.
  • I read and followed the Flutter Style Guide and the C++, Objective-C, Java style guides.
  • I listed at least one issue that this PR fixes in the description above.
  • I added new tests to check the change I am making or feature I am adding, or the PR is test-exempt. See testing the engine for instructions on writing and running engine tests.
  • I updated/added relevant documentation (doc comments with ///).
  • I signed the CLA.
  • All existing and new tests are passing.

If you need help, consider asking for advice on the #hackers-new channel on Discord.

@TahaTesser TahaTesser marked this pull request as ready for review February 5, 2024 21:05
@TahaTesser TahaTesser requested a review from justinmc February 5, 2024 21:05
Copy link
Contributor

@justinmc justinmc left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM 👍

@@ -1520,6 +1520,15 @@ - (void)handleKeyboardNotification:(NSNotification*)notification {
BOOL keyboardAnimationIsCompounding =
self.keyboardAnimationIsShowing == keyboardWillShow && _keyboardAnimationVSyncClient != nil;

// Avoid triggering startKeyBoardAnimation when keyboard notifications are triggered
// by the dismissal of password autofill prompt. When this happens, there is
// no keyboard on the screen and FlutterTextInputViewAccessibilityHider is nil.
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Nice.

@TahaTesser TahaTesser force-pushed the fix_iOS_password_prompt_bug branch from bf3ea6f to d674797 Compare February 5, 2024 21:18
@TahaTesser TahaTesser added the autosubmit Merge PR when tree becomes green via auto submit App label Feb 5, 2024
@auto-submit auto-submit bot merged commit 472df41 into flutter:main Feb 5, 2024
@TahaTesser TahaTesser deleted the fix_iOS_password_prompt_bug branch February 5, 2024 22:02
engine-flutter-autoroll added a commit to engine-flutter-autoroll/flutter that referenced this pull request Feb 6, 2024
auto-submit bot pushed a commit to flutter/flutter that referenced this pull request Feb 6, 2024
…142954)

flutter/engine@9bd98bc...9c1b6c9

2024-02-05 [email protected] Manual roll Dart SDK from 5a5d4c262200 to b62066b42af0 (5 revisions) (flutter/engine#50366)
2024-02-05 [email protected] Fix iOS password autofill prompt dismissal causes layout to resize (flutter/engine#50364)
2024-02-05 [email protected] `visiblePassword` uses ASCII keyboard on iOS (flutter/engine#50293)
2024-02-05 [email protected] [Impeller] Do not reference `this` in the submit callback for Metal GPU Surfaces (flutter/engine#50361)

If this roll has caused a breakage, revert this CL and stop the roller
using the controls here:
https://autoroll.skia.org/r/flutter-engine-flutter-autoroll
Please CC [email protected],[email protected],[email protected] on the revert to ensure that a human
is aware of the problem.

To file a bug in Flutter: https://github.com/flutter/flutter/issues/new/choose

To report a problem with the AutoRoller itself, please file a bug:
https://issues.skia.org/issues/new?component=1389291&template=1850622

Documentation for the AutoRoller is here:
https://skia.googlesource.com/buildbot/+doc/main/autoroll/README.md
@TahaTesser
Copy link
Member Author

Reverting this since this is causing a regression for text field created by a third-party package.

@TahaTesser TahaTesser added the revert Label used to revert changes in a closed and merged pull request. label Feb 19, 2024
Copy link
Contributor

auto-submit bot commented Feb 19, 2024

Time to revert pull request flutter/engine/50364 has elapsed.
You need to open the revert manually and process as a regular pull request.

@auto-submit auto-submit bot removed the revert Label used to revert changes in a closed and merged pull request. label Feb 19, 2024
TahaTesser added a commit to TahaTesser/engine that referenced this pull request Feb 19, 2024
@TahaTesser
Copy link
Member Author

Reverting this manually in #50760

auto-submit bot pushed a commit that referenced this pull request Feb 19, 2024
…esize (#50364)" (#50760)

This reverts commit 472df41.

Reverts #50364

fixes flutter/flutter#143642

*Replace this paragraph with a description of what this PR is changing or adding, and why. Consider including before/after screenshots.*

*List which issues are fixed by this PR. You must list at least one issue.*

*If you had to change anything in the [flutter/tests] repo, include a link to the migration guide as per the [breaking change policy].*

[C++, Objective-C, Java style guides]: https://github.com/flutter/engine/blob/main/CONTRIBUTING.md#style
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
autosubmit Merge PR when tree becomes green via auto submit App platform-ios
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Save password prompt dismiss is pushing UI up and down
2 participants