/* ============================================================
*
* This file is a part of the rekonq project
*
* Copyright (C) 2008-2010 by Andrea Diamantini <adjam7 at gmail dot com>
* Copyright (C) 2010 by Yoann Laissus <yoann dot laissus at gmail dot com>
*
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License as
* published by the Free Software Foundation; either version 2 of
* the License or (at your option) version 3 or any later version
* accepted by the membership of KDE e.V. (or its successor approved
* by the membership of KDE e.V.), which shall act as a proxy
* defined in Section 14 of version 3 of the license.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program.  If not, see <http://www.gnu.org/licenses/>.
*
* ============================================================ */

#ifndef BOOKMARKSTOOLBAR_H
#define BOOKMARKSTOOLBAR_H


// Rekonq Includes
#include "rekonq_defines.h"

// KDE Includes
#include <KBookmarkMenu>

/**
 * This class represent the rekonq bookmarks menu.
 * It's just a simple class inherited from KBookmarkMenu
 *
 */
class BookmarkMenu : public KBookmarkMenu
{
    Q_OBJECT

public:
    BookmarkMenu(KBookmarkManager* manager,
                 KBookmarkOwner* owner,
                 KMenu* menu,
                 KActionCollection* actionCollection);
    BookmarkMenu(KBookmarkManager  *manager,
                 KBookmarkOwner  *owner,
                 KMenu  *parentMenu,
                 const QString &parentAddress);
    ~BookmarkMenu();

protected:
    virtual KMenu * contextMenu(QAction * act);
    virtual void refill();
    virtual QAction* actionForBookmark(const KBookmark &bookmark);

private slots:
    void actionHovered();

private:
    void addOpenFolderInTabs();

};


// ------------------------------------------------------------------------------


// KDE Includes
#include <KToolBar>


/**
 * This class manage the bookmark toolbar.
 * Some events from the toolbar are handled to allow the drag and drop
 */

class BookmarkToolBar : public QObject
{
    Q_OBJECT

public:
BookmarkToolBar(KToolBar *toolBar, QObject *parent);
~BookmarkToolBar();

KToolBar* toolBar();

protected:
    bool eventFilter(QObject *watched, QEvent *event);

private slots:
    void contextMenu(const QPoint &);
    void actionHovered();
    void menuDisplayed();
    void menuHidden();
    void hideMenu();
    void dragDestroyed();

private:
    void startDrag();

    KToolBar *m_toolBar;
    KMenu *m_currentMenu;
    QPoint m_startDragPos;
    QAction *m_dragAction;
    QAction *m_dropAction;
    bool m_filled;
};

#endif // BOOKMARKSTOOLBAR_H