diff --git a/dat/harbour-muchkin.desktop b/dat/harbour-muchkin.desktop index 5b076a3..970a07e 100644 --- a/dat/harbour-muchkin.desktop +++ b/dat/harbour-muchkin.desktop @@ -1,6 +1,6 @@ [Desktop Entry] Type=Application X-Nemo-Application-Type=silica-qt5 -Name=harbour-muchkin -Icon=icon-launcher-component-gallery +Name=Muchkin +Icon= Exec=sailfish-qml harbour-muchkin diff --git a/icon.png b/icon.png new file mode 100644 index 0000000..94cb1f1 Binary files /dev/null and b/icon.png differ diff --git a/qml/About.qml b/qml/About.qml new file mode 100644 index 0000000..55c0602 --- /dev/null +++ b/qml/About.qml @@ -0,0 +1,48 @@ +import QtQuick 2.0 +import Sailfish.Silica 1.0 + +Page { + PageHeader { + id: header + title: "About" + } + + Label { + anchors.top: header.bottom + anchors.horizontalCenter: parent.horizontalCenter + width: parent.width + text: "this application was created by\nkirbylife\nunder the GPL V2.0 license,\nanyone is free to view\nthe code and modify it." + truncationMode: TruncationMode.Elide + } + + Button { + id: btnCode + anchors.bottom: btnTwitter.top + anchors.horizontalCenter: parent.horizontalCenter + anchors.bottomMargin: 50 + text: "Code" + onClicked: { + Qt.openUrlExternally("https://gitlab.com/kirbylife/harbour-muchkin") + } + } + Button { + id: btnTwitter + anchors.bottom: btnDonate.top + anchors.horizontalCenter: parent.horizontalCenter + anchors.bottomMargin: 50 + text: "Twitter" + onClicked: { + Qt.openUrlExternally("https://twitter.com/kirbylife") + } + } + Button { + id: btnDonate + anchors.bottom: parent.bottom + anchors.horizontalCenter: parent.horizontalCenter + anchors.bottomMargin: 50 + text: "Donate" + onClicked: { + Qt.openUrlExternally("https://www.paypal.com/paypalme/kirbylife") + } + } +} diff --git a/qml/Icon.qml b/qml/Icon.qml index 730e500..14fb4f8 100644 --- a/qml/Icon.qml +++ b/qml/Icon.qml @@ -62,7 +62,6 @@ Page { anchors.top: header.bottom width: parent.width height: width - // source: attrs.Icon } Button { @@ -75,7 +74,9 @@ Page { py.importModule("main", function(){ py.call("main.save_icon", [iconEditor.attrs], function(result){ if(result){ - pageStack.navigateBack(PageStackAction.Animated) + pageStack.pop() + pageStack.completeAnimation() + pageStack.currentPage.mainList.reload() } }) }) diff --git a/qml/Main.qml b/qml/Main.qml index 0fce714..b17f8f3 100644 --- a/qml/Main.qml +++ b/qml/Main.qml @@ -3,55 +3,74 @@ import Sailfish.Silica 1.0 import io.thp.pyotherside 1.3 Page { - id: mainList + SilicaFlickable { + id: mainList + anchors.fill: parent - PageHeader { - id: header - width: parent.width - title: "Select the webapp to unify" - } - SilicaGridView { - anchors.top: header.bottom - width: parent.width - height: parent.height - cellWidth: width / 4 - cellHeight: cellWidth - - model: ListModel { - id: appsList + PullDownMenu { + MenuItem { + text: "About" + onClicked: pageStack.push(Qt.resolvedUrl("About.qml")) + } } - delegate: GridItem { - menu: Component { - ContextMenu { - MenuItem { - text: attrs.Name + PageHeader { + id: header + width: parent.width + title: "Select the webapp to unify" + } + + SilicaGridView { + + anchors.top: header.bottom + width: parent.width + height: parent.height + cellWidth: width / 4 + cellHeight: cellWidth + + model: ListModel { + id: appsList + } + + delegate: GridItem { + menu: Component { + ContextMenu { + MenuItem { + text: attrs.Name + } } } - } - Image { - anchors.centerIn: parent - source: attrs.Icon - } + Image { + anchors.centerIn: parent + source: attrs.Icon + } - onClicked: { - pageStack.push(Qt.resolvedUrl("Icon.qml"), {attrs: attrs}); + onClicked: { + pageStack.push(Qt.resolvedUrl("Icon.qml"), {attrs: attrs}); + } } } - } - Python { - id: py - Component.onCompleted: { - py.addImportPath(Qt.resolvedUrl("../src")); + function reload(){ + appsList.clear() + py.addImportPath(Qt.resolvedUrl("../src")) py.importModule("main", function(){ py.call("main.get_web_icons", [], function(apps){ for(var i=0; i < apps.length; i++){ - appsList.append({attrs: apps[i]}); + appsList.append({attrs: apps[i]}) } }) }) } + + Python { + id: py + + Component.onCompleted: { + mainList.reload() + } + } } + }