File indexing completed on 2024-09-08 03:36:50

0001 /*
0002     This file is part of the KDE libraries
0003     SPDX-FileCopyrightText: 2000, 2006 David Faure <faure@kde.org>
0004 
0005     SPDX-License-Identifier: LGPL-2.0-only
0006 */
0007 #ifndef KBOOKMARK_OWNER_H
0008 #define KBOOKMARK_OWNER_H
0009 
0010 #include "kbookmark.h"
0011 
0012 #include <QSharedDataPointer>
0013 #include <QString>
0014 
0015 class QWidget;
0016 
0017 class KBookmarkGroup;
0018 
0019 /**
0020  * @class KBookmarkOwner kbookmarkowner.h KBookmarkOwner
0021  *
0022  * The KBookmarkMenu and KBookmarkBar classes gives the user
0023  * the ability to either edit bookmarks or add their own.  In the
0024  * first case, the app may want to open the bookmark in a special way.
0025  * In the second case, the app @em must supply the name and the
0026  * URL for the bookmark.
0027  *
0028  * This class gives the app this callback-like ability.
0029  *
0030  * If your app does not give the user the ability to add bookmarks and
0031  * you don't mind using the default bookmark editor to edit your
0032  * bookmarks, then you don't need to overload this class at all.
0033  * Rather, just use something like:
0034  *
0035  * @code
0036  * bookmarks = new KBookmarkMenu(manager, nullptr, menu);
0037  * @endcode
0038  *
0039  * If you wish to use your own editor or allow the user to add
0040  * bookmarks, you must overload this class.
0041  */
0042 class KBOOKMARKS_EXPORT KBookmarkOwner
0043 {
0044 public:
0045     KBookmarkOwner();
0046     virtual ~KBookmarkOwner();
0047 
0048     /**
0049      * This function is called whenever the user wants to add the
0050      * current page to the bookmarks list.  The title will become the
0051      * "name" of the bookmark.  You must overload this function if you
0052      * wish to give your users the ability to add bookmarks.
0053      * The default returns an empty string.
0054      *
0055      * @return the title of the current page.
0056      */
0057     virtual QString currentTitle() const
0058     {
0059         return QString();
0060     }
0061 
0062     /**
0063      * This function is called whenever the user wants to add the
0064      * current page to the bookmarks list.  The URL will become the URL
0065      * of the bookmark.  You must overload this function if you wish to
0066      * give your users the ability to add bookmarks.
0067      * The default returns an empty string.
0068      *
0069      * @return the URL of the current page.
0070      * Since 5.0 this method returns a QUrl. While porting it, remember to implement currentIcon too.
0071      */
0072     virtual QUrl currentUrl() const
0073     {
0074         return QUrl();
0075     }
0076 
0077     /**
0078      * This function is called whenever the user wants to add the
0079      * current page to the bookmarks list.  The icon will become the icon
0080      * of the bookmark.  You must overload this function if you wish to
0081      * give your users the ability to add bookmarks.
0082      * The default returns an empty string.
0083      *
0084      * A very common implementation for this method is
0085      * return KIO::iconNameForUrl(currentUrl());
0086      *
0087      * @return the icon name of the current page.
0088      * @since 5.0
0089      */
0090     virtual QString currentIcon() const
0091     {
0092         return QString();
0093     }
0094 
0095     /**
0096      * This function returns whether the owner supports tabs.
0097      * The default returns @c false.
0098      */
0099     virtual bool supportsTabs() const
0100     {
0101         return false;
0102     }
0103 
0104     class FutureBookmarkPrivate;
0105     /**
0106      * Represents the data for a bookmark that will be added.
0107      * @since 5.0
0108      */
0109     class KBOOKMARKS_EXPORT FutureBookmark
0110     {
0111     public:
0112         FutureBookmark(const QString &title, const QUrl &url, const QString &icon);
0113         ~FutureBookmark();
0114         FutureBookmark(const FutureBookmark &other);
0115         FutureBookmark &operator=(const FutureBookmark &other);
0116 
0117         QString title() const;
0118         QUrl url() const;
0119         QString icon() const;
0120 
0121     private:
0122         QSharedDataPointer<FutureBookmarkPrivate> d;
0123     };
0124 
0125     /**
0126      * Returns a list of bookmark data for the open tabs.
0127      * The default returns an empty list.
0128      */
0129     virtual QList<FutureBookmark> currentBookmarkList() const
0130     {
0131         return QList<FutureBookmark>();
0132     }
0133 
0134     enum BookmarkOption { ShowAddBookmark, ShowEditBookmark };
0135 
0136     /** Returns true if \p action should be shown in the menu
0137      *  The default is to show both a add and editBookmark Entry
0138      *  //TODO ContextMenuAction? to disable the contextMenu?
0139      *         Delete and Properties to disable those in the
0140      *         context menu?
0141      */
0142     virtual bool enableOption(BookmarkOption option) const;
0143 
0144     /**
0145      * Called if a bookmark is selected. You need to override this.
0146      */
0147     virtual void openBookmark(const KBookmark &bm, Qt::MouseButtons mb, Qt::KeyboardModifiers km) = 0;
0148 
0149     /**
0150      * Called if the user wants to open every bookmark in this folder in a new tab.
0151      * The default implementation does nothing.
0152      * This is only called if supportsTabs() returns true
0153      */
0154     virtual void openFolderinTabs(const KBookmarkGroup &bm);
0155 
0156     /**
0157      * Called when a bookmark should be opened in a new tab.
0158      * The default implementation calls openBookmark.
0159      * @since 5.0
0160      */
0161     virtual void openInNewTab(const KBookmark &bm);
0162 
0163     /**
0164      * Called when a bookmark should be opened in a new window.
0165      * The default implementation calls openBookmark.
0166      * @since 5.0
0167      */
0168     virtual void openInNewWindow(const KBookmark &bm);
0169 
0170 private:
0171     class KBookmarkOwnerPrivate;
0172     KBookmarkOwnerPrivate *d;
0173 };
0174 
0175 #endif