vymmodel.h
author insilmaril
Sat, 08 Aug 2009 21:58:26 +0000
changeset 787 c6bb4fdcc55f
parent 786 6269016c9905
child 788 78ba80b54bc4
permissions -rw-r--r--
Fixed selections with cursor in MapEditor
insilmaril@650
     1
#ifndef VYMMODEL_H
insilmaril@650
     2
#define VYMMODEL_H
insilmaril@650
     3
insilmaril@650
     4
#include <QGraphicsScene>
insilmaril@721
     5
#include <QtNetwork>
insilmaril@650
     6
insilmaril@784
     7
#include <QtDBus/QDBusAbstractAdaptor>
insilmaril@784
     8
#include <QtDBus/QDBusVariant>
insilmaril@784
     9
insilmaril@784
    10
#include "adaptormodel.h"
insilmaril@721
    11
#include "file.h"
insilmaril@776
    12
#include "imageitem.h"
insilmaril@650
    13
#include "mapeditor.h"
insilmaril@721
    14
#include "parser.h"
insilmaril@726
    15
#include "treeitem.h"
insilmaril@725
    16
#include "treemodel.h"
insilmaril@650
    17
insilmaril@786
    18
class AttributeItem;
insilmaril@749
    19
class BranchItem;
insilmaril@754
    20
class MapEditor;
insilmaril@749
    21
insilmaril@784
    22
class VymModel :  public TreeModel {		
insilmaril@696
    23
	Q_OBJECT
insilmaril@784
    24
	Q_CLASSINFO("D-Bus Interface", "org.insilmaril.vym.VymModel-h")
insilmaril@784
    25
insilmaril@696
    26
insilmaril@721
    27
////////////////////////////////////////////
insilmaril@721
    28
// General housekeeping
insilmaril@721
    29
////////////////////////////////////////////
insilmaril@721
    30
private:
insilmaril@721
    31
	QString version;	//!< version string saved in vym file
insilmaril@721
    32
	QString author;
insilmaril@721
    33
	QString comment;
insilmaril@721
    34
	QDate date;
insilmaril@721
    35
insilmaril@650
    36
public:
insilmaril@650
    37
	VymModel();
insilmaril@650
    38
	~VymModel ();
insilmaril@650
    39
    void clear();
insilmaril@650
    40
    void init();
insilmaril@721
    41
	void makeTmpDirectories();		//!< create temporary directories e.g. for history
insilmaril@721
    42
insilmaril@754
    43
	MapEditor* getMapEditor();			// FIXME-2 still necessary?
insilmaril@721
    44
insilmaril@721
    45
	bool isRepositionBlocked();		//!< While load or undo there is no need to update graphicsview
insilmaril@721
    46
insilmaril@721
    47
	void updateActions();			//!< Update buttons in mainwindow
insilmaril@721
    48
insilmaril@721
    49
insilmaril@721
    50
////////////////////////////////////////////
insilmaril@721
    51
// Load/save 
insilmaril@721
    52
////////////////////////////////////////////
insilmaril@721
    53
private:
insilmaril@721
    54
insilmaril@721
    55
	bool zipped;				// should map be zipped
insilmaril@721
    56
	static	int mapNum;			// unique number for model used in save/undo
insilmaril@721
    57
	FileType fileType;			// type of file, e.g. vym, freemind...
insilmaril@721
    58
	QString fileName;			// short name of file (for tab)
insilmaril@721
    59
	QString filePath;			// path to file which will be saved
insilmaril@721
    60
	QString fileDir;			// dir where file is saved
insilmaril@721
    61
	QString destPath;			// path to .vym file (needed for vymlinks)
insilmaril@721
    62
	QString mapName;			// fileName without ".vym"
insilmaril@721
    63
insilmaril@721
    64
	QString tmpMapDir;			// tmp directory with undo history
insilmaril@721
    65
insilmaril@721
    66
	QTimer *autosaveTimer;
insilmaril@721
    67
	QTimer *fileChangedTimer;
insilmaril@721
    68
	QDateTime fileChangedTime;
insilmaril@721
    69
insilmaril@721
    70
public:
insilmaril@721
    71
	/*! This function saves all information of the map to disc.
insilmaril@721
    72
	    saveToDir also calls the functions for all BranchObj and other objects in the map.
insilmaril@721
    73
		The structure of the map itself is returned as QString and passed back to Main, 
insilmaril@721
    74
		where saveToDir is called initially
insilmaril@721
    75
	*/	
insilmaril@753
    76
    QString saveToDir (const QString &tmpdir, const QString &prefix, bool writeflags, const QPointF &offset, TreeItem *saveSel);
insilmaril@721
    77
insilmaril@745
    78
	/*! Save all data in tree*/
insilmaril@745
    79
	QString saveTreeToDir (const QString&,const QString&,int, const QPointF&);// Save data recursivly to tempdir
insilmaril@745
    80
insilmaril@745
    81
insilmaril@721
    82
	/*! \brief Sets filepath, filename and mapname
insilmaril@721
    83
insilmaril@721
    84
	     If the filepath is "/home/tux/map.xml", then the filename will be set
insilmaril@721
    85
		 to map.xml. The destname is needed for vymLinks, pointing to another map. 
insilmaril@721
    86
		 The destname holds the real name of the file, after it has been compressed, e.g. "map.vym"
insilmaril@721
    87
	*/	 
insilmaril@721
    88
insilmaril@721
    89
insilmaril@721
    90
	/*! \brief Set File path
insilmaril@721
    91
insilmaril@721
    92
	     The destname is needed to construct the references between maps
insilmaril@721
    93
	*/	 
insilmaril@721
    94
	void setFilePath (QString filepath,QString destname);	
insilmaril@721
    95
	void setFilePath (QString);	//!< Overloaded for convenience
insilmaril@721
    96
	QString getFilePath ();	//!< Full path e.g. "/home/tux/map.xml"
insilmaril@721
    97
	QString getFileName ();	//!< e.g. "map.xml"
insilmaril@721
    98
	QString getMapName ();	//!< e.g. "map"
insilmaril@721
    99
	QString getDestPath (); //!< e.g. "/home/tux/map.vym"
insilmaril@721
   100
insilmaril@721
   101
	/*! \brief Load map
insilmaril@721
   102
insilmaril@721
   103
		The data is read from file. Depending on LoadMode the current
insilmaril@721
   104
		selection gets replaced by data or the data is appended.
insilmaril@721
   105
	*/	
insilmaril@721
   106
    ErrorCode load (QString, const LoadMode &, const FileType& );	// newmap, import/replace selection
insilmaril@721
   107
insilmaril@721
   108
public:
insilmaril@721
   109
	/*! \brief Save the map to file */
insilmaril@721
   110
    ErrorCode save(const SaveMode &);	
insilmaril@721
   111
insilmaril@721
   112
private:
insilmaril@721
   113
    void addMapReplaceInt(const QString & undoSel, const QString & path);
insilmaril@721
   114
    void addMapInsertInt (const QString & path, int pos);
insilmaril@721
   115
insilmaril@776
   116
	ImageItem* loadFloatImageInt (BranchItem *dst,QString);
insilmaril@776
   117
	void saveFloatImageInt (ImageItem*, const QString &, const QString &);
insilmaril@721
   118
public:	
insilmaril@721
   119
	void loadFloatImage ();
insilmaril@721
   120
	void saveFloatImage ();
insilmaril@721
   121
insilmaril@721
   122
private:	
insilmaril@721
   123
    void importDirInt(BranchObj *,QDir);
insilmaril@721
   124
    void importDirInt(const QString&);
insilmaril@721
   125
public:	
insilmaril@721
   126
    void importDir();
insilmaril@721
   127
insilmaril@721
   128
private slots:
insilmaril@721
   129
	void autosave ();
insilmaril@721
   130
	void fileChanged();
insilmaril@721
   131
insilmaril@721
   132
////////////////////////////////////////////
insilmaril@721
   133
// history (undo/redo)
insilmaril@721
   134
////////////////////////////////////////////
insilmaril@721
   135
private:
insilmaril@721
   136
    bool mapDefault;			//!< Flag if map is untouched
insilmaril@721
   137
    bool mapChanged;			//!< Flag if undo is possible
insilmaril@721
   138
	bool mapUnsaved;			//!< Flag if map should be saved
insilmaril@721
   139
insilmaril@721
   140
	QString histPath;			//!< Path to history file
insilmaril@721
   141
	SimpleSettings undoSet;		//!< undo/redo commands, saved in histPath
insilmaril@721
   142
	int stepsTotal;				//!< total number of steps (undos+redos) 
insilmaril@721
   143
	int curStep;				//!< Current step in history (ring buffer)
insilmaril@721
   144
	int curClipboard;			//!< number of history step, which is the current clipboard
insilmaril@721
   145
	int redosAvail;				//!< Available number of redo steps
insilmaril@721
   146
	int undosAvail;				//!< Available number of undo steps
insilmaril@721
   147
	bool blockReposition;		//!< block while load or undo
insilmaril@721
   148
	bool blockSaveState;		//!< block while load or undo
insilmaril@721
   149
public:
insilmaril@721
   150
	bool isDefault();			//!< true, if map is still the empty default map
insilmaril@721
   151
	void makeDefault();			//!< Reset changelog, declare this as default map
insilmaril@721
   152
    bool hasChanged()	;		//!< true, if something has changed and is not saved yet
insilmaril@721
   153
	void setChanged();			//!< called from TextEditor via LinkableMapObj
insilmaril@721
   154
insilmaril@721
   155
	/*! \brief Get name of object
insilmaril@721
   156
	  
insilmaril@721
   157
	  Returns heading of a branch or name of an object for use in comment
insilmaril@721
   158
	  of undo/redo history
insilmaril@721
   159
	*/ 
insilmaril@776
   160
	QString getObjectName(LinkableMapObj*);	
insilmaril@776
   161
	QString getObjectName(TreeItem*);	
insilmaril@721
   162
insilmaril@721
   163
    void redo();						//!< Redo last action
insilmaril@721
   164
	bool isRedoAvailable();				//!< True, if redo is available
insilmaril@721
   165
    void undo();						//!< Undo last action
insilmaril@721
   166
	bool isUndoAvailable();				//!< True, if undo is available
insilmaril@721
   167
	void gotoHistoryStep (int);			//!< Goto a specifig step in history
insilmaril@721
   168
insilmaril@721
   169
insilmaril@721
   170
	QString getHistoryPath();			//!< Path to directory containing the history
insilmaril@721
   171
insilmaril@721
   172
	/*! \brief Save the current changes in map 
insilmaril@721
   173
insilmaril@721
   174
		Two commands and selections are saved:
insilmaril@721
   175
insilmaril@721
   176
			- undocommand and undoselection to undo the change
insilmaril@721
   177
			- redocommand and redoselection to redo the action after an undo
insilmaril@721
   178
insilmaril@721
   179
		Additionally a comment is logged. 
insilmaril@721
   180
insilmaril@721
   181
	*/	
insilmaril@721
   182
    void saveState(
insilmaril@721
   183
		const SaveMode& savemode, 
insilmaril@721
   184
		const QString &undoSelection, 
insilmaril@721
   185
		const QString &undoCommand, 
insilmaril@721
   186
		const QString &redoSelection, 
insilmaril@721
   187
		const QString &redoCommand, 
insilmaril@721
   188
		const QString &comment, 
insilmaril@753
   189
		TreeItem *saveSelection);
insilmaril@721
   190
	/*! Overloaded for convenience */
insilmaril@721
   191
    void saveStateChangingPart(
insilmaril@753
   192
		TreeItem *undoSelection, 
insilmaril@753
   193
		TreeItem* redoSelection, 
insilmaril@721
   194
		const QString &redoCommand, 
insilmaril@721
   195
		const QString &comment);
insilmaril@721
   196
	/*! Overloaded for convenience */
insilmaril@721
   197
    void saveStateRemovingPart(
insilmaril@753
   198
		TreeItem *redoSelection, 
insilmaril@721
   199
		const QString &comment);
insilmaril@721
   200
	/*! Overloaded for convenience */
insilmaril@721
   201
    void saveState(
insilmaril@753
   202
		TreeItem *undoSelection, 
insilmaril@721
   203
		const QString &undoCommand, 
insilmaril@753
   204
		TreeItem *redoSelection, 
insilmaril@721
   205
		const QString &redoCommand, 
insilmaril@721
   206
		const QString &comment); 
insilmaril@721
   207
	/*! Overloaded for convenience */
insilmaril@721
   208
    void saveState(
insilmaril@721
   209
		const QString &undoSelection, 
insilmaril@721
   210
		const QString &undoCommand, 
insilmaril@721
   211
		const QString &redoSelection, 
insilmaril@721
   212
		const QString &redoCommand, 
insilmaril@721
   213
		const QString &comment) ;
insilmaril@721
   214
    void saveState(
insilmaril@721
   215
		const QString &undoCommand, 
insilmaril@721
   216
		const QString &redoCommand, 
insilmaril@721
   217
		const QString &comment) ;
insilmaril@721
   218
insilmaril@721
   219
insilmaril@721
   220
////////////////////////////////////////////
insilmaril@721
   221
// unsorted so far
insilmaril@721
   222
////////////////////////////////////////////
insilmaril@784
   223
private:
insilmaril@784
   224
	QGraphicsScene *mapScene;
insilmaril@721
   225
public:
insilmaril@721
   226
	void setScene(QGraphicsScene *s);
insilmaril@721
   227
	QGraphicsScene *getScene();
insilmaril@721
   228
insilmaril@761
   229
    TreeItem* findBySelectString (QString s);		
insilmaril@754
   230
    TreeItem* findID (const QString &s);				// find MapObj by previously set ID
insilmaril@721
   231
insilmaril@721
   232
insilmaril@721
   233
////////////////////////////////////////////
insilmaril@721
   234
// Interface 
insilmaril@721
   235
////////////////////////////////////////////
insilmaril@721
   236
public:
insilmaril@650
   237
	void setVersion(const  QString &);
insilmaril@650
   238
	void setAuthor  (const QString &);
insilmaril@650
   239
	QString getAuthor ();
insilmaril@650
   240
	void setComment (const QString &);
insilmaril@650
   241
	QString getComment ();
insilmaril@650
   242
	QString getDate();
insilmaril@749
   243
	int branchCount();
insilmaril@721
   244
insilmaril@721
   245
public:	
insilmaril@784
   246
	void setHeading(const QString &);		//!< Set heading of item	
insilmaril@784
   247
	QString getHeading ();					//!< Get heading of item
insilmaril@721
   248
insilmaril@721
   249
private:
insilmaril@784
   250
	BranchItem* findCurrent;				// next object in find process
insilmaril@784
   251
	BranchItem* findPrevious;				// next object in find process
insilmaril@784
   252
	bool EOFind;							// true, if search failed
insilmaril@721
   253
public:
insilmaril@753
   254
    BranchItem* findText(QString,bool);		// Find object
insilmaril@721
   255
    void findReset();						// Reset Search
insilmaril@721
   256
insilmaril@721
   257
	void setURL(const QString &url);
insilmaril@721
   258
	QString getURL();						// returns URL of selection or ""
insilmaril@721
   259
	QStringList getURLs();					// returns URLs of subtree
insilmaril@721
   260
insilmaril@721
   261
insilmaril@721
   262
	void setFrameType(const FrameObj::FrameType &);
insilmaril@721
   263
	void setFrameType(const QString &);
insilmaril@721
   264
	void setFramePenColor (const QColor &);
insilmaril@721
   265
	void setFrameBrushColor (const QColor &);
insilmaril@721
   266
	void setFramePadding (const int &);
insilmaril@721
   267
	void setFrameBorderWidth (const int &);
insilmaril@721
   268
	void setIncludeImagesVer(bool);
insilmaril@721
   269
	void setIncludeImagesHor(bool);
insilmaril@721
   270
	void setHideLinkUnselected (bool);
insilmaril@721
   271
insilmaril@721
   272
	/*! Should object be hidden in exports (clouded)? */
insilmaril@721
   273
	void setHideExport(bool);			
insilmaril@721
   274
insilmaril@721
   275
	/*! Should object be hidden in exports (clouded)? */
insilmaril@721
   276
	void toggleHideExport();		
insilmaril@721
   277
insilmaril@721
   278
    void copy();						//!< Copy to clipboard
insilmaril@721
   279
private:	
insilmaril@721
   280
    void pasteNoSave(const int &n);		//!< paste clipboard to branch
insilmaril@721
   281
public:	
insilmaril@784
   282
    void paste();			//!< Paste clipboard to branch and backup
insilmaril@784
   283
    void cut();				//!< Cut to clipboard (and copy)
insilmaril@721
   284
insilmaril@784
   285
    void moveUp();			//!< Move branch up
insilmaril@784
   286
    void moveDown();		//!< Move branch down
insilmaril@721
   287
	void sortChildren();	//!< Sort children lexically
insilmaril@721
   288
insilmaril@726
   289
	// The create methods are used to quickly parse a XML file
insilmaril@775
   290
	BranchItem* createMapCenter();				//!< Create MapCenter 
insilmaril@775
   291
	BranchItem* createBranch(BranchItem *dst);	//!< Create Branch
insilmaril@784
   292
	ImageItem* createImage(BranchItem *dst);	//!< Create image
insilmaril@726
   293
insilmaril@786
   294
	AttributeItem* addAttribute();
insilmaril@786
   295
insilmaril@721
   296
	/*! \brief Add new mapcenter
insilmaril@721
   297
insilmaril@721
   298
	    Disclaimer: Still experimental, not fully supported yet.
insilmaril@721
   299
	*/	
insilmaril@773
   300
	BranchItem* addMapCenter();
insilmaril@721
   301
private:	
insilmaril@773
   302
	BranchItem* addMapCenter(QPointF absPos);
insilmaril@652
   303
insilmaril@721
   304
	/*! \brief Add new branch
insilmaril@650
   305
insilmaril@721
   306
		Depending on num the new branch is created
insilmaril@652
   307
insilmaril@721
   308
		-3 above selection as child of selections parent
insilmaril@721
   309
		-2 as child of selection
insilmaril@721
   310
		-1 below selection as child of selections parent
insilmaril@721
   311
		0..n	insert at a specific position in selections parent
insilmaril@721
   312
		(needed for free relinking)
insilmaril@721
   313
	*/	
insilmaril@723
   314
insilmaril@721
   315
private:	
insilmaril@771
   316
    BranchItem* addNewBranchInt(BranchItem *dst, int pos);	// pos allows to add above/below selection
insilmaril@721
   317
public:	
insilmaril@721
   318
	/*! \Add new branch
insilmaril@721
   319
		
insilmaril@721
   320
		Depending on num the new branch is created
insilmaril@721
   321
		-1 above selection
insilmaril@721
   322
		 0 as child of selection
insilmaril@721
   323
		 1 below selection
insilmaril@721
   324
	*/
insilmaril@775
   325
    BranchItem* addNewBranch(int pos=0);		
insilmaril@755
   326
    BranchItem* addNewBranchBefore();		//!< Insert branch between selection and its parent
insilmaril@767
   327
	/*! \brief Relink a branch to a new destination dst 
insilmaril@767
   328
	    Relinks branch to dst at branch position pos. There is no saveState
insilmaril@767
   329
		here, as for example moveUp or moving in MapEditor have
insilmaril@767
   330
		different needs to call saveState
insilmaril@767
   331
		Returns true if relinking was successful.
insilmaril@767
   332
	*/	
insilmaril@767
   333
	bool relinkBranch (BranchItem* branch, BranchItem* dst, int pos =-1);	
insilmaril@777
   334
	bool relinkImage  (ImageItem* image, BranchItem* dst);	
insilmaril@767
   335
insilmaril@776
   336
    void deleteSelection();				//!< Delete selection
insilmaril@776
   337
	void deleteKeepChildren();			//!< remove branch, but keep children
insilmaril@776
   338
	void deleteChildren();				//!< keep branch, but remove children
insilmaril@652
   339
insilmaril@721
   340
private:	
insilmaril@776
   341
	TreeItem* deleteItem(TreeItem*);	//!< Delete item and return parent (if parent!= rootItem)
insilmaril@749
   342
	bool scrollBranch(BranchItem *);
insilmaril@749
   343
	bool unscrollBranch(BranchItem *);
insilmaril@721
   344
public:	
insilmaril@721
   345
    void toggleScroll();
insilmaril@721
   346
    void unscrollChildren();
insilmaril@763
   347
	void emitExpandAll();
insilmaril@763
   348
signals:	
insilmaril@763
   349
	void expandAll();
insilmaril@763
   350
insilmaril@763
   351
public:	
insilmaril@767
   352
	void toggleStandardFlag (const QString &name, FlagRow *master=NULL);
insilmaril@721
   353
    void addFloatImage(const QPixmap &img);
insilmaril@721
   354
insilmaril@721
   355
    void colorBranch(QColor);
insilmaril@721
   356
    void colorSubtree(QColor);
insilmaril@721
   357
	QColor getCurrentHeadingColor();
insilmaril@721
   358
insilmaril@721
   359
insilmaril@721
   360
	void editURL();							// edit URL
insilmaril@721
   361
	void editLocalURL();					// edit URL to local file
insilmaril@721
   362
	void editHeading2URL();					// copy heading to URL
insilmaril@721
   363
	void editBugzilla2URL();				// create URL to Bugzilla
insilmaril@721
   364
	void editFATE2URL();					// create URL to FATE
insilmaril@721
   365
	void editVymLink();						// edit link to another map
insilmaril@721
   366
	void setVymLink (const QString &);	// Set vymLink for selection
insilmaril@721
   367
	void deleteVymLink();					// delete link to another map
insilmaril@721
   368
	QString getVymLink();					// return path to map
insilmaril@721
   369
	QStringList getVymLinks();				// return paths in subtree
insilmaril@721
   370
	void followXLink (int);
insilmaril@721
   371
	void editXLink (int);
insilmaril@721
   372
insilmaril@721
   373
insilmaril@721
   374
insilmaril@721
   375
insilmaril@721
   376
////////////////////////////////////////////
insilmaril@721
   377
// Scripting
insilmaril@721
   378
////////////////////////////////////////////
insilmaril@721
   379
public:	
insilmaril@721
   380
insilmaril@721
   381
	/* \brief Process one command and its parameters */
insilmaril@721
   382
    void parseAtom (const QString &atom);	
insilmaril@721
   383
insilmaril@721
   384
	/* \brief Runs the script */
insilmaril@721
   385
	void runScript (QString script);
insilmaril@721
   386
insilmaril@721
   387
private:
insilmaril@721
   388
	Parser parser;
insilmaril@721
   389
insilmaril@721
   390
////////////////////////////////////////////
insilmaril@721
   391
// Exports
insilmaril@721
   392
////////////////////////////////////////////
insilmaril@721
   393
private:
insilmaril@753
   394
	TreeItem::HideTmpMode hidemode;	// true while exporting to hide some stuff
insilmaril@721
   395
insilmaril@721
   396
public:
insilmaril@721
   397
	/*! Set or unset temporary hiding of objects during export  */
insilmaril@721
   398
	void setExportMode (bool);
insilmaril@721
   399
insilmaril@721
   400
	/*! Save as image */
insilmaril@721
   401
    void exportImage (QString fname="",bool askForName=true,QString format="PNG");
insilmaril@721
   402
insilmaril@721
   403
insilmaril@721
   404
	/*! Export as XTML to directory */
insilmaril@721
   405
    void exportXML(QString dir="", bool askForName=true);
insilmaril@721
   406
insilmaril@721
   407
	/*! Export as ASCII text to file */
insilmaril@721
   408
	void exportASCII (QString fname="",bool askForName=true);  
insilmaril@721
   409
insilmaril@721
   410
	/*! Export as XHTML to directory */
insilmaril@721
   411
    void exportXHTML(const QString& dir="", bool askForName=true);	
insilmaril@721
   412
insilmaril@721
   413
    /*! Export as OpenOfficeOrg presentation */
insilmaril@721
   414
    void exportOOPresentation(const QString &,const QString &);	
insilmaril@721
   415
insilmaril@721
   416
insilmaril@721
   417
////////////////////////////////////////////
insilmaril@721
   418
// View related
insilmaril@721
   419
////////////////////////////////////////////
insilmaril@721
   420
public:
insilmaril@721
   421
	void registerEditor (QWidget *);
insilmaril@721
   422
	void unregisterEditor (QWidget *);
insilmaril@723
   423
insilmaril@723
   424
private: 
insilmaril@723
   425
	QPointF contextPos;					//!< local position during context menu
insilmaril@723
   426
public:
insilmaril@723
   427
	void setContextPos (QPointF);		//!< local position during context menu
insilmaril@723
   428
	void unsetContextPos ();			//!< forget local position after context menu
insilmaril@723
   429
insilmaril@721
   430
	void updateNoteFlag();				//!< Signal origination in TextEditor
insilmaril@650
   431
    void updateRelPositions();
insilmaril@650
   432
insilmaril@650
   433
	void reposition();					//!< Call reposition for all MCOs
insilmaril@753
   434
	void setHideTmpMode (TreeItem::HideTmpMode mode);	
insilmaril@721
   435
insilmaril@773
   436
	//FIXME-5 QPolygonF shape(BranchObj *bo);		//!< Returns arbitrary shape of subtree
insilmaril@773
   437
	//FIXME-5 void moveAway (LinkableMapObj *lmo);//!< Autolayout: Move all out of the way
insilmaril@652
   438
insilmaril@753
   439
	void emitNoteHasChanged (TreeItem *ti);
insilmaril@753
   440
	void emitDataHasChanged (TreeItem *ti);
insilmaril@746
   441
insilmaril@745
   442
signals:
insilmaril@753
   443
	void noteHasChanged (QModelIndex ix);
insilmaril@745
   444
	void newChildObject(QModelIndex ix);
insilmaril@745
   445
insilmaril@721
   446
private:
insilmaril@721
   447
	MapEditor *mapEditor;
insilmaril@721
   448
insilmaril@721
   449
	QColor defLinkColor;		// default color for links
insilmaril@721
   450
	QColor defXLinkColor;		// default color for xlinks
insilmaril@721
   451
	int defXLinkWidth;			// default width for xlinks
insilmaril@721
   452
	LinkableMapObj::ColorHint linkcolorhint;// use heading color or own color
insilmaril@721
   453
	LinkableMapObj::Style linkstyle;		// default style for links
insilmaril@721
   454
insilmaril@696
   455
public:
insilmaril@721
   456
	void setMapLinkStyle (const QString &);	// Set style of link
insilmaril@721
   457
	LinkableMapObj::Style getMapLinkStyle ();	// requested in LMO
insilmaril@721
   458
	void setMapDefLinkColor(QColor);		// default color of links
insilmaril@721
   459
	void setMapLinkColorHintInt();			// color of links
insilmaril@721
   460
	void setMapLinkColorHint(LinkableMapObj::ColorHint);// color of links
insilmaril@721
   461
	void toggleMapLinkColorHint();			// after changing linkStyles
insilmaril@721
   462
    void selectMapBackgroundImage();
insilmaril@721
   463
    void setMapBackgroundImage(const QString &);
insilmaril@721
   464
    void selectMapBackgroundColor();
insilmaril@721
   465
    void setMapBackgroundColor(QColor);
insilmaril@721
   466
    QColor getMapBackgroundColor();
insilmaril@721
   467
insilmaril@721
   468
insilmaril@721
   469
	LinkableMapObj::ColorHint getMapLinkColorHint();
insilmaril@721
   470
	QColor getMapDefLinkColor();
insilmaril@721
   471
	void setMapDefXLinkColor(QColor);
insilmaril@721
   472
	QColor getMapDefXLinkColor();
insilmaril@721
   473
	void setMapDefXLinkWidth (int);
insilmaril@721
   474
	int getMapDefXLinkWidth();
insilmaril@721
   475
insilmaril@721
   476
	/*!  Move absolutly to (x,y).  */	
insilmaril@721
   477
    void move    (const double &x, const double &y);
insilmaril@721
   478
insilmaril@721
   479
	/*!  Move relativly to (x,y).  */	
insilmaril@721
   480
    void moveRel (const double &x, const double &y);
insilmaril@721
   481
insilmaril@721
   482
////////////////////////////////////////////
insilmaril@721
   483
// Animation  **experimental**
insilmaril@721
   484
////////////////////////////////////////////
insilmaril@696
   485
private:	
insilmaril@696
   486
	QTimer *animationTimer;
insilmaril@696
   487
	bool animationUse;
insilmaril@696
   488
	uint animationTicks;
insilmaril@696
   489
	uint animationInterval;
insilmaril@696
   490
	int timerId;				// animation timer
insilmaril@767
   491
	QList <MapObj*> animObjList;// list with animated objects //FIXME-2 should go to MapEditor
insilmaril@696
   492
insilmaril@721
   493
private slots:
insilmaril@721
   494
	void animate();						//!< Called by timer to animate stuff
insilmaril@696
   495
public:
insilmaril@723
   496
	void startAnimation(BranchObj *bo, const QPointF &start, const QPointF &dest);
insilmaril@722
   497
	void stopAnimation(MapObj *mo);
insilmaril@722
   498
insilmaril@721
   499
////////////////////////////////////////////
insilmaril@721
   500
// Network related 
insilmaril@721
   501
////////////////////////////////////////////
insilmaril@721
   502
public:
insilmaril@721
   503
    /*! \brief Networking states
insilmaril@721
   504
		
insilmaril@721
   505
		In Network modus we want to switch of saveState, autosave, ...
insilmaril@721
   506
	*/
insilmaril@721
   507
	enum NetState {
insilmaril@721
   508
		Offline,			//!< Offline
insilmaril@721
   509
		Client,				//!< I am the client and connected to server
insilmaril@721
   510
		Server				//!< I am the server
insilmaril@721
   511
	};
insilmaril@721
   512
insilmaril@721
   513
private:
insilmaril@721
   514
	// Network connections **Experimental**
insilmaril@721
   515
	NetState netstate;			// offline, client, server
insilmaril@721
   516
	QTcpServer *tcpServer;		// Act as server in conference mode (experimental)
insilmaril@721
   517
	QList <QTcpSocket*> clientList;		// List of connected clients
insilmaril@721
   518
	quint16 sendCounter;		// Increased with every sent command
insilmaril@721
   519
insilmaril@721
   520
	QTcpSocket	*clientSocket;	// socket of this client
insilmaril@721
   521
	QString server;				// server address of this client
insilmaril@721
   522
	int port;					// server port of this client
insilmaril@721
   523
insilmaril@721
   524
insilmaril@721
   525
insilmaril@721
   526
protected:
insilmaril@721
   527
	void sendSelection();
insilmaril@721
   528
insilmaril@721
   529
public:
insilmaril@721
   530
	void newServer();
insilmaril@721
   531
	void connectToServer();
insilmaril@721
   532
insilmaril@721
   533
private slots:	
insilmaril@721
   534
	void newClient();
insilmaril@721
   535
	void sendData(const QString &s);
insilmaril@721
   536
	void readData();
insilmaril@721
   537
	void displayNetworkError (QAbstractSocket::SocketError);
insilmaril@721
   538
insilmaril@784
   539
////////////////////////////////////////////
insilmaril@784
   540
// DBUS related 
insilmaril@784
   541
////////////////////////////////////////////
insilmaril@721
   542
insilmaril@784
   543
private:
insilmaril@784
   544
AdaptorModel *adaptorModel; //FIXME-3
insilmaril@721
   545
insilmaril@785
   546
public slots:
insilmaril@785
   547
	void testslot();
insilmaril@785
   548
insilmaril@721
   549
////////////////////////////////////////////
insilmaril@721
   550
// Selection related 
insilmaril@721
   551
////////////////////////////////////////////
insilmaril@721
   552
private:
insilmaril@761
   553
	TreeItem *latestAddedItem;				// latest added object, reset on setChanged()
insilmaril@721
   554
insilmaril@721
   555
public:
insilmaril@727
   556
	void setSelectionModel(QItemSelectionModel *);		// Set common selectionModel
insilmaril@728
   557
	QItemSelectionModel* getSelectionModel();
insilmaril@727
   558
insilmaril@721
   559
	void setSelectionBlocked(bool);
insilmaril@721
   560
	bool isSelectionBlocked();
insilmaril@721
   561
insilmaril@769
   562
	bool select ();							//! select by using common QItemSelectionModel
insilmaril@769
   563
	bool select (const QString &);			//! Select by string
insilmaril@769
   564
	bool select (LinkableMapObj *lmo);		//! Select by pointer to LMO
insilmaril@769
   565
	bool select (TreeItem *ti );			//! Select by pointer to TreeItem
insilmaril@769
   566
	bool select (const QModelIndex &index);	//! Select by ModelIndex
insilmaril@721
   567
	void unselect();
insilmaril@787
   568
	bool reselect();
insilmaril@721
   569
insilmaril@763
   570
	void emitShowSelection();				//!< Show selection in all views
insilmaril@763
   571
signals:
insilmaril@763
   572
	void showSelection();
insilmaril@721
   573
insilmaril@787
   574
//	bool selectInt(LinkableMapObj*);	//FIXME-4
insilmaril@721
   575
insilmaril@721
   576
public:	
insilmaril@787
   577
    bool selectFirstBranch();
insilmaril@787
   578
    bool selectLastBranch();
insilmaril@787
   579
	bool selectLastSelectedBranch();
insilmaril@787
   580
	bool selectParent();
insilmaril@721
   581
insilmaril@721
   582
public:
insilmaril@735
   583
	TreeItem::Type selectionType();
insilmaril@735
   584
	LinkableMapObj* getSelectedLMO();
insilmaril@776
   585
	BranchObj* getSelectedBranchObj();	// FIXME-3 replace by item...
insilmaril@787
   586
	BranchItem* getSelectedBranch();
insilmaril@787
   587
	ImageItem* getSelectedImage();
insilmaril@787
   588
	AttributeItem* getSelectedAttribute();
insilmaril@738
   589
	TreeItem* getSelectedItem();
insilmaril@735
   590
	QModelIndex getSelectedIndex();
insilmaril@721
   591
	QString getSelectString ();
insilmaril@652
   592
	QString getSelectString (LinkableMapObj *lmo);
insilmaril@749
   593
	QString getSelectString (TreeItem *item);
insilmaril@721
   594
	
insilmaril@746
   595
	
insilmaril@775
   596
signals:
insilmaril@775
   597
	void selectionChanged(const QItemSelection &newsel, const QItemSelection &oldsel);
insilmaril@775
   598
insilmaril@746
   599
public slots:
insilmaril@775
   600
	void updateSelection (const QItemSelection &newSel, const QItemSelection &delSel);
insilmaril@746
   601
insilmaril@746
   602
public:
insilmaril@775
   603
	void emitSelectionChanged(const QItemSelection &oldsel);
insilmaril@775
   604
	void emitSelectionChanged();
insilmaril@721
   605
	void selectMapLinkColor();
insilmaril@721
   606
    void selectMapSelectionColor();
insilmaril@721
   607
private:	
insilmaril@721
   608
    void setSelectionColorInt(QColor);
insilmaril@727
   609
	QItemSelectionModel *selModel;
insilmaril@773
   610
	QString lastSelectString;
insilmaril@773
   611
	bool selectionBlocked;		//! Used to block changes of selection while editing a heading
insilmaril@727
   612
insilmaril@721
   613
public:	
insilmaril@721
   614
    void setSelectionColor(QColor);
insilmaril@721
   615
    QColor getSelectionColor();
insilmaril@650
   616
};
insilmaril@650
   617
insilmaril@650
   618
#endif