1
mirror of https://invent.kde.org/network/falkon.git synced 2024-09-23 02:32:10 +02:00
falkonOfficial/src/lib/bookmarks/bookmarkstoolbar.cpp

208 lines
6.2 KiB
C++
Raw Normal View History

2011-03-03 18:29:20 +01:00
/* ============================================================
* QupZilla - WebKit based browser
2014-01-11 16:11:42 +01:00
* Copyright (C) 2010-2014 David Rosca <nowrep@gmail.com>
2011-03-03 18:29:20 +01:00
*
* 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 3 of the License, or
* (at your option) any later version.
*
* 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/>.
* ============================================================ */
2011-03-02 16:57:41 +01:00
#include "bookmarkstoolbar.h"
#include "bookmarkstoolbarbutton.h"
#include "bookmarkstools.h"
#include "bookmarkitem.h"
#include "mainapplication.h"
#include "bookmarks.h"
#include <QDragEnterEvent>
#include <QHBoxLayout>
#include <QMimeData>
#include <QTimer>
#include <QFrame>
BookmarksToolbar::BookmarksToolbar(QupZilla* mainClass, QWidget* parent)
: QWidget(parent)
, m_window(mainClass)
, m_bookmarks(mApp->bookmarks())
, m_clickedBookmark(0)
2011-03-02 16:57:41 +01:00
{
setObjectName("bookmarksbar");
setContextMenuPolicy(Qt::CustomContextMenu);
setAcceptDrops(true);
m_layout = new QHBoxLayout(this);
m_layout->setMargin(1);
m_layout->setSpacing(0);
setLayout(m_layout);
2011-03-02 16:57:41 +01:00
m_updateTimer = new QTimer(this);
m_updateTimer->setInterval(300);
m_updateTimer->setSingleShot(true);
connect(m_updateTimer, SIGNAL(timeout()), this, SLOT(refresh()));
2011-03-02 16:57:41 +01:00
connect(m_bookmarks, SIGNAL(bookmarkAdded(BookmarkItem*)), this, SLOT(bookmarksChanged()));
connect(m_bookmarks, SIGNAL(bookmarkRemoved(BookmarkItem*)), this, SLOT(bookmarksChanged()));
connect(m_bookmarks, SIGNAL(bookmarkChanged(BookmarkItem*)), this, SLOT(bookmarksChanged()));
connect(this, SIGNAL(customContextMenuRequested(QPoint)), this, SLOT(contextMenuRequested(QPoint)));
2011-03-02 16:57:41 +01:00
refresh();
2011-03-02 16:57:41 +01:00
}
void BookmarksToolbar::contextMenuRequested(const QPoint &pos)
{
QPoint globalPos = mapToGlobal(pos);
BookmarksToolbarButton* button = qobject_cast<BookmarksToolbarButton*>(QApplication::widgetAt(globalPos));
m_clickedBookmark = button ? button->bookmark() : 0;
QMenu menu;
QAction* actNewTab = menu.addAction(QIcon::fromTheme("tab-new", QIcon(":/icons/menu/tab-new.png")), tr("Open in new tab"));
QAction* actNewWindow = menu.addAction(QIcon::fromTheme("window-new"), tr("Open in new window"));
menu.addSeparator();
QAction* actDelete = menu.addAction(QIcon::fromTheme("edit-delete"), tr("Delete"));
menu.addSeparator();
QAction* act = menu.addAction(tr("Show Only Icons"));
act->setCheckable(true);
2014-02-10 12:58:34 +01:00
act->setChecked(m_bookmarks->showOnlyIconsInToolbar());
connect(act, SIGNAL(toggled(bool)), m_bookmarks, SLOT(setShowOnlyIconsInToolbar(bool)));
connect(actNewTab, SIGNAL(triggered()), this, SLOT(openBookmarkInNewTab()));
connect(actNewWindow, SIGNAL(triggered()), this, SLOT(openBookmarkInNewWindow()));
connect(actDelete, SIGNAL(triggered()), this, SLOT(deleteBookmark()));
actDelete->setEnabled(m_clickedBookmark && (m_clickedBookmark->isUrl() || m_clickedBookmark->isFolder()));
actNewTab->setEnabled(m_clickedBookmark && m_clickedBookmark->isUrl());
actNewWindow->setEnabled(m_clickedBookmark && m_clickedBookmark->isUrl());
menu.exec(globalPos);
m_clickedBookmark = 0;
}
void BookmarksToolbar::addItem(BookmarkItem* item)
{
Q_ASSERT(item);
switch (item->type()) {
case BookmarkItem::Folder:
case BookmarkItem::Url: {
BookmarksToolbarButton* button = new BookmarksToolbarButton(item, this);
button->setMainWindow(m_window);
2014-02-10 12:58:34 +01:00
button->setShowOnlyIcon(m_bookmarks->showOnlyIconsInToolbar());
m_layout->addWidget(button);
break;
}
case BookmarkItem::Separator: {
QFrame* separator = new QFrame(this);
separator->setFrameShape(QFrame::VLine);
m_layout->addWidget(separator);
break;
}
default:
break;
}
}
void BookmarksToolbar::clear()
2011-03-02 16:57:41 +01:00
{
int count = m_layout->count();
for (int i = 0; i < count; ++i) {
QLayoutItem* item = m_layout->takeAt(0);
delete item->widget();
delete item;
}
Q_ASSERT(m_layout->isEmpty());
}
void BookmarksToolbar::refresh()
{
clear();
BookmarkItem* folder = mApp->bookmarks()->toolbarFolder();
foreach (BookmarkItem* child, folder->children()) {
addItem(child);
}
m_layout->addStretch();
}
void BookmarksToolbar::bookmarksChanged()
{
m_updateTimer->stop();
m_updateTimer->start();
2011-03-02 16:57:41 +01:00
}
2014-02-10 12:58:34 +01:00
void BookmarksToolbar::showOnlyIconsChanged(bool state)
{
for (int i = 0; i < m_layout->count(); ++i) {
BookmarksToolbarButton* b = qobject_cast<BookmarksToolbarButton*>(m_layout->itemAt(i)->widget());
if (b) {
b->setShowOnlyIcon(state);
}
}
}
void BookmarksToolbar::openBookmarkInNewTab()
{
if (m_clickedBookmark) {
BookmarksTools::openBookmarkInNewTab(m_window, m_clickedBookmark);
}
}
void BookmarksToolbar::openBookmarkInNewWindow()
{
if (m_clickedBookmark) {
BookmarksTools::openBookmarkInNewWindow(m_clickedBookmark);
}
2011-03-02 16:57:41 +01:00
}
void BookmarksToolbar::deleteBookmark()
{
if (m_clickedBookmark) {
m_bookmarks->removeBookmark(m_clickedBookmark);
}
}
void BookmarksToolbar::dropEvent(QDropEvent* e)
{
const QMimeData* mime = e->mimeData();
if (!mime->hasUrls() || !mime->hasText()) {
QWidget::dropEvent(e);
return;
}
QString title = mime->text();
QUrl url = mime->urls().at(0);
BookmarkItem* bookmark = new BookmarkItem(BookmarkItem::Url);
bookmark->setTitle(title);
bookmark->setUrl(url);
m_bookmarks->addBookmark(m_bookmarks->toolbarFolder(), bookmark);
}
void BookmarksToolbar::dragEnterEvent(QDragEnterEvent* e)
{
const QMimeData* mime = e->mimeData();
if (mime->hasUrls() && mime->hasText()) {
e->acceptProposedAction();
return;
}
QWidget::dragEnterEvent(e);
}