Create DB management activity by taking the existing functionalities from the debug activity.
This commit is contained in:
parent
84e644fa1a
commit
6a2043eeb7
|
@ -226,6 +226,12 @@
|
||||||
android:parentActivityName=".activities.ControlCenter"
|
android:parentActivityName=".activities.ControlCenter"
|
||||||
android:screenOrientation="portrait"
|
android:screenOrientation="portrait"
|
||||||
android:windowSoftInputMode="stateHidden" />
|
android:windowSoftInputMode="stateHidden" />
|
||||||
|
<activity
|
||||||
|
android:name=".activities.DbManagementActivity"
|
||||||
|
android:label="@string/title_activity_db_management"
|
||||||
|
android:parentActivityName=".activities.ControlCenter"
|
||||||
|
android:screenOrientation="portrait"
|
||||||
|
android:windowSoftInputMode="stateHidden" />
|
||||||
<activity
|
<activity
|
||||||
android:name=".activities.OnboardingActivity"
|
android:name=".activities.OnboardingActivity"
|
||||||
android:label="@string/title_activity_onboarding"
|
android:label="@string/title_activity_onboarding"
|
||||||
|
|
|
@ -310,6 +310,10 @@ public class ControlCenter extends GBActivity {
|
||||||
Intent debugIntent = new Intent(this, DebugActivity.class);
|
Intent debugIntent = new Intent(this, DebugActivity.class);
|
||||||
startActivity(debugIntent);
|
startActivity(debugIntent);
|
||||||
return true;
|
return true;
|
||||||
|
case R.id.action_db_management:
|
||||||
|
Intent dbIntent = new Intent(this, DbManagementActivity.class);
|
||||||
|
startActivity(dbIntent);
|
||||||
|
return true;
|
||||||
case R.id.action_quit:
|
case R.id.action_quit:
|
||||||
GBApplication.quit();
|
GBApplication.quit();
|
||||||
return true;
|
return true;
|
||||||
|
|
|
@ -0,0 +1,219 @@
|
||||||
|
package nodomain.freeyourgadget.gadgetbridge.activities;
|
||||||
|
|
||||||
|
import android.app.AlertDialog;
|
||||||
|
import android.app.ProgressDialog;
|
||||||
|
import android.content.DialogInterface;
|
||||||
|
import android.content.IntentFilter;
|
||||||
|
import android.database.sqlite.SQLiteOpenHelper;
|
||||||
|
import android.os.AsyncTask;
|
||||||
|
import android.os.Bundle;
|
||||||
|
import android.support.v4.app.NavUtils;
|
||||||
|
import android.view.MenuItem;
|
||||||
|
import android.view.View;
|
||||||
|
import android.widget.Button;
|
||||||
|
import android.widget.Toast;
|
||||||
|
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.util.Collections;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import nodomain.freeyourgadget.gadgetbridge.GBApplication;
|
||||||
|
import nodomain.freeyourgadget.gadgetbridge.R;
|
||||||
|
import nodomain.freeyourgadget.gadgetbridge.adapter.GBDeviceAdapter;
|
||||||
|
import nodomain.freeyourgadget.gadgetbridge.database.ActivityDatabaseHandler;
|
||||||
|
import nodomain.freeyourgadget.gadgetbridge.database.DBHandler;
|
||||||
|
import nodomain.freeyourgadget.gadgetbridge.database.DBHelper;
|
||||||
|
import nodomain.freeyourgadget.gadgetbridge.impl.GBDevice;
|
||||||
|
import nodomain.freeyourgadget.gadgetbridge.util.FileUtils;
|
||||||
|
import nodomain.freeyourgadget.gadgetbridge.util.GB;
|
||||||
|
|
||||||
|
|
||||||
|
public class DbManagementActivity extends GBActivity {
|
||||||
|
private static final Logger LOG = LoggerFactory.getLogger(DbManagementActivity.class);
|
||||||
|
|
||||||
|
private Button exportDBButton;
|
||||||
|
private Button importDBButton;
|
||||||
|
private Button importOldActivityDataButton;
|
||||||
|
private Button deleteDBButton;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onCreate(Bundle savedInstanceState) {
|
||||||
|
super.onCreate(savedInstanceState);
|
||||||
|
setContentView(R.layout.activity_db_management);
|
||||||
|
|
||||||
|
IntentFilter filter = new IntentFilter();
|
||||||
|
filter.addAction(GBApplication.ACTION_QUIT);
|
||||||
|
|
||||||
|
exportDBButton = (Button) findViewById(R.id.exportDBButton);
|
||||||
|
exportDBButton.setOnClickListener(new View.OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(View v) {
|
||||||
|
exportDB();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
importDBButton = (Button) findViewById(R.id.importDBButton);
|
||||||
|
importDBButton.setOnClickListener(new View.OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(View v) {
|
||||||
|
importDB();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
importOldActivityDataButton = (Button) findViewById(R.id.mergeOldActivityData);
|
||||||
|
importOldActivityDataButton.setOnClickListener(new View.OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(View v) {
|
||||||
|
mergeOldActivityDbContents();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
deleteDBButton = (Button) findViewById(R.id.emptyDBButton);
|
||||||
|
deleteDBButton.setOnClickListener(new View.OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(View v) {
|
||||||
|
deleteActivityDatabase();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
private void exportDB() {
|
||||||
|
try (DBHandler dbHandler = GBApplication.acquireDB()) {
|
||||||
|
DBHelper helper = new DBHelper(this);
|
||||||
|
File dir = FileUtils.getExternalFilesDir();
|
||||||
|
File destFile = helper.exportDB(dbHandler, dir);
|
||||||
|
GB.toast(this, "Exported to: " + destFile.getAbsolutePath(), Toast.LENGTH_LONG, GB.INFO);
|
||||||
|
} catch (Exception ex) {
|
||||||
|
GB.toast(this, "Error exporting DB: " + ex.getMessage(), Toast.LENGTH_LONG, GB.ERROR, ex);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void importDB() {
|
||||||
|
new AlertDialog.Builder(this)
|
||||||
|
.setCancelable(true)
|
||||||
|
.setTitle("Import Activity Data?")
|
||||||
|
.setMessage("Really overwrite the current activity database? All your activity data (if any) will be lost.")
|
||||||
|
.setPositiveButton("Overwrite", new DialogInterface.OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(DialogInterface dialog, int which) {
|
||||||
|
try (DBHandler dbHandler = GBApplication.acquireDB()) {
|
||||||
|
DBHelper helper = new DBHelper(DbManagementActivity.this);
|
||||||
|
File dir = FileUtils.getExternalFilesDir();
|
||||||
|
SQLiteOpenHelper sqLiteOpenHelper = dbHandler.getHelper();
|
||||||
|
File sourceFile = new File(dir, sqLiteOpenHelper.getDatabaseName());
|
||||||
|
helper.importDB(dbHandler, sourceFile);
|
||||||
|
helper.validateDB(sqLiteOpenHelper);
|
||||||
|
GB.toast(DbManagementActivity.this, "Import successful.", Toast.LENGTH_LONG, GB.INFO);
|
||||||
|
} catch (Exception ex) {
|
||||||
|
GB.toast(DbManagementActivity.this, "Error importing DB: " + ex.getMessage(), Toast.LENGTH_LONG, GB.ERROR, ex);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.setNegativeButton("Cancel", new DialogInterface.OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(DialogInterface dialog, int which) {
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.show();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void mergeOldActivityDbContents() {
|
||||||
|
final DBHelper helper = new DBHelper(getBaseContext());
|
||||||
|
final ActivityDatabaseHandler oldHandler = helper.getOldActivityDatabaseHandler();
|
||||||
|
if (oldHandler == null) {
|
||||||
|
GB.toast(this, "No old activity database found, nothing to import.", Toast.LENGTH_LONG, GB.ERROR);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
selectDeviceForMergingActivityDatabaseInto(new DeviceSelectionCallback() {
|
||||||
|
@Override
|
||||||
|
public void invoke(final GBDevice device) {
|
||||||
|
if (device == null) {
|
||||||
|
GB.toast(DbManagementActivity.this, "No connected device to associate old activity data with.", Toast.LENGTH_LONG, GB.ERROR);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
try (DBHandler targetHandler = GBApplication.acquireDB()) {
|
||||||
|
final ProgressDialog progress = ProgressDialog.show(DbManagementActivity.this, "Merging Activity Data", "Please wait while merging your activity data...", true, false);
|
||||||
|
new AsyncTask<Object, ProgressDialog, Object>() {
|
||||||
|
@Override
|
||||||
|
protected Object doInBackground(Object[] params) {
|
||||||
|
helper.importOldDb(oldHandler, device, targetHandler);
|
||||||
|
if (!isFinishing() && !isDestroyed()) {
|
||||||
|
progress.dismiss();
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}.execute((Object[]) null);
|
||||||
|
} catch (Exception ex) {
|
||||||
|
GB.toast(DbManagementActivity.this, "Error importing old activity data into new database.", Toast.LENGTH_LONG, GB.ERROR, ex);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
private void selectDeviceForMergingActivityDatabaseInto(final DeviceSelectionCallback callback) {
|
||||||
|
GBDevice connectedDevice = GBApplication.getDeviceManager().getSelectedDevice();
|
||||||
|
if (connectedDevice == null) {
|
||||||
|
callback.invoke(null);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
final List<GBDevice> availableDevices = Collections.singletonList(connectedDevice);
|
||||||
|
GBDeviceAdapter adapter = new GBDeviceAdapter(getBaseContext(), availableDevices);
|
||||||
|
|
||||||
|
new AlertDialog.Builder(this)
|
||||||
|
.setCancelable(true)
|
||||||
|
.setTitle("Associate old Data with Device")
|
||||||
|
.setAdapter(adapter, new DialogInterface.OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(DialogInterface dialog, int which) {
|
||||||
|
GBDevice device = availableDevices.get(which);
|
||||||
|
callback.invoke(device);
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.setNegativeButton("Cancel", new DialogInterface.OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(DialogInterface dialog, int which) {
|
||||||
|
// ignore, just return
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.show();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void deleteActivityDatabase() {
|
||||||
|
new AlertDialog.Builder(this)
|
||||||
|
.setCancelable(true)
|
||||||
|
.setTitle("Delete Activity Data?")
|
||||||
|
.setMessage("Really delete the entire activity database? All your activity data will be lost.")
|
||||||
|
.setPositiveButton("Delete", new DialogInterface.OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(DialogInterface dialog, int which) {
|
||||||
|
if (GBApplication.deleteActivityDatabase(DbManagementActivity.this)) {
|
||||||
|
GB.toast(DbManagementActivity.this, "Activity database successfully deleted.", Toast.LENGTH_SHORT, GB.INFO);
|
||||||
|
} else {
|
||||||
|
GB.toast(DbManagementActivity.this, "Activity database deletion failed.", Toast.LENGTH_SHORT, GB.INFO);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.setNegativeButton("Cancel", new DialogInterface.OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(DialogInterface dialog, int which) {
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.show();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean onOptionsItemSelected(MenuItem item) {
|
||||||
|
switch (item.getItemId()) {
|
||||||
|
case android.R.id.home:
|
||||||
|
NavUtils.navigateUpFromSameTask(this);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return super.onOptionsItemSelected(item);
|
||||||
|
}
|
||||||
|
|
||||||
|
public interface DeviceSelectionCallback {
|
||||||
|
void invoke(GBDevice device);
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,16 +1,11 @@
|
||||||
package nodomain.freeyourgadget.gadgetbridge.activities;
|
package nodomain.freeyourgadget.gadgetbridge.activities;
|
||||||
|
|
||||||
import android.app.AlertDialog;
|
|
||||||
import android.app.NotificationManager;
|
import android.app.NotificationManager;
|
||||||
import android.app.PendingIntent;
|
import android.app.PendingIntent;
|
||||||
import android.app.ProgressDialog;
|
|
||||||
import android.content.BroadcastReceiver;
|
import android.content.BroadcastReceiver;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.DialogInterface;
|
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.content.IntentFilter;
|
import android.content.IntentFilter;
|
||||||
import android.database.sqlite.SQLiteOpenHelper;
|
|
||||||
import android.os.AsyncTask;
|
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.support.v4.app.NavUtils;
|
import android.support.v4.app.NavUtils;
|
||||||
import android.support.v4.app.NotificationCompat;
|
import android.support.v4.app.NotificationCompat;
|
||||||
|
@ -25,16 +20,8 @@ import android.widget.Toast;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
import java.io.File;
|
|
||||||
import java.util.Collections;
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import nodomain.freeyourgadget.gadgetbridge.GBApplication;
|
import nodomain.freeyourgadget.gadgetbridge.GBApplication;
|
||||||
import nodomain.freeyourgadget.gadgetbridge.R;
|
import nodomain.freeyourgadget.gadgetbridge.R;
|
||||||
import nodomain.freeyourgadget.gadgetbridge.adapter.GBDeviceAdapter;
|
|
||||||
import nodomain.freeyourgadget.gadgetbridge.database.ActivityDatabaseHandler;
|
|
||||||
import nodomain.freeyourgadget.gadgetbridge.database.DBHandler;
|
|
||||||
import nodomain.freeyourgadget.gadgetbridge.database.DBHelper;
|
|
||||||
import nodomain.freeyourgadget.gadgetbridge.impl.GBDevice;
|
import nodomain.freeyourgadget.gadgetbridge.impl.GBDevice;
|
||||||
import nodomain.freeyourgadget.gadgetbridge.model.CallSpec;
|
import nodomain.freeyourgadget.gadgetbridge.model.CallSpec;
|
||||||
import nodomain.freeyourgadget.gadgetbridge.model.DeviceService;
|
import nodomain.freeyourgadget.gadgetbridge.model.DeviceService;
|
||||||
|
@ -42,7 +29,6 @@ import nodomain.freeyourgadget.gadgetbridge.model.MusicSpec;
|
||||||
import nodomain.freeyourgadget.gadgetbridge.model.MusicStateSpec;
|
import nodomain.freeyourgadget.gadgetbridge.model.MusicStateSpec;
|
||||||
import nodomain.freeyourgadget.gadgetbridge.model.NotificationSpec;
|
import nodomain.freeyourgadget.gadgetbridge.model.NotificationSpec;
|
||||||
import nodomain.freeyourgadget.gadgetbridge.model.NotificationType;
|
import nodomain.freeyourgadget.gadgetbridge.model.NotificationType;
|
||||||
import nodomain.freeyourgadget.gadgetbridge.util.FileUtils;
|
|
||||||
import nodomain.freeyourgadget.gadgetbridge.util.GB;
|
import nodomain.freeyourgadget.gadgetbridge.util.GB;
|
||||||
|
|
||||||
|
|
||||||
|
@ -64,10 +50,6 @@ public class DebugActivity extends GBActivity {
|
||||||
private Button setTimeButton;
|
private Button setTimeButton;
|
||||||
private Button rebootButton;
|
private Button rebootButton;
|
||||||
private Button HeartRateButton;
|
private Button HeartRateButton;
|
||||||
private Button exportDBButton;
|
|
||||||
private Button importDBButton;
|
|
||||||
private Button importOldActivityDataButton;
|
|
||||||
private Button deleteDBButton;
|
|
||||||
|
|
||||||
private EditText editContent;
|
private EditText editContent;
|
||||||
private final BroadcastReceiver mReceiver = new BroadcastReceiver() {
|
private final BroadcastReceiver mReceiver = new BroadcastReceiver() {
|
||||||
|
@ -173,37 +155,6 @@ public class DebugActivity extends GBActivity {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
exportDBButton = (Button) findViewById(R.id.exportDBButton);
|
|
||||||
exportDBButton.setOnClickListener(new View.OnClickListener() {
|
|
||||||
@Override
|
|
||||||
public void onClick(View v) {
|
|
||||||
exportDB();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
importDBButton = (Button) findViewById(R.id.importDBButton);
|
|
||||||
importDBButton.setOnClickListener(new View.OnClickListener() {
|
|
||||||
@Override
|
|
||||||
public void onClick(View v) {
|
|
||||||
importDB();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
importOldActivityDataButton = (Button) findViewById(R.id.mergeOldActivityData);
|
|
||||||
importOldActivityDataButton.setOnClickListener(new View.OnClickListener() {
|
|
||||||
@Override
|
|
||||||
public void onClick(View v) {
|
|
||||||
mergeOldActivityDbContents();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
deleteDBButton = (Button) findViewById(R.id.emptyDBButton);
|
|
||||||
deleteDBButton.setOnClickListener(new View.OnClickListener() {
|
|
||||||
@Override
|
|
||||||
public void onClick(View v) {
|
|
||||||
deleteActivityDatabase();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
rebootButton = (Button) findViewById(R.id.rebootButton);
|
rebootButton = (Button) findViewById(R.id.rebootButton);
|
||||||
rebootButton.setOnClickListener(new View.OnClickListener() {
|
rebootButton.setOnClickListener(new View.OnClickListener() {
|
||||||
@Override
|
@Override
|
||||||
|
@ -262,130 +213,6 @@ public class DebugActivity extends GBActivity {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
private void exportDB() {
|
|
||||||
try (DBHandler dbHandler = GBApplication.acquireDB()) {
|
|
||||||
DBHelper helper = new DBHelper(this);
|
|
||||||
File dir = FileUtils.getExternalFilesDir();
|
|
||||||
File destFile = helper.exportDB(dbHandler, dir);
|
|
||||||
GB.toast(this, "Exported to: " + destFile.getAbsolutePath(), Toast.LENGTH_LONG, GB.INFO);
|
|
||||||
} catch (Exception ex) {
|
|
||||||
GB.toast(this, "Error exporting DB: " + ex.getMessage(), Toast.LENGTH_LONG, GB.ERROR, ex);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void importDB() {
|
|
||||||
new AlertDialog.Builder(this)
|
|
||||||
.setCancelable(true)
|
|
||||||
.setTitle("Import Activity Data?")
|
|
||||||
.setMessage("Really overwrite the current activity database? All your activity data (if any) will be lost.")
|
|
||||||
.setPositiveButton("Overwrite", new DialogInterface.OnClickListener() {
|
|
||||||
@Override
|
|
||||||
public void onClick(DialogInterface dialog, int which) {
|
|
||||||
try (DBHandler dbHandler = GBApplication.acquireDB()) {
|
|
||||||
DBHelper helper = new DBHelper(DebugActivity.this);
|
|
||||||
File dir = FileUtils.getExternalFilesDir();
|
|
||||||
SQLiteOpenHelper sqLiteOpenHelper = dbHandler.getHelper();
|
|
||||||
File sourceFile = new File(dir, sqLiteOpenHelper.getDatabaseName());
|
|
||||||
helper.importDB(dbHandler, sourceFile);
|
|
||||||
helper.validateDB(sqLiteOpenHelper);
|
|
||||||
GB.toast(DebugActivity.this, "Import successful.", Toast.LENGTH_LONG, GB.INFO);
|
|
||||||
} catch (Exception ex) {
|
|
||||||
GB.toast(DebugActivity.this, "Error importing DB: " + ex.getMessage(), Toast.LENGTH_LONG, GB.ERROR, ex);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
})
|
|
||||||
.setNegativeButton("Cancel", new DialogInterface.OnClickListener() {
|
|
||||||
@Override
|
|
||||||
public void onClick(DialogInterface dialog, int which) {
|
|
||||||
}
|
|
||||||
})
|
|
||||||
.show();
|
|
||||||
}
|
|
||||||
|
|
||||||
private void mergeOldActivityDbContents() {
|
|
||||||
final DBHelper helper = new DBHelper(getBaseContext());
|
|
||||||
final ActivityDatabaseHandler oldHandler = helper.getOldActivityDatabaseHandler();
|
|
||||||
if (oldHandler == null) {
|
|
||||||
GB.toast(this, "No old activity database found, nothing to import.", Toast.LENGTH_LONG, GB.ERROR);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
selectDeviceForMergingActivityDatabaseInto(new DeviceSelectionCallback() {
|
|
||||||
@Override
|
|
||||||
public void invoke(final GBDevice device) {
|
|
||||||
if (device == null) {
|
|
||||||
GB.toast(DebugActivity.this, "No connected device to associate old activity data with.", Toast.LENGTH_LONG, GB.ERROR);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
try (DBHandler targetHandler = GBApplication.acquireDB()) {
|
|
||||||
final ProgressDialog progress = ProgressDialog.show(DebugActivity.this, "Merging Activity Data", "Please wait while merging your activity data...", true, false);
|
|
||||||
new AsyncTask<Object,ProgressDialog,Object>() {
|
|
||||||
@Override
|
|
||||||
protected Object doInBackground(Object[] params) {
|
|
||||||
helper.importOldDb(oldHandler, device, targetHandler);
|
|
||||||
if (!isFinishing() && !isDestroyed()) {
|
|
||||||
progress.dismiss();
|
|
||||||
}
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
}.execute((Object[]) null);
|
|
||||||
} catch (Exception ex) {
|
|
||||||
GB.toast(DebugActivity.this, "Error importing old activity data into new database.", Toast.LENGTH_LONG, GB.ERROR, ex);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
private void selectDeviceForMergingActivityDatabaseInto(final DeviceSelectionCallback callback) {
|
|
||||||
GBDevice connectedDevice = GBApplication.getDeviceManager().getSelectedDevice();
|
|
||||||
if (connectedDevice == null) {
|
|
||||||
callback.invoke(null);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
final List<GBDevice> availableDevices = Collections.singletonList(connectedDevice);
|
|
||||||
GBDeviceAdapter adapter = new GBDeviceAdapter(getBaseContext(), availableDevices);
|
|
||||||
|
|
||||||
new AlertDialog.Builder(this)
|
|
||||||
.setCancelable(true)
|
|
||||||
.setTitle("Associate old Data with Device")
|
|
||||||
.setAdapter(adapter, new DialogInterface.OnClickListener() {
|
|
||||||
@Override
|
|
||||||
public void onClick(DialogInterface dialog, int which) {
|
|
||||||
GBDevice device = availableDevices.get(which);
|
|
||||||
callback.invoke(device);
|
|
||||||
}
|
|
||||||
})
|
|
||||||
.setNegativeButton("Cancel", new DialogInterface.OnClickListener() {
|
|
||||||
@Override
|
|
||||||
public void onClick(DialogInterface dialog, int which) {
|
|
||||||
// ignore, just return
|
|
||||||
}
|
|
||||||
})
|
|
||||||
.show();
|
|
||||||
}
|
|
||||||
|
|
||||||
private void deleteActivityDatabase() {
|
|
||||||
new AlertDialog.Builder(this)
|
|
||||||
.setCancelable(true)
|
|
||||||
.setTitle("Delete Activity Data?")
|
|
||||||
.setMessage("Really delete the entire activity database? All your activity data will be lost.")
|
|
||||||
.setPositiveButton("Delete", new DialogInterface.OnClickListener() {
|
|
||||||
@Override
|
|
||||||
public void onClick(DialogInterface dialog, int which) {
|
|
||||||
if (GBApplication.deleteActivityDatabase(DebugActivity.this)) {
|
|
||||||
GB.toast(DebugActivity.this, "Activity database successfully deleted.", Toast.LENGTH_SHORT, GB.INFO);
|
|
||||||
} else {
|
|
||||||
GB.toast(DebugActivity.this, "Activity database deletion failed.", Toast.LENGTH_SHORT, GB.INFO);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
})
|
|
||||||
.setNegativeButton("Cancel", new DialogInterface.OnClickListener() {
|
|
||||||
@Override
|
|
||||||
public void onClick(DialogInterface dialog, int which) {
|
|
||||||
}
|
|
||||||
})
|
|
||||||
.show();
|
|
||||||
}
|
|
||||||
|
|
||||||
private void testNotification() {
|
private void testNotification() {
|
||||||
Intent notificationIntent = new Intent(getApplicationContext(), DebugActivity.class);
|
Intent notificationIntent = new Intent(getApplicationContext(), DebugActivity.class);
|
||||||
notificationIntent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK
|
notificationIntent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK
|
||||||
|
|
|
@ -0,0 +1,69 @@
|
||||||
|
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
xmlns:tools="http://schemas.android.com/tools"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
android:paddingBottom="@dimen/activity_vertical_margin"
|
||||||
|
android:paddingLeft="@dimen/activity_horizontal_margin"
|
||||||
|
android:paddingRight="@dimen/activity_horizontal_margin"
|
||||||
|
android:paddingTop="@dimen/activity_vertical_margin"
|
||||||
|
tools:context="nodomain.freeyourgadget.gadgetbridge.activities.ControlCenter">
|
||||||
|
|
||||||
|
<ScrollView
|
||||||
|
android:id="@+id/scrollView"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_alignParentBottom="true"
|
||||||
|
android:layout_alignParentEnd="true"
|
||||||
|
android:layout_alignParentStart="true"
|
||||||
|
android:layout_alignParentTop="true">
|
||||||
|
|
||||||
|
<GridLayout
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:columnCount="3"
|
||||||
|
android:rowCount="15"
|
||||||
|
android:alignmentMode="alignMargins">
|
||||||
|
|
||||||
|
|
||||||
|
<Button
|
||||||
|
android:id="@+id/exportDBButton"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_column="0"
|
||||||
|
android:layout_gravity="fill_horizontal"
|
||||||
|
android:layout_row="6"
|
||||||
|
android:singleLine="false"
|
||||||
|
android:text="Export DB" />
|
||||||
|
|
||||||
|
<Button
|
||||||
|
android:id="@+id/importDBButton"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_column="1"
|
||||||
|
android:layout_gravity="fill_horizontal"
|
||||||
|
android:layout_row="6"
|
||||||
|
android:text="Import DB" />
|
||||||
|
|
||||||
|
<Button
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="Empty DB"
|
||||||
|
android:id="@+id/emptyDBButton"
|
||||||
|
android:layout_row="6"
|
||||||
|
android:layout_column="2" />
|
||||||
|
|
||||||
|
<Button
|
||||||
|
android:id="@+id/mergeOldActivityData"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_column="0"
|
||||||
|
android:layout_columnSpan="3"
|
||||||
|
android:layout_gravity="fill_horizontal"
|
||||||
|
android:layout_row="7"
|
||||||
|
android:text="Merge old activity data" />
|
||||||
|
|
||||||
|
|
||||||
|
</GridLayout>
|
||||||
|
</ScrollView>
|
||||||
|
|
||||||
|
</RelativeLayout>
|
|
@ -152,45 +152,6 @@
|
||||||
android:layout_row="11"
|
android:layout_row="11"
|
||||||
android:text="reboot" />
|
android:text="reboot" />
|
||||||
|
|
||||||
|
|
||||||
<Button
|
|
||||||
android:id="@+id/exportDBButton"
|
|
||||||
android:layout_width="wrap_content"
|
|
||||||
android:layout_height="wrap_content"
|
|
||||||
android:layout_column="0"
|
|
||||||
android:layout_gravity="fill_horizontal"
|
|
||||||
android:layout_row="6"
|
|
||||||
android:singleLine="false"
|
|
||||||
android:text="Export DB" />
|
|
||||||
|
|
||||||
<Button
|
|
||||||
android:id="@+id/importDBButton"
|
|
||||||
android:layout_width="wrap_content"
|
|
||||||
android:layout_height="wrap_content"
|
|
||||||
android:layout_column="1"
|
|
||||||
android:layout_gravity="fill_horizontal"
|
|
||||||
android:layout_row="6"
|
|
||||||
android:text="Import DB" />
|
|
||||||
|
|
||||||
<Button
|
|
||||||
android:layout_width="wrap_content"
|
|
||||||
android:layout_height="wrap_content"
|
|
||||||
android:text="Empty DB"
|
|
||||||
android:id="@+id/emptyDBButton"
|
|
||||||
android:layout_row="6"
|
|
||||||
android:layout_column="2" />
|
|
||||||
|
|
||||||
<Button
|
|
||||||
android:id="@+id/mergeOldActivityData"
|
|
||||||
android:layout_width="wrap_content"
|
|
||||||
android:layout_height="wrap_content"
|
|
||||||
android:layout_column="0"
|
|
||||||
android:layout_columnSpan="3"
|
|
||||||
android:layout_gravity="fill_horizontal"
|
|
||||||
android:layout_row="7"
|
|
||||||
android:text="Merge old activity data" />
|
|
||||||
|
|
||||||
|
|
||||||
</GridLayout>
|
</GridLayout>
|
||||||
</ScrollView>
|
</ScrollView>
|
||||||
|
|
||||||
|
|
|
@ -6,6 +6,11 @@
|
||||||
android:orderInCategory="100" app:showAsAction="never" />
|
android:orderInCategory="100" app:showAsAction="never" />
|
||||||
<item android:id="@+id/action_debug" android:title="@string/action_debug"
|
<item android:id="@+id/action_debug" android:title="@string/action_debug"
|
||||||
android:orderInCategory="100" app:showAsAction="never" />
|
android:orderInCategory="100" app:showAsAction="never" />
|
||||||
|
<item
|
||||||
|
android:id="@+id/action_db_management"
|
||||||
|
android:title="@string/action_db_management"
|
||||||
|
android:orderInCategory="100"
|
||||||
|
app:showAsAction="never" />
|
||||||
<item android:id="@+id/action_quit" android:title="@string/action_quit"
|
<item android:id="@+id/action_quit" android:title="@string/action_quit"
|
||||||
android:orderInCategory="100" app:showAsAction="never" />
|
android:orderInCategory="100" app:showAsAction="never" />
|
||||||
</menu>
|
</menu>
|
||||||
|
|
|
@ -297,4 +297,6 @@
|
||||||
</string>
|
</string>
|
||||||
<string name="pref_title_pebble_health_store_raw">Store raw record in the database</string>
|
<string name="pref_title_pebble_health_store_raw">Store raw record in the database</string>
|
||||||
<string name="pref_summary_pebble_health_store_raw">If checked the data is stored \"as is\" and is available for later interpretation. NB: the database will be bigger in this case!</string>
|
<string name="pref_summary_pebble_health_store_raw">If checked the data is stored \"as is\" and is available for later interpretation. NB: the database will be bigger in this case!</string>
|
||||||
|
<string name="action_db_management">Database Management</string>
|
||||||
|
<string name="title_activity_db_management">Database management</string>
|
||||||
</resources>
|
</resources>
|
||||||
|
|
Loading…
Reference in New Issue