diff options
author | toma <toma@283d02a7-25f6-0310-bc7c-ecb5cbfe19da> | 2009-11-25 17:56:58 +0000 |
---|---|---|
committer | toma <toma@283d02a7-25f6-0310-bc7c-ecb5cbfe19da> | 2009-11-25 17:56:58 +0000 |
commit | 460c52653ab0dcca6f19a4f492ed2c5e4e963ab0 (patch) | |
tree | 67208f7c145782a7e90b123b982ca78d88cc2c87 /akregator/src/viewer.h | |
download | tdepim-460c52653ab0dcca6f19a4f492ed2c5e4e963ab0.tar.gz tdepim-460c52653ab0dcca6f19a4f492ed2c5e4e963ab0.zip |
Copy the KDE 3.5 branch to branches/trinity for new KDE 3.5 features.
BUG:215923
git-svn-id: svn://anonsvn.kde.org/home/kde/branches/trinity/kdepim@1054174 283d02a7-25f6-0310-bc7c-ecb5cbfe19da
Diffstat (limited to 'akregator/src/viewer.h')
-rw-r--r-- | akregator/src/viewer.h | 123 |
1 files changed, 123 insertions, 0 deletions
diff --git a/akregator/src/viewer.h b/akregator/src/viewer.h new file mode 100644 index 000000000..364aeb9e6 --- /dev/null +++ b/akregator/src/viewer.h @@ -0,0 +1,123 @@ +/* + This file is part of Akregator. + + Copyright (C) 2004 Teemu Rytilahti <tpr@d5k.net> + + 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) 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, write to the Free Software + Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. + + As a special exception, permission is given to link this program + with any edition of Qt, and distribute the resulting executable, + without including the source code for Qt in the source distribution. +*/ + +#ifndef VIEWER_H +#define VIEWER_H + +#include <khtml_part.h> + +class KURL; + +namespace KIO +{ + class MetaData; +} + +namespace Akregator +{ + class Viewer : public KHTMLPart + { + Q_OBJECT + public: + + /** + * Display article in external browser. + */ + static void displayInExternalBrowser(const KURL &url, const QString& mimetype=QString::null); + + Viewer(QWidget* parent, const char* name); + virtual ~Viewer(); + + virtual bool closeURL(); + + + public slots: + + void slotScrollUp(); + void slotScrollDown(); + void slotZoomIn(); + void slotZoomOut(); + void slotSetZoomFactor(int percent); + void slotPrint(); + void setSafeMode(); + + virtual void slotPaletteOrFontChanged() = 0; + + signals: + /** This gets emitted when url gets clicked */ + void urlClicked(const KURL& url, Viewer* viewer, bool newTab, bool background); + + protected: // methods + int pointsToPixel(int points) const; + + protected slots: + + // FIXME: Sort out how things are supposed to work and clean up the following slots + + /** reimplemented to handle url selection according to the settings for LMB and MMB */ + virtual void urlSelected(const QString &url, int button, int state, const QString &_target, KParts::URLArgs args); + + /** slot for handling openURLRequestDelayed() signal from the browserextension. Handles POST requests (for forms) only, other link handling goes to urlSelected(). Does nothing in Viewer, reimplemented in PageViewer to make forms working */ + virtual void slotOpenURLRequest(const KURL& url, const KParts::URLArgs& args); + + virtual void slotPopupMenu(KXMLGUIClient*, const QPoint&, const KURL&, const KParts::URLArgs&, KParts::BrowserExtension::PopupFlags, mode_t); + + /** Copies current link to clipboard. */ + void slotCopyLinkAddress(); + + /** Copies currently selected text to clipboard */ + virtual void slotCopy(); + + /** Opens @c m_url inside this viewer */ + virtual void slotOpenLinkInternal(); + + /** Opens @c m_url in external viewer, eg. Konqueror */ + virtual void slotOpenLinkInBrowser(); + + /** Opens @c m_url in foreground tab */ + virtual void slotOpenLinkInForegroundTab(); + + /** Opens @c m_url in background tab */ + virtual void slotOpenLinkInBackgroundTab(); + + virtual void slotOpenLinkInThisTab(); + + virtual void slotSaveLinkAs(); + + /** This changes cursor to wait cursor */ + void slotStarted(KIO::Job *); + + /** This reverts cursor back to normal one */ + void slotCompleted(); + + virtual void slotSelectionChanged(); + + protected: // attributes + KURL m_url; + + }; +} + +#endif // VIEWER_H +// vim: ts=4 sw=4 et |