2016-06-29 15:47:52 +02:00
|
|
|
/*
|
|
|
|
* Twidere - Twitter client for Android
|
|
|
|
*
|
|
|
|
* Copyright (C) 2012-2014 Mariotaku Lee <mariotaku.lee@gmail.com>
|
|
|
|
*
|
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
|
|
|
package org.mariotaku.twidere.fragment
|
|
|
|
|
2017-03-31 10:05:50 +02:00
|
|
|
import android.app.Dialog
|
2016-06-29 15:47:52 +02:00
|
|
|
import android.content.Context
|
|
|
|
import android.os.Bundle
|
|
|
|
import android.support.v4.content.Loader
|
2017-03-31 10:05:50 +02:00
|
|
|
import android.support.v7.app.AlertDialog
|
|
|
|
import org.mariotaku.kpreferences.get
|
|
|
|
import org.mariotaku.kpreferences.set
|
|
|
|
import org.mariotaku.twidere.R
|
2016-06-29 15:47:52 +02:00
|
|
|
import org.mariotaku.twidere.TwidereConstants.*
|
2017-03-31 10:05:50 +02:00
|
|
|
import org.mariotaku.twidere.constant.userTimelineFilterKey
|
|
|
|
import org.mariotaku.twidere.extension.applyTheme
|
2017-04-21 11:23:55 +02:00
|
|
|
import org.mariotaku.twidere.loader.statuses.UserTimelineLoader
|
2016-06-29 15:47:52 +02:00
|
|
|
import org.mariotaku.twidere.model.ParcelableStatus
|
|
|
|
import org.mariotaku.twidere.model.UserKey
|
2017-03-31 10:05:50 +02:00
|
|
|
import org.mariotaku.twidere.model.timeline.TimelineFilter
|
|
|
|
import org.mariotaku.twidere.model.timeline.UserTimelineFilter
|
2016-06-29 15:47:52 +02:00
|
|
|
import org.mariotaku.twidere.util.Utils
|
2017-03-31 10:05:50 +02:00
|
|
|
import org.mariotaku.twidere.view.holder.TimelineFilterHeaderViewHolder
|
2016-06-29 15:47:52 +02:00
|
|
|
import java.util.*
|
|
|
|
|
|
|
|
/**
|
2017-04-12 08:12:45 +02:00
|
|
|
* User timeline
|
|
|
|
*
|
2016-06-29 15:47:52 +02:00
|
|
|
* Created by mariotaku on 14/12/2.
|
|
|
|
*/
|
|
|
|
class UserTimelineFragment : ParcelableStatusesFragment() {
|
|
|
|
|
2016-08-19 16:25:27 +02:00
|
|
|
val pinnedStatusIds: Array<String>?
|
|
|
|
get() = (parentFragment as? UserTimelineFragmentDelegate)?.pinnedStatusIds
|
2016-06-29 15:47:52 +02:00
|
|
|
|
|
|
|
override val savedStatusesFileArgs: Array<String>?
|
|
|
|
get() {
|
2017-04-12 14:58:08 +02:00
|
|
|
val accountKey = Utils.getAccountKey(context, arguments)
|
|
|
|
val userKey = arguments.getParcelable<UserKey?>(EXTRA_USER_KEY)
|
2017-03-31 10:05:50 +02:00
|
|
|
val screenName = arguments.getString(EXTRA_SCREEN_NAME)
|
2016-06-29 15:47:52 +02:00
|
|
|
val result = ArrayList<String>()
|
|
|
|
result.add(AUTHORITY_USER_TIMELINE)
|
|
|
|
result.add("account=$accountKey")
|
|
|
|
if (userKey != null) {
|
|
|
|
result.add("user_id=$userKey")
|
|
|
|
} else if (screenName != null) {
|
|
|
|
result.add("screen_name=$screenName")
|
|
|
|
} else {
|
|
|
|
return null
|
|
|
|
}
|
2017-03-31 10:05:50 +02:00
|
|
|
(timelineFilter as? UserTimelineFilter)?.let {
|
|
|
|
if (it.isIncludeReplies) {
|
|
|
|
result.add("include_replies")
|
|
|
|
}
|
|
|
|
if (it.isIncludeRetweets) {
|
|
|
|
result.add("include_retweets")
|
|
|
|
}
|
2017-03-27 05:08:09 +02:00
|
|
|
}
|
2016-06-29 15:47:52 +02:00
|
|
|
return result.toTypedArray()
|
|
|
|
}
|
|
|
|
|
|
|
|
override val readPositionTagWithArguments: String?
|
|
|
|
get() {
|
2017-03-31 10:05:50 +02:00
|
|
|
if (arguments.getLong(EXTRA_TAB_ID, -1) < 0) return null
|
2016-06-29 15:47:52 +02:00
|
|
|
val sb = StringBuilder("user_timeline_")
|
|
|
|
|
2017-03-31 10:05:50 +02:00
|
|
|
val userKey = arguments.getParcelable<UserKey>(EXTRA_USER_KEY)
|
|
|
|
val screenName = arguments.getString(EXTRA_SCREEN_NAME)
|
2016-06-29 15:47:52 +02:00
|
|
|
if (userKey != null) {
|
|
|
|
sb.append(userKey)
|
|
|
|
} else if (screenName != null) {
|
|
|
|
sb.append(screenName)
|
|
|
|
} else {
|
|
|
|
return null
|
|
|
|
}
|
|
|
|
return sb.toString()
|
|
|
|
}
|
2016-08-19 16:25:27 +02:00
|
|
|
|
2017-03-31 10:05:50 +02:00
|
|
|
override val enableTimelineFilter: Boolean
|
|
|
|
get() = arguments.getBoolean(EXTRA_ENABLE_TIMELINE_FILTER)
|
|
|
|
|
|
|
|
override val timelineFilter: TimelineFilter?
|
|
|
|
get() = if (enableTimelineFilter) preferences[userTimelineFilterKey] else null
|
|
|
|
|
2017-02-14 04:34:31 +01:00
|
|
|
override fun onCreateStatusesLoader(context: Context, args: Bundle, fromUser: Boolean):
|
|
|
|
Loader<List<ParcelableStatus>?> {
|
2016-08-19 16:25:27 +02:00
|
|
|
refreshing = true
|
|
|
|
val data = adapterData
|
|
|
|
val accountKey = Utils.getAccountKey(context, args)
|
|
|
|
val maxId = args.getString(EXTRA_MAX_ID)
|
|
|
|
val sinceId = args.getString(EXTRA_SINCE_ID)
|
|
|
|
val userKey = args.getParcelable<UserKey>(EXTRA_USER_KEY)
|
|
|
|
val screenName = args.getString(EXTRA_SCREEN_NAME)
|
2017-04-07 13:05:02 +02:00
|
|
|
val profileUrl = args.getString(EXTRA_PROFILE_URL)
|
2016-08-19 16:25:27 +02:00
|
|
|
val tabPosition = args.getInt(EXTRA_TAB_POSITION, -1)
|
|
|
|
val loadingMore = args.getBoolean(EXTRA_LOADING_MORE, false)
|
2016-12-08 15:43:18 +01:00
|
|
|
val pinnedIds = if (adapter.hasPinnedStatuses) null else pinnedStatusIds
|
2017-04-07 13:05:02 +02:00
|
|
|
return UserTimelineLoader(context, accountKey, userKey, screenName, profileUrl, sinceId,
|
|
|
|
maxId, data, savedStatusesFileArgs, tabPosition, fromUser, loadingMore, pinnedIds,
|
2017-03-31 10:05:50 +02:00
|
|
|
timelineFilter as? UserTimelineFilter)
|
2016-08-19 16:25:27 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
override fun onStatusesLoaded(loader: Loader<List<ParcelableStatus>?>, data: List<ParcelableStatus>?) {
|
2017-02-14 04:34:31 +01:00
|
|
|
val timelineLoader = loader as? UserTimelineLoader
|
2016-08-19 16:25:27 +02:00
|
|
|
if (!adapter.hasPinnedStatuses) {
|
2017-02-14 04:34:31 +01:00
|
|
|
adapter.pinnedStatuses = timelineLoader?.pinnedStatuses
|
2016-08-19 16:25:27 +02:00
|
|
|
}
|
|
|
|
super.onStatusesLoaded(loader, data)
|
|
|
|
}
|
|
|
|
|
2017-03-31 10:05:50 +02:00
|
|
|
override fun onFilterClick(holder: TimelineFilterHeaderViewHolder) {
|
|
|
|
val df = UserTimelineFilterDialogFragment()
|
|
|
|
df.setTargetFragment(this, REQUEST_SET_TIMELINE_FILTER)
|
|
|
|
df.show(childFragmentManager, "set_timeline_filter")
|
|
|
|
}
|
|
|
|
|
|
|
|
private fun reloadAllStatuses() {
|
|
|
|
adapterData = null
|
|
|
|
triggerRefresh()
|
|
|
|
showProgress()
|
|
|
|
}
|
|
|
|
|
2016-08-19 16:25:27 +02:00
|
|
|
interface UserTimelineFragmentDelegate {
|
|
|
|
val pinnedStatusIds: Array<String>?
|
2017-03-31 10:05:50 +02:00
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
class UserTimelineFilterDialogFragment : BaseDialogFragment() {
|
|
|
|
|
|
|
|
override fun onCreateDialog(savedInstanceState: Bundle?): Dialog {
|
|
|
|
val builder = AlertDialog.Builder(context)
|
|
|
|
val values = resources.getStringArray(R.array.values_user_timeline_filter)
|
|
|
|
val checkedItems = BooleanArray(values.size) {
|
|
|
|
val filter = preferences[userTimelineFilterKey]
|
|
|
|
when (values[it]) {
|
|
|
|
"replies" -> filter.isIncludeReplies
|
|
|
|
"retweets" -> filter.isIncludeRetweets
|
|
|
|
else -> false
|
|
|
|
}
|
|
|
|
}
|
|
|
|
builder.setTitle(R.string.title_user_timeline_filter)
|
|
|
|
builder.setMultiChoiceItems(R.array.entries_user_timeline_filter, checkedItems, null)
|
|
|
|
builder.setNegativeButton(android.R.string.cancel, null)
|
|
|
|
builder.setPositiveButton(android.R.string.ok) { dialog, _ ->
|
|
|
|
dialog as AlertDialog
|
|
|
|
val listView = dialog.listView
|
|
|
|
val filter = UserTimelineFilter().apply {
|
|
|
|
isIncludeRetweets = listView.isItemChecked(values.indexOf("retweets"))
|
|
|
|
isIncludeReplies = listView.isItemChecked(values.indexOf("replies"))
|
|
|
|
}
|
|
|
|
preferences.edit().apply {
|
|
|
|
this[userTimelineFilterKey] = filter
|
|
|
|
}.apply()
|
|
|
|
(targetFragment as UserTimelineFragment).reloadAllStatuses()
|
|
|
|
}
|
|
|
|
val dialog = builder.create()
|
|
|
|
dialog.setOnShowListener {
|
|
|
|
it as AlertDialog
|
|
|
|
it.applyTheme()
|
|
|
|
}
|
|
|
|
return dialog
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
companion object {
|
|
|
|
const val EXTRA_ENABLE_TIMELINE_FILTER = "enable_timeline_filter"
|
|
|
|
const val REQUEST_SET_TIMELINE_FILTER = 101
|
2016-08-19 16:25:27 +02:00
|
|
|
}
|
2016-06-29 15:47:52 +02:00
|
|
|
}
|