26 #include <QTableWidget> 27 #include <QGridLayout> 28 #include <QToolButton> 31 #include <QHeaderView> 35 QgsFilterAlgorithmConfigurationWidget::QgsFilterAlgorithmConfigurationWidget( QWidget *parent )
38 setContentsMargins( 0, 0, 0, 0 );
40 mOutputExpressionWidget =
new QTableWidget();
41 mOutputExpressionWidget->setColumnCount( 3 );
42 mOutputExpressionWidget->setHorizontalHeaderItem( 0,
new QTableWidgetItem( tr(
"Output Name" ) ) );
43 mOutputExpressionWidget->setHorizontalHeaderItem( 1,
new QTableWidgetItem( tr(
"Filter Expression" ) ) );
44 mOutputExpressionWidget->setHorizontalHeaderItem( 2,
new QTableWidgetItem( tr(
"Final Output" ) ) );
45 mOutputExpressionWidget->horizontalHeader()->setResizeMode( 1, QHeaderView::Stretch );
46 QGridLayout *layout =
new QGridLayout();
49 layout->addWidget(
new QLabel( tr(
"Outputs and filters" ) ), 0, 0, 1, 2 );
50 layout->addWidget( mOutputExpressionWidget, 1, 0, 4, 1 );
51 QToolButton *addOutputButton =
new QToolButton();
53 addOutputButton->setText( tr(
"Add Output" ) );
55 QToolButton *removeOutputButton =
new QToolButton();
57 removeOutputButton->setToolTip( tr(
"Remove Selected Outputs" ) );
59 layout->addWidget( addOutputButton, 2, 1, 1, 1 );
60 layout->addWidget( removeOutputButton, 3, 1, 1, 1 );
62 connect( addOutputButton, &QToolButton::clicked,
this, &QgsFilterAlgorithmConfigurationWidget::addOutput );
63 connect( removeOutputButton, &QToolButton::clicked,
this, &QgsFilterAlgorithmConfigurationWidget::removeSelectedOutputs );
65 connect( mOutputExpressionWidget->selectionModel(), &QItemSelectionModel::selectionChanged,
this, [removeOutputButton,
this]
67 removeOutputButton->setEnabled( !mOutputExpressionWidget->selectionModel()->selectedIndexes().isEmpty() );
71 QVariantMap QgsFilterAlgorithmConfigurationWidget::configuration()
const 75 for (
int i = 0; i < mOutputExpressionWidget->rowCount(); ++i )
78 output.insert( QStringLiteral(
"name" ), mOutputExpressionWidget->item( i, 0 )->text() );
79 output.insert( QStringLiteral(
"expression" ), qobject_cast<QgsExpressionLineEdit *>( mOutputExpressionWidget->cellWidget( i, 1 ) )->expression() );
80 output.insert( QStringLiteral(
"isModelOutput" ), qobject_cast<QCheckBox *>( mOutputExpressionWidget->cellWidget( i, 2 ) )->isChecked() );
81 outputs.append( output );
85 map.insert(
"outputs", outputs );
91 void QgsFilterAlgorithmConfigurationWidget::setConfiguration(
const QVariantMap &configuration )
93 mOutputExpressionWidget->setRowCount( 0 );
95 const QVariantList outputs = configuration.value(
"outputs" ).toList();
97 for (
const QVariant &outputvar : outputs )
99 const QVariantMap output = outputvar.toMap();
100 mOutputExpressionWidget->insertRow( currentRow );
101 mOutputExpressionWidget->setItem( currentRow, 0,
new QTableWidgetItem( output.value(
"name" ).toString() ) );
103 expressionBuilder->
setExpression( output.value(
"expression" ).toString() );
104 mOutputExpressionWidget->setCellWidget( currentRow, 1, expressionBuilder );
105 QCheckBox *isModelOutput =
new QCheckBox();
106 isModelOutput->setChecked( output.value(
"isModelOutput" ).toBool() );
107 mOutputExpressionWidget->setCellWidget( currentRow, 2, isModelOutput );
112 if ( outputs.isEmpty() )
116 void QgsFilterAlgorithmConfigurationWidget::removeSelectedOutputs()
118 QItemSelection selection( mOutputExpressionWidget->selectionModel()->selection() );
121 const QModelIndexList indexes = selection.indexes();
122 for (
const QModelIndex &index : indexes )
124 rows.append( index.row() );
127 std::sort( rows.begin(), rows.end() );
130 for (
int i = rows.count() - 1; i >= 0; i -= 1 )
132 int current = rows[i];
133 if ( current != prev )
135 mOutputExpressionWidget->removeRow( current );
141 void QgsFilterAlgorithmConfigurationWidget::addOutput()
143 int rowIndex = mOutputExpressionWidget->rowCount();
144 mOutputExpressionWidget->setRowCount( rowIndex + 1 );
146 mOutputExpressionWidget->setItem( rowIndex, 0,
new QTableWidgetItem( QString() ) );
147 mOutputExpressionWidget->setCellWidget( rowIndex, 1, expressionBuilder );
148 mOutputExpressionWidget->setCellWidget( rowIndex, 2,
new QCheckBox() );
153 if ( algorithm->
name() == QStringLiteral(
"filter" ) )
154 return new QgsFilterAlgorithmConfigurationWidget();
159 bool QgsFilterAlgorithmConfigurationWidgetFactory::canCreateFor(
const QgsProcessingAlgorithm *algorithm )
const 161 return algorithm->
name() == QStringLiteral(
"filter" );
virtual QString name() const =0
Returns the algorithm name, used for identifying the algorithm.
static QIcon getThemeIcon(const QString &name)
Helper to get a theme icon.
Abstract base class for processing algorithms.
void setExpression(const QString &expression)
Sets the current expression to show in the widget.
The QgsExpressionLineEdit widget includes a line edit for entering expressions together with a button...
As part of the API refactoring and improvements which landed in the Processing API was substantially reworked from the x version This was done in order to allow much of the underlying Processing framework to be ported into allowing algorithms to be written in pure substantial changes are required in order to port existing x Processing algorithms for QGIS x The most significant changes are outlined not GeoAlgorithm For algorithms which operate on features one by consider subclassing the QgsProcessingFeatureBasedAlgorithm class This class allows much of the boilerplate code for looping over features from a vector layer to be bypassed and instead requires implementation of a processFeature method Ensure that your algorithm(or algorithm's parent class) implements the new pure virtual createInstance(self) call