2018-01-04 19:52:25 +01:00
|
|
|
package jp.juggler.subwaytooter
|
|
|
|
|
|
|
|
import android.app.DownloadManager
|
|
|
|
import android.content.BroadcastReceiver
|
|
|
|
import android.content.Context
|
|
|
|
import android.content.Intent
|
2023-01-13 13:22:25 +01:00
|
|
|
import jp.juggler.util.data.getIntOrNull
|
|
|
|
import jp.juggler.util.data.getStringOrNull
|
|
|
|
import jp.juggler.util.log.LogCategory
|
|
|
|
import jp.juggler.util.log.showToast
|
2023-01-14 21:37:23 +01:00
|
|
|
import jp.juggler.util.long
|
2018-01-04 19:52:25 +01:00
|
|
|
|
|
|
|
class DownloadReceiver : BroadcastReceiver() {
|
2019-11-15 07:13:59 +01:00
|
|
|
|
2021-06-20 15:12:25 +02:00
|
|
|
companion object {
|
|
|
|
|
|
|
|
private val log = LogCategory("DownloadReceiver")
|
|
|
|
}
|
|
|
|
|
|
|
|
override fun onReceive(context: Context, intent: Intent?) {
|
|
|
|
when (intent?.action) {
|
|
|
|
DownloadManager.ACTION_DOWNLOAD_COMPLETE -> {
|
|
|
|
|
|
|
|
val downloadManager =
|
|
|
|
context.getSystemService(Context.DOWNLOAD_SERVICE) as DownloadManager
|
|
|
|
|
|
|
|
try {
|
2023-01-14 21:37:23 +01:00
|
|
|
val id = intent.long(DownloadManager.EXTRA_DOWNLOAD_ID)
|
|
|
|
?: error("missing download id")
|
|
|
|
|
2021-06-20 15:12:25 +02:00
|
|
|
val query = DownloadManager.Query().setFilterById(id)
|
|
|
|
|
|
|
|
downloadManager.query(query)?.use { cursor ->
|
|
|
|
if (!cursor.moveToFirst()) {
|
|
|
|
log.e("cursor.moveToFirst() failed.")
|
|
|
|
return
|
|
|
|
}
|
|
|
|
val title = cursor.getStringOrNull(DownloadManager.COLUMN_TITLE)
|
|
|
|
val status = cursor.getIntOrNull(DownloadManager.COLUMN_STATUS)
|
|
|
|
context.showToast(
|
|
|
|
false,
|
|
|
|
if (status == DownloadManager.STATUS_SUCCESSFUL) {
|
|
|
|
context.getString(R.string.download_complete, title)
|
|
|
|
} else {
|
|
|
|
context.getString(R.string.download_failed, title)
|
2023-07-09 03:59:45 +02:00
|
|
|
},
|
|
|
|
forceToast = true,
|
2021-06-20 15:12:25 +02:00
|
|
|
)
|
|
|
|
/*
|
|
|
|
ダウンロード完了通知がシステムからのものと重複することがある
|
|
|
|
|
|
|
|
- (Aubee elm. Android 5.1) don't shows toast.
|
|
|
|
- (Samsung Galaxy S8+ Android 7.0) don't show toast.
|
|
|
|
- (Kyocera AndroidOne Android 8.0 S2) don't show toast.
|
|
|
|
- (LGE LGL24 Android 5.0.2) SHOWS toast.
|
|
|
|
- (LGE LGV32 Android 6.0) SHOWS toast.
|
|
|
|
|
|
|
|
maybe it depends on customization by device maker. not depends on OS version.
|
|
|
|
|
|
|
|
重複を回避する方法はなさそうだ…
|
|
|
|
*/
|
|
|
|
}
|
|
|
|
} catch (ex: Throwable) {
|
|
|
|
log.e(ex, "downloadManager.query() failed.")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2018-01-04 19:52:25 +01:00
|
|
|
}
|