/** * * gPodder QML UI Reference Implementation * Copyright (c) 2013, Thomas Perl * * 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' import 'common/util.js' as Util import 'icons/icons.js' as Icons import 'common/constants.js' as Constants SlidePage { id: page canClose: false hasMenuButton: true menuButtonLabel: 'Settings' onMenuButtonClicked: { pgst.showSelection([ { label: 'Check for new episodes', callback: function () { py.call('main.check_for_episodes'); } }, { label: 'Filter episodes', callback: function () { pgst.loadPage('EpisodeQueryPage.qml'); } }, { label: 'Settings', callback: function () { pgst.loadPage('SettingsPage.qml'); }, }, { label: 'Add new podcast', callback: function () { var ctx = { py: py }; pgst.loadPage('TextInputDialog.qml', { buttonText: 'Subscribe', placeholderText: 'Feed URL', pasteOnLoad: true, callback: function (url) { ctx.py.call('main.subscribe', [url]); } }); }, }, { label: 'Add from OPML', callback: function () { var ctx = { py: py }; pgst.loadPage('TextInputDialog.qml', { buttonText: 'Subscribe', placeholderText: 'OPML URL', pasteOnLoad: true, callback: function (url) { ctx.py.call('main.import_opml', [url]); } }); }, }, { label: 'Discover new podcasts', callback: function () { py.call('main.get_directory_providers', [], function (result) { var items = []; for (var i=0; i