mirror of https://github.com/tasks/tasks
First pass at creating a note-viewing activity as a quick action on the task
parent
a3e6b8fcb0
commit
03684c9f25
@ -0,0 +1,43 @@
|
|||||||
|
package com.todoroo.astrid.notes;
|
||||||
|
|
||||||
|
import android.app.Activity;
|
||||||
|
import android.os.Bundle;
|
||||||
|
import android.text.util.Linkify;
|
||||||
|
import android.view.View;
|
||||||
|
import android.view.View.OnClickListener;
|
||||||
|
import android.widget.Button;
|
||||||
|
import android.widget.LinearLayout;
|
||||||
|
import android.widget.TextView;
|
||||||
|
|
||||||
|
import com.timsu.astrid.R;
|
||||||
|
import com.todoroo.astrid.data.Task;
|
||||||
|
|
||||||
|
public class NoteViewingActivity extends Activity {
|
||||||
|
|
||||||
|
private Task task;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onCreate(Bundle savedInstanceState) {
|
||||||
|
super.onCreate(savedInstanceState);
|
||||||
|
setContentView(R.layout.empty_linear_layout);
|
||||||
|
LinearLayout body = (LinearLayout) findViewById(R.id.body);
|
||||||
|
|
||||||
|
task = getIntent().getParcelableExtra(NotesActionExposer.EXTRA_TASK);
|
||||||
|
setTitle(task.getValue(Task.TITLE));
|
||||||
|
|
||||||
|
TextView linkifiedTextView = new TextView(this);
|
||||||
|
linkifiedTextView.setText(task.getValue(Task.NOTES) + "\n\n"); //$NON-NLS-1$
|
||||||
|
Linkify.addLinks(linkifiedTextView, Linkify.ALL);
|
||||||
|
body.addView(linkifiedTextView);
|
||||||
|
|
||||||
|
Button ok = new Button(this);
|
||||||
|
ok.setText(android.R.string.ok);
|
||||||
|
ok.setOnClickListener(new OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(View arg0) {
|
||||||
|
finish();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
body.addView(ok);
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,76 @@
|
|||||||
|
/**
|
||||||
|
* See the file "LICENSE" for the full license governing this code.
|
||||||
|
*/
|
||||||
|
package com.todoroo.astrid.notes;
|
||||||
|
|
||||||
|
import android.app.PendingIntent;
|
||||||
|
import android.content.BroadcastReceiver;
|
||||||
|
import android.content.Context;
|
||||||
|
import android.content.Intent;
|
||||||
|
import android.graphics.Bitmap;
|
||||||
|
import android.graphics.drawable.BitmapDrawable;
|
||||||
|
import android.graphics.drawable.Drawable;
|
||||||
|
import android.text.TextUtils;
|
||||||
|
|
||||||
|
import com.timsu.astrid.R;
|
||||||
|
import com.todoroo.andlib.service.ContextManager;
|
||||||
|
import com.todoroo.astrid.api.AstridApiConstants;
|
||||||
|
import com.todoroo.astrid.api.TaskAction;
|
||||||
|
import com.todoroo.astrid.api.TaskDecoration;
|
||||||
|
import com.todoroo.astrid.core.PluginServices;
|
||||||
|
import com.todoroo.astrid.data.Task;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Exposes {@link TaskDecoration} for timers
|
||||||
|
*
|
||||||
|
* @author Tim Su <tim@todoroo.com>
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
public class NotesActionExposer extends BroadcastReceiver {
|
||||||
|
|
||||||
|
static final String EXTRA_TASK = "task"; //$NON-NLS-1$
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onReceive(Context context, Intent intent) {
|
||||||
|
ContextManager.setContext(context);
|
||||||
|
long taskId = intent.getLongExtra(AstridApiConstants.EXTRAS_TASK_ID, -1);
|
||||||
|
if(taskId == -1)
|
||||||
|
return;
|
||||||
|
|
||||||
|
Task task = PluginServices.getTaskService().fetchById(taskId, Task.ID, Task.TITLE, Task.NOTES);
|
||||||
|
if(!task.containsNonNullValue(Task.NOTES) || TextUtils.isEmpty(task.getValue(Task.NOTES)))
|
||||||
|
return;
|
||||||
|
|
||||||
|
if(AstridApiConstants.BROADCAST_REQUEST_ACTIONS.equals(intent.getAction())) {
|
||||||
|
sendNoteAction(context, taskId);
|
||||||
|
} else {
|
||||||
|
displayNote(context, task);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void displayNote(Context context, Task task) {
|
||||||
|
Intent intent = new Intent(context, NoteViewingActivity.class);
|
||||||
|
intent.putExtra(EXTRA_TASK, task);
|
||||||
|
intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
|
||||||
|
context.startActivity(intent);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void sendNoteAction(Context context, long taskId) {
|
||||||
|
final String label = context.getString(R.string.TEA_note_label);
|
||||||
|
final Drawable drawable = context.getResources().getDrawable(R.drawable.tango_notes);
|
||||||
|
|
||||||
|
Bitmap icon = ((BitmapDrawable)drawable).getBitmap();
|
||||||
|
Intent newIntent = new Intent(context, getClass());
|
||||||
|
newIntent.putExtra(AstridApiConstants.EXTRAS_TASK_ID, taskId);
|
||||||
|
TaskAction action = new TaskAction(label,
|
||||||
|
PendingIntent.getBroadcast(context, (int)taskId, newIntent, 0), icon);
|
||||||
|
|
||||||
|
// transmit
|
||||||
|
Intent broadcastIntent = new Intent(AstridApiConstants.BROADCAST_SEND_ACTIONS);
|
||||||
|
broadcastIntent.putExtra(AstridApiConstants.EXTRAS_ADDON, NotesPlugin.IDENTIFIER);
|
||||||
|
broadcastIntent.putExtra(AstridApiConstants.EXTRAS_RESPONSE, action);
|
||||||
|
broadcastIntent.putExtra(AstridApiConstants.EXTRAS_TASK_ID, taskId);
|
||||||
|
context.sendBroadcast(broadcastIntent, AstridApiConstants.PERMISSION_READ);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
Binary file not shown.
After Width: | Height: | Size: 509 B |
@ -0,0 +1,9 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
android:id="@+id/body"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:orientation="vertical"
|
||||||
|
android:padding="5dip">
|
||||||
|
|
||||||
|
</LinearLayout>
|
Loading…
Reference in New Issue