chinwag-android/app/src/main/java/com/keylesspalace/tusky/ReportActivity.java

214 lines
7.8 KiB
Java
Raw Normal View History

2017-02-27 16:21:46 +11:00
/* Copyright 2017 Andrew Dawson
*
2017-04-10 10:12:31 +10:00
* This file is a part of Tusky.
2017-02-27 16:21:46 +11:00
*
2017-04-10 10:12:31 +10:00
* 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.
2017-02-27 16:21:46 +11:00
*
* Tusky is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even
2017-04-10 10:12:31 +10:00
* the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General
* Public License for more details.
2017-02-27 16:21:46 +11:00
*
2017-04-10 10:12:31 +10:00
* You should have received a copy of the GNU General Public License along with Tusky; if not,
* see <http://www.gnu.org/licenses>. */
2017-02-27 16:21:46 +11:00
package com.keylesspalace.tusky;
import android.content.Intent;
import android.graphics.drawable.Drawable;
2017-02-27 16:21:46 +11:00
import android.os.Bundle;
import android.support.annotation.Nullable;
import android.support.design.widget.Snackbar;
import android.support.v7.app.ActionBar;
import android.support.v7.widget.DividerItemDecoration;
import android.support.v7.widget.LinearLayoutManager;
import android.support.v7.widget.RecyclerView;
2017-02-27 16:21:46 +11:00
import android.support.v7.widget.Toolbar;
import android.util.Log;
2017-03-11 09:47:04 +11:00
import android.view.Menu;
import android.view.MenuItem;
2017-02-27 16:21:46 +11:00
import android.view.View;
import android.widget.EditText;
2017-05-05 08:55:34 +10:00
import com.keylesspalace.tusky.adapter.ReportAdapter;
2017-03-10 10:20:08 +11:00
import com.keylesspalace.tusky.entity.Status;
2017-05-05 08:55:34 +10:00
import com.keylesspalace.tusky.util.HtmlUtils;
import com.keylesspalace.tusky.util.ThemeUtils;
2017-02-27 16:21:46 +11:00
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
2017-02-27 16:21:46 +11:00
import okhttp3.ResponseBody;
import retrofit2.Call;
import retrofit2.Callback;
2017-06-23 04:59:12 +10:00
import retrofit2.Response;
2017-02-27 16:21:46 +11:00
public class ReportActivity extends BaseActivity {
2017-03-10 10:20:08 +11:00
private static final String TAG = "ReportActivity"; // logging tag
2017-02-27 16:21:46 +11:00
private View anyView; // what Snackbar will use to find the root view
private ReportAdapter adapter;
private boolean reportAlreadyInFlight;
2017-03-11 09:47:04 +11:00
private String accountId;
private EditText comment;
2017-02-27 16:21:46 +11:00
@Override
protected void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_report);
Intent intent = getIntent();
2017-03-11 09:47:04 +11:00
accountId = intent.getStringExtra("account_id");
String accountUsername = intent.getStringExtra("account_username");
String statusId = intent.getStringExtra("status_id");
String statusContent = intent.getStringExtra("status_content");
2017-02-27 16:21:46 +11:00
Toolbar toolbar = findViewById(R.id.toolbar);
2017-02-27 16:21:46 +11:00
setSupportActionBar(toolbar);
ActionBar bar = getSupportActionBar();
if (bar != null) {
String title = String.format(getString(R.string.report_username_format),
accountUsername);
bar.setTitle(title);
2017-03-11 09:47:04 +11:00
bar.setDisplayHomeAsUpEnabled(true);
bar.setDisplayShowHomeEnabled(true);
2017-02-27 16:21:46 +11:00
}
anyView = toolbar;
final RecyclerView recyclerView = findViewById(R.id.report_recycler_view);
recyclerView.setHasFixedSize(true);
LinearLayoutManager layoutManager = new LinearLayoutManager(this);
recyclerView.setLayoutManager(layoutManager);
adapter = new ReportAdapter();
recyclerView.setAdapter(adapter);
DividerItemDecoration divider = new DividerItemDecoration(
this, layoutManager.getOrientation());
Drawable drawable = ThemeUtils.getDrawable(this, R.attr.report_status_divider_drawable,
R.drawable.report_status_divider_dark);
divider.setDrawable(drawable);
recyclerView.addItemDecoration(divider);
ReportAdapter.ReportStatus reportStatus = new ReportAdapter.ReportStatus(statusId,
HtmlUtils.fromHtml(statusContent), true);
adapter.addItem(reportStatus);
2017-02-27 16:21:46 +11:00
comment = findViewById(R.id.report_comment);
2017-03-11 09:47:04 +11:00
reportAlreadyInFlight = false;
fetchRecentStatuses(accountId);
2017-02-27 16:21:46 +11:00
}
2017-03-11 09:47:04 +11:00
private void onClickSend() {
if (reportAlreadyInFlight) {
return;
}
String[] statusIds = adapter.getCheckedStatusIds();
if (statusIds.length > 0) {
reportAlreadyInFlight = true;
sendReport(accountId, statusIds, comment.getText().toString());
} else {
comment.setError(getString(R.string.error_report_too_few_statuses));
}
}
2017-02-27 16:21:46 +11:00
private void sendReport(final String accountId, final String[] statusIds,
final String comment) {
2017-06-23 04:59:12 +10:00
Callback<ResponseBody> callback = new Callback<ResponseBody>() {
2017-02-27 16:21:46 +11:00
@Override
2017-06-23 04:59:12 +10:00
public void onResponse(Call<ResponseBody> call, Response<ResponseBody> response) {
if (response.isSuccessful()) {
onSendSuccess();
} else {
onSendFailure(accountId, statusIds, comment);
}
2017-02-27 16:21:46 +11:00
}
@Override
public void onFailure(Call<ResponseBody> call, Throwable t) {
onSendFailure(accountId, statusIds, comment);
}
2017-06-23 04:59:12 +10:00
};
mastodonApi.report(accountId, Arrays.asList(statusIds), comment)
.enqueue(callback);
2017-02-27 16:21:46 +11:00
}
private void onSendSuccess() {
Snackbar bar = Snackbar.make(anyView, getString(R.string.confirmation_reported), Snackbar.LENGTH_SHORT);
bar.show();
2017-02-27 16:21:46 +11:00
finish();
}
private void onSendFailure(final String accountId, final String[] statusIds,
final String comment) {
Snackbar.make(anyView, R.string.error_generic, Snackbar.LENGTH_LONG)
2017-02-27 16:21:46 +11:00
.setAction(R.string.action_retry, new View.OnClickListener() {
@Override
public void onClick(View v) {
sendReport(accountId, statusIds, comment);
}
})
.show();
reportAlreadyInFlight = false;
2017-02-27 16:21:46 +11:00
}
private void fetchRecentStatuses(String accountId) {
2017-06-23 04:59:12 +10:00
Callback<List<Status>> callback = new Callback<List<Status>>() {
@Override
2017-06-23 04:59:12 +10:00
public void onResponse(Call<List<Status>> call, Response<List<Status>> response) {
if (!response.isSuccessful()) {
onFetchStatusesFailure(new Exception(response.message()));
return;
}
List<Status> statusList = response.body();
List<ReportAdapter.ReportStatus> itemList = new ArrayList<>();
for (Status status : statusList) {
if (status.reblog == null) {
ReportAdapter.ReportStatus item = new ReportAdapter.ReportStatus(
status.id, status.content, false);
itemList.add(item);
}
}
adapter.addItems(itemList);
}
@Override
public void onFailure(Call<List<Status>> call, Throwable t) {
onFetchStatusesFailure((Exception) t);
}
2017-06-23 04:59:12 +10:00
};
mastodonApi.accountStatuses(accountId, null, null, null)
.enqueue(callback);
}
private void onFetchStatusesFailure(Exception exception) {
Log.e(TAG, "Failed to fetch recent statuses to report. " + exception.getMessage());
}
2017-03-11 09:47:04 +11:00
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.report_toolbar, menu);
return super.onCreateOptionsMenu(menu);
}
@Override
public boolean onOptionsItemSelected(MenuItem item) {
switch (item.getItemId()) {
case android.R.id.home: {
onBackPressed();
return true;
}
case R.id.action_report: {
onClickSend();
return true;
}
}
return super.onOptionsItemSelected(item);
}
2017-02-27 16:21:46 +11:00
}