From 26b506ed62751f004f3db1708d019d761a7eb5da Mon Sep 17 00:00:00 2001 From: Xilin Jia <6257601+XilinJia@users.noreply.github.com> Date: Thu, 11 Apr 2024 20:31:36 +0000 Subject: [PATCH] 4.7.0 commit --- Licenses_and_permissions.md | 7 +- README.md | 49 +++-- app/build.gradle | 4 +- .../java/ac/test/podcini/EspressoTestUtils.kt | 2 +- .../service/download/HttpDownloaderTest.kt | 4 +- .../PlaybackServiceMediaPlayerTest.kt | 2 +- .../PlaybackServiceTaskManagerTest.kt | 6 +- app/src/main/AndroidManifest.xml | 176 +++++++++--------- app/src/main/assets/html-export-template.html | 2 +- .../mdiq/podcini/feed/parser/FeedHandler.kt | 4 +- .../podcini/{ui => }/glide/ApGlideModule.kt | 2 +- .../{ui => }/glide/ApOkHttpUrlLoader.kt | 4 +- .../{ui => }/glide/AudioCoverFetcher.kt | 2 +- .../{ui => }/glide/ChapterImageModelLoader.kt | 4 +- .../{ui => }/glide/FastBlurTransformation.kt | 2 +- .../GenerativePlaceholderImageModelLoader.kt | 2 +- .../{ui => }/glide/MetadataRetrieverLoader.kt | 2 +- .../{ui => }/glide/NoHttpStringLoader.kt | 2 +- .../glide/ResizingOkHttpStreamFetcher.kt | 2 +- .../ac/mdiq/podcini/net/common/UrlChecker.kt | 22 +-- .../net/discovery/FyydPodcastSearcher.kt | 2 +- .../net/discovery/GpodnetPodcastSearcher.kt | 2 +- .../net/discovery/ItunesPodcastSearcher.kt | 2 +- .../net/discovery/ItunesTopListLoader.kt | 2 +- .../discovery/PodcastIndexPodcastSearcher.kt | 2 +- .../podcini/net/download/FeedUpdateManager.kt | 4 +- .../podcini/net/download/MediaSizeLoader.kt | 2 +- .../service/BasicAuthorizationInterceptor.kt | 4 +- .../service}/DefaultDownloaderFactory.kt | 2 +- .../service}/DownloadRequestCreator.kt | 2 +- .../service}/DownloadServiceInterfaceImpl.kt | 2 +- .../download/service}/Downloader.kt | 2 +- .../download/service}/DownloaderFactory.kt | 2 +- .../service}/EpisodeDownloadWorker.kt | 12 +- .../download}/service/FeedUpdateWorker.kt | 8 +- .../service}/HttpCredentialEncoder.kt | 2 +- .../download/service}/HttpDownloader.kt | 9 +- .../service}/NewEpisodesNotification.kt | 8 +- .../download/service}/PodciniHttpClient.kt | 4 +- .../download}/service/UserAgentInterceptor.kt | 2 +- .../service}/handler/FeedParserTask.kt | 2 +- .../download/service}/handler/FeedSyncTask.kt | 2 +- .../handler/MediaDownloadedHandler.kt | 2 +- .../ac/mdiq/podcini/net/sync/SyncService.kt | 4 +- .../podcini/playback/PlaybackController.kt | 18 +- .../playback/PlaybackServiceStarter.kt | 8 +- .../base/PlaybackServiceMediaPlayer.kt | 3 +- .../service}/ExoPlayerWrapper.kt | 6 +- .../service}/LocalPSMP.kt | 21 ++- .../service}/PlaybackService.kt | 159 ++++++++-------- .../service}/PlaybackServiceInterface.kt | 2 +- .../PlaybackServiceNotificationBuilder.kt | 8 +- .../service}/PlaybackServiceStateManager.kt | 2 +- .../service}/PlaybackServiceTaskManager.kt | 16 +- .../service}/PlaybackVolumeUpdater.kt | 2 +- .../service/QuickSettingsTileService.kt | 3 +- .../service}/ShakeListener.kt | 4 +- .../preferences/MasterSwitchPreference.kt | 2 +- .../preferences/PlaybackPreferences.kt | 5 +- .../podcini/preferences/PreferenceUpgrader.kt | 4 +- .../AutoDownloadPreferencesFragment.kt | 2 +- .../DownloadsPreferencesFragment.kt | 2 +- .../ImportExportPreferencesFragment.kt | 2 +- .../fragments}/MainPreferencesFragment.kt | 55 +++--- .../NotificationPreferencesFragment.kt | 4 +- .../fragments}/PlaybackPreferencesFragment.kt | 2 +- .../fragments}/SwipePreferencesFragment.kt | 2 +- .../UserInterfacePreferencesFragment.kt | 3 +- .../fragments}/about/AboutFragment.kt | 2 +- .../about/ContributorsPagerFragment.kt | 2 +- .../fragments}/about/DevelopersFragment.kt | 2 +- .../fragments}/about/LicensesFragment.kt | 2 +- .../fragments}/about/SpecialThanksFragment.kt | 2 +- .../fragments}/about/TranslatorsFragment.kt | 2 +- .../fragments}/dialog/PreferenceListDialog.kt | 2 +- .../dialog/PreferenceSwitchDialog.kt | 2 +- .../GpodderAuthenticationFragment.kt | 4 +- .../NextcloudAuthenticationFragment.kt | 4 +- .../SynchronizationPreferencesFragment.kt | 2 +- .../podcini/receiver/MediaButtonReceiver.kt | 3 +- .../java/ac/mdiq/podcini/storage/DBReader.kt | 11 +- .../java/ac/mdiq/podcini/storage/DBTasks.kt | 10 +- .../java/ac/mdiq/podcini/storage/DBWriter.kt | 4 +- .../podcini/storage/database/PodDBAdapter.kt | 3 +- .../EpisodeMultiSelectActionHandler.kt | 2 +- .../actions/FeedMultiSelectActionHandler.kt | 9 +- .../CancelDownloadActionButton.kt | 2 +- .../actionbutton/DeleteActionButton.kt | 2 +- .../actionbutton/DownloadActionButton.kt | 2 +- .../actionbutton/ItemActionButton.kt | 2 +- .../actionbutton/MarkAsPlayedActionButton.kt | 2 +- .../actionbutton/PauseActionButton.kt | 2 +- .../actionbutton/PlayActionButton.kt | 8 +- .../actionbutton/PlayLocalActionButton.kt | 4 +- .../actionbutton/StreamActionButton.kt | 16 +- .../actionbutton/VisitWebsiteActionButton.kt | 2 +- .../menuhandler/FeedItemMenuHandler.kt | 4 +- .../menuhandler/FeedMenuHandler.kt | 2 +- .../menuhandler/MenuItemUtils.kt | 2 +- .../swipeactions/AddToQueueSwipeAction.kt | 2 +- .../swipeactions/DeleteSwipeAction.kt | 2 +- .../swipeactions/MarkFavoriteSwipeAction.kt | 2 +- .../swipeactions/NoActionSwipeAction.kt | 4 +- .../RemoveFromHistorySwipeAction.kt | 2 +- .../RemoveFromQueueSwipeAction.kt | 2 +- .../ShowFirstSwipeDialogAction.kt | 2 +- .../swipeactions/StartDownloadSwipeAction.kt | 4 +- .../swipeactions/SwipeAction.kt | 2 +- .../swipeactions/SwipeActions.kt | 4 +- .../TogglePlaybackStateSwipeAction.kt | 4 +- .../mdiq/podcini/ui/activity/MainActivity.kt | 15 +- .../podcini/ui/activity/OpmlImportActivity.kt | 3 +- .../podcini/ui/activity/PreferenceActivity.kt | 6 +- .../ui/activity/VideoplayerActivity.kt | 16 +- .../appstartintent/MainActivityStarter.kt | 9 +- .../PlaybackSpeedActivityStarter.kt | 4 +- .../VideoPlayerActivityStarter.kt | 4 +- .../podcini/ui/adapter/ChaptersListAdapter.kt | 2 +- .../podcini/ui/adapter/DownloadLogAdapter.kt | 4 +- .../ui/adapter/EpisodeItemListAdapter.kt | 16 +- .../ui/adapter/HorizontalFeedListAdapter.kt | 2 +- .../mdiq/podcini/ui/adapter/NavListAdapter.kt | 10 +- .../ui/adapter/QueueRecyclerAdapter.kt | 2 +- .../ui/adapter/SubscriptionsAdapter.kt | 12 +- .../ac/mdiq/podcini/ui/dialog/ProxyDialog.kt | 8 +- .../podcini/ui/dialog/SleepTimerDialog.kt | 4 +- .../podcini/ui/dialog/SwipeActionsDialog.kt | 10 +- .../mdiq/podcini/ui/dialog/TimeRangeDialog.kt | 2 +- .../podcini/ui/dialog/VariableSpeedDialog.kt | 2 +- .../ui/fragment/AudioPlayerFragment.kt | 52 ++++-- .../ui/fragment/BaseEpisodesListFragment.kt | 10 +- .../podcini/ui/fragment/ChaptersFragment.kt | 2 +- .../podcini/ui/fragment/DownloadsFragment.kt | 12 +- .../ui/fragment/EpisodeInfoFragment.kt | 12 +- .../ui/fragment/EpisodesListFragment.kt | 10 - .../podcini/ui/fragment/FeedInfoFragment.kt | 2 +- .../ui/fragment/FeedItemlistFragment.kt | 12 +- .../podcini/ui/fragment/NavDrawerFragment.kt | 35 ++-- .../ui/fragment/OnlineFeedViewFragment.kt | 10 +- .../PagedToolbarFragment.kt | 2 +- .../ui/fragment/PlaybackHistoryFragment.kt | 2 +- .../ui/fragment/PlayerDetailsFragment.kt | 74 +++++--- .../mdiq/podcini/ui/fragment/QueueFragment.kt | 11 +- .../podcini/ui/fragment/SearchFragment.kt | 10 +- .../ui/fragment/SubscriptionFragment.kt | 6 +- .../ui/statistics/StatisticsFragment.kt | 2 +- .../feed/FeedStatisticsDialogFragment.kt | 2 +- .../ui/statistics/years/BarChartView.kt | 2 +- .../ui/{common => utils}/ThemeUtils.kt | 2 +- .../ac/mdiq/podcini/ui/view/ChapterSeekBar.kt | 2 +- .../{common => view}/CircularProgressBar.kt | 2 +- .../PlaybackSpeedIndicatorView.kt | 2 +- .../mdiq/podcini/ui/view/ShownotesWebView.kt | 10 +- .../ui/{common => view}/SquareImageView.kt | 2 +- .../ui/{common => view}/TriangleLabelView.kt | 2 +- .../ui/{common => view}/WrappingGridView.kt | 2 +- .../viewholder/DownloadLogItemViewHolder.kt | 4 +- .../view/viewholder/EpisodeItemViewHolder.kt | 12 +- .../mdiq/podcini/ui/widget/WidgetUpdater.kt | 6 +- .../java/ac/mdiq/podcini/util/ChapterUtils.kt | 2 +- .../java/ac/mdiq/podcini/util/FeedItemUtil.kt | 3 +- .../java/ac/mdiq/podcini/util/NetworkUtils.kt | 25 ++- .../ac/mdiq/podcini/util/PlaybackStatus.kt | 2 +- .../java/ac/mdiq/podcini/util/ShareUtils.kt | 15 +- .../java/ac/mdiq/podcini/util/StackTrace.kt | 8 + .../podcini/util/config/ClientConfigurator.kt | 6 +- .../event/playback}/BufferUpdateEvent.kt | 2 +- .../event/playback}/PlaybackHistoryEvent.kt | 2 +- .../event/playback}/PlaybackPositionEvent.kt | 2 +- .../event/playback}/PlaybackServiceEvent.kt | 2 +- .../event/playback}/SleepTimerUpdatedEvent.kt | 2 +- .../event/playback}/SpeedChangedEvent.kt | 2 +- .../util/event/playback/StartPlayEvent.kt | 5 + .../main/res/layout/episode_info_fragment.xml | 2 +- .../main/res/layout/horizontal_feed_item.xml | 2 +- .../res/layout/internal_player_fragment.xml | 2 +- .../main/res/layout/quick_feed_discovery.xml | 2 +- .../res/layout/quick_feed_discovery_item.xml | 2 +- app/src/main/res/layout/secondary_action.xml | 2 +- app/src/main/res/layout/subscription_item.xml | 2 +- .../ac/mdiq/podcini/playback/cast/CastPsmp.kt | 25 ++- .../playback/cast/CastStateListener.kt | 2 +- .../mdiq/podcini/net/common/UrlCheckerTest.kt | 20 +- .../playback/PlaybackVolumeUpdaterTest.kt | 1 + changelog.md | 16 +- .../android/en-US/changelogs/3020128.txt | 12 ++ 186 files changed, 759 insertions(+), 722 deletions(-) rename app/src/main/java/ac/mdiq/podcini/{ui => }/glide/ApGlideModule.kt (98%) rename app/src/main/java/ac/mdiq/podcini/{ui => }/glide/ApOkHttpUrlLoader.kt (97%) rename app/src/main/java/ac/mdiq/podcini/{ui => }/glide/AudioCoverFetcher.kt (97%) rename app/src/main/java/ac/mdiq/podcini/{ui => }/glide/ChapterImageModelLoader.kt (97%) rename app/src/main/java/ac/mdiq/podcini/{ui => }/glide/FastBlurTransformation.kt (99%) rename app/src/main/java/ac/mdiq/podcini/{ui => }/glide/GenerativePlaceholderImageModelLoader.kt (99%) rename app/src/main/java/ac/mdiq/podcini/{ui => }/glide/MetadataRetrieverLoader.kt (97%) rename app/src/main/java/ac/mdiq/podcini/{ui => }/glide/NoHttpStringLoader.kt (97%) rename app/src/main/java/ac/mdiq/podcini/{ui => }/glide/ResizingOkHttpStreamFetcher.kt (99%) rename app/src/main/java/ac/mdiq/podcini/{ => net/download}/service/BasicAuthorizationInterceptor.kt (96%) rename app/src/main/java/ac/mdiq/podcini/{service/download => net/download/service}/DefaultDownloaderFactory.kt (92%) rename app/src/main/java/ac/mdiq/podcini/{service/download => net/download/service}/DownloadRequestCreator.kt (98%) rename app/src/main/java/ac/mdiq/podcini/{service/download => net/download/service}/DownloadServiceInterfaceImpl.kt (98%) rename app/src/main/java/ac/mdiq/podcini/{service/download => net/download/service}/Downloader.kt (97%) rename app/src/main/java/ac/mdiq/podcini/{service/download => net/download/service}/DownloaderFactory.kt (77%) rename app/src/main/java/ac/mdiq/podcini/{service/download => net/download/service}/EpisodeDownloadWorker.kt (95%) rename app/src/main/java/ac/mdiq/podcini/{ => net/download}/service/FeedUpdateWorker.kt (96%) rename app/src/main/java/ac/mdiq/podcini/{service/download => net/download/service}/HttpCredentialEncoder.kt (92%) rename app/src/main/java/ac/mdiq/podcini/{service/download => net/download/service}/HttpDownloader.kt (98%) rename app/src/main/java/ac/mdiq/podcini/{service/download => net/download/service}/NewEpisodesNotification.kt (96%) rename app/src/main/java/ac/mdiq/podcini/{service/download => net/download/service}/PodciniHttpClient.kt (95%) rename app/src/main/java/ac/mdiq/podcini/{ => net/download}/service/UserAgentInterceptor.kt (90%) rename app/src/main/java/ac/mdiq/podcini/{service/download => net/download/service}/handler/FeedParserTask.kt (98%) rename app/src/main/java/ac/mdiq/podcini/{service/download => net/download/service}/handler/FeedSyncTask.kt (94%) rename app/src/main/java/ac/mdiq/podcini/{service/download => net/download/service}/handler/MediaDownloadedHandler.kt (98%) rename app/src/main/java/ac/mdiq/podcini/{service/playback => playback/service}/ExoPlayerWrapper.kt (98%) rename app/src/main/java/ac/mdiq/podcini/{service/playback => playback/service}/LocalPSMP.kt (97%) rename app/src/main/java/ac/mdiq/podcini/{service/playback => playback/service}/PlaybackService.kt (95%) rename app/src/main/java/ac/mdiq/podcini/{service/playback => playback/service}/PlaybackServiceInterface.kt (96%) rename app/src/main/java/ac/mdiq/podcini/{service/playback => playback/service}/PlaybackServiceNotificationBuilder.kt (97%) rename app/src/main/java/ac/mdiq/podcini/{service/playback => playback/service}/PlaybackServiceStateManager.kt (97%) rename app/src/main/java/ac/mdiq/podcini/{service/playback => playback/service}/PlaybackServiceTaskManager.kt (96%) rename app/src/main/java/ac/mdiq/podcini/{service/playback => playback/service}/PlaybackVolumeUpdater.kt (97%) rename app/src/main/java/ac/mdiq/podcini/{ => playback}/service/QuickSettingsTileService.kt (95%) rename app/src/main/java/ac/mdiq/podcini/{service/playback => playback/service}/ShakeListener.kt (94%) rename app/src/main/java/ac/mdiq/podcini/{ui/fragment/preferences => preferences/fragments}/AutoDownloadPreferencesFragment.kt (99%) rename app/src/main/java/ac/mdiq/podcini/{ui/fragment/preferences => preferences/fragments}/DownloadsPreferencesFragment.kt (98%) rename app/src/main/java/ac/mdiq/podcini/{ui/fragment/preferences => preferences/fragments}/ImportExportPreferencesFragment.kt (99%) rename app/src/main/java/ac/mdiq/podcini/{ui/fragment/preferences => preferences/fragments}/MainPreferencesFragment.kt (88%) rename app/src/main/java/ac/mdiq/podcini/{ui/fragment/preferences => preferences/fragments}/NotificationPreferencesFragment.kt (81%) rename app/src/main/java/ac/mdiq/podcini/{ui/fragment/preferences => preferences/fragments}/PlaybackPreferencesFragment.kt (99%) rename app/src/main/java/ac/mdiq/podcini/{ui/fragment/preferences => preferences/fragments}/SwipePreferencesFragment.kt (98%) rename app/src/main/java/ac/mdiq/podcini/{ui/fragment/preferences => preferences/fragments}/UserInterfacePreferencesFragment.kt (98%) rename app/src/main/java/ac/mdiq/podcini/{ui/fragment/preferences => preferences/fragments}/about/AboutFragment.kt (98%) rename app/src/main/java/ac/mdiq/podcini/{ui/fragment/preferences => preferences/fragments}/about/ContributorsPagerFragment.kt (97%) rename app/src/main/java/ac/mdiq/podcini/{ui/fragment/preferences => preferences/fragments}/about/DevelopersFragment.kt (97%) rename app/src/main/java/ac/mdiq/podcini/{ui/fragment/preferences => preferences/fragments}/about/LicensesFragment.kt (98%) rename app/src/main/java/ac/mdiq/podcini/{ui/fragment/preferences => preferences/fragments}/about/SpecialThanksFragment.kt (97%) rename app/src/main/java/ac/mdiq/podcini/{ui/fragment/preferences => preferences/fragments}/about/TranslatorsFragment.kt (97%) rename app/src/main/java/ac/mdiq/podcini/{ui/fragment/preferences => preferences/fragments}/dialog/PreferenceListDialog.kt (96%) rename app/src/main/java/ac/mdiq/podcini/{ui/fragment/preferences => preferences/fragments}/dialog/PreferenceSwitchDialog.kt (96%) rename app/src/main/java/ac/mdiq/podcini/{ui/fragment/preferences => preferences/fragments}/synchronization/GpodderAuthenticationFragment.kt (98%) rename app/src/main/java/ac/mdiq/podcini/{ui/fragment/preferences => preferences/fragments}/synchronization/NextcloudAuthenticationFragment.kt (96%) rename app/src/main/java/ac/mdiq/podcini/{ui/fragment/preferences => preferences/fragments}/synchronization/SynchronizationPreferencesFragment.kt (99%) rename app/src/main/java/ac/mdiq/podcini/ui/{fragment => }/actions/EpisodeMultiSelectActionHandler.kt (99%) rename app/src/main/java/ac/mdiq/podcini/ui/{fragment => }/actions/FeedMultiSelectActionHandler.kt (95%) rename app/src/main/java/ac/mdiq/podcini/ui/{adapter => actions}/actionbutton/CancelDownloadActionButton.kt (95%) rename app/src/main/java/ac/mdiq/podcini/ui/{adapter => actions}/actionbutton/DeleteActionButton.kt (95%) rename app/src/main/java/ac/mdiq/podcini/ui/{adapter => actions}/actionbutton/DownloadActionButton.kt (98%) rename app/src/main/java/ac/mdiq/podcini/ui/{adapter => actions}/actionbutton/ItemActionButton.kt (97%) rename app/src/main/java/ac/mdiq/podcini/ui/{adapter => actions}/actionbutton/MarkAsPlayedActionButton.kt (94%) rename app/src/main/java/ac/mdiq/podcini/ui/{adapter => actions}/actionbutton/PauseActionButton.kt (94%) rename app/src/main/java/ac/mdiq/podcini/ui/{adapter => actions}/actionbutton/PlayActionButton.kt (80%) rename app/src/main/java/ac/mdiq/podcini/ui/{adapter => actions}/actionbutton/PlayLocalActionButton.kt (88%) rename app/src/main/java/ac/mdiq/podcini/ui/{adapter => actions}/actionbutton/StreamActionButton.kt (75%) rename app/src/main/java/ac/mdiq/podcini/ui/{adapter => actions}/actionbutton/VisitWebsiteActionButton.kt (93%) rename app/src/main/java/ac/mdiq/podcini/ui/{ => actions}/menuhandler/FeedItemMenuHandler.kt (99%) rename app/src/main/java/ac/mdiq/podcini/ui/{ => actions}/menuhandler/FeedMenuHandler.kt (96%) rename app/src/main/java/ac/mdiq/podcini/ui/{ => actions}/menuhandler/MenuItemUtils.kt (95%) rename app/src/main/java/ac/mdiq/podcini/ui/{fragment => actions}/swipeactions/AddToQueueSwipeAction.kt (96%) rename app/src/main/java/ac/mdiq/podcini/ui/{fragment => actions}/swipeactions/DeleteSwipeAction.kt (96%) rename app/src/main/java/ac/mdiq/podcini/ui/{fragment => actions}/swipeactions/MarkFavoriteSwipeAction.kt (95%) rename app/src/main/java/ac/mdiq/podcini/ui/{fragment => actions}/swipeactions/NoActionSwipeAction.kt (83%) rename app/src/main/java/ac/mdiq/podcini/ui/{fragment => actions}/swipeactions/RemoveFromHistorySwipeAction.kt (97%) rename app/src/main/java/ac/mdiq/podcini/ui/{fragment => actions}/swipeactions/RemoveFromQueueSwipeAction.kt (97%) rename app/src/main/java/ac/mdiq/podcini/ui/{fragment => actions}/swipeactions/ShowFirstSwipeDialogAction.kt (94%) rename app/src/main/java/ac/mdiq/podcini/ui/{fragment => actions}/swipeactions/StartDownloadSwipeAction.kt (89%) rename app/src/main/java/ac/mdiq/podcini/ui/{fragment => actions}/swipeactions/SwipeAction.kt (95%) rename app/src/main/java/ac/mdiq/podcini/ui/{fragment => actions}/swipeactions/SwipeActions.kt (98%) rename app/src/main/java/ac/mdiq/podcini/ui/{fragment => actions}/swipeactions/TogglePlaybackStateSwipeAction.kt (90%) rename app/src/main/java/ac/mdiq/podcini/ui/{ => activity}/appstartintent/MainActivityStarter.kt (90%) rename app/src/main/java/ac/mdiq/podcini/ui/{ => activity}/appstartintent/PlaybackSpeedActivityStarter.kt (83%) rename app/src/main/java/ac/mdiq/podcini/ui/{ => activity}/appstartintent/VideoPlayerActivityStarter.kt (83%) rename app/src/main/java/ac/mdiq/podcini/ui/{common => fragment}/PagedToolbarFragment.kt (98%) rename app/src/main/java/ac/mdiq/podcini/ui/{common => utils}/ThemeUtils.kt (96%) rename app/src/main/java/ac/mdiq/podcini/ui/{common => view}/CircularProgressBar.kt (98%) rename app/src/main/java/ac/mdiq/podcini/ui/{common => view}/PlaybackSpeedIndicatorView.kt (99%) rename app/src/main/java/ac/mdiq/podcini/ui/{common => view}/SquareImageView.kt (98%) rename app/src/main/java/ac/mdiq/podcini/ui/{common => view}/TriangleLabelView.kt (99%) rename app/src/main/java/ac/mdiq/podcini/ui/{common => view}/WrappingGridView.kt (96%) create mode 100644 app/src/main/java/ac/mdiq/podcini/util/StackTrace.kt rename app/src/main/java/ac/mdiq/podcini/{playback/event => util/event/playback}/BufferUpdateEvent.kt (94%) rename app/src/main/java/ac/mdiq/podcini/{playback/event => util/event/playback}/PlaybackHistoryEvent.kt (86%) rename app/src/main/java/ac/mdiq/podcini/{playback/event => util/event/playback}/PlaybackPositionEvent.kt (66%) rename app/src/main/java/ac/mdiq/podcini/{playback/event => util/event/playback}/PlaybackServiceEvent.kt (76%) rename app/src/main/java/ac/mdiq/podcini/{playback/event => util/event/playback}/SleepTimerUpdatedEvent.kt (95%) rename app/src/main/java/ac/mdiq/podcini/{playback/event => util/event/playback}/SpeedChangedEvent.kt (56%) create mode 100644 app/src/main/java/ac/mdiq/podcini/util/event/playback/StartPlayEvent.kt create mode 100644 fastlane/metadata/android/en-US/changelogs/3020128.txt diff --git a/Licenses_and_permissions.md b/Licenses_and_permissions.md index 82b54380..562d6492 100644 --- a/Licenses_and_permissions.md +++ b/Licenses_and_permissions.md @@ -5,7 +5,7 @@ [Androidx](https://github.com/androidx/androidx/blob/androidx-main/LICENSE.txt) Apache License 2.0 -[](https://github.com/material-components/material-components-android/blob/master/LICENSE) +[com.google.android.material](https://github.com/material-components/material-components-android/blob/master/LICENSE) Apache License 2.0 [JetBrains Kotlin](https://github.com/JetBrains/kotlin/blob/master/license/LICENSE.txt) Apache License Version 2.0 @@ -20,8 +20,9 @@ Apache License 2.0 [com.squareup.okhttp3](https://github.com/square/okhttp/blob/master/LICENSE.txt) Apache License 2.0 -[com.squareup.okio](https://github.com/square/okio/blob/master/LICENSE.txt) Apache License 2.0 - + + [org.greenrobot:eventbus](https://github.com/greenrobot/EventBus/blob/master/LICENSE) Apache License 2.0 [io.reactivex.rxjava2](https://github.com/ReactiveX/RxJava/blob/3.x/LICENSE) Apache License 2.0 diff --git a/README.md b/README.md index 3a529e7e..bea65148 100644 --- a/README.md +++ b/README.md @@ -20,21 +20,13 @@ Some drastic changes are made in the project since version 4.0. There is now a w Even so, the database remains backward compatible, and AntennaPod's db can be easily imported. -Other notable features and changes include: +## Notable new features/enhancements + +### Player * A more convenient player control displayed on all pages * A revamped and more efficient expanded player view showing episode description on the front * External player class is merged into the player -* New and efficient ways of click and long-click operations on lists: - * click on title area opens the podcast/episode - * long-press on title area automatically enters in selection mode - * options to select all above or below are shown action bar together with Select All - * operations are only on the selected (single or multiple) -* A new share notes menu option on various episode views -* List info is shown in Queue and Downloads views -* Left and right swipe actions on lists now have telltales and can be configured on the spot -* Played episodes have clearer markings -* Sort dialog no longer dims the main view * Play speed setting has been straightened up, three speed can be set separately or combined: current audio, podcast, and global. The order of precedence is in that same order. * Added preference "Fast Forward Speed" under "Playback" in settings with default value of 0.0, dialog allows setting a float number (capped between 0.0 and 10.0) * The "Skip to next episode" button on the player @@ -48,19 +40,46 @@ Other notable features and changes include: * the Play button on the player * by default, it behaves the same as usual * if the user customize "Fallback speed" to a value greater than 0.1, long-press the button during play enters the fallback mode and plays at the set fallback speed, single tap exits the fallback mode +* Various efficiency improvements, including removal of + * redundant media loadings and ui updates + * frequent list search during audio play +* streamed media somewhat equivalent to downloaded media + * enabled episode description on player detailed view + * enabled intro- and end- skipping + * mark as played when finished + * streamed media is added to queue and is resumed after restart + +### Podcast/Episode list + +* New and efficient ways of click and long-click operations on lists: + * click on title area opens the podcast/episode + * long-press on title area automatically enters in selection mode + * options to select all above or below are shown action bar together with Select All + * operations are only on the selected (single or multiple) +* List info is shown in Queue and Downloads views +* Left and right swipe actions on lists now have telltales and can be configured on the spot +* Played episodes have clearer markings +* Sort dialog no longer dims the main view * Subscriptions view has sorting by "Unread publication date" + +### Podcast/Episode + +* A new share notes menu option on various episode views * Feed info view offers a link for direct search of feeds related to author + +### Online feed + * More info about feeds are shown in the online search view * Ability to open podcast from webpage address * Online feed info display is handled in similar ways as any local feed, and offers options to subscribe or view episodes * Online feed episodes can be freely played (streamed) without a subscription -* usesCleartextTraffic (for non-secure content transmission) is now disabled in the project -* Various efficiency improvements, including removal of - * redundant media loadings and ui updates - * frequent list search during audio play * externally shared feed opens in the new online feed view fragment * Youtube channels are accepted from external share or paste of address in podcast search view, and can be subscribed as a normal podcast, though video play is handled externally +### Security + +* usesCleartextTraffic (for non-secure content transmission) is now disabled in the project + For more details of the changes, see the [Changelog](changelog.md) ## Screenshots diff --git a/app/build.gradle b/app/build.gradle index 6e764fc7..4772c734 100644 --- a/app/build.gradle +++ b/app/build.gradle @@ -149,8 +149,8 @@ android { // Version code schema (not used): // "1.2.3-beta4" -> 1020304 // "1.2.3" -> 1020395 - versionCode 3020127 - versionName "4.6.2" + versionCode 3020128 + versionName "4.7.0" def commit = "" try { diff --git a/app/src/androidTest/java/ac/test/podcini/EspressoTestUtils.kt b/app/src/androidTest/java/ac/test/podcini/EspressoTestUtils.kt index 744c725f..b51d5a97 100644 --- a/app/src/androidTest/java/ac/test/podcini/EspressoTestUtils.kt +++ b/app/src/androidTest/java/ac/test/podcini/EspressoTestUtils.kt @@ -18,7 +18,7 @@ import androidx.test.espresso.util.TreeIterables import androidx.test.platform.app.InstrumentationRegistry import ac.mdiq.podcini.R import ac.mdiq.podcini.ui.activity.MainActivity -import ac.mdiq.podcini.service.playback.PlaybackService +import ac.mdiq.podcini.playback.service.PlaybackService import ac.mdiq.podcini.ui.dialog.RatingDialog import ac.mdiq.podcini.ui.dialog.RatingDialog.saveRated import ac.mdiq.podcini.ui.fragment.NavDrawerFragment diff --git a/app/src/androidTest/java/ac/test/podcini/service/download/HttpDownloaderTest.kt b/app/src/androidTest/java/ac/test/podcini/service/download/HttpDownloaderTest.kt index df93c467..85d743b5 100644 --- a/app/src/androidTest/java/ac/test/podcini/service/download/HttpDownloaderTest.kt +++ b/app/src/androidTest/java/ac/test/podcini/service/download/HttpDownloaderTest.kt @@ -3,8 +3,8 @@ package de.test.podcini.service.download import android.util.Log import androidx.test.filters.LargeTest import androidx.test.platform.app.InstrumentationRegistry -import ac.mdiq.podcini.service.download.Downloader -import ac.mdiq.podcini.service.download.HttpDownloader +import ac.mdiq.podcini.net.download.service.Downloader +import ac.mdiq.podcini.net.download.service.HttpDownloader import ac.mdiq.podcini.storage.model.download.DownloadError import ac.mdiq.podcini.storage.model.feed.FeedFile import ac.mdiq.podcini.net.download.serviceinterface.DownloadRequest diff --git a/app/src/androidTest/java/ac/test/podcini/service/playback/PlaybackServiceMediaPlayerTest.kt b/app/src/androidTest/java/ac/test/podcini/service/playback/PlaybackServiceMediaPlayerTest.kt index 6710b1a5..1592b0fb 100644 --- a/app/src/androidTest/java/ac/test/podcini/service/playback/PlaybackServiceMediaPlayerTest.kt +++ b/app/src/androidTest/java/ac/test/podcini/service/playback/PlaybackServiceMediaPlayerTest.kt @@ -3,7 +3,7 @@ package de.test.podcini.service.playback import androidx.test.annotation.UiThreadTest import androidx.test.filters.MediumTest import androidx.test.platform.app.InstrumentationRegistry -import ac.mdiq.podcini.service.playback.LocalPSMP +import ac.mdiq.podcini.playback.service.LocalPSMP import ac.mdiq.podcini.storage.model.feed.* import ac.mdiq.podcini.storage.model.playback.Playable import ac.mdiq.podcini.playback.base.PlaybackServiceMediaPlayer diff --git a/app/src/androidTest/java/ac/test/podcini/service/playback/PlaybackServiceTaskManagerTest.kt b/app/src/androidTest/java/ac/test/podcini/service/playback/PlaybackServiceTaskManagerTest.kt index 28cdce3b..4fcd9eac 100644 --- a/app/src/androidTest/java/ac/test/podcini/service/playback/PlaybackServiceTaskManagerTest.kt +++ b/app/src/androidTest/java/ac/test/podcini/service/playback/PlaybackServiceTaskManagerTest.kt @@ -5,10 +5,10 @@ import androidx.test.filters.LargeTest import androidx.test.platform.app.InstrumentationRegistry import ac.mdiq.podcini.preferences.SleepTimerPreferences.setShakeToReset import ac.mdiq.podcini.preferences.SleepTimerPreferences.setVibrate -import ac.mdiq.podcini.service.playback.PlaybackServiceTaskManager -import ac.mdiq.podcini.service.playback.PlaybackServiceTaskManager.PSTMCallback +import ac.mdiq.podcini.playback.service.PlaybackServiceTaskManager +import ac.mdiq.podcini.playback.service.PlaybackServiceTaskManager.PSTMCallback import ac.mdiq.podcini.ui.widget.WidgetUpdater.WidgetState -import ac.mdiq.podcini.playback.event.SleepTimerUpdatedEvent +import ac.mdiq.podcini.util.event.playback.SleepTimerUpdatedEvent import ac.mdiq.podcini.storage.model.feed.Feed import ac.mdiq.podcini.storage.model.feed.FeedItem import ac.mdiq.podcini.storage.model.playback.Playable diff --git a/app/src/main/AndroidManifest.xml b/app/src/main/AndroidManifest.xml index 2a1d8bcc..a2b9ef2e 100644 --- a/app/src/main/AndroidManifest.xml +++ b/app/src/main/AndroidManifest.xml @@ -49,7 +49,7 @@ android:allowAudioPlaybackCapture="true" android:networkSecurityConfig="@xml/network_security_config"> - - - - - - - - - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + @@ -272,39 +272,36 @@ android:value="ac.mdiq.podcini.ui.activity.MainActivity"/> - - - - - - - - - - - - - + + + + + + + + + + + + - - - - - - - - - - - - - + + + + + + + + + + + + - @@ -319,7 +316,6 @@ - @@ -330,50 +326,46 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + - - diff --git a/app/src/main/assets/html-export-template.html b/app/src/main/assets/html-export-template.html index d4357772..215eb18a 100644 --- a/app/src/main/assets/html-export-template.html +++ b/app/src/main/assets/html-export-template.html @@ -101,7 +101,7 @@ - +

Podcini {TITLE}

    {FEEDS} diff --git a/app/src/main/java/ac/mdiq/podcini/feed/parser/FeedHandler.kt b/app/src/main/java/ac/mdiq/podcini/feed/parser/FeedHandler.kt index 10dce72a..b7be5752 100644 --- a/app/src/main/java/ac/mdiq/podcini/feed/parser/FeedHandler.kt +++ b/app/src/main/java/ac/mdiq/podcini/feed/parser/FeedHandler.kt @@ -34,8 +34,6 @@ class FeedHandler { saxParser.parse(inputSource, handler) inputStreamReader.close() } - return FeedHandlerResult(handler.state.feed, - handler.state.alternateUrls, - handler.state.redirectUrl ?: "") + return FeedHandlerResult(handler.state.feed, handler.state.alternateUrls, handler.state.redirectUrl ?: "") } } diff --git a/app/src/main/java/ac/mdiq/podcini/ui/glide/ApGlideModule.kt b/app/src/main/java/ac/mdiq/podcini/glide/ApGlideModule.kt similarity index 98% rename from app/src/main/java/ac/mdiq/podcini/ui/glide/ApGlideModule.kt rename to app/src/main/java/ac/mdiq/podcini/glide/ApGlideModule.kt index 1b21a1b2..cbaac5ec 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/glide/ApGlideModule.kt +++ b/app/src/main/java/ac/mdiq/podcini/glide/ApGlideModule.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.glide +package ac.mdiq.podcini.glide import ac.mdiq.podcini.storage.model.feed.EmbeddedChapterImage import android.annotation.SuppressLint diff --git a/app/src/main/java/ac/mdiq/podcini/ui/glide/ApOkHttpUrlLoader.kt b/app/src/main/java/ac/mdiq/podcini/glide/ApOkHttpUrlLoader.kt similarity index 97% rename from app/src/main/java/ac/mdiq/podcini/ui/glide/ApOkHttpUrlLoader.kt rename to app/src/main/java/ac/mdiq/podcini/glide/ApOkHttpUrlLoader.kt index 0d3b70cc..93231ead 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/glide/ApOkHttpUrlLoader.kt +++ b/app/src/main/java/ac/mdiq/podcini/glide/ApOkHttpUrlLoader.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.glide +package ac.mdiq.podcini.glide import android.content.ContentResolver import com.bumptech.glide.load.Options @@ -7,7 +7,7 @@ import com.bumptech.glide.load.model.ModelLoader import com.bumptech.glide.load.model.ModelLoaderFactory import com.bumptech.glide.load.model.MultiModelLoaderFactory import com.bumptech.glide.signature.ObjectKey -import ac.mdiq.podcini.service.download.PodciniHttpClient.newBuilder +import ac.mdiq.podcini.net.download.service.PodciniHttpClient.newBuilder import ac.mdiq.podcini.util.NetworkUtils.isImageAllowed import ac.mdiq.podcini.storage.model.feed.Feed import ac.mdiq.podcini.storage.model.feed.FeedMedia diff --git a/app/src/main/java/ac/mdiq/podcini/ui/glide/AudioCoverFetcher.kt b/app/src/main/java/ac/mdiq/podcini/glide/AudioCoverFetcher.kt similarity index 97% rename from app/src/main/java/ac/mdiq/podcini/ui/glide/AudioCoverFetcher.kt rename to app/src/main/java/ac/mdiq/podcini/glide/AudioCoverFetcher.kt index 0e23ebaa..2ba34a30 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/glide/AudioCoverFetcher.kt +++ b/app/src/main/java/ac/mdiq/podcini/glide/AudioCoverFetcher.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.glide +package ac.mdiq.podcini.glide import android.content.ContentResolver import android.content.Context diff --git a/app/src/main/java/ac/mdiq/podcini/ui/glide/ChapterImageModelLoader.kt b/app/src/main/java/ac/mdiq/podcini/glide/ChapterImageModelLoader.kt similarity index 97% rename from app/src/main/java/ac/mdiq/podcini/ui/glide/ChapterImageModelLoader.kt rename to app/src/main/java/ac/mdiq/podcini/glide/ChapterImageModelLoader.kt index 7af03fdc..41a24fdb 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/glide/ChapterImageModelLoader.kt +++ b/app/src/main/java/ac/mdiq/podcini/glide/ChapterImageModelLoader.kt @@ -1,6 +1,6 @@ -package ac.mdiq.podcini.ui.glide +package ac.mdiq.podcini.glide -import ac.mdiq.podcini.service.download.PodciniHttpClient.getHttpClient +import ac.mdiq.podcini.net.download.service.PodciniHttpClient.getHttpClient import ac.mdiq.podcini.storage.model.feed.EmbeddedChapterImage import com.bumptech.glide.Priority import com.bumptech.glide.load.DataSource diff --git a/app/src/main/java/ac/mdiq/podcini/ui/glide/FastBlurTransformation.kt b/app/src/main/java/ac/mdiq/podcini/glide/FastBlurTransformation.kt similarity index 99% rename from app/src/main/java/ac/mdiq/podcini/ui/glide/FastBlurTransformation.kt rename to app/src/main/java/ac/mdiq/podcini/glide/FastBlurTransformation.kt index f0b4f50f..d22a3246 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/glide/FastBlurTransformation.kt +++ b/app/src/main/java/ac/mdiq/podcini/glide/FastBlurTransformation.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.glide +package ac.mdiq.podcini.glide import android.graphics.Bitmap import android.media.ThumbnailUtils diff --git a/app/src/main/java/ac/mdiq/podcini/ui/glide/GenerativePlaceholderImageModelLoader.kt b/app/src/main/java/ac/mdiq/podcini/glide/GenerativePlaceholderImageModelLoader.kt similarity index 99% rename from app/src/main/java/ac/mdiq/podcini/ui/glide/GenerativePlaceholderImageModelLoader.kt rename to app/src/main/java/ac/mdiq/podcini/glide/GenerativePlaceholderImageModelLoader.kt index b3281ce6..8c89d942 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/glide/GenerativePlaceholderImageModelLoader.kt +++ b/app/src/main/java/ac/mdiq/podcini/glide/GenerativePlaceholderImageModelLoader.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.glide +package ac.mdiq.podcini.glide import android.graphics.* import com.bumptech.glide.Priority diff --git a/app/src/main/java/ac/mdiq/podcini/ui/glide/MetadataRetrieverLoader.kt b/app/src/main/java/ac/mdiq/podcini/glide/MetadataRetrieverLoader.kt similarity index 97% rename from app/src/main/java/ac/mdiq/podcini/ui/glide/MetadataRetrieverLoader.kt rename to app/src/main/java/ac/mdiq/podcini/glide/MetadataRetrieverLoader.kt index 34037f91..acc02b1f 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/glide/MetadataRetrieverLoader.kt +++ b/app/src/main/java/ac/mdiq/podcini/glide/MetadataRetrieverLoader.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.glide +package ac.mdiq.podcini.glide import android.content.Context import com.bumptech.glide.load.Options diff --git a/app/src/main/java/ac/mdiq/podcini/ui/glide/NoHttpStringLoader.kt b/app/src/main/java/ac/mdiq/podcini/glide/NoHttpStringLoader.kt similarity index 97% rename from app/src/main/java/ac/mdiq/podcini/ui/glide/NoHttpStringLoader.kt rename to app/src/main/java/ac/mdiq/podcini/glide/NoHttpStringLoader.kt index 888c4db4..f772f771 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/glide/NoHttpStringLoader.kt +++ b/app/src/main/java/ac/mdiq/podcini/glide/NoHttpStringLoader.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.glide +package ac.mdiq.podcini.glide import android.net.Uri import com.bumptech.glide.load.model.ModelLoader diff --git a/app/src/main/java/ac/mdiq/podcini/ui/glide/ResizingOkHttpStreamFetcher.kt b/app/src/main/java/ac/mdiq/podcini/glide/ResizingOkHttpStreamFetcher.kt similarity index 99% rename from app/src/main/java/ac/mdiq/podcini/ui/glide/ResizingOkHttpStreamFetcher.kt rename to app/src/main/java/ac/mdiq/podcini/glide/ResizingOkHttpStreamFetcher.kt index 27530486..387f3fb8 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/glide/ResizingOkHttpStreamFetcher.kt +++ b/app/src/main/java/ac/mdiq/podcini/glide/ResizingOkHttpStreamFetcher.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.glide +package ac.mdiq.podcini.glide import android.graphics.Bitmap.CompressFormat import android.graphics.BitmapFactory diff --git a/app/src/main/java/ac/mdiq/podcini/net/common/UrlChecker.kt b/app/src/main/java/ac/mdiq/podcini/net/common/UrlChecker.kt index 76671a09..d680b77b 100644 --- a/app/src/main/java/ac/mdiq/podcini/net/common/UrlChecker.kt +++ b/app/src/main/java/ac/mdiq/podcini/net/common/UrlChecker.kt @@ -3,8 +3,6 @@ package ac.mdiq.podcini.net.common import android.net.Uri import android.util.Log import okhttp3.HttpUrl.Companion.toHttpUrlOrNull -import java.io.UnsupportedEncodingException -import java.net.URLDecoder /** * Provides methods for checking and editing a URL. @@ -16,7 +14,7 @@ object UrlChecker { private const val TAG = "UrlChecker" private const val AP_SUBSCRIBE = "podcini-subscribe://" - private const val AP_SUBSCRIBE_DEEPLINK = "podcini.org/deeplink/subscribe" +// private const val AP_SUBSCRIBE_DEEPLINK = "podcini.org/deeplink/subscribe" /** * Checks if URL is valid and modifies it if necessary. @@ -50,15 +48,15 @@ object UrlChecker { Log.d(TAG, "Removing podcini-subscribe://") return prepareUrl(url.substring(AP_SUBSCRIBE.length)) } - lowerCaseUrl.contains(AP_SUBSCRIBE_DEEPLINK) -> { - Log.d(TAG, "Removing $AP_SUBSCRIBE_DEEPLINK") - val removedWebsite = url.substring(url.indexOf("?url=") + "?url=".length) - return try { - prepareUrl(URLDecoder.decode(removedWebsite, "UTF-8")) - } catch (e: UnsupportedEncodingException) { - prepareUrl(removedWebsite) - } - } +// lowerCaseUrl.contains(AP_SUBSCRIBE_DEEPLINK) -> { +// Log.d(TAG, "Removing $AP_SUBSCRIBE_DEEPLINK") +// val removedWebsite = url.substring(url.indexOf("?url=") + "?url=".length) +// return try { +// prepareUrl(URLDecoder.decode(removedWebsite, "UTF-8")) +// } catch (e: UnsupportedEncodingException) { +// prepareUrl(removedWebsite) +// } +// } !(lowerCaseUrl.startsWith("http://") || lowerCaseUrl.startsWith("https://")) -> { Log.d(TAG, "Adding http:// at the beginning of the URL") return "http://$url" diff --git a/app/src/main/java/ac/mdiq/podcini/net/discovery/FyydPodcastSearcher.kt b/app/src/main/java/ac/mdiq/podcini/net/discovery/FyydPodcastSearcher.kt index 50d5c5e0..861091de 100644 --- a/app/src/main/java/ac/mdiq/podcini/net/discovery/FyydPodcastSearcher.kt +++ b/app/src/main/java/ac/mdiq/podcini/net/discovery/FyydPodcastSearcher.kt @@ -1,6 +1,6 @@ package ac.mdiq.podcini.net.discovery -import ac.mdiq.podcini.service.download.PodciniHttpClient.getHttpClient +import ac.mdiq.podcini.net.download.service.PodciniHttpClient.getHttpClient import de.mfietz.fyydlin.FyydClient import io.reactivex.Single import io.reactivex.SingleEmitter diff --git a/app/src/main/java/ac/mdiq/podcini/net/discovery/GpodnetPodcastSearcher.kt b/app/src/main/java/ac/mdiq/podcini/net/discovery/GpodnetPodcastSearcher.kt index 170c16a3..e873feb8 100644 --- a/app/src/main/java/ac/mdiq/podcini/net/discovery/GpodnetPodcastSearcher.kt +++ b/app/src/main/java/ac/mdiq/podcini/net/discovery/GpodnetPodcastSearcher.kt @@ -1,6 +1,6 @@ package ac.mdiq.podcini.net.discovery -import ac.mdiq.podcini.service.download.PodciniHttpClient.getHttpClient +import ac.mdiq.podcini.net.download.service.PodciniHttpClient.getHttpClient import ac.mdiq.podcini.net.sync.SynchronizationCredentials import ac.mdiq.podcini.net.sync.gpoddernet.GpodnetService import ac.mdiq.podcini.net.sync.gpoddernet.GpodnetServiceException diff --git a/app/src/main/java/ac/mdiq/podcini/net/discovery/ItunesPodcastSearcher.kt b/app/src/main/java/ac/mdiq/podcini/net/discovery/ItunesPodcastSearcher.kt index 3f62ddd6..889dfcb2 100644 --- a/app/src/main/java/ac/mdiq/podcini/net/discovery/ItunesPodcastSearcher.kt +++ b/app/src/main/java/ac/mdiq/podcini/net/discovery/ItunesPodcastSearcher.kt @@ -1,7 +1,7 @@ package ac.mdiq.podcini.net.discovery import ac.mdiq.podcini.feed.FeedUrlNotFoundException -import ac.mdiq.podcini.service.download.PodciniHttpClient.getHttpClient +import ac.mdiq.podcini.net.download.service.PodciniHttpClient.getHttpClient import io.reactivex.Single import io.reactivex.SingleEmitter import io.reactivex.android.schedulers.AndroidSchedulers diff --git a/app/src/main/java/ac/mdiq/podcini/net/discovery/ItunesTopListLoader.kt b/app/src/main/java/ac/mdiq/podcini/net/discovery/ItunesTopListLoader.kt index 2d70377e..d8e8af46 100644 --- a/app/src/main/java/ac/mdiq/podcini/net/discovery/ItunesTopListLoader.kt +++ b/app/src/main/java/ac/mdiq/podcini/net/discovery/ItunesTopListLoader.kt @@ -4,7 +4,7 @@ package ac.mdiq.podcini.net.discovery import ac.mdiq.podcini.R import android.content.Context import android.util.Log -import ac.mdiq.podcini.service.download.PodciniHttpClient.getHttpClient +import ac.mdiq.podcini.net.download.service.PodciniHttpClient.getHttpClient import ac.mdiq.podcini.storage.model.feed.Feed import okhttp3.CacheControl import okhttp3.OkHttpClient diff --git a/app/src/main/java/ac/mdiq/podcini/net/discovery/PodcastIndexPodcastSearcher.kt b/app/src/main/java/ac/mdiq/podcini/net/discovery/PodcastIndexPodcastSearcher.kt index 5036f0d0..14597ef4 100644 --- a/app/src/main/java/ac/mdiq/podcini/net/discovery/PodcastIndexPodcastSearcher.kt +++ b/app/src/main/java/ac/mdiq/podcini/net/discovery/PodcastIndexPodcastSearcher.kt @@ -1,7 +1,7 @@ package ac.mdiq.podcini.net.discovery import ac.mdiq.podcini.BuildConfig -import ac.mdiq.podcini.service.download.PodciniHttpClient.getHttpClient +import ac.mdiq.podcini.net.download.service.PodciniHttpClient.getHttpClient import ac.mdiq.podcini.util.config.ClientConfig import io.reactivex.Single import io.reactivex.SingleEmitter diff --git a/app/src/main/java/ac/mdiq/podcini/net/download/FeedUpdateManager.kt b/app/src/main/java/ac/mdiq/podcini/net/download/FeedUpdateManager.kt index 6c7acd23..f641d2f0 100644 --- a/app/src/main/java/ac/mdiq/podcini/net/download/FeedUpdateManager.kt +++ b/app/src/main/java/ac/mdiq/podcini/net/download/FeedUpdateManager.kt @@ -7,7 +7,7 @@ import android.util.Log import androidx.work.* import androidx.work.Constraints.Builder import com.google.android.material.dialog.MaterialAlertDialogBuilder -import ac.mdiq.podcini.service.FeedUpdateWorker +import ac.mdiq.podcini.net.download.service.FeedUpdateWorker import ac.mdiq.podcini.util.NetworkUtils.isFeedRefreshAllowed import ac.mdiq.podcini.util.NetworkUtils.isNetworkRestricted import ac.mdiq.podcini.util.NetworkUtils.isVpnOverWifi @@ -20,7 +20,7 @@ import java.util.concurrent.TimeUnit object FeedUpdateManager { const val WORK_TAG_FEED_UPDATE: String = "feedUpdate" - private const val WORK_ID_FEED_UPDATE = "ac.mdiq.podcini.service.FeedUpdateWorker" + private const val WORK_ID_FEED_UPDATE = "ac.mdiq.podcini.service.download.FeedUpdateWorker" private const val WORK_ID_FEED_UPDATE_MANUAL = "feedUpdateManual" const val EXTRA_FEED_ID: String = "feed_id" const val EXTRA_NEXT_PAGE: String = "next_page" diff --git a/app/src/main/java/ac/mdiq/podcini/net/download/MediaSizeLoader.kt b/app/src/main/java/ac/mdiq/podcini/net/download/MediaSizeLoader.kt index 938dacae..fc69facc 100644 --- a/app/src/main/java/ac/mdiq/podcini/net/download/MediaSizeLoader.kt +++ b/app/src/main/java/ac/mdiq/podcini/net/download/MediaSizeLoader.kt @@ -2,7 +2,7 @@ package ac.mdiq.podcini.net.download import android.util.Log import androidx.media3.common.util.UnstableApi -import ac.mdiq.podcini.service.download.PodciniHttpClient.getHttpClient +import ac.mdiq.podcini.net.download.service.PodciniHttpClient.getHttpClient import ac.mdiq.podcini.storage.DBWriter import ac.mdiq.podcini.util.NetworkUtils.isEpisodeHeadDownloadAllowed import ac.mdiq.podcini.storage.model.feed.FeedMedia diff --git a/app/src/main/java/ac/mdiq/podcini/service/BasicAuthorizationInterceptor.kt b/app/src/main/java/ac/mdiq/podcini/net/download/service/BasicAuthorizationInterceptor.kt similarity index 96% rename from app/src/main/java/ac/mdiq/podcini/service/BasicAuthorizationInterceptor.kt rename to app/src/main/java/ac/mdiq/podcini/net/download/service/BasicAuthorizationInterceptor.kt index 77ee94ea..7734e718 100644 --- a/app/src/main/java/ac/mdiq/podcini/service/BasicAuthorizationInterceptor.kt +++ b/app/src/main/java/ac/mdiq/podcini/net/download/service/BasicAuthorizationInterceptor.kt @@ -1,8 +1,8 @@ -package ac.mdiq.podcini.service +package ac.mdiq.podcini.net.download.service import android.text.TextUtils import android.util.Log -import ac.mdiq.podcini.service.download.HttpCredentialEncoder.encode +import ac.mdiq.podcini.net.download.service.HttpCredentialEncoder.encode import ac.mdiq.podcini.storage.DBReader import ac.mdiq.podcini.util.URIUtil import ac.mdiq.podcini.net.download.serviceinterface.DownloadRequest diff --git a/app/src/main/java/ac/mdiq/podcini/service/download/DefaultDownloaderFactory.kt b/app/src/main/java/ac/mdiq/podcini/net/download/service/DefaultDownloaderFactory.kt similarity index 92% rename from app/src/main/java/ac/mdiq/podcini/service/download/DefaultDownloaderFactory.kt rename to app/src/main/java/ac/mdiq/podcini/net/download/service/DefaultDownloaderFactory.kt index bf78fd0d..39b41f90 100644 --- a/app/src/main/java/ac/mdiq/podcini/service/download/DefaultDownloaderFactory.kt +++ b/app/src/main/java/ac/mdiq/podcini/net/download/service/DefaultDownloaderFactory.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.service.download +package ac.mdiq.podcini.net.download.service import android.util.Log import android.webkit.URLUtil diff --git a/app/src/main/java/ac/mdiq/podcini/service/download/DownloadRequestCreator.kt b/app/src/main/java/ac/mdiq/podcini/net/download/service/DownloadRequestCreator.kt similarity index 98% rename from app/src/main/java/ac/mdiq/podcini/service/download/DownloadRequestCreator.kt rename to app/src/main/java/ac/mdiq/podcini/net/download/service/DownloadRequestCreator.kt index 74bb12c0..e1d8d816 100644 --- a/app/src/main/java/ac/mdiq/podcini/service/download/DownloadRequestCreator.kt +++ b/app/src/main/java/ac/mdiq/podcini/net/download/service/DownloadRequestCreator.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.service.download +package ac.mdiq.podcini.net.download.service import android.util.Log import android.webkit.URLUtil diff --git a/app/src/main/java/ac/mdiq/podcini/service/download/DownloadServiceInterfaceImpl.kt b/app/src/main/java/ac/mdiq/podcini/net/download/service/DownloadServiceInterfaceImpl.kt similarity index 98% rename from app/src/main/java/ac/mdiq/podcini/service/download/DownloadServiceInterfaceImpl.kt rename to app/src/main/java/ac/mdiq/podcini/net/download/service/DownloadServiceInterfaceImpl.kt index 70cb55ed..696a2cfc 100644 --- a/app/src/main/java/ac/mdiq/podcini/service/download/DownloadServiceInterfaceImpl.kt +++ b/app/src/main/java/ac/mdiq/podcini/net/download/service/DownloadServiceInterfaceImpl.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.service.download +package ac.mdiq.podcini.net.download.service import android.content.Context import androidx.work.* diff --git a/app/src/main/java/ac/mdiq/podcini/service/download/Downloader.kt b/app/src/main/java/ac/mdiq/podcini/net/download/service/Downloader.kt similarity index 97% rename from app/src/main/java/ac/mdiq/podcini/service/download/Downloader.kt rename to app/src/main/java/ac/mdiq/podcini/net/download/service/Downloader.kt index 85a0e2dc..4a3dcb99 100644 --- a/app/src/main/java/ac/mdiq/podcini/service/download/Downloader.kt +++ b/app/src/main/java/ac/mdiq/podcini/net/download/service/Downloader.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.service.download +package ac.mdiq.podcini.net.download.service import ac.mdiq.podcini.R import ac.mdiq.podcini.net.download.serviceinterface.DownloadRequest diff --git a/app/src/main/java/ac/mdiq/podcini/service/download/DownloaderFactory.kt b/app/src/main/java/ac/mdiq/podcini/net/download/service/DownloaderFactory.kt similarity index 77% rename from app/src/main/java/ac/mdiq/podcini/service/download/DownloaderFactory.kt rename to app/src/main/java/ac/mdiq/podcini/net/download/service/DownloaderFactory.kt index 317c6bf5..67cbd5be 100644 --- a/app/src/main/java/ac/mdiq/podcini/service/download/DownloaderFactory.kt +++ b/app/src/main/java/ac/mdiq/podcini/net/download/service/DownloaderFactory.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.service.download +package ac.mdiq.podcini.net.download.service import ac.mdiq.podcini.net.download.serviceinterface.DownloadRequest diff --git a/app/src/main/java/ac/mdiq/podcini/service/download/EpisodeDownloadWorker.kt b/app/src/main/java/ac/mdiq/podcini/net/download/service/EpisodeDownloadWorker.kt similarity index 95% rename from app/src/main/java/ac/mdiq/podcini/service/download/EpisodeDownloadWorker.kt rename to app/src/main/java/ac/mdiq/podcini/net/download/service/EpisodeDownloadWorker.kt index c3cde141..8a0605ab 100644 --- a/app/src/main/java/ac/mdiq/podcini/service/download/EpisodeDownloadWorker.kt +++ b/app/src/main/java/ac/mdiq/podcini/net/download/service/EpisodeDownloadWorker.kt @@ -1,15 +1,15 @@ -package ac.mdiq.podcini.service.download +package ac.mdiq.podcini.net.download.service import ac.mdiq.podcini.R import ac.mdiq.podcini.net.download.serviceinterface.DownloadRequest import ac.mdiq.podcini.net.download.serviceinterface.DownloadServiceInterface -import ac.mdiq.podcini.service.download.DownloadRequestCreator.create -import ac.mdiq.podcini.service.download.handler.MediaDownloadedHandler +import ac.mdiq.podcini.net.download.service.DownloadRequestCreator.create +import ac.mdiq.podcini.net.download.service.handler.MediaDownloadedHandler import ac.mdiq.podcini.storage.DBReader import ac.mdiq.podcini.storage.DBWriter import ac.mdiq.podcini.storage.model.download.DownloadError import ac.mdiq.podcini.storage.model.feed.FeedMedia -import ac.mdiq.podcini.ui.appstartintent.MainActivityStarter +import ac.mdiq.podcini.ui.activity.appstartintent.MainActivityStarter import ac.mdiq.podcini.ui.utils.NotificationUtils import ac.mdiq.podcini.util.config.ClientConfigurator import ac.mdiq.podcini.util.event.MessageEvent @@ -205,13 +205,13 @@ class EpisodeDownloadWorker(context: Context, params: WorkerParameters) : Worker private fun getDownloadLogsIntent(context: Context): PendingIntent { val intent = MainActivityStarter(context).withDownloadLogsOpen().getIntent() return PendingIntent.getActivity(context, R.id.pending_intent_download_service_report, intent, - PendingIntent.FLAG_UPDATE_CURRENT or (if (Build.VERSION.SDK_INT >= 23) PendingIntent.FLAG_IMMUTABLE else 0)) + PendingIntent.FLAG_UPDATE_CURRENT or PendingIntent.FLAG_IMMUTABLE) } private fun getDownloadsIntent(context: Context): PendingIntent { val intent = MainActivityStarter(context).withFragmentLoaded("DownloadsFragment").getIntent() return PendingIntent.getActivity(context, R.id.pending_intent_download_service_notification, intent, - PendingIntent.FLAG_UPDATE_CURRENT or (if (Build.VERSION.SDK_INT >= 23) PendingIntent.FLAG_IMMUTABLE else 0)) + PendingIntent.FLAG_UPDATE_CURRENT or PendingIntent.FLAG_IMMUTABLE) } private fun sendErrorNotification(title: String) { diff --git a/app/src/main/java/ac/mdiq/podcini/service/FeedUpdateWorker.kt b/app/src/main/java/ac/mdiq/podcini/net/download/service/FeedUpdateWorker.kt similarity index 96% rename from app/src/main/java/ac/mdiq/podcini/service/FeedUpdateWorker.kt rename to app/src/main/java/ac/mdiq/podcini/net/download/service/FeedUpdateWorker.kt index bf07b021..1a098584 100644 --- a/app/src/main/java/ac/mdiq/podcini/service/FeedUpdateWorker.kt +++ b/app/src/main/java/ac/mdiq/podcini/net/download/service/FeedUpdateWorker.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.service +package ac.mdiq.podcini.net.download.service import ac.mdiq.podcini.R import android.Manifest @@ -17,10 +17,8 @@ import com.google.common.util.concurrent.Futures import com.google.common.util.concurrent.ListenableFuture import ac.mdiq.podcini.util.config.ClientConfigurator import ac.mdiq.podcini.feed.LocalFeedUpdater -import ac.mdiq.podcini.service.download.DefaultDownloaderFactory -import ac.mdiq.podcini.service.download.DownloadRequestCreator.create -import ac.mdiq.podcini.service.download.NewEpisodesNotification -import ac.mdiq.podcini.service.download.handler.FeedSyncTask +import ac.mdiq.podcini.net.download.service.DownloadRequestCreator.create +import ac.mdiq.podcini.net.download.service.handler.FeedSyncTask import ac.mdiq.podcini.storage.DBReader import ac.mdiq.podcini.storage.DBTasks import ac.mdiq.podcini.storage.DBWriter diff --git a/app/src/main/java/ac/mdiq/podcini/service/download/HttpCredentialEncoder.kt b/app/src/main/java/ac/mdiq/podcini/net/download/service/HttpCredentialEncoder.kt similarity index 92% rename from app/src/main/java/ac/mdiq/podcini/service/download/HttpCredentialEncoder.kt rename to app/src/main/java/ac/mdiq/podcini/net/download/service/HttpCredentialEncoder.kt index 210b013a..21fce355 100644 --- a/app/src/main/java/ac/mdiq/podcini/service/download/HttpCredentialEncoder.kt +++ b/app/src/main/java/ac/mdiq/podcini/net/download/service/HttpCredentialEncoder.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.service.download +package ac.mdiq.podcini.net.download.service import okio.ByteString import java.io.UnsupportedEncodingException diff --git a/app/src/main/java/ac/mdiq/podcini/service/download/HttpDownloader.kt b/app/src/main/java/ac/mdiq/podcini/net/download/service/HttpDownloader.kt similarity index 98% rename from app/src/main/java/ac/mdiq/podcini/service/download/HttpDownloader.kt rename to app/src/main/java/ac/mdiq/podcini/net/download/service/HttpDownloader.kt index 0c396518..30d869b9 100644 --- a/app/src/main/java/ac/mdiq/podcini/service/download/HttpDownloader.kt +++ b/app/src/main/java/ac/mdiq/podcini/net/download/service/HttpDownloader.kt @@ -1,9 +1,9 @@ -package ac.mdiq.podcini.service.download +package ac.mdiq.podcini.net.download.service import ac.mdiq.podcini.R import android.text.TextUtils import android.util.Log -import ac.mdiq.podcini.service.download.PodciniHttpClient.getHttpClient +import ac.mdiq.podcini.net.download.service.PodciniHttpClient.getHttpClient import ac.mdiq.podcini.util.NetworkUtils.wasDownloadBlocked import ac.mdiq.podcini.util.StorageUtils.freeSpaceAvailable import ac.mdiq.podcini.util.URIUtil.getURIFromRequestUrl @@ -278,9 +278,8 @@ class HttpDownloader(request: DownloadRequest) : Downloader(request) { responses.add(response) response = response.priorResponse } - if (responses.size < 2) { - return - } + if (responses.size < 2) return + responses.reverse() val firstCode = responses[0]!!.code val firstUrl = responses[0]!!.request.url.toString() diff --git a/app/src/main/java/ac/mdiq/podcini/service/download/NewEpisodesNotification.kt b/app/src/main/java/ac/mdiq/podcini/net/download/service/NewEpisodesNotification.kt similarity index 96% rename from app/src/main/java/ac/mdiq/podcini/service/download/NewEpisodesNotification.kt rename to app/src/main/java/ac/mdiq/podcini/net/download/service/NewEpisodesNotification.kt index f063482d..085f9716 100644 --- a/app/src/main/java/ac/mdiq/podcini/service/download/NewEpisodesNotification.kt +++ b/app/src/main/java/ac/mdiq/podcini/net/download/service/NewEpisodesNotification.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.service.download +package ac.mdiq.podcini.net.download.service import ac.mdiq.podcini.R import ac.mdiq.podcini.storage.database.PodDBAdapter @@ -65,8 +65,7 @@ class NewEpisodesNotification { intent.setComponent(ComponentName(context, "ac.mdiq.podcini.activity.MainActivity")) intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK or Intent.FLAG_ACTIVITY_CLEAR_TASK) intent.putExtra("fragment_feed_id", feed.id) - val pendingIntent = PendingIntent.getActivity(context, 0, intent, - (if (Build.VERSION.SDK_INT >= 23) PendingIntent.FLAG_IMMUTABLE else 0)) + val pendingIntent = PendingIntent.getActivity(context, 0, intent, PendingIntent.FLAG_IMMUTABLE) val notification = NotificationCompat.Builder( context, NotificationUtils.CHANNEL_ID_EPISODE_NOTIFICATIONS) @@ -106,8 +105,7 @@ class NewEpisodesNotification { intent.setComponent(ComponentName(context, "ac.mdiq.podcini.activity.MainActivity")) intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK or Intent.FLAG_ACTIVITY_CLEAR_TASK) intent.putExtra("fragment_tag", "NewEpisodesFragment") - val pendingIntent = PendingIntent.getActivity(context, 0, intent, - (if (Build.VERSION.SDK_INT >= 23) PendingIntent.FLAG_IMMUTABLE else 0)) + val pendingIntent = PendingIntent.getActivity(context, 0, intent, PendingIntent.FLAG_IMMUTABLE) val notificationGroupSummary = NotificationCompat.Builder( context, NotificationUtils.CHANNEL_ID_EPISODE_NOTIFICATIONS) diff --git a/app/src/main/java/ac/mdiq/podcini/service/download/PodciniHttpClient.kt b/app/src/main/java/ac/mdiq/podcini/net/download/service/PodciniHttpClient.kt similarity index 95% rename from app/src/main/java/ac/mdiq/podcini/service/download/PodciniHttpClient.kt rename to app/src/main/java/ac/mdiq/podcini/net/download/service/PodciniHttpClient.kt index cb407256..fe9ef501 100644 --- a/app/src/main/java/ac/mdiq/podcini/service/download/PodciniHttpClient.kt +++ b/app/src/main/java/ac/mdiq/podcini/net/download/service/PodciniHttpClient.kt @@ -1,8 +1,6 @@ -package ac.mdiq.podcini.service.download +package ac.mdiq.podcini.net.download.service import android.util.Log -import ac.mdiq.podcini.service.BasicAuthorizationInterceptor -import ac.mdiq.podcini.service.UserAgentInterceptor import ac.mdiq.podcini.storage.model.download.ProxyConfig import ac.mdiq.podcini.net.ssl.SslClientSetup import okhttp3.* diff --git a/app/src/main/java/ac/mdiq/podcini/service/UserAgentInterceptor.kt b/app/src/main/java/ac/mdiq/podcini/net/download/service/UserAgentInterceptor.kt similarity index 90% rename from app/src/main/java/ac/mdiq/podcini/service/UserAgentInterceptor.kt rename to app/src/main/java/ac/mdiq/podcini/net/download/service/UserAgentInterceptor.kt index 9a76cc49..8a70722a 100644 --- a/app/src/main/java/ac/mdiq/podcini/service/UserAgentInterceptor.kt +++ b/app/src/main/java/ac/mdiq/podcini/net/download/service/UserAgentInterceptor.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.service +package ac.mdiq.podcini.net.download.service import ac.mdiq.podcini.util.config.ClientConfig import okhttp3.Interceptor diff --git a/app/src/main/java/ac/mdiq/podcini/service/download/handler/FeedParserTask.kt b/app/src/main/java/ac/mdiq/podcini/net/download/service/handler/FeedParserTask.kt similarity index 98% rename from app/src/main/java/ac/mdiq/podcini/service/download/handler/FeedParserTask.kt rename to app/src/main/java/ac/mdiq/podcini/net/download/service/handler/FeedParserTask.kt index 497c8a28..3c3fd64e 100644 --- a/app/src/main/java/ac/mdiq/podcini/service/download/handler/FeedParserTask.kt +++ b/app/src/main/java/ac/mdiq/podcini/net/download/service/handler/FeedParserTask.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.service.download.handler +package ac.mdiq.podcini.net.download.service.handler import ac.mdiq.podcini.feed.parser.FeedHandlerResult import android.util.Log diff --git a/app/src/main/java/ac/mdiq/podcini/service/download/handler/FeedSyncTask.kt b/app/src/main/java/ac/mdiq/podcini/net/download/service/handler/FeedSyncTask.kt similarity index 94% rename from app/src/main/java/ac/mdiq/podcini/service/download/handler/FeedSyncTask.kt rename to app/src/main/java/ac/mdiq/podcini/net/download/service/handler/FeedSyncTask.kt index 057af753..3c67191d 100644 --- a/app/src/main/java/ac/mdiq/podcini/service/download/handler/FeedSyncTask.kt +++ b/app/src/main/java/ac/mdiq/podcini/net/download/service/handler/FeedSyncTask.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.service.download.handler +package ac.mdiq.podcini.net.download.service.handler import ac.mdiq.podcini.feed.parser.FeedHandlerResult import ac.mdiq.podcini.net.download.serviceinterface.DownloadRequest diff --git a/app/src/main/java/ac/mdiq/podcini/service/download/handler/MediaDownloadedHandler.kt b/app/src/main/java/ac/mdiq/podcini/net/download/service/handler/MediaDownloadedHandler.kt similarity index 98% rename from app/src/main/java/ac/mdiq/podcini/service/download/handler/MediaDownloadedHandler.kt rename to app/src/main/java/ac/mdiq/podcini/net/download/service/handler/MediaDownloadedHandler.kt index 2a852ce8..89ba02b4 100644 --- a/app/src/main/java/ac/mdiq/podcini/service/download/handler/MediaDownloadedHandler.kt +++ b/app/src/main/java/ac/mdiq/podcini/net/download/service/handler/MediaDownloadedHandler.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.service.download.handler +package ac.mdiq.podcini.net.download.service.handler import android.content.Context import android.media.MediaMetadataRetriever diff --git a/app/src/main/java/ac/mdiq/podcini/net/sync/SyncService.kt b/app/src/main/java/ac/mdiq/podcini/net/sync/SyncService.kt index 49e0ebd9..decf8613 100644 --- a/app/src/main/java/ac/mdiq/podcini/net/sync/SyncService.kt +++ b/app/src/main/java/ac/mdiq/podcini/net/sync/SyncService.kt @@ -19,7 +19,7 @@ import ac.mdiq.podcini.net.sync.nextcloud.NextcloudSyncService import ac.mdiq.podcini.net.sync.queue.SynchronizationQueueStorage import ac.mdiq.podcini.preferences.UserPreferences.gpodnetNotificationsEnabled import ac.mdiq.podcini.preferences.UserPreferences.isAllowMobileSync -import ac.mdiq.podcini.service.download.PodciniHttpClient.getHttpClient +import ac.mdiq.podcini.net.download.service.PodciniHttpClient.getHttpClient import ac.mdiq.podcini.storage.DBReader.getEpisodes import ac.mdiq.podcini.storage.DBReader.getFeedItemByGuidOrEpisodeUrl import ac.mdiq.podcini.storage.DBReader.getFeedListDownloadUrls @@ -266,7 +266,7 @@ class SyncService(context: Context, params: WorkerParameters) : Worker(context, applicationContext.packageName) val pendingIntent = PendingIntent.getActivity(applicationContext, R.id.pending_intent_sync_error, intent, PendingIntent.FLAG_UPDATE_CURRENT - or (if (Build.VERSION.SDK_INT >= 23) PendingIntent.FLAG_IMMUTABLE else 0)) + or PendingIntent.FLAG_IMMUTABLE) val notification = NotificationCompat.Builder(applicationContext, NotificationUtils.CHANNEL_ID_SYNC_ERROR) .setContentTitle(applicationContext.getString(R.string.gpodnetsync_error_title)) diff --git a/app/src/main/java/ac/mdiq/podcini/playback/PlaybackController.kt b/app/src/main/java/ac/mdiq/podcini/playback/PlaybackController.kt index fed923d0..c887cf9b 100644 --- a/app/src/main/java/ac/mdiq/podcini/playback/PlaybackController.kt +++ b/app/src/main/java/ac/mdiq/podcini/playback/PlaybackController.kt @@ -2,13 +2,13 @@ package ac.mdiq.podcini.playback import ac.mdiq.podcini.feed.util.PlaybackSpeedUtils.getCurrentPlaybackSpeed import ac.mdiq.podcini.preferences.PlaybackPreferences -import ac.mdiq.podcini.service.playback.PlaybackService -import ac.mdiq.podcini.service.playback.PlaybackService.LocalBinder -import ac.mdiq.podcini.service.playback.PlaybackServiceInterface +import ac.mdiq.podcini.playback.service.PlaybackService +import ac.mdiq.podcini.playback.service.PlaybackService.LocalBinder +import ac.mdiq.podcini.playback.service.PlaybackServiceInterface import ac.mdiq.podcini.storage.DBWriter -import ac.mdiq.podcini.playback.event.PlaybackPositionEvent -import ac.mdiq.podcini.playback.event.PlaybackServiceEvent -import ac.mdiq.podcini.playback.event.SpeedChangedEvent +import ac.mdiq.podcini.util.event.playback.PlaybackPositionEvent +import ac.mdiq.podcini.util.event.playback.PlaybackServiceEvent +import ac.mdiq.podcini.util.event.playback.SpeedChangedEvent import ac.mdiq.podcini.storage.model.feed.FeedMedia import ac.mdiq.podcini.storage.model.playback.MediaType import ac.mdiq.podcini.storage.model.playback.Playable @@ -299,10 +299,8 @@ abstract class PlaybackController(private val activity: FragmentActivity) { get() = playbackService?.duration ?: getMedia()?.getDuration()?:Playable.INVALID_TIME fun getMedia(): Playable? { - if (media == null) { - media = if (playbackService != null) playbackService!!.pSMPInfo.playable - else PlaybackPreferences.createInstanceFromPreferences(activity) - } + if (media == null && playbackService != null) media = playbackService!!.pSMPInfo.playable + if (media == null) media = PlaybackPreferences.createInstanceFromPreferences(activity) return media } diff --git a/app/src/main/java/ac/mdiq/podcini/playback/PlaybackServiceStarter.kt b/app/src/main/java/ac/mdiq/podcini/playback/PlaybackServiceStarter.kt index 53dc5d32..a1c9a92b 100644 --- a/app/src/main/java/ac/mdiq/podcini/playback/PlaybackServiceStarter.kt +++ b/app/src/main/java/ac/mdiq/podcini/playback/PlaybackServiceStarter.kt @@ -5,8 +5,8 @@ import android.content.Intent import android.os.Parcelable import androidx.core.content.ContextCompat import androidx.media3.common.util.UnstableApi -import ac.mdiq.podcini.service.playback.PlaybackService -import ac.mdiq.podcini.service.playback.PlaybackServiceInterface +import ac.mdiq.podcini.playback.service.PlaybackService +import ac.mdiq.podcini.playback.service.PlaybackServiceInterface import ac.mdiq.podcini.storage.model.playback.Playable @UnstableApi @@ -37,9 +37,7 @@ class PlaybackServiceStarter(private val context: Context, private val media: Pl } fun start() { - if (PlaybackService.isRunning && !callEvenIfRunning) { - return - } + if (PlaybackService.isRunning && !callEvenIfRunning) return ContextCompat.startForegroundService(context, intent) } } diff --git a/app/src/main/java/ac/mdiq/podcini/playback/base/PlaybackServiceMediaPlayer.kt b/app/src/main/java/ac/mdiq/podcini/playback/base/PlaybackServiceMediaPlayer.kt index 7b07acd8..eb623982 100644 --- a/app/src/main/java/ac/mdiq/podcini/playback/base/PlaybackServiceMediaPlayer.kt +++ b/app/src/main/java/ac/mdiq/podcini/playback/base/PlaybackServiceMediaPlayer.kt @@ -21,8 +21,7 @@ import kotlin.concurrent.Volatile * and remote (cast devices) playback. */ abstract class PlaybackServiceMediaPlayer protected constructor(protected val context: Context, - protected val callback: PSMPCallback -) { + protected val callback: PSMPCallback) { @Volatile private var oldPlayerStatus: PlayerStatus? = null diff --git a/app/src/main/java/ac/mdiq/podcini/service/playback/ExoPlayerWrapper.kt b/app/src/main/java/ac/mdiq/podcini/playback/service/ExoPlayerWrapper.kt similarity index 98% rename from app/src/main/java/ac/mdiq/podcini/service/playback/ExoPlayerWrapper.kt rename to app/src/main/java/ac/mdiq/podcini/playback/service/ExoPlayerWrapper.kt index debf7d4b..a40a81c5 100644 --- a/app/src/main/java/ac/mdiq/podcini/service/playback/ExoPlayerWrapper.kt +++ b/app/src/main/java/ac/mdiq/podcini/playback/service/ExoPlayerWrapper.kt @@ -1,9 +1,9 @@ -package ac.mdiq.podcini.service.playback +package ac.mdiq.podcini.playback.service import ac.mdiq.podcini.R import ac.mdiq.podcini.util.config.ClientConfig -import ac.mdiq.podcini.service.download.HttpCredentialEncoder -import ac.mdiq.podcini.service.download.PodciniHttpClient +import ac.mdiq.podcini.net.download.service.HttpCredentialEncoder +import ac.mdiq.podcini.net.download.service.PodciniHttpClient import ac.mdiq.podcini.util.NetworkUtils.wasDownloadBlocked import ac.mdiq.podcini.storage.model.playback.Playable import ac.mdiq.podcini.preferences.UserPreferences diff --git a/app/src/main/java/ac/mdiq/podcini/service/playback/LocalPSMP.kt b/app/src/main/java/ac/mdiq/podcini/playback/service/LocalPSMP.kt similarity index 97% rename from app/src/main/java/ac/mdiq/podcini/service/playback/LocalPSMP.kt rename to app/src/main/java/ac/mdiq/podcini/playback/service/LocalPSMP.kt index 8759c6ee..0cc46044 100644 --- a/app/src/main/java/ac/mdiq/podcini/service/playback/LocalPSMP.kt +++ b/app/src/main/java/ac/mdiq/podcini/playback/service/LocalPSMP.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.service.playback +package ac.mdiq.podcini.playback.service import android.app.UiModeManager import android.content.Context @@ -16,8 +16,8 @@ import androidx.media.AudioFocusRequestCompat import androidx.media.AudioManagerCompat import androidx.media3.common.util.UnstableApi import ac.mdiq.podcini.feed.util.PlaybackSpeedUtils -import ac.mdiq.podcini.playback.event.BufferUpdateEvent -import ac.mdiq.podcini.playback.event.SpeedChangedEvent +import ac.mdiq.podcini.util.event.playback.BufferUpdateEvent +import ac.mdiq.podcini.util.event.playback.SpeedChangedEvent import ac.mdiq.podcini.storage.model.feed.FeedMedia import ac.mdiq.podcini.storage.model.playback.MediaType import ac.mdiq.podcini.storage.model.playback.Playable @@ -144,7 +144,7 @@ class LocalPSMP(context: Context, callback: PSMPCallback) : PlaybackServiceMedia if (media!!.getIdentifier() != playable.getIdentifier()) { val oldMedia: Playable = media!! - callback.onPostPlayback(oldMedia, false, false, true) + callback.onPostPlayback(oldMedia, ended = false, skipped = false, true) } setPlayerStatus(PlayerStatus.INDETERMINATE, null) @@ -360,7 +360,7 @@ class LocalPSMP(context: Context, callback: PSMPCallback) : PlaybackServiceMedia if (t >= getDuration()) { Log.d(TAG, "Seek reached end of file, skipping to next episode") - endPlayback(true, true, true, true) + endPlayback(true, wasSkipped = true, true, toStoppedState = true) return } @@ -597,7 +597,7 @@ class LocalPSMP(context: Context, callback: PSMPCallback) : PlaybackServiceMedia } focusChange == AudioManager.AUDIOFOCUS_LOSS -> { Log.d(TAG, "Lost audio focus") - pause(true, false) + pause(true, reinit = false) callback.shouldStop() } focusChange == AudioManager.AUDIOFOCUS_LOSS_TRANSIENT_CAN_DUCK @@ -618,7 +618,7 @@ class LocalPSMP(context: Context, callback: PSMPCallback) : PlaybackServiceMedia audioFocusCanceller.postDelayed({ if (pausedBecauseOfTransientAudiofocusLoss) { // Still did not get back the audio focus. Now actually pause. - pause(true, false) + pause(abandonFocus = true, reinit = false) } }, 30000) } @@ -723,7 +723,10 @@ class LocalPSMP(context: Context, callback: PSMPCallback) : PlaybackServiceMedia if (mp == null || media == null) { return } - mp.setOnCompletionListener(Runnable { endPlayback(true, false, true, true) }) + mp.setOnCompletionListener(Runnable { endPlayback(hasEnded = true, + wasSkipped = false, + shouldContinue = true, + toStoppedState = true) }) mp.setOnSeekCompleteListener(Runnable { this.genericSeekCompleteListener() }) mp.setOnBufferingUpdateListener(Consumer { percent: Int -> when (percent) { @@ -748,7 +751,7 @@ class LocalPSMP(context: Context, callback: PSMPCallback) : PlaybackServiceMedia mediaPlayer!!.setOnCompletionListener {} mediaPlayer!!.setOnSeekCompleteListener {} mediaPlayer!!.setOnBufferingUpdateListener { } - mediaPlayer!!.setOnErrorListener { x: String? -> } + mediaPlayer!!.setOnErrorListener { } } private fun genericSeekCompleteListener() { diff --git a/app/src/main/java/ac/mdiq/podcini/service/playback/PlaybackService.kt b/app/src/main/java/ac/mdiq/podcini/playback/service/PlaybackService.kt similarity index 95% rename from app/src/main/java/ac/mdiq/podcini/service/playback/PlaybackService.kt rename to app/src/main/java/ac/mdiq/podcini/playback/service/PlaybackService.kt index 5c15f5d0..31cf57e1 100644 --- a/app/src/main/java/ac/mdiq/podcini/service/playback/PlaybackService.kt +++ b/app/src/main/java/ac/mdiq/podcini/playback/service/PlaybackService.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.service.playback +package ac.mdiq.podcini.playback.service import ac.mdiq.podcini.R import ac.mdiq.podcini.net.sync.queue.SynchronizationQueueSink @@ -10,10 +10,7 @@ import ac.mdiq.podcini.playback.base.PlaybackServiceMediaPlayer.PSMPInfo import ac.mdiq.podcini.playback.base.PlayerStatus import ac.mdiq.podcini.playback.cast.CastPsmp import ac.mdiq.podcini.playback.cast.CastStateListener -import ac.mdiq.podcini.playback.event.BufferUpdateEvent -import ac.mdiq.podcini.playback.event.PlaybackPositionEvent -import ac.mdiq.podcini.playback.event.PlaybackServiceEvent -import ac.mdiq.podcini.playback.event.SleepTimerUpdatedEvent +import ac.mdiq.podcini.playback.service.PlaybackServiceTaskManager.PSTMCallback import ac.mdiq.podcini.preferences.PlaybackPreferences import ac.mdiq.podcini.preferences.PlaybackPreferences.Companion.clearCurrentlyPlayingTemporaryPlaybackSpeed import ac.mdiq.podcini.preferences.PlaybackPreferences.Companion.createInstanceFromPreferences @@ -52,8 +49,7 @@ import ac.mdiq.podcini.preferences.UserPreferences.showPlaybackSpeedOnFullNotifi import ac.mdiq.podcini.preferences.UserPreferences.showSkipOnFullNotification import ac.mdiq.podcini.preferences.UserPreferences.videoPlaybackSpeed import ac.mdiq.podcini.receiver.MediaButtonReceiver -import ac.mdiq.podcini.service.QuickSettingsTileService -import ac.mdiq.podcini.service.playback.PlaybackServiceTaskManager.PSTMCallback +import ac.mdiq.podcini.service.playback.WearMediaSession import ac.mdiq.podcini.storage.DBReader import ac.mdiq.podcini.storage.DBWriter import ac.mdiq.podcini.storage.FeedSearcher @@ -61,8 +57,8 @@ import ac.mdiq.podcini.storage.model.feed.* import ac.mdiq.podcini.storage.model.feed.FeedPreferences.AutoDeleteAction import ac.mdiq.podcini.storage.model.playback.MediaType import ac.mdiq.podcini.storage.model.playback.Playable -import ac.mdiq.podcini.ui.appstartintent.MainActivityStarter -import ac.mdiq.podcini.ui.appstartintent.VideoPlayerActivityStarter +import ac.mdiq.podcini.ui.activity.appstartintent.MainActivityStarter +import ac.mdiq.podcini.ui.activity.appstartintent.VideoPlayerActivityStarter import ac.mdiq.podcini.ui.utils.NotificationUtils import ac.mdiq.podcini.ui.widget.WidgetUpdater.WidgetState import ac.mdiq.podcini.util.ChapterUtils.getCurrentChapterIndex @@ -72,11 +68,13 @@ import ac.mdiq.podcini.util.IntentUtils.sendLocalBroadcast import ac.mdiq.podcini.util.NetworkUtils.isStreamingAllowed import ac.mdiq.podcini.util.event.MessageEvent import ac.mdiq.podcini.util.event.PlayerErrorEvent +import ac.mdiq.podcini.util.event.playback.* import ac.mdiq.podcini.util.event.settings.SkipIntroEndingChangedEvent import ac.mdiq.podcini.util.event.settings.SpeedPresetChangedEvent import ac.mdiq.podcini.util.event.settings.VolumeAdaptionChangedEvent import android.Manifest import android.annotation.SuppressLint +import android.app.NotificationManager import android.app.PendingIntent import android.app.UiModeManager import android.bluetooth.BluetoothA2dp @@ -142,6 +140,8 @@ class PlaybackService : MediaBrowserServiceCompat() { private var normalSpeed = 1.0f private var isFallbackSpeed = false + private var currentitem: FeedItem? = null + /** * Used for Lollipop notifications, Android Wear, and Android Auto. */ @@ -435,8 +435,7 @@ class PlaybackService : MediaBrowserServiceCompat() { override fun onBind(intent: Intent): IBinder? { Log.d(TAG, "Received onBind event") - return if (intent.action != null && TextUtils.equals(intent.action, - SERVICE_INTERFACE)) { + return if (intent.action != null && TextUtils.equals(intent.action, SERVICE_INTERFACE)) { super.onBind(intent) } else { mBinder @@ -519,9 +518,11 @@ class PlaybackService : MediaBrowserServiceCompat() { } private fun skipIntro(playable: Playable) { - if (playable !is FeedMedia) return + val item = (playable as? FeedMedia)?.item ?: currentitem ?: return +// val item = currentitem ?: (playable as? FeedMedia)?.item ?: return + val feed = item.feed ?: DBReader.getFeed(item.feedId) + val preferences = feed?.preferences - val preferences = playable.item?.feed?.preferences val skipIntro = preferences?.feedSkipIntro ?: 0 val skipIntroMS = skipIntro * 1000 if (skipIntro > 0 && playable.getPosition() < skipIntroMS) { @@ -553,8 +554,7 @@ class PlaybackService : MediaBrowserServiceCompat() { PendingIntent.FLAG_UPDATE_CURRENT or PendingIntent.FLAG_IMMUTABLE) } else { PendingIntent.getService(this, - R.id.pending_intent_allow_stream_this_time, intentAllowThisTime, PendingIntent.FLAG_UPDATE_CURRENT - or (if (Build.VERSION.SDK_INT >= 23) PendingIntent.FLAG_IMMUTABLE else 0)) + R.id.pending_intent_allow_stream_this_time, intentAllowThisTime, PendingIntent.FLAG_UPDATE_CURRENT or PendingIntent.FLAG_IMMUTABLE) } val intentAlwaysAllow = Intent(intentAllowThisTime) @@ -566,8 +566,7 @@ class PlaybackService : MediaBrowserServiceCompat() { PendingIntent.FLAG_UPDATE_CURRENT or PendingIntent.FLAG_IMMUTABLE) } else { PendingIntent.getService(this, - R.id.pending_intent_allow_stream_always, intentAlwaysAllow, PendingIntent.FLAG_UPDATE_CURRENT - or (if (Build.VERSION.SDK_INT >= 23) PendingIntent.FLAG_IMMUTABLE else 0)) + R.id.pending_intent_allow_stream_always, intentAlwaysAllow, PendingIntent.FLAG_UPDATE_CURRENT or PendingIntent.FLAG_IMMUTABLE) } val builder = NotificationCompat.Builder(this, @@ -707,7 +706,6 @@ class PlaybackService : MediaBrowserServiceCompat() { if (this.status == PlayerStatus.FALLBACK || status == PlayerStatus.PLAYING) { mediaPlayer?.pause(true, true) } - stateManager.stopForeground(true) // gets rid of persistent notification return true } @@ -804,13 +802,13 @@ class PlaybackService : MediaBrowserServiceCompat() { when (newInfo.playerStatus) { PlayerStatus.INITIALIZED -> { if (mediaPlayer != null) { - writeMediaPlaying(mediaPlayer!!.pSMPInfo.playable, mediaPlayer!!.pSMPInfo.playerStatus) + writeMediaPlaying(mediaPlayer!!.pSMPInfo.playable, mediaPlayer!!.pSMPInfo.playerStatus, currentitem) } updateNotificationAndMediaSession(newInfo.playable) } PlayerStatus.PREPARED -> { if (mediaPlayer != null) { - writeMediaPlaying(mediaPlayer!!.pSMPInfo.playable, mediaPlayer!!.pSMPInfo.playerStatus) + writeMediaPlaying(mediaPlayer!!.pSMPInfo.playable, mediaPlayer!!.pSMPInfo.playerStatus, currentitem) } taskManager.startChapterLoader(newInfo.playable!!) } @@ -844,9 +842,7 @@ class PlaybackService : MediaBrowserServiceCompat() { if (newInfo.oldPlayerStatus != null && newInfo.oldPlayerStatus != PlayerStatus.SEEKING && autoEnable() && autoEnableByTime && !sleepTimerActive()) { setSleepTimer(timerMillis()) - EventBus.getDefault() - .post(MessageEvent(getString(R.string.sleep_timer_enabled_label), - { disableSleepTimer() }, getString(R.string.undo))) + EventBus.getDefault().post(MessageEvent(getString(R.string.sleep_timer_enabled_label), { disableSleepTimer() }, getString(R.string.undo))) } loadQueueForMediaSession() } @@ -999,7 +995,7 @@ class PlaybackService : MediaBrowserServiceCompat() { if (!isFollowQueue) { Log.d(TAG, "getNextInQueue(), but follow queue is not enabled.") - writeMediaPlaying(nextItem.media, PlayerStatus.STOPPED) + writeMediaPlaying(nextItem.media, PlayerStatus.STOPPED, currentitem) updateNotificationAndMediaSession(nextItem.media) return null } @@ -1059,9 +1055,7 @@ class PlaybackService : MediaBrowserServiceCompat() { * Instances when we'd set it to false would be when we're not following the * queue or when the queue has ended. */ - private fun onPostPlayback(playable: Playable?, ended: Boolean, skipped: Boolean, - playingNext: Boolean - ) { + private fun onPostPlayback(playable: Playable?, ended: Boolean, skipped: Boolean, playingNext: Boolean) { if (playable == null) { Log.e(TAG, "Cannot do post-playback processing: media was null") return @@ -1075,10 +1069,10 @@ class PlaybackService : MediaBrowserServiceCompat() { } else { playable.onPlaybackPause(applicationContext) } - return +// return } val media = playable - val item = media.item + val item = (media as? FeedMedia)?.item ?: currentitem val smartMarkAsPlayed = hasAlmostEnded(media) if (!ended && smartMarkAsPlayed) { Log.d(TAG, "smart mark as played") @@ -1090,20 +1084,20 @@ class PlaybackService : MediaBrowserServiceCompat() { autoSkipped = true } - if (ended || smartMarkAsPlayed) { - SynchronizationQueueSink.enqueueEpisodePlayedIfSynchronizationIsActive( - applicationContext, media, true) - media.onPlaybackCompleted(applicationContext) - } else { - SynchronizationQueueSink.enqueueEpisodePlayedIfSynchronizationIsActive( - applicationContext, media, false) - media.onPlaybackPause(applicationContext) + if (media is FeedMedia) { + if (ended || smartMarkAsPlayed) { + SynchronizationQueueSink.enqueueEpisodePlayedIfSynchronizationIsActive( + applicationContext, media, true) + media.onPlaybackCompleted(applicationContext) + } else { + SynchronizationQueueSink.enqueueEpisodePlayedIfSynchronizationIsActive( + applicationContext, media, false) + media.onPlaybackPause(applicationContext) + } } if (item != null) { - if (ended || smartMarkAsPlayed - || autoSkipped - || (skipped && !shouldSkipKeepEpisode())) { + if (ended || smartMarkAsPlayed || autoSkipped || (skipped && !shouldSkipKeepEpisode())) { // only mark the item as played if we're not keeping it anyways DBWriter.markItemPlayed(item, FeedItem.PLAYED, ended || (skipped && smartMarkAsPlayed)) // don't know if it actually matters to not autodownload when smart mark as played is triggered @@ -1112,8 +1106,8 @@ class PlaybackService : MediaBrowserServiceCompat() { val action = item.feed?.preferences?.currentAutoDelete val shouldAutoDelete = (action == AutoDeleteAction.ALWAYS || (action == AutoDeleteAction.GLOBAL && item.feed != null && shouldAutoDeleteItemsOnThatFeed(item.feed!!))) - if (shouldAutoDelete && (!item.isTagged(FeedItem.TAG_FAVORITE) - || !shouldFavoriteKeepEpisode())) { + if (media is FeedMedia && shouldAutoDelete && + (!item.isTagged(FeedItem.TAG_FAVORITE) || !shouldFavoriteKeepEpisode())) { DBWriter.deleteFeedMediaOfItem(this@PlaybackService, media.id) Log.d(TAG, "Episode Deleted") } @@ -1121,7 +1115,7 @@ class PlaybackService : MediaBrowserServiceCompat() { } } - if (ended || skipped || playingNext) { + if (media is FeedMedia && (ended || skipped || playingNext)) { DBWriter.addItemToPlaybackHistory(media) } } @@ -1144,18 +1138,18 @@ class PlaybackService : MediaBrowserServiceCompat() { } private fun skipEndingIfNecessary() { - val playable = mediaPlayer?.getPlayable() as? FeedMedia ?: return + val playable = mediaPlayer?.getPlayable() as? FeedMedia val duration = duration val remainingTime = duration - currentPosition - val feedMedia = playable - val preferences = feedMedia.item?.feed?.preferences + val item = playable?.item ?: currentitem ?: return + val feed = item.feed ?: DBReader.getFeed(item.feedId) + val preferences = feed?.preferences + val skipEnd = preferences?.feedSkipEnding?:0 val skipEndMS = skipEnd * 1000 // Log.d(TAG, "skipEndingIfNecessary: checking " + remainingTime + " " + skipEndMS + " speed " + currentPlaybackSpeed) -// if (skipEnd > 0 && skipEndMS < this.duration && (remainingTime - skipEndMS > 0) -// && ((remainingTime - skipEndMS) < currentPlaybackSpeed * 1000)) { if (skipEnd > 0 && skipEndMS < this.duration && (remainingTime - skipEndMS < 0)) { Log.d(TAG, "skipEndingIfNecessary: Skipping the remaining " + remainingTime + " " + skipEndMS + " speed " + currentPlaybackSpeed) val context = applicationContext @@ -1163,7 +1157,7 @@ class PlaybackService : MediaBrowserServiceCompat() { val toast = Toast.makeText(context, skipMesg, Toast.LENGTH_LONG) toast.show() - this.autoSkippedFeedMediaId = feedMedia.item!!.identifyingValue + this.autoSkippedFeedMediaId = item?.identifyingValue mediaPlayer?.skip() } } @@ -1241,11 +1235,7 @@ class PlaybackService : MediaBrowserServiceCompat() { if (showSkipOnFullNotification()) { sessionState.addCustomAction( - PlaybackStateCompat.CustomAction.Builder( - CUSTOM_ACTION_SKIP_TO_NEXT, - getString(R.string.skip_episode_label), - R.drawable.ic_notification_skip - ).build() + PlaybackStateCompat.CustomAction.Builder(CUSTOM_ACTION_SKIP_TO_NEXT, getString(R.string.skip_episode_label), R.drawable.ic_notification_skip).build() ) } @@ -1278,7 +1268,8 @@ class PlaybackService : MediaBrowserServiceCompat() { builder.putBitmap(MediaMetadataCompat.METADATA_KEY_ART, notificationBuilder.cachedIcon) } else { var iconUri = p.getImageLocation() - if (p is FeedMedia) { // Don't use embedded cover etc, which Android can't load + // Don't use embedded cover etc, which Android can't load + if (p is FeedMedia) { val m = p if (m.item != null) { val item = m.item!! @@ -1562,32 +1553,41 @@ class PlaybackService : MediaBrowserServiceCompat() { @Suppress("unused") fun speedPresetChanged(event: SpeedPresetChangedEvent) { // TODO: speed - if (playable is FeedMedia) { - if ((playable as FeedMedia).item?.feed?.id == event.feedId) { - if (event.speed == FeedPreferences.SPEED_USE_GLOBAL) { - setSpeed(getPlaybackSpeed(playable!!.getMediaType())) - } else { - setSpeed(event.speed) - } + val item = (playable as? FeedMedia)?.item ?: currentitem +// if (playable is FeedMedia) { + if (item?.feed?.id == event.feedId) { + if (event.speed == FeedPreferences.SPEED_USE_GLOBAL) { + setSpeed(getPlaybackSpeed(playable!!.getMediaType())) + } else { + setSpeed(event.speed) } } +// } } @Subscribe(threadMode = ThreadMode.MAIN) @Suppress("unused") fun skipIntroEndingPresetChanged(event: SkipIntroEndingChangedEvent) { - if (playable is FeedMedia) { - if ((playable as FeedMedia).item?.feed?.id == event.feedId) { - val feedPreferences = (playable as FeedMedia).item?.feed?.preferences - if (feedPreferences != null) { - Log.d(TAG, "skipIntroEndingPresetChanged ${event.skipIntro} ${event.skipEnding}") - feedPreferences.feedSkipIntro = event.skipIntro - feedPreferences.feedSkipEnding = event.skipEnding - } + val item = (playable as? FeedMedia)?.item ?: currentitem +// if (playable is FeedMedia) { + if (item?.feed?.id == event.feedId) { + val feedPreferences = item.feed?.preferences + if (feedPreferences != null) { + Log.d(TAG, "skipIntroEndingPresetChanged ${event.skipIntro} ${event.skipEnding}") + feedPreferences.feedSkipIntro = event.skipIntro + feedPreferences.feedSkipEnding = event.skipEnding } } +// } } + @Subscribe(threadMode = ThreadMode.MAIN) + fun onEvenStartPlay(event: StartPlayEvent) { + Log.d(TAG, "onEvenStartPlay ${event.item.title}") + currentitem = event.item + } + + fun resume() { mediaPlayer?.resume() taskManager.restartSleepTimer() @@ -1624,11 +1624,12 @@ class PlaybackService : MediaBrowserServiceCompat() { } else { if (codeArray != null && codeArray.size == 3) { if (codeArray[2]) setPlaybackSpeed(speed) - if (codeArray[1] && playable is FeedMedia) { - var item = (playable as FeedMedia).item + if (codeArray[1]) { + var item = (playable as? FeedMedia)?.item ?: currentitem +// var item = (playable as FeedMedia).item if (item == null) { - val itemId = (playable as FeedMedia).itemId - item = DBReader.getFeedItem(itemId) + val itemId = (playable as? FeedMedia)?.itemId + if (itemId != null) item = DBReader.getFeedItem(itemId) } if (item != null) { var feed = item.feed @@ -1754,11 +1755,11 @@ class PlaybackService : MediaBrowserServiceCompat() { Log.d(TAG, "notificationBuilder.updatePosition currentPosition: $currentPosition, currentPlaybackSpeed: $currentPlaybackSpeed") EventBus.getDefault().post(PlaybackPositionEvent(currentPosition, duration)) // TODO: why set SDK_INT < 29 -// if (Build.VERSION.SDK_INT < 29) { -// notificationBuilder.updatePosition(currentPosition, currentPlaybackSpeed) -// val notificationManager = getSystemService(NOTIFICATION_SERVICE) as? NotificationManager -// notificationManager?.notify(R.id.notification_playing, notificationBuilder.build()) -// } + if (Build.VERSION.SDK_INT < 29) { + notificationBuilder.updatePosition(currentPosition, currentPlaybackSpeed) + val notificationManager = getSystemService(NOTIFICATION_SERVICE) as? NotificationManager + notificationManager?.notify(R.id.notification_playing, notificationBuilder.build()) + } skipEndingIfNecessary() } } diff --git a/app/src/main/java/ac/mdiq/podcini/service/playback/PlaybackServiceInterface.kt b/app/src/main/java/ac/mdiq/podcini/playback/service/PlaybackServiceInterface.kt similarity index 96% rename from app/src/main/java/ac/mdiq/podcini/service/playback/PlaybackServiceInterface.kt rename to app/src/main/java/ac/mdiq/podcini/playback/service/PlaybackServiceInterface.kt index d5de6cbb..e5779d2c 100644 --- a/app/src/main/java/ac/mdiq/podcini/service/playback/PlaybackServiceInterface.kt +++ b/app/src/main/java/ac/mdiq/podcini/playback/service/PlaybackServiceInterface.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.service.playback +package ac.mdiq.podcini.playback.service object PlaybackServiceInterface { const val EXTRA_PLAYABLE: String = "PlaybackService.PlayableExtra" diff --git a/app/src/main/java/ac/mdiq/podcini/service/playback/PlaybackServiceNotificationBuilder.kt b/app/src/main/java/ac/mdiq/podcini/playback/service/PlaybackServiceNotificationBuilder.kt similarity index 97% rename from app/src/main/java/ac/mdiq/podcini/service/playback/PlaybackServiceNotificationBuilder.kt rename to app/src/main/java/ac/mdiq/podcini/playback/service/PlaybackServiceNotificationBuilder.kt index f91ce0be..50577a23 100644 --- a/app/src/main/java/ac/mdiq/podcini/service/playback/PlaybackServiceNotificationBuilder.kt +++ b/app/src/main/java/ac/mdiq/podcini/playback/service/PlaybackServiceNotificationBuilder.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.service.playback +package ac.mdiq.podcini.playback.service import ac.mdiq.podcini.R import android.app.Notification @@ -138,7 +138,7 @@ class PlaybackServiceNotificationBuilder(private val context: Context) { private val playerActivityPendingIntent: PendingIntent get() = PendingIntent.getActivity(context, R.id.pending_intent_player_activity, PlaybackService.getPlayerActivityIntent(context), PendingIntent.FLAG_UPDATE_CURRENT - or (if (Build.VERSION.SDK_INT >= 23) PendingIntent.FLAG_IMMUTABLE else 0)) + or PendingIntent.FLAG_IMMUTABLE) private fun addActions(notification: NotificationCompat.Builder, mediaSessionToken: MediaSessionCompat.Token?, playerStatus: PlayerStatus? @@ -210,7 +210,7 @@ class PlaybackServiceNotificationBuilder(private val context: Context) { PendingIntent.FLAG_UPDATE_CURRENT or PendingIntent.FLAG_IMMUTABLE) } else { PendingIntent.getService(context, requestCode, intent, PendingIntent.FLAG_UPDATE_CURRENT - or (if (Build.VERSION.SDK_INT >= 23) PendingIntent.FLAG_IMMUTABLE else 0)) + or PendingIntent.FLAG_IMMUTABLE) } } @@ -224,7 +224,7 @@ class PlaybackServiceNotificationBuilder(private val context: Context) { PendingIntent.FLAG_UPDATE_CURRENT or PendingIntent.FLAG_IMMUTABLE) } else { PendingIntent.getService(context, requestCode, intent, PendingIntent.FLAG_UPDATE_CURRENT - or (if (Build.VERSION.SDK_INT >= 23) PendingIntent.FLAG_IMMUTABLE else 0)) + or PendingIntent.FLAG_IMMUTABLE) } } diff --git a/app/src/main/java/ac/mdiq/podcini/service/playback/PlaybackServiceStateManager.kt b/app/src/main/java/ac/mdiq/podcini/playback/service/PlaybackServiceStateManager.kt similarity index 97% rename from app/src/main/java/ac/mdiq/podcini/service/playback/PlaybackServiceStateManager.kt rename to app/src/main/java/ac/mdiq/podcini/playback/service/PlaybackServiceStateManager.kt index 7de1c437..4035a35d 100644 --- a/app/src/main/java/ac/mdiq/podcini/service/playback/PlaybackServiceStateManager.kt +++ b/app/src/main/java/ac/mdiq/podcini/playback/service/PlaybackServiceStateManager.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.service.playback +package ac.mdiq.podcini.playback.service import android.app.Notification import android.content.pm.ServiceInfo.FOREGROUND_SERVICE_TYPE_MEDIA_PLAYBACK diff --git a/app/src/main/java/ac/mdiq/podcini/service/playback/PlaybackServiceTaskManager.kt b/app/src/main/java/ac/mdiq/podcini/playback/service/PlaybackServiceTaskManager.kt similarity index 96% rename from app/src/main/java/ac/mdiq/podcini/service/playback/PlaybackServiceTaskManager.kt rename to app/src/main/java/ac/mdiq/podcini/playback/service/PlaybackServiceTaskManager.kt index b9c4bab6..977adc11 100644 --- a/app/src/main/java/ac/mdiq/podcini/service/playback/PlaybackServiceTaskManager.kt +++ b/app/src/main/java/ac/mdiq/podcini/playback/service/PlaybackServiceTaskManager.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.service.playback +package ac.mdiq.podcini.playback.service import android.content.Context import android.os.Handler @@ -9,7 +9,7 @@ import ac.mdiq.podcini.preferences.SleepTimerPreferences import ac.mdiq.podcini.util.ChapterUtils import ac.mdiq.podcini.ui.widget.WidgetUpdater import ac.mdiq.podcini.ui.widget.WidgetUpdater.WidgetState -import ac.mdiq.podcini.playback.event.SleepTimerUpdatedEvent +import ac.mdiq.podcini.util.event.playback.SleepTimerUpdatedEvent import ac.mdiq.podcini.storage.model.playback.Playable import io.reactivex.Completable import io.reactivex.CompletableEmitter @@ -273,14 +273,14 @@ class PlaybackServiceTaskManager(private val context: Context, private var shakeListener: ShakeListener? = null override fun run() { - Log.d(Companion.TAG, "Starting") + Log.d(TAG, "Starting") var lastTick = System.currentTimeMillis() EventBus.getDefault().post(SleepTimerUpdatedEvent.updated(timeLeft)) while (timeLeft > 0) { try { - Thread.sleep(Companion.UPDATE_INTERVAL) + Thread.sleep(UPDATE_INTERVAL) } catch (e: InterruptedException) { - Log.d(Companion.TAG, "Thread was interrupted while waiting") + Log.d(TAG, "Thread was interrupted while waiting") e.printStackTrace() break } @@ -290,8 +290,8 @@ class PlaybackServiceTaskManager(private val context: Context, lastTick = now EventBus.getDefault().post(SleepTimerUpdatedEvent.updated(timeLeft)) - if (timeLeft < Companion.NOTIFICATION_THRESHOLD) { - Log.d(Companion.TAG, "Sleep timer is about to expire") + if (timeLeft < NOTIFICATION_THRESHOLD) { + Log.d(TAG, "Sleep timer is about to expire") if (SleepTimerPreferences.vibrate() && !hasVibrated) { val v = context.getSystemService(Context.VIBRATOR_SERVICE) as Vibrator if (v != null) { @@ -304,7 +304,7 @@ class PlaybackServiceTaskManager(private val context: Context, } } if (timeLeft <= 0) { - Log.d(Companion.TAG, "Sleep timer expired") + Log.d(TAG, "Sleep timer expired") if (shakeListener != null) { shakeListener!!.pause() shakeListener = null diff --git a/app/src/main/java/ac/mdiq/podcini/service/playback/PlaybackVolumeUpdater.kt b/app/src/main/java/ac/mdiq/podcini/playback/service/PlaybackVolumeUpdater.kt similarity index 97% rename from app/src/main/java/ac/mdiq/podcini/service/playback/PlaybackVolumeUpdater.kt rename to app/src/main/java/ac/mdiq/podcini/playback/service/PlaybackVolumeUpdater.kt index a5a0dd28..f4d0aac0 100644 --- a/app/src/main/java/ac/mdiq/podcini/service/playback/PlaybackVolumeUpdater.kt +++ b/app/src/main/java/ac/mdiq/podcini/playback/service/PlaybackVolumeUpdater.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.service.playback +package ac.mdiq.podcini.playback.service import ac.mdiq.podcini.storage.model.feed.FeedMedia import ac.mdiq.podcini.storage.model.feed.VolumeAdaptionSetting diff --git a/app/src/main/java/ac/mdiq/podcini/service/QuickSettingsTileService.kt b/app/src/main/java/ac/mdiq/podcini/playback/service/QuickSettingsTileService.kt similarity index 95% rename from app/src/main/java/ac/mdiq/podcini/service/QuickSettingsTileService.kt rename to app/src/main/java/ac/mdiq/podcini/playback/service/QuickSettingsTileService.kt index b9f822c9..6b4df506 100644 --- a/app/src/main/java/ac/mdiq/podcini/service/QuickSettingsTileService.kt +++ b/app/src/main/java/ac/mdiq/podcini/playback/service/QuickSettingsTileService.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.service +package ac.mdiq.podcini.playback.service import android.content.ComponentName import android.content.Intent @@ -12,7 +12,6 @@ import androidx.annotation.RequiresApi import androidx.media3.common.util.UnstableApi import ac.mdiq.podcini.preferences.PlaybackPreferences import ac.mdiq.podcini.receiver.MediaButtonReceiver -import ac.mdiq.podcini.service.playback.PlaybackService @UnstableApi @RequiresApi(api = Build.VERSION_CODES.N) diff --git a/app/src/main/java/ac/mdiq/podcini/service/playback/ShakeListener.kt b/app/src/main/java/ac/mdiq/podcini/playback/service/ShakeListener.kt similarity index 94% rename from app/src/main/java/ac/mdiq/podcini/service/playback/ShakeListener.kt rename to app/src/main/java/ac/mdiq/podcini/playback/service/ShakeListener.kt index d923c903..403ae12c 100644 --- a/app/src/main/java/ac/mdiq/podcini/service/playback/ShakeListener.kt +++ b/app/src/main/java/ac/mdiq/podcini/playback/service/ShakeListener.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.service.playback +package ac.mdiq.podcini.playback.service import android.content.Context import android.hardware.Sensor @@ -6,7 +6,7 @@ import android.hardware.SensorEvent import android.hardware.SensorEventListener import android.hardware.SensorManager import android.util.Log -import ac.mdiq.podcini.service.playback.PlaybackServiceTaskManager.SleepTimer +import ac.mdiq.podcini.playback.service.PlaybackServiceTaskManager.SleepTimer import kotlin.math.sqrt internal class ShakeListener(private val mContext: Context, private val mSleepTimer: SleepTimer) : SensorEventListener { diff --git a/app/src/main/java/ac/mdiq/podcini/preferences/MasterSwitchPreference.kt b/app/src/main/java/ac/mdiq/podcini/preferences/MasterSwitchPreference.kt index 067af55a..033e5887 100644 --- a/app/src/main/java/ac/mdiq/podcini/preferences/MasterSwitchPreference.kt +++ b/app/src/main/java/ac/mdiq/podcini/preferences/MasterSwitchPreference.kt @@ -7,7 +7,7 @@ import android.widget.TextView import androidx.preference.PreferenceViewHolder import androidx.preference.SwitchPreferenceCompat import ac.mdiq.podcini.R -import ac.mdiq.podcini.ui.common.ThemeUtils.getColorFromAttr +import ac.mdiq.podcini.ui.utils.ThemeUtils.getColorFromAttr class MasterSwitchPreference : SwitchPreferenceCompat { constructor(context: Context, attrs: AttributeSet?, defStyleAttr: Int) : super(context, attrs, defStyleAttr) diff --git a/app/src/main/java/ac/mdiq/podcini/preferences/PlaybackPreferences.kt b/app/src/main/java/ac/mdiq/podcini/preferences/PlaybackPreferences.kt index 180aea3a..e6d1a7de 100644 --- a/app/src/main/java/ac/mdiq/podcini/preferences/PlaybackPreferences.kt +++ b/app/src/main/java/ac/mdiq/podcini/preferences/PlaybackPreferences.kt @@ -2,6 +2,7 @@ package ac.mdiq.podcini.preferences import ac.mdiq.podcini.playback.base.PlayerStatus import ac.mdiq.podcini.storage.DBReader +import ac.mdiq.podcini.storage.model.feed.FeedItem import ac.mdiq.podcini.storage.model.feed.FeedMedia import ac.mdiq.podcini.storage.model.feed.FeedPreferences import ac.mdiq.podcini.storage.model.playback.MediaType @@ -132,13 +133,14 @@ class PlaybackPreferences private constructor() : OnSharedPreferenceChangeListen } @JvmStatic - fun writeMediaPlaying(playable: Playable?, playerStatus: PlayerStatus) { + fun writeMediaPlaying(playable: Playable?, playerStatus: PlayerStatus, item: FeedItem? = null) { Log.d(TAG, "Writing playback preferences") val editor = prefs.edit() if (playable == null) { writeNoMediaPlaying() } else { +// Log.d(TAG, "writeMediaPlaying ${playable.getPlayableType()}") editor.putLong(PREF_CURRENTLY_PLAYING_MEDIA_TYPE, playable.getPlayableType().toLong()) editor.putBoolean(PREF_CURRENT_EPISODE_IS_VIDEO, playable.getMediaType() == MediaType.VIDEO) if (playable is FeedMedia) { @@ -190,6 +192,7 @@ class PlaybackPreferences private constructor() : OnSharedPreferenceChangeListen @JvmStatic fun createInstanceFromPreferences(context: Context): Playable? { val currentlyPlayingMedia = currentlyPlayingMediaType + Log.d(TAG, "currentlyPlayingMedia: $currentlyPlayingMedia") if (currentlyPlayingMedia != NO_MEDIA_PLAYING) { val prefs = PreferenceManager.getDefaultSharedPreferences(context.applicationContext) return createInstanceFromPreferences(currentlyPlayingMedia.toInt(), prefs) diff --git a/app/src/main/java/ac/mdiq/podcini/preferences/PreferenceUpgrader.kt b/app/src/main/java/ac/mdiq/podcini/preferences/PreferenceUpgrader.kt index 864b20b2..3db9f475 100644 --- a/app/src/main/java/ac/mdiq/podcini/preferences/PreferenceUpgrader.kt +++ b/app/src/main/java/ac/mdiq/podcini/preferences/PreferenceUpgrader.kt @@ -12,8 +12,8 @@ import ac.mdiq.podcini.preferences.SleepTimerPreferences.setLastTimer import ac.mdiq.podcini.util.error.CrashReportWriter.Companion.file import ac.mdiq.podcini.ui.fragment.AllEpisodesFragment import ac.mdiq.podcini.ui.fragment.QueueFragment -import ac.mdiq.podcini.ui.fragment.swipeactions.SwipeAction -import ac.mdiq.podcini.ui.fragment.swipeactions.SwipeActions +import ac.mdiq.podcini.ui.actions.swipeactions.SwipeAction +import ac.mdiq.podcini.ui.actions.swipeactions.SwipeActions import ac.mdiq.podcini.preferences.UserPreferences.EnqueueLocation import ac.mdiq.podcini.preferences.UserPreferences.episodeCleanupValue import ac.mdiq.podcini.preferences.UserPreferences.isAllowMobileAutoDownload diff --git a/app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/AutoDownloadPreferencesFragment.kt b/app/src/main/java/ac/mdiq/podcini/preferences/fragments/AutoDownloadPreferencesFragment.kt similarity index 99% rename from app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/AutoDownloadPreferencesFragment.kt rename to app/src/main/java/ac/mdiq/podcini/preferences/fragments/AutoDownloadPreferencesFragment.kt index 5df87c79..5d744cfe 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/AutoDownloadPreferencesFragment.kt +++ b/app/src/main/java/ac/mdiq/podcini/preferences/fragments/AutoDownloadPreferencesFragment.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.fragment.preferences +package ac.mdiq.podcini.preferences.fragments import android.annotation.SuppressLint import android.app.Activity diff --git a/app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/DownloadsPreferencesFragment.kt b/app/src/main/java/ac/mdiq/podcini/preferences/fragments/DownloadsPreferencesFragment.kt similarity index 98% rename from app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/DownloadsPreferencesFragment.kt rename to app/src/main/java/ac/mdiq/podcini/preferences/fragments/DownloadsPreferencesFragment.kt index 47016c4d..726762a9 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/DownloadsPreferencesFragment.kt +++ b/app/src/main/java/ac/mdiq/podcini/preferences/fragments/DownloadsPreferencesFragment.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.fragment.preferences +package ac.mdiq.podcini.preferences.fragments import android.content.DialogInterface import android.content.SharedPreferences diff --git a/app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/ImportExportPreferencesFragment.kt b/app/src/main/java/ac/mdiq/podcini/preferences/fragments/ImportExportPreferencesFragment.kt similarity index 99% rename from app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/ImportExportPreferencesFragment.kt rename to app/src/main/java/ac/mdiq/podcini/preferences/fragments/ImportExportPreferencesFragment.kt index a0991f02..7f7e4f5a 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/ImportExportPreferencesFragment.kt +++ b/app/src/main/java/ac/mdiq/podcini/preferences/fragments/ImportExportPreferencesFragment.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.fragment.preferences +package ac.mdiq.podcini.preferences.fragments import android.app.Activity import android.app.ProgressDialog diff --git a/app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/MainPreferencesFragment.kt b/app/src/main/java/ac/mdiq/podcini/preferences/fragments/MainPreferencesFragment.kt similarity index 88% rename from app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/MainPreferencesFragment.kt rename to app/src/main/java/ac/mdiq/podcini/preferences/fragments/MainPreferencesFragment.kt index 7b30f662..cf610e23 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/MainPreferencesFragment.kt +++ b/app/src/main/java/ac/mdiq/podcini/preferences/fragments/MainPreferencesFragment.kt @@ -1,5 +1,11 @@ -package ac.mdiq.podcini.ui.fragment.preferences +package ac.mdiq.podcini.preferences.fragments +import ac.mdiq.podcini.R +import ac.mdiq.podcini.ui.activity.BugReportActivity +import ac.mdiq.podcini.ui.activity.PreferenceActivity +import ac.mdiq.podcini.ui.activity.PreferenceActivity.Companion.getTitleOfPage +import ac.mdiq.podcini.preferences.fragments.about.AboutFragment +import ac.mdiq.podcini.util.IntentUtils.openInBrowser import android.annotation.SuppressLint import android.content.Intent import android.graphics.PorterDuff @@ -9,17 +15,6 @@ import androidx.appcompat.app.AppCompatActivity import androidx.preference.Preference import androidx.preference.PreferenceFragmentCompat import com.bytehamster.lib.preferencesearch.SearchPreference -import ac.mdiq.podcini.R -import ac.mdiq.podcini.ui.activity.BugReportActivity -import ac.mdiq.podcini.ui.activity.PreferenceActivity -import ac.mdiq.podcini.ui.activity.PreferenceActivity.Companion.getTitleOfPage -import ac.mdiq.podcini.util.IntentUtils.openInBrowser -import ac.mdiq.podcini.ui.fragment.preferences.about.AboutFragment -import org.apache.commons.io.IOUtils -import org.apache.commons.lang3.ArrayUtils -import java.io.IOException -import java.nio.charset.StandardCharsets -import java.util.* class MainPreferencesFragment : PreferenceFragmentCompat() { override fun onCreatePreferences(savedInstanceState: Bundle?, rootKey: String?) { @@ -122,24 +117,24 @@ class MainPreferencesFragment : PreferenceFragmentCompat() { } } - private val localizedWebsiteLink: String - get() { - try { - requireContext().assets.open("website-languages.txt").use { `is` -> - val languages = IOUtils.toString(`is`, StandardCharsets.UTF_8.name()).split("\n".toRegex()) - .dropLastWhile { it.isEmpty() } - .toTypedArray() - val deviceLanguage = Locale.getDefault().language - return if (ArrayUtils.contains(languages, deviceLanguage) && "en" != deviceLanguage) { - "https://podcini.org/$deviceLanguage" - } else { - "https://podcini.org" - } - } - } catch (e: IOException) { - throw RuntimeException(e) - } - } +// private val localizedWebsiteLink: String +// get() { +// try { +// requireContext().assets.open("website-languages.txt").use { `is` -> +// val languages = IOUtils.toString(`is`, StandardCharsets.UTF_8.name()).split("\n".toRegex()) +// .dropLastWhile { it.isEmpty() } +// .toTypedArray() +// val deviceLanguage = Locale.getDefault().language +// return if (ArrayUtils.contains(languages, deviceLanguage) && "en" != deviceLanguage) { +// "https://podcini.org/$deviceLanguage" +// } else { +// "https://podcini.org" +// } +// } +// } catch (e: IOException) { +// throw RuntimeException(e) +// } +// } private fun setupSearch() { val searchPreference = findPreference("searchPreference") diff --git a/app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/NotificationPreferencesFragment.kt b/app/src/main/java/ac/mdiq/podcini/preferences/fragments/NotificationPreferencesFragment.kt similarity index 81% rename from app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/NotificationPreferencesFragment.kt rename to app/src/main/java/ac/mdiq/podcini/preferences/fragments/NotificationPreferencesFragment.kt index d4c9074c..6e8b10c1 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/NotificationPreferencesFragment.kt +++ b/app/src/main/java/ac/mdiq/podcini/preferences/fragments/NotificationPreferencesFragment.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.fragment.preferences +package ac.mdiq.podcini.preferences.fragments import android.os.Bundle import androidx.preference.Preference @@ -19,7 +19,7 @@ class NotificationPreferencesFragment : PreferenceFragmentCompat() { } private fun setUpScreen() { - findPreference(PREF_GPODNET_NOTIFICATIONS)!!.isEnabled = + findPreference(ac.mdiq.podcini.preferences.fragments.NotificationPreferencesFragment.Companion.PREF_GPODNET_NOTIFICATIONS)!!.isEnabled = SynchronizationSettings.isProviderConnected } diff --git a/app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/PlaybackPreferencesFragment.kt b/app/src/main/java/ac/mdiq/podcini/preferences/fragments/PlaybackPreferencesFragment.kt similarity index 99% rename from app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/PlaybackPreferencesFragment.kt rename to app/src/main/java/ac/mdiq/podcini/preferences/fragments/PlaybackPreferencesFragment.kt index 173c9316..d9ef558c 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/PlaybackPreferencesFragment.kt +++ b/app/src/main/java/ac/mdiq/podcini/preferences/fragments/PlaybackPreferencesFragment.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.fragment.preferences +package ac.mdiq.podcini.preferences.fragments import ac.mdiq.podcini.R import ac.mdiq.podcini.preferences.UsageStatistics diff --git a/app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/SwipePreferencesFragment.kt b/app/src/main/java/ac/mdiq/podcini/preferences/fragments/SwipePreferencesFragment.kt similarity index 98% rename from app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/SwipePreferencesFragment.kt rename to app/src/main/java/ac/mdiq/podcini/preferences/fragments/SwipePreferencesFragment.kt index 756ca250..db9cb8f5 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/SwipePreferencesFragment.kt +++ b/app/src/main/java/ac/mdiq/podcini/preferences/fragments/SwipePreferencesFragment.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.fragment.preferences +package ac.mdiq.podcini.preferences.fragments import android.os.Bundle import androidx.preference.Preference diff --git a/app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/UserInterfacePreferencesFragment.kt b/app/src/main/java/ac/mdiq/podcini/preferences/fragments/UserInterfacePreferencesFragment.kt similarity index 98% rename from app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/UserInterfacePreferencesFragment.kt rename to app/src/main/java/ac/mdiq/podcini/preferences/fragments/UserInterfacePreferencesFragment.kt index 69e9353b..7dc57e66 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/UserInterfacePreferencesFragment.kt +++ b/app/src/main/java/ac/mdiq/podcini/preferences/fragments/UserInterfacePreferencesFragment.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.fragment.preferences +package ac.mdiq.podcini.preferences.fragments import ac.mdiq.podcini.R import ac.mdiq.podcini.preferences.UserPreferences @@ -7,7 +7,6 @@ import ac.mdiq.podcini.preferences.UserPreferences.setShowRemainTimeSetting import ac.mdiq.podcini.ui.activity.PreferenceActivity import ac.mdiq.podcini.ui.dialog.DrawerPreferencesDialog import ac.mdiq.podcini.ui.dialog.FeedSortDialog -import ac.mdiq.podcini.ui.dialog.SubscriptionsFilterDialog import ac.mdiq.podcini.util.event.PlayerStatusEvent import ac.mdiq.podcini.util.event.UnreadItemsUpdateEvent import android.content.Context diff --git a/app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/about/AboutFragment.kt b/app/src/main/java/ac/mdiq/podcini/preferences/fragments/about/AboutFragment.kt similarity index 98% rename from app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/about/AboutFragment.kt rename to app/src/main/java/ac/mdiq/podcini/preferences/fragments/about/AboutFragment.kt index 8df12cbd..a3a314ba 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/about/AboutFragment.kt +++ b/app/src/main/java/ac/mdiq/podcini/preferences/fragments/about/AboutFragment.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.fragment.preferences.about +package ac.mdiq.podcini.preferences.fragments.about import android.annotation.SuppressLint import android.content.ClipData diff --git a/app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/about/ContributorsPagerFragment.kt b/app/src/main/java/ac/mdiq/podcini/preferences/fragments/about/ContributorsPagerFragment.kt similarity index 97% rename from app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/about/ContributorsPagerFragment.kt rename to app/src/main/java/ac/mdiq/podcini/preferences/fragments/about/ContributorsPagerFragment.kt index c7479f1c..34e9e8c3 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/about/ContributorsPagerFragment.kt +++ b/app/src/main/java/ac/mdiq/podcini/preferences/fragments/about/ContributorsPagerFragment.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.fragment.preferences.about +package ac.mdiq.podcini.preferences.fragments.about import ac.mdiq.podcini.R import ac.mdiq.podcini.databinding.PagerFragmentBinding diff --git a/app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/about/DevelopersFragment.kt b/app/src/main/java/ac/mdiq/podcini/preferences/fragments/about/DevelopersFragment.kt similarity index 97% rename from app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/about/DevelopersFragment.kt rename to app/src/main/java/ac/mdiq/podcini/preferences/fragments/about/DevelopersFragment.kt index 368a6076..bb2e73c5 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/about/DevelopersFragment.kt +++ b/app/src/main/java/ac/mdiq/podcini/preferences/fragments/about/DevelopersFragment.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.fragment.preferences.about +package ac.mdiq.podcini.preferences.fragments.about import android.R.color import android.os.Bundle diff --git a/app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/about/LicensesFragment.kt b/app/src/main/java/ac/mdiq/podcini/preferences/fragments/about/LicensesFragment.kt similarity index 98% rename from app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/about/LicensesFragment.kt rename to app/src/main/java/ac/mdiq/podcini/preferences/fragments/about/LicensesFragment.kt index dfebba66..60113aaa 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/about/LicensesFragment.kt +++ b/app/src/main/java/ac/mdiq/podcini/preferences/fragments/about/LicensesFragment.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.fragment.preferences.about +package ac.mdiq.podcini.preferences.fragments.about import android.content.DialogInterface import android.os.Bundle diff --git a/app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/about/SpecialThanksFragment.kt b/app/src/main/java/ac/mdiq/podcini/preferences/fragments/about/SpecialThanksFragment.kt similarity index 97% rename from app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/about/SpecialThanksFragment.kt rename to app/src/main/java/ac/mdiq/podcini/preferences/fragments/about/SpecialThanksFragment.kt index a209093e..28b89108 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/about/SpecialThanksFragment.kt +++ b/app/src/main/java/ac/mdiq/podcini/preferences/fragments/about/SpecialThanksFragment.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.fragment.preferences.about +package ac.mdiq.podcini.preferences.fragments.about import android.R.color import android.os.Bundle diff --git a/app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/about/TranslatorsFragment.kt b/app/src/main/java/ac/mdiq/podcini/preferences/fragments/about/TranslatorsFragment.kt similarity index 97% rename from app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/about/TranslatorsFragment.kt rename to app/src/main/java/ac/mdiq/podcini/preferences/fragments/about/TranslatorsFragment.kt index 56f45de7..778e2b1a 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/about/TranslatorsFragment.kt +++ b/app/src/main/java/ac/mdiq/podcini/preferences/fragments/about/TranslatorsFragment.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.fragment.preferences.about +package ac.mdiq.podcini.preferences.fragments.about import android.R.color import android.os.Bundle diff --git a/app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/dialog/PreferenceListDialog.kt b/app/src/main/java/ac/mdiq/podcini/preferences/fragments/dialog/PreferenceListDialog.kt similarity index 96% rename from app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/dialog/PreferenceListDialog.kt rename to app/src/main/java/ac/mdiq/podcini/preferences/fragments/dialog/PreferenceListDialog.kt index 18e888cf..001a60ad 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/dialog/PreferenceListDialog.kt +++ b/app/src/main/java/ac/mdiq/podcini/preferences/fragments/dialog/PreferenceListDialog.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.fragment.preferences.dialog +package ac.mdiq.podcini.preferences.fragments.dialog import android.content.Context import android.content.DialogInterface diff --git a/app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/dialog/PreferenceSwitchDialog.kt b/app/src/main/java/ac/mdiq/podcini/preferences/fragments/dialog/PreferenceSwitchDialog.kt similarity index 96% rename from app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/dialog/PreferenceSwitchDialog.kt rename to app/src/main/java/ac/mdiq/podcini/preferences/fragments/dialog/PreferenceSwitchDialog.kt index a51fd683..2751e357 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/dialog/PreferenceSwitchDialog.kt +++ b/app/src/main/java/ac/mdiq/podcini/preferences/fragments/dialog/PreferenceSwitchDialog.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.fragment.preferences.dialog +package ac.mdiq.podcini.preferences.fragments.dialog import ac.mdiq.podcini.R import ac.mdiq.podcini.databinding.DialogSwitchPreferenceBinding diff --git a/app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/synchronization/GpodderAuthenticationFragment.kt b/app/src/main/java/ac/mdiq/podcini/preferences/fragments/synchronization/GpodderAuthenticationFragment.kt similarity index 98% rename from app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/synchronization/GpodderAuthenticationFragment.kt rename to app/src/main/java/ac/mdiq/podcini/preferences/fragments/synchronization/GpodderAuthenticationFragment.kt index a6e13fe9..1b427a84 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/synchronization/GpodderAuthenticationFragment.kt +++ b/app/src/main/java/ac/mdiq/podcini/preferences/fragments/synchronization/GpodderAuthenticationFragment.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.fragment.preferences.synchronization +package ac.mdiq.podcini.preferences.fragments.synchronization import ac.mdiq.podcini.R import ac.mdiq.podcini.databinding.* @@ -8,7 +8,7 @@ import ac.mdiq.podcini.net.sync.SynchronizationProviderViewData import ac.mdiq.podcini.net.sync.SynchronizationSettings import ac.mdiq.podcini.net.sync.gpoddernet.GpodnetService import ac.mdiq.podcini.net.sync.gpoddernet.model.GpodnetDevice -import ac.mdiq.podcini.service.download.PodciniHttpClient.getHttpClient +import ac.mdiq.podcini.net.download.service.PodciniHttpClient.getHttpClient import ac.mdiq.podcini.util.FileNameGenerator.generateFileName import android.app.Dialog import android.content.Context diff --git a/app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/synchronization/NextcloudAuthenticationFragment.kt b/app/src/main/java/ac/mdiq/podcini/preferences/fragments/synchronization/NextcloudAuthenticationFragment.kt similarity index 96% rename from app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/synchronization/NextcloudAuthenticationFragment.kt rename to app/src/main/java/ac/mdiq/podcini/preferences/fragments/synchronization/NextcloudAuthenticationFragment.kt index 039ea99e..c757c787 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/synchronization/NextcloudAuthenticationFragment.kt +++ b/app/src/main/java/ac/mdiq/podcini/preferences/fragments/synchronization/NextcloudAuthenticationFragment.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.fragment.preferences.synchronization +package ac.mdiq.podcini.preferences.fragments.synchronization import android.app.Dialog import android.content.DialogInterface @@ -7,7 +7,7 @@ import android.view.View import androidx.fragment.app.DialogFragment import com.google.android.material.dialog.MaterialAlertDialogBuilder import ac.mdiq.podcini.R -import ac.mdiq.podcini.service.download.PodciniHttpClient.getHttpClient +import ac.mdiq.podcini.net.download.service.PodciniHttpClient.getHttpClient import ac.mdiq.podcini.net.sync.SyncService import ac.mdiq.podcini.net.sync.SynchronizationCredentials import ac.mdiq.podcini.net.sync.SynchronizationProviderViewData diff --git a/app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/synchronization/SynchronizationPreferencesFragment.kt b/app/src/main/java/ac/mdiq/podcini/preferences/fragments/synchronization/SynchronizationPreferencesFragment.kt similarity index 99% rename from app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/synchronization/SynchronizationPreferencesFragment.kt rename to app/src/main/java/ac/mdiq/podcini/preferences/fragments/synchronization/SynchronizationPreferencesFragment.kt index 7a63ff54..b85d5489 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/fragment/preferences/synchronization/SynchronizationPreferencesFragment.kt +++ b/app/src/main/java/ac/mdiq/podcini/preferences/fragments/synchronization/SynchronizationPreferencesFragment.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.fragment.preferences.synchronization +package ac.mdiq.podcini.preferences.fragments.synchronization import android.app.Activity import android.content.DialogInterface diff --git a/app/src/main/java/ac/mdiq/podcini/receiver/MediaButtonReceiver.kt b/app/src/main/java/ac/mdiq/podcini/receiver/MediaButtonReceiver.kt index 1941da44..85b8489f 100644 --- a/app/src/main/java/ac/mdiq/podcini/receiver/MediaButtonReceiver.kt +++ b/app/src/main/java/ac/mdiq/podcini/receiver/MediaButtonReceiver.kt @@ -59,8 +59,7 @@ class MediaButtonReceiver : BroadcastReceiver() { @JvmStatic fun createPendingIntent(context: Context, eventCode: Int): PendingIntent { - return PendingIntent.getBroadcast(context, eventCode, createIntent(context, eventCode), - (if (Build.VERSION.SDK_INT >= 23) PendingIntent.FLAG_IMMUTABLE else 0)) + return PendingIntent.getBroadcast(context, eventCode, createIntent(context, eventCode), PendingIntent.FLAG_IMMUTABLE) } } } diff --git a/app/src/main/java/ac/mdiq/podcini/storage/DBReader.kt b/app/src/main/java/ac/mdiq/podcini/storage/DBReader.kt index 77e6eea6..3640b16d 100644 --- a/app/src/main/java/ac/mdiq/podcini/storage/DBReader.kt +++ b/app/src/main/java/ac/mdiq/podcini/storage/DBReader.kt @@ -19,7 +19,6 @@ import ac.mdiq.podcini.preferences.UserPreferences import ac.mdiq.podcini.preferences.UserPreferences.feedCounterSetting import ac.mdiq.podcini.preferences.UserPreferences.feedOrder import ac.mdiq.podcini.storage.model.feed.FeedPreferences.Companion.TAG_ROOT -import java.text.SimpleDateFormat import java.util.* import kotlin.math.min @@ -247,10 +246,7 @@ object DBReader { @JvmStatic fun getQueueIDList(): LongList { Log.d(TAG, "getQueueIDList() called") -// val stackTraceElements = Thread.currentThread().stackTrace -// stackTraceElements.forEach { element -> -// println(element) -// } +// printStackTrce() val adapter = getInstance() adapter.open() @@ -668,10 +664,7 @@ object DBReader { fun loadDescriptionOfFeedItem(item: FeedItem) { Log.d(TAG, "loadDescriptionOfFeedItem() called with: item = [$item]") // TODO: need to find out who are often calling this -// val stackTraceElements = Thread.currentThread().stackTrace -// stackTraceElements.forEach { element -> -// println(element) -// } +// printStackTrce() val adapter = getInstance() adapter.open() try { diff --git a/app/src/main/java/ac/mdiq/podcini/storage/DBTasks.kt b/app/src/main/java/ac/mdiq/podcini/storage/DBTasks.kt index b0a3d6bb..a7c9e54b 100644 --- a/app/src/main/java/ac/mdiq/podcini/storage/DBTasks.kt +++ b/app/src/main/java/ac/mdiq/podcini/storage/DBTasks.kt @@ -229,11 +229,11 @@ import java.util.concurrent.* // get the most recent date now, before we start changing the list // only used to add to IN_Box??? - val priorMostRecent = savedFeed.mostRecentItem - var priorMostRecentDate: Date? = Date() - if (priorMostRecent != null) { - priorMostRecentDate = priorMostRecent.getPubDate() - } +// val priorMostRecent = savedFeed.mostRecentItem +// var priorMostRecentDate: Date? = Date() +// if (priorMostRecent != null) { +// priorMostRecentDate = priorMostRecent.getPubDate() +// } // Look for new or updated Items for (idx in newFeed.items.indices) { diff --git a/app/src/main/java/ac/mdiq/podcini/storage/DBWriter.kt b/app/src/main/java/ac/mdiq/podcini/storage/DBWriter.kt index dc3168e3..5b7344fa 100644 --- a/app/src/main/java/ac/mdiq/podcini/storage/DBWriter.kt +++ b/app/src/main/java/ac/mdiq/podcini/storage/DBWriter.kt @@ -14,7 +14,7 @@ import ac.mdiq.podcini.feed.LocalFeedUpdater.updateFeed import ac.mdiq.podcini.preferences.PlaybackPreferences.Companion.createInstanceFromPreferences import ac.mdiq.podcini.preferences.PlaybackPreferences.Companion.currentlyPlayingFeedMediaId import ac.mdiq.podcini.preferences.PlaybackPreferences.Companion.writeNoMediaPlaying -import ac.mdiq.podcini.service.playback.PlaybackServiceInterface +import ac.mdiq.podcini.playback.service.PlaybackServiceInterface import ac.mdiq.podcini.storage.DBReader.getFeed import ac.mdiq.podcini.storage.DBReader.getFeedItem import ac.mdiq.podcini.storage.DBReader.getFeedItemList @@ -33,7 +33,7 @@ import ac.mdiq.podcini.util.event.QueueEvent.Companion.cleared import ac.mdiq.podcini.util.event.QueueEvent.Companion.irreversibleRemoved import ac.mdiq.podcini.util.event.QueueEvent.Companion.moved import ac.mdiq.podcini.util.event.QueueEvent.Companion.removed -import ac.mdiq.podcini.playback.event.PlaybackHistoryEvent +import ac.mdiq.podcini.util.event.playback.PlaybackHistoryEvent import ac.mdiq.podcini.storage.model.download.DownloadResult import ac.mdiq.podcini.storage.model.feed.* import ac.mdiq.podcini.net.download.serviceinterface.DownloadServiceInterface diff --git a/app/src/main/java/ac/mdiq/podcini/storage/database/PodDBAdapter.kt b/app/src/main/java/ac/mdiq/podcini/storage/database/PodDBAdapter.kt index f8398b32..7b8e1874 100644 --- a/app/src/main/java/ac/mdiq/podcini/storage/database/PodDBAdapter.kt +++ b/app/src/main/java/ac/mdiq/podcini/storage/database/PodDBAdapter.kt @@ -188,8 +188,7 @@ class PodDBAdapter private constructor() { val values = ContentValues() values.put(KEY_PLAYBACK_COMPLETION_DATE, media.getPlaybackCompletionDate()!!.time) values.put(KEY_PLAYED_DURATION, media.playedDuration) - db.update(TABLE_NAME_FEED_MEDIA, values, "$KEY_ID=?", - arrayOf(media.id.toString())) + db.update(TABLE_NAME_FEED_MEDIA, values, "$KEY_ID=?", arrayOf(media.id.toString())) } else { Log.e(TAG, "setFeedMediaPlaybackCompletionDate: ID of media was 0") } diff --git a/app/src/main/java/ac/mdiq/podcini/ui/fragment/actions/EpisodeMultiSelectActionHandler.kt b/app/src/main/java/ac/mdiq/podcini/ui/actions/EpisodeMultiSelectActionHandler.kt similarity index 99% rename from app/src/main/java/ac/mdiq/podcini/ui/fragment/actions/EpisodeMultiSelectActionHandler.kt rename to app/src/main/java/ac/mdiq/podcini/ui/actions/EpisodeMultiSelectActionHandler.kt index d49f4003..b5e5506d 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/fragment/actions/EpisodeMultiSelectActionHandler.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/actions/EpisodeMultiSelectActionHandler.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.fragment.actions +package ac.mdiq.podcini.ui.actions import ac.mdiq.podcini.ui.activity.MainActivity import android.util.Log diff --git a/app/src/main/java/ac/mdiq/podcini/ui/fragment/actions/FeedMultiSelectActionHandler.kt b/app/src/main/java/ac/mdiq/podcini/ui/actions/FeedMultiSelectActionHandler.kt similarity index 95% rename from app/src/main/java/ac/mdiq/podcini/ui/fragment/actions/FeedMultiSelectActionHandler.kt rename to app/src/main/java/ac/mdiq/podcini/ui/actions/FeedMultiSelectActionHandler.kt index 2c413819..285f0a8d 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/fragment/actions/FeedMultiSelectActionHandler.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/actions/FeedMultiSelectActionHandler.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.fragment.actions +package ac.mdiq.podcini.ui.actions import ac.mdiq.podcini.ui.activity.MainActivity import android.content.DialogInterface @@ -11,16 +11,13 @@ import com.google.android.material.snackbar.Snackbar import ac.mdiq.podcini.R import ac.mdiq.podcini.storage.DBWriter import ac.mdiq.podcini.databinding.PlaybackSpeedFeedSettingDialogBinding +import ac.mdiq.podcini.preferences.fragments.dialog.PreferenceListDialog +import ac.mdiq.podcini.preferences.fragments.dialog.PreferenceSwitchDialog import ac.mdiq.podcini.ui.dialog.RemoveFeedDialog import ac.mdiq.podcini.ui.dialog.TagSettingsDialog -import ac.mdiq.podcini.ui.fragment.preferences.dialog.PreferenceListDialog -import ac.mdiq.podcini.ui.fragment.preferences.dialog.PreferenceSwitchDialog import ac.mdiq.podcini.storage.model.feed.Feed import ac.mdiq.podcini.storage.model.feed.FeedPreferences -import ac.mdiq.podcini.ui.fragment.SubscriptionFragment -import ac.mdiq.podcini.util.event.FeedTagsChangedEvent import androidx.media3.common.util.UnstableApi -import org.greenrobot.eventbus.EventBus import java.util.* @UnstableApi diff --git a/app/src/main/java/ac/mdiq/podcini/ui/adapter/actionbutton/CancelDownloadActionButton.kt b/app/src/main/java/ac/mdiq/podcini/ui/actions/actionbutton/CancelDownloadActionButton.kt similarity index 95% rename from app/src/main/java/ac/mdiq/podcini/ui/adapter/actionbutton/CancelDownloadActionButton.kt rename to app/src/main/java/ac/mdiq/podcini/ui/actions/actionbutton/CancelDownloadActionButton.kt index 3cd7e938..d1b37fba 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/adapter/actionbutton/CancelDownloadActionButton.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/actions/actionbutton/CancelDownloadActionButton.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.adapter.actionbutton +package ac.mdiq.podcini.ui.actions.actionbutton import android.content.Context import androidx.annotation.DrawableRes diff --git a/app/src/main/java/ac/mdiq/podcini/ui/adapter/actionbutton/DeleteActionButton.kt b/app/src/main/java/ac/mdiq/podcini/ui/actions/actionbutton/DeleteActionButton.kt similarity index 95% rename from app/src/main/java/ac/mdiq/podcini/ui/adapter/actionbutton/DeleteActionButton.kt rename to app/src/main/java/ac/mdiq/podcini/ui/actions/actionbutton/DeleteActionButton.kt index 513fd70d..78a621fe 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/adapter/actionbutton/DeleteActionButton.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/actions/actionbutton/DeleteActionButton.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.adapter.actionbutton +package ac.mdiq.podcini.ui.actions.actionbutton import android.content.Context import android.view.View diff --git a/app/src/main/java/ac/mdiq/podcini/ui/adapter/actionbutton/DownloadActionButton.kt b/app/src/main/java/ac/mdiq/podcini/ui/actions/actionbutton/DownloadActionButton.kt similarity index 98% rename from app/src/main/java/ac/mdiq/podcini/ui/adapter/actionbutton/DownloadActionButton.kt rename to app/src/main/java/ac/mdiq/podcini/ui/actions/actionbutton/DownloadActionButton.kt index e0e9a67a..3c24c2f1 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/adapter/actionbutton/DownloadActionButton.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/actions/actionbutton/DownloadActionButton.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.adapter.actionbutton +package ac.mdiq.podcini.ui.actions.actionbutton import android.content.Context import android.content.DialogInterface diff --git a/app/src/main/java/ac/mdiq/podcini/ui/adapter/actionbutton/ItemActionButton.kt b/app/src/main/java/ac/mdiq/podcini/ui/actions/actionbutton/ItemActionButton.kt similarity index 97% rename from app/src/main/java/ac/mdiq/podcini/ui/adapter/actionbutton/ItemActionButton.kt rename to app/src/main/java/ac/mdiq/podcini/ui/actions/actionbutton/ItemActionButton.kt index c434e18c..6b3dd54c 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/adapter/actionbutton/ItemActionButton.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/actions/actionbutton/ItemActionButton.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.adapter.actionbutton +package ac.mdiq.podcini.ui.actions.actionbutton import ac.mdiq.podcini.net.download.serviceinterface.DownloadServiceInterface import ac.mdiq.podcini.preferences.UserPreferences.isStreamOverDownload diff --git a/app/src/main/java/ac/mdiq/podcini/ui/adapter/actionbutton/MarkAsPlayedActionButton.kt b/app/src/main/java/ac/mdiq/podcini/ui/actions/actionbutton/MarkAsPlayedActionButton.kt similarity index 94% rename from app/src/main/java/ac/mdiq/podcini/ui/adapter/actionbutton/MarkAsPlayedActionButton.kt rename to app/src/main/java/ac/mdiq/podcini/ui/actions/actionbutton/MarkAsPlayedActionButton.kt index a1413138..3d9c0580 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/adapter/actionbutton/MarkAsPlayedActionButton.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/actions/actionbutton/MarkAsPlayedActionButton.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.adapter.actionbutton +package ac.mdiq.podcini.ui.actions.actionbutton import android.content.Context import android.view.View diff --git a/app/src/main/java/ac/mdiq/podcini/ui/adapter/actionbutton/PauseActionButton.kt b/app/src/main/java/ac/mdiq/podcini/ui/actions/actionbutton/PauseActionButton.kt similarity index 94% rename from app/src/main/java/ac/mdiq/podcini/ui/adapter/actionbutton/PauseActionButton.kt rename to app/src/main/java/ac/mdiq/podcini/ui/actions/actionbutton/PauseActionButton.kt index cf1b07a5..9d22be8e 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/adapter/actionbutton/PauseActionButton.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/actions/actionbutton/PauseActionButton.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.adapter.actionbutton +package ac.mdiq.podcini.ui.actions.actionbutton import android.content.Context import android.view.KeyEvent diff --git a/app/src/main/java/ac/mdiq/podcini/ui/adapter/actionbutton/PlayActionButton.kt b/app/src/main/java/ac/mdiq/podcini/ui/actions/actionbutton/PlayActionButton.kt similarity index 80% rename from app/src/main/java/ac/mdiq/podcini/ui/adapter/actionbutton/PlayActionButton.kt rename to app/src/main/java/ac/mdiq/podcini/ui/actions/actionbutton/PlayActionButton.kt index f2b75406..c4d34318 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/adapter/actionbutton/PlayActionButton.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/actions/actionbutton/PlayActionButton.kt @@ -1,14 +1,16 @@ -package ac.mdiq.podcini.ui.adapter.actionbutton +package ac.mdiq.podcini.ui.actions.actionbutton import android.content.Context import androidx.media3.common.util.UnstableApi import ac.mdiq.podcini.R -import ac.mdiq.podcini.service.playback.PlaybackService.Companion.getPlayerActivityIntent +import ac.mdiq.podcini.playback.service.PlaybackService.Companion.getPlayerActivityIntent import ac.mdiq.podcini.storage.DBTasks import ac.mdiq.podcini.playback.PlaybackServiceStarter import ac.mdiq.podcini.storage.model.feed.FeedItem import ac.mdiq.podcini.storage.model.playback.MediaType +import ac.mdiq.podcini.util.event.playback.StartPlayEvent import android.util.Log +import org.greenrobot.eventbus.EventBus class PlayActionButton(item: FeedItem) : ItemActionButton(item) { override fun getLabel(): Int { @@ -24,6 +26,8 @@ class PlayActionButton(item: FeedItem) : ItemActionButton(item) { DBTasks.notifyMissingFeedMediaFile(context, media) return } + + EventBus.getDefault().post(StartPlayEvent(item)) PlaybackServiceStarter(context, media) .callEvenIfRunning(true) .start() diff --git a/app/src/main/java/ac/mdiq/podcini/ui/adapter/actionbutton/PlayLocalActionButton.kt b/app/src/main/java/ac/mdiq/podcini/ui/actions/actionbutton/PlayLocalActionButton.kt similarity index 88% rename from app/src/main/java/ac/mdiq/podcini/ui/adapter/actionbutton/PlayLocalActionButton.kt rename to app/src/main/java/ac/mdiq/podcini/ui/actions/actionbutton/PlayLocalActionButton.kt index 252f8a98..696ffad5 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/adapter/actionbutton/PlayLocalActionButton.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/actions/actionbutton/PlayLocalActionButton.kt @@ -1,9 +1,9 @@ -package ac.mdiq.podcini.ui.adapter.actionbutton +package ac.mdiq.podcini.ui.actions.actionbutton import android.content.Context import androidx.media3.common.util.UnstableApi import ac.mdiq.podcini.R -import ac.mdiq.podcini.service.playback.PlaybackService.Companion.getPlayerActivityIntent +import ac.mdiq.podcini.playback.service.PlaybackService.Companion.getPlayerActivityIntent import ac.mdiq.podcini.playback.PlaybackServiceStarter import ac.mdiq.podcini.storage.model.feed.FeedItem import ac.mdiq.podcini.storage.model.playback.MediaType diff --git a/app/src/main/java/ac/mdiq/podcini/ui/adapter/actionbutton/StreamActionButton.kt b/app/src/main/java/ac/mdiq/podcini/ui/actions/actionbutton/StreamActionButton.kt similarity index 75% rename from app/src/main/java/ac/mdiq/podcini/ui/adapter/actionbutton/StreamActionButton.kt rename to app/src/main/java/ac/mdiq/podcini/ui/actions/actionbutton/StreamActionButton.kt index e7f88e88..ddab6132 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/adapter/actionbutton/StreamActionButton.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/actions/actionbutton/StreamActionButton.kt @@ -1,36 +1,42 @@ -package ac.mdiq.podcini.ui.adapter.actionbutton +package ac.mdiq.podcini.ui.actions.actionbutton import android.content.Context import androidx.media3.common.util.UnstableApi import ac.mdiq.podcini.R import ac.mdiq.podcini.preferences.UsageStatistics import ac.mdiq.podcini.preferences.UsageStatistics.logAction -import ac.mdiq.podcini.service.playback.PlaybackService.Companion.getPlayerActivityIntent +import ac.mdiq.podcini.playback.service.PlaybackService.Companion.getPlayerActivityIntent import ac.mdiq.podcini.util.NetworkUtils.isStreamingAllowed import ac.mdiq.podcini.playback.PlaybackServiceStarter import ac.mdiq.podcini.ui.dialog.StreamingConfirmationDialog import ac.mdiq.podcini.storage.model.feed.FeedItem import ac.mdiq.podcini.storage.model.playback.MediaType import ac.mdiq.podcini.storage.model.playback.RemoteMedia +import ac.mdiq.podcini.util.event.playback.StartPlayEvent +import android.util.Log +import org.greenrobot.eventbus.EventBus class StreamActionButton(item: FeedItem) : ItemActionButton(item) { override fun getLabel(): Int { return R.string.stream_label } + override fun getDrawable(): Int { return R.drawable.ic_stream } + @UnstableApi override fun onClick(context: Context) { -// TODO: test if (item.media == null) return - - val media = RemoteMedia(item) +// Log.d("StreamActionButton", "item.feed: ${item.feedId}") + val media = if (item.feedId > 0) item.media!! else RemoteMedia(item) logAction(UsageStatistics.ACTION_STREAM) if (!isStreamingAllowed) { StreamingConfirmationDialog(context, media).show() return } + + EventBus.getDefault().post(StartPlayEvent(item)) PlaybackServiceStarter(context, media) .shouldStreamThisTime(true) .callEvenIfRunning(true) diff --git a/app/src/main/java/ac/mdiq/podcini/ui/adapter/actionbutton/VisitWebsiteActionButton.kt b/app/src/main/java/ac/mdiq/podcini/ui/actions/actionbutton/VisitWebsiteActionButton.kt similarity index 93% rename from app/src/main/java/ac/mdiq/podcini/ui/adapter/actionbutton/VisitWebsiteActionButton.kt rename to app/src/main/java/ac/mdiq/podcini/ui/actions/actionbutton/VisitWebsiteActionButton.kt index 6f473cfb..79bbd896 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/adapter/actionbutton/VisitWebsiteActionButton.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/actions/actionbutton/VisitWebsiteActionButton.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.adapter.actionbutton +package ac.mdiq.podcini.ui.actions.actionbutton import android.content.Context import android.view.View diff --git a/app/src/main/java/ac/mdiq/podcini/ui/menuhandler/FeedItemMenuHandler.kt b/app/src/main/java/ac/mdiq/podcini/ui/actions/menuhandler/FeedItemMenuHandler.kt similarity index 99% rename from app/src/main/java/ac/mdiq/podcini/ui/menuhandler/FeedItemMenuHandler.kt rename to app/src/main/java/ac/mdiq/podcini/ui/actions/menuhandler/FeedItemMenuHandler.kt index 10322903..0a874ecc 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/menuhandler/FeedItemMenuHandler.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/actions/menuhandler/FeedItemMenuHandler.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.menuhandler +package ac.mdiq.podcini.ui.actions.menuhandler import ac.mdiq.podcini.R import ac.mdiq.podcini.net.sync.SynchronizationSettings @@ -6,7 +6,7 @@ import ac.mdiq.podcini.net.sync.model.EpisodeAction import ac.mdiq.podcini.net.sync.queue.SynchronizationQueueSink import ac.mdiq.podcini.preferences.PlaybackPreferences import ac.mdiq.podcini.receiver.MediaButtonReceiver -import ac.mdiq.podcini.service.playback.PlaybackServiceInterface +import ac.mdiq.podcini.playback.service.PlaybackServiceInterface import ac.mdiq.podcini.storage.DBWriter import ac.mdiq.podcini.storage.model.feed.FeedItem import ac.mdiq.podcini.storage.model.feed.FeedMedia diff --git a/app/src/main/java/ac/mdiq/podcini/ui/menuhandler/FeedMenuHandler.kt b/app/src/main/java/ac/mdiq/podcini/ui/actions/menuhandler/FeedMenuHandler.kt similarity index 96% rename from app/src/main/java/ac/mdiq/podcini/ui/menuhandler/FeedMenuHandler.kt rename to app/src/main/java/ac/mdiq/podcini/ui/actions/menuhandler/FeedMenuHandler.kt index 7c58a051..94a32dd7 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/menuhandler/FeedMenuHandler.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/actions/menuhandler/FeedMenuHandler.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.menuhandler +package ac.mdiq.podcini.ui.actions.menuhandler import ac.mdiq.podcini.R import ac.mdiq.podcini.storage.model.feed.Feed diff --git a/app/src/main/java/ac/mdiq/podcini/ui/menuhandler/MenuItemUtils.kt b/app/src/main/java/ac/mdiq/podcini/ui/actions/menuhandler/MenuItemUtils.kt similarity index 95% rename from app/src/main/java/ac/mdiq/podcini/ui/menuhandler/MenuItemUtils.kt rename to app/src/main/java/ac/mdiq/podcini/ui/actions/menuhandler/MenuItemUtils.kt index ab430d79..3372e512 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/menuhandler/MenuItemUtils.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/actions/menuhandler/MenuItemUtils.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.menuhandler +package ac.mdiq.podcini.ui.actions.menuhandler import android.view.Menu import android.view.MenuItem diff --git a/app/src/main/java/ac/mdiq/podcini/ui/fragment/swipeactions/AddToQueueSwipeAction.kt b/app/src/main/java/ac/mdiq/podcini/ui/actions/swipeactions/AddToQueueSwipeAction.kt similarity index 96% rename from app/src/main/java/ac/mdiq/podcini/ui/fragment/swipeactions/AddToQueueSwipeAction.kt rename to app/src/main/java/ac/mdiq/podcini/ui/actions/swipeactions/AddToQueueSwipeAction.kt index 6be177b4..7fa84144 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/fragment/swipeactions/AddToQueueSwipeAction.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/actions/swipeactions/AddToQueueSwipeAction.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.fragment.swipeactions +package ac.mdiq.podcini.ui.actions.swipeactions import android.content.Context import androidx.fragment.app.Fragment diff --git a/app/src/main/java/ac/mdiq/podcini/ui/fragment/swipeactions/DeleteSwipeAction.kt b/app/src/main/java/ac/mdiq/podcini/ui/actions/swipeactions/DeleteSwipeAction.kt similarity index 96% rename from app/src/main/java/ac/mdiq/podcini/ui/fragment/swipeactions/DeleteSwipeAction.kt rename to app/src/main/java/ac/mdiq/podcini/ui/actions/swipeactions/DeleteSwipeAction.kt index 2fd535be..f0baa067 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/fragment/swipeactions/DeleteSwipeAction.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/actions/swipeactions/DeleteSwipeAction.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.fragment.swipeactions +package ac.mdiq.podcini.ui.actions.swipeactions import android.content.Context import androidx.fragment.app.Fragment diff --git a/app/src/main/java/ac/mdiq/podcini/ui/fragment/swipeactions/MarkFavoriteSwipeAction.kt b/app/src/main/java/ac/mdiq/podcini/ui/actions/swipeactions/MarkFavoriteSwipeAction.kt similarity index 95% rename from app/src/main/java/ac/mdiq/podcini/ui/fragment/swipeactions/MarkFavoriteSwipeAction.kt rename to app/src/main/java/ac/mdiq/podcini/ui/actions/swipeactions/MarkFavoriteSwipeAction.kt index 5e4b6892..356ecd89 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/fragment/swipeactions/MarkFavoriteSwipeAction.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/actions/swipeactions/MarkFavoriteSwipeAction.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.fragment.swipeactions +package ac.mdiq.podcini.ui.actions.swipeactions import android.content.Context import androidx.fragment.app.Fragment diff --git a/app/src/main/java/ac/mdiq/podcini/ui/fragment/swipeactions/NoActionSwipeAction.kt b/app/src/main/java/ac/mdiq/podcini/ui/actions/swipeactions/NoActionSwipeAction.kt similarity index 83% rename from app/src/main/java/ac/mdiq/podcini/ui/fragment/swipeactions/NoActionSwipeAction.kt rename to app/src/main/java/ac/mdiq/podcini/ui/actions/swipeactions/NoActionSwipeAction.kt index d893e07f..b7c638d8 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/fragment/swipeactions/NoActionSwipeAction.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/actions/swipeactions/NoActionSwipeAction.kt @@ -1,13 +1,11 @@ -package ac.mdiq.podcini.ui.fragment.swipeactions +package ac.mdiq.podcini.ui.actions.swipeactions import android.content.Context import androidx.fragment.app.Fragment import androidx.media3.common.util.UnstableApi import ac.mdiq.podcini.R -import ac.mdiq.podcini.storage.DBWriter import ac.mdiq.podcini.storage.model.feed.FeedItem import ac.mdiq.podcini.storage.model.feed.FeedItemFilter -import ac.mdiq.podcini.ui.view.LocalDeleteModal.showLocalFeedDeleteWarningIfNecessary class NoActionSwipeAction : SwipeAction { override fun getId(): String { diff --git a/app/src/main/java/ac/mdiq/podcini/ui/fragment/swipeactions/RemoveFromHistorySwipeAction.kt b/app/src/main/java/ac/mdiq/podcini/ui/actions/swipeactions/RemoveFromHistorySwipeAction.kt similarity index 97% rename from app/src/main/java/ac/mdiq/podcini/ui/fragment/swipeactions/RemoveFromHistorySwipeAction.kt rename to app/src/main/java/ac/mdiq/podcini/ui/actions/swipeactions/RemoveFromHistorySwipeAction.kt index eef241a6..6755df58 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/fragment/swipeactions/RemoveFromHistorySwipeAction.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/actions/swipeactions/RemoveFromHistorySwipeAction.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.fragment.swipeactions +package ac.mdiq.podcini.ui.actions.swipeactions import ac.mdiq.podcini.ui.activity.MainActivity import android.content.Context diff --git a/app/src/main/java/ac/mdiq/podcini/ui/fragment/swipeactions/RemoveFromQueueSwipeAction.kt b/app/src/main/java/ac/mdiq/podcini/ui/actions/swipeactions/RemoveFromQueueSwipeAction.kt similarity index 97% rename from app/src/main/java/ac/mdiq/podcini/ui/fragment/swipeactions/RemoveFromQueueSwipeAction.kt rename to app/src/main/java/ac/mdiq/podcini/ui/actions/swipeactions/RemoveFromQueueSwipeAction.kt index 950b0f54..c6e83787 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/fragment/swipeactions/RemoveFromQueueSwipeAction.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/actions/swipeactions/RemoveFromQueueSwipeAction.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.fragment.swipeactions +package ac.mdiq.podcini.ui.actions.swipeactions import ac.mdiq.podcini.ui.activity.MainActivity import android.content.Context diff --git a/app/src/main/java/ac/mdiq/podcini/ui/fragment/swipeactions/ShowFirstSwipeDialogAction.kt b/app/src/main/java/ac/mdiq/podcini/ui/actions/swipeactions/ShowFirstSwipeDialogAction.kt similarity index 94% rename from app/src/main/java/ac/mdiq/podcini/ui/fragment/swipeactions/ShowFirstSwipeDialogAction.kt rename to app/src/main/java/ac/mdiq/podcini/ui/actions/swipeactions/ShowFirstSwipeDialogAction.kt index 12c96396..9971afdc 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/fragment/swipeactions/ShowFirstSwipeDialogAction.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/actions/swipeactions/ShowFirstSwipeDialogAction.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.fragment.swipeactions +package ac.mdiq.podcini.ui.actions.swipeactions import android.content.Context import androidx.fragment.app.Fragment diff --git a/app/src/main/java/ac/mdiq/podcini/ui/fragment/swipeactions/StartDownloadSwipeAction.kt b/app/src/main/java/ac/mdiq/podcini/ui/actions/swipeactions/StartDownloadSwipeAction.kt similarity index 89% rename from app/src/main/java/ac/mdiq/podcini/ui/fragment/swipeactions/StartDownloadSwipeAction.kt rename to app/src/main/java/ac/mdiq/podcini/ui/actions/swipeactions/StartDownloadSwipeAction.kt index 74f58d82..697fac8d 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/fragment/swipeactions/StartDownloadSwipeAction.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/actions/swipeactions/StartDownloadSwipeAction.kt @@ -1,9 +1,9 @@ -package ac.mdiq.podcini.ui.fragment.swipeactions +package ac.mdiq.podcini.ui.actions.swipeactions import android.content.Context import androidx.fragment.app.Fragment import ac.mdiq.podcini.R -import ac.mdiq.podcini.ui.adapter.actionbutton.DownloadActionButton +import ac.mdiq.podcini.ui.actions.actionbutton.DownloadActionButton import ac.mdiq.podcini.storage.model.feed.FeedItem import ac.mdiq.podcini.storage.model.feed.FeedItemFilter diff --git a/app/src/main/java/ac/mdiq/podcini/ui/fragment/swipeactions/SwipeAction.kt b/app/src/main/java/ac/mdiq/podcini/ui/actions/swipeactions/SwipeAction.kt similarity index 95% rename from app/src/main/java/ac/mdiq/podcini/ui/fragment/swipeactions/SwipeAction.kt rename to app/src/main/java/ac/mdiq/podcini/ui/actions/swipeactions/SwipeAction.kt index e52250bb..27ae953b 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/fragment/swipeactions/SwipeAction.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/actions/swipeactions/SwipeAction.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.fragment.swipeactions +package ac.mdiq.podcini.ui.actions.swipeactions import android.content.Context import androidx.annotation.AttrRes diff --git a/app/src/main/java/ac/mdiq/podcini/ui/fragment/swipeactions/SwipeActions.kt b/app/src/main/java/ac/mdiq/podcini/ui/actions/swipeactions/SwipeActions.kt similarity index 98% rename from app/src/main/java/ac/mdiq/podcini/ui/fragment/swipeactions/SwipeActions.kt rename to app/src/main/java/ac/mdiq/podcini/ui/actions/swipeactions/SwipeActions.kt index 60535bc7..d9223fb9 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/fragment/swipeactions/SwipeActions.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/actions/swipeactions/SwipeActions.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.fragment.swipeactions +package ac.mdiq.podcini.ui.actions.swipeactions import android.content.Context import android.graphics.Canvas @@ -15,7 +15,7 @@ import ac.mdiq.podcini.R import ac.mdiq.podcini.ui.dialog.SwipeActionsDialog import ac.mdiq.podcini.ui.fragment.* import ac.mdiq.podcini.storage.model.feed.FeedItemFilter -import ac.mdiq.podcini.ui.common.ThemeUtils.getColorFromAttr +import ac.mdiq.podcini.ui.utils.ThemeUtils.getColorFromAttr import ac.mdiq.podcini.ui.view.viewholder.EpisodeItemViewHolder import ac.mdiq.podcini.util.event.SwipeActionsChangedEvent import it.xabaras.android.recyclerview.swipedecorator.RecyclerViewSwipeDecorator diff --git a/app/src/main/java/ac/mdiq/podcini/ui/fragment/swipeactions/TogglePlaybackStateSwipeAction.kt b/app/src/main/java/ac/mdiq/podcini/ui/actions/swipeactions/TogglePlaybackStateSwipeAction.kt similarity index 90% rename from app/src/main/java/ac/mdiq/podcini/ui/fragment/swipeactions/TogglePlaybackStateSwipeAction.kt rename to app/src/main/java/ac/mdiq/podcini/ui/actions/swipeactions/TogglePlaybackStateSwipeAction.kt index 61a87866..210db884 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/fragment/swipeactions/TogglePlaybackStateSwipeAction.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/actions/swipeactions/TogglePlaybackStateSwipeAction.kt @@ -1,9 +1,9 @@ -package ac.mdiq.podcini.ui.fragment.swipeactions +package ac.mdiq.podcini.ui.actions.swipeactions import android.content.Context import androidx.fragment.app.Fragment import ac.mdiq.podcini.R -import ac.mdiq.podcini.ui.menuhandler.FeedItemMenuHandler.markReadWithUndo +import ac.mdiq.podcini.ui.actions.menuhandler.FeedItemMenuHandler.markReadWithUndo import ac.mdiq.podcini.storage.model.feed.FeedItem import ac.mdiq.podcini.storage.model.feed.FeedItemFilter diff --git a/app/src/main/java/ac/mdiq/podcini/ui/activity/MainActivity.kt b/app/src/main/java/ac/mdiq/podcini/ui/activity/MainActivity.kt index a7eb2989..e5600a95 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/activity/MainActivity.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/activity/MainActivity.kt @@ -16,8 +16,8 @@ import ac.mdiq.podcini.preferences.UserPreferences.hiddenDrawerItems import ac.mdiq.podcini.receiver.MediaButtonReceiver.Companion.createIntent import ac.mdiq.podcini.storage.DBReader import ac.mdiq.podcini.storage.model.download.DownloadStatus -import ac.mdiq.podcini.ui.appstartintent.MainActivityStarter -import ac.mdiq.podcini.ui.common.ThemeUtils.getDrawableFromAttr +import ac.mdiq.podcini.ui.activity.appstartintent.MainActivityStarter +import ac.mdiq.podcini.ui.utils.ThemeUtils.getDrawableFromAttr import ac.mdiq.podcini.ui.dialog.RatingDialog import ac.mdiq.podcini.ui.fragment.* import ac.mdiq.podcini.ui.statistics.StatisticsFragment @@ -345,7 +345,8 @@ class MainActivity : CastEnabledActivity() { bottomSheet.setLocked(!visible) if (visible) { - bottomSheetCallback.onStateChanged(dummyView, bottomSheet.state) // Update toolbar visibility + // Update toolbar visibility + bottomSheetCallback.onStateChanged(dummyView, bottomSheet.state) } else { bottomSheet.setState(BottomSheetBehavior.STATE_COLLAPSED) } @@ -359,6 +360,7 @@ class MainActivity : CastEnabledActivity() { val playerParams = playerView.layoutParams as MarginLayoutParams playerParams.setMargins(navigationBarInsets.left, 0, navigationBarInsets.right, 0) playerView.layoutParams = playerParams + audioPlayerFragmentView.visibility = if (visible) View.VISIBLE else View.GONE } @@ -659,9 +661,8 @@ class MainActivity : CastEnabledActivity() { * @param uri incoming deep link */ private fun handleDeeplink(uri: Uri?) { - if (uri?.path == null) { - return - } + if (uri?.path == null) return + Log.d(TAG, "Handling deeplink: $uri") when (uri.path) { "/deeplink/search" -> { @@ -715,7 +716,7 @@ class MainActivity : CastEnabledActivity() { AudioManager.ADJUST_LOWER, AudioManager.FLAG_SHOW_UI) return true } - KeyEvent.KEYCODE_M -> if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) { + KeyEvent.KEYCODE_M -> { audioManager.adjustStreamVolume(AudioManager.STREAM_MUSIC, AudioManager.ADJUST_TOGGLE_MUTE, AudioManager.FLAG_SHOW_UI) return true diff --git a/app/src/main/java/ac/mdiq/podcini/ui/activity/OpmlImportActivity.kt b/app/src/main/java/ac/mdiq/podcini/ui/activity/OpmlImportActivity.kt index a4b1278a..ed96f684 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/activity/OpmlImportActivity.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/activity/OpmlImportActivity.kt @@ -238,8 +238,7 @@ class OpmlImportActivity : AppCompatActivity() { }, { e: Throwable -> Log.d(TAG, Log.getStackTraceString(e)) val message = if (e.message == null) "" else e.message!! - if (message.lowercase().contains("permission") - && Build.VERSION.SDK_INT >= 23) { + if (message.lowercase().contains("permission")) { val permission = ActivityCompat.checkSelfPermission(this, Manifest.permission.READ_EXTERNAL_STORAGE) if (permission != PackageManager.PERMISSION_GRANTED) { diff --git a/app/src/main/java/ac/mdiq/podcini/ui/activity/PreferenceActivity.kt b/app/src/main/java/ac/mdiq/podcini/ui/activity/PreferenceActivity.kt index 60e642d5..303839a1 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/activity/PreferenceActivity.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/activity/PreferenceActivity.kt @@ -3,8 +3,8 @@ package ac.mdiq.podcini.ui.activity import ac.mdiq.podcini.R import ac.mdiq.podcini.databinding.SettingsActivityBinding import ac.mdiq.podcini.preferences.ThemeSwitcher.getTheme -import ac.mdiq.podcini.ui.fragment.preferences.* -import ac.mdiq.podcini.ui.fragment.preferences.synchronization.SynchronizationPreferencesFragment +import ac.mdiq.podcini.preferences.fragments.* +import ac.mdiq.podcini.preferences.fragments.synchronization.SynchronizationPreferencesFragment import ac.mdiq.podcini.util.event.MessageEvent import android.annotation.SuppressLint import android.content.Intent @@ -78,7 +78,7 @@ class PreferenceActivity : AppCompatActivity(), SearchPreferenceResultListener { prefFragment = PlaybackPreferencesFragment() } R.xml.preferences_notifications -> { - prefFragment = NotificationPreferencesFragment() + prefFragment = ac.mdiq.podcini.preferences.fragments.NotificationPreferencesFragment() } R.xml.preferences_swipe -> { prefFragment = SwipePreferencesFragment() diff --git a/app/src/main/java/ac/mdiq/podcini/ui/activity/VideoplayerActivity.kt b/app/src/main/java/ac/mdiq/podcini/ui/activity/VideoplayerActivity.kt index 63b9301f..4a78a87a 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/activity/VideoplayerActivity.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/activity/VideoplayerActivity.kt @@ -1,8 +1,8 @@ package ac.mdiq.podcini.ui.activity import ac.mdiq.podcini.R -import ac.mdiq.podcini.service.playback.PlaybackService.Companion.getPlayerActivityIntent -import ac.mdiq.podcini.service.playback.PlaybackService.Companion.isCasting +import ac.mdiq.podcini.playback.service.PlaybackService.Companion.getPlayerActivityIntent +import ac.mdiq.podcini.playback.service.PlaybackService.Companion.isCasting import ac.mdiq.podcini.storage.DBReader import ac.mdiq.podcini.storage.DBWriter import ac.mdiq.podcini.util.Converter.getDurationStringLong @@ -14,10 +14,10 @@ import ac.mdiq.podcini.ui.utils.PictureInPictureUtil import ac.mdiq.podcini.playback.PlaybackController import ac.mdiq.podcini.databinding.VideoplayerActivityBinding import ac.mdiq.podcini.ui.dialog.* -import ac.mdiq.podcini.playback.event.BufferUpdateEvent -import ac.mdiq.podcini.playback.event.PlaybackPositionEvent -import ac.mdiq.podcini.playback.event.PlaybackServiceEvent -import ac.mdiq.podcini.playback.event.SleepTimerUpdatedEvent +import ac.mdiq.podcini.util.event.playback.BufferUpdateEvent +import ac.mdiq.podcini.util.event.playback.PlaybackPositionEvent +import ac.mdiq.podcini.util.event.playback.PlaybackServiceEvent +import ac.mdiq.podcini.util.event.playback.SleepTimerUpdatedEvent import ac.mdiq.podcini.ui.fragment.ChaptersFragment import ac.mdiq.podcini.storage.model.feed.FeedItem import ac.mdiq.podcini.storage.model.feed.FeedMedia @@ -28,7 +28,7 @@ import ac.mdiq.podcini.preferences.UserPreferences.fastForwardSecs import ac.mdiq.podcini.preferences.UserPreferences.rewindSecs import ac.mdiq.podcini.preferences.UserPreferences.setShowRemainTimeSetting import ac.mdiq.podcini.preferences.UserPreferences.shouldShowRemainingTime -import ac.mdiq.podcini.ui.appstartintent.MainActivityStarter +import ac.mdiq.podcini.ui.activity.appstartintent.MainActivityStarter import ac.mdiq.podcini.util.event.MessageEvent import ac.mdiq.podcini.util.event.PlayerErrorEvent import android.content.DialogInterface @@ -755,7 +755,7 @@ class VideoplayerActivity : CastEnabledActivity(), OnSeekBarChangeListener { AudioManager.ADJUST_LOWER, AudioManager.FLAG_SHOW_UI) return true } - KeyEvent.KEYCODE_M -> if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) { + KeyEvent.KEYCODE_M -> { audioManager.adjustStreamVolume(AudioManager.STREAM_MUSIC, AudioManager.ADJUST_TOGGLE_MUTE, AudioManager.FLAG_SHOW_UI) return true diff --git a/app/src/main/java/ac/mdiq/podcini/ui/appstartintent/MainActivityStarter.kt b/app/src/main/java/ac/mdiq/podcini/ui/activity/appstartintent/MainActivityStarter.kt similarity index 90% rename from app/src/main/java/ac/mdiq/podcini/ui/appstartintent/MainActivityStarter.kt rename to app/src/main/java/ac/mdiq/podcini/ui/activity/appstartintent/MainActivityStarter.kt index 9b14b6f7..96e145de 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/appstartintent/MainActivityStarter.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/activity/appstartintent/MainActivityStarter.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.appstartintent +package ac.mdiq.podcini.ui.activity.appstartintent import ac.mdiq.podcini.R @@ -29,7 +29,7 @@ class MainActivityStarter(private val context: Context) { val pendingIntent: PendingIntent get() = PendingIntent.getActivity(context, R.id.pending_intent_player_activity, getIntent(), - PendingIntent.FLAG_UPDATE_CURRENT or (if (Build.VERSION.SDK_INT >= 23) PendingIntent.FLAG_IMMUTABLE else 0)) + PendingIntent.FLAG_UPDATE_CURRENT or PendingIntent.FLAG_IMMUTABLE) fun start() { context.startActivity(getIntent()) @@ -66,9 +66,8 @@ class MainActivityStarter(private val context: Context) { } fun withFragmentArgs(name: String?, value: Boolean): MainActivityStarter { - if (fragmentArgs == null) { - fragmentArgs = Bundle() - } + if (fragmentArgs == null) fragmentArgs = Bundle() + fragmentArgs!!.putBoolean(name, value) return this } diff --git a/app/src/main/java/ac/mdiq/podcini/ui/appstartintent/PlaybackSpeedActivityStarter.kt b/app/src/main/java/ac/mdiq/podcini/ui/activity/appstartintent/PlaybackSpeedActivityStarter.kt similarity index 83% rename from app/src/main/java/ac/mdiq/podcini/ui/appstartintent/PlaybackSpeedActivityStarter.kt rename to app/src/main/java/ac/mdiq/podcini/ui/activity/appstartintent/PlaybackSpeedActivityStarter.kt index 3e9ebc3d..45bcba53 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/appstartintent/PlaybackSpeedActivityStarter.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/activity/appstartintent/PlaybackSpeedActivityStarter.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.appstartintent +package ac.mdiq.podcini.ui.activity.appstartintent import ac.mdiq.podcini.R @@ -21,7 +21,7 @@ class PlaybackSpeedActivityStarter(private val context: Context) { val pendingIntent: PendingIntent get() = PendingIntent.getActivity(context, R.id.pending_intent_playback_speed, intent, - PendingIntent.FLAG_UPDATE_CURRENT or (if (Build.VERSION.SDK_INT >= 23) PendingIntent.FLAG_IMMUTABLE else 0)) + PendingIntent.FLAG_UPDATE_CURRENT or PendingIntent.FLAG_IMMUTABLE) fun start() { context.startActivity(intent) diff --git a/app/src/main/java/ac/mdiq/podcini/ui/appstartintent/VideoPlayerActivityStarter.kt b/app/src/main/java/ac/mdiq/podcini/ui/activity/appstartintent/VideoPlayerActivityStarter.kt similarity index 83% rename from app/src/main/java/ac/mdiq/podcini/ui/appstartintent/VideoPlayerActivityStarter.kt rename to app/src/main/java/ac/mdiq/podcini/ui/activity/appstartintent/VideoPlayerActivityStarter.kt index 00d1db36..5008c6a7 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/appstartintent/VideoPlayerActivityStarter.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/activity/appstartintent/VideoPlayerActivityStarter.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.appstartintent +package ac.mdiq.podcini.ui.activity.appstartintent import ac.mdiq.podcini.R @@ -21,7 +21,7 @@ class VideoPlayerActivityStarter(private val context: Context) { val pendingIntent: PendingIntent get() = PendingIntent.getActivity(context, R.id.pending_intent_video_player, intent, - PendingIntent.FLAG_UPDATE_CURRENT or (if (Build.VERSION.SDK_INT >= 23) PendingIntent.FLAG_IMMUTABLE else 0)) + PendingIntent.FLAG_UPDATE_CURRENT or PendingIntent.FLAG_IMMUTABLE) fun start() { context.startActivity(intent) diff --git a/app/src/main/java/ac/mdiq/podcini/ui/adapter/ChaptersListAdapter.kt b/app/src/main/java/ac/mdiq/podcini/ui/adapter/ChaptersListAdapter.kt index 8a15df62..80539183 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/adapter/ChaptersListAdapter.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/adapter/ChaptersListAdapter.kt @@ -22,7 +22,7 @@ import ac.mdiq.podcini.util.IntentUtils.openInBrowser import ac.mdiq.podcini.storage.model.feed.Chapter import ac.mdiq.podcini.storage.model.feed.EmbeddedChapterImage import ac.mdiq.podcini.storage.model.playback.Playable -import ac.mdiq.podcini.ui.common.CircularProgressBar +import ac.mdiq.podcini.ui.view.CircularProgressBar import kotlin.math.max import kotlin.math.min diff --git a/app/src/main/java/ac/mdiq/podcini/ui/adapter/DownloadLogAdapter.kt b/app/src/main/java/ac/mdiq/podcini/ui/adapter/DownloadLogAdapter.kt index 2ba74c39..1d9099d5 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/adapter/DownloadLogAdapter.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/adapter/DownloadLogAdapter.kt @@ -9,7 +9,7 @@ import android.view.ViewGroup import android.widget.BaseAdapter import android.widget.Toast import ac.mdiq.podcini.R -import ac.mdiq.podcini.ui.adapter.actionbutton.DownloadActionButton +import ac.mdiq.podcini.ui.actions.actionbutton.DownloadActionButton import ac.mdiq.podcini.storage.DBReader import ac.mdiq.podcini.util.DownloadErrorLabel import ac.mdiq.podcini.net.download.FeedUpdateManager @@ -17,7 +17,7 @@ import ac.mdiq.podcini.storage.model.download.DownloadError import ac.mdiq.podcini.storage.model.download.DownloadResult import ac.mdiq.podcini.storage.model.feed.Feed import ac.mdiq.podcini.storage.model.feed.FeedMedia -import ac.mdiq.podcini.ui.common.ThemeUtils +import ac.mdiq.podcini.ui.utils.ThemeUtils import ac.mdiq.podcini.ui.view.viewholder.DownloadLogItemViewHolder import androidx.media3.common.util.UnstableApi diff --git a/app/src/main/java/ac/mdiq/podcini/ui/adapter/EpisodeItemListAdapter.kt b/app/src/main/java/ac/mdiq/podcini/ui/adapter/EpisodeItemListAdapter.kt index e53b581d..00995099 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/adapter/EpisodeItemListAdapter.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/adapter/EpisodeItemListAdapter.kt @@ -3,11 +3,10 @@ package ac.mdiq.podcini.ui.adapter import ac.mdiq.podcini.R import ac.mdiq.podcini.storage.model.feed.FeedItem import ac.mdiq.podcini.ui.activity.MainActivity -import ac.mdiq.podcini.ui.common.ThemeUtils +import ac.mdiq.podcini.ui.utils.ThemeUtils import ac.mdiq.podcini.ui.fragment.EpisodeInfoFragment -import ac.mdiq.podcini.ui.menuhandler.FeedItemMenuHandler +import ac.mdiq.podcini.ui.actions.menuhandler.FeedItemMenuHandler import ac.mdiq.podcini.ui.view.viewholder.EpisodeItemViewHolder -import ac.mdiq.podcini.util.FeedItemUtil import android.R.color import android.app.Activity import android.os.Build @@ -15,7 +14,6 @@ import android.util.Log import android.view.* import androidx.media3.common.util.UnstableApi import androidx.recyclerview.widget.RecyclerView -import org.apache.commons.lang3.ArrayUtils import java.lang.ref.WeakReference @@ -102,12 +100,10 @@ open class EpisodeItemListAdapter(mainActivity: MainActivity) : } } holder.itemView.setOnTouchListener(View.OnTouchListener { _: View?, e: MotionEvent -> - if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) { - if (e.isFromSource(InputDevice.SOURCE_MOUSE) && e.buttonState == MotionEvent.BUTTON_SECONDARY) { - longPressedItem = item - longPressedPosition = holder.bindingAdapterPosition - return@OnTouchListener false - } + if (e.isFromSource(InputDevice.SOURCE_MOUSE) && e.buttonState == MotionEvent.BUTTON_SECONDARY) { + longPressedItem = item + longPressedPosition = holder.bindingAdapterPosition + return@OnTouchListener false } false }) diff --git a/app/src/main/java/ac/mdiq/podcini/ui/adapter/HorizontalFeedListAdapter.kt b/app/src/main/java/ac/mdiq/podcini/ui/adapter/HorizontalFeedListAdapter.kt index ec9dc93b..94dae11f 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/adapter/HorizontalFeedListAdapter.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/adapter/HorizontalFeedListAdapter.kt @@ -16,7 +16,7 @@ import ac.mdiq.podcini.R import ac.mdiq.podcini.databinding.HorizontalFeedItemBinding import ac.mdiq.podcini.ui.fragment.FeedItemlistFragment import ac.mdiq.podcini.storage.model.feed.Feed -import ac.mdiq.podcini.ui.common.SquareImageView +import ac.mdiq.podcini.ui.view.SquareImageView import java.lang.ref.WeakReference open class HorizontalFeedListAdapter(mainActivity: MainActivity) : diff --git a/app/src/main/java/ac/mdiq/podcini/ui/adapter/NavListAdapter.kt b/app/src/main/java/ac/mdiq/podcini/ui/adapter/NavListAdapter.kt index a61022a2..0dd612b6 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/adapter/NavListAdapter.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/adapter/NavListAdapter.kt @@ -192,12 +192,10 @@ class NavListAdapter(private val itemAccess: ItemAccess, context: Activity) : holder.itemView.setOnClickListener { itemAccess.onItemClick(position) } holder.itemView.setOnLongClickListener { itemAccess.onItemLongClick(position) } holder.itemView.setOnTouchListener { _: View?, e: MotionEvent -> - if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) { - if (e.isFromSource(InputDevice.SOURCE_MOUSE) - && e.buttonState == MotionEvent.BUTTON_SECONDARY) { - itemAccess.onItemLongClick(position) - return@setOnTouchListener false - } + if (e.isFromSource(InputDevice.SOURCE_MOUSE) + && e.buttonState == MotionEvent.BUTTON_SECONDARY) { + itemAccess.onItemLongClick(position) + return@setOnTouchListener false } false } diff --git a/app/src/main/java/ac/mdiq/podcini/ui/adapter/QueueRecyclerAdapter.kt b/app/src/main/java/ac/mdiq/podcini/ui/adapter/QueueRecyclerAdapter.kt index eb473a7d..aa89eb58 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/adapter/QueueRecyclerAdapter.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/adapter/QueueRecyclerAdapter.kt @@ -9,7 +9,7 @@ import android.view.MotionEvent import android.view.View import androidx.media3.common.util.UnstableApi import ac.mdiq.podcini.R -import ac.mdiq.podcini.ui.fragment.swipeactions.SwipeActions +import ac.mdiq.podcini.ui.actions.swipeactions.SwipeActions import ac.mdiq.podcini.preferences.UserPreferences import ac.mdiq.podcini.ui.view.viewholder.EpisodeItemViewHolder diff --git a/app/src/main/java/ac/mdiq/podcini/ui/adapter/SubscriptionsAdapter.kt b/app/src/main/java/ac/mdiq/podcini/ui/adapter/SubscriptionsAdapter.kt index bccb12ad..7b245117 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/adapter/SubscriptionsAdapter.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/adapter/SubscriptionsAdapter.kt @@ -86,13 +86,11 @@ open class SubscriptionsAdapter(mainActivity: MainActivity) : } holder.itemView.setOnTouchListener { _: View?, e: MotionEvent -> - if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) { - if (e.isFromSource(InputDevice.SOURCE_MOUSE) - && e.buttonState == MotionEvent.BUTTON_SECONDARY) { - if (!inActionMode()) { - longPressedPosition = holder.bindingAdapterPosition - selectedItem = drawerItem - } + if (e.isFromSource(InputDevice.SOURCE_MOUSE) + && e.buttonState == MotionEvent.BUTTON_SECONDARY) { + if (!inActionMode()) { + longPressedPosition = holder.bindingAdapterPosition + selectedItem = drawerItem } } false diff --git a/app/src/main/java/ac/mdiq/podcini/ui/dialog/ProxyDialog.kt b/app/src/main/java/ac/mdiq/podcini/ui/dialog/ProxyDialog.kt index a293fcc3..72e03f4c 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/dialog/ProxyDialog.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/dialog/ProxyDialog.kt @@ -12,12 +12,12 @@ import androidx.appcompat.app.AlertDialog import com.google.android.material.dialog.MaterialAlertDialogBuilder import ac.mdiq.podcini.R import ac.mdiq.podcini.databinding.ProxySettingsBinding -import ac.mdiq.podcini.service.download.PodciniHttpClient.newBuilder -import ac.mdiq.podcini.service.download.PodciniHttpClient.reinit -import ac.mdiq.podcini.service.download.PodciniHttpClient.setProxyConfig +import ac.mdiq.podcini.net.download.service.PodciniHttpClient.newBuilder +import ac.mdiq.podcini.net.download.service.PodciniHttpClient.reinit +import ac.mdiq.podcini.net.download.service.PodciniHttpClient.setProxyConfig import ac.mdiq.podcini.storage.model.download.ProxyConfig import ac.mdiq.podcini.preferences.UserPreferences.proxyConfig -import ac.mdiq.podcini.ui.common.ThemeUtils.getColorFromAttr +import ac.mdiq.podcini.ui.utils.ThemeUtils.getColorFromAttr import io.reactivex.Completable import io.reactivex.CompletableEmitter import io.reactivex.android.schedulers.AndroidSchedulers diff --git a/app/src/main/java/ac/mdiq/podcini/ui/dialog/SleepTimerDialog.kt b/app/src/main/java/ac/mdiq/podcini/ui/dialog/SleepTimerDialog.kt index f42559c4..48ee55ce 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/dialog/SleepTimerDialog.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/dialog/SleepTimerDialog.kt @@ -2,7 +2,7 @@ package ac.mdiq.podcini.ui.dialog import ac.mdiq.podcini.R import ac.mdiq.podcini.databinding.TimeDialogBinding -import ac.mdiq.podcini.playback.event.SleepTimerUpdatedEvent +import ac.mdiq.podcini.util.event.playback.SleepTimerUpdatedEvent import ac.mdiq.podcini.preferences.SleepTimerPreferences.autoEnable import ac.mdiq.podcini.preferences.SleepTimerPreferences.autoEnableFrom import ac.mdiq.podcini.preferences.SleepTimerPreferences.autoEnableTo @@ -16,7 +16,7 @@ import ac.mdiq.podcini.preferences.SleepTimerPreferences.setVibrate import ac.mdiq.podcini.preferences.SleepTimerPreferences.shakeToReset import ac.mdiq.podcini.preferences.SleepTimerPreferences.timerMillis import ac.mdiq.podcini.preferences.SleepTimerPreferences.vibrate -import ac.mdiq.podcini.service.playback.PlaybackService +import ac.mdiq.podcini.playback.service.PlaybackService import ac.mdiq.podcini.util.Converter.getDurationStringLong import ac.mdiq.podcini.playback.PlaybackController import android.app.Activity diff --git a/app/src/main/java/ac/mdiq/podcini/ui/dialog/SwipeActionsDialog.kt b/app/src/main/java/ac/mdiq/podcini/ui/dialog/SwipeActionsDialog.kt index 3d2045db..97be5eb8 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/dialog/SwipeActionsDialog.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/dialog/SwipeActionsDialog.kt @@ -14,11 +14,11 @@ import com.google.android.material.dialog.MaterialAlertDialogBuilder import ac.mdiq.podcini.R import ac.mdiq.podcini.databinding.* import ac.mdiq.podcini.ui.fragment.* -import ac.mdiq.podcini.ui.fragment.swipeactions.SwipeAction -import ac.mdiq.podcini.ui.fragment.swipeactions.SwipeActions -import ac.mdiq.podcini.ui.fragment.swipeactions.SwipeActions.Companion.getPrefsWithDefaults -import ac.mdiq.podcini.ui.fragment.swipeactions.SwipeActions.Companion.isSwipeActionEnabled -import ac.mdiq.podcini.ui.common.ThemeUtils.getColorFromAttr +import ac.mdiq.podcini.ui.actions.swipeactions.SwipeAction +import ac.mdiq.podcini.ui.actions.swipeactions.SwipeActions +import ac.mdiq.podcini.ui.actions.swipeactions.SwipeActions.Companion.getPrefsWithDefaults +import ac.mdiq.podcini.ui.actions.swipeactions.SwipeActions.Companion.isSwipeActionEnabled +import ac.mdiq.podcini.ui.utils.ThemeUtils.getColorFromAttr class SwipeActionsDialog(private val context: Context, private val tag: String) { private lateinit var keys: List diff --git a/app/src/main/java/ac/mdiq/podcini/ui/dialog/TimeRangeDialog.kt b/app/src/main/java/ac/mdiq/podcini/ui/dialog/TimeRangeDialog.kt index f9b30f06..096e9bff 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/dialog/TimeRangeDialog.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/dialog/TimeRangeDialog.kt @@ -10,7 +10,7 @@ import android.view.MotionEvent import android.view.View import com.google.android.material.dialog.MaterialAlertDialogBuilder import ac.mdiq.podcini.R -import ac.mdiq.podcini.ui.common.ThemeUtils.getColorFromAttr +import ac.mdiq.podcini.ui.utils.ThemeUtils.getColorFromAttr import java.util.* import kotlin.math.abs import kotlin.math.atan2 diff --git a/app/src/main/java/ac/mdiq/podcini/ui/dialog/VariableSpeedDialog.kt b/app/src/main/java/ac/mdiq/podcini/ui/dialog/VariableSpeedDialog.kt index b096d0f2..f66b9b6f 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/dialog/VariableSpeedDialog.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/dialog/VariableSpeedDialog.kt @@ -3,7 +3,7 @@ package ac.mdiq.podcini.ui.dialog import ac.mdiq.podcini.R import ac.mdiq.podcini.databinding.SpeedSelectDialogBinding import ac.mdiq.podcini.playback.PlaybackController -import ac.mdiq.podcini.playback.event.SpeedChangedEvent +import ac.mdiq.podcini.util.event.playback.SpeedChangedEvent import ac.mdiq.podcini.preferences.UserPreferences.isSkipSilence import ac.mdiq.podcini.preferences.UserPreferences.playbackSpeedArray import ac.mdiq.podcini.ui.view.ItemOffsetDecoration diff --git a/app/src/main/java/ac/mdiq/podcini/ui/fragment/AudioPlayerFragment.kt b/app/src/main/java/ac/mdiq/podcini/ui/fragment/AudioPlayerFragment.kt index dcb40846..7f725048 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/fragment/AudioPlayerFragment.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/fragment/AudioPlayerFragment.kt @@ -8,25 +8,21 @@ import ac.mdiq.podcini.feed.util.PlaybackSpeedUtils import ac.mdiq.podcini.playback.PlaybackController import ac.mdiq.podcini.playback.base.PlayerStatus import ac.mdiq.podcini.playback.cast.CastEnabledActivity -import ac.mdiq.podcini.playback.event.PlaybackPositionEvent -import ac.mdiq.podcini.playback.event.PlaybackServiceEvent -import ac.mdiq.podcini.playback.event.SleepTimerUpdatedEvent -import ac.mdiq.podcini.playback.event.SpeedChangedEvent import ac.mdiq.podcini.preferences.UserPreferences import ac.mdiq.podcini.receiver.MediaButtonReceiver -import ac.mdiq.podcini.service.playback.PlaybackService +import ac.mdiq.podcini.playback.service.PlaybackService import ac.mdiq.podcini.storage.model.feed.Chapter import ac.mdiq.podcini.storage.model.feed.FeedItem import ac.mdiq.podcini.storage.model.feed.FeedMedia import ac.mdiq.podcini.storage.model.playback.MediaType import ac.mdiq.podcini.storage.model.playback.Playable import ac.mdiq.podcini.ui.activity.MainActivity -import ac.mdiq.podcini.ui.common.PlaybackSpeedIndicatorView +import ac.mdiq.podcini.ui.view.PlaybackSpeedIndicatorView import ac.mdiq.podcini.ui.dialog.MediaPlayerErrorDialog import ac.mdiq.podcini.ui.dialog.SkipPreferenceDialog import ac.mdiq.podcini.ui.dialog.SleepTimerDialog import ac.mdiq.podcini.ui.dialog.VariableSpeedDialog -import ac.mdiq.podcini.ui.menuhandler.FeedItemMenuHandler +import ac.mdiq.podcini.ui.actions.menuhandler.FeedItemMenuHandler import ac.mdiq.podcini.ui.view.ChapterSeekBar import ac.mdiq.podcini.ui.view.PlayButton import ac.mdiq.podcini.util.ChapterUtils @@ -34,6 +30,7 @@ import ac.mdiq.podcini.util.Converter import ac.mdiq.podcini.util.TimeSpeedConverter import ac.mdiq.podcini.util.event.FavoritesEvent import ac.mdiq.podcini.util.event.PlayerErrorEvent +import ac.mdiq.podcini.util.event.playback.* import android.annotation.SuppressLint import android.app.Activity import android.content.Intent @@ -79,7 +76,8 @@ class AudioPlayerFragment : Fragment(), SeekBar.OnSeekBarChangeListener, Toolbar var _binding: AudioplayerFragmentBinding? = null private val binding get() = _binding!! - private lateinit var itemDesrView: View +// private lateinit var itemDesrView: View + private lateinit var itemDescFrag: PlayerDetailsFragment private lateinit var toolbar: MaterialToolbar private var playerFragment1: InternalPlayerFragment? = null @@ -97,6 +95,7 @@ class AudioPlayerFragment : Fragment(), SeekBar.OnSeekBarChangeListener, Toolbar private var duration = 0 private var currentMedia: Playable? = null + private var currentitem: FeedItem? = null @SuppressLint("WrongConstant") override fun onCreateView(inflater: LayoutInflater, @@ -138,13 +137,13 @@ class AudioPlayerFragment : Fragment(), SeekBar.OnSeekBarChangeListener, Toolbar playerView2.setBackgroundColor( SurfaceColors.getColorForElevation(requireContext(), 8 * resources.displayMetrics.density)) - itemDesrView = binding.itemDescription +// itemDesrView = binding.itemDescription cardViewSeek = binding.cardViewSeek txtvSeek = binding.txtvSeek val fm = requireActivity().supportFragmentManager val transaction = fm.beginTransaction() - val itemDescFrag = PlayerDetailsFragment() + itemDescFrag = PlayerDetailsFragment() transaction.replace(R.id.itemDescription, itemDescFrag).commit() // controller = externalPlayerFragment1.controller @@ -167,11 +166,9 @@ class AudioPlayerFragment : Fragment(), SeekBar.OnSeekBarChangeListener, Toolbar private fun setChapterDividers(media: Playable?) { if (media == null) return - var dividerPos: FloatArray? = null - if (media.getChapters().isNotEmpty()) { val chapters: List = media.getChapters() - dividerPos = FloatArray(chapters.size) + val dividerPos = FloatArray(chapters.size) for (i in chapters.indices) { dividerPos[i] = chapters[i].start / duration.toFloat() @@ -214,6 +211,8 @@ class AudioPlayerFragment : Fragment(), SeekBar.OnSeekBarChangeListener, Toolbar Log.d(TAG, "loadMediaInfo called") val theMedia = controller?.getMedia() ?: return + Log.d(TAG, "loadMediaInfo $theMedia") + if (currentMedia == null || theMedia?.getIdentifier() != currentMedia?.getIdentifier()) { Log.d(TAG, "loadMediaInfo loading details") disposable?.dispose() @@ -239,7 +238,9 @@ class AudioPlayerFragment : Fragment(), SeekBar.OnSeekBarChangeListener, Toolbar loadMediaInfo(true) } }, { error: Throwable? -> Log.e(TAG, Log.getStackTraceString(error)) }, - { updateUi(null) }) + { + updateUi(null) + }) } } @@ -257,7 +258,7 @@ class AudioPlayerFragment : Fragment(), SeekBar.OnSeekBarChangeListener, Toolbar override fun onPlaybackEnd() { playerFragment1?.butPlay?.setIsShowPlay(true) playerFragment2?.butPlay?.setIsShowPlay(true) - (activity as MainActivity).setPlayerVisible(null) + (activity as MainActivity).setPlayerVisible(false) } } } @@ -321,6 +322,15 @@ class AudioPlayerFragment : Fragment(), SeekBar.OnSeekBarChangeListener, Toolbar MediaPlayerErrorDialog.show(activity as Activity, event) } + @Subscribe(threadMode = ThreadMode.MAIN) + fun onEvenStartPlay(event: StartPlayEvent) { + Log.d(TAG, "onEvenStartPlay ${event.item.title}") + currentitem = event.item + if (currentMedia?.getIdentifier() == null || currentitem!!.media!!.getIdentifier() != currentMedia?.getIdentifier()) { + itemDescFrag.setItem(currentitem!!) + } + } + override fun onProgressChanged(seekBar: SeekBar, progress: Int, fromUser: Boolean) { if (controller == null) return @@ -388,9 +398,9 @@ class AudioPlayerFragment : Fragment(), SeekBar.OnSeekBarChangeListener, Toolbar val isFeedMedia = media is FeedMedia toolbar.menu?.findItem(R.id.open_feed_item)?.setVisible(isFeedMedia) - if (media != null && isFeedMedia) { - FeedItemMenuHandler.onPrepareMenu(toolbar.menu, (media as FeedMedia).item) - } + var item = currentitem + if (item == null && isFeedMedia) item = (media as FeedMedia).item + FeedItemMenuHandler.onPrepareMenu(toolbar.menu, item) if (controller != null) { toolbar.menu.findItem(R.id.set_sleeptimer_item).setVisible(!controller!!.sleepTimerActive()) @@ -402,7 +412,9 @@ class AudioPlayerFragment : Fragment(), SeekBar.OnSeekBarChangeListener, Toolbar override fun onMenuItemClick(menuItem: MenuItem): Boolean { val media: Playable = controller?.getMedia() ?: return false - val feedItem: FeedItem? = if (media is FeedMedia) media.item else null + var feedItem = currentitem + if (feedItem == null && media is FeedMedia) feedItem = media.item +// feedItem: FeedItem? = if (media is FeedMedia) media.item else null if (feedItem != null && FeedItemMenuHandler.onMenuItemClicked(this, menuItem.itemId, feedItem)) { return true } @@ -692,8 +704,8 @@ class AudioPlayerFragment : Fragment(), SeekBar.OnSeekBarChangeListener, Toolbar @UnstableApi fun updateUi(media: Playable?) { + Log.d(TAG, "updateUi called $media") if (media == null) return - Log.d(TAG, "updateUi called") episodeTitle.text = media.getEpisodeTitle() (activity as MainActivity).setPlayerVisible(true) diff --git a/app/src/main/java/ac/mdiq/podcini/ui/fragment/BaseEpisodesListFragment.kt b/app/src/main/java/ac/mdiq/podcini/ui/fragment/BaseEpisodesListFragment.kt index df8cb95f..08a577b2 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/fragment/BaseEpisodesListFragment.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/fragment/BaseEpisodesListFragment.kt @@ -4,17 +4,17 @@ import ac.mdiq.podcini.R import ac.mdiq.podcini.databinding.BaseEpisodesListFragmentBinding import ac.mdiq.podcini.databinding.MultiSelectSpeedDialBinding import ac.mdiq.podcini.net.download.FeedUpdateManager -import ac.mdiq.podcini.playback.event.PlaybackPositionEvent +import ac.mdiq.podcini.util.event.playback.PlaybackPositionEvent import ac.mdiq.podcini.storage.model.feed.FeedItem import ac.mdiq.podcini.storage.model.feed.FeedItemFilter import ac.mdiq.podcini.ui.activity.MainActivity import ac.mdiq.podcini.ui.adapter.EpisodeItemListAdapter import ac.mdiq.podcini.ui.adapter.SelectableAdapter import ac.mdiq.podcini.ui.dialog.ConfirmationDialog -import ac.mdiq.podcini.ui.fragment.actions.EpisodeMultiSelectActionHandler -import ac.mdiq.podcini.ui.fragment.swipeactions.SwipeActions -import ac.mdiq.podcini.ui.menuhandler.FeedItemMenuHandler -import ac.mdiq.podcini.ui.menuhandler.MenuItemUtils +import ac.mdiq.podcini.ui.actions.EpisodeMultiSelectActionHandler +import ac.mdiq.podcini.ui.actions.swipeactions.SwipeActions +import ac.mdiq.podcini.ui.actions.menuhandler.FeedItemMenuHandler +import ac.mdiq.podcini.ui.actions.menuhandler.MenuItemUtils import ac.mdiq.podcini.ui.view.EmptyViewHandler import ac.mdiq.podcini.ui.view.EpisodeItemListRecyclerView import ac.mdiq.podcini.ui.view.LiftOnScrollListener diff --git a/app/src/main/java/ac/mdiq/podcini/ui/fragment/ChaptersFragment.kt b/app/src/main/java/ac/mdiq/podcini/ui/fragment/ChaptersFragment.kt index 21ba6957..e1efcfb7 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/fragment/ChaptersFragment.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/fragment/ChaptersFragment.kt @@ -4,7 +4,7 @@ import ac.mdiq.podcini.R import ac.mdiq.podcini.databinding.SimpleListFragmentBinding import ac.mdiq.podcini.playback.PlaybackController import ac.mdiq.podcini.playback.base.PlayerStatus -import ac.mdiq.podcini.playback.event.PlaybackPositionEvent +import ac.mdiq.podcini.util.event.playback.PlaybackPositionEvent import ac.mdiq.podcini.storage.model.feed.FeedMedia import ac.mdiq.podcini.storage.model.playback.Playable import ac.mdiq.podcini.ui.adapter.ChaptersListAdapter diff --git a/app/src/main/java/ac/mdiq/podcini/ui/fragment/DownloadsFragment.kt b/app/src/main/java/ac/mdiq/podcini/ui/fragment/DownloadsFragment.kt index ba8f40b9..8adfda72 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/fragment/DownloadsFragment.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/fragment/DownloadsFragment.kt @@ -5,7 +5,7 @@ import ac.mdiq.podcini.databinding.MultiSelectSpeedDialBinding import ac.mdiq.podcini.databinding.SimpleListFragmentBinding import ac.mdiq.podcini.net.download.FeedUpdateManager import ac.mdiq.podcini.net.download.serviceinterface.DownloadServiceInterface -import ac.mdiq.podcini.playback.event.PlaybackPositionEvent +import ac.mdiq.podcini.util.event.playback.PlaybackPositionEvent import ac.mdiq.podcini.preferences.UserPreferences import ac.mdiq.podcini.storage.DBReader import ac.mdiq.podcini.storage.model.feed.FeedItem @@ -14,12 +14,12 @@ import ac.mdiq.podcini.storage.model.feed.SortOrder import ac.mdiq.podcini.ui.activity.MainActivity import ac.mdiq.podcini.ui.adapter.EpisodeItemListAdapter import ac.mdiq.podcini.ui.adapter.SelectableAdapter -import ac.mdiq.podcini.ui.adapter.actionbutton.DeleteActionButton +import ac.mdiq.podcini.ui.actions.actionbutton.DeleteActionButton import ac.mdiq.podcini.ui.dialog.ItemSortDialog -import ac.mdiq.podcini.ui.fragment.actions.EpisodeMultiSelectActionHandler -import ac.mdiq.podcini.ui.fragment.swipeactions.SwipeActions -import ac.mdiq.podcini.ui.menuhandler.FeedItemMenuHandler -import ac.mdiq.podcini.ui.menuhandler.MenuItemUtils +import ac.mdiq.podcini.ui.actions.EpisodeMultiSelectActionHandler +import ac.mdiq.podcini.ui.actions.swipeactions.SwipeActions +import ac.mdiq.podcini.ui.actions.menuhandler.FeedItemMenuHandler +import ac.mdiq.podcini.ui.actions.menuhandler.MenuItemUtils import ac.mdiq.podcini.ui.view.EmptyViewHandler import ac.mdiq.podcini.ui.view.EpisodeItemListRecyclerView import ac.mdiq.podcini.ui.view.LiftOnScrollListener diff --git a/app/src/main/java/ac/mdiq/podcini/ui/fragment/EpisodeInfoFragment.kt b/app/src/main/java/ac/mdiq/podcini/ui/fragment/EpisodeInfoFragment.kt index 130c1049..a769332b 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/fragment/EpisodeInfoFragment.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/fragment/EpisodeInfoFragment.kt @@ -11,12 +11,12 @@ import ac.mdiq.podcini.storage.DBReader import ac.mdiq.podcini.storage.model.feed.FeedItem import ac.mdiq.podcini.storage.model.feed.FeedMedia import ac.mdiq.podcini.storage.model.playback.MediaType +import ac.mdiq.podcini.ui.actions.actionbutton.* import ac.mdiq.podcini.ui.activity.MainActivity -import ac.mdiq.podcini.ui.adapter.actionbutton.* -import ac.mdiq.podcini.ui.common.CircularProgressBar -import ac.mdiq.podcini.ui.common.ThemeUtils +import ac.mdiq.podcini.ui.view.CircularProgressBar +import ac.mdiq.podcini.ui.utils.ThemeUtils import ac.mdiq.podcini.ui.utils.ShownotesCleaner -import ac.mdiq.podcini.ui.menuhandler.FeedItemMenuHandler +import ac.mdiq.podcini.ui.actions.menuhandler.FeedItemMenuHandler import ac.mdiq.podcini.ui.view.ShownotesWebView import ac.mdiq.podcini.util.Converter import ac.mdiq.podcini.util.DateFormatter @@ -122,9 +122,7 @@ class EpisodeInfoFragment : Fragment(), Toolbar.OnMenuItemClickListener { txtvPodcast = binding.txtvPodcast txtvPodcast.setOnClickListener { openPodcast() } txtvTitle = binding.txtvTitle - if (Build.VERSION.SDK_INT >= 23) { - txtvTitle.setHyphenationFrequency(Layout.HYPHENATION_FREQUENCY_FULL) - } + txtvTitle.setHyphenationFrequency(Layout.HYPHENATION_FREQUENCY_FULL) txtvDuration = binding.txtvDuration txtvPublished = binding.txtvPublished txtvTitle.ellipsize = TextUtils.TruncateAt.END diff --git a/app/src/main/java/ac/mdiq/podcini/ui/fragment/EpisodesListFragment.kt b/app/src/main/java/ac/mdiq/podcini/ui/fragment/EpisodesListFragment.kt index 138c8c32..b121a51e 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/fragment/EpisodesListFragment.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/fragment/EpisodesListFragment.kt @@ -82,16 +82,6 @@ class EpisodesListFragment : BaseEpisodesListFragment() { // AllEpisodesFilterDialog.newInstance(getFilter()).show(childFragmentManager, null) // return true // } -// R.id.action_favorites -> { -// val filter = ArrayList(getFilter().valuesList) -// if (filter.contains(FeedItemFilter.IS_FAVORITE)) { -// filter.remove(FeedItemFilter.IS_FAVORITE) -// } else { -// filter.add(FeedItemFilter.IS_FAVORITE) -// } -// onFilterChanged(AllEpisodesFilterChangedEvent(HashSet(filter))) -// return true -// } // R.id.episodes_sort -> { // AllEpisodesSortDialog().show(childFragmentManager.beginTransaction(), "SortDialog") // return true diff --git a/app/src/main/java/ac/mdiq/podcini/ui/fragment/FeedInfoFragment.kt b/app/src/main/java/ac/mdiq/podcini/ui/fragment/FeedInfoFragment.kt index 4071a601..d3246d7a 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/fragment/FeedInfoFragment.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/fragment/FeedInfoFragment.kt @@ -9,7 +9,7 @@ import ac.mdiq.podcini.storage.model.feed.Feed import ac.mdiq.podcini.storage.model.feed.FeedFunding import ac.mdiq.podcini.ui.activity.MainActivity import ac.mdiq.podcini.ui.dialog.EditUrlSettingsDialog -import ac.mdiq.podcini.ui.glide.FastBlurTransformation +import ac.mdiq.podcini.glide.FastBlurTransformation import ac.mdiq.podcini.ui.statistics.StatisticsFragment import ac.mdiq.podcini.ui.statistics.feed.FeedStatisticsFragment import ac.mdiq.podcini.ui.view.ToolbarIconTintManager diff --git a/app/src/main/java/ac/mdiq/podcini/ui/fragment/FeedItemlistFragment.kt b/app/src/main/java/ac/mdiq/podcini/ui/fragment/FeedItemlistFragment.kt index bf0d1c20..fda742e2 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/fragment/FeedItemlistFragment.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/fragment/FeedItemlistFragment.kt @@ -25,7 +25,7 @@ import ac.mdiq.podcini.R import ac.mdiq.podcini.ui.adapter.EpisodeItemListAdapter import ac.mdiq.podcini.ui.adapter.SelectableAdapter import ac.mdiq.podcini.feed.FeedEvent -import ac.mdiq.podcini.ui.menuhandler.MenuItemUtils +import ac.mdiq.podcini.ui.actions.menuhandler.MenuItemUtils import ac.mdiq.podcini.storage.DBReader import ac.mdiq.podcini.storage.DBWriter import ac.mdiq.podcini.util.FeedItemPermutors @@ -38,17 +38,17 @@ import ac.mdiq.podcini.databinding.FeedItemListFragmentBinding import ac.mdiq.podcini.databinding.MultiSelectSpeedDialBinding import ac.mdiq.podcini.ui.dialog.* import ac.mdiq.podcini.util.event.* -import ac.mdiq.podcini.playback.event.PlaybackPositionEvent -import ac.mdiq.podcini.ui.fragment.actions.EpisodeMultiSelectActionHandler -import ac.mdiq.podcini.ui.fragment.swipeactions.SwipeActions -import ac.mdiq.podcini.ui.menuhandler.FeedItemMenuHandler +import ac.mdiq.podcini.util.event.playback.PlaybackPositionEvent +import ac.mdiq.podcini.ui.actions.EpisodeMultiSelectActionHandler +import ac.mdiq.podcini.ui.actions.swipeactions.SwipeActions +import ac.mdiq.podcini.ui.actions.menuhandler.FeedItemMenuHandler import ac.mdiq.podcini.storage.model.download.DownloadResult import ac.mdiq.podcini.storage.model.feed.Feed import ac.mdiq.podcini.storage.model.feed.FeedItem import ac.mdiq.podcini.storage.model.feed.FeedItemFilter import ac.mdiq.podcini.storage.model.feed.SortOrder import ac.mdiq.podcini.preferences.UserPreferences -import ac.mdiq.podcini.ui.glide.FastBlurTransformation +import ac.mdiq.podcini.glide.FastBlurTransformation import ac.mdiq.podcini.ui.view.ToolbarIconTintManager import ac.mdiq.podcini.ui.view.viewholder.EpisodeItemViewHolder import io.reactivex.Maybe diff --git a/app/src/main/java/ac/mdiq/podcini/ui/fragment/NavDrawerFragment.kt b/app/src/main/java/ac/mdiq/podcini/ui/fragment/NavDrawerFragment.kt index 350cd3f9..1ac2c21a 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/fragment/NavDrawerFragment.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/fragment/NavDrawerFragment.kt @@ -10,10 +10,10 @@ import ac.mdiq.podcini.storage.model.feed.Feed import ac.mdiq.podcini.ui.activity.MainActivity import ac.mdiq.podcini.ui.activity.PreferenceActivity import ac.mdiq.podcini.ui.adapter.NavListAdapter -import ac.mdiq.podcini.ui.appstartintent.MainActivityStarter -import ac.mdiq.podcini.ui.common.ThemeUtils +import ac.mdiq.podcini.ui.activity.appstartintent.MainActivityStarter +import ac.mdiq.podcini.ui.utils.ThemeUtils import ac.mdiq.podcini.ui.dialog.* -import ac.mdiq.podcini.ui.menuhandler.MenuItemUtils +import ac.mdiq.podcini.ui.actions.menuhandler.MenuItemUtils import ac.mdiq.podcini.ui.statistics.StatisticsFragment import ac.mdiq.podcini.util.event.FeedListUpdateEvent import ac.mdiq.podcini.util.event.QueueEvent @@ -83,8 +83,7 @@ class NavDrawerFragment : Fragment(), SharedPreferences.OnSharedPreferenceChange navigationBarHeight = if (requireActivity().window.navigationBarDividerColor == Color.TRANSPARENT ) 0f else 1 * resources.displayMetrics.density // Assuming the divider is 1dp in height } - val bottomInset = max(0.0, Math.round(bars.bottom - navigationBarHeight).toDouble()) - .toFloat() + val bottomInset = max(0.0, Math.round(bars.bottom - navigationBarHeight).toDouble()).toFloat() (view.layoutParams as ViewGroup.MarginLayoutParams).bottomMargin = bottomInset.toInt() insets } @@ -155,9 +154,8 @@ class NavDrawerFragment : Fragment(), SharedPreferences.OnSharedPreferenceChange override fun onContextItemSelected(item: MenuItem): Boolean { val pressedItem: NavDrawerData.FeedDrawerItem? = contextPressedItem contextPressedItem = null - if (pressedItem == null) { - return false - } + if (pressedItem == null) return false + return onFeedContextMenuClicked(pressedItem.feed, item) } @@ -211,7 +209,7 @@ class NavDrawerFragment : Fragment(), SharedPreferences.OnSharedPreferenceChange fun onQueueChanged(event: QueueEvent) { Log.d(TAG, "onQueueChanged($event)") // we are only interested in the number of queue items, not download status or position - if (event.action == ac.mdiq.podcini.util.event.QueueEvent.Action.DELETED_MEDIA || event.action == ac.mdiq.podcini.util.event.QueueEvent.Action.SORTED || event.action == ac.mdiq.podcini.util.event.QueueEvent.Action.MOVED) { + if (event.action == QueueEvent.Action.DELETED_MEDIA || event.action == QueueEvent.Action.SORTED || event.action == QueueEvent.Action.MOVED) { return } loadData() @@ -224,11 +222,7 @@ class NavDrawerFragment : Fragment(), SharedPreferences.OnSharedPreferenceChange private val itemAccess: NavListAdapter.ItemAccess = object : NavListAdapter.ItemAccess { override val count: Int - get() = if (flatItemList != null) { - flatItemList!!.size - } else { - 0 - } + get() = flatItemList?.size ?: 0 override fun getItem(position: Int): NavDrawerData.FeedDrawerItem? { return if (flatItemList != null && 0 <= position && position < flatItemList!!.size) { @@ -257,22 +251,21 @@ class NavDrawerFragment : Fragment(), SharedPreferences.OnSharedPreferenceChange } override val queueSize: Int - get() = if ((navDrawerData != null)) navDrawerData!!.queueSize else 0 + get() = navDrawerData?.queueSize ?: 0 override val numberOfNewItems: Int - get() = if ((navDrawerData != null)) navDrawerData!!.numNewItems else 0 + get() = navDrawerData?.numNewItems ?: 0 override val numberOfDownloadedItems: Int - get() = if ((navDrawerData != null)) navDrawerData!!.numDownloadedItems else 0 + get() = navDrawerData?.numDownloadedItems ?: 0 override val reclaimableItems: Int - get() = if ((navDrawerData != null)) navDrawerData!!.reclaimableSpace else 0 + get() = navDrawerData?.reclaimableSpace ?: 0 override val feedCounterSum: Int get() { - if (navDrawerData == null) { - return 0 - } + if (navDrawerData == null) return 0 + var sum = 0 for (counter in navDrawerData!!.feedCounters.values) { sum += counter diff --git a/app/src/main/java/ac/mdiq/podcini/ui/fragment/OnlineFeedViewFragment.kt b/app/src/main/java/ac/mdiq/podcini/ui/fragment/OnlineFeedViewFragment.kt index 92dce3cc..f52c9831 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/fragment/OnlineFeedViewFragment.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/fragment/OnlineFeedViewFragment.kt @@ -12,9 +12,9 @@ import ac.mdiq.podcini.net.discovery.CombinedSearcher import ac.mdiq.podcini.net.discovery.PodcastSearcherRegistry import ac.mdiq.podcini.net.download.serviceinterface.DownloadServiceInterface import ac.mdiq.podcini.preferences.UserPreferences.isEnableAutodownload -import ac.mdiq.podcini.service.download.DownloadRequestCreator.create -import ac.mdiq.podcini.service.download.Downloader -import ac.mdiq.podcini.service.download.HttpDownloader +import ac.mdiq.podcini.net.download.service.DownloadRequestCreator.create +import ac.mdiq.podcini.net.download.service.Downloader +import ac.mdiq.podcini.net.download.service.HttpDownloader import ac.mdiq.podcini.storage.DBReader import ac.mdiq.podcini.storage.DBTasks import ac.mdiq.podcini.storage.DBWriter @@ -23,9 +23,9 @@ import ac.mdiq.podcini.storage.model.download.DownloadResult import ac.mdiq.podcini.storage.model.feed.Feed import ac.mdiq.podcini.storage.model.feed.FeedItem import ac.mdiq.podcini.ui.activity.MainActivity -import ac.mdiq.podcini.ui.common.ThemeUtils.getColorFromAttr +import ac.mdiq.podcini.ui.utils.ThemeUtils.getColorFromAttr import ac.mdiq.podcini.ui.dialog.AuthenticationDialog -import ac.mdiq.podcini.ui.glide.FastBlurTransformation +import ac.mdiq.podcini.glide.FastBlurTransformation import ac.mdiq.podcini.util.DownloadErrorLabel.from import ac.mdiq.podcini.util.event.EpisodeDownloadEvent import ac.mdiq.podcini.util.event.FeedListUpdateEvent diff --git a/app/src/main/java/ac/mdiq/podcini/ui/common/PagedToolbarFragment.kt b/app/src/main/java/ac/mdiq/podcini/ui/fragment/PagedToolbarFragment.kt similarity index 98% rename from app/src/main/java/ac/mdiq/podcini/ui/common/PagedToolbarFragment.kt rename to app/src/main/java/ac/mdiq/podcini/ui/fragment/PagedToolbarFragment.kt index bd7bacbe..79a410b8 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/common/PagedToolbarFragment.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/fragment/PagedToolbarFragment.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.common +package ac.mdiq.podcini.ui.fragment import android.view.MenuItem import androidx.fragment.app.Fragment diff --git a/app/src/main/java/ac/mdiq/podcini/ui/fragment/PlaybackHistoryFragment.kt b/app/src/main/java/ac/mdiq/podcini/ui/fragment/PlaybackHistoryFragment.kt index d9305178..e26994c6 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/fragment/PlaybackHistoryFragment.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/fragment/PlaybackHistoryFragment.kt @@ -11,7 +11,7 @@ import ac.mdiq.podcini.R import ac.mdiq.podcini.ui.dialog.ConfirmationDialog import ac.mdiq.podcini.storage.DBReader import ac.mdiq.podcini.storage.DBWriter -import ac.mdiq.podcini.playback.event.PlaybackHistoryEvent +import ac.mdiq.podcini.util.event.playback.PlaybackHistoryEvent import ac.mdiq.podcini.storage.model.feed.FeedItem import ac.mdiq.podcini.storage.model.feed.FeedItemFilter import android.util.Log diff --git a/app/src/main/java/ac/mdiq/podcini/ui/fragment/PlayerDetailsFragment.kt b/app/src/main/java/ac/mdiq/podcini/ui/fragment/PlayerDetailsFragment.kt index db35d5d1..07864010 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/fragment/PlayerDetailsFragment.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/fragment/PlayerDetailsFragment.kt @@ -4,10 +4,11 @@ import ac.mdiq.podcini.R import ac.mdiq.podcini.databinding.PlayerDetailsFragmentBinding import ac.mdiq.podcini.feed.util.ImageResourceUtils import ac.mdiq.podcini.playback.PlaybackController -import ac.mdiq.podcini.playback.event.PlaybackPositionEvent +import ac.mdiq.podcini.util.event.playback.PlaybackPositionEvent import ac.mdiq.podcini.storage.DBReader import ac.mdiq.podcini.storage.model.feed.Chapter import ac.mdiq.podcini.storage.model.feed.EmbeddedChapterImage +import ac.mdiq.podcini.storage.model.feed.FeedItem import ac.mdiq.podcini.storage.model.feed.FeedMedia import ac.mdiq.podcini.storage.model.playback.Playable import ac.mdiq.podcini.ui.activity.MainActivity @@ -64,8 +65,11 @@ class PlayerDetailsFragment : Fragment() { private val binding get() = _binding!! private var media: Playable? = null + private var item: FeedItem? = null + private var loadedMediaId: Any? = null private var displayedChapterIndex = -1 + private var cleanedNotes: String? = null private var disposable: Disposable? = null private var webViewLoader: Disposable? = null private var controller: PlaybackController? = null @@ -81,8 +85,7 @@ class PlayerDetailsFragment : Fragment() { binding.butNextChapter.colorFilter = colorFilter binding.butPrevChapter.colorFilter = colorFilter binding.chapterButton.setOnClickListener { - ChaptersFragment().show( - childFragmentManager, ChaptersFragment.TAG) + ChaptersFragment().show(childFragmentManager, ChaptersFragment.TAG) } binding.butPrevChapter.setOnClickListener { seekToPrevChapter() } binding.butNextChapter.setOnClickListener { seekToNextChapter() } @@ -111,12 +114,9 @@ class PlayerDetailsFragment : Fragment() { controller = object : PlaybackController(requireActivity()) { override fun loadMediaInfo() { load() - loadMediaInfo(false) } } controller?.init() - load() - loadMediaInfo(false) return binding.root } @@ -147,11 +147,20 @@ class PlayerDetailsFragment : Fragment() { } if (media is FeedMedia) { val feedMedia = media as FeedMedia - val item = feedMedia.item - if (item != null && item.description == null) DBReader.loadDescriptionOfFeedItem(item) + item = feedMedia.item } - val shownotesCleaner = ShownotesCleaner(context, media!!.getDescription()?:"", media!!.getDuration()) - emitter.onSuccess(shownotesCleaner.processShownotes()) +// Log.d(TAG, "webViewLoader ${item?.id} ${cleanedNotes==null} ${item!!.description==null} ${loadedMediaId == null} ${item?.media?.getIdentifier()} ${media?.getIdentifier()}") + if (item != null) { + if (cleanedNotes == null || item!!.description == null || loadedMediaId != media?.getIdentifier()) { + Log.d(TAG, "calling load description ${cleanedNotes==null} ${item!!.description==null} ${item!!.media?.getIdentifier()} ${media?.getIdentifier()}") +// printStackTrce() + DBReader.loadDescriptionOfFeedItem(item!!) + loadedMediaId = media?.getIdentifier() + val shownotesCleaner = ShownotesCleaner(context, item?.description ?: "", media?.getDuration()?:0) + cleanedNotes = shownotesCleaner.processShownotes() + } + } + emitter.onSuccess(cleanedNotes?:"") } .subscribeOn(Schedulers.io()) .observeOn(AndroidSchedulers.mainThread()) @@ -160,9 +169,10 @@ class PlayerDetailsFragment : Fragment() { "utf-8", "about:blank") Log.d(TAG, "Webview loaded") }, { error: Throwable? -> Log.e(TAG, Log.getStackTraceString(error)) }) + loadMediaInfo() } - @UnstableApi private fun loadMediaInfo(includingChapters: Boolean) { + @UnstableApi private fun loadMediaInfo() { disposable?.dispose() disposable = Maybe.create { emitter: MaybeEmitter -> @@ -183,14 +193,16 @@ class PlayerDetailsFragment : Fragment() { @UnstableApi private fun displayMediaInfo(media: Playable) { val pubDateStr = DateFormatter.formatAbbrev(context, media.getPubDate()) binding.txtvPodcastTitle.text = StringUtils.stripToEmpty(media.getFeedTitle()) - if (media is FeedMedia) { - val items = media.item - if (items != null) { - val openFeed: Intent = MainActivity.getIntentToOpenFeed(requireContext(), items.feedId) - binding.txtvPodcastTitle.setOnClickListener { startActivity(openFeed) } + if (item == null || item!!.media?.getIdentifier() != media.getIdentifier()) { + if (media is FeedMedia) { + item = media.item + if (item != null) { + val openFeed: Intent = MainActivity.getIntentToOpenFeed(requireContext(), item!!.feedId) + binding.txtvPodcastTitle.setOnClickListener { startActivity(openFeed) } + } + } else { + binding.txtvPodcastTitle.setOnClickListener(null) } - } else { - binding.txtvPodcastTitle.setOnClickListener(null) } binding.txtvPodcastTitle.setOnLongClickListener { copyText(media.getFeedTitle()) } binding.episodeDate.text = StringUtils.stripToEmpty(pubDateStr) @@ -205,11 +217,9 @@ class PlayerDetailsFragment : Fragment() { - binding.txtvEpisodeTitle.paddingBottom) val verticalMarquee: ObjectAnimator = ObjectAnimator.ofInt( binding.txtvEpisodeTitle, "scrollY", 0, - (lines - binding.txtvEpisodeTitle.maxLines) - * (titleHeight / binding.txtvEpisodeTitle.maxLines)) + (lines - binding.txtvEpisodeTitle.maxLines) * (titleHeight / binding.txtvEpisodeTitle.maxLines)) .setDuration((lines * animUnit).toLong()) - val fadeOut: ObjectAnimator = ObjectAnimator.ofFloat( - binding.txtvEpisodeTitle, "alpha", 0f) + val fadeOut: ObjectAnimator = ObjectAnimator.ofFloat(binding.txtvEpisodeTitle, "alpha", 0f) fadeOut.setStartDelay(animUnit.toLong()) fadeOut.addListener(object : AnimatorListenerAdapter() { override fun onAnimationEnd(animation: Animator) { @@ -307,9 +317,7 @@ class PlayerDetailsFragment : Fragment() { @UnstableApi private fun seekToPrevChapter() { val curr: Chapter? = currentChapter - if (controller == null || curr == null || displayedChapterIndex == -1) { - return - } + if (controller == null || curr == null || displayedChapterIndex == -1) return when { displayedChapterIndex < 1 -> { @@ -363,9 +371,14 @@ class PlayerDetailsFragment : Fragment() { val prefs = activity.getSharedPreferences(PREF, Activity.MODE_PRIVATE) val id = prefs.getString(PREF_PLAYABLE_ID, "") val scrollY = prefs.getInt(PREF_SCROLL_Y, -1) - if (controller != null && scrollY != -1 && controller!!.getMedia() != null && id == controller!!.getMedia()!!.getIdentifier().toString()) { - Log.d(TAG, "Restored scroll Position: $scrollY") - webvDescription.scrollTo(webvDescription.scrollX, scrollY) + if (scrollY != -1) { + if (id == controller?.getMedia()?.getIdentifier()?.toString()) { + Log.d(TAG, "Restored scroll Position: $scrollY") + webvDescription.scrollTo(webvDescription.scrollX, scrollY) + return true + } + Log.d(TAG, "reset scroll Position: 0") + webvDescription.scrollTo(webvDescription.scrollX, 0) return true } } @@ -385,6 +398,11 @@ class PlayerDetailsFragment : Fragment() { } } + fun setItem(item_: FeedItem) { + Log.d(TAG, "setItem ${item_.title}") + item = item_ + } + // override fun onConfigurationChanged(newConfig: Configuration) { // super.onConfigurationChanged(newConfig) // configureForOrientation(newConfig) diff --git a/app/src/main/java/ac/mdiq/podcini/ui/fragment/QueueFragment.kt b/app/src/main/java/ac/mdiq/podcini/ui/fragment/QueueFragment.kt index 6179fe4f..853c275c 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/fragment/QueueFragment.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/fragment/QueueFragment.kt @@ -6,7 +6,7 @@ import ac.mdiq.podcini.databinding.MultiSelectSpeedDialBinding import ac.mdiq.podcini.databinding.QueueFragmentBinding import ac.mdiq.podcini.feed.util.PlaybackSpeedUtils import ac.mdiq.podcini.net.download.FeedUpdateManager -import ac.mdiq.podcini.playback.event.PlaybackPositionEvent +import ac.mdiq.podcini.util.event.playback.PlaybackPositionEvent import ac.mdiq.podcini.preferences.UserPreferences import ac.mdiq.podcini.storage.DBReader import ac.mdiq.podcini.storage.DBWriter @@ -16,10 +16,10 @@ import ac.mdiq.podcini.ui.adapter.QueueRecyclerAdapter import ac.mdiq.podcini.ui.adapter.SelectableAdapter import ac.mdiq.podcini.ui.dialog.ConfirmationDialog import ac.mdiq.podcini.ui.dialog.ItemSortDialog -import ac.mdiq.podcini.ui.fragment.actions.EpisodeMultiSelectActionHandler -import ac.mdiq.podcini.ui.fragment.swipeactions.SwipeActions -import ac.mdiq.podcini.ui.menuhandler.FeedItemMenuHandler -import ac.mdiq.podcini.ui.menuhandler.MenuItemUtils +import ac.mdiq.podcini.ui.actions.EpisodeMultiSelectActionHandler +import ac.mdiq.podcini.ui.actions.swipeactions.SwipeActions +import ac.mdiq.podcini.ui.actions.menuhandler.FeedItemMenuHandler +import ac.mdiq.podcini.ui.actions.menuhandler.MenuItemUtils import ac.mdiq.podcini.ui.view.EmptyViewHandler import ac.mdiq.podcini.ui.view.EpisodeItemListRecyclerView import ac.mdiq.podcini.ui.view.LiftOnScrollListener @@ -27,7 +27,6 @@ import ac.mdiq.podcini.ui.view.viewholder.EpisodeItemViewHolder import ac.mdiq.podcini.util.Converter import ac.mdiq.podcini.util.FeedItemUtil import ac.mdiq.podcini.util.event.* -import ac.mdiq.podcini.util.event.settings.SpeedPresetChangedEvent import android.content.Context import android.content.DialogInterface import android.content.SharedPreferences diff --git a/app/src/main/java/ac/mdiq/podcini/ui/fragment/SearchFragment.kt b/app/src/main/java/ac/mdiq/podcini/ui/fragment/SearchFragment.kt index a3f09d16..4242127c 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/fragment/SearchFragment.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/fragment/SearchFragment.kt @@ -5,7 +5,7 @@ import ac.mdiq.podcini.R import ac.mdiq.podcini.databinding.MultiSelectSpeedDialBinding import ac.mdiq.podcini.databinding.SearchFragmentBinding import ac.mdiq.podcini.net.discovery.CombinedSearcher -import ac.mdiq.podcini.playback.event.PlaybackPositionEvent +import ac.mdiq.podcini.util.event.playback.PlaybackPositionEvent import ac.mdiq.podcini.storage.FeedSearcher import ac.mdiq.podcini.storage.model.feed.Feed import ac.mdiq.podcini.storage.model.feed.FeedItem @@ -13,10 +13,10 @@ import ac.mdiq.podcini.ui.activity.MainActivity import ac.mdiq.podcini.ui.adapter.EpisodeItemListAdapter import ac.mdiq.podcini.ui.adapter.HorizontalFeedListAdapter import ac.mdiq.podcini.ui.adapter.SelectableAdapter -import ac.mdiq.podcini.ui.fragment.actions.EpisodeMultiSelectActionHandler -import ac.mdiq.podcini.ui.menuhandler.FeedItemMenuHandler -import ac.mdiq.podcini.ui.menuhandler.FeedMenuHandler -import ac.mdiq.podcini.ui.menuhandler.MenuItemUtils +import ac.mdiq.podcini.ui.actions.EpisodeMultiSelectActionHandler +import ac.mdiq.podcini.ui.actions.menuhandler.FeedItemMenuHandler +import ac.mdiq.podcini.ui.actions.menuhandler.FeedMenuHandler +import ac.mdiq.podcini.ui.actions.menuhandler.MenuItemUtils import ac.mdiq.podcini.ui.view.EmptyViewHandler import ac.mdiq.podcini.ui.view.EpisodeItemListRecyclerView import ac.mdiq.podcini.ui.view.LiftOnScrollListener diff --git a/app/src/main/java/ac/mdiq/podcini/ui/fragment/SubscriptionFragment.kt b/app/src/main/java/ac/mdiq/podcini/ui/fragment/SubscriptionFragment.kt index 46a24f31..9c6f0ca7 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/fragment/SubscriptionFragment.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/fragment/SubscriptionFragment.kt @@ -13,9 +13,9 @@ import ac.mdiq.podcini.ui.adapter.SelectableAdapter import ac.mdiq.podcini.ui.adapter.SubscriptionsAdapter import ac.mdiq.podcini.ui.dialog.FeedSortDialog import ac.mdiq.podcini.ui.dialog.SubscriptionsFilterDialog -import ac.mdiq.podcini.ui.fragment.actions.FeedMultiSelectActionHandler -import ac.mdiq.podcini.ui.menuhandler.FeedMenuHandler -import ac.mdiq.podcini.ui.menuhandler.MenuItemUtils +import ac.mdiq.podcini.ui.actions.FeedMultiSelectActionHandler +import ac.mdiq.podcini.ui.actions.menuhandler.FeedMenuHandler +import ac.mdiq.podcini.ui.actions.menuhandler.MenuItemUtils import ac.mdiq.podcini.ui.view.EmptyViewHandler import ac.mdiq.podcini.ui.view.LiftOnScrollListener import ac.mdiq.podcini.util.event.FeedListUpdateEvent diff --git a/app/src/main/java/ac/mdiq/podcini/ui/statistics/StatisticsFragment.kt b/app/src/main/java/ac/mdiq/podcini/ui/statistics/StatisticsFragment.kt index b6d088f5..59e6280e 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/statistics/StatisticsFragment.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/statistics/StatisticsFragment.kt @@ -5,7 +5,7 @@ import ac.mdiq.podcini.R import ac.mdiq.podcini.databinding.PagerFragmentBinding import ac.mdiq.podcini.storage.DBWriter import ac.mdiq.podcini.ui.activity.MainActivity -import ac.mdiq.podcini.ui.common.PagedToolbarFragment +import ac.mdiq.podcini.ui.fragment.PagedToolbarFragment import ac.mdiq.podcini.ui.dialog.ConfirmationDialog import ac.mdiq.podcini.ui.statistics.downloads.DownloadStatisticsFragment import ac.mdiq.podcini.ui.statistics.subscriptions.SubscriptionStatisticsFragment diff --git a/app/src/main/java/ac/mdiq/podcini/ui/statistics/feed/FeedStatisticsDialogFragment.kt b/app/src/main/java/ac/mdiq/podcini/ui/statistics/feed/FeedStatisticsDialogFragment.kt index 88350586..65045a02 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/statistics/feed/FeedStatisticsDialogFragment.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/statistics/feed/FeedStatisticsDialogFragment.kt @@ -7,7 +7,7 @@ import android.content.DialogInterface import android.os.Bundle import androidx.fragment.app.DialogFragment import com.google.android.material.dialog.MaterialAlertDialogBuilder -import ac.mdiq.podcini.ui.appstartintent.MainActivityStarter +import ac.mdiq.podcini.ui.activity.appstartintent.MainActivityStarter class FeedStatisticsDialogFragment : DialogFragment() { override fun onCreateDialog(savedInstanceState: Bundle?): Dialog { diff --git a/app/src/main/java/ac/mdiq/podcini/ui/statistics/years/BarChartView.kt b/app/src/main/java/ac/mdiq/podcini/ui/statistics/years/BarChartView.kt index a458e0d5..3ce3e6c7 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/statistics/years/BarChartView.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/statistics/years/BarChartView.kt @@ -9,7 +9,7 @@ import android.graphics.drawable.Drawable import android.util.AttributeSet import androidx.appcompat.widget.AppCompatImageView import ac.mdiq.podcini.storage.DBReader.MonthlyStatisticsItem -import ac.mdiq.podcini.ui.common.ThemeUtils.getColorFromAttr +import ac.mdiq.podcini.ui.utils.ThemeUtils.getColorFromAttr import kotlin.math.floor import kotlin.math.max diff --git a/app/src/main/java/ac/mdiq/podcini/ui/common/ThemeUtils.kt b/app/src/main/java/ac/mdiq/podcini/ui/utils/ThemeUtils.kt similarity index 96% rename from app/src/main/java/ac/mdiq/podcini/ui/common/ThemeUtils.kt rename to app/src/main/java/ac/mdiq/podcini/ui/utils/ThemeUtils.kt index cc3958a8..6acfe7b2 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/common/ThemeUtils.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/utils/ThemeUtils.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.common +package ac.mdiq.podcini.ui.utils import android.content.Context import android.util.TypedValue diff --git a/app/src/main/java/ac/mdiq/podcini/ui/view/ChapterSeekBar.kt b/app/src/main/java/ac/mdiq/podcini/ui/view/ChapterSeekBar.kt index 10612da5..94e97482 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/view/ChapterSeekBar.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/view/ChapterSeekBar.kt @@ -8,7 +8,7 @@ import android.os.Looper import android.util.AttributeSet import androidx.appcompat.widget.AppCompatSeekBar import ac.mdiq.podcini.R -import ac.mdiq.podcini.ui.common.ThemeUtils.getColorFromAttr +import ac.mdiq.podcini.ui.utils.ThemeUtils.getColorFromAttr class ChapterSeekBar : AppCompatSeekBar { private var top = 0f diff --git a/app/src/main/java/ac/mdiq/podcini/ui/common/CircularProgressBar.kt b/app/src/main/java/ac/mdiq/podcini/ui/view/CircularProgressBar.kt similarity index 98% rename from app/src/main/java/ac/mdiq/podcini/ui/common/CircularProgressBar.kt rename to app/src/main/java/ac/mdiq/podcini/ui/view/CircularProgressBar.kt index 742ad539..52e569f8 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/common/CircularProgressBar.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/view/CircularProgressBar.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.common +package ac.mdiq.podcini.ui.view import ac.mdiq.podcini.R diff --git a/app/src/main/java/ac/mdiq/podcini/ui/common/PlaybackSpeedIndicatorView.kt b/app/src/main/java/ac/mdiq/podcini/ui/view/PlaybackSpeedIndicatorView.kt similarity index 99% rename from app/src/main/java/ac/mdiq/podcini/ui/common/PlaybackSpeedIndicatorView.kt rename to app/src/main/java/ac/mdiq/podcini/ui/view/PlaybackSpeedIndicatorView.kt index c1643913..66caa62f 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/common/PlaybackSpeedIndicatorView.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/view/PlaybackSpeedIndicatorView.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.common +package ac.mdiq.podcini.ui.view import ac.mdiq.podcini.R diff --git a/app/src/main/java/ac/mdiq/podcini/ui/view/ShownotesWebView.kt b/app/src/main/java/ac/mdiq/podcini/ui/view/ShownotesWebView.kt index b7d5923d..af4439e0 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/view/ShownotesWebView.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/view/ShownotesWebView.kt @@ -21,7 +21,7 @@ import androidx.core.content.ContextCompat import androidx.core.util.Consumer import com.google.android.material.snackbar.Snackbar import ac.mdiq.podcini.R -import ac.mdiq.podcini.ui.menuhandler.MenuItemUtils +import ac.mdiq.podcini.ui.actions.menuhandler.MenuItemUtils import ac.mdiq.podcini.util.IntentUtils import ac.mdiq.podcini.util.NetworkUtils import ac.mdiq.podcini.util.ShareUtils @@ -105,9 +105,7 @@ class ShownotesWebView : WebView, View.OnLongClickListener { } fun onContextItemSelected(item: MenuItem): Boolean { - if (selectedUrl == null) { - return false - } + if (selectedUrl == null) return false val itemId = item.itemId when (itemId) { @@ -145,9 +143,7 @@ class ShownotesWebView : WebView, View.OnLongClickListener { override fun onCreateContextMenu(menu: ContextMenu) { super.onCreateContextMenu(menu) - if (selectedUrl == null) { - return - } + if (selectedUrl == null) return if (ShownotesCleaner.isTimecodeLink(selectedUrl)) { menu.add(Menu.NONE, R.id.go_to_position_item, Menu.NONE, R.string.go_to_position_label) diff --git a/app/src/main/java/ac/mdiq/podcini/ui/common/SquareImageView.kt b/app/src/main/java/ac/mdiq/podcini/ui/view/SquareImageView.kt similarity index 98% rename from app/src/main/java/ac/mdiq/podcini/ui/common/SquareImageView.kt rename to app/src/main/java/ac/mdiq/podcini/ui/view/SquareImageView.kt index fc36dd8c..f56a5c4e 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/common/SquareImageView.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/view/SquareImageView.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.common +package ac.mdiq.podcini.ui.view import ac.mdiq.podcini.R diff --git a/app/src/main/java/ac/mdiq/podcini/ui/common/TriangleLabelView.kt b/app/src/main/java/ac/mdiq/podcini/ui/view/TriangleLabelView.kt similarity index 99% rename from app/src/main/java/ac/mdiq/podcini/ui/common/TriangleLabelView.kt rename to app/src/main/java/ac/mdiq/podcini/ui/view/TriangleLabelView.kt index e415f567..2846933e 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/common/TriangleLabelView.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/view/TriangleLabelView.kt @@ -16,7 +16,7 @@ * Source: https://github.com/shts/TriangleLabelView * Modified for our need; see Podcini #5925 for context */ -package ac.mdiq.podcini.ui.common +package ac.mdiq.podcini.ui.view import ac.mdiq.podcini.R diff --git a/app/src/main/java/ac/mdiq/podcini/ui/common/WrappingGridView.kt b/app/src/main/java/ac/mdiq/podcini/ui/view/WrappingGridView.kt similarity index 96% rename from app/src/main/java/ac/mdiq/podcini/ui/common/WrappingGridView.kt rename to app/src/main/java/ac/mdiq/podcini/ui/view/WrappingGridView.kt index 2002f1de..4d1a8543 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/common/WrappingGridView.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/view/WrappingGridView.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.ui.common +package ac.mdiq.podcini.ui.view import android.content.Context import android.util.AttributeSet diff --git a/app/src/main/java/ac/mdiq/podcini/ui/view/viewholder/DownloadLogItemViewHolder.kt b/app/src/main/java/ac/mdiq/podcini/ui/view/viewholder/DownloadLogItemViewHolder.kt index 8ccc1101..7b5c2d8f 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/view/viewholder/DownloadLogItemViewHolder.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/view/viewholder/DownloadLogItemViewHolder.kt @@ -33,9 +33,7 @@ class DownloadLogItemViewHolder(context: Context, parent: ViewGroup?) : val tapForDetails: TextView = binding.txtvTapForDetails init { - if (Build.VERSION.SDK_INT >= 23) { - title.hyphenationFrequency = Layout.HYPHENATION_FREQUENCY_FULL - } + title.hyphenationFrequency = Layout.HYPHENATION_FREQUENCY_FULL itemView.tag = this } } diff --git a/app/src/main/java/ac/mdiq/podcini/ui/view/viewholder/EpisodeItemViewHolder.kt b/app/src/main/java/ac/mdiq/podcini/ui/view/viewholder/EpisodeItemViewHolder.kt index e04bb404..0d6fb8bf 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/view/viewholder/EpisodeItemViewHolder.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/view/viewholder/EpisodeItemViewHolder.kt @@ -24,16 +24,16 @@ import ac.mdiq.podcini.util.DateFormatter import ac.mdiq.podcini.util.NetworkUtils import ac.mdiq.podcini.util.PlaybackStatus import ac.mdiq.podcini.net.download.MediaSizeLoader -import ac.mdiq.podcini.playback.event.PlaybackPositionEvent +import ac.mdiq.podcini.util.event.playback.PlaybackPositionEvent import ac.mdiq.podcini.storage.model.feed.FeedItem import ac.mdiq.podcini.storage.model.feed.FeedMedia import ac.mdiq.podcini.storage.model.playback.MediaType import ac.mdiq.podcini.storage.model.playback.Playable import ac.mdiq.podcini.net.download.serviceinterface.DownloadServiceInterface import ac.mdiq.podcini.preferences.UserPreferences -import ac.mdiq.podcini.ui.adapter.actionbutton.ItemActionButton -import ac.mdiq.podcini.ui.common.CircularProgressBar -import ac.mdiq.podcini.ui.common.ThemeUtils +import ac.mdiq.podcini.ui.actions.actionbutton.ItemActionButton +import ac.mdiq.podcini.ui.view.CircularProgressBar +import ac.mdiq.podcini.ui.utils.ThemeUtils import ac.mdiq.podcini.util.Converter import android.widget.LinearLayout import io.reactivex.functions.Consumer @@ -78,9 +78,7 @@ class EpisodeItemViewHolder(private val activity: MainActivity, parent: ViewGrou private var item: FeedItem? = null init { - if (Build.VERSION.SDK_INT >= 23) { - title.setHyphenationFrequency(Layout.HYPHENATION_FREQUENCY_FULL) - } + title.setHyphenationFrequency(Layout.HYPHENATION_FREQUENCY_FULL) itemView.tag = this } diff --git a/app/src/main/java/ac/mdiq/podcini/ui/widget/WidgetUpdater.kt b/app/src/main/java/ac/mdiq/podcini/ui/widget/WidgetUpdater.kt index 1eae002b..b881bae5 100644 --- a/app/src/main/java/ac/mdiq/podcini/ui/widget/WidgetUpdater.kt +++ b/app/src/main/java/ac/mdiq/podcini/ui/widget/WidgetUpdater.kt @@ -24,9 +24,9 @@ import ac.mdiq.podcini.storage.model.playback.MediaType import ac.mdiq.podcini.storage.model.playback.Playable import ac.mdiq.podcini.playback.base.PlayerStatus import ac.mdiq.podcini.preferences.UserPreferences.shouldShowRemainingTime -import ac.mdiq.podcini.ui.appstartintent.MainActivityStarter -import ac.mdiq.podcini.ui.appstartintent.PlaybackSpeedActivityStarter -import ac.mdiq.podcini.ui.appstartintent.VideoPlayerActivityStarter +import ac.mdiq.podcini.ui.activity.appstartintent.MainActivityStarter +import ac.mdiq.podcini.ui.activity.appstartintent.PlaybackSpeedActivityStarter +import ac.mdiq.podcini.ui.activity.appstartintent.VideoPlayerActivityStarter import java.util.concurrent.TimeUnit import kotlin.math.max diff --git a/app/src/main/java/ac/mdiq/podcini/util/ChapterUtils.kt b/app/src/main/java/ac/mdiq/podcini/util/ChapterUtils.kt index c4690f91..c966f477 100644 --- a/app/src/main/java/ac/mdiq/podcini/util/ChapterUtils.kt +++ b/app/src/main/java/ac/mdiq/podcini/util/ChapterUtils.kt @@ -5,7 +5,7 @@ import android.content.Context import android.net.Uri import android.util.Log import ac.mdiq.podcini.feed.ChapterMerger.merge -import ac.mdiq.podcini.service.download.PodciniHttpClient.getHttpClient +import ac.mdiq.podcini.net.download.service.PodciniHttpClient.getHttpClient import ac.mdiq.podcini.storage.DBReader import ac.mdiq.podcini.util.comparator.ChapterStartTimeComparator import ac.mdiq.podcini.storage.model.feed.Chapter diff --git a/app/src/main/java/ac/mdiq/podcini/util/FeedItemUtil.kt b/app/src/main/java/ac/mdiq/podcini/util/FeedItemUtil.kt index f8b397a5..d9b73c0d 100644 --- a/app/src/main/java/ac/mdiq/podcini/util/FeedItemUtil.kt +++ b/app/src/main/java/ac/mdiq/podcini/util/FeedItemUtil.kt @@ -3,6 +3,7 @@ package ac.mdiq.podcini.util import ac.mdiq.podcini.storage.model.feed.FeedItem import ac.mdiq.podcini.storage.model.feed.FeedMedia import ac.mdiq.podcini.preferences.UserPreferences +import ac.mdiq.podcini.storage.model.playback.Playable import org.apache.commons.lang3.StringUtils object FeedItemUtil { @@ -70,7 +71,7 @@ object FeedItemUtil { } @JvmStatic - fun hasAlmostEnded(media: FeedMedia): Boolean { + fun hasAlmostEnded(media: Playable): Boolean { val smartMarkAsPlayedSecs = UserPreferences.smartMarkAsPlayedSecs return media.getDuration() > 0 && media.getPosition() >= media.getDuration() - smartMarkAsPlayedSecs * 1000 } diff --git a/app/src/main/java/ac/mdiq/podcini/util/NetworkUtils.kt b/app/src/main/java/ac/mdiq/podcini/util/NetworkUtils.kt index 7e57179e..42566a7a 100644 --- a/app/src/main/java/ac/mdiq/podcini/util/NetworkUtils.kt +++ b/app/src/main/java/ac/mdiq/podcini/util/NetworkUtils.kt @@ -82,9 +82,6 @@ object NetworkUtils { @JvmStatic val isVpnOverWifi: Boolean get() { - if (Build.VERSION.SDK_INT < Build.VERSION_CODES.M) { - return false - } val connManager = context.getSystemService(Context.CONNECTIVITY_SERVICE) as ConnectivityManager val capabilities = connManager.getNetworkCapabilities(connManager.activeNetwork) return (capabilities != null && capabilities.hasTransport(NetworkCapabilities.TRANSPORT_WIFI) @@ -94,17 +91,17 @@ object NetworkUtils { private val isNetworkCellular: Boolean get() { val connManager = context.getSystemService(Context.CONNECTIVITY_SERVICE) as ConnectivityManager - if (Build.VERSION.SDK_INT >= 23) { - val network = connManager.activeNetwork ?: return false // Nothing connected - val info = connManager.getNetworkInfo(network) ?: return true // Better be safe than sorry - val capabilities = connManager.getNetworkCapabilities(network) ?: return true // Better be safe than sorry - return capabilities.hasTransport(NetworkCapabilities.TRANSPORT_CELLULAR) - } else { - // if the default network is a VPN, - // this method will return the NetworkInfo for one of its underlying networks - val info = connManager.activeNetworkInfo ?: return false // Nothing connected - return info.type == ConnectivityManager.TYPE_MOBILE - } +// if (Build.VERSION.SDK_INT >= 23) { + val network = connManager.activeNetwork ?: return false // Nothing connected + val info = connManager.getNetworkInfo(network) ?: return true // Better be safe than sorry + val capabilities = connManager.getNetworkCapabilities(network) ?: return true // Better be safe than sorry + return capabilities.hasTransport(NetworkCapabilities.TRANSPORT_CELLULAR) +// } else { +// // if the default network is a VPN, +// // this method will return the NetworkInfo for one of its underlying networks +// val info = connManager.activeNetworkInfo ?: return false // Nothing connected +// return info.type == ConnectivityManager.TYPE_MOBILE +// } } private val isInAllowedWifiNetwork: Boolean diff --git a/app/src/main/java/ac/mdiq/podcini/util/PlaybackStatus.kt b/app/src/main/java/ac/mdiq/podcini/util/PlaybackStatus.kt index f65e62cc..3ef1cad4 100644 --- a/app/src/main/java/ac/mdiq/podcini/util/PlaybackStatus.kt +++ b/app/src/main/java/ac/mdiq/podcini/util/PlaybackStatus.kt @@ -2,7 +2,7 @@ package ac.mdiq.podcini.util import androidx.media3.common.util.UnstableApi import ac.mdiq.podcini.preferences.PlaybackPreferences -import ac.mdiq.podcini.service.playback.PlaybackService +import ac.mdiq.podcini.playback.service.PlaybackService import ac.mdiq.podcini.storage.model.feed.FeedMedia @UnstableApi diff --git a/app/src/main/java/ac/mdiq/podcini/util/ShareUtils.kt b/app/src/main/java/ac/mdiq/podcini/util/ShareUtils.kt index 170f9857..bb0eb2c1 100644 --- a/app/src/main/java/ac/mdiq/podcini/util/ShareUtils.kt +++ b/app/src/main/java/ac/mdiq/podcini/util/ShareUtils.kt @@ -27,14 +27,23 @@ object ShareUtils { context.startActivity(intent) } +// fun shareFeedLink(context: Context, feed: Feed) { +// val text = """ +// ${feed.title} +// +// https://podcini.org/deeplink/subscribe/?url=${URLEncoder.encode(feed.download_url)}&title=${ +// URLEncoder.encode(feed.title) +// } +// """.trimIndent() +// shareLink(context, text) +// } + @JvmStatic fun shareFeedLink(context: Context, feed: Feed) { val text = """ ${feed.title} - https://podcini.org/deeplink/subscribe/?url=${URLEncoder.encode(feed.download_url)}&title=${ - URLEncoder.encode(feed.title) - } + ${URLEncoder.encode(feed.download_url)}&title=${URLEncoder.encode(feed.title)} """.trimIndent() shareLink(context, text) } diff --git a/app/src/main/java/ac/mdiq/podcini/util/StackTrace.kt b/app/src/main/java/ac/mdiq/podcini/util/StackTrace.kt new file mode 100644 index 00000000..6ca77643 --- /dev/null +++ b/app/src/main/java/ac/mdiq/podcini/util/StackTrace.kt @@ -0,0 +1,8 @@ +package ac.mdiq.podcini.util + +fun printStackTrace() { + val stackTraceElements = Thread.currentThread().stackTrace + stackTraceElements.forEach { element -> + println(element) + } +} \ No newline at end of file diff --git a/app/src/main/java/ac/mdiq/podcini/util/config/ClientConfigurator.kt b/app/src/main/java/ac/mdiq/podcini/util/config/ClientConfigurator.kt index 227dd617..4d99a3a8 100644 --- a/app/src/main/java/ac/mdiq/podcini/util/config/ClientConfigurator.kt +++ b/app/src/main/java/ac/mdiq/podcini/util/config/ClientConfigurator.kt @@ -5,8 +5,8 @@ import androidx.media3.common.util.UnstableApi import ac.mdiq.podcini.preferences.PlaybackPreferences import ac.mdiq.podcini.preferences.SleepTimerPreferences import ac.mdiq.podcini.preferences.UsageStatistics -import ac.mdiq.podcini.service.download.PodciniHttpClient.setCacheDirectory -import ac.mdiq.podcini.service.download.PodciniHttpClient.setProxyConfig +import ac.mdiq.podcini.net.download.service.PodciniHttpClient.setCacheDirectory +import ac.mdiq.podcini.net.download.service.PodciniHttpClient.setProxyConfig import ac.mdiq.podcini.net.sync.SyncService import ac.mdiq.podcini.net.sync.queue.SynchronizationQueueSink import ac.mdiq.podcini.util.NetworkUtils @@ -17,7 +17,7 @@ import ac.mdiq.podcini.net.ssl.SslProviderInstaller import ac.mdiq.podcini.storage.database.PodDBAdapter import ac.mdiq.podcini.preferences.UserPreferences import ac.mdiq.podcini.preferences.UserPreferences.proxyConfig -import ac.mdiq.podcini.service.download.DownloadServiceInterfaceImpl +import ac.mdiq.podcini.net.download.service.DownloadServiceInterfaceImpl import java.io.File @UnstableApi diff --git a/app/src/main/java/ac/mdiq/podcini/playback/event/BufferUpdateEvent.kt b/app/src/main/java/ac/mdiq/podcini/util/event/playback/BufferUpdateEvent.kt similarity index 94% rename from app/src/main/java/ac/mdiq/podcini/playback/event/BufferUpdateEvent.kt rename to app/src/main/java/ac/mdiq/podcini/util/event/playback/BufferUpdateEvent.kt index 6755bb40..82fc63dd 100644 --- a/app/src/main/java/ac/mdiq/podcini/playback/event/BufferUpdateEvent.kt +++ b/app/src/main/java/ac/mdiq/podcini/util/event/playback/BufferUpdateEvent.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.playback.event +package ac.mdiq.podcini.util.event.playback class BufferUpdateEvent private constructor(@JvmField val progress: Float) { fun hasStarted(): Boolean { diff --git a/app/src/main/java/ac/mdiq/podcini/playback/event/PlaybackHistoryEvent.kt b/app/src/main/java/ac/mdiq/podcini/util/event/playback/PlaybackHistoryEvent.kt similarity index 86% rename from app/src/main/java/ac/mdiq/podcini/playback/event/PlaybackHistoryEvent.kt rename to app/src/main/java/ac/mdiq/podcini/util/event/playback/PlaybackHistoryEvent.kt index 91b1c6d5..2aec0a40 100644 --- a/app/src/main/java/ac/mdiq/podcini/playback/event/PlaybackHistoryEvent.kt +++ b/app/src/main/java/ac/mdiq/podcini/util/event/playback/PlaybackHistoryEvent.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.playback.event +package ac.mdiq.podcini.util.event.playback class PlaybackHistoryEvent private constructor() { override fun toString(): String { diff --git a/app/src/main/java/ac/mdiq/podcini/playback/event/PlaybackPositionEvent.kt b/app/src/main/java/ac/mdiq/podcini/util/event/playback/PlaybackPositionEvent.kt similarity index 66% rename from app/src/main/java/ac/mdiq/podcini/playback/event/PlaybackPositionEvent.kt rename to app/src/main/java/ac/mdiq/podcini/util/event/playback/PlaybackPositionEvent.kt index d823d1a4..b217c909 100644 --- a/app/src/main/java/ac/mdiq/podcini/playback/event/PlaybackPositionEvent.kt +++ b/app/src/main/java/ac/mdiq/podcini/util/event/playback/PlaybackPositionEvent.kt @@ -1,3 +1,3 @@ -package ac.mdiq.podcini.playback.event +package ac.mdiq.podcini.util.event.playback class PlaybackPositionEvent(@JvmField val position: Int, @JvmField val duration: Int) diff --git a/app/src/main/java/ac/mdiq/podcini/playback/event/PlaybackServiceEvent.kt b/app/src/main/java/ac/mdiq/podcini/util/event/playback/PlaybackServiceEvent.kt similarity index 76% rename from app/src/main/java/ac/mdiq/podcini/playback/event/PlaybackServiceEvent.kt rename to app/src/main/java/ac/mdiq/podcini/util/event/playback/PlaybackServiceEvent.kt index d472779c..ebf94e9c 100644 --- a/app/src/main/java/ac/mdiq/podcini/playback/event/PlaybackServiceEvent.kt +++ b/app/src/main/java/ac/mdiq/podcini/util/event/playback/PlaybackServiceEvent.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.playback.event +package ac.mdiq.podcini.util.event.playback class PlaybackServiceEvent(@JvmField val action: Action) { enum class Action { diff --git a/app/src/main/java/ac/mdiq/podcini/playback/event/SleepTimerUpdatedEvent.kt b/app/src/main/java/ac/mdiq/podcini/util/event/playback/SleepTimerUpdatedEvent.kt similarity index 95% rename from app/src/main/java/ac/mdiq/podcini/playback/event/SleepTimerUpdatedEvent.kt rename to app/src/main/java/ac/mdiq/podcini/util/event/playback/SleepTimerUpdatedEvent.kt index 1082f38f..a317a9d4 100644 --- a/app/src/main/java/ac/mdiq/podcini/playback/event/SleepTimerUpdatedEvent.kt +++ b/app/src/main/java/ac/mdiq/podcini/util/event/playback/SleepTimerUpdatedEvent.kt @@ -1,4 +1,4 @@ -package ac.mdiq.podcini.playback.event +package ac.mdiq.podcini.util.event.playback import kotlin.math.abs import kotlin.math.max diff --git a/app/src/main/java/ac/mdiq/podcini/playback/event/SpeedChangedEvent.kt b/app/src/main/java/ac/mdiq/podcini/util/event/playback/SpeedChangedEvent.kt similarity index 56% rename from app/src/main/java/ac/mdiq/podcini/playback/event/SpeedChangedEvent.kt rename to app/src/main/java/ac/mdiq/podcini/util/event/playback/SpeedChangedEvent.kt index 1cba7f2e..fc5eee47 100644 --- a/app/src/main/java/ac/mdiq/podcini/playback/event/SpeedChangedEvent.kt +++ b/app/src/main/java/ac/mdiq/podcini/util/event/playback/SpeedChangedEvent.kt @@ -1,3 +1,3 @@ -package ac.mdiq.podcini.playback.event +package ac.mdiq.podcini.util.event.playback class SpeedChangedEvent(@JvmField val newSpeed: Float) diff --git a/app/src/main/java/ac/mdiq/podcini/util/event/playback/StartPlayEvent.kt b/app/src/main/java/ac/mdiq/podcini/util/event/playback/StartPlayEvent.kt new file mode 100644 index 00000000..2a33821b --- /dev/null +++ b/app/src/main/java/ac/mdiq/podcini/util/event/playback/StartPlayEvent.kt @@ -0,0 +1,5 @@ +package ac.mdiq.podcini.util.event.playback + +import ac.mdiq.podcini.storage.model.feed.FeedItem + +class StartPlayEvent(@JvmField val item: FeedItem) \ No newline at end of file diff --git a/app/src/main/res/layout/episode_info_fragment.xml b/app/src/main/res/layout/episode_info_fragment.xml index 96b73097..e200193a 100644 --- a/app/src/main/res/layout/episode_info_fragment.xml +++ b/app/src/main/res/layout/episode_info_fragment.xml @@ -162,7 +162,7 @@ android:layout_marginBottom="4dp" android:layout_gravity="bottom|end"> - - - - - - - = 0) { oldMedia.setPosition(position) } - callback.onPostPlayback(oldMedia, false, false, false) + callback.onPostPlayback(oldMedia, ended = false, skipped = false, playingNext = false) } // onPlaybackEnded pretty much takes care of updating the UI return @@ -201,14 +201,14 @@ class CastPsmp(context: Context, callback: PSMPCallback) : PlaybackServiceMediaP if (mediaChanged && currentMedia != null) { media = currentMedia } - endPlayback(true, false, true, true) + endPlayback(true, wasSkipped = false, shouldContinue = true, toStoppedState = true) return } MediaStatus.IDLE_REASON_ERROR -> { Log.w(TAG, "Got an error status from the Chromecast. " + "Skipping, if possible, to the next episode...") EventBus.getDefault().post(PlayerErrorEvent("Chromecast error code 1")) - endPlayback(false, false, true, true) + endPlayback(false, wasSkipped = false, shouldContinue = true, toStoppedState = true) return } else -> return @@ -222,7 +222,7 @@ class CastPsmp(context: Context, callback: PSMPCallback) : PlaybackServiceMediaP if (mediaChanged) { callback.onMediaChanged(true) if (oldMedia != null) { - callback.onPostPlayback(oldMedia, false, false, currentMedia != null) + callback.onPostPlayback(oldMedia, ended = false, skipped = false, playingNext = currentMedia != null) } } } @@ -272,7 +272,7 @@ class CastPsmp(context: Context, callback: PSMPCallback) : PlaybackServiceMediaP } if (media != null && media?.getIdentifier() != playable.getIdentifier()) { val oldMedia: Playable = media!! - callback.onPostPlayback(oldMedia, false, false, true) + callback.onPostPlayback(oldMedia, false, skipped = false, playingNext = true) } setPlayerStatus(PlayerStatus.INDETERMINATE, null) } @@ -323,7 +323,10 @@ class CastPsmp(context: Context, callback: PSMPCallback) : PlaybackServiceMediaP override fun reinit() { Log.d(TAG, "reinit() called") if (media != null) { - playMediaObject(media!!, true, false, startWhenPrepared.get(), false) + playMediaObject(media!!, true, + stream = false, + startWhenPrepared = startWhenPrepared.get(), + prepareImmediately = false) } else { Log.d(TAG, "Call to reinit was ignored: media was null") } @@ -420,7 +423,7 @@ class CastPsmp(context: Context, callback: PSMPCallback) : PlaybackServiceMediaP } override fun getAudioTracks(): List { - return emptyList() + return emptyList() } override fun setAudioTrack(track: Int) { @@ -463,7 +466,11 @@ class CastPsmp(context: Context, callback: PSMPCallback) : PlaybackServiceMediaP callback.onPlaybackEnded(nextMedia.getMediaType(), !playNextEpisode) // setting media to null signals to playMediaObject() that we're taking care of post-playback processing media = null - playMediaObject(nextMedia, false, true, playNextEpisode, playNextEpisode) + playMediaObject(nextMedia, + forceReset = false, + stream = true, + startWhenPrepared = playNextEpisode, + prepareImmediately = playNextEpisode) } } if (shouldContinue || toStoppedState) { diff --git a/app/src/play/java/ac/mdiq/podcini/playback/cast/CastStateListener.kt b/app/src/play/java/ac/mdiq/podcini/playback/cast/CastStateListener.kt index 2ae04da1..b26764c4 100644 --- a/app/src/play/java/ac/mdiq/podcini/playback/cast/CastStateListener.kt +++ b/app/src/play/java/ac/mdiq/podcini/playback/cast/CastStateListener.kt @@ -11,7 +11,7 @@ open class CastStateListener(context: Context) : SessionManagerListener