Add support for gpodder.net directory search
This commit is contained in:
parent
3e45909551
commit
e38cd8e4e6
5 changed files with 229 additions and 2 deletions
49
common/GPodderDirectorySearchModel.qml
Normal file
49
common/GPodderDirectorySearchModel.qml
Normal file
|
@ -0,0 +1,49 @@
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* gPodder QML UI Reference Implementation
|
||||||
|
* Copyright (c) 2013, 2014, Thomas Perl <m@thp.io>
|
||||||
|
*
|
||||||
|
* Permission to use, copy, modify, and/or distribute this software for any
|
||||||
|
* purpose with or without fee is hereby granted, provided that the above
|
||||||
|
* copyright notice and this permission notice appear in all copies.
|
||||||
|
*
|
||||||
|
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
|
||||||
|
* REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
|
||||||
|
* AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
|
||||||
|
* INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
|
||||||
|
* LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
|
||||||
|
* OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
|
||||||
|
* PERFORMANCE OF THIS SOFTWARE.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
import QtQuick 2.0
|
||||||
|
|
||||||
|
ListModel {
|
||||||
|
id: directorySearchModel
|
||||||
|
|
||||||
|
function search(query, callback) {
|
||||||
|
clear();
|
||||||
|
|
||||||
|
var result = new XMLHttpRequest();
|
||||||
|
result.onreadystatechange = function() {
|
||||||
|
if (result.readyState == XMLHttpRequest.DONE) {
|
||||||
|
var data = JSON.parse(result.responseText);
|
||||||
|
data.sort(function (a, b) {
|
||||||
|
// Sort by subscriber count, descending
|
||||||
|
return b.subscribers - a.subscribers;
|
||||||
|
});
|
||||||
|
for (var i=0; i<data.length; i++) {
|
||||||
|
directorySearchModel.append(data[i]);
|
||||||
|
}
|
||||||
|
if (callback !== undefined) {
|
||||||
|
callback();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
result.open('GET', 'http://gpodder.net/search.json?q=' + query);
|
||||||
|
result.send();
|
||||||
|
}
|
||||||
|
}
|
90
touch/Directory.qml
Normal file
90
touch/Directory.qml
Normal file
|
@ -0,0 +1,90 @@
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* gPodder QML UI Reference Implementation
|
||||||
|
* Copyright (c) 2013, Thomas Perl <m@thp.io>
|
||||||
|
*
|
||||||
|
* Permission to use, copy, modify, and/or distribute this software for any
|
||||||
|
* purpose with or without fee is hereby granted, provided that the above
|
||||||
|
* copyright notice and this permission notice appear in all copies.
|
||||||
|
*
|
||||||
|
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
|
||||||
|
* REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
|
||||||
|
* AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
|
||||||
|
* INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
|
||||||
|
* LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
|
||||||
|
* OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
|
||||||
|
* PERFORMANCE OF THIS SOFTWARE.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
import QtQuick 2.0
|
||||||
|
|
||||||
|
import 'common'
|
||||||
|
|
||||||
|
SlidePage {
|
||||||
|
id: directory
|
||||||
|
|
||||||
|
ListView {
|
||||||
|
anchors.fill: parent
|
||||||
|
|
||||||
|
model: GPodderDirectorySearchModel { id: directorySearchModel }
|
||||||
|
|
||||||
|
header: Column {
|
||||||
|
anchors {
|
||||||
|
left: parent.left
|
||||||
|
right: parent.right
|
||||||
|
}
|
||||||
|
|
||||||
|
SlidePageHeader { title: 'Search gpodder.net' }
|
||||||
|
|
||||||
|
Column {
|
||||||
|
spacing: 0.5 * 30 * pgst.scalef
|
||||||
|
|
||||||
|
anchors {
|
||||||
|
left: parent.left
|
||||||
|
right: parent.right
|
||||||
|
margins: 30 * pgst.scalef
|
||||||
|
}
|
||||||
|
|
||||||
|
PTextField {
|
||||||
|
id: input
|
||||||
|
width: parent.width
|
||||||
|
placeholderText: 'Search term'
|
||||||
|
}
|
||||||
|
|
||||||
|
ButtonArea {
|
||||||
|
id: button
|
||||||
|
width: input.width
|
||||||
|
height: input.height
|
||||||
|
|
||||||
|
PLabel {
|
||||||
|
anchors.centerIn: parent
|
||||||
|
text: 'Search'
|
||||||
|
}
|
||||||
|
|
||||||
|
onClicked: {
|
||||||
|
loading.visible = true;
|
||||||
|
directorySearchModel.search(input.text, function() {
|
||||||
|
loading.visible = false;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
delegate: DirectoryItem {
|
||||||
|
onClicked: {
|
||||||
|
py.call('main.subscribe', [url], function () {
|
||||||
|
directory.closePage();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
PBusyIndicator {
|
||||||
|
id: loading
|
||||||
|
visible: false
|
||||||
|
anchors.centerIn: parent
|
||||||
|
}
|
||||||
|
}
|
75
touch/DirectoryItem.qml
Normal file
75
touch/DirectoryItem.qml
Normal file
|
@ -0,0 +1,75 @@
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* gPodder QML UI Reference Implementation
|
||||||
|
* Copyright (c) 2013, 2014, Thomas Perl <m@thp.io>
|
||||||
|
*
|
||||||
|
* Permission to use, copy, modify, and/or distribute this software for any
|
||||||
|
* purpose with or without fee is hereby granted, provided that the above
|
||||||
|
* copyright notice and this permission notice appear in all copies.
|
||||||
|
*
|
||||||
|
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
|
||||||
|
* REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
|
||||||
|
* AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
|
||||||
|
* INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
|
||||||
|
* LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
|
||||||
|
* OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
|
||||||
|
* PERFORMANCE OF THIS SOFTWARE.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
import QtQuick 2.0
|
||||||
|
|
||||||
|
ButtonArea {
|
||||||
|
id: podcastItem
|
||||||
|
|
||||||
|
transparent: true
|
||||||
|
|
||||||
|
height: 100 * pgst.scalef
|
||||||
|
anchors {
|
||||||
|
left: parent.left
|
||||||
|
right: parent.right
|
||||||
|
}
|
||||||
|
|
||||||
|
Image {
|
||||||
|
id: cover
|
||||||
|
|
||||||
|
anchors {
|
||||||
|
left: parent.left
|
||||||
|
leftMargin: 10 * pgst.scalef
|
||||||
|
verticalCenter: parent.verticalCenter
|
||||||
|
}
|
||||||
|
|
||||||
|
sourceSize.width: width
|
||||||
|
sourceSize.height: height
|
||||||
|
|
||||||
|
width: 80 * pgst.scalef
|
||||||
|
height: 80 * pgst.scalef
|
||||||
|
|
||||||
|
source: scaled_logo_url
|
||||||
|
}
|
||||||
|
|
||||||
|
PLabel {
|
||||||
|
anchors {
|
||||||
|
left: cover.right
|
||||||
|
leftMargin: 10 * pgst.scalef
|
||||||
|
rightMargin: 10 * pgst.scalef
|
||||||
|
right: subcount.left
|
||||||
|
verticalCenter: parent.verticalCenter
|
||||||
|
}
|
||||||
|
|
||||||
|
elide: Text.ElideRight
|
||||||
|
text: title
|
||||||
|
}
|
||||||
|
|
||||||
|
PLabel {
|
||||||
|
id: subcount
|
||||||
|
anchors {
|
||||||
|
right: parent.right
|
||||||
|
rightMargin: 10 * pgst.scalef
|
||||||
|
verticalCenter: parent.verticalCenter
|
||||||
|
}
|
||||||
|
|
||||||
|
text: subscribers
|
||||||
|
}
|
||||||
|
}
|
|
@ -204,8 +204,8 @@ SlidePage {
|
||||||
StartPageButton {
|
StartPageButton {
|
||||||
id: recommendationsPane
|
id: recommendationsPane
|
||||||
|
|
||||||
title: 'Recommendations'
|
title: 'gpodder.net'
|
||||||
onClicked: pgst.loadPage('Settings.qml');
|
onClicked: pgst.loadPage('Directory.qml');
|
||||||
|
|
||||||
Row {
|
Row {
|
||||||
anchors {
|
anchors {
|
||||||
|
|
|
@ -55,6 +55,19 @@ SlidePage {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ButtonArea {
|
||||||
|
id: directory
|
||||||
|
width: input.width
|
||||||
|
height: input.height
|
||||||
|
|
||||||
|
PLabel {
|
||||||
|
anchors.centerIn: parent
|
||||||
|
text: 'gpodder.net'
|
||||||
|
}
|
||||||
|
|
||||||
|
onClicked: pgst.loadPage('Directory.qml');
|
||||||
|
}
|
||||||
|
|
||||||
PBusyIndicator {
|
PBusyIndicator {
|
||||||
id: loading
|
id: loading
|
||||||
visible: false
|
visible: false
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue