22#include "moc_qgsprocessingtoolboxtreeview.cpp"
26QgsProcessingToolboxTreeView::QgsProcessingToolboxTreeView( QWidget *parent,
QgsProcessingRegistry *registry, QgsProcessingRecentAlgorithmLog *recentLog, QgsProcessingFavoriteAlgorithmManager *favoriteManager )
30 mToolboxModel = mModel->toolboxModel();
34void QgsProcessingToolboxTreeView::setRegistry(
QgsProcessingRegistry *registry, QgsProcessingRecentAlgorithmLog *recentLog, QgsProcessingFavoriteAlgorithmManager *favoriteManager )
39 mModel->deleteLater();
47 mModel->deleteLater();
51void QgsProcessingToolboxTreeView::setFilterString(
const QString &filter )
53 const QString text = filter.trimmed().toLower();
55 if ( !text.isEmpty() )
58 if ( !selectedAlgorithm() )
61 const QModelIndex firstVisibleIndex = findFirstVisibleAlgorithm( QModelIndex() );
62 if ( firstVisibleIndex.isValid() )
63 selectionModel()->setCurrentIndex( firstVisibleIndex, QItemSelectionModel::ClearAndSelect );
72void QgsProcessingToolboxTreeView::reset()
76 if ( !mModel->filterString().isEmpty() )
84 const QModelIndex sourceIndex = mModel->mapToSource( index );
85 if ( mToolboxModel->isAlgorithm( sourceIndex ) )
86 return mToolboxModel->algorithmForIndex( sourceIndex );
93 if ( selectionModel()->hasSelection() )
95 const QModelIndex index = selectionModel()->selectedIndexes().at( 0 );
96 return algorithmForIndex( index );
106 const QModelIndex sourceIndex = mModel->mapToSource( index );
107 if ( mToolboxModel->isParameter( sourceIndex ) )
108 return mToolboxModel->parameterTypeForIndex( sourceIndex );
115 if ( selectionModel()->hasSelection() )
117 const QModelIndex index = selectionModel()->selectedIndexes().at( 0 );
118 return parameterTypeForIndex( index );
128 mModel->setFilters( filters );
133 return mModel->filters();
136void QgsProcessingToolboxTreeView::setInPlaceLayer(
QgsVectorLayer *layer )
138 mModel->setInPlaceLayer( layer );
141QModelIndex QgsProcessingToolboxTreeView::findFirstVisibleAlgorithm(
const QModelIndex &parent )
143 for (
int r = 0; r < mModel->rowCount( parent ); ++r )
145 QModelIndex proxyIndex = mModel->index( r, 0, parent );
146 const QModelIndex sourceIndex = mModel->mapToSource( proxyIndex );
147 if ( mToolboxModel->isAlgorithm( sourceIndex ) )
150 QModelIndex index = findFirstVisibleAlgorithm( proxyIndex );
151 if ( index.isValid() )
154 return QModelIndex();
157void QgsProcessingToolboxTreeView::keyPressEvent( QKeyEvent *event )
159 if ( event->key() == Qt::Key_Return || event->key() == Qt::Key_Enter )
160 emit doubleClicked( currentIndex() );
162 QTreeView::keyPressEvent( event );
Abstract base class for processing algorithms.
Makes metadata of processing parameters available.
Registry for various processing components, including providers, algorithms and various parameters an...
Represents a vector layer which manages a vector based dataset.