| // Copyright 2019 The Chromium Authors. All rights reserved. |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| |
| #ifndef CHROME_BROWSER_UI_WEB_APPLICATIONS_APP_BROWSER_CONTROLLER_H_ |
| #define CHROME_BROWSER_UI_WEB_APPLICATIONS_APP_BROWSER_CONTROLLER_H_ |
| |
| #include <memory> |
| #include <string> |
| |
| #include "base/macros.h" |
| #include "base/optional.h" |
| #include "base/strings/string16.h" |
| #include "chrome/browser/ui/tabs/tab_strip_model_observer.h" |
| #include "content/public/browser/web_contents_observer.h" |
| #include "third_party/skia/include/core/SkColor.h" |
| |
| class Browser; |
| |
| namespace gfx { |
| class ImageSkia; |
| } |
| |
| namespace web_app { |
| |
| // Returns true if |app_url| and |page_url| are the same origin. To avoid |
| // breaking Hosted Apps and Bookmark Apps that might redirect to sites in the |
| // same domain but with "www.", this returns true if |page_url| is secure and in |
| // the same origin as |app_url| with "www.". |
| bool IsSameHostAndPort(const GURL& app_url, const GURL& page_url); |
| |
| // Class to encapsulate logic to control the browser UI for web apps. |
| class AppBrowserController : public TabStripModelObserver, |
| public content::WebContentsObserver { |
| public: |
| ~AppBrowserController() override; |
| |
| static std::unique_ptr<AppBrowserController> MaybeCreateWebAppController( |
| Browser* browser); |
| |
| // Returns whether |browser| uses the experimental hosted app experience. |
| // Convenience wrapper for checking IsForExperimentalWebAppBrowser() on |
| // |browser|'s HostedAppBrowserController if it exists. |
| static bool IsForWebAppBrowser(const Browser* browser); |
| |
| // Renders |url|'s origin as Unicode. |
| static base::string16 FormatUrlOrigin(const GURL& url); |
| |
| // Returns whether this controller was created for an installed PWA. |
| virtual bool IsHostedApp() const; |
| |
| virtual base::Optional<std::string> GetAppId() const = 0; |
| |
| // Returns true if the associated Hosted App is for a PWA. |
| virtual bool CreatedForInstalledPwa() const; |
| |
| // Whether the custom tab bar should be visible. |
| virtual bool ShouldShowCustomTabBar() const = 0; |
| |
| // Whether the browser should include the tab strip. |
| virtual bool HasTabStrip() const; |
| |
| // Whether the browser toolbar is present. |
| // Note: web app windows have their browser toolbar inline in their titlebar. |
| virtual bool HasTitlebarToolbar() const; |
| |
| // Whether to show app origin text in the titlebar toolbar. |
| virtual bool HasTitlebarAppOriginText() const; |
| |
| // Whether to show content settings in the titlebar toolbar. |
| virtual bool HasTitlebarContentSettings() const; |
| |
| // Returns the app icon for the window to use in the task list. |
| virtual gfx::ImageSkia GetWindowAppIcon() const = 0; |
| |
| // Returns the icon to be displayed in the window title bar. |
| virtual gfx::ImageSkia GetWindowIcon() const = 0; |
| |
| // Returns the color of the title bar. |
| virtual base::Optional<SkColor> GetThemeColor() const; |
| |
| // Returns the title to be displayed in the window title bar. |
| virtual base::string16 GetTitle() const; |
| |
| // Gets the short name of the app. |
| virtual std::string GetAppShortName() const = 0; |
| |
| // Gets the origin of the app start url suitable for display (e.g |
| // example.com.au). |
| virtual base::string16 GetFormattedUrlOrigin() const = 0; |
| |
| // Gets the launch url for the app. |
| virtual GURL GetAppLaunchURL() const = 0; |
| |
| // Determines whether the specified url is 'inside' the app |this| controls. |
| virtual bool IsUrlInAppScope(const GURL& url) const = 0; |
| |
| virtual bool CanUninstall() const; |
| |
| virtual void Uninstall(); |
| |
| // Returns whether the app is installed (uninstallation may complete within |
| // the lifetime of HostedAppBrowserController). |
| virtual bool IsInstalled() const; |
| |
| // Updates the custom tab bar's visibility based on whether it should be |
| // currently visible or not. If |animate| is set, the change will be |
| // animated. |
| void UpdateCustomTabBarVisibility(bool animate) const; |
| |
| // Returns true if this controller is for a System Web App. |
| bool IsForSystemWebApp() const; |
| |
| Browser* browser() const { return browser_; } |
| |
| // Gets the url that the app browser controller was created with. Note: This |
| // may be empty until the web contents begins navigating. |
| const GURL& initial_url() const { return initial_url_; } |
| |
| // content::WebContentsObserver: |
| void DidStartNavigation(content::NavigationHandle* handle) override; |
| void DidChangeThemeColor(base::Optional<SkColor> theme_color) override; |
| |
| // TabStripModelObserver: |
| void OnTabStripModelChanged( |
| TabStripModel* tab_strip_model, |
| const TabStripModelChange& change, |
| const TabStripSelectionChange& selection) override; |
| |
| protected: |
| explicit AppBrowserController(Browser* browser); |
| |
| // Called once the app browser controller has determined its initial url. |
| virtual void OnReceivedInitialURL() {} |
| |
| // Called by OnTabstripModelChanged(). |
| virtual void OnTabInserted(content::WebContents* contents); |
| virtual void OnTabRemoved(content::WebContents* contents); |
| |
| private: |
| // Sets the url that the app browser controller was created with. |
| void SetInitialURL(const GURL& initial_url); |
| |
| Browser* const browser_; |
| GURL initial_url_; |
| |
| DISALLOW_COPY_AND_ASSIGN(AppBrowserController); |
| }; |
| |
| } // namespace web_app |
| |
| #endif // CHROME_BROWSER_UI_WEB_APPLICATIONS_APP_BROWSER_CONTROLLER_H_ |