Subversion Repositories OpenInventory

Rev

Rev 182 | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
48 pingvin 1
#include "mymodel.h"
2
 
3
MyModel::MyModel(QObject *parent) :
4
      QSqlTableModel(parent)
5
{
6
    setEditStrategy(QSqlTableModel::OnManualSubmit);
7
}
8
 
9
Qt::ItemFlags MyModel::flags(
10
         const QModelIndex &index) const {
11
Qt::ItemFlags flags = QSqlTableModel::flags(index);
165 pingvin 12
if ((index.column() != 3) && (index.column() != 0) /* && (index.column() != 5)*/)
48 pingvin 13
     flags |= Qt::ItemIsEditable;
14
//if (index.column() == 4)
15
//     flags |= Qt::ItemIsUserCheckable;
51 pingvin 16
else
17
{
165 pingvin 18
    if ((index.column() == 3) || (index.column() == 0) /* || (index.column() == 5)*/) flags &= ~Qt::ItemIsEditable; //   0, 3  5 
48 pingvin 19
}
51 pingvin 20
    return flags;
21
}
48 pingvin 22
 
23
 
24
bool MyModel::setData(const QModelIndex &index, const QVariant &value, int role) {
54 pingvin 25
  ////  if (index.column()==3) return false; //       
48 pingvin 26
    bool lResult = false;
51 pingvin 27
 
28
    /*
29
    QString str_tmp;
30
    if (index.column()==1) {                //    
31
        str_tmp = value.toString();         //     
32
        str_tmp.append(tr(" instance"));
33
      }
34
      */
54 pingvin 35
/*
36
    QString str_tmp;
37
    if (index.column()==0) {                //    
38
        str_tmp = value.toString();         //     
39
        str_tmp.append(tr("_instance"));
40
      }
41
*/
48 pingvin 42
    lResult = QSqlTableModel::setData(index, value, role);
182 pingvin 43
 
44
 //   if (index.column() == 5) return lResult;
48 pingvin 45
    if (lResult) {
51 pingvin 46
        QModelIndex newindex;
48 pingvin 47
        QSqlRecord rec = record(index.row());
51 pingvin 48
 
182 pingvin 49
        if (value.isNull()) {
50
        rec.setNull(index.column());
51
 
52
        }
53
        else rec.setValue(index.column(), value);
54
 
48 pingvin 55
        rec.setGenerated(index.column(), true);
51 pingvin 56
 
57
        /*
58
        if (index.column()==1){
59
            rec.setValue(index.column()+2, QVariant(str_tmp));
60
            rec.setGenerated(index.column()+2, true);
61
            newindex = MyModel::index(index.row(), index.column()+2);
62
            QSqlTableModel::setData(newindex, QVariant(str_tmp), Qt::EditRole);
63
        }
64
        */
54 pingvin 65
/*
51 pingvin 66
 
54 pingvin 67
        if (index.column()==0){
68
            rec.setValue(index.column()+3, QVariant(str_tmp));
69
            rec.setGenerated(index.column()+3, true);
70
            newindex = MyModel::index(index.row(), index.column()+3);
71
            QSqlTableModel::setData(newindex, QVariant(str_tmp), Qt::EditRole);
72
        }
73
*/
51 pingvin 74
 
48 pingvin 75
        lResult = updateRowInTable(index.row(), rec);
54 pingvin 76
  ///      QSqlTableModel::setData(newindex, QVariant(str_tmp), Qt::EditRole);
182 pingvin 77
  //          submitAll();
78
   //         this->select();
51 pingvin 79
 
48 pingvin 80
    }
184 pingvin 81
    if (value.isNull()) {
82
        select();
83
        emit dataChanged(index, index);
84
    }
48 pingvin 85
    return lResult;
86
}
51 pingvin 87
 
88
 
89
 
90
QVariant MyModel::data(const QModelIndex &index, int role) const {
91
 
92
     QVariant value = QSqlTableModel::data(index, role);
93
  switch (role) {
94
        case Qt::DisplayRole: return value;
95
        case Qt::EditRole: return value;
96
        case Qt::TextColorRole:
97
            if(index.column() == 1)
98
                return qVariantFromValue(QColor(Qt::blue));
99
            else
100
              return value;
101
        case Qt::TextAlignmentRole: return value;
102
        case Qt::FontRole:
103
           if(index.column() == 1) {
104
               QFont font = QFont("Helvetica", 16, QFont::Bold);
105
              return qVariantFromValue(font);
106
           }else
107
               return value;
108
 
109
       case Qt::BackgroundColorRole: {
110
                int a = (index.row() % 2) ? 14 : 0;
111
                if(index.column() == 2)
112
                           return qVariantFromValue(QColor(220,240-a,230-a));
113
                        else if(index.column() == 4)
114
                            return qVariantFromValue(QColor(200,220-a,255-a));
115
                        else
116
                           return value;
117
                                    }
118
 
119
 
120
 
121
     case Qt::CheckStateRole: return value;
122
 
165 pingvin 123
     case Qt::SizeHintRole:
124
              {
51 pingvin 125
 
166 pingvin 126
             int height = value.toSize().height();
127
             int widht = value.toSize().width();
128
             if(index.column() == 5) {
129
                               QVariant currentImage = QSqlTableModel::data(index, 0);
130
                               QByteArray bytes = currentImage.toByteArray();
131
                               QPixmap pxmp;
132
 
133
 
134
                               if (currentImage.isValid()) {
135
                                    pxmp.loadFromData(bytes);
136
                                    if (height < pxmp.height()) height =  pxmp.height() +10;
137
                                    if (widht < pxmp.width()) widht = pxmp.width() +10;
138
                                    return QVariant(QSize(widht, height));
139
 
140
                                }
141
                               else return value;
142
 
143
                           }
144
 
145
 
146
        //     QSize size(200,100);
147
 
165 pingvin 148
                 return value;
166 pingvin 149
          //        return QVariant(size);
165 pingvin 150
              }
151
 
152
      case Qt::DecorationRole: {
172 pingvin 153
              if(index.column() == 1) return iconProvider.icon(QFileIconProvider::Folder);
154
              else return QVariant();
155
              /*{
165 pingvin 156
                  QVariant currentImage = QSqlTableModel::data(index, 0);
157
                  QByteArray bytes = currentImage.toByteArray();
158
                  QPixmap pxmp;
159
                  if (currentImage.isValid()) {
160
                       pxmp.loadFromData(bytes);
161
                       QIcon icon;
162
                       icon.addPixmap(pxmp);
163
                       return icon;
164
 
165
                  }
166
                  else {
167
                      //QItemDelegate::paint(painter, option, index);
168
                  return value;
169
                  }
170
 
171
              }
172
       */
173
 
174
          }
175
 
176
 
177
 
178
     }
51 pingvin 179
  return value;
180
}
181