1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
|
/* This file is part of the KDE project
Copyright (C) 2003 Lucijan Busch <lucijan@gmx.at>
Copyright (C) 2004 Cedric Pasteur <cedric.pasteur@free.fr>
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Library General Public
License as published by the Free Software Foundation; either
version 2 of the License, or (at your option) any later version.
This library 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
Library General Public License for more details.
You should have received a copy of the GNU Library General Public License
along with this library; see the file COPYING.LIB. If not, write to
the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
* Boston, MA 02110-1301, USA.
*/
#ifndef FORMEDITORCONTAINER_H
#define FORMEDITORCONTAINER_H
#include <tqobject.h>
#include <tqguardedptr.h>
#include <tqptrlist.h>
#include <tqwidget.h>
#include "utils.h"
class TQEvent;
class TQWidget;
class TQLayout;
namespace KFormDesigner {
class Container;
class WidgetLibrary;
class ObjectTreeItem;
class Form;
/**
* This class is used to filter the events from any widget (and all its subwidgets)
* and direct it to the Container.
*/
//! A class for redirecting events
class KFORMEDITOR_EXPORT EventEater : public TQObject
{
Q_OBJECT
TQ_OBJECT
public:
/*! Constructs eater object. All events for \a widget and it's subwidgets
will be redirected to \a container. \a container will be also tqparent of eater object,
so you don't need to care about deleting it. */
EventEater(TQWidget *widget, TQObject *container);
~EventEater();
//! Sets the object which will receive the events
void setContainer(TQObject *container) { m_container = container; }
bool eventFilter(TQObject *o, TQEvent *ev);
private:
TQGuardedPtr<TQWidget> m_widget;
TQGuardedPtr<TQObject> m_container;
};
/**
* This class makes a container out of any TQWidget. You can then create child widgets, and
the background is dotted.
*/
//! A class to make a container from any widget
class KFORMEDITOR_EXPORT Container : public TQObject
{
Q_OBJECT
TQ_OBJECT
public:
enum LayoutType { NoLayout=0, HBox, VBox, Grid, HFlow, VFlow, /* special types */ HSplitter, VSplitter };
/**
* Creates a Container from the widget \a container, which have
\a toplevel as tqparent Container. */
Container(Container *toplevel, TQWidget *container, TQObject *tqparent=0, const char *name=0);
virtual ~Container();
//! \return a pointer to the toplevel Container, or 0 if this Container is toplevel
Container* toplevel();
//! \return The form this Container belongs to.
Form* form() const { return m_form; }
//! \return The watched widget.
TQWidget* widget() const { return m_container; }
//! \return The ObjectTreeItem associated with this Container's widget.
ObjectTreeItem* objectTree() const { return m_tree; }
//! Sets the Form which this Container belongs to.
void setForm(Form *form);
/*! Sets the ObjectTree of this Container.\n
* NOTE: this is needed only if we are toplevel. */
void setObjectTree(ObjectTreeItem *t) { m_tree = t; }
//! \return a pointer to the TQLayout of this Container, or 0 if there is not.
TQLayout* tqlayout() const { return m_layout; }
//! \return the type of the tqlayout associated to this Container's widget (see LayoutType enum).
LayoutType tqlayoutType() const { return m_layType; }
//! \return the margin of this Container.
int tqlayoutMargin() { return m_margin; }
//! \return the spacing of this Container.
int tqlayoutSpacing() { return m_spacing; }
/*! Sets this Container to use \a type of tqlayout. The widget are inserted
automatically in the tqlayout following their positions.
\sa createBoxLayout(), createGridLayout() */
void setLayout(LayoutType type);
//! Sets the spacing of this Container.
void setLayoutSpacing(int spacing) { m_spacing = spacing;}
//! Sets the margin of this Container.
void setLayoutMargin(int margin) { m_margin = margin;}
//! \return the string representing the tqlayoutType \a type.
static TQString tqlayoutTypeToString(int type);
//! \return the LayoutType (an int) for a given tqlayout name.
static LayoutType stringToLayoutType(const TQString &name);
/*! Stops the inline editing of the current widget (as when you click
on another widget or press Esc). */
void stopInlineEditing() { m_state = DoingNothing; }
/*! This is the main function of Container, which filters the event sent
to the watched widget.\n It takes care of drawing the background and
the insert rect, of creating the new child widgets, of moving the widgets
and pop up a menu when right-clicking. */
virtual bool eventFilter(TQObject *o, TQEvent *e);
public slots:
/*! Sets \a selected to be the selected widget of this container
(and so of the Form). If \a add is true, the formerly selected widget
is still selected, and the new one is just added. If false, \a selected
replace the actually selected widget. If \a dontRaise is true, then
the widget \a selected (and its tqparent) won't be raised (eg when you
select widget in ObjectTreeView).
\sa Form::setSelectedWidget() */
void setSelectedWidget(TQWidget *selected, bool add, bool dontRaise=false,
bool moreWillBeSelected = false);
/*! Unselects the widget \a w. The widget is removed from the Form's list
and its resizeHandles are removed. */
void unSelectWidget(TQWidget *w);
/*! Deletes the widget \a w. Removes it from ObjectTree, and sets selection
to Container's widget. */
void deleteWidget(TQWidget *w);
/*! Recreates the Container tqlayout. Calls this when a widget has been moved
or added to update the tqlayout. */
void reloadLayout();
protected slots:
/*! This slot is called when the watched widget is deleted. Deletes the Container too. */
void widgetDeleted();
protected:
/*! Internal function to create a HBoxLayout or VBoxLayout for this container.
\a list is a subclass of TQObjectList that can sort widgets
following their position (such as HorWidgetList or VerWidgetList). */
void createBoxLayout(WidgetList *list);
/*! Internal function to create a KexiFlowLayout. */
void createFlowLayout();
/*! Internal function to create a GridLayout. if \a testOnly is true, the tqlayout
is simulated, and only the widget's grid info aris filled. */
void createGridLayout(bool testOnly=false);
void drawConnection(TQMouseEvent *mev);
void drawSelectionRect(TQMouseEvent *mev);
void drawInsertRect(TQMouseEvent *mev, TQObject *s);
void drawCopiedWidgetRect(TQMouseEvent *mev);
void moveSelectedWidgetsBy(int realdx, int realdy, TQMouseEvent *mev=0);
private:
bool handleMouseReleaseEvent(TQObject *s, TQMouseEvent *mev);
// the watched container and it's toplevel one...
TQGuardedPtr<TQWidget> m_container;
TQGuardedPtr<Container> m_toplevel;
int m_state;
enum { DoingNothing = 100, DrawingSelectionRect, CopyingWidget,
MovingWidget, InlineEditing };
// Layout
TQLayout *m_layout;
LayoutType m_layType;
int m_margin, m_spacing;
// moving etc.
TQPoint m_grab;
//TQPoint m_initialPos;
TQGuardedPtr<TQWidget> m_moving;
//TQRect m_copyRect;
//inserting
TQPoint m_insertBegin;
TQRect m_insertRect;
ObjectTreeItem *m_tree;
TQGuardedPtr<Form> m_form;
bool m_mousePressEventReceived;
TQMouseEvent m_mouseReleaseEvent;
TQGuardedPtr<TQObject> m_objectForMouseReleaseEvent;
friend class InsertWidgetCommand;
friend class PasteWidgetCommand;
friend class DeleteWidgetCommand;
friend class FormIO;
};
//! Interface for adding dynamically created (at design time) widget to event eater.
/*! This is currently used by KexiDBFieldEdit from Kexi forms. */
class KFORMEDITOR_EXPORT DesignTimeDynamicChildWidgetHandler
{
public:
DesignTimeDynamicChildWidgetHandler();
~DesignTimeDynamicChildWidgetHandler();
protected:
void childWidgetAdded(TQWidget* w);
void assignItem(ObjectTreeItem* item) { m_item = item; }
private:
ObjectTreeItem* m_item;
friend class InsertWidgetCommand;
friend class FormIO;
};
}
#endif
|