Skip to content

Commit

Permalink
relationconfig
Browse files Browse the repository at this point in the history
  • Loading branch information
signedav committed Oct 27, 2017
1 parent 9df37d3 commit 6af4bb8
Show file tree
Hide file tree
Showing 2 changed files with 70 additions and 8 deletions.
61 changes: 53 additions & 8 deletions src/app/qgsattributesformproperties.cpp
Expand Up @@ -188,6 +188,22 @@ QgsAttributesFormProperties::FieldConfig QgsAttributesFormProperties::configForC
return FieldConfig();
}

QgsAttributesFormProperties::RelationConfig QgsAttributesFormProperties::configForRelationChild( const QString &relationName )
{
QTreeWidgetItemIterator itemIt( mAvailableWidgetsTree );
while ( *itemIt )
{
QTreeWidgetItem *item = *itemIt;
if ( item->data( 0, FieldNameRole ).toString() == relationName )
return item->data( 0, RelationConfigRole ).value<RelationConfig>();
++itemIt;
}

// Should never get here
Q_ASSERT( false );
return RelationConfig();
}


QTreeWidgetItem *QgsAttributesFormProperties::loadAttributeEditorTreeItem( QgsAttributeEditorElement *const widgetDef, QTreeWidgetItem *parent, DnDTree *tree )
{
Expand Down Expand Up @@ -313,14 +329,16 @@ void QgsAttributesFormProperties::initAvailableWidgetsTree()

for ( const QgsRelation &relation : relations )
{
DnDTreeItemData itemData = DnDTreeItemData( DnDTreeItemData::Relation, relation.name() );
DnDTreeItemData itemData = DnDTreeItemData( DnDTreeItemData::Relation, QStringLiteral( "%1" ).arg( relation.id() )); //relation.name() );
itemData.setShowLabel( true );

//daveRelation
RelationConfig cfg( mLayer, relation.id() );

QTreeWidgetItem *item = mAvailableWidgetsTree->addItem( catitem, itemData );
item->setData( 0, FieldNameRole, relation.name() );
item->setData( 0, RelationConfigRole, cfg );
item->setData( 0, FieldNameRole, QStringLiteral( "%1" ).arg( relation.id() ) ); //relation.name() );
}


}


Expand Down Expand Up @@ -416,10 +434,12 @@ void QgsAttributesFormProperties::apply()

QTreeWidgetItem* fieldContainer=mAvailableWidgetsTree->invisibleRootItem()->child(0);

int idx;

for ( int i = 0; i < fieldContainer->childCount(); i++ )
{
QTreeWidgetItem *fieldItem = fieldContainer->child( i );
int idx=fieldContainer->indexOfChild( fieldItem );
idx=fieldContainer->indexOfChild( fieldItem );

QString name = mLayer->fields().at( idx ).name();
FieldConfig cfg = configForChild( idx );
Expand Down Expand Up @@ -479,16 +499,24 @@ void QgsAttributesFormProperties::apply()
editFormConfig.setSuppress( ( QgsEditFormConfig::FeatureFormSuppress )mFormSuppressCmbBx->currentIndex() );
*/

/*

// relations
QTreeWidgetItem* relationContainer=mAvailableWidgetsTree->invisibleRootItem()->child(1);

for ( int i = 0; i < relationContainer->childCount(); i++ )
{
QTreeWidgetItem *relationItem = relationContainer->child( i );
int idx=relationContainer->indexOfChild( relationItem );
DnDTreeItemData itemData= relationItem->data( 0, DnDTreeRole ).value<DnDTreeItemData>();

QString name = mLayer->fields().at( idx ).name();
RelationConfig relCfg = configForRelChild( itemData.name() );

QVariantMap cfg;
cfg[QStringLiteral( "nm-rel" )]=relCfg.mCardinality;

editFormConfig.setWidgetConfig( itemData.name(), cfg );
}

/*
for ( int i = 0; i < mRelationsList->rowCount(); ++i )
{
Expand All @@ -509,6 +537,7 @@ void QgsAttributesFormProperties::apply()
editFormConfig.setWidgetConfig( relationName, cfg );
}
*/

mLayer->setEditFormConfig( editFormConfig );
}

Expand Down Expand Up @@ -552,6 +581,22 @@ QgsAttributesFormProperties::FieldConfig::operator QVariant()
return QVariant::fromValue<QgsAttributesFormProperties::FieldConfig>( *this );
}


/*
* RelationConfig implementation
*/
QgsAttributesFormProperties::RelationConfig::RelationConfig( QgsVectorLayer *layer, const QString &relationId )
{
const QVariant nmrelcfg = layer->editFormConfig().widgetConfig( relationId ).value( QStringLiteral( "nm-rel" ) );

mCardinality=nmrelcfg.toString();
}

QgsAttributesFormProperties::RelationConfig::operator QVariant()
{
return QVariant::fromValue<QgsAttributesFormProperties::RelationConfig>( *this );
}

/*
* DnDTree implementation
*/
Expand Down
17 changes: 17 additions & 0 deletions src/app/qgsattributesformproperties.h
Expand Up @@ -58,6 +58,7 @@ class APP_EXPORT QgsAttributesFormProperties : public QWidget, private Ui_QgsAtt
{
DnDTreeRole = Qt::UserRole,
FieldConfigRole,
RelationConfigRole,
FieldNameRole
};

Expand Down Expand Up @@ -156,6 +157,20 @@ class APP_EXPORT QgsAttributesFormProperties : public QWidget, private Ui_QgsAtt
operator QVariant();
};


/**
* Holds the configuration for a relation
*/
struct RelationConfig
{
RelationConfig();
RelationConfig( QgsVectorLayer *layer, const QString &relationId );

QString mCardinality;

operator QVariant();
};

public:
explicit QgsAttributesFormProperties( QgsVectorLayer *layer, QWidget *parent = nullptr );
~QgsAttributesFormProperties();
Expand All @@ -179,6 +194,8 @@ class APP_EXPORT QgsAttributesFormProperties : public QWidget, private Ui_QgsAtt
FieldConfig configForChild( int index );
void setConfigForChild( int index, const FieldConfig &cfg );

RelationConfig configForRelationChild( const QString &relationName );

//QList<QgsRelation> mRelations;
QgsVectorLayer *mLayer = nullptr;

Expand Down

0 comments on commit 6af4bb8

Please sign in to comment.