diff options
author | Ken Moore <ken@ixsystems.com> | 2017-02-06 11:01:13 -0500 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-02-06 11:01:13 -0500 |
commit | 39ccacf377c82380839e0dd8bcc3b3c88c320c5d (patch) | |
tree | be64d1cf48ac5865c3ef8d99342386e9ace18423 /src-qt5/core-utils/lumina-config/AppDialog.h | |
parent | Merge pull request #369 from antab/issue-363 (diff) | |
parent | Change the app selection comboBox to list and add search feature. (diff) | |
download | lumina-39ccacf377c82380839e0dd8bcc3b3c88c320c5d.tar.gz lumina-39ccacf377c82380839e0dd8bcc3b3c88c320c5d.tar.bz2 lumina-39ccacf377c82380839e0dd8bcc3b3c88c320c5d.zip |
Merge pull request #370 from antab/app-selection
App selection UI improvement
Diffstat (limited to 'src-qt5/core-utils/lumina-config/AppDialog.h')
-rw-r--r-- | src-qt5/core-utils/lumina-config/AppDialog.h | 34 |
1 files changed, 31 insertions, 3 deletions
diff --git a/src-qt5/core-utils/lumina-config/AppDialog.h b/src-qt5/core-utils/lumina-config/AppDialog.h index ea7615e2..4eb6471c 100644 --- a/src-qt5/core-utils/lumina-config/AppDialog.h +++ b/src-qt5/core-utils/lumina-config/AppDialog.h @@ -26,10 +26,15 @@ public: AppDialog(QWidget *parent = 0) : QDialog(parent), ui(new Ui::AppDialog){ ui->setupUi(this); //load the designer file appreset = false; - ui->comboBox->clear(); + ui->listApps->clear(); QList<XDGDesktop*> APPS = LXDG::sortDesktopNames(APPSLIST->apps(false,false)); //Don't show all/hidden for(int i=0; i<APPS.length(); i++){ - ui->comboBox->addItem( LXDG::findIcon(APPS[i]->icon,"application-x-executable"), APPS[i]->name, APPS[i]->filePath); + QListWidgetItem *app = new QListWidgetItem(LXDG::findIcon(APPS[i]->icon,"application-x-executable"), APPS[i]->name); + app->setData(Qt::UserRole, APPS[i]->filePath); + ui->listApps->addItem(app); + } + if(ui->listApps->count()){ + ui->listApps->setCurrentItem(ui->listApps->item(0)); } this->setWindowIcon( LXDG::findIcon("system-search","") ); if(parent!=0){ @@ -56,7 +61,10 @@ public: private slots: void on_buttonBox_accepted(){ - appselected = ui->comboBox->currentData().toString(); + QListWidgetItem *item = ui->listApps->currentItem(); + if(item != nullptr){ + appselected = item->data(Qt::UserRole).toString(); + } this->close(); } void on_buttonBox_rejected(){ @@ -68,6 +76,26 @@ private slots: this->close(); } } + void on_listApps_itemDoubleClicked(QListWidgetItem *item){ + appselected = item->data(Qt::UserRole).toString(); + this->close(); + } + void on_lineSearch_textChanged(const QString &term){ + QListWidgetItem *first_visible = nullptr; + for(int i = 0; i < ui->listApps->count(); i++){ + QListWidgetItem *item = ui->listApps->item(i); + bool visible = item->text().contains(term, Qt::CaseInsensitive); + item->setHidden(!visible); + if(visible && first_visible == nullptr){ + first_visible = item; + } + } + //Select the first app + ui->listApps->setCurrentItem(first_visible); + if(first_visible != nullptr){ + ui->listApps->scrollToItem(first_visible); + } + } }; #endif |