From af092e08b6e8b0dcfa0c37cc96d7f4c7d5fe990e Mon Sep 17 00:00:00 2001
From: Isaac Sh <424675+Iktwo@users.noreply.github.com>
Date: Fri, 30 Sep 2016 12:23:36 -0700
Subject: [PATCH] Add settings for theme selection
---
.../CustomFirebaseMessagingService.java | 6 +-
.../qutelauncher/QuteLauncherFlavored.java | 4 +-
.../qutelauncher/PackageChangedReceiver.java | 1 -
.../com/iktwo/qutelauncher/QuteLauncher.java | 3 -
src/qml/IntroView.qml | 8 +++
.../components/RadioButtonStyleDefault.qml | 32 +++++++++
src/qml/components/qmldir | 1 +
src/qml/intro/IntroEnd.qml | 7 +-
src/qml/intro/IntroMain.qml | 2 +-
src/qml/intro/IntroScreen.qml | 11 +++
src/qml/intro/IntroSelection.qml | 39 +++++++++++
src/qml/main.qml | 67 +++++++++----------
src/qml/themes/classic/ThemeMain.qml | 18 ++++-
src/qml/themes/tiles/ApplicationList.qml | 3 +-
src/resources.qrc | 3 +
15 files changed, 154 insertions(+), 51 deletions(-)
create mode 100644 src/qml/components/RadioButtonStyleDefault.qml
create mode 100644 src/qml/intro/IntroScreen.qml
create mode 100644 src/qml/intro/IntroSelection.qml
diff --git a/src/android/full/com/iktwo/qutelauncher/CustomFirebaseMessagingService.java b/src/android/full/com/iktwo/qutelauncher/CustomFirebaseMessagingService.java
index d9c22cf..7a6b874 100644
--- a/src/android/full/com/iktwo/qutelauncher/CustomFirebaseMessagingService.java
+++ b/src/android/full/com/iktwo/qutelauncher/CustomFirebaseMessagingService.java
@@ -10,14 +10,14 @@ public class CustomFirebaseMessagingService extends FirebaseMessagingService {
@Override
public void onMessageReceived(RemoteMessage remoteMessage) {
- Log.d(TAG, "From: " + remoteMessage.getFrom());
+ // Log.d(TAG, "From: " + remoteMessage.getFrom());
if (remoteMessage.getData().size() > 0) {
- Log.d(TAG, "Message data payload: " + remoteMessage.getData());
+ // Log.d(TAG, "Message data payload: " + remoteMessage.getData());
}
if (remoteMessage.getNotification() != null) {
- Log.d(TAG, "Message Notification Body: " + remoteMessage.getNotification().getBody());
+ // Log.d(TAG, "Message Notification Body: " + remoteMessage.getNotification().getBody());
}
}
}
diff --git a/src/android/full/com/iktwo/qutelauncher/QuteLauncherFlavored.java b/src/android/full/com/iktwo/qutelauncher/QuteLauncherFlavored.java
index ee77e34..ed84983 100755
--- a/src/android/full/com/iktwo/qutelauncher/QuteLauncherFlavored.java
+++ b/src/android/full/com/iktwo/qutelauncher/QuteLauncherFlavored.java
@@ -5,12 +5,12 @@
import com.google.firebase.analytics.FirebaseAnalytics;
public class QuteLauncherFlavored extends QuteLauncher {
- private FirebaseAnalytics mFirebaseAnalytics;
+ private FirebaseAnalytics firebaseAnalytics;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
- mFirebaseAnalytics = FirebaseAnalytics.getInstance(this);
+ firebaseAnalytics = FirebaseAnalytics.getInstance(this);
}
}
diff --git a/src/android/src/com/iktwo/qutelauncher/PackageChangedReceiver.java b/src/android/src/com/iktwo/qutelauncher/PackageChangedReceiver.java
index aa5d2f4..06c5ede 100755
--- a/src/android/src/com/iktwo/qutelauncher/PackageChangedReceiver.java
+++ b/src/android/src/com/iktwo/qutelauncher/PackageChangedReceiver.java
@@ -13,7 +13,6 @@ public void onReceive(final Context context, Intent intent) {
final String packageName = intent.getData().getSchemeSpecificPart();
if (packageName == null || packageName.length() == 0) {
- // they sent us a bad intent
return;
}
diff --git a/src/android/src/com/iktwo/qutelauncher/QuteLauncher.java b/src/android/src/com/iktwo/qutelauncher/QuteLauncher.java
index eec82f6..5893b77 100755
--- a/src/android/src/com/iktwo/qutelauncher/QuteLauncher.java
+++ b/src/android/src/com/iktwo/qutelauncher/QuteLauncher.java
@@ -88,11 +88,8 @@ public static void launchApplication(String packageName) {
}
public static byte[] getApplicationIcon(String packageName) {
- // Log.d(TAG, "TRYING TO GET ICON FOR: " + packageName);
-
Drawable icon;
- /// Get application icon
try {
ApplicationInfo app = mPm.getApplicationInfo(packageName, 0);
Resources resources = mPm.getResourcesForApplication(app);
diff --git a/src/qml/IntroView.qml b/src/qml/IntroView.qml
index 3ae8c2a..03e1928 100644
--- a/src/qml/IntroView.qml
+++ b/src/qml/IntroView.qml
@@ -110,9 +110,17 @@ FocusScope {
maximumFlickVelocity: width * 2
delegate: Item {
+ property int parentIndex: listView.currentIndex
+
height: ListView.view.height
width: ListView.view.width
+ onParentIndexChanged: {
+ if (parentIndex === index + 1) {
+ loader.item.next()
+ }
+ }
+
Loader {
id: loader
diff --git a/src/qml/components/RadioButtonStyleDefault.qml b/src/qml/components/RadioButtonStyleDefault.qml
new file mode 100644
index 0000000..eefdfb0
--- /dev/null
+++ b/src/qml/components/RadioButtonStyleDefault.qml
@@ -0,0 +1,32 @@
+import QtQuick 2.6
+import QtQuick.Controls 1.4
+import QtQuick.Controls.Styles 1.4
+import com.iktwo.qutelauncher 1.0 as QL
+
+RadioButtonStyle {
+ label: Label {
+ text: control.text
+ color: "#ffffff"
+ }
+
+ indicator: Rectangle {
+ implicitWidth: QL.ScreenValues.dp * 16
+ implicitHeight: QL.ScreenValues.dp * 16
+ radius: QL.ScreenValues.dp * 9
+ border {
+ color: control.activeFocus ? "darkblue" : "gray"
+ width: QL.ScreenValues.dp * 1
+ }
+
+ Rectangle {
+ anchors {
+ fill: parent
+ margins: QL.ScreenValues.dp * 4
+ }
+
+ visible: control.checked
+ color: "#555"
+ radius: QL.ScreenValues.dp * 9
+ }
+ }
+}
diff --git a/src/qml/components/qmldir b/src/qml/components/qmldir
index d4b5d9c..dc7ccb4 100644
--- a/src/qml/components/qmldir
+++ b/src/qml/components/qmldir
@@ -1,2 +1,3 @@
MenuItem 1.0 MenuItem.qml
+RadioButtonStyleDefault 1.0 RadioButtonStyleDefault.qml
PressAndHoldMenu 1.0 PressAndHoldMenu.qml
diff --git a/src/qml/intro/IntroEnd.qml b/src/qml/intro/IntroEnd.qml
index 67eacb4..d21f066 100644
--- a/src/qml/intro/IntroEnd.qml
+++ b/src/qml/intro/IntroEnd.qml
@@ -2,15 +2,14 @@ import QtQuick 2.6
import QtQuick.Controls 1.4
import com.iktwo.qutelauncher 1.0 as QL
-Item {
+IntroScreen {
id: root
- signal done
-
Button {
anchors.centerIn: parent
- text: "DONE"
+ text: qsTr("DONE")
+
onClicked: root.done()
}
}
diff --git a/src/qml/intro/IntroMain.qml b/src/qml/intro/IntroMain.qml
index 5d9c7a2..08060c2 100644
--- a/src/qml/intro/IntroMain.qml
+++ b/src/qml/intro/IntroMain.qml
@@ -2,7 +2,7 @@ import QtQuick 2.6
import QtQuick.Controls 1.4
import com.iktwo.qutelauncher 1.0 as QL
-Item {
+IntroScreen {
Column {
anchors {
diff --git a/src/qml/intro/IntroScreen.qml b/src/qml/intro/IntroScreen.qml
new file mode 100644
index 0000000..436b7aa
--- /dev/null
+++ b/src/qml/intro/IntroScreen.qml
@@ -0,0 +1,11 @@
+import QtQuick 2.0
+import QtQuick.Controls 1.4
+import QtQuick.Controls.Styles 1.4
+import Qt.labs.settings 1.0
+import com.iktwo.qutelauncher 1.0 as QL
+import components 1.0 as C
+
+FocusScope {
+ signal done
+ signal next
+}
diff --git a/src/qml/intro/IntroSelection.qml b/src/qml/intro/IntroSelection.qml
new file mode 100644
index 0000000..759b6c8
--- /dev/null
+++ b/src/qml/intro/IntroSelection.qml
@@ -0,0 +1,39 @@
+import QtQuick 2.0
+import QtQuick.Controls 1.4
+import QtQuick.Controls.Styles 1.4
+import Qt.labs.settings 1.0
+import com.iktwo.qutelauncher 1.0 as QL
+import components 1.0 as C
+
+IntroScreen {
+ Column {
+ anchors.centerIn: parent
+
+ Repeater {
+ id: repeater
+
+ model: ["Classic", "Tiles"]
+
+ RadioButton {
+ text: modelData
+ checked: index === 0
+
+ style: C.RadioButtonStyleDefault { }
+
+ exclusiveGroup: exclusiveGroupTheme
+ }
+ }
+ }
+
+ Settings {
+ id: settings
+
+ property string theme: repeater.model[0].toLowerCase()
+ }
+
+ ExclusiveGroup {
+ id: exclusiveGroupTheme
+ }
+
+ onNext: settings.theme = exclusiveGroupTheme.current.text.toLowerCase()
+}
diff --git a/src/qml/main.qml b/src/qml/main.qml
index a9d3f47..e769f0e 100755
--- a/src/qml/main.qml
+++ b/src/qml/main.qml
@@ -1,6 +1,7 @@
import QtQuick 2.5
import QtQuick.Controls 1.4
import QtQuick.Window 2.2
+import Qt.labs.settings 1.0
import com.iktwo.qutelauncher 1.0 as QL
import config 1.0 as Config
import debug 1.0 as D
@@ -24,6 +25,8 @@ ApplicationWindow {
property bool activeScreen: Qt.application.state === Qt.ApplicationActive
+ property string currentTheme
+
function updatePortraitMode() {
if (height >= width)
Config.Theme.portrait = true
@@ -63,50 +66,38 @@ ApplicationWindow {
Config.Theme.tablet = QL.ScreenValues.isTablet
}
- FocusScope {
- id: keyHandler
-
- height: 1
- width: 1
-
- focus: true
+ Timer {
+ interval: 550
+ running: true
- Keys.onBackPressed: {
- if (loaderMainTheme.item && loaderMainTheme.item.opened) {
- QL.Launcher.minimize()
- }
+ onTriggered: {
+ QL.Launcher.registerMethods()
+ QL.PackageManager.registerBroadcast()
}
+ }
- Keys.onUpPressed: {
- if (Qt.platform.os !== "android")
- explandableItem.open()
-
- event.accepted = false
- }
+ Component {
+ id: componentSettings
- Keys.onDownPressed: {
- if (Qt.platform.os !== "android")
- explandableItem.close()
+ Item {
- event.accepted = false
}
}
- Timer {
- interval: 550
- running: true
+ Settings {
+ property string theme
- onTriggered: {
- QL.Launcher.registerMethods()
- QL.PackageManager.registerBroadcast()
- }
+ onThemeChanged: currentTheme = theme
}
Loader {
id: loaderMainTheme
anchors.fill: parent
- source: "themes/classic/ThemeMain.qml"
+
+ focus: true
+
+ source: currentTheme !== "" ? ("themes/" + currentTheme + "/ThemeMain.qml") : undefined
}
Loader {
@@ -118,7 +109,15 @@ ApplicationWindow {
anchors.fill: parent
- sourceComponent: !QL.ApplicationInfo.hasShownInitialDialog ? introView : undefined
+ sourceComponent: !QL.ApplicationInfo.hasShownInitialDialog ? introView : componentSettings
+
+ focus: true
+
+ Keys.onBackPressed: {
+ if (loaderMainTheme.item && loaderMainTheme.item.opened) {
+ QL.Launcher.minimize()
+ }
+ }
Component {
id: introView
@@ -129,21 +128,19 @@ ApplicationWindow {
statusbarMargin: QL.ScreenValues.statusBarHeight
navbarMargin: QL.ScreenValues.navBarVisible ? QL.ScreenValues.navigationBarHeight : 0
- // enabled: false
- // visible: false
-
model: ListModel {
ListElement { name: "IntroMain.qml"; backgroundColor: "#424242" }
- ListElement { name: "IntroEnd.qml"; backgroundColor: "#2c3e50" }
+ ListElement { name: "IntroSelection.qml"; backgroundColor: "#2c3e50" }
+ ListElement { name: "IntroEnd.qml"; backgroundColor: "#424242" }
}
onDone: {
QL.ApplicationInfo.hasShownInitialDialog = true
loader.unload()
+ loader.sourceComponent = componentSettings
}
}
}
-
}
Image {
diff --git a/src/qml/themes/classic/ThemeMain.qml b/src/qml/themes/classic/ThemeMain.qml
index 6dd5022..fa50c8e 100644
--- a/src/qml/themes/classic/ThemeMain.qml
+++ b/src/qml/themes/classic/ThemeMain.qml
@@ -1,7 +1,7 @@
import QtQuick 2.0
import com.iktwo.qutelauncher 1.0 as QL
-Item {
+FocusScope {
id: root
property int navbarMargin: QL.ScreenValues.navBarVisible ? QL.ScreenValues.navigationBarHeight : 0
@@ -9,6 +9,22 @@ Item {
property bool opened: explandableItem.isOpened
+ focus: true
+
+ Keys.onUpPressed: {
+ if (Qt.platform.os !== "android")
+ explandableItem.open()
+
+ event.accepted = false
+ }
+
+ Keys.onDownPressed: {
+ if (Qt.platform.os !== "android")
+ explandableItem.close()
+
+ event.accepted = false
+ }
+
MouseArea {
anchors.fill: parent
diff --git a/src/qml/themes/tiles/ApplicationList.qml b/src/qml/themes/tiles/ApplicationList.qml
index e128e4e..2a1c0d3 100644
--- a/src/qml/themes/tiles/ApplicationList.qml
+++ b/src/qml/themes/tiles/ApplicationList.qml
@@ -29,7 +29,7 @@ Item {
bottom: parent.bottom
}
- cacheBuffer: height * 9
+ cacheBuffer: height >= 0 ? (height * 9) : root.height
maximumFlickVelocity: root.height * 2.5
section {
@@ -133,6 +133,7 @@ Item {
Image {
anchors.fill: parent
+
antialiasing: true
/// TODO: verify this
source: "qrc:/images/menu"
diff --git a/src/resources.qrc b/src/resources.qrc
index 051058f..18a71b5 100755
--- a/src/resources.qrc
+++ b/src/resources.qrc
@@ -26,6 +26,9 @@
qml/components/qmldir
qml/themes/classic/ApplicationGridMenu.qml
qml/components/MenuItem.qml
+ qml/intro/IntroSelection.qml
+ qml/components/RadioButtonStyleDefault.qml
+ qml/intro/IntroScreen.qml
resources/images/test.png