// Copyright 2013 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 ASH_SHELF_SHELF_DELEGATE_H_
#define ASH_SHELF_SHELF_DELEGATE_H_
#include "ash/ash_export.h"
#include "ash/shelf/shelf_item_types.h"
namespace ash {
class Shelf;
// Delegate for the Shelf.
class ASH_EXPORT ShelfDelegate {
public:
// Shelf owns the delegate.
virtual ~ShelfDelegate() {}
// Callback used to allow delegate to perform initialization actions that
// depend on the Shelf being in a known state.
virtual void OnShelfCreated(Shelf* shelf) = 0;
// Callback used to inform the delegate that a specific shelf no longer
// exists.
virtual void OnShelfDestroyed(Shelf* shelf) = 0;
// Get the shelf ID from an application ID.
virtual ShelfID GetShelfIDForAppID(const std::string& app_id) = 0;
// Get the application ID for a given shelf ID.
virtual const std::string& GetAppIDForShelfID(ShelfID id) = 0;
// Pins an app with |app_id| to shelf. A running instance will get pinned.
// In case there is no running instance a new shelf item is created and
// pinned.
virtual void PinAppWithID(const std::string& app_id) = 0;
// Check if the app with |app_id_| is pinned to the shelf.
virtual bool IsAppPinned(const std::string& app_id) = 0;
// Checks whether the user is allowed to pin/unpin apps. Pinning may be
// disallowed by policy in case there is a pre-defined set of pinned apps.
virtual bool CanPin() const = 0;
// Unpins app item with |app_id|.
virtual void UnpinAppWithID(const std::string& app_id) = 0;
};
} // namespace ash
#endif // ASH_SHELF_SHELF_DELEGATE_H_