/*************************************************************************** scripttreeview.h - description ------------------- begin : Thu Sep 16 2003 copyright : (C) 2003-2004 by Andras Mantia <amantia@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; version 2 of the License. * * * ***************************************************************************/ #ifndef SCRIPTTREEVIEW_H #define SCRIPTTREEVIEW_H //own includes #include "basetreeview.h" /** * @short treeview with all in Quanta available scripts. * * You can manage and excecute scripts from here. * * There are local and global scripts in different branches. * * For every script should exist an .info file! * * The .info file is an xhtml file with the extention .info and * must be in one folder together with the script. * * Inside of your .info file should be an options tag like this * example: * * <options editor="kmdr-editor" interpreter="kmdr-executor" /> * * Here is defined which program is used for editing and executing the script. * * @author Andras Mantia <amantia@kde.org> */ class ScriptTreeView : public BaseTreeView { Q_OBJECT TQ_OBJECT public: ScriptTreeView(TQWidget *parent, const char *name = 0L); ~ScriptTreeView(); protected slots: /** * displays the RBM * * * @param listView KListView where the event comes from * * @param item TQListViewItem where the mousepointer is hovering * * @param point TQPoint coordinates of the event * */ virtual void slotMenu(KListView *listView, TQListViewItem *item, const TQPoint &point); /** * slot of TQListView * * shows the .info file for the script * * @param item the selected TQListViewItem */ virtual void slotSelectFile(TQListViewItem *item); /** * slot for the RBM * * invokes the editor for a script */ void slotEditScript(); /** * slot for the RBM * * opens the script in Quanta * * if @ref infoOptionValue can not find the definition of the editor * in the .info file the script will be opened in Quanta */ void slotEditInQuanta(); /** * slot for the RBM * * opens the .info file of the script in Quanta */ void slotEditDescription(); /** * slot for the RBM * * excecutes the script * * If @ref infoOptionValue can not find the definition of the interpreter * in the .info file you will get a open-with dialog to choose a program. */ void slotRun(); /** * slot for the RBM * * opens an dialog to assign an action to this script */ void slotAssignAction(); /** * slot for the RBM * * packs and sends the script as attachment to an email */ void slotSendScriptInMail(); /** * slot for the RBM * * packs and uploads the script to the main server */ void slotUploadScript(); /** * slot for the RBM * * shows .info file for the script * * calls @ref slotSelectFile */ void slotProperties(); protected: /** * don't need this in the class but it is abstract in the base class * so I need to implement it */ virtual KFileTreeBranch* newBranch(const KURL& url) { Q_UNUSED(url) return 0l; }; signals: /** * emited from @ref slotSelectFile to display the .info file */ void openFileInPreview(const KURL&); /** * emited from @ref slotAssignAction to open the assignment dialog */ void assignActionToScript(const KURL&, const TQString&); /** * emited to make the script describtion visible */ void showPreviewWidget(bool); /** * emitted to request downloading of a script from the main server */ void downloadScript(); /** * request to upload the @ref fileName script tarball */ void uploadScript(const TQString& fileName); private: /** * make the default constructor private to force the use of the other one */ ScriptTreeView() { }; /** * creates the URL of the .info file * * @param url URL of the script file * @param htmlVersion if true returns the HTML version of the file * * @return URL of the matching .info file (no check is done if the file exists) */ KURL infoFile(const KURL& url, bool htmlVersion = false); /** * query options from the .info file * * inside of your .info file only the first options tag is located * * @param infoURL URL of the .info file * * @param optionName name of the option you want to query * * @return the value of the option */ TQString infoOptionValue(const KURL& infoURL, const TQString& optionName); /** Create a script tarball which can be uploaded or sent in email. Returns * the name of the created file or TQString() if creation has failed. */ TQString createScriptTarball(); /** * remember the menu for manipulation */ KPopupMenu *m_fileMenu; KPopupMenu *m_folderMenu; int m_downloadMenuId; }; #endif