[lensoverlay] Expand search stack push and pop logic.

There are two major goals for this change:
- Remove the thumbnail from the searchbox when the user clicks a related search in the SRP.
- Ensure that pushing and then popping searches from the query history stack saves and restores all necessary state that the overlay and searchbox rely on.

Theoretically, these could have been handled in separate CLs but the code is related and I think it'll be easier to review and land together.

Specifically, this CL includes the following changes:
- Renames a number of variables to be more consistently named between corresponding values in the controller and in the `SearchQuery` struct.
- Adds `additional_search_query_params_` to the `SearchQuery` struct for saving and restoring.
- Has `AddQueryToHistory` infer when a search URL looks like it was a SRP click and then clears the searchbox thumbnail and overlay selection in this case.
- Has `PopAndLoadQueryFromHistory` restore additional state so that searchbox suggestions and search URLs are correct.
- Removes `LensOverlayController::IssueObjectSelectionRequest` and downstream code, which appear to be unused.

Bug: b:340591543, b:335718601, b:341804325, 342390515
Change-Id: I71c9afbb46f7ddf653f17a07093a54184156698d
Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/5548877
Commit-Queue: Justin Donnelly <jdonnelly@chromium.org>
Code-Coverage: findit-for-me@appspot.gserviceaccount.com <findit-for-me@appspot.gserviceaccount.com>
Reviewed-by: Juan Mojica <juanmojica@google.com>
Cr-Commit-Position: refs/heads/main@{#1305205}
9 files changed
tree: 1041490a6074cba9b786465160e24239af66572c
  1. android_webview/
  2. apps/
  3. ash/
  4. base/
  5. build/
  6. build_overrides/
  7. buildtools/
  8. cc/
  9. chrome/
  10. chromecast/
  11. chromeos/
  12. codelabs/
  13. components/
  14. content/
  15. courgette/
  16. crypto/
  17. dbus/
  18. device/
  19. docs/
  20. extensions/
  21. fuchsia_web/
  22. gin/
  23. google_apis/
  24. google_update/
  25. gpu/
  26. headless/
  27. infra/
  28. ios/
  29. ipc/
  30. media/
  31. mojo/
  32. native_client_sdk/
  33. net/
  34. pdf/
  35. ppapi/
  36. printing/
  37. remoting/
  38. rlz/
  39. sandbox/
  40. services/
  41. skia/
  42. sql/
  43. storage/
  44. styleguide/
  45. testing/
  46. third_party/
  47. tools/
  48. ui/
  49. url/
  50. webkit/
  51. .clang-format
  52. .clang-tidy
  53. .clangd
  54. .eslintrc.js
  55. .git-blame-ignore-revs
  56. .gitallowed
  57. .gitattributes
  58. .gitignore
  59. .gitmodules
  60. .gn
  61. .mailmap
  62. .rustfmt.toml
  63. .vpython3
  64. .yapfignore
  65. ATL_OWNERS
  66. AUTHORS
  67. BUILD.gn
  68. CODE_OF_CONDUCT.md
  69. codereview.settings
  70. CPPLINT.cfg
  71. DEPS
  72. DIR_METADATA
  73. LICENSE
  74. LICENSE.chromium_os
  75. OWNERS
  76. PRESUBMIT.py
  77. PRESUBMIT_test.py
  78. PRESUBMIT_test_mocks.py
  79. README.md
  80. WATCHLISTS
README.md

Logo Chromium

Chromium is an open-source browser project that aims to build a safer, faster, and more stable way for all users to experience the web.

The project's web site is https://www.chromium.org.

To check out the source code locally, don't use git clone! Instead, follow the instructions on how to get the code.

Documentation in the source is rooted in docs/README.md.

Learn how to Get Around the Chromium Source Code Directory Structure.

For historical reasons, there are some small top level directories. Now the guidance is that new top level directories are for product (e.g. Chrome, Android WebView, Ash). Even if these products have multiple executables, the code should be in subdirectories of the product.

If you found a bug, please file it at https://crbug.com/new.