summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/application.cpp6
-rw-r--r--src/application.hpp4
-rw-r--r--src/bookmarks/CMakeLists.txt9
-rw-r--r--src/bookmarks/bookmarkmanager.cpp177
-rw-r--r--src/bookmarks/bookmarkmanager.hpp96
-rw-r--r--src/bookmarks/bookmarkowner.cpp349
-rw-r--r--src/bookmarks/bookmarkowner.h148
-rw-r--r--src/bookmarks/bookmarksmenu.hpp6
-rw-r--r--src/bookmarks/bookmarkstreeitem.hpp19
-rw-r--r--src/bookmarks/bookmarkstreemodel.cpp44
-rw-r--r--src/bookmarks/bookmarkstreemodel.hpp6
-rw-r--r--src/bookmarks/test/bookmarkmanager.cpp21
-rw-r--r--src/bookmarks/test/test_bookmarkstreemodel.cpp25
-rw-r--r--src/panels/bookmarkspanel.cpp4
-rw-r--r--src/panels/bookmarkspanel.hpp4
-rw-r--r--src/test/application_mock.hpp2
16 files changed, 85 insertions, 835 deletions
diff --git a/src/application.cpp b/src/application.cpp
index 910e0bb5..736c0e6d 100644
--- a/src/application.cpp
+++ b/src/application.cpp
@@ -101,7 +101,7 @@ struct BookmarksModelPrivate {
BookmarksModelPrivate()
{
- model = new BookmarkModel;
+ model = new BookmarksTreeModel;
const auto path = QStandardPaths::writableLocation(QStandardPaths::AppConfigLocation) + "/bookmarks.xbel";
spdlog::debug("Loading bookmarks from {}", qUtf8Printable(path));
QFile f(path);
@@ -122,11 +122,11 @@ struct BookmarksModelPrivate {
delete model;
}
- BookmarkModel *model;
+ BookmarksTreeModel *model;
};
Q_GLOBAL_STATIC(BookmarksModelPrivate, bookmarks_d);
-BookmarkModel *Application::bookmarks() const { return bookmarks_d->model; }
+BookmarksTreeModel *Application::bookmarks() const { return bookmarks_d->model; }
/*
int Application::newInstance()
diff --git a/src/application.hpp b/src/application.hpp
index 2f08a575..c6c41b9e 100644
--- a/src/application.hpp
+++ b/src/application.hpp
@@ -22,7 +22,7 @@ class RekonqView;
class RekonqWindow;
class PluginLoader;
class RekonqSettings;
-class BookmarkModel;
+class BookmarksTreeModel;
using RekonqPluginList = QList<QPointer<PluginLoader>>;
using RekonqWindowList = QList<QPointer<RekonqWindow>>;
@@ -46,7 +46,7 @@ public:
// int newInstance();
static Application *instance() { return (qobject_cast<Application *>(QCoreApplication::instance())); }
[[nodiscard]] auto *settings() const { return m_settings; }
- REKONQ_TEST_VIRTUAL BookmarkModel *bookmarks() const REKONQ_TEST_PURE;
+ REKONQ_TEST_VIRTUAL BookmarksTreeModel *bookmarks() const REKONQ_TEST_PURE;
// RekonqWindow *rekonqWindow(const QString &activityID = QString());
[[nodiscard]] auto windowList() const { return m_windows; }
diff --git a/src/bookmarks/CMakeLists.txt b/src/bookmarks/CMakeLists.txt
index 2ff32c80..1d0f846f 100644
--- a/src/bookmarks/CMakeLists.txt
+++ b/src/bookmarks/CMakeLists.txt
@@ -1,5 +1,4 @@
add_library(bookmarks STATIC
-# bookmarkmanager.cpp bookmarkmanager.h
# bookmarkowner.cpp bookmarkowner.h
# bookmarkstoolbar.cpp bookmarkstoolbar.h
# Bookmarks Model
@@ -8,8 +7,6 @@ add_library(bookmarks STATIC
bookmarkstreemodel.cpp bookmarkstreemodel.hpp
bookmarkstreeformats.hpp
bookmarkstreeformat_xbel_read.cpp bookmarkstreeformat_xbel_write.cpp
- # Bookmark Manager
- bookmarkmanager.cpp bookmarkmanager.hpp
# UI
bookmarksmenu.cpp bookmarksmenu.hpp
)
@@ -17,9 +14,9 @@ target_include_directories(bookmarks PUBLIC ${CMAKE_SOURCE_DIR}/src)
target_link_libraries(bookmarks PUBLIC Qt6::Core Qt6::Widgets)
if(${CMAKE_BUILD_TYPE} STREQUAL "Debug")
- add_executable(bookmarkmanager test/bookmarkmanager.cpp)
- target_link_libraries(bookmarkmanager GTest::gtest GTest::gtest_main bookmarks)
- gtest_discover_tests(bookmarkmanager WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}/test)
+ add_executable(test_bookmarkstreemodel test/test_bookmarkstreemodel.cpp)
+ target_link_libraries(test_bookmarkstreemodel GTest::gtest GTest::gtest_main bookmarks)
+ gtest_discover_tests(test_bookmarkstreemodel WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}/test)
add_executable(xbel test/xbel.cpp)
target_link_libraries(xbel GTest::gtest GTest::gtest_main bookmarks)
diff --git a/src/bookmarks/bookmarkmanager.cpp b/src/bookmarks/bookmarkmanager.cpp
deleted file mode 100644
index b5077111..00000000
--- a/src/bookmarks/bookmarkmanager.cpp
+++ /dev/null
@@ -1,177 +0,0 @@
-/* ============================================================
- * The rekonq project
- * ============================================================
- * SPDX-License-Identifier: GPL-2.0-or-later
- * Copyright (C) 2008-2012 by Andrea Diamantini <adjam7 at gmail dot com>
- * Copyright (C) 2009 by Paweł Prażak <pawelprazak at gmail dot com>
- * Copyright (C) 2009-2010 by Lionel Chauvin <megabigbug@yahoo.fr>
- * Copyright (C) 2010 by Yoann Laissus <yoann dot laissus at gmail dot com>
- * SPDX-License-Identifier: GPL-3.0-only
- * Copyright (C) 2022 aqua <aqua@iserlohn-fortress.net>
- * ============================================================
- * Description: rekonq bookmarks system interface
- * ============================================================ */
-
-#include "bookmarkmanager.hpp"
-#include <QCoreApplication>
-#include <QFile>
-#include <QMenu>
-
-// ----------------------------------------------------------------------------------------------
-// Constructor and Destructor
-
-BookmarkManager::BookmarkManager(const QString &bookmarksFile, QObject *parent)
- : QObject(parent), m_model(new BookmarkModel(this))
-{
- if (!bookmarksFile.isEmpty()) {
- QFile bf(bookmarksFile);
- if (bf.open(QIODevice::ReadOnly | QIODevice::Text)) {
- m_errors += m_model->load(&bf);
- bf.close();
- }
- else
- m_errors +=
- tr("%1 Bookmarks file '%2' cannot be opened: %3").arg(__PRETTY_FUNCTION__, bookmarksFile, bf.errorString());
- }
-
- // connect(m_manager, SIGNAL(changed(QString, QString)), this, SLOT(slotBookmarksChanged()));
-
- // bookmarks loading
- // connect(this, SIGNAL(openUrl(KUrl, Rekonq::OpenType)), rApp, SLOT(loadUrl(KUrl, Rekonq::OpenType)));
-}
-
-BookmarkManager::~BookmarkManager() { delete m_model; }
-
-// ----------------------------------------------------------------------------------------------
-/*
-QList<Bookmark> BookmarkManager::find(const QString &text)
-{
- BookmarkGroup list;
- auto *root = m_model->item();
- Q_CHECK_PTR(root);
-
-
- KBookmarkGroup root = rootGroup();
- if (!root.isNull())
- for (KBookmark bookmark = root.first(); !bookmark.isNull(); bookmark = root.next(bookmark))
- find(&list, bookmark, text);
-
- return list;
-}
-
-KBookmark BookmarkManager::bookmarkForUrl(const KUrl &url)
-{
- KBookmarkGroup root = rootGroup();
- if (root.isNull()) return KBookmark();
-
- return bookmarkForUrl(root, url);
-}
-
-void BookmarkManager::slotBookmarksChanged()
-{
- Q_FOREACH (BookmarkToolBar *bookmarkToolBar, m_bookmarkToolBars) {
- if (bookmarkToolBar) {
- bookmarkToolBar->clear();
- fillBookmarkBar(bookmarkToolBar);
- }
- }
-
- // NOTE with this signal, we should (eventual) update about:bookmarks page...
- emit bookmarksUpdated();
-}
-
-KBookmark BookmarkManager::bookmarkCurrentPage(const KBookmark &bookmark)
-{
- return m_owner->bookmarkCurrentPage(bookmark);
-}
-
-void BookmarkManager::fillBookmarkBar(BookmarkToolBar *toolBar)
-{
- KBookmarkGroup root = m_manager->toolbar();
- if (root.isNull()) return;
-
- for (KBookmark bookmark = root.first(); !bookmark.isNull(); bookmark = root.next(bookmark)) {
- if (bookmark.isGroup()) {
- KBookmarkActionMenu *menuAction = new KBookmarkActionMenu(bookmark.toGroup(), toolBar);
- menuAction->setDelayed(false);
- BookmarkMenu *bMenu = new BookmarkMenu(m_manager, m_owner, menuAction->menu(), bookmark.address());
- bMenu->setParent(menuAction->menu());
-
- connect(menuAction->menu(), SIGNAL(aboutToShow()), toolBar, SLOT(menuDisplayed()));
- connect(menuAction->menu(), SIGNAL(aboutToHide()), toolBar, SLOT(menuHidden()));
-
- toolBar->addAction(menuAction);
- toolBar->widgetForAction(menuAction)->installEventFilter(toolBar);
- }
- else if (bookmark.isSeparator()) {
- toolBar->addSeparator();
- }
- else {
- KBookmarkAction *action = new KBookmarkAction(bookmark, m_owner, toolBar);
- action->setIcon(IconManager::self()->iconForUrl(KUrl(bookmark.url())));
- toolBar->addAction(action);
- toolBar->widgetForAction(action)->installEventFilter(toolBar);
- }
- }
-}
-
-void BookmarkManager::find(QList<KBookmark> *list, const KBookmark &bookmark, const QString &text)
-{
- if (bookmark.isGroup()) {
- KBookmarkGroup group = bookmark.toGroup();
- for (KBookmark bm = group.first(); !bm.isNull(); bm = group.next(bm)) find(list, bm, text);
- }
- else {
- QStringList words = text.split(' ');
- bool matches = true;
- Q_FOREACH (const QString &word, words) {
- if (!bookmark.url().url().contains(word, Qt::CaseInsensitive) &&
- !bookmark.fullText().contains(word, Qt::CaseInsensitive)) {
- matches = false;
- break;
- }
- }
- if (matches) *list << bookmark;
- }
-}
-
-KBookmark BookmarkManager::bookmarkForUrl(const KBookmark &bookmark, const KUrl &url)
-{
- KBookmark found;
-
- if (bookmark.isGroup()) {
- KBookmarkGroup group = bookmark.toGroup();
- KBookmark bookmark = group.first();
-
- while (!bookmark.isNull() && found.isNull()) {
- found = bookmarkForUrl(bookmark, url);
- bookmark = group.next(bookmark);
- }
- }
- else if (!bookmark.isSeparator() && bookmark.url() == url) {
- found = bookmark;
- }
-
- return found;
-}
-
-void BookmarkManager::slotEditBookmarks() { m_manager->slotEditBookmarks(); }
-
-void BookmarkManager::openFolderInTabs(const BookmarkGroup &group) {
- for(const auto &bookmark : group) {
- // TODO emit openUrl
- }
-}
-
-KActionMenu *BookmarkManager::bookmarkActionMenu(QWidget *parent)
-{
- auto *menu = new QMenu(parent);
- KActionMenu *bookmarkActionMenu = new KActionMenu(menu);
- bookmarkActionMenu->setMenu(menu);
- bookmarkActionMenu->setText(tr("&Bookmarks"));
- BookmarkMenu *bMenu = new BookmarkMenu(m_manager, m_owner, menu, m_actionCollection);
- bMenu->setParent(menu);
-
- return bookmarkActionMenu;
-}
-*/
diff --git a/src/bookmarks/bookmarkmanager.hpp b/src/bookmarks/bookmarkmanager.hpp
deleted file mode 100644
index f76b8b3f..00000000
--- a/src/bookmarks/bookmarkmanager.hpp
+++ /dev/null
@@ -1,96 +0,0 @@
-/* ============================================================
- * The rekonq project
- * ============================================================
- * SPDX-License-Identifier: GPL-2.0-or-later
- * Copyright (C) 2008-2012 by Andrea Diamantini <adjam7 at gmail dot com>
- * Copyright (C) 2009 by Paweł Prażak <pawelprazak at gmail dot com>
- * Copyright (C) 2009-2010 by Lionel Chauvin <megabigbug@yahoo.fr>
- * Copyright (C) 2010 by Yoann Laissus <yoann dot laissus at gmail dot com>
- * SPDX-License-Identifier: GPL-3.0-only
- * Copyright (C) 2022 aqua <aqua@iserlohn-fortress.net>
- * ============================================================
- * Description: rekonq bookmarks system interface
- * ============================================================ */
-
-#pragma once
-
-#include "bookmark.hpp"
-#include "bookmarkstreemodel.hpp"
-#include "rekonq.hpp"
-#include <QObject>
-
-class QToolBar;
-
-/**
- * This class represent the interface to the rekonq bookmarks system. It provides bookmarks access to the
- * Bookmarks Menu and Bookmarks Toolbar.
- */
-class BookmarkManager final : public QObject {
- Q_OBJECT
-
-public:
- /**
- * @short Class constructor.
- * Connect BookmarksProvider with bookmarks source
- * (actually konqueror's bookmarks).
- * @param parent The WebWindow to provide bookmarks objects.
- */
- explicit BookmarkManager(const QString &bookmarksFile, QObject *parent = nullptr);
- ~BookmarkManager() override;
-
- /**
- * Return a list of errors
- * @return A copy of the error list
- */
- auto errors()
- {
- auto e = m_errors;
- m_errors.clear();
- return e;
- }
-
- /**
- * @short set the Bookmarks Toolbar Action
- */
- void registerBookmarkBar(QToolBar *toolbar)
- {
- if (!m_bookmarkToolBars.contains(toolbar)) m_bookmarkToolBars.append(toolbar);
- }
- void removeBookmarkBar(QToolBar *toolbar) { m_bookmarkToolBars.removeOne(toolbar); }
-
- // QList<Bookmark> find(const QString &text);
- // QList<Bookmark> findByUrl(const QUrl &url);
-
- // Bookmark bookmarkForUrl(const QUrl &url);
-
- // void openFolderInTabs(const BookmarkGroup &group);
-
- // QMenu *bookmarkActionMenu(QWidget *parent);
-
-public slots:
- /**
- * @short Waits for signal that the group with the address has been modified by the caller.
- * Waits for signal that the group (or any of its children) with the address
- * @p groupAddress (e.g. "/4/5") has been modified by the caller @p caller.
- * @param groupAddress bookmark group address
- * @param caller caller that modified the bookmarks
- * @see KBookmarkManager::changed
- */
- // void slotBookmarksChanged();
- // void fillBookmarkBar(QToolBar *toolBar);
-
- // void slotEditBookmarks();
-
- // Bookmark bookmarkCurrentPage(const Bookmark &bookmark = Bookmark());
-
-signals:
- /**
- * @short This signal is emitted when a URL has to be loaded
- */
- void openUrl(const QUrl &, rekonq::OpenType);
-
-private:
- QList<QString> m_errors;
- QList<QToolBar *> m_bookmarkToolBars;
- BookmarkModel *m_model;
-};
diff --git a/src/bookmarks/bookmarkowner.cpp b/src/bookmarks/bookmarkowner.cpp
deleted file mode 100644
index 49e3dd87..00000000
--- a/src/bookmarks/bookmarkowner.cpp
+++ /dev/null
@@ -1,349 +0,0 @@
-/* ============================================================
- *
- * This file is a part of the rekonq project
- *
- * Copyright (C) 2008-2012 by Andrea Diamantini <adjam7 at gmail dot com>
- * Copyright (C) 2009 by Paweł Prażak <pawelprazak at gmail dot com>
- * Copyright (C) 2009-2010 by Lionel Chauvin <megabigbug@yahoo.fr>
- * 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/>.
- *
- * ============================================================ */
-
-// Self Includes
-#include "bookmarkowner.h"
-#include "bookmarkowner.moc"
-
-// Local Includes
-#include "bookmarkmanager.h"
-
-#include "application.h"
-#include "rekonqwindow.h"
-#include "tabwidget.h"
-#include "webwindow.h"
-
-// KDE Includes
-#include <KBookmarkDialog>
-#include <KLocalizedString>
-#include <KMessageBox>
-
-// Qt Includes
-#include <QClipboard>
-
-// Nepomuk Includes
-#ifdef HAVE_NEPOMUK
-// Local Nepomuk Includes
-#include "resourcelinkdialog.h"
-
-// Nepomuk Includes
-#include <Nepomuk2/Resource>
-#include <Nepomuk2/Vocabulary/NFO>
-#endif
-
-BookmarkOwner::BookmarkOwner(KBookmarkManager *manager, QObject *parent)
- : QObject(parent), KBookmarkOwner(), m_manager(manager)
-{
-}
-
-KAction *BookmarkOwner::createAction(const KBookmark &bookmark, const BookmarkAction &bmAction)
-{
- switch (bmAction) {
- case OPEN:
- return createAction(i18n("Open"), "tab-new", i18n("Open bookmark in current tab"), SLOT(loadBookmark(KBookmark)),
- bookmark);
- case OPEN_IN_TAB:
- return createAction(i18n("Open in New Tab"), "tab-new", i18n("Open bookmark in new tab"),
- SLOT(loadBookmarkInNewTab(KBookmark)), bookmark);
- case OPEN_IN_WINDOW:
- return createAction(i18n("Open in New Window"), "window-new", i18n("Open bookmark in new window"),
- SLOT(loadBookmarkInNewWindow(KBookmark)), bookmark);
- case OPEN_FOLDER:
- return createAction(i18n("Open Folder in Tabs"), "tab-new", i18n("Open all the bookmarks in folder in tabs"),
- SLOT(loadBookmarkFolder(KBookmark)), bookmark);
- case BOOKMARK_PAGE:
- return createAction(i18n("Add Bookmark"), "bookmark-new", i18n("Bookmark current page"),
- SLOT(bookmarkCurrentPage(KBookmark)), bookmark);
- case NEW_FOLDER:
- return createAction(i18n("New Folder"), "folder-new", i18n("Create a new bookmark folder"),
- SLOT(newBookmarkFolder(KBookmark)), bookmark);
- case NEW_SEPARATOR:
- return createAction(i18n("New Separator"), "edit-clear", i18n("Create a new bookmark separator"),
- SLOT(newSeparator(KBookmark)), bookmark);
- case COPY:
- return createAction(i18n("Copy Link"), "edit-copy", i18n("Copy the bookmark's link address"),
- SLOT(copyLink(KBookmark)), bookmark);
- case EDIT:
- return createAction(i18n("Edit"), "configure", i18n("Edit the bookmark"), SLOT(editBookmark(KBookmark)), bookmark);
-#ifdef HAVE_NEPOMUK
- case FANCYBOOKMARK:
- return createAction(i18n("Fancy Bookmark"), "nepomuk", i18n("Link Nepomuk resources"),
- SLOT(fancyBookmark(KBookmark)), bookmark);
-#endif
- case DELETE:
- return createAction(i18n("Delete"), "edit-delete", i18n("Delete the bookmark"), SLOT(deleteBookmark(KBookmark)),
- bookmark);
- case SET_TOOLBAR_FOLDER:
- return createAction(i18n("Set as toolbar folder"), "bookmark-toolbar", "", SLOT(setToolBarFolder(KBookmark)),
- bookmark);
- case UNSET_TOOLBAR_FOLDER:
- return createAction(i18n("Unset this folder as the toolbar folder"), "bookmark-toolbar", "",
- SLOT(unsetToolBarFolder()), bookmark);
- default:
- ASSERT_NOT_REACHED(unknown BookmarkAction);
- return 0;
- }
-}
-
-QString BookmarkOwner::currentTitle() const { return rApp->rekonqWindow()->currentWebWindow()->title(); }
-
-QString BookmarkOwner::currentUrl() const { return rApp->rekonqWindow()->currentWebWindow()->url().url(); }
-
-QList<QPair<QString, QString>> BookmarkOwner::currentBookmarkList() const
-{
- QList<QPair<QString, QString>> bkList;
- TabWidget *view = rApp->rekonqWindow()->tabWidget();
- int tabNumber = view->count();
-
- for (int i = 0; i < tabNumber; ++i) {
- QPair<QString, QString> item;
- item.first = view->webWindow(i)->title();
- item.second = view->webWindow(i)->url().url();
- bkList << item;
- }
-
- return bkList;
-}
-
-void BookmarkOwner::openBookmark(const KBookmark &bookmark, Qt::MouseButtons mouseButtons,
- Qt::KeyboardModifiers keyboardModifiers)
-{
- if (keyboardModifiers & Qt::ControlModifier || mouseButtons & Qt::MidButton) loadBookmarkInNewTab(bookmark);
- else
- loadBookmark(bookmark);
-}
-
-void BookmarkOwner::openFolderinTabs(const KBookmarkGroup &bkGoup)
-{
- QList<KUrl> urlList = bkGoup.groupUrlList();
-
- if (urlList.length() > 8) {
- if (KMessageBox::warningContinueCancel(rApp->rekonqWindow(), i18ncp("%1=Number of tabs. Value is always >=8",
- "You are about to open %1 tabs.\nAre you sure?",
- "You are about to open %1 tabs.\nAre you sure?",
- urlList.length())) != KMessageBox::Continue)
- return;
- }
-
- Q_FOREACH (const KUrl &url, urlList) { emit openUrl(url, Rekonq::NewFocusedTab); }
-}
-
-void BookmarkOwner::loadBookmark(const KBookmark &bookmark) { emit openUrl(bookmark.url(), Rekonq::CurrentTab); }
-
-void BookmarkOwner::loadBookmarkInNewTab(const KBookmark &bookmark) { emit openUrl(bookmark.url(), Rekonq::NewTab); }
-
-void BookmarkOwner::loadBookmarkInNewWindow(const KBookmark &bookmark)
-{
- emit openUrl(bookmark.url(), Rekonq::NewWindow);
-}
-
-void BookmarkOwner::loadBookmarkFolder(const KBookmark &bookmark)
-{
- Q_ASSERT(bookmark.isGroup());
- openFolderinTabs(bookmark.toGroup());
-}
-
-KBookmark BookmarkOwner::bookmarkCurrentPage(const KBookmark &bookmark)
-{
- KBookmarkGroup parent;
-
- if (!bookmark.isNull()) {
- if (bookmark.isGroup()) parent = bookmark.toGroup();
- else
- parent = bookmark.parentGroup();
- }
- else {
- parent = BookmarkManager::self()->rootGroup();
-#ifdef HAVE_NEPOMUK
- Nepomuk2::Resource nfoResource;
- nfoResource = ((QUrl)currentUrl());
- nfoResource.addType(Nepomuk2::Vocabulary::NFO::Website());
- nfoResource.setLabel(currentTitle());
-#endif
- }
-
- KBookmark newBk = parent.addBookmark(currentTitle(), KUrl(currentUrl()));
- if (!bookmark.isNull()) parent.moveBookmark(newBk, bookmark);
-
- m_manager->emitChanged(parent);
- return newBk;
-}
-
-KBookmarkGroup BookmarkOwner::newBookmarkFolder(const KBookmark &bookmark, const QString &name)
-{
- KBookmarkGroup newBk;
- KBookmarkDialog *dialog = bookmarkDialog(m_manager, 0);
-
- QString folderName;
- if (name.isEmpty()) folderName = i18n("New folder");
- else
- folderName = name;
-
- if (!bookmark.isNull()) {
- if (bookmark.isGroup()) { newBk = dialog->createNewFolder(folderName, bookmark); }
- else {
- newBk = dialog->createNewFolder(folderName, bookmark.parentGroup());
- if (!newBk.isNull()) {
- KBookmarkGroup parent = newBk.parentGroup();
- parent.moveBookmark(newBk, bookmark);
- m_manager->emitChanged(parent);
- }
- }
- }
- else {
- newBk = dialog->createNewFolder(folderName);
- }
-
- delete dialog;
- return newBk;
-}
-
-KBookmark BookmarkOwner::newSeparator(const KBookmark &bookmark)
-{
- KBookmark newBk;
-
- if (!bookmark.isNull()) {
- if (bookmark.isGroup()) { newBk = bookmark.toGroup().createNewSeparator(); }
- else {
- newBk = bookmark.parentGroup().createNewSeparator();
- newBk.parentGroup().moveBookmark(newBk, bookmark);
- }
- }
- else {
- newBk = BookmarkManager::self()->rootGroup().createNewSeparator();
- }
-
- newBk.setIcon("edit-clear");
-
- m_manager->emitChanged(newBk.parentGroup());
- return newBk;
-}
-
-void BookmarkOwner::copyLink(const KBookmark &bookmark)
-{
- if (bookmark.isNull()) return;
-
- QApplication::clipboard()->setText(bookmark.url().url());
-}
-
-void BookmarkOwner::editBookmark(KBookmark bookmark)
-{
- if (bookmark.isNull()) return;
-
- KBookmarkDialog *dialog = bookmarkDialog(m_manager, 0);
- dialog->editBookmark(bookmark);
-
- delete dialog;
-}
-
-#ifdef HAVE_NEPOMUK
-void BookmarkOwner::fancyBookmark(KBookmark bookmark)
-{
- Nepomuk2::Resource nfoResource = (KUrl)bookmark.url();
-
- QPointer<Nepomuk2::ResourceLinkDialog> r = new Nepomuk2::ResourceLinkDialog(nfoResource);
- r->exec();
-
- r->deleteLater();
-}
-#endif
-
-bool BookmarkOwner::deleteBookmark(const KBookmark &bookmark)
-{
- if (bookmark.isNull()) return false;
-
- KBookmarkGroup bmg = bookmark.parentGroup();
- QString dialogCaption, dialogText;
-
- if (bookmark.isGroup()) {
- dialogCaption = i18n("Bookmark Folder Deletion");
- dialogText = i18n("Are you sure you wish to remove the bookmark folder\n\"%1\"?", bookmark.fullText());
- }
- else if (bookmark.isSeparator()) {
- dialogCaption = i18n("Separator Deletion");
- dialogText = i18n("Are you sure you wish to remove this separator?");
- }
- else {
- dialogCaption = i18n("Bookmark Deletion");
- dialogText = i18n("Are you sure you wish to remove the bookmark\n\"%1\"?", bookmark.fullText());
- }
-
- if (KMessageBox::warningContinueCancel(0, dialogText, dialogCaption, KStandardGuiItem::del(),
- KStandardGuiItem::cancel(),
- "bookmarkDeletition_askAgain") != KMessageBox::Continue)
- return false;
-
- bmg.deleteBookmark(bookmark);
-#ifdef HAVE_NEPOMUK
- Nepomuk2::Resource nfoResource(bookmark.url());
- nfoResource.remove();
-#endif
- m_manager->emitChanged(bmg);
- return true;
-}
-
-void BookmarkOwner::setToolBarFolder(KBookmark bookmark)
-{
- if (!bookmark.isGroup()) return;
-
- unsetToolBarFolder();
- bookmark.internalElement().setAttribute("toolbar", "yes");
- bookmark.setIcon("bookmark-toolbar");
-
- m_manager->emitChanged();
-}
-
-void BookmarkOwner::unsetToolBarFolder()
-{
- KBookmarkGroup toolbar = m_manager->toolbar();
- if (!toolbar.isNull()) {
- toolbar.internalElement().setAttribute("toolbar", "no");
- toolbar.setIcon("");
- }
- m_manager->emitChanged();
-}
-
-KAction *BookmarkOwner::createAction(const QString &text, const QString &icon, const QString &help, const char *slot,
- const KBookmark &bookmark)
-{
- CustomBookmarkAction *act = new CustomBookmarkAction(bookmark, KIcon(icon), text, this);
- act->setHelpText(help);
- connect(act, SIGNAL(triggered(KBookmark)), this, slot);
- return act;
-}
-
-// -------------------------------------------------------------------------------------------------
-
-CustomBookmarkAction::CustomBookmarkAction(const KBookmark &bookmark, const KIcon &icon, const QString &text,
- QObject *parent)
- : KAction(icon, text, parent), m_bookmark(bookmark)
-{
- connect(this, SIGNAL(triggered()), this, SLOT(onActionTriggered()));
-}
-
-void CustomBookmarkAction::onActionTriggered() { emit triggered(m_bookmark); }
diff --git a/src/bookmarks/bookmarkowner.h b/src/bookmarks/bookmarkowner.h
deleted file mode 100644
index 284c9459..00000000
--- a/src/bookmarks/bookmarkowner.h
+++ /dev/null
@@ -1,148 +0,0 @@
-/* ============================================================
-*
-* This file is a part of the rekonq project
-*
-* Copyright (C) 2008-2012 by Andrea Diamantini <adjam7 at gmail dot com>
-* Copyright (C) 2009 by Paweł Prażak <pawelprazak at gmail dot com>
-* Copyright (C) 2009-2010 by Lionel Chauvin <megabigbug@yahoo.fr>
-* 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 BOOKMARKOWNER_H
-#define BOOKMARKOWNER_H
-
-#include "rekonq.hpp"
-#include <QObject>
-
-/**
- * This class allows to manage bookmarks as actions.
- */
-class REKONQ_TESTS_EXPORT BookmarkOwner : public QObject {
- Q_OBJECT
-
-public:
- explicit BookmarkOwner(KBookmarkManager *manager, QObject *parent = 0);
-
- enum BookmarkAction
- {
- OPEN = 0,
- OPEN_IN_TAB,
- OPEN_IN_WINDOW,
- OPEN_FOLDER,
- BOOKMARK_PAGE,
- NEW_FOLDER,
- NEW_SEPARATOR,
- COPY,
- EDIT,
-#ifdef HAVE_NEPOMUK
- FANCYBOOKMARK,
-#endif
- DELETE,
- NUM_ACTIONS,
- SET_TOOLBAR_FOLDER,
- UNSET_TOOLBAR_FOLDER
- };
-
- /**
- * @return A new action for the given bookmark.
- */
- KAction* createAction(const KBookmark &bookmark, const BookmarkAction &bmAction);
-
- // @{
- /**
- * Functions to get current information.
- */
- virtual QString currentTitle() const;
- virtual QString currentUrl() const;
- virtual QList< QPair<QString, QString> > currentBookmarkList() const;
- // @}
-
- virtual bool supportsTabs() const
- {
- return true;
- }
-
- // @{
- /**
- * This functions emit signals that open the selected URLs
- */
- virtual void openBookmark(const KBookmark &bookmark,
- Qt::MouseButtons mouseButtons,
- Qt::KeyboardModifiers keyboardModifiers);
- virtual void openFolderinTabs(const KBookmarkGroup &bkGoup);
- // @}
-
-public Q_SLOTS:
- void loadBookmark(const KBookmark &bookmark);
- void loadBookmarkInNewTab(const KBookmark &bookmark);
- void loadBookmarkInNewWindow(const KBookmark &bookmark);
- void loadBookmarkFolder(const KBookmark &bookmark);
-
- KBookmark bookmarkCurrentPage(const KBookmark &bookmark = KBookmark());
- KBookmarkGroup newBookmarkFolder(const KBookmark &bookmark = KBookmark(), const QString &name = QString());
- KBookmark newSeparator(const KBookmark &bookmark = KBookmark());
-
- void copyLink(const KBookmark &bookmark);
- void editBookmark(KBookmark bookmark);
-#ifdef HAVE_NEPOMUK
- void fancyBookmark(KBookmark bookmark);
-#endif
- bool deleteBookmark(const KBookmark &bookmark);
- void setToolBarFolder(KBookmark bookmark = KBookmark());
- void unsetToolBarFolder();
-
-Q_SIGNALS:
- /**
- * This signal is emitted when an url has to be loaded
- * @param url the URL to load
- */
- void openUrl(const KUrl &, const Rekonq::OpenType &);
-
-private:
- KAction* createAction(const QString &text, const QString &icon,
- const QString &help, const char *slot,
- const KBookmark &bookmark);
-
- KBookmarkManager *m_manager;
-};
-
-// -----------------------------------------------------------------------------------------------
-
-
-class CustomBookmarkAction : public KAction
-{
- Q_OBJECT
-
-public:
- CustomBookmarkAction(const KBookmark &bookmark, const KIcon &icon, const QString &text, QObject *parent);
-
-Q_SIGNALS:
- void triggered(const KBookmark &);
-
-private Q_SLOTS:
- void onActionTriggered();
-
-private:
- KBookmark m_bookmark;
-};
-
-#endif // BOOKMARKOWNER_H
diff --git a/src/bookmarks/bookmarksmenu.hpp b/src/bookmarks/bookmarksmenu.hpp
index 6199708f..ad175991 100644
--- a/src/bookmarks/bookmarksmenu.hpp
+++ b/src/bookmarks/bookmarksmenu.hpp
@@ -15,7 +15,7 @@
#include "rekonq.hpp"
#include <QMenu>
-class BookmarkModel;
+class BookmarksTreeModel;
class BookmarksMenu : public QMenu {
Q_OBJECT
@@ -23,7 +23,7 @@ public:
explicit BookmarksMenu(QWidget *parent = nullptr);
~BookmarksMenu() override = default;
- void setModel(const BookmarkModel *ptr)
+ void setModel(const BookmarksTreeModel *ptr)
{
Q_CHECK_PTR(ptr);
model = ptr;
@@ -36,6 +36,6 @@ private slots:
void refill();
private:
- const BookmarkModel *model = nullptr;
+ const BookmarksTreeModel *model = nullptr;
QList<QAction *> actions;
};
diff --git a/src/bookmarks/bookmarkstreeitem.hpp b/src/bookmarks/bookmarkstreeitem.hpp
index a0af91aa..1f87ecad 100644
--- a/src/bookmarks/bookmarkstreeitem.hpp
+++ b/src/bookmarks/bookmarkstreeitem.hpp
@@ -18,6 +18,25 @@
class BookmarksTreeItem {
public:
+ enum BookmarkAction {
+ OPEN = 0,
+ OPEN_IN_TAB,
+ OPEN_IN_WINDOW,
+ OPEN_FOLDER,
+ BOOKMARK_PAGE,
+ NEW_FOLDER,
+ NEW_SEPARATOR,
+ COPY,
+ EDIT,
+#ifdef HAVE_NEPOMUK
+ FANCYBOOKMARK,
+#endif
+ DELETE,
+ NUM_ACTIONS,
+ SET_TOOLBAR_FOLDER,
+ UNSET_TOOLBAR_FOLDER
+ };
+
enum Types { Root, Folder, Bookmark, Separator, Alias };
constexpr static int TypesCount = 5;
diff --git a/src/bookmarks/bookmarkstreemodel.cpp b/src/bookmarks/bookmarkstreemodel.cpp
index a4f322b8..d64f1588 100644
--- a/src/bookmarks/bookmarkstreemodel.cpp
+++ b/src/bookmarks/bookmarkstreemodel.cpp
@@ -13,20 +13,20 @@
#include <QDateTime>
#include <QMimeData>
-BookmarkModel::BookmarkModel(QObject *parent) : QAbstractItemModel(parent)
+BookmarksTreeModel::BookmarksTreeModel(QObject *parent) : QAbstractItemModel(parent)
{
rootItem = new BookmarksTreeItem(BookmarksTreeItem::Root, {.title = tr("Title"), .href = tr("Address")}, nullptr);
}
-BookmarkModel::~BookmarkModel() { delete rootItem; }
+BookmarksTreeModel::~BookmarksTreeModel() { delete rootItem; }
-QVariant BookmarkModel::headerData(int section, Qt::Orientation, int role) const
+QVariant BookmarksTreeModel::headerData(int section, Qt::Orientation, int role) const
{
if (role != Qt::DisplayRole) return {};
return rootItem->data(static_cast<BookmarksTreeItem::Attributes>(section));
}
-QVariant BookmarkModel::data(const QModelIndex &index, int role) const
+QVariant BookmarksTreeModel::data(const QModelIndex &index, int role) const
{
if (!index.isValid()) return {};
@@ -61,7 +61,7 @@ QVariant BookmarkModel::data(const QModelIndex &index, int role) const
return {};
}
-bool BookmarkModel::setData(const QModelIndex &index, const QVariant &value, int role)
+bool BookmarksTreeModel::setData(const QModelIndex &index, const QVariant &value, int role)
{
if (!index.isValid()) return false;
@@ -80,7 +80,7 @@ bool BookmarkModel::setData(const QModelIndex &index, const QVariant &value, int
return success;
}
-Qt::ItemFlags BookmarkModel::flags(const QModelIndex &index) const
+Qt::ItemFlags BookmarksTreeModel::flags(const QModelIndex &index) const
{
switch (item(index)->type()) {
case BookmarksTreeItem::Root:
@@ -100,14 +100,14 @@ Qt::ItemFlags BookmarkModel::flags(const QModelIndex &index) const
__builtin_unreachable();
}
-int BookmarkModel::rowCount(const QModelIndex &index) const
+int BookmarksTreeModel::rowCount(const QModelIndex &index) const
{
if (index.column() > 0) return 0;
return static_cast<int>(item(index)->childCount());
}
-QModelIndex BookmarkModel::appendItem(BookmarksTreeItem::Types type, BookmarksTreeItem::Attributes_t data,
- const QModelIndex &parent)
+QModelIndex BookmarksTreeModel::appendItem(BookmarksTreeItem::Types type, BookmarksTreeItem::Attributes_t data,
+ const QModelIndex &parent)
{
auto *parentItem = item(parent);
const auto row = rowCount(parent);
@@ -126,7 +126,7 @@ QModelIndex BookmarkModel::appendItem(BookmarksTreeItem::Types type, BookmarksTr
return {};
}
-bool BookmarkModel::removeRows(int position, int rows, const QModelIndex &parent)
+bool BookmarksTreeModel::removeRows(int position, int rows, const QModelIndex &parent)
{
auto *parentItem = item(parent);
@@ -138,7 +138,7 @@ bool BookmarkModel::removeRows(int position, int rows, const QModelIndex &parent
return success;
}
-QModelIndex BookmarkModel::index(int row, int column, const QModelIndex &parent) const
+QModelIndex BookmarksTreeModel::index(int row, int column, const QModelIndex &parent) const
{
if (!this->hasIndex(row, column, parent)) return {};
@@ -148,7 +148,7 @@ QModelIndex BookmarkModel::index(int row, int column, const QModelIndex &parent)
return {};
}
-QModelIndex BookmarkModel::parent(const QModelIndex &index) const
+QModelIndex BookmarksTreeModel::parent(const QModelIndex &index) const
{
if (!index.isValid()) return {};
@@ -160,7 +160,7 @@ QModelIndex BookmarkModel::parent(const QModelIndex &index) const
return createIndex(parentItem->row(), 0, parentItem);
}
-QModelIndex BookmarkModel::parentFolder(const QModelIndex &index) const
+QModelIndex BookmarksTreeModel::parentFolder(const QModelIndex &index) const
{
// invalid index is the root index -> return it back
if (!index.isValid()) return {};
@@ -170,7 +170,7 @@ QModelIndex BookmarkModel::parentFolder(const QModelIndex &index) const
return index;
}
-BookmarksTreeItem *BookmarkModel::item(const QModelIndex &index) const
+BookmarksTreeItem *BookmarksTreeModel::item(const QModelIndex &index) const
{
if (!index.isValid()) return rootItem;
return static_cast<BookmarksTreeItem *>(index.internalPointer());
@@ -178,12 +178,12 @@ BookmarksTreeItem *BookmarkModel::item(const QModelIndex &index) const
/*
* Drag'n'Drop implementation
- * How drag and drop actually works: the view encodes the data of the original item (using BookmarkModel::mimeData), and
- * then uses BookmarkModel::dropMimeData to create the new item. If successful, the old item is removed (through
- * BookmarkModel::removeRows).
+ * How drag and drop actually works: the view encodes the data of the original item (using
+ * BookmarksTreeModel::mimeData), and then uses BookmarksTreeModel::dropMimeData to create the new item. If successful,
+ * the old item is removed (through BookmarksTreeModel::removeRows).
*/
-QMimeData *BookmarkModel::mimeData(const QModelIndexList &indexes) const
+QMimeData *BookmarksTreeModel::mimeData(const QModelIndexList &indexes) const
{
QByteArray data;
QBuffer buffer(&data);
@@ -201,8 +201,8 @@ QMimeData *BookmarkModel::mimeData(const QModelIndexList &indexes) const
return mimeData;
}
-bool BookmarkModel::dropMimeData(const QMimeData *mimeData, Qt::DropAction action, int row, int column,
- const QModelIndex &parent)
+bool BookmarksTreeModel::dropMimeData(const QMimeData *mimeData, Qt::DropAction action, int row, int column,
+ const QModelIndex &parent)
{
if (action == Qt::IgnoreAction) return true;
if (action != Qt::MoveAction) return false; // we only implement MoveAction's
@@ -229,9 +229,9 @@ bool BookmarkModel::dropMimeData(const QMimeData *mimeData, Qt::DropAction actio
return true;
}
-QList<QString> BookmarkModel::load(QIODevice *buffer) { return readFns[Formats::FormatXbel](buffer, rootItem); }
+QList<QString> BookmarksTreeModel::load(QIODevice *buffer) { return readFns[Formats::FormatXbel](buffer, rootItem); }
-void BookmarkModel::save(QIODevice *buffer)
+void BookmarksTreeModel::save(QIODevice *buffer)
{
if (!buffer->isOpen() || !buffer->isWritable()) return;
m_isModified = !writeFns[Formats::FormatXbel](buffer, {rootItem});
diff --git a/src/bookmarks/bookmarkstreemodel.hpp b/src/bookmarks/bookmarkstreemodel.hpp
index f92166d3..23257040 100644
--- a/src/bookmarks/bookmarkstreemodel.hpp
+++ b/src/bookmarks/bookmarkstreemodel.hpp
@@ -13,14 +13,14 @@
#include <QAbstractItemModel>
class QFile;
-class BookmarkModel final : public QAbstractItemModel {
+class BookmarksTreeModel final : public QAbstractItemModel {
Q_OBJECT
public:
enum Roles { CompletionMatchingRole = Qt::UserRole + 1 };
- explicit BookmarkModel(QObject *parent = nullptr);
- ~BookmarkModel() final;
+ explicit BookmarksTreeModel(QObject *parent = nullptr);
+ ~BookmarksTreeModel() final;
[[nodiscard]] QVariant headerData(int section, Qt::Orientation orientation, int role) const override;
[[nodiscard]] QVariant data(const QModelIndex &index, int role) const override;
diff --git a/src/bookmarks/test/bookmarkmanager.cpp b/src/bookmarks/test/bookmarkmanager.cpp
deleted file mode 100644
index 5bfaf649..00000000
--- a/src/bookmarks/test/bookmarkmanager.cpp
+++ /dev/null
@@ -1,21 +0,0 @@
-#include "../bookmarkmanager.hpp"
-#include <QStandardPaths>
-#include <gtest/gtest.h>
-
-// clazy:excludeall=non-pod-global-static
-
-namespace {
-TEST(BookmarkManager, QStandardPaths)
-{
- const auto file = QStandardPaths::locate(QStandardPaths::AppLocalDataLocation, QString::fromLatin1("bookmarks.xbel"));
- EXPECT_TRUE(file.isEmpty()) << qUtf8Printable(file);
-}
-
-TEST(BookmarkManager, Manager)
-{
- BookmarkManager manager("bookmarks.xbel");
-
- const auto load_errors = manager.errors();
- EXPECT_EQ(load_errors.length(), 0) << qUtf8Printable(load_errors.join('\n'));
-}
-} // namespace \ No newline at end of file
diff --git a/src/bookmarks/test/test_bookmarkstreemodel.cpp b/src/bookmarks/test/test_bookmarkstreemodel.cpp
new file mode 100644
index 00000000..febd4cd4
--- /dev/null
+++ b/src/bookmarks/test/test_bookmarkstreemodel.cpp
@@ -0,0 +1,25 @@
+#include <QFile>
+#include <QStandardPaths>
+#include <gtest/gtest.h>
+
+#include "../bookmarkstreemodel.hpp"
+
+// clazy:excludeall=non-pod-global-static
+
+namespace {
+TEST(bookmarks, QStandardPaths)
+{
+ const auto file = QStandardPaths::locate(QStandardPaths::AppLocalDataLocation, QString::fromLatin1("bookmarks.xbel"));
+ EXPECT_TRUE(file.isEmpty()) << qUtf8Printable(file);
+}
+
+TEST(bookmarks, BookmarksTreeModel)
+{
+ BookmarksTreeModel model;
+ QFile f("bookmarks.xbel");
+ ASSERT_TRUE(f.open(QIODevice::ReadOnly | QIODevice::Text));
+
+ EXPECT_TRUE(model.load(&f).isEmpty());
+ f.close();
+}
+} // namespace
diff --git a/src/panels/bookmarkspanel.cpp b/src/panels/bookmarkspanel.cpp
index 5eda1c67..dab99203 100644
--- a/src/panels/bookmarkspanel.cpp
+++ b/src/panels/bookmarkspanel.cpp
@@ -18,9 +18,9 @@ BookmarksPanel::BookmarksPanel(QWidget *parent) : QTreeView(parent)
connect(this, &QTreeView::customContextMenuRequested, this, &BookmarksPanel::customContextMenu);
}
-BookmarkModel *BookmarksPanel::model() const
+BookmarksTreeModel *BookmarksPanel::model() const
{
- auto *m = qobject_cast<BookmarkModel *>(QTreeView::model());
+ auto *m = qobject_cast<BookmarksTreeModel *>(QTreeView::model());
Q_CHECK_PTR(m);
return m;
}
diff --git a/src/panels/bookmarkspanel.hpp b/src/panels/bookmarkspanel.hpp
index 38d58f14..9dc969a7 100644
--- a/src/panels/bookmarkspanel.hpp
+++ b/src/panels/bookmarkspanel.hpp
@@ -13,7 +13,7 @@
#include "rekonq.hpp"
#include <QTreeView>
-class BookmarkModel;
+class BookmarksTreeModel;
class BookmarksPanel : public QTreeView {
Q_OBJECT
@@ -32,5 +32,5 @@ private slots:
void remove(const QModelIndex &index);
private:
- [[nodiscard]] BookmarkModel *model() const;
+ [[nodiscard]] BookmarksTreeModel *model() const;
};
diff --git a/src/test/application_mock.hpp b/src/test/application_mock.hpp
index cff135a8..7001346d 100644
--- a/src/test/application_mock.hpp
+++ b/src/test/application_mock.hpp
@@ -11,7 +11,7 @@ public:
~FakeApplication() override = default;
MOCK_METHOD(bool, registerPlugin, (const QString &), (override));
- MOCK_METHOD(BookmarkModel *, bookmarks, (), (const override));
+ MOCK_METHOD(BookmarksTreeModel *, bookmarks, (), (const override));
MOCK_METHOD(RekonqWindow *, newWindow, (), (override));
MOCK_METHOD(RekonqView *, newView, (const QUrl &, RekonqWindow *), (override));