summaryrefslogtreecommitdiffstats
path: root/kexi/core/kexidataiteminterface.h
diff options
context:
space:
mode:
Diffstat (limited to 'kexi/core/kexidataiteminterface.h')
-rw-r--r--kexi/core/kexidataiteminterface.h249
1 files changed, 249 insertions, 0 deletions
diff --git a/kexi/core/kexidataiteminterface.h b/kexi/core/kexidataiteminterface.h
new file mode 100644
index 00000000..dbd38005
--- /dev/null
+++ b/kexi/core/kexidataiteminterface.h
@@ -0,0 +1,249 @@
+/* This file is part of the KDE project
+ Copyright (C) 2005-2006 Jaroslaw Staniek <[email protected]>
+
+ This program 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 program 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 program; see the file COPYING. If not, write to
+ the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
+ * Boston, MA 02110-1301, USA.
+*/
+
+#ifndef KEXIDATAITEMINTERFACE_H
+#define KEXIDATAITEMINTERFACE_H
+
+#include <qvariant.h>
+#include <qwidget.h>
+#include <qguardedptr.h>
+
+class KexiDataItemInterface;
+namespace KexiDB {
+ class Field;
+ class QueryColumnInfo;
+}
+
+//! An helper class used to react on KexiDataItemInterface objects' changes.
+class KEXICORE_EXPORT KexiDataItemChangesListener
+{
+ public:
+ KexiDataItemChangesListener();
+ virtual ~KexiDataItemChangesListener();
+
+ /*! Implement this to react for change of \a item.
+ Called by KexiDataItemInterface::valueChanged() */
+ virtual void valueChanged(KexiDataItemInterface* item) = 0;
+
+ /*! Implement this to return information whether we're currently at new row or not.
+ This can be used e.g. by data-aware widgets to determine if "(autonumber)"
+ label should be displayed. */
+ virtual bool cursorAtNewRow() const = 0;
+};
+
+//! An interface for declaring widgets to be data-aware.
+class KEXICORE_EXPORT KexiDataItemInterface
+{
+ public:
+ KexiDataItemInterface();
+ virtual ~KexiDataItemInterface();
+
+ /*! Just initializes \a value, and calls setValueInternal(const QString& add, bool removeOld).
+ If \a removeOld is true, current value is set up as \a add.
+ If \a removeOld if false, current value is set up as \a value + \a add.
+ \a value is stored as 'old value' -it'd be usable in the future
+ (e.g. Combo Box editor can use old value if current value does not
+ match any item on the list).
+
+ \a visibleValue (if not NULL) is passed to provide visible value to display instead of \a value.
+ This is currently used only in case of the combo box form widget, where displayed content
+ (usually a text of image) differs from the value of the widget (a numeric index).
+
+ This method is called by table view's and form's editors. */
+ void setValue(const QVariant& value, const QVariant& add = QVariant(), bool removeOld = false,
+ const QVariant* visibleValue = 0);
+
+ //! \return field information for this item
+ virtual KexiDB::Field *field() const = 0;
+
+ //! \return column information for this item
+ virtual KexiDB::QueryColumnInfo* columnInfo() const = 0;
+
+ //! Used internally to set column information.
+ virtual void setColumnInfo(KexiDB::QueryColumnInfo* cinfo) = 0;
+
+ //! Sets listener. No need to reimplement this.
+ virtual void installListener(KexiDataItemChangesListener* listener);
+
+// //! Sets value \a value for a widget.
+// //! Just calls setValueInternal(), but also blocks valueChanged()
+// //! as you we don't want to react on our own change
+// void setValue(const QVariant& value);
+
+ //! \return value currently represented by this item.
+ virtual QVariant value() = 0;
+
+ //! \return true if editor's value is valid for a given type
+ //! Used for checking if an entered value is valid,
+ //! E.g. a part of time value can be entered: "12:8" and this is invalid, not only null.
+ //! Null time or date is valid in Kexi, so it is not enough to test value().isValid().
+ //! Default implementation just returns true.
+ virtual bool valueIsValid();
+
+ //! \return true if editor's value is null (not empty)
+ //! Used for checking if a given constraint within table or form is met.
+ virtual bool valueIsNull() = 0;
+
+ //! \return true if editor's value is empty (not necessary null).
+ //! Only few data types can accept "EMPTY" property
+ //! (use KexiDB::Field::hasEmptyProperty() to check this).
+ //! Used for checking if a given constraint within table of form is met.
+ virtual bool valueIsEmpty() = 0;
+
+ //! \return value that should be displayed for this item.
+ //! Only used for items like combo box, where real value is an integer while
+ //! displayed value is usually a text. For other item types this method should be empty.
+ virtual QVariant visibleValue() { return QVariant(); }
+
+ /*! \return 'readOnly' flag for this item. The flag is usually taken from
+ the item's widget, e.g. KLineEdit::isReadOnly().
+ By default, always returns false. */
+ virtual bool isReadOnly() const { return false; }
+
+ /*! \return the view widget of this item, e.g. line edit widget. */
+ virtual QWidget* widget() = 0;
+
+ /*! Hides item's widget, if available. */
+ virtual void hideWidget() { if (widget()) widget()->hide(); }
+
+ /*! Shows item's widget, if available. */
+ virtual void showWidget() { if (widget()) widget()->show(); }
+
+ //! \return true if editor's value is changed (compared to original value)
+ virtual bool valueChanged();
+
+ /*! \return true if the item widget's cursor (whatever that means, eg. line edit cursor)
+ is at the beginning of editor's contents. This can inform table/form view that
+ after pressing "left arrow" key should stop editing and move to a field on the left hand. */
+ virtual bool cursorAtStart() = 0;
+
+ /*! \return true if the item widget's cursor (whatever that means, eg. line edit cursor)
+ is at the end of editor's contents. This can inform table/form view that
+ after pressing "right arrow" key should stop editing and move to a field on the right hand. */
+ virtual bool cursorAtEnd() = 0;
+
+ /*! Moves cursor after the last character (or element).
+ For implementation in items supporting text cursor's movement; by default does nothing. */
+ virtual void moveCursorToEnd() {};
+
+ /*! Moves cursor before the first character (or element).
+ For implementation in items supporting text cursor's movement; by default does nothing. */
+ virtual void moveCursorToStart() {};
+
+ /*! Selects all characters (or elements) of the item.
+ For implementation in items supporting text or elements; by default does nothing. */
+ virtual void selectAll() {};
+
+ //! clears item's data, so the data will contain NULL data
+ virtual void clear() = 0;
+
+ /*! \return true if this editor offers a widget (e.g. line edit) that we can move focus to.
+ Editor for boolean values has this set to false (see KexiBoolTableEdit).
+ This is true by default. You can override this flag by changing
+ m_hasFocusableWidget in your subclass' constructor. */
+ inline bool hasFocusableWidget() const { return m_hasFocusableWidget; }
+
+ /*! Displays additional elements that are needed for indicating that the current cell
+ is selected. For example, combobox editor (KexiComboBoxTableEdit) moves and shows
+ dropdown button. \a r is the rectangle for the cell.
+ If \a readOnly is true, additional elements should be visually disabled,
+ e.g. dropdown button of the combobox editor should be disabled.
+ For reimplementation. By default does nothing. */
+ virtual void showFocus( const QRect& r, bool readOnly );
+
+ /*! Hides additional elements that are needed for indicating that the current cell
+ is selected.
+ For reimplementation. By default does nothing. */
+ virtual void hideFocus();
+
+ /*! Allows to define reaction for clicking on cell's contents.
+ Currently it's used for editor of type boolean, where we want to toggle true/false
+ on single mouse click. \sa hasFocusableWidget(), KexiBoolTableEdit.
+ Default implementation does nothing. */
+ virtual void clickedOnContents();
+
+ /*! \return true if editing should be accepted immediately after
+ deleting contents for the cell (usually using Delete key).
+ This flag is false by default, and is true e.g. for date, time and datetime types. */
+ bool acceptEditorAfterDeleteContents() const { return m_acceptEditorAfterDeleteContents; }
+
+ inline virtual void setFocus() { if (widget()) widget()->setFocus(); }
+
+ bool cursorAtNewRow();
+
+ /*! Sets a pointer to a Parent Data Item Interface. This pointer is 0 by default,
+ but can be set by parent widget if this interface is a building block of a larger data widget.
+ It is the case for KexiDBFieldEdit widget (see KexiDBFieldEdit::createEditor()). Use with care.
+ signalValueChanged() method will check this pointer, and if it's not 0,
+ m_parentDataItemInterface->signalValueChanged() is called, so a changes can be signalled at higher level. */
+ void setParentDataItemInterface(KexiDataItemInterface* parentDataItemInterface);
+
+ /*! \return a pointer to a Parent Data Item Interface.
+ @see setParentDataItemInterface() */
+ inline KexiDataItemInterface* parentInterface() const { return m_parentDataItemInterface; }
+
+ /*! Handles action having standard name \a actionName.
+ Action could be: "edit_cut", "edit_paste", etc.
+ For reimplementation. */
+ virtual void handleAction(const QString& actionName) { Q_UNUSED(actionName); }
+
+ protected:
+ /*! Initializes this editor with \a add value, which should be somewhat added to the current
+ value (already storted in m_origValue).
+ If \a removeOld is true, a value should be set to \a add, otherwise
+ -it should be set to current \a m_origValue + \a add, if possible.
+ Implement this. */
+ virtual void setValueInternal(const QVariant& add, bool removeOld) = 0;
+
+ /*! Initializes this editor with \a value visible value.
+ This is currently used only in case of the combo box form widget, where displayed content
+ (usually a text of image) differs from the value of the widget (a numeric index).
+ For implementation in the combo box widget, by default does nothing. */
+ virtual void setVisibleValueInternal(const QVariant& value);
+
+// //! Sets value \a value for a widget.
+// //! Implement this method to allow setting value for this widget item.
+// virtual void setValueInternal(const QVariant& value) = 0;
+
+ /*! Call this in your implementation when value changes,
+ so installed listener can react on this change. If there is a parent data item defined
+ (see setParentDataItemInterface()), parent's signalValueChanged() method will be called instead. */
+ virtual void signalValueChanged();
+
+ /*! Used to perform some actions before signalValueChanged() call.
+ We need this because the intrface is not QObject and thus has got no real signals.
+ Used in KexiDBComboBox. */
+ virtual void beforeSignalValueChanged() {};
+
+ KexiDataItemChangesListener* listener();
+
+//moved to KexiFormDataItemInterface: QString m_dataSource;
+ QGuardedPtr<QObject> m_listenerObject;
+ KexiDataItemChangesListener* m_listener;
+ bool m_listenerIsQObject;
+ QVariant m_origValue;
+
+ /*! @see parentDataItemInterface() */
+ KexiDataItemInterface* m_parentDataItemInterface;
+ bool m_hasFocusableWidget : 1;
+ bool m_disable_signalValueChanged : 1;
+ bool m_acceptEditorAfterDeleteContents : 1;
+};
+
+#endif