fixes merge conflicts
This commit is contained in:
commit
66bac21236
5 changed files with 65 additions and 1 deletions
|
@ -145,6 +145,11 @@ public class TimelineAdapter extends RecyclerView.Adapter implements AdapterItem
|
||||||
notifyItemRemoved(position);
|
notifyItemRemoved(position);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void clear() {
|
||||||
|
statuses.clear();
|
||||||
|
notifyDataSetChanged();
|
||||||
|
}
|
||||||
|
|
||||||
public void removeAllByAccountId(String accountId) {
|
public void removeAllByAccountId(String accountId) {
|
||||||
for (int i = 0; i < statuses.size();) {
|
for (int i = 0; i < statuses.size();) {
|
||||||
Status status = statuses.get(i);
|
Status status = statuses.get(i);
|
||||||
|
|
|
@ -43,6 +43,7 @@ import com.keylesspalace.tusky.util.Log;
|
||||||
import com.keylesspalace.tusky.util.TimelineReceiver;
|
import com.keylesspalace.tusky.util.TimelineReceiver;
|
||||||
import com.keylesspalace.tusky.util.ThemeUtils;
|
import com.keylesspalace.tusky.util.ThemeUtils;
|
||||||
|
|
||||||
|
import java.util.Iterator;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
import retrofit2.Call;
|
import retrofit2.Call;
|
||||||
|
@ -73,6 +74,9 @@ public class TimelineFragment extends SFragment implements
|
||||||
private LinearLayoutManager layoutManager;
|
private LinearLayoutManager layoutManager;
|
||||||
private EndlessOnScrollListener scrollListener;
|
private EndlessOnScrollListener scrollListener;
|
||||||
private TabLayout.OnTabSelectedListener onTabSelectedListener;
|
private TabLayout.OnTabSelectedListener onTabSelectedListener;
|
||||||
|
private SharedPreferences preferences;
|
||||||
|
private boolean filterRemoveReplies;
|
||||||
|
private boolean filterRemoveReblogs;
|
||||||
private boolean hideFab;
|
private boolean hideFab;
|
||||||
private TimelineReceiver timelineReceiver;
|
private TimelineReceiver timelineReceiver;
|
||||||
|
|
||||||
|
@ -201,6 +205,8 @@ public class TimelineFragment extends SFragment implements
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
recyclerView.addOnScrollListener(scrollListener);
|
recyclerView.addOnScrollListener(scrollListener);
|
||||||
|
|
||||||
|
preferences = PreferenceManager.getDefaultSharedPreferences(getActivity());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -292,7 +298,36 @@ public class TimelineFragment extends SFragment implements
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected void filterStatuses(List<Status> statuses) {
|
||||||
|
Iterator<Status> it = statuses.iterator();
|
||||||
|
while (it.hasNext()) {
|
||||||
|
Status status = it.next();
|
||||||
|
if ((status.inReplyToId != null && filterRemoveReplies) || (status.reblog != null && filterRemoveReblogs)) {
|
||||||
|
it.remove();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void setFiltersFromSettings() {
|
||||||
|
boolean oldRemoveReplies = filterRemoveReplies;
|
||||||
|
boolean oldRemoveReblogs = filterRemoveReblogs;
|
||||||
|
filterRemoveReplies = (kind == Kind.HOME && !preferences.getBoolean("tabFilterHomeReplies", true));
|
||||||
|
filterRemoveReblogs = (kind == Kind.HOME && !preferences.getBoolean("tabFilterHomeBoosts", true));
|
||||||
|
|
||||||
|
if (adapter.getItemCount() > 1 && (oldRemoveReblogs != filterRemoveReblogs || oldRemoveReplies != filterRemoveReplies)) {
|
||||||
|
adapter.clear();
|
||||||
|
sendFetchTimelineRequest(null, null);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onResume() {
|
||||||
|
super.onResume();
|
||||||
|
setFiltersFromSettings();
|
||||||
|
}
|
||||||
|
|
||||||
public void onFetchTimelineSuccess(List<Status> statuses, String fromId) {
|
public void onFetchTimelineSuccess(List<Status> statuses, String fromId) {
|
||||||
|
filterStatuses(statuses);
|
||||||
if (fromId != null) {
|
if (fromId != null) {
|
||||||
if (statuses.size() > 0 && !findStatus(statuses, fromId)) {
|
if (statuses.size() > 0 && !findStatus(statuses, fromId)) {
|
||||||
adapter.addItems(statuses);
|
adapter.addItems(statuses);
|
||||||
|
|
|
@ -160,6 +160,10 @@
|
||||||
<string name="pref_title_browser_settings">Browser</string>
|
<string name="pref_title_browser_settings">Browser</string>
|
||||||
<string name="pref_title_custom_tabs">Use Chrome Custom Tabs</string>
|
<string name="pref_title_custom_tabs">Use Chrome Custom Tabs</string>
|
||||||
<string name="pref_title_hide_follow_button">Hide follow button while scrolling</string>
|
<string name="pref_title_hide_follow_button">Hide follow button while scrolling</string>
|
||||||
|
<string name="pref_title_status_filter">Toot filtering</string>
|
||||||
|
<string name="pref_title_status_tabs">Tabs</string>
|
||||||
|
<string name="pref_title_show_boosts">Show boosts</string>
|
||||||
|
<string name="pref_title_show_replies">Show replies</string>
|
||||||
|
|
||||||
<string name="notification_mention_format">%s mentioned you</string>
|
<string name="notification_mention_format">%s mentioned you</string>
|
||||||
<string name="notification_summary_large">%1$s, %2$s, %3$s and %4$d others</string>
|
<string name="notification_summary_large">%1$s, %2$s, %3$s and %4$d others</string>
|
||||||
|
|
|
@ -21,6 +21,26 @@
|
||||||
android:title="@string/pref_title_custom_tabs"
|
android:title="@string/pref_title_custom_tabs"
|
||||||
android:defaultValue="true" />
|
android:defaultValue="true" />
|
||||||
</PreferenceCategory>
|
</PreferenceCategory>
|
||||||
|
|
||||||
|
<PreferenceCategory android:title="@string/pref_title_status_filter">
|
||||||
|
<PreferenceScreen android:title="@string/pref_title_status_tabs">
|
||||||
|
|
||||||
|
<PreferenceCategory
|
||||||
|
android:dependency="notificationsEnabled"
|
||||||
|
android:title="@string/title_home">
|
||||||
|
<CheckBoxPreference
|
||||||
|
android:key="tabFilterHomeBoosts"
|
||||||
|
android:title="@string/pref_title_show_boosts"
|
||||||
|
android:defaultValue="true" />
|
||||||
|
<CheckBoxPreference
|
||||||
|
android:key="tabFilterHomeReplies"
|
||||||
|
android:title="@string/pref_title_show_replies"
|
||||||
|
android:defaultValue="true" />
|
||||||
|
</PreferenceCategory>
|
||||||
|
|
||||||
|
</PreferenceScreen>
|
||||||
|
</PreferenceCategory>
|
||||||
|
|
||||||
<PreferenceCategory android:title="@string/pref_title_notification_settings">
|
<PreferenceCategory android:title="@string/pref_title_notification_settings">
|
||||||
<PreferenceScreen android:title="@string/pref_title_edit_notification_settings">
|
<PreferenceScreen android:title="@string/pref_title_edit_notification_settings">
|
||||||
|
|
||||||
|
|
|
@ -5,7 +5,7 @@ buildscript {
|
||||||
jcenter()
|
jcenter()
|
||||||
}
|
}
|
||||||
dependencies {
|
dependencies {
|
||||||
classpath 'com.android.tools.build:gradle:2.3.1'
|
classpath 'com.android.tools.build:gradle:2.3.2'
|
||||||
|
|
||||||
// NOTE: Do not place your application dependencies here; they belong
|
// NOTE: Do not place your application dependencies here; they belong
|
||||||
// in the individual module build.gradle files
|
// in the individual module build.gradle files
|
||||||
|
|
Loading…
Reference in a new issue