|
|
|
/***************************************************************************
|
|
|
|
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
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
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
|