// Copyright 2025 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_BOOKMARKS_BOOKMARK_MERGED_SURFACE_SERVICE_OBSERVER_H_
#define CHROME_BROWSER_BOOKMARKS_BOOKMARK_MERGED_SURFACE_SERVICE_OBSERVER_H_
#include <cstddef>
#include "base/containers/flat_set.h"
#include "base/observer_list_types.h"
struct BookmarkParentFolder;
namespace bookmarks {
class BookmarkNode;
} // namespace bookmarks
class BookmarkMergedSurfaceServiceObserver : public base::CheckedObserver {
public:
~BookmarkMergedSurfaceServiceObserver() override = default;
// Invoked when the service has finished loading.
virtual void BookmarkMergedSurfaceServiceLoaded() = 0;
// Invoked from the destructor of the `BookmarkMergedSurfaceService`.
virtual void BookmarkMergedSurfaceServiceBeingDeleted() {}
// Invoked when a node has been added. If the added node has any descendants,
// `BookmarkNodeAdded` will be invoked for all of the descendants.
virtual void BookmarkNodeAdded(const BookmarkParentFolder& parent,
size_t index) = 0;
virtual void BookmarkNodesRemoved(
const BookmarkParentFolder& parent,
const base::flat_set<const bookmarks::BookmarkNode*>& nodes) = 0;
virtual void BookmarkNodeMoved(const BookmarkParentFolder& old_parent,
size_t old_index,
const BookmarkParentFolder& new_parent,
size_t new_index) = 0;
// Invoked when the title or url of a node changes.
virtual void BookmarkNodeChanged(const bookmarks::BookmarkNode* node) = 0;
// Invoked when a favicon has been loaded or changed.
virtual void BookmarkNodeFaviconChanged(
const bookmarks::BookmarkNode* node) = 0;
// Invoked when the children (just direct children, not descendants) of
// `folder` have been reordered in some way, such as sorted.
virtual void BookmarkParentFolderChildrenReordered(
const BookmarkParentFolder& folder) = 0;
// Invoked when all non-permanent bookmark nodes that are editable by the
// user have been removed.
virtual void BookmarkAllUserNodesRemoved() = 0;
// Invoked before an extensive set of model changes is about to begin.
// This tells UI intensive observers to wait until the updates finish to
// update themselves.
// Observers should still respond to BookmarkNodeRemoved immediately,
// to avoid holding onto stale node pointers.
virtual void ExtensiveBookmarkChangesBeginning() {}
// Invoked after an extensive set of model changes has ended.
// This tells observers to update themselves if they were waiting for the
// update to finish.
virtual void ExtensiveBookmarkChangesEnded() {}
};
#endif // CHROME_BROWSER_BOOKMARKS_BOOKMARK_MERGED_SURFACE_SERVICE_OBSERVER_H_