blob: 5be706373e3e5a619044db5006b9f605e614813f [file] [log] [blame]
// Copyright (c) 2012 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_ANDROID_TAB_MODEL_TAB_MODEL_H_
#define CHROME_BROWSER_UI_ANDROID_TAB_MODEL_TAB_MODEL_H_
#include <memory>
#include "base/macros.h"
#include "chrome/browser/ui/android/tab_model/android_live_tab_context.h"
#include "components/sessions/core/session_id.h"
#include "components/sync_sessions/synced_window_delegate.h"
#include "components/toolbar/toolbar_model.h"
#include "components/toolbar/toolbar_model_delegate.h"
#include "content/public/browser/notification_observer.h"
#include "content/public/browser/notification_registrar.h"
namespace browser_sync {
class SyncedWindowDelegateAndroid;
}
namespace content {
class WebContents;
}
namespace sync_sessions {
class SyncedWindowDelegate;
}
class Profile;
class TabAndroid;
class TabModelObserver;
// Abstract representation of a Tab Model for Android. Since Android does
// not use Browser/BrowserList, this is required to allow Chrome to interact
// with Android's Tabs and Tab Model.
class TabModel : public content::NotificationObserver {
public:
// TODO(chrisha): Clean up these enums so that the Java ones are generated
// from them.
// https://chromium.googlesource.com/chromium/src/+/lkcr/docs/android_accessing_cpp_enums_in_java.md
// Various ways tabs can be launched. See TabModel.java.
enum class TabLaunchType {
FROM_LINK,
FROM_EXTERNAL_APP,
FROM_CHROME_UI,
FROM_RESTORE,
FROM_LONGPRESS_FOREGROUND,
FROM_LONGPRESS_BACKGROUND,
FROM_REPARENTING,
FROM_LAUNCHER_SHORTCUT,
FROM_SPECULATIVE_BACKGROUND_CREATION,
FROM_BROWSER_ACTIONS,
// Must be last.
SIZE
};
// Various ways tabs can be selected. See TabModel.java.
enum class TabSelectionType {
FROM_CLOSE,
FROM_EXIT,
FROM_NEW,
FROM_USER,
// Must be last.
SIZE
};
virtual Profile* GetProfile() const;
virtual bool IsOffTheRecord() const;
virtual sync_sessions::SyncedWindowDelegate* GetSyncedWindowDelegate() const;
virtual SessionID GetSessionId() const;
virtual sessions::LiveTabContext* GetLiveTabContext() const;
virtual int GetTabCount() const = 0;
virtual int GetActiveIndex() const = 0;
virtual content::WebContents* GetActiveWebContents() const;
virtual content::WebContents* GetWebContentsAt(int index) const = 0;
// This will return NULL if the tab has not yet been initialized.
virtual TabAndroid* GetTabAt(int index) const = 0;
virtual void SetActiveIndex(int index) = 0;
virtual void CloseTabAt(int index) = 0;
// Used for restoring tabs from synced foreign sessions.
virtual void CreateTab(TabAndroid* parent,
content::WebContents* web_contents,
int parent_tab_id) = 0;
// Used by Developer Tools to create a new tab with a given URL.
// Replaces CreateTabForTesting.
virtual content::WebContents* CreateNewTabForDevTools(const GURL& url) = 0;
// Return true if we are currently restoring sessions asynchronously.
virtual bool IsSessionRestoreInProgress() const = 0;
// Return true if this class is the currently selected in the correspond
// tab model selector.
virtual bool IsCurrentModel() const = 0;
// Adds an observer to this TabModel.
virtual void AddObserver(TabModelObserver* observer) = 0;
// Removes an observer from this TabModel.
virtual void RemoveObserver(TabModelObserver* observer) = 0;
protected:
explicit TabModel(Profile* profile, bool is_tabbed_activity);
~TabModel() override;
// Instructs the TabModel to broadcast a notification that all tabs are now
// loaded from storage.
void BroadcastSessionRestoreComplete();
ToolbarModel* GetToolbarModel();
private:
// Determines how TabModel will interact with the profile.
void Observe(int type,
const content::NotificationSource& source,
const content::NotificationDetails& details) override;
// The profile associated with this TabModel.
Profile* profile_;
// The LiveTabContext associated with TabModel.
// Used to restore closed tabs through the TabRestoreService.
std::unique_ptr<AndroidLiveTabContext> live_tab_context_;
// Describes if this TabModel contains an off-the-record profile.
bool is_off_the_record_;
// The SyncedWindowDelegate associated with this TabModel.
std::unique_ptr<browser_sync::SyncedWindowDelegateAndroid>
synced_window_delegate_;
// Unique identifier of this TabModel for session restore. This id is only
// unique within the current session, and is not guaranteed to be unique
// across sessions.
SessionID session_id_;
// The Registrar used to register TabModel for notifications.
content::NotificationRegistrar registrar_;
DISALLOW_COPY_AND_ASSIGN(TabModel);
};
#endif // CHROME_BROWSER_UI_ANDROID_TAB_MODEL_TAB_MODEL_H_