chromium/chrome/browser/ui/ash/keyboard/chrome_keyboard_web_contents.h

// Copyright 2018 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

#ifndef CHROME_BROWSER_UI_ASH_KEYBOARD_CHROME_KEYBOARD_WEB_CONTENTS_H_
#define CHROME_BROWSER_UI_ASH_KEYBOARD_CHROME_KEYBOARD_WEB_CONTENTS_H_

#include <memory>

#include "ash/style/ash_color_provider_source.h"
#include "base/functional/callback.h"
#include "base/memory/weak_ptr.h"
#include "content/public/browser/web_contents_observer.h"
#include "ui/aura/window_observer.h"
#include "ui/gfx/geometry/size.h"

class GURL;

namespace content {
class WebContents;
}

class ChromeKeyboardBoundsObserver;

// WebContents manager for the virtual keyboard. This observes the web
// contents, manages the content::HostZoomMap, and informs the virtual
// keyboard controller when the contents have loaded. It also provides a
// WebContentsDelegate implementation.
class ChromeKeyboardWebContents : public content::WebContentsObserver,
                                  public aura::WindowObserver {
 public:
  using LoadCallback = base::OnceCallback<void()>;
  using UnembedCallback = base::RepeatingClosure;

  // Immediately starts loading |url| in a WebContents. |load_callback| is
  // called when the WebContents finishes loading. |unembed_callback| is only
  // used when the content is embedded using Window Service and is called when
  // it gets unembedded (e.g. the hosting window is closed). Note that
  // |unembed_callback| might end up deleting this.
  ChromeKeyboardWebContents(content::BrowserContext* context,
                            const GURL& url,
                            LoadCallback load_callback,
                            UnembedCallback unembed_callback);

  ChromeKeyboardWebContents(const ChromeKeyboardWebContents&) = delete;
  ChromeKeyboardWebContents& operator=(const ChromeKeyboardWebContents&) =
      delete;

  ~ChromeKeyboardWebContents() override;

  // Updates the keyboard URL if |url| does not match the existing url.
  void SetKeyboardUrl(const GURL& url);

  // Called via ash.mojo.KeyboardControllerObserver to provide an initial
  // size for the keyboard contents, necessary to trigger SetContentsBounds
  // in the delegate.
  void SetInitialContentsSize(const gfx::Size& size);

  // Provide access to the native view (aura::Window) and frame
  // (RenderWidgetHostView) through WebContents. TODO(stevenjb): Remove this
  // once host window ownership is moved to ash.
  content::WebContents* web_contents() { return web_contents_.get(); }

 private:
  // content::WebContentsObserver overrides
  void RenderFrameCreated(content::RenderFrameHost* frame_host) override;
  void DidStopLoading() override;
  void OnColorProviderChanged() override;

  // Loads the web contents for the given |url|.
  void LoadContents(const GURL& url);

  // aura::WindowObserver
  void OnWindowBoundsChanged(aura::Window* window,
                             const gfx::Rect& old_bounds,
                             const gfx::Rect& new_bounds,
                             ui::PropertyChangeReason reason) override;

  ash::AshColorProviderSource color_provider_source_;

  std::unique_ptr<content::WebContents> web_contents_;
  std::unique_ptr<ChromeKeyboardBoundsObserver> window_bounds_observer_;

  // Called from DidStopLoading().
  LoadCallback load_callback_;

  // Called when content is unembedded from Window Service.
  UnembedCallback unembed_callback_;

  gfx::Size contents_size_;

  base::WeakPtrFactory<ChromeKeyboardWebContents> weak_ptr_factory_{this};
};

#endif  // CHROME_BROWSER_UI_ASH_KEYBOARD_CHROME_KEYBOARD_WEB_CONTENTS_H_