|
|
@ -6,9 +6,15 @@ import java.util.Collections;
|
|
|
|
import java.util.List;
|
|
|
|
import java.util.List;
|
|
|
|
|
|
|
|
|
|
|
|
import android.app.AlertDialog;
|
|
|
|
import android.app.AlertDialog;
|
|
|
|
|
|
|
|
import android.app.PendingIntent;
|
|
|
|
|
|
|
|
import android.content.BroadcastReceiver;
|
|
|
|
import android.content.ContentValues;
|
|
|
|
import android.content.ContentValues;
|
|
|
|
|
|
|
|
import android.content.Context;
|
|
|
|
import android.content.DialogInterface;
|
|
|
|
import android.content.DialogInterface;
|
|
|
|
import android.content.Intent;
|
|
|
|
import android.content.Intent;
|
|
|
|
|
|
|
|
import android.graphics.Bitmap;
|
|
|
|
|
|
|
|
import android.graphics.drawable.BitmapDrawable;
|
|
|
|
|
|
|
|
import android.graphics.drawable.Drawable;
|
|
|
|
import android.widget.ArrayAdapter;
|
|
|
|
import android.widget.ArrayAdapter;
|
|
|
|
|
|
|
|
|
|
|
|
import com.timsu.astrid.R;
|
|
|
|
import com.timsu.astrid.R;
|
|
|
@ -18,31 +24,56 @@ import com.todoroo.andlib.sql.Criterion;
|
|
|
|
import com.todoroo.andlib.sql.QueryTemplate;
|
|
|
|
import com.todoroo.andlib.sql.QueryTemplate;
|
|
|
|
import com.todoroo.andlib.utility.AndroidUtilities;
|
|
|
|
import com.todoroo.andlib.utility.AndroidUtilities;
|
|
|
|
import com.todoroo.astrid.activity.TaskListActivity;
|
|
|
|
import com.todoroo.astrid.activity.TaskListActivity;
|
|
|
|
|
|
|
|
import com.todoroo.astrid.api.AstridApiConstants;
|
|
|
|
import com.todoroo.astrid.api.Filter;
|
|
|
|
import com.todoroo.astrid.api.Filter;
|
|
|
|
import com.todoroo.astrid.api.TaskContextActionExposer;
|
|
|
|
import com.todoroo.astrid.api.TaskAction;
|
|
|
|
import com.todoroo.astrid.dao.TaskDao.TaskCriteria;
|
|
|
|
import com.todoroo.astrid.dao.TaskDao.TaskCriteria;
|
|
|
|
import com.todoroo.astrid.data.Metadata;
|
|
|
|
import com.todoroo.astrid.data.Metadata;
|
|
|
|
import com.todoroo.astrid.data.Task;
|
|
|
|
|
|
|
|
import com.todoroo.astrid.tags.TagService.Tag;
|
|
|
|
import com.todoroo.astrid.tags.TagService.Tag;
|
|
|
|
|
|
|
|
|
|
|
|
public class FilterByTagContextAction implements TaskContextActionExposer {
|
|
|
|
public class FilterByTagExposer extends BroadcastReceiver {
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private static final String FILTER_ACTION = "com.todoroo.astrid.FILTER_BY_TAG"; //$NON-NLS-1$
|
|
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
@Override
|
|
|
|
public Object getLabel(Task task) {
|
|
|
|
public void onReceive(Context context, Intent intent) {
|
|
|
|
TodorooCursor<Metadata> cursor = TagService.getInstance().getTags(task.getId());
|
|
|
|
ContextManager.setContext(context);
|
|
|
|
|
|
|
|
long taskId = intent.getLongExtra(AstridApiConstants.EXTRAS_TASK_ID, -1);
|
|
|
|
|
|
|
|
if(taskId == -1)
|
|
|
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
TodorooCursor<Metadata> cursor = TagService.getInstance().getTags(taskId);
|
|
|
|
try {
|
|
|
|
try {
|
|
|
|
if(cursor.getCount() > 0)
|
|
|
|
if(cursor.getCount() == 0)
|
|
|
|
return R.string.TAd_contextFilterByTag;
|
|
|
|
return;
|
|
|
|
} finally {
|
|
|
|
} finally {
|
|
|
|
cursor.close();
|
|
|
|
cursor.close();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return null;
|
|
|
|
|
|
|
|
|
|
|
|
if(AstridApiConstants.BROADCAST_REQUEST_ACTIONS.equals(intent.getAction())) {
|
|
|
|
|
|
|
|
final String label = context.getString(R.string.TAd_contextFilterByTag);
|
|
|
|
|
|
|
|
final Drawable drawable = context.getResources().getDrawable(R.drawable.silk_tag_pink);
|
|
|
|
|
|
|
|
Intent newIntent = new Intent(FILTER_ACTION);
|
|
|
|
|
|
|
|
newIntent.putExtra(AstridApiConstants.EXTRAS_TASK_ID, taskId);
|
|
|
|
|
|
|
|
Bitmap icon = ((BitmapDrawable)drawable).getBitmap();
|
|
|
|
|
|
|
|
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, TagsPlugin.IDENTIFIER);
|
|
|
|
|
|
|
|
broadcastIntent.putExtra(AstridApiConstants.EXTRAS_RESPONSE, action);
|
|
|
|
|
|
|
|
broadcastIntent.putExtra(AstridApiConstants.EXTRAS_TASK_ID, taskId);
|
|
|
|
|
|
|
|
context.sendBroadcast(broadcastIntent, AstridApiConstants.PERMISSION_READ);
|
|
|
|
|
|
|
|
} else if(FILTER_ACTION.equals(intent.getAction())) {
|
|
|
|
|
|
|
|
invoke(taskId);
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public void invoke(Task task) {
|
|
|
|
public void invoke(long taskId) {
|
|
|
|
final TodorooCursor<Metadata> cursor = TagService.getInstance().getTags(
|
|
|
|
|
|
|
|
task.getId());
|
|
|
|
|
|
|
|
final List<String> tags;
|
|
|
|
final List<String> tags;
|
|
|
|
|
|
|
|
final TodorooCursor<Metadata> cursor = TagService.getInstance().getTags(
|
|
|
|
|
|
|
|
taskId);
|
|
|
|
try {
|
|
|
|
try {
|
|
|
|
if (!cursor.moveToFirst())
|
|
|
|
if (!cursor.moveToFirst())
|
|
|
|
return;
|
|
|
|
return;
|
|
|
@ -59,7 +90,6 @@ public class FilterByTagContextAction implements TaskContextActionExposer {
|
|
|
|
Collections.sort(tags, collator);
|
|
|
|
Collections.sort(tags, collator);
|
|
|
|
|
|
|
|
|
|
|
|
DialogInterface.OnClickListener listener = new DialogInterface.OnClickListener() {
|
|
|
|
DialogInterface.OnClickListener listener = new DialogInterface.OnClickListener() {
|
|
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
@Override
|
|
|
|
public void onClick(DialogInterface dialog, int which) {
|
|
|
|
public void onClick(DialogInterface dialog, int which) {
|
|
|
|
Tag tag = new Tag(tags.get(which), 0);
|
|
|
|
Tag tag = new Tag(tags.get(which), 0);
|