25#include <QItemSelectionModel>
29#include "moc_qgsfieldmappingwidget.cpp"
31#ifdef ENABLE_MODELTEST
39 const QMap<QString, QString> &expressions,
40 const QList< QgsVectorDataProvider::NativeType > &nativeTypes
44 QVBoxLayout *verticalLayout =
new QVBoxLayout();
45 verticalLayout->setContentsMargins( 0, 0, 0, 0 );
46 mTableView =
new QTableView();
47 verticalLayout->addWidget( mTableView );
48 setLayout( verticalLayout );
51 mModel->setNativeTypes( nativeTypes );
53#ifdef ENABLE_MODELTEST
54 new ModelTest( mModel,
this );
57 mTableView->setModel( mModel );
59 mTypeDelegate =
new QgsFieldMappingTypeDelegate( nativeTypes, mTableView );
63 connect( mModel, &QgsFieldMappingModel::rowsInserted,
this, [
this] { updateColumns(); } );
64 connect( mModel, &QgsFieldMappingModel::modelReset,
this, [
this] { updateColumns(); } );
73 qobject_cast<QgsFieldMappingModel *>( mModel )->setDestinationEditable( editable );
79 return qobject_cast<QgsFieldMappingModel *>( mModel )->destinationEditable();
84 return qobject_cast<QgsFieldMappingModel *>( mModel );
104 return mTableView->selectionModel();
114 mSourceLayer = layer;
129 mTypeDelegate->setNativeTypes( nativeTypes );
130 mModel->setNativeTypes( nativeTypes );
135 mTableView->scrollTo( index );
150 if ( !mTableView->selectionModel()->hasSelection() )
153 std::list<int> rowsToRemove { selectedRows() };
154 rowsToRemove.reverse();
155 for (
const int row : rowsToRemove )
157 if ( !
model()->removeField(
model()->index( row, 0, QModelIndex() ) ) )
167 for (
int i = 0; i < mTableView->model()->rowCount(); ++i )
169 for (
int j = 0; j < mTableView->model()->columnCount(); j++ )
171 QModelIndex index = mTableView->model()->index( i, j );
172 mTableView->selectionModel()->select( index, QItemSelectionModel::Toggle );
179 if ( !mTableView->selectionModel()->hasSelection() )
182 const std::list<int> rowsToMoveUp { selectedRows() };
183 for (
const int row : rowsToMoveUp )
185 if ( !
model()->moveUp(
model()->index( row, 0, QModelIndex() ) ) )
195 if ( !mTableView->selectionModel()->hasSelection() )
198 std::list<int> rowsToMoveDown { selectedRows() };
199 rowsToMoveDown.reverse();
200 for (
const int row : rowsToMoveDown )
202 if ( !
model()->moveDown(
model()->index( row, 0, QModelIndex() ) ) )
210void QgsFieldMappingWidget::updateColumns()
212 for (
int i = 0; i < mModel->
rowCount(); ++i )
218 for (
int i = 0; i < mModel->columnCount(); ++i )
220 mTableView->resizeColumnToContents( i );
224std::list<int> QgsFieldMappingWidget::selectedRows()
227 if ( mTableView->selectionModel()->hasSelection() )
229 const QModelIndexList constSelection { mTableView->selectionModel()->selectedIndexes() };
230 for (
const QModelIndex &index : constSelection )
232 rows.push_back( index.row() );
246QgsFieldMappingExpressionDelegate::QgsFieldMappingExpressionDelegate( QObject *parent )
247 : QStyledItemDelegate( parent )
251void QgsFieldMappingExpressionDelegate::setModelData( QWidget *editor, QAbstractItemModel *model,
const QModelIndex &index )
const
259 const QString currentValue { editorWidget->
currentField( &isExpression, &isValid ) };
262 model->setData( index, currentValue, Qt::EditRole );
270void QgsFieldMappingExpressionDelegate::setEditorData( QWidget *editor,
const QModelIndex &index )
const
276 const QVariant value = index.model()->data( index, Qt::EditRole );
277 editorWidget->
setField( value.toString() );
280QWidget *QgsFieldMappingExpressionDelegate::createEditor( QWidget *parent,
const QStyleOptionViewItem &option,
const QModelIndex &index )
const
284 editor->setAutoFillBackground(
true );
286 if (
const QgsFieldMappingModel *model = qobject_cast<const QgsFieldMappingModel *>( index.model() ) )
289 editor->
setFields( model->sourceFields() );
294 editor->
setFields( model->sourceFields() );
301 if (
QgsFieldMappingWidget *mappingWidget = qobject_cast<QgsFieldMappingWidget *>( QgsFieldMappingExpressionDelegate::parent() ) )
303 if ( mappingWidget->sourceLayer() )
304 editor->
setLayer( mappingWidget->sourceLayer() );
306 else if (
QgsAggregateMappingWidget *aggregateWidget = qobject_cast<QgsAggregateMappingWidget *>( QgsFieldMappingExpressionDelegate::parent() ) )
308 if ( aggregateWidget->sourceLayer() )
309 editor->
setLayer( aggregateWidget->sourceLayer() );
312 editor->
setField( index.model()->data( index, Qt::DisplayRole ).toString() );
314 Q_UNUSED( fieldName )
315 const_cast<QgsFieldMappingExpressionDelegate *
>( this )->emit commitData( editor );
325QgsFieldMappingTypeDelegate::QgsFieldMappingTypeDelegate(
const QList< QgsVectorDataProvider::NativeType > &nativeTypes, QObject *parent )
326 : QStyledItemDelegate( parent )
327 , mNativeTypes( nativeTypes.isEmpty() ?
QgsFieldMappingModel::supportedDataTypes() : nativeTypes )
331QWidget *QgsFieldMappingTypeDelegate::createEditor( QWidget *parent,
const QStyleOptionViewItem &option,
const QModelIndex &index )
const
334 QComboBox *editor =
new QComboBox( parent );
340 editor->setItemData( i, type.mTypeName, Qt::UserRole );
344 const QgsFieldMappingModel *model { qobject_cast<const QgsFieldMappingModel *>( index.model() ) };
348 editor->setEnabled(
false );
352 connect( editor, qOverload<int>( &QComboBox::currentIndexChanged ),
this, [
this, editor](
int currentIndex ) {
353 Q_UNUSED( currentIndex )
354 const_cast<QgsFieldMappingTypeDelegate *
>( this )->emit commitData( editor );
360void QgsFieldMappingTypeDelegate::setEditorData( QWidget *editor,
const QModelIndex &index )
const
362 QComboBox *editorWidget { qobject_cast<QComboBox *>( editor ) };
366 const QVariant value = index.model()->data( index, Qt::EditRole );
367 editorWidget->setCurrentIndex( editorWidget->findData( value ) );
370void QgsFieldMappingTypeDelegate::setModelData( QWidget *editor, QAbstractItemModel *model,
const QModelIndex &index )
const
372 QComboBox *editorWidget { qobject_cast<QComboBox *>( editor ) };
376 const QVariant currentValue = editorWidget->currentData();
377 model->setData( index, currentValue, Qt::EditRole );
380void QgsFieldMappingTypeDelegate::setNativeTypes(
const QList<QgsVectorDataProvider::NativeType> &nativeTypes )
Holds mapping information for defining sets of aggregates of fields from a QgsFields object.
Abstract interface for generating an expression context.
static QString quotedColumnRef(QString name)
Returns a quoted column reference (in double quotes).
Holds mapping information for mapping from one set of QgsFields to another.
@ SourceExpression
Expression.
@ DestinationType
Destination field type string.
void appendField(const QgsField &field, const QString &expression=QString())
Appends a new field to the model, with an optional expression.
QMap< QString, QgsProperty > fieldPropertyMap() const
Returns a map of destination field name to QgsProperty definition for field value,...
QList< QgsFieldMappingModel::Field > mapping() const
Returns a list of Field objects representing the current status of the model.
int rowCount(const QModelIndex &parent=QModelIndex()) const override
void setBaseExpressionContextGenerator(const QgsExpressionContextGenerator *generator)
Sets the base expression context generator, which will generate the expression contexts for expressio...
static const QList< QgsVectorDataProvider::NativeType > supportedDataTypes()
Returns a static list of supported data types.
void setDestinationFields(const QgsFields &destinationFields, const QMap< QString, QString > &expressions=QMap< QString, QString >())
Set destination fields to destinationFields, initial values for the expressions can be optionally spe...
void setSourceFields(const QgsFields &sourceFields)
Set source fields to sourceFields.
bool destinationEditable() const
Returns true if the destination fields are editable.
void setFieldPropertyMap(const QMap< QString, QgsProperty > &map)
Sets a map of destination field name to QgsProperty definition for field value.
Encapsulate a field in an attribute table or data source.
Container of fields for a vector layer.
static QIcon iconForFieldType(QMetaType::Type type, QMetaType::Type subType=QMetaType::Type::UnknownType, const QString &typeString=QString())
Returns an icon corresponding to a field type.
Represents a vector layer which manages a vector based dataset.