Bring primary storage migration back into the adoption flow, and provide a path for long-lived notifications to re-launch into the Settings app. Also provide option to initiate migration if skipped during wizard. For now, estmiate migration size and time based on a Class 10 card. Follow other callback refactoring. Bug: 19993667 Change-Id: Ia0c28eb114bc6c8066c17b3142ed74f962140c91
85 lines
3.1 KiB
Java
85 lines
3.1 KiB
Java
/*
|
|
* Copyright (C) 2015 The Android Open Source Project
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
package com.android.settings.deviceinfo;
|
|
|
|
import static android.content.pm.PackageManager.EXTRA_MOVE_ID;
|
|
import static com.android.settings.deviceinfo.StorageSettings.TAG;
|
|
|
|
import android.content.Context;
|
|
import android.content.Intent;
|
|
import android.content.pm.PackageManager;
|
|
import android.content.pm.PackageManager.MoveCallback;
|
|
import android.os.Bundle;
|
|
import android.os.Handler;
|
|
import android.os.storage.DiskInfo;
|
|
import android.util.Log;
|
|
import android.view.View;
|
|
import android.widget.Toast;
|
|
|
|
import com.android.internal.util.Preconditions;
|
|
import com.android.settings.R;
|
|
|
|
public class StorageWizardMigrateProgress extends StorageWizardBase {
|
|
private int mMoveId;
|
|
|
|
@Override
|
|
protected void onCreate(Bundle savedInstanceState) {
|
|
super.onCreate(savedInstanceState);
|
|
setContentView(R.layout.storage_wizard_progress);
|
|
|
|
Preconditions.checkNotNull(mVolume);
|
|
|
|
mMoveId = getIntent().getIntExtra(EXTRA_MOVE_ID, -1);
|
|
|
|
final String descrip = mStorage.getBestVolumeDescription(mVolume);
|
|
setHeaderText(R.string.storage_wizard_migrate_progress_title, descrip);
|
|
setBodyText(R.string.storage_wizard_migrate_details, descrip);
|
|
|
|
getNextButton().setVisibility(View.GONE);
|
|
|
|
// Register for updates and push through current status
|
|
getPackageManager().registerMoveCallback(mCallback, new Handler());
|
|
mCallback.onStatusChanged(mMoveId, getPackageManager().getMoveStatus(mMoveId), -1);
|
|
}
|
|
|
|
private final MoveCallback mCallback = new MoveCallback() {
|
|
@Override
|
|
public void onStatusChanged(int moveId, int status, long estMillis) {
|
|
if (mMoveId != moveId) return;
|
|
|
|
final Context context = StorageWizardMigrateProgress.this;
|
|
if (PackageManager.isMoveStatusFinished(status)) {
|
|
Log.d(TAG, "Finished with status " + status);
|
|
if (status == PackageManager.MOVE_SUCCEEDED) {
|
|
if (mDisk != null) {
|
|
final Intent intent = new Intent(context, StorageWizardReady.class);
|
|
intent.putExtra(DiskInfo.EXTRA_DISK_ID, mDisk.getId());
|
|
startActivity(intent);
|
|
}
|
|
} else {
|
|
Toast.makeText(context, getString(R.string.insufficient_storage),
|
|
Toast.LENGTH_LONG).show();
|
|
}
|
|
finishAffinity();
|
|
|
|
} else {
|
|
setCurrentProgress(status);
|
|
}
|
|
}
|
|
};
|
|
}
|