You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
koffice/lib/koproperty/editor.h

190 lines
6.8 KiB

/* This file is part of the KDE project
Copyright (C) 2004 Cedric Pasteur <cedric.pasteur@free.fr>
Copyright (C) 2004 Alexander Dymo <cloudtemple@mskat.net>
Copyright (C) 2004-2006 Jaroslaw Staniek <js@iidea.pl>
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 KPROPERTY_PROPERTYEDITOR_H
#define KPROPERTY_PROPERTYEDITOR_H
#include <tqguardedptr.h>
#include "koproperty_global.h"
#include <klistview.h>
class TQSize;
namespace KoProperty {
class EditorPrivate;
class Property;
class Set;
class Widget;
class EditorItem;
/*! \brief A listview to edit properties
Editor widgets use property options using Property::option(const char *)
to override default behaviour of editor items.
Currently supported options are:
<ul><li> min: integer setting for minimum value of IntEdit and DoubleEdit item. Default is 0.
Set "min" to -1, if you want this special value to be allowed.</li>
<li> minValueText: i18n'd TQString used in IntEdit to set "specialValueText"
widget's property</li>
<li> max: integer setting for minimum value of IntEdit item. Default is 0xffff.</li>
<li> precision: The number of decimals after the decimal point. (for DoubleEdit)</li>
<li> step : the size of the step that is taken when the user hits the up
or down buttons (for DoubleEdit) </li>
<li> 3rdState: i18n'd TQString used in BoolEdit. If not empty, the the editor's button
accept third "null" state with name equal to this string. When this value is selected,
Widget::value() returns null TQVariant. This option is used for example in the "defaultValue"
property for a field of type boolean (in Kexi Table Designer). Third, "null" value
of the property means there is no "defaultValue" specified. </li>
</ul>
\author Cedric Pasteur <cedric.pasteur@free.fr>
\author Alexander Dymo <cloudtemple@mskat.net>
\author Jaroslaw Staniek <js@iidea.pl>
*/
class KOPROPERTY_EXPORT Editor : public KListView
{
Q_OBJECT
public:
/*! Creates an empty Editor with \a parent as parent widget.
If \a autoSync == true, properties values are automatically synced as
soon as editor contents change (eg the user types text, etc.)
and the values are written in the property set. Otherwise, property set
is updated only when selected item changes or user presses Enter key.
Each property can overwrite this if its autoSync() == 0 or 1.
*/
Editor(TQWidget *parent=0, bool autoSync=true, const char *name=0);
virtual ~Editor();
virtual TQSize sizeHint() const;
virtual void setFocus();
virtual void setSorting( int column, bool ascending = true );
public slots:
/*! Populates the editor with an item for each property in the List.
Also creates child items for composed properties.
If \a preservePrevSelection is true, previously selected editor
item will be kept selected, if present. */
void changeSet(Set *set, bool preservePrevSelection = false);
/*! Populates the editor with an item for each property in the List.
Also creates child items for composed properties.
If \a propertyToSelect is not empty, editor item for this property name
will be selected, if present. */
void changeSet(Set *set, const TQCString& propertyToSelect);
/*! Clears all items in the list.
if \a editorOnly is true, then only the current editor will be cleared,
not the whole list.
*/
void clear(bool editorOnly = false);
/*! Accept the changes mae to the current editor (as if the user had pressed Enter key) */
void acceptInput();
signals:
/*! Emitted when current property set has been changed. May be 0. */
void propertySetChanged(KoProperty::Set *set);
protected slots:
/*! Updates property widget in the editor.*/
void slotPropertyChanged(KoProperty::Set& set, KoProperty::Property& property);
void slotPropertyReset(KoProperty::Set& set, KoProperty::Property& property);
/*! Updates property in the list when new value is selected in the editor.*/
void slotWidgetValueChanged(Widget* widget);
/*! Called when the user presses Enter to accet the input
(only applies when autoSync() == false).*/
void slotWidgetAcceptInput(Widget *widget);
/*! Called when the user presses Esc. Calls undo(). */
void slotWidgetRejectInput(Widget *widget);
/*! Called when current property set is about to be cleared. */
void slotSetWillBeCleared();
/*! Called when current property set is about to be destroyed. */
void slotSetWillBeDeleted();
/*! This slot is called when the user clicks the list view.
It takes care of deleting current editor and
creating a new editor for the newly selected item. */
void slotClicked(TQListViewItem *item);
/*! Undoes the last change in property editor.*/
void undo();
void updateEditorGeometry(bool forceUndoButtonSettings = false, bool undoButtonVisible = false);
void updateEditorGeometry(EditorItem *item, Widget* widget, bool forceUndoButtonSettings = false, bool undoButtonVisible = false);
void updateGroupLabelsPosition();
void hideEditor();
void slotCollapsed(TQListViewItem *item);
void slotExpanded(TQListViewItem *item);
void slotColumnSizeChanged(int section);
void slotColumnSizeChanged(int section, int oldSize, int newSize);
void slotCurrentChanged(TQListViewItem *item);
void changeSetLater();
void selectItemLater();
protected:
/*! \return \ref Widget for given property.
Uses cache to store created widgets.
Cache will be cleared only with clearWidgetCache().*/
Widget *createWidgetForProperty(Property *property, bool changeWidgetProperty=true);
/*! Deletes cached machines.*/
void clearWidgetCache();
void fill();
void addItem(const TQCString &name, EditorItem *parent);
void showUndoButton( bool show );
virtual void resizeEvent(TQResizeEvent *ev);
virtual bool eventFilter( TQObject * watched, TQEvent * e );
bool handleKeyPress(TQKeyEvent* ev);
virtual bool event( TQEvent * e );
void updateFont();
virtual void contentsMousePressEvent( TQMouseEvent * e );
/*! Used for changeSet(). */
void changeSetInternal(Set *set, bool preservePrevSelection,
const TQCString& propertyToSelect);
private:
EditorPrivate *d;
friend class EditorItem;
friend class Widget;
};
}
#endif