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
|
/***************************************************************************
* Copyright (C) 2004-2006 by Thomas Fischer *
* fischer@unix-ag.uni-kl.de *
* *
* This program is free software; you can redistribute it and/or modify *
* it under the terms of the GNU 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 General Public License for more details. *
* *
* You should have received a copy of the GNU General Public License *
* along with this program; if not, write to the *
* Free Software Foundation, Inc., *
* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
***************************************************************************/
#ifndef KBIBTEXFIELDLINEEDIT_H
#define KBIBTEXFIELDLINEEDIT_H
#include <ntqwidget.h>
#include <entryfield.h>
#include <value.h>
class KLineEdit;
class TQTextEdit;
class TQPushButton;
class KCompletion;
namespace KBibTeX
{
class FieldLineEdit : public TQWidget
{
Q_OBJECT
public:
enum InputType {itSingleLine, itMultiLine};
enum ErrorType {etNoError, etInvalidStringKey};
FieldLineEdit( const TQString& caption, InputType inputType = itSingleLine, bool readOnly = FALSE, TQWidget *parent = 0, const char *name = 0 );
~FieldLineEdit();
/**
* Set the widget to use this value. The widget will make
* a deep copy internally and not modify the parameter.
* If NULL is passed to this function, the widget will be
* initialized with an empty BibTeXValue internally.
*/
void setValue( const BibTeX::Value *value );
/**
* Return the BibTeXValue of this widget. The returned
* variable is a deep copy of the widget's internal state.
* The returned variable must be delete later by the
* function caller.
* The function will return NULL if no data is set by the
* user for this widget.
*/
BibTeX::Value *value();
void setEnabled( bool enabled );
void setFieldType( BibTeX::EntryField::FieldType fieldType );
TQString caption();
bool isEmpty();
bool isModified();
ErrorType error();
signals:
void textChanged( );
protected slots:
void updateGUI();
private slots:
void slotTextChanged();
void slotStringToggled();
void slotComplexClicked();
private:
BibTeX::Value *m_value;
TQString m_caption;
KLineEdit *m_lineEdit;
TQTextEdit *m_textEdit;
TQPushButton *m_pushButtonString;
TQPushButton *m_pushButtonComplex;
bool m_isReadOnly;
bool m_enabled;
InputType m_inputType;
bool m_isModified;
BibTeX::EntryField::FieldType m_fieldType;
KCompletion *m_completion;
void setupGUI( const char *name );
void enableSignals( bool enabled );
};
}
#endif
|