summaryrefslogtreecommitdiffstats
path: root/examples/sql/overview/table4/main.h
blob: d1fb591a00ae1b683929ef81220add3fda7b3eab (plain)
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
/****************************************************************************
**
** Copyright (C) 1992-2008 Trolltech ASA.  All rights reserved.
**
** This file is part of an example program for TQt.  This example
** program may be used, distributed and modified without limitation.
**
*****************************************************************************/

#include <ntqapplication.h>
#include <ntqcombobox.h>
#include <ntqmap.h>
#include <ntqpainter.h>
#include <tqsqldatabase.h>
#include <tqsqlcursor.h>
#include <tqsqleditorfactory.h>
#include <tqsqlpropertymap.h>
#include <tqdatatable.h>
#include "../connection.h"

class StatusPicker : public TQComboBox
{
    TQ_OBJECT
    TQ_PROPERTY( int statusid READ statusId WRITE setStatusId )
public:
    StatusPicker( TQWidget *parent=0, const char *name=0 );
    int statusId() const;
    void setStatusId( int id );
private:
    TQMap< int, int > index2id;
};


class CustomTable : public TQDataTable
{
    TQ_OBJECT
public:
    CustomTable( 
	    TQSqlCursor *cursor, bool autoPopulate = FALSE, 
	    TQWidget * parent = 0, const char * name = 0 ) : 
	TQDataTable( cursor, autoPopulate, parent, name ) {}
    void paintField(
	    TQPainter * p, const TQSqlField* field, const TQRect & cr, bool );

};


class CustomSqlEditorFactory : public TQSqlEditorFactory
{
    TQ_OBJECT
public:
    TQWidget *createEditor( TQWidget *parent, const TQSqlField *field );
};