/* This file is part of the KDE projects Copyright (C) 2000 David Faure <faure@kde.org> 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; see the file COPYING. If not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ #ifndef __konqdirpart_h #define __konqdirpart_h #include <tqstring.h> #include <tdeparts/part.h> #include <tdeparts/browserextension.h> #include <tdefileitem.h> #include <kdatastream.h> #include <tdeio/global.h> #include <libkonq_export.h> class KDirLister; namespace KParts { class BrowserExtension; } class KonqPropsView; class TQScrollView; class TDEAction; class TDEToggleAction; class KonqDirPartBrowserExtension; class LIBKONQ_EXPORT KonqDirPart: public KParts::ReadOnlyPart { TQ_OBJECT friend class KonqDirPartBrowserExtension; public: KonqDirPart( TQObject *parent, const char *name ); virtual ~KonqDirPart(); /** * The derived part should call this in its constructor */ void setBrowserExtension( KonqDirPartBrowserExtension * extension ) { m_extension = extension; } KonqDirPartBrowserExtension * extension() { return m_extension; } /** * The derived part should call this in its constructor */ void setDirLister( KDirLister* lister ); // TODO KDE4 create the KDirLister here and simplify the parts? TQScrollView * scrollWidget(); virtual void saveState( TQDataStream &stream ); virtual void restoreState( TQDataStream &stream ); /** Called when LMB'ing an item in a directory view. * @param fileItem must be set * @param widget is only set as parent pointer for dialog boxes */ void lmbClicked( KFileItem * fileItem ); /** Called when MMB'ing an item in a directory view. * @param fileItem if 0 it means we MMB'ed the background. */ void mmbClicked( KFileItem * fileItem ); void setNameFilter( const TQString & nameFilter ) { m_nameFilter = nameFilter; } TQString nameFilter() const { return m_nameFilter; } void setFilesToSelect( const TQStringList & filesToSelect ) { m_filesToSelect = filesToSelect; } /** * Sets per directory mime-type based filtering. * * This method causes only the items matching the mime-type given * by @p filters to be displayed. You can supply multiple mime-types * by separating them with a space, eg. "text/plain image/x-png". * To clear all the filters set for the current url simply call this * function with a null or empty argument. * * NOTE: the filter(s) specified here only apply to the current * directory as returned by @ref #url(). * * @param filter mime-type(s) to filter directory by. */ void setMimeFilter (const TQStringList& filters); /** * Completely clears the internally stored list of mime filters * set by call to @ref #setMimeFilter. */ TQStringList mimeFilter() const; KonqPropsView * props() const { return m_pProps; } /** * "Cut" icons : disable those whose URL is in lst, enable the others */ virtual void disableIcons( const KURL::List & lst ) = 0; /** * This class takes care of the counting of items, size etc. in the * current directory. Call this in slotClear. */ void resetCount(); /** * Update the counts for those new items */ void newItems( const KFileItemList & entries ); /** * Update the counts with this item being deleted */ void deleteItem( KFileItem * fileItem ); /** * Refresh the items */ void refreshItems(const KFileItemList &entries); /** * Show the counts for the directory in the status bar */ void emitTotalCount(); // ##### TODO KDE 4: remove! /** * Show the counts for the list of items in the status bar. * If none are provided emitTotalCount() is called to display * the counts for the whole directory. However, that does not work * for a treeview. * * @deprecated */ void emitCounts( const KFileItemList & lst, bool selectionChanged ); /** * Show the counts for the list of items in the status bar. The list * can be empty. * * @param lst the list of fileitems for which to display the counts * @since 3.4 */ void emitCounts( const KFileItemList & lst ); void emitMouseOver( const KFileItem * item ); /** * Enables or disables the paste action. This depends both on * the data in the clipboard and the number of files selected * (pasting is only possible if not more than one file is selected). */ void updatePasteAction(); /** * Change the icon size of the view. * The view should call it initially. * The view should also reimplement it, to update the icons. */ virtual void newIconSize( int size ); /** * This is called by the actions that change the icon size. * It stores the new size and calls newIconSize. */ void setIconSize( int size ); /** * This is called by konqueror itself, when the "find" functionality is activated */ void setFindPart( KParts::ReadOnlyPart * part ); KParts::ReadOnlyPart * findPart() const { return m_findPart; } virtual const KFileItem * currentItem() = 0; // { return 0L; } virtual KFileItemList selectedFileItems() { return KFileItemList(); } /** * Re-implemented for internal reasons. API is unaffected. All inheriting * classes should re-implement @ref doCloseURL() instead instead of this one. */ bool closeURL (); signals: /** * Emitted whenever the current URL is about to be changed. */ void aboutToOpenURL(); /** * We emit this if we want a find part to be created for us. * This happens when restoring from history */ void findOpen( KonqDirPart * ); /** * We emit this _after_ a find part has been created for us. * This also happens initially. */ void findOpened( KonqDirPart * ); /** * We emit this to ask konq to close the find part */ void findClosed( KonqDirPart * ); /** * Emitted as the part is updated with new items. * Useful for informing plugins of changes in view. */ void itemsAdded(const KFileItemList &); /** * Emitted as the part is updated with these items. * Useful for informing plugins of changes in view. */ void itemRemoved(const KFileItem *); /** * Emitted when items need to be refreshed (for example when * a file is renamed) */ void itemsRefresh(const KFileItemList &); /** * Emitted with the list of filtered-out items whenever * a mime-based filter(s) is set. */ void itemsFilteredByMime( const KFileItemList& ); public slots: /** * Re-implemented for internal reasons. API is unaffected. All inheriting * classes should re-implement @ref doOpenURL() instead instead of this one. */ bool openURL (const KURL&); /** * This is called either by the part's close button, or by the * dir part itself, if entering a directory. It deletes the find * part. */ void slotFindClosed(); /** * Start the animated "K" during kfindpart's file search */ void slotStartAnimationSearching(); /** * Start the animated "K" during kfindpart's file search */ void slotStopAnimationSearching(); void slotBackgroundSettings(); /** * Called when the clipboard's data changes, to update the 'cut' icons * Call this when the directory's listing is finished, to draw icons as cut. */ void slotClipboardDataChanged(); void slotIncIconSize(); void slotDecIconSize(); void slotIconSizeToggled( bool ); // slots connected to the directory lister - or to the kfind interface virtual void slotStarted() = 0; virtual void slotCanceled() = 0; virtual void slotCompleted() = 0; virtual void slotNewItems( const KFileItemList& ) = 0; virtual void slotDeleteItem( KFileItem * ) = 0; virtual void slotRefreshItems( const KFileItemList& ) = 0; virtual void slotClear() = 0; virtual void slotRedirection( const KURL & ) = 0; private slots: void slotIconChanged(int group); protected: /** * Invoked from openURL to enable childern classes to * handle open URL requests. */ virtual bool doOpenURL( const KURL& ) = 0; virtual bool doCloseURL () = 0; protected: TQString m_nameFilter; TQStringList m_filesToSelect; KonqPropsView * m_pProps; TDEAction *m_paIncIconSize; TDEAction *m_paDecIconSize; TDEToggleAction *m_paDefaultIcons; TDEToggleAction *m_paHugeIcons; TDEToggleAction *m_paLargeIcons; TDEToggleAction *m_paMediumIcons; TDEToggleAction *m_paSmallIcons; KParts::ReadOnlyPart * m_findPart; KonqDirPartBrowserExtension * m_extension; // Remove all those in KDE4 int m_iIconSize[5]; TDEIO::filesize_t m_lDirSize; uint m_lFileCount; uint m_lDirCount; private: void saveFindState( TQDataStream& ); void restoreFindState( TQDataStream& ); void adjustIconSizes(); class KonqDirPartPrivate; KonqDirPartPrivate* d; }; class LIBKONQ_EXPORT KonqDirPartBrowserExtension : public KParts::BrowserExtension { public: KonqDirPartBrowserExtension( KonqDirPart* dirPart ) : KParts::BrowserExtension( dirPart ) , m_dirPart( dirPart ) {} /** * This calls saveState in KonqDirPart, and also takes care of the "find part". * * If your KonqDirPart-derived class needs to save and restore state, * you should probably override KonqDirPart::saveState * and KonqDirPart::restoreState, not the following methods. */ virtual void saveState( TQDataStream &stream ); virtual void restoreState( TQDataStream &stream ); private: KonqDirPart* m_dirPart; }; #endif