ShareLinkActivity does not extend AstridActivity

pull/384/head
Alex Baker 9 years ago
parent f431aeaa56
commit 5f352a4966

@ -7,63 +7,58 @@ import android.content.Intent;
import android.os.Bundle; import android.os.Bundle;
import com.todoroo.astrid.data.Task; import com.todoroo.astrid.data.Task;
import com.todoroo.astrid.service.StartupService;
import com.todoroo.astrid.service.TaskCreator; import com.todoroo.astrid.service.TaskCreator;
import com.todoroo.astrid.service.TaskService; import com.todoroo.astrid.service.TaskService;
import org.tasks.injection.InjectingAppCompatActivity;
import javax.inject.Inject; import javax.inject.Inject;
import static org.tasks.intents.TaskIntents.getEditTaskStack;
/** /**
* @author joshuagross * @author joshuagross
* *
* Create a new task based on incoming links from the "share" menu * Create a new task based on incoming links from the "share" menu
*/ */
public final class ShareLinkActivity extends TaskListActivity { public final class ShareLinkActivity extends InjectingAppCompatActivity {
@Inject StartupService startupService;
@Inject TaskService taskService; @Inject TaskService taskService;
@Inject TaskCreator taskCreator; @Inject TaskCreator taskCreator;
private String subject;
private boolean handled;
private static final String TOKEN_LINK_HANDLED = "linkHandled"; //$NON-NLS-1$
@Override @Override
public void onCreate(Bundle savedInstanceState) { public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState); super.onCreate(savedInstanceState);
Intent callerIntent = getIntent(); startupService.onStartupApplication(this);
subject = callerIntent.getStringExtra(Intent.EXTRA_SUBJECT); readIntent();
if(subject == null) {
subject = ""; //$NON-NLS-1$
}
} }
@Override @Override
protected void onPostResume() { protected void onNewIntent(Intent intent) {
super.onPostResume(); super.onNewIntent(intent);
if (!handled) {
Intent callerIntent = getIntent();
Task task = taskCreator.basicQuickAddTask(subject); setIntent(intent);
if (task != null) {
task.setNotes(callerIntent.getStringExtra(Intent.EXTRA_TEXT));
taskService.save(task);
handled = true;
onTaskListItemClicked(task.getId());
}
}
}
@Override readIntent();
protected void onSaveInstanceState(Bundle outState) {
super.onSaveInstanceState(outState);
outState.putBoolean(TOKEN_LINK_HANDLED, handled);
} }
@Override private void readIntent() {
protected void onRestoreInstanceState(Bundle savedInstanceState) { Intent intent = getIntent();
super.onRestoreInstanceState(savedInstanceState); String subject = intent.getStringExtra(Intent.EXTRA_SUBJECT);
handled = savedInstanceState.getBoolean(TOKEN_LINK_HANDLED); if (subject == null) {
subject = "";
}
Task task = taskCreator.basicQuickAddTask(subject);
if (task != null) {
task.setNotes(intent.getStringExtra(Intent.EXTRA_TEXT));
taskService.save(task);
getEditTaskStack(this, null, task.getId()).startActivities();
}
finish();
} }
} }

Loading…
Cancel
Save