mirror of https://github.com/tasks/tasks
Pass task from TaskEditActivity
parent
c36f71705e
commit
de9fc7e254
@ -1,23 +1,57 @@
|
|||||||
package com.todoroo.astrid.activity;
|
package com.todoroo.astrid.activity;
|
||||||
|
|
||||||
import android.app.Activity;
|
import com.todoroo.astrid.dao.TaskDao;
|
||||||
import android.content.Intent;
|
import com.todoroo.astrid.service.TaskCreator;
|
||||||
import android.os.Bundle;
|
import io.reactivex.Single;
|
||||||
|
import io.reactivex.android.schedulers.AndroidSchedulers;
|
||||||
|
import io.reactivex.disposables.CompositeDisposable;
|
||||||
|
import io.reactivex.schedulers.Schedulers;
|
||||||
|
import javax.inject.Inject;
|
||||||
|
import org.tasks.injection.ActivityComponent;
|
||||||
|
import org.tasks.injection.InjectingAppCompatActivity;
|
||||||
|
import org.tasks.intents.TaskIntents;
|
||||||
|
|
||||||
public class TaskEditActivity extends Activity {
|
public class TaskEditActivity extends InjectingAppCompatActivity {
|
||||||
|
|
||||||
private static final String TOKEN_ID = "id";
|
private static final String TOKEN_ID = "id";
|
||||||
|
|
||||||
|
@Inject TaskCreator taskCreator;
|
||||||
|
@Inject TaskDao taskDao;
|
||||||
|
private CompositeDisposable disposables;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void onCreate(Bundle savedInstanceState) {
|
protected void onResume() {
|
||||||
super.onCreate(savedInstanceState);
|
super.onResume();
|
||||||
|
|
||||||
|
long taskId = getIntent().getLongExtra(TOKEN_ID, 0);
|
||||||
|
|
||||||
|
disposables = new CompositeDisposable();
|
||||||
|
|
||||||
|
if (taskId == 0) {
|
||||||
|
startActivity(TaskIntents.getEditTaskIntent(this, taskCreator.createWithValues("")));
|
||||||
|
finish();
|
||||||
|
} else {
|
||||||
|
disposables.add(
|
||||||
|
Single.fromCallable(() -> taskDao.fetch(taskId))
|
||||||
|
.subscribeOn(Schedulers.io())
|
||||||
|
.observeOn(AndroidSchedulers.mainThread())
|
||||||
|
.subscribe(
|
||||||
|
task -> {
|
||||||
|
startActivity(TaskIntents.getEditTaskIntent(this, task));
|
||||||
|
finish();
|
||||||
|
}));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
final long taskId = getIntent().getLongExtra(TOKEN_ID, 0);
|
@Override
|
||||||
|
protected void onPause() {
|
||||||
|
super.onPause();
|
||||||
|
|
||||||
Intent intent = new Intent(this, MainActivity.class);
|
disposables.dispose();
|
||||||
intent.putExtra(MainActivity.OPEN_TASK, taskId);
|
}
|
||||||
startActivity(intent);
|
|
||||||
|
|
||||||
finish();
|
@Override
|
||||||
|
public void inject(ActivityComponent component) {
|
||||||
|
component.inject(this);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
Reference in New Issue