summaryrefslogtreecommitdiffstats
path: root/kregexpeditor/KMultiFormListBox/kmultiformlistbox-multivisible.h
diff options
context:
space:
mode:
authortoma <toma@283d02a7-25f6-0310-bc7c-ecb5cbfe19da>2009-11-25 17:56:58 +0000
committertoma <toma@283d02a7-25f6-0310-bc7c-ecb5cbfe19da>2009-11-25 17:56:58 +0000
commit2bda8f7717adf28da4af0d34fb82f63d2868c31d (patch)
tree8d927b7b47a90c4adb646482a52613f58acd6f8c /kregexpeditor/KMultiFormListBox/kmultiformlistbox-multivisible.h
downloadtdeutils-2bda8f7717adf28da4af0d34fb82f63d2868c31d.tar.gz
tdeutils-2bda8f7717adf28da4af0d34fb82f63d2868c31d.zip
Copy the KDE 3.5 branch to branches/trinity for new KDE 3.5 features.
BUG:215923 git-svn-id: svn://anonsvn.kde.org/home/kde/branches/trinity/kdeutils@1054174 283d02a7-25f6-0310-bc7c-ecb5cbfe19da
Diffstat (limited to 'kregexpeditor/KMultiFormListBox/kmultiformlistbox-multivisible.h')
-rw-r--r--kregexpeditor/KMultiFormListBox/kmultiformlistbox-multivisible.h135
1 files changed, 135 insertions, 0 deletions
diff --git a/kregexpeditor/KMultiFormListBox/kmultiformlistbox-multivisible.h b/kregexpeditor/KMultiFormListBox/kmultiformlistbox-multivisible.h
new file mode 100644
index 0000000..87aeba4
--- /dev/null
+++ b/kregexpeditor/KMultiFormListBox/kmultiformlistbox-multivisible.h
@@ -0,0 +1,135 @@
+/*
+ * Copyright (c) 2002-2003 Jesper K. Pedersen <[email protected]>
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Library General Public
+ * License version 2 as published by the Free Software Foundation.
+ *
+ * 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.
+ **/
+// ------------------------------- Description ----------------------------
+// This is the KMultiFormListBox Widget. You do not need to inheret from this class,
+// your interface to it will be through the methods `append` and `elements'.
+//
+// To make an instance of the widget, you need to inherit the classes
+// `KMultiFormListBoxFactory' and `KMultiFormListBoxEntry'.
+// ------------------------------------------------------------------------
+#ifndef __kmultiformlistboxmultivisble
+#define __kmultiformlistboxmultivisble
+
+// -------------------------------- includes ------------------------------
+#include "kmultiformlistbox.h"
+//-------------------------------------------------------------------------
+
+/**
+ @internal
+*/
+class KMultiFormListBoxMultiVisible :public QScrollView, KMultiFormListBoxShower {
+
+Q_OBJECT
+
+friend class KMultiFormListBox;
+
+private:
+ /**
+ @param factory A factory used to generate the instances of KMultiFormListBoxEntry
+ class which is repeated in the KMultiFormListBox
+ @param parent A pointer to the parent widget
+ */
+ KMultiFormListBoxMultiVisible(KMultiFormListBoxFactory *factory, QWidget *parent = 0, const char *name = 0);
+
+ /**
+ @return The elements in the KMultiFormListBox
+ */
+ KMultiFormListBoxEntryList elements();
+ void append(KMultiFormListBoxEntry *);
+
+ QWidget* qWidget() { return this; }
+
+
+public slots:
+
+ /**
+ This slot should be connected to a button which lets the user know that
+ he may get more elements in this KMultiFormListBox by pressing it.
+ The button should be labeled ``More Entries'' or something similar.
+ */
+ void addElement(); // Adds an empty element to the KMultiFormListBox
+
+
+protected slots:
+
+ /**
+ When this slot is invoked then the Idx menu will be shown.
+ @param elm The KMultiFormListBoxEntry element where the Idx button was
+ pressed. This information is necessary to be able to calculate the
+ location where the drop down menu should be shown
+ */
+ void showIndexList(KMultiFormListBoxEntry *elm);
+
+protected:
+ /**
+ Copies the element pointed to by which to the clipboard and removes it
+ from the interface.
+ This function is accessed from the class @ref CCP.
+ @param which A pointer to the element to cut.
+ */
+ void cut(KMultiFormListBoxEntry *which);
+
+ /**
+ Copies the element pointed to by which to the clipboard.
+ This function is accessed from the class @ref CCP.
+ @param which A pointer to the element to copied.
+ */
+ void copy(KMultiFormListBoxEntry *which);
+
+ /**
+ Paste the element from the clipboard to the KMultiFormListBox
+ This function is accessed from the class @ref CCP.
+ @param which A pointer to the KMultiFormListBoxEntry element which the
+ clipboard element should be inserted before,.
+ */
+ void paste(KMultiFormListBoxEntry *which);
+
+ /**
+ Inserts an empty KMultiFormListBoxEntry into the widget.
+ @param which A pointer to the element which the new empty widget
+ should be inserted before.
+ */
+
+ void addElement(KMultiFormListBoxEntry *);
+
+ friend class CCP;
+
+ virtual void resizeEvent(QResizeEvent *);
+ void addElemBefore(KMultiFormListBoxEntry *newElm, QWidget *existing);
+ void insertElmIntoWidget(KMultiFormListBoxEntry *elm, KMultiFormListBoxEntry *after);
+ void showWidget(KMultiFormListBoxEntry *elm);
+ void delElement(QWidget *);
+ void delAnElement();
+ void addElemBefore(KMultiFormListBoxEntry *newElm, KMultiFormListBoxEntry *existing);
+ void updateClipperContent();
+ int countElements(WidgetList *);
+
+
+
+private:
+ // Instance variables
+
+ KMultiFormListBoxFactory *factory;
+ WidgetList *elms;
+ QPushButton *addBut;
+ QByteArray clipboard;
+};
+
+
+#endif /* kmultiformlistboxmultivisble */
+