summaryrefslogtreecommitdiffstats
path: root/chrome/browser/views/bookmark_folder_tree_view.h
blob: ae12b2c4f9209202cebbbf82e04c280202308e25 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
// Copyright (c) 2006-2008 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_VIEWS_BOOKMARK_FOLDER_TREE_VIEW_H_
#define CHROME_BROWSER_VIEWS_BOOKMARK_FOLDER_TREE_VIEW_H_

#include "chrome/browser/bookmarks/bookmark_drag_data.h"
#include "chrome/browser/bookmarks/bookmark_folder_tree_model.h"
#include "chrome/views/tree_view.h"

class BookmarkModel;
class BookmarkNode;
class OSExchangeData;
class Profile;

// BookmarkFolderTreeView is used to show the contents of a
// BookmarkFolderTreeModel and provides drag and drop support.
class BookmarkFolderTreeView : public views::TreeView {
 public:
  BookmarkFolderTreeView(Profile* profile, BookmarkFolderTreeModel* model);

  // Drag and drop methods.
  virtual bool CanDrop(const OSExchangeData& data);
  virtual void OnDragEntered(const views::DropTargetEvent& event);
  virtual int OnDragUpdated(const views::DropTargetEvent& event);
  virtual void OnDragExited();
  virtual int OnPerformDrop(const views::DropTargetEvent& event);

  // Returns the selected node as a BookmarkNode. This returns NULL if the
  // selected node is not of type BookmarkFolderTreeModel::BOOKMARK or
  // nothing is selected.
  BookmarkNode* GetSelectedBookmarkNode();

 protected:
  // Overriden to start a drag.
  virtual LRESULT OnNotify(int w_param, LPNMHDR l_param);

 private:
  // Provides information used during a drop.
  struct DropInfo {
    DropInfo()
        : drop_parent(NULL),
          only_folders(true),
          drop_index(-1),
          drop_operation(0),
          drop_on(false) {}

    // Parent the mouse is over.
    FolderNode* drop_parent;

    // Drag data.
    BookmarkDragData drag_data;

    // Does drag_data consists of folders only.
    bool only_folders;

    // If drop_on is false, this is the index to add the child.
    // WARNING: this index is in terms of the BookmarkFolderTreeModel, which is
    // not the same as the BookmarkModel.
    int drop_index;

    // Operation for the drop.
    int drop_operation;

    // Is the user dropping on drop_parent? If false, the mouse is positioned
    // such that the drop should insert the data at position drop_index in
    // drop_parent.
    bool drop_on;
  };

  // Starts a drag operation for the specified node.
  void BeginDrag(BookmarkNode* node);

  // Calculates the drop parent. Returns NULL if not over a valid drop
  // location. See DropInfos documentation for a description of |drop_index|
  // and |drop_on|.
  FolderNode* CalculateDropParent(int y,
                                  bool only_folders,
                                  int* drop_index,
                                  bool* drop_on);

  // Determines the appropriate drop operation. This returns DRAG_NONE
  // if the location is not valid.
  int CalculateDropOperation(const views::DropTargetEvent& event,
                             FolderNode* drop_parent,
                             int drop_index,
                             bool drop_on);

  // Performs the drop operation.
  void OnPerformDropImpl();

  // Sets the parent of the drop operation.
  void SetDropParent(FolderNode* node, int drop_index, bool drop_on);

  // Returns the model as a BookmarkFolderTreeModel.
  BookmarkFolderTreeModel* folder_model() const;

  // Converts FolderNode into a BookmarkNode.
  BookmarkNode* TreeNodeAsBookmarkNode(FolderNode* node);

  // Converts an index in terms of the BookmarkFolderTreeModel to an index
  // in terms of the BookmarkModel.
  int FolderIndexToBookmarkIndex(FolderNode* node, int index, bool drop_on);

  Profile* profile_;

  // Non-null during a drop.
  scoped_ptr<DropInfo> drop_info_;

  // Did we originate the drag?
  bool is_dragging_;

  DISALLOW_COPY_AND_ASSIGN(BookmarkFolderTreeView);
};

#endif  // CHROME_BROWSER_VIEWS_BOOKMARK_FOLDER_TREE_VIEW_H_