17#include "moc_qgsprocessingtoolboxtreeview.cpp"
24QgsProcessingToolboxTreeView::QgsProcessingToolboxTreeView( QWidget *parent,
QgsProcessingRegistry *registry, QgsProcessingRecentAlgorithmLog *recentLog, QgsProcessingFavoriteAlgorithmManager *favoriteManager )
28 mToolboxModel = mModel->toolboxModel();
32void QgsProcessingToolboxTreeView::setRegistry(
QgsProcessingRegistry *registry, QgsProcessingRecentAlgorithmLog *recentLog, QgsProcessingFavoriteAlgorithmManager *favoriteManager )
37 mModel->deleteLater();
45 mModel->deleteLater();
49void QgsProcessingToolboxTreeView::setFilterString(
const QString &filter )
51 const QString text = filter.trimmed().toLower();
53 if ( !text.isEmpty() )
56 if ( !selectedAlgorithm() )
59 const QModelIndex firstVisibleIndex = findFirstVisibleAlgorithm( QModelIndex() );
60 if ( firstVisibleIndex.isValid() )
61 selectionModel()->setCurrentIndex( firstVisibleIndex, QItemSelectionModel::ClearAndSelect );
72 const QModelIndex sourceIndex = mModel->mapToSource( index );
73 if ( mToolboxModel->isAlgorithm( sourceIndex ) )
74 return mToolboxModel->algorithmForIndex( sourceIndex );
81 if ( selectionModel()->hasSelection() )
83 const QModelIndex index = selectionModel()->selectedIndexes().at( 0 );
84 return algorithmForIndex( index );
94 const QModelIndex sourceIndex = mModel->mapToSource( index );
95 if ( mToolboxModel->isParameter( sourceIndex ) )
96 return mToolboxModel->parameterTypeForIndex( sourceIndex );
103 if ( selectionModel()->hasSelection() )
105 const QModelIndex index = selectionModel()->selectedIndexes().at( 0 );
106 return parameterTypeForIndex( index );
116 mModel->setFilters( filters );
121 return mModel->filters();
124void QgsProcessingToolboxTreeView::setInPlaceLayer(
QgsVectorLayer *layer )
126 mModel->setInPlaceLayer( layer );
129QModelIndex QgsProcessingToolboxTreeView::findFirstVisibleAlgorithm(
const QModelIndex &parent )
131 for (
int r = 0; r < mModel->rowCount( parent ); ++r )
133 QModelIndex proxyIndex = mModel->index( r, 0, parent );
134 const QModelIndex sourceIndex = mModel->mapToSource( proxyIndex );
135 if ( mToolboxModel->isAlgorithm( sourceIndex ) )
138 QModelIndex index = findFirstVisibleAlgorithm( proxyIndex );
139 if ( index.isValid() )
142 return QModelIndex();
145void QgsProcessingToolboxTreeView::keyPressEvent( QKeyEvent *event )
147 if ( event->key() == Qt::Key_Return || event->key() == Qt::Key_Enter )
148 emit doubleClicked( currentIndex() );
150 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.