/** * * 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 SlidePage { id: podcastsPage hasPull: true PullMenu { PullMenuItem { text: 'Now Playing' icon: Icons.play onClicked: { pgst.loadPage('PlayerPage.qml'); podcastsPage.unPull(); } } PullMenuItem { text: 'Refresh feeds' icon: Icons.reload onClicked: { podcastsPage.unPull(); py.call('main.check_for_episodes'); } } PullMenuItem { text: 'Subscribe' icon: Icons.plus onClicked: { pgst.loadPage('Subscribe.qml'); podcastsPage.unPull(); } } } PListView { id: podcastList title: 'Subscriptions' section.property: 'section' section.delegate: SectionHeader { text: section } model: podcastListModel delegate: PodcastItem { onClicked: pgst.loadPage('EpisodesPage.qml', {'podcast_id': id, 'title': title}); } } }