aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorq5sys <jt@obs-sec.com>2017-07-27 19:40:08 -0400
committerq5sys <jt@obs-sec.com>2017-07-27 19:40:08 -0400
commit589fa4192b0a7a44e0a0f6db0aedccbf2310b3e6 (patch)
tree1f9cffe587b2bb5b99a5bf60aaf6214a835eb611
parentMerge remote-tracking branch 'origin/master' (diff)
downloadlumina-589fa4192b0a7a44e0a0f6db0aedccbf2310b3e6.tar.gz
lumina-589fa4192b0a7a44e0a0f6db0aedccbf2310b3e6.tar.bz2
lumina-589fa4192b0a7a44e0a0f6db0aedccbf2310b3e6.zip
2nd attempt at wm selection patch
-rw-r--r--src-qt5/core-utils/lumina-config/pages/page_session_options.cpp50
-rw-r--r--src-qt5/core-utils/lumina-config/pages/page_session_options.h1
-rw-r--r--src-qt5/core-utils/lumina-config/pages/page_session_options.ui20
3 files changed, 68 insertions, 3 deletions
diff --git a/src-qt5/core-utils/lumina-config/pages/page_session_options.cpp b/src-qt5/core-utils/lumina-config/pages/page_session_options.cpp
index 3aba502f..e4218b88 100644
--- a/src-qt5/core-utils/lumina-config/pages/page_session_options.cpp
+++ b/src-qt5/core-utils/lumina-config/pages/page_session_options.cpp
@@ -54,6 +54,18 @@ void page_session_options::SaveSettings(){
sessionsettings.setValue("DateFormat", ui->line_session_date->text());
sessionsettings.setValue("DateTimeOrder", ui->combo_session_datetimeorder->currentData().toString());
+ QString my_win = ui->mywindowmanager->currentText();
+ // Warn user if they select a non-default window manager
+ if (! my_win.contains("Lumina") )
+ QMessageBox::information(this, tr("Window manager"), "Warning: Please note window managers other than Lumina are not supported." );
+ // If we selected "Lumina" as the window manager, leave the field blank to get default
+ if (! my_win.compare("Lumina"))
+ sessionsettings.remove("WindowManager");
+ else
+ sessionsettings.setValue("WindowManager", my_win);
+
+
+
QString lopenWatchFile = QString(getenv("XDG_CONFIG_HOME"))+"/lumina-desktop/nowatch";
if(QFile::exists(lopenWatchFile) && ui->check_watch_app_procs->isChecked()){
QFile::remove(lopenWatchFile);
@@ -91,6 +103,25 @@ void page_session_options::LoadSettings(int){
int index = ui->combo_session_datetimeorder->findData( sessionsettings.value("DateTimeOrder","timeonly").toString() );
ui->combo_session_datetimeorder->setCurrentIndex(index);
+ FindWindowManagerOptions(); // check system for available options
+ QString old_wm = sessionsettings.value("WindowManager").toString();
+
+ // Check to see if old window manager is in our list and, if not, add it
+ if ( old_wm.length() > 0 )
+ {
+ index = ui->mywindowmanager->findText( old_wm );
+ if (index == -1) // did not find existing option in list, so add it
+ {
+ ui->mywindowmanager->addItem( old_wm );
+ // Past window manager is now in list so we can select it, even if it did not exist before
+ index = ui->mywindowmanager->findText( old_wm );
+ }
+ }
+ else // there was no "old" window manager, default to using Lumina/default
+ index = ui->mywindowmanager->findText( "Lumina" );
+
+ ui->mywindowmanager->setCurrentIndex(index);
+
QString lopenWatchFile = QString(getenv("XDG_CONFIG_HOME"))+"/lumina-desktop/nowatch";
ui->check_watch_app_procs->setChecked( !QFile::exists(lopenWatchFile) );
@@ -111,6 +142,25 @@ void page_session_options::updateIcons(){
// PRIVATE
//=================
+void page_session_options::FindWindowManagerOptions(){
+ // Try to find all available window managers and add them to drop-down box.
+ ui->mywindowmanager->clear();
+ ui->mywindowmanager->addItem("Lumina"); // make sure there is a default
+ if (QFileInfo::exists("/usr/bin/fluxbox"))
+ ui->mywindowmanager->addItem("/usr/bin/fluxbox");
+ else if (QFileInfo::exists("/usr/local/bin/fluxbox"))
+ ui->mywindowmanager->addItem("/usr/local/bin/fluxbox");
+ if (QFileInfo::exists("/usr/bin/kwin"))
+ ui->mywindowmanager->addItem("/usr/bin/kwin");
+ else if (QFileInfo::exists("/usr/local/bin/kwin"))
+ ui->mywindowmanager->addItem("/usr/local/bin/kwin");
+ if (QFileInfo::exists("/usr/bin/openbox"))
+ ui->mywindowmanager->addItem("/usr/bin/openbox");
+ else if (QFileInfo::exists("/usr/local/bin/openbox"))
+ ui->mywindowmanager->addItem("/usr/local/bin/openbox");
+}
+
+
//=================
// PRIVATE SLOTS
//=================
diff --git a/src-qt5/core-utils/lumina-config/pages/page_session_options.h b/src-qt5/core-utils/lumina-config/pages/page_session_options.h
index d28cb7e9..8e3805a6 100644
--- a/src-qt5/core-utils/lumina-config/pages/page_session_options.h
+++ b/src-qt5/core-utils/lumina-config/pages/page_session_options.h
@@ -30,6 +30,7 @@ public slots:
private:
Ui::page_session_options *ui;
bool loading;
+ void FindWindowManagerOptions();
private slots:
void sessionChangeUserIcon();
diff --git a/src-qt5/core-utils/lumina-config/pages/page_session_options.ui b/src-qt5/core-utils/lumina-config/pages/page_session_options.ui
index 255166de..1e0e37ba 100644
--- a/src-qt5/core-utils/lumina-config/pages/page_session_options.ui
+++ b/src-qt5/core-utils/lumina-config/pages/page_session_options.ui
@@ -204,10 +204,24 @@
</property>
</widget>
</item>
- <item row="4" column="1">
- <widget class="QComboBox" name="combo_session_datetimeorder"/>
+ <item row="4" column="1">
+ <widget class="QComboBox" name="combo_session_datetimeorder"/>
+ </item>
+ <item row="5" column="1">
+ <widget class="QComboBox" name="mywindowmanager">
+ <property name="toolTip">
+ <string/>
+ </property>
+ </widget>
</item>
- </layout>
+ <item row="5" column="0">
+ <widget class="QLabel" name="label">
+ <property name="text">
+ <string>Window Manager</string>
+ </property>
+ </widget>
+ </item>
+ </layout>
</item>
<item row="1" column="0">
<spacer name="verticalSpacer_2">
bgstack15