forked from jens/Automation
UI changes.
This commit is contained in:
parent
74f50d3e13
commit
09298bce55
app/src
@ -143,6 +143,8 @@
|
|||||||
<activity android:name=".ActivityManageActionSendTextMessage" />
|
<activity android:name=".ActivityManageActionSendTextMessage" />
|
||||||
<activity android:name=".ActivityManageActionPlaySound" />
|
<activity android:name=".ActivityManageActionPlaySound" />
|
||||||
<activity android:name=".ActivityManageTriggerTimeFrame" />
|
<activity android:name=".ActivityManageTriggerTimeFrame" />
|
||||||
|
<activity android:name=".ActivityMaintenance" />
|
||||||
|
<activity android:name=".ActivityTriggerPhoneCall" />
|
||||||
<activity android:name=".ActivityManageActionBrightnessSetting" />
|
<activity android:name=".ActivityManageActionBrightnessSetting" />
|
||||||
<activity android:name=".ActivityHelp" />
|
<activity android:name=".ActivityHelp" />
|
||||||
<activity
|
<activity
|
||||||
|
@ -568,7 +568,7 @@ public class Actions
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void startOtherActivity(boolean byActivity, String param)
|
public static void startOtherActivity(boolean startByAction, String param)
|
||||||
{
|
{
|
||||||
Miscellaneous.logEvent("i", "StartOtherActivity", "Starting other Activity...", 4);
|
Miscellaneous.logEvent("i", "StartOtherActivity", "Starting other Activity...", 4);
|
||||||
|
|
||||||
@ -580,7 +580,7 @@ public class Actions
|
|||||||
|
|
||||||
int paramsStartIndex;
|
int paramsStartIndex;
|
||||||
|
|
||||||
if(byActivity)
|
if(!startByAction)
|
||||||
{
|
{
|
||||||
// selected by activity
|
// selected by activity
|
||||||
|
|
||||||
@ -1097,7 +1097,7 @@ public class Actions
|
|||||||
if(enable)
|
if(enable)
|
||||||
desiredState = 1;
|
desiredState = 1;
|
||||||
|
|
||||||
if(MobileDataStuff.setMobileNetworkfromLollipop(desiredState, autoMationServerRef))
|
if(MobileDataStuff.setMobileNetworkFromLollipop(desiredState, autoMationServerRef))
|
||||||
{
|
{
|
||||||
Miscellaneous.logEvent("i", "setDataConnectionWithRoot()", Miscellaneous.getAnyContext().getResources().getString(R.string.dataConWithRootSuccess), 2);
|
Miscellaneous.logEvent("i", "setDataConnectionWithRoot()", Miscellaneous.getAnyContext().getResources().getString(R.string.dataConWithRootSuccess), 2);
|
||||||
return true;
|
return true;
|
||||||
@ -1122,7 +1122,7 @@ public class Actions
|
|||||||
}
|
}
|
||||||
|
|
||||||
@SuppressLint("NewApi")
|
@SuppressLint("NewApi")
|
||||||
public static boolean setMobileNetworkfromLollipop(int desiredState, Context context) throws Exception
|
public static boolean setMobileNetworkFromLollipop(int desiredState, Context context) throws Exception
|
||||||
{
|
{
|
||||||
String command = null;
|
String command = null;
|
||||||
int state = 0;
|
int state = 0;
|
||||||
|
@ -42,8 +42,8 @@ public class ActivityMainScreen extends ActivityGeneric
|
|||||||
|
|
||||||
private static ActivityMainScreen activityMainScreenInstance = null;
|
private static ActivityMainScreen activityMainScreenInstance = null;
|
||||||
private ToggleButton toggleService, tbLockSound;
|
private ToggleButton toggleService, tbLockSound;
|
||||||
private Button bShowHelp, bPrivacy, bSettingsErase, bSettingsSetToDefault, bVolumeTest, bAddSoundLockTIme, bShareConfigAndLog;
|
private Button bShowHelp, bPrivacy, bSettingsErase, bAddSoundLockTIme;
|
||||||
private TextView tvActivePoi, tvClosestPoi, tvLastRule, tvMainScreenNotePermissions, tvMainScreenNoteFeaturesFromOtherFlavor, tvMainScreenNoteLocationImpossibleBlameGoogle, tvMainScreenNoteNews, tvlockSoundDuration, tvFileStoreLocation;
|
private TextView tvActivePoi, tvClosestPoi, tvLastRule, tvMainScreenNotePermissions, tvMainScreenNoteFeaturesFromOtherFlavor, tvMainScreenNoteLocationImpossibleBlameGoogle, tvMainScreenNoteNews, tvlockSoundDuration;
|
||||||
|
|
||||||
private ListView lvRuleHistory;
|
private ListView lvRuleHistory;
|
||||||
private ArrayAdapter<Rule> ruleHistoryListViewAdapter;
|
private ArrayAdapter<Rule> ruleHistoryListViewAdapter;
|
||||||
@ -77,11 +77,7 @@ public class ActivityMainScreen extends ActivityGeneric
|
|||||||
tvMainScreenNoteLocationImpossibleBlameGoogle = (TextView) findViewById(R.id.tvMainScreenNoteLocationImpossibleBlameGoogle);
|
tvMainScreenNoteLocationImpossibleBlameGoogle = (TextView) findViewById(R.id.tvMainScreenNoteLocationImpossibleBlameGoogle);
|
||||||
tvMainScreenNoteNews = (TextView) findViewById(R.id.tvMainScreenNoteNews);
|
tvMainScreenNoteNews = (TextView) findViewById(R.id.tvMainScreenNoteNews);
|
||||||
tvlockSoundDuration = (TextView)findViewById(R.id.tvlockSoundDuration);
|
tvlockSoundDuration = (TextView)findViewById(R.id.tvlockSoundDuration);
|
||||||
tvFileStoreLocation = (TextView)findViewById(R.id.tvFileStoreLocation);
|
|
||||||
tbLockSound = (ToggleButton) findViewById(R.id.tbLockSound);
|
tbLockSound = (ToggleButton) findViewById(R.id.tbLockSound);
|
||||||
bVolumeTest = (Button) findViewById(R.id.bVolumeTest);
|
|
||||||
bSettingsSetToDefault = (Button) findViewById(R.id.bSettingsSetToDefault);
|
|
||||||
bShareConfigAndLog = (Button) findViewById(R.id.bShareConfigAndLog);
|
|
||||||
toggleService = (ToggleButton) findViewById(R.id.tbArmMastListener);
|
toggleService = (ToggleButton) findViewById(R.id.tbArmMastListener);
|
||||||
toggleService.setChecked(AutomationService.isMyServiceRunning(this));
|
toggleService.setChecked(AutomationService.isMyServiceRunning(this));
|
||||||
toggleService.setOnCheckedChangeListener(new OnCheckedChangeListener()
|
toggleService.setOnCheckedChangeListener(new OnCheckedChangeListener()
|
||||||
@ -136,18 +132,8 @@ public class ActivityMainScreen extends ActivityGeneric
|
|||||||
@Override
|
@Override
|
||||||
public void onClick(View v)
|
public void onClick(View v)
|
||||||
{
|
{
|
||||||
Intent myIntent = new Intent(ActivityMainScreen.this, ActivitySettings.class);
|
Intent myIntent = new Intent(ActivityMainScreen.this, ActivityMaintenance.class);
|
||||||
startActivityForResult(myIntent, 6000);
|
startActivity(myIntent);
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
bVolumeTest.setOnClickListener(new OnClickListener()
|
|
||||||
{
|
|
||||||
@Override
|
|
||||||
public void onClick(View v)
|
|
||||||
{
|
|
||||||
Intent intent = new Intent(ActivityMainScreen.this, ActivityVolumeTest.class);
|
|
||||||
startActivity(intent);
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -184,24 +170,6 @@ public class ActivityMainScreen extends ActivityGeneric
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
bSettingsSetToDefault.setOnClickListener(new OnClickListener()
|
|
||||||
{
|
|
||||||
@Override
|
|
||||||
public void onClick(View v)
|
|
||||||
{
|
|
||||||
getDefaultSettingsDialog(ActivityMainScreen.this).show();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
bShareConfigAndLog.setOnClickListener(new OnClickListener()
|
|
||||||
{
|
|
||||||
@Override
|
|
||||||
public void onClick(View v)
|
|
||||||
{
|
|
||||||
getShareConfigAndLogDialogue(ActivityMainScreen.this).show();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
lvRuleHistory.setOnTouchListener(new OnTouchListener()
|
lvRuleHistory.setOnTouchListener(new OnTouchListener()
|
||||||
{
|
{
|
||||||
@Override
|
@Override
|
||||||
@ -264,81 +232,6 @@ public class ActivityMainScreen extends ActivityGeneric
|
|||||||
return alertDialog;
|
return alertDialog;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static AlertDialog getDefaultSettingsDialog(final Context context)
|
|
||||||
{
|
|
||||||
AlertDialog.Builder alertDialogBuilder = new AlertDialog.Builder(context);
|
|
||||||
alertDialogBuilder.setTitle(context.getResources().getString(R.string.areYouSure));
|
|
||||||
alertDialogBuilder.setPositiveButton(context.getResources().getString(R.string.yes), new DialogInterface.OnClickListener()
|
|
||||||
{
|
|
||||||
@Override
|
|
||||||
public void onClick(DialogInterface dialog, int which)
|
|
||||||
{
|
|
||||||
if (Settings.initializeSettings(context, true))
|
|
||||||
Toast.makeText(context, context.getResources().getString(R.string.settingsSetToDefault), Toast.LENGTH_LONG).show();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
alertDialogBuilder.setNegativeButton(context.getResources().getString(R.string.no), null);
|
|
||||||
AlertDialog alertDialog = alertDialogBuilder.create();
|
|
||||||
|
|
||||||
return alertDialog;
|
|
||||||
}
|
|
||||||
|
|
||||||
AlertDialog getShareConfigAndLogDialogue(final Context context)
|
|
||||||
{
|
|
||||||
AlertDialog.Builder alertDialogBuilder = new AlertDialog.Builder(context);
|
|
||||||
alertDialogBuilder.setTitle(context.getResources().getString(R.string.shareConfigAndLogFilesWithDev));
|
|
||||||
alertDialogBuilder.setMessage(context.getResources().getString(R.string.shareConfigAndLogExplanation));
|
|
||||||
alertDialogBuilder.setPositiveButton(context.getResources().getString(R.string.yes), new DialogInterface.OnClickListener()
|
|
||||||
{
|
|
||||||
@Override
|
|
||||||
public void onClick(DialogInterface dialog, int which)
|
|
||||||
{
|
|
||||||
File dstZipFile = new File(Miscellaneous.getAnyContext().getCacheDir() + "/" + Settings.zipFileName);
|
|
||||||
|
|
||||||
ArrayList<String> srcFilesList = new ArrayList<>();
|
|
||||||
srcFilesList.add(Miscellaneous.getWriteableFolder() + "/" + XmlFileInterface.settingsFileName);
|
|
||||||
|
|
||||||
String logFilePath = Miscellaneous.getWriteableFolder() + "/" + Miscellaneous.logFileName;
|
|
||||||
if((new File(logFilePath)).exists())
|
|
||||||
srcFilesList.add(logFilePath);
|
|
||||||
|
|
||||||
String logFilePathArchive = Miscellaneous.getWriteableFolder() + "/" + Miscellaneous.logFileName + "-old";
|
|
||||||
if((new File(logFilePathArchive)).exists())
|
|
||||||
srcFilesList.add(logFilePathArchive);
|
|
||||||
|
|
||||||
String[] srcFiles = srcFilesList.toArray(new String[srcFilesList.size()]);
|
|
||||||
|
|
||||||
if(dstZipFile.exists())
|
|
||||||
dstZipFile.delete();
|
|
||||||
|
|
||||||
Miscellaneous.zip(srcFiles, dstZipFile.getAbsolutePath());
|
|
||||||
|
|
||||||
/*
|
|
||||||
Without root the zip file in the cache directory is not directly accessible.
|
|
||||||
But have to route it through this content provider crap.
|
|
||||||
*/
|
|
||||||
|
|
||||||
String subject = "Automation logs";
|
|
||||||
|
|
||||||
StringBuilder emailBody = new StringBuilder();
|
|
||||||
emailBody.append("Device details" + Miscellaneous.lineSeparator);
|
|
||||||
emailBody.append("OS version: " + System.getProperty("os.version") + Miscellaneous.lineSeparator);
|
|
||||||
emailBody.append("API Level: " + android.os.Build.VERSION.SDK + Miscellaneous.lineSeparator);
|
|
||||||
emailBody.append("Device: " + android.os.Build.DEVICE + Miscellaneous.lineSeparator);
|
|
||||||
emailBody.append("Model: " + android.os.Build.MODEL + Miscellaneous.lineSeparator);
|
|
||||||
emailBody.append("Product: " + android.os.Build.PRODUCT);
|
|
||||||
|
|
||||||
Uri uri = Uri.parse("content://com.jens.automation2/" + Settings.zipFileName);
|
|
||||||
|
|
||||||
Miscellaneous.sendEmail(ActivityMainScreen.this, "android-development@gmx.de", "Automation logs", emailBody.toString(), uri);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
alertDialogBuilder.setNegativeButton(context.getResources().getString(R.string.no), null);
|
|
||||||
AlertDialog alertDialog = alertDialogBuilder.create();
|
|
||||||
|
|
||||||
return alertDialog;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static ActivityMainScreen getActivityMainScreenInstance()
|
public static ActivityMainScreen getActivityMainScreenInstance()
|
||||||
{
|
{
|
||||||
return activityMainScreenInstance;
|
return activityMainScreenInstance;
|
||||||
@ -515,34 +408,6 @@ public class ActivityMainScreen extends ActivityGeneric
|
|||||||
|
|
||||||
Settings.considerDone(Settings.constNewsOptInDone);
|
Settings.considerDone(Settings.constNewsOptInDone);
|
||||||
Settings.writeSettings(Miscellaneous.getAnyContext());
|
Settings.writeSettings(Miscellaneous.getAnyContext());
|
||||||
|
|
||||||
String folder = Miscellaneous.getWriteableFolder();
|
|
||||||
if(folder != null && folder.length() > 0)
|
|
||||||
{
|
|
||||||
activityMainScreenInstance.tvFileStoreLocation.setText(String.format(activityMainScreenInstance.getResources().getString(R.string.filesStoredAt), folder));
|
|
||||||
activityMainScreenInstance.tvFileStoreLocation.setOnClickListener(new OnClickListener()
|
|
||||||
{
|
|
||||||
@Override
|
|
||||||
public void onClick(View v)
|
|
||||||
{
|
|
||||||
Uri selectedUri = Uri.parse(folder);
|
|
||||||
Intent intent = new Intent(Intent.ACTION_VIEW);
|
|
||||||
intent.setDataAndType(selectedUri, "resource/folder");
|
|
||||||
|
|
||||||
if (intent.resolveActivityInfo(activityMainScreenInstance.getPackageManager(), 0) != null)
|
|
||||||
{
|
|
||||||
activityMainScreenInstance.startActivity(intent);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
// if you reach this place, it means there is no any file
|
|
||||||
// explorer app installed on your device
|
|
||||||
Toast.makeText(activityMainScreenInstance, activityMainScreenInstance.getResources().getString(R.string.noFileManageInstalled), Toast.LENGTH_LONG).show();
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -598,16 +463,6 @@ public class ActivityMainScreen extends ActivityGeneric
|
|||||||
case ActivityPermissions.requestCodeForPermissions:
|
case ActivityPermissions.requestCodeForPermissions:
|
||||||
updateMainScreen();
|
updateMainScreen();
|
||||||
break;
|
break;
|
||||||
case 6000: //settings
|
|
||||||
Settings.readFromPersistentStorage(this);
|
|
||||||
|
|
||||||
if (boundToService && AutomationService.isMyServiceRunning(this))
|
|
||||||
myAutomationService.serviceInterface(serviceCommands.reloadSettings);
|
|
||||||
|
|
||||||
if(AutomationService.isMyServiceRunning(ActivityMainScreen.this))
|
|
||||||
Toast.makeText(this, getResources().getString(R.string.settingsWillTakeTime), Toast.LENGTH_LONG).show();
|
|
||||||
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (AutomationService.isMyServiceRunning(this))
|
if (AutomationService.isMyServiceRunning(this))
|
||||||
|
248
app/src/main/java/com/jens/automation2/ActivityMaintenance.java
Normal file
248
app/src/main/java/com/jens/automation2/ActivityMaintenance.java
Normal file
@ -0,0 +1,248 @@
|
|||||||
|
package com.jens.automation2;
|
||||||
|
|
||||||
|
import android.app.Activity;
|
||||||
|
import android.app.AlertDialog;
|
||||||
|
import android.content.Context;
|
||||||
|
import android.content.DialogInterface;
|
||||||
|
import android.content.Intent;
|
||||||
|
import android.net.Uri;
|
||||||
|
import android.os.Bundle;
|
||||||
|
import android.view.View;
|
||||||
|
import android.widget.Button;
|
||||||
|
import android.widget.TextView;
|
||||||
|
import android.widget.Toast;
|
||||||
|
|
||||||
|
import androidx.annotation.Nullable;
|
||||||
|
import androidx.documentfile.provider.DocumentFile;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
|
||||||
|
public class ActivityMaintenance extends Activity
|
||||||
|
{
|
||||||
|
final static int requestCodeImport = 1001;
|
||||||
|
final static int requestCodeExport = 1002;
|
||||||
|
final static int requestCodeMoreSettings = 6000;
|
||||||
|
|
||||||
|
TextView tvFileStoreLocation;
|
||||||
|
Button bVolumeTest, bMoreSettings, bSettingsSetToDefault, bShareConfigAndLog, bImportConfiguration, bExportConfiguration;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onCreate(@Nullable Bundle savedInstanceState)
|
||||||
|
{
|
||||||
|
super.onCreate(savedInstanceState);
|
||||||
|
setContentView(R.layout.activity_maintenance);
|
||||||
|
|
||||||
|
bVolumeTest = (Button) findViewById(R.id.bVolumeTest);
|
||||||
|
bVolumeTest.setOnClickListener(new View.OnClickListener()
|
||||||
|
{
|
||||||
|
@Override
|
||||||
|
public void onClick(View v)
|
||||||
|
{
|
||||||
|
Intent intent = new Intent(ActivityMaintenance.this, ActivityVolumeTest.class);
|
||||||
|
startActivity(intent);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
bShareConfigAndLog = (Button) findViewById(R.id.bShareConfigAndLog);
|
||||||
|
bShareConfigAndLog.setOnClickListener(new View.OnClickListener()
|
||||||
|
{
|
||||||
|
@Override
|
||||||
|
public void onClick(View v)
|
||||||
|
{
|
||||||
|
getShareConfigAndLogDialogue(ActivityMaintenance.this).show();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
bSettingsSetToDefault = (Button) findViewById(R.id.bSettingsSetToDefault);
|
||||||
|
bSettingsSetToDefault.setOnClickListener(new View.OnClickListener()
|
||||||
|
{
|
||||||
|
@Override
|
||||||
|
public void onClick(View v)
|
||||||
|
{
|
||||||
|
getDefaultSettingsDialog(ActivityMaintenance.this).show();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
Button bMoreSettings = (Button) findViewById(R.id.bMoreSettings);
|
||||||
|
bMoreSettings.setOnClickListener(new View.OnClickListener()
|
||||||
|
{
|
||||||
|
@Override
|
||||||
|
public void onClick(View v)
|
||||||
|
{
|
||||||
|
Intent myIntent = new Intent(ActivityMaintenance.this, ActivitySettings.class);
|
||||||
|
startActivityForResult(myIntent, requestCodeMoreSettings);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
bImportConfiguration = (Button) findViewById(R.id.bImportConfiguration);
|
||||||
|
bImportConfiguration.setOnClickListener(new View.OnClickListener()
|
||||||
|
{
|
||||||
|
@Override
|
||||||
|
public void onClick(View v)
|
||||||
|
{
|
||||||
|
Intent intent = new Intent(Intent.ACTION_OPEN_DOCUMENT_TREE);
|
||||||
|
startActivityForResult(intent, requestCodeImport);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
bExportConfiguration = (Button) findViewById(R.id.bExportConfiguration);
|
||||||
|
bExportConfiguration.setOnClickListener(new View.OnClickListener()
|
||||||
|
{
|
||||||
|
@Override
|
||||||
|
public void onClick(View v)
|
||||||
|
{
|
||||||
|
Intent intent = new Intent(Intent.ACTION_OPEN_DOCUMENT_TREE);
|
||||||
|
startActivityForResult(intent, requestCodeExport);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
tvFileStoreLocation = (TextView)findViewById(R.id.tvFileStoreLocation);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onActivityResult(int requestCode, int resultCode, Intent data)
|
||||||
|
{
|
||||||
|
switch(requestCode)
|
||||||
|
{
|
||||||
|
case requestCodeMoreSettings: //settings
|
||||||
|
Settings.readFromPersistentStorage(this);
|
||||||
|
|
||||||
|
if (AutomationService.isMyServiceRunning(this))
|
||||||
|
AutomationService.getInstance().serviceInterface(AutomationService.serviceCommands.reloadSettings);
|
||||||
|
|
||||||
|
if (AutomationService.isMyServiceRunning(ActivityMaintenance.this))
|
||||||
|
Toast.makeText(this, getResources().getString(R.string.settingsWillTakeTime), Toast.LENGTH_LONG).show();
|
||||||
|
|
||||||
|
break;
|
||||||
|
case requestCodeImport:
|
||||||
|
if(resultCode == RESULT_OK)
|
||||||
|
{
|
||||||
|
Uri uriTree = data.getData();
|
||||||
|
DocumentFile directory = DocumentFile.fromTreeUri(this, uriTree);
|
||||||
|
for(DocumentFile file : directory.listFiles())
|
||||||
|
{
|
||||||
|
if(file.canRead() && file.getName().equals(XmlFileInterface.settingsFileName))
|
||||||
|
{
|
||||||
|
// import rules, locations, etc.
|
||||||
|
Miscellaneous.copyFileUsingStream(file, Miscellaneous.getWriteableFolder() + "/" + XmlFileInterface.settingsFileName);
|
||||||
|
}
|
||||||
|
else if(false && file.canRead() && file.getName().equals(XmlFileInterface.settingsFileName))
|
||||||
|
{
|
||||||
|
// import rules, locations, etc.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static AlertDialog getDefaultSettingsDialog(final Context context)
|
||||||
|
{
|
||||||
|
AlertDialog.Builder alertDialogBuilder = new AlertDialog.Builder(context);
|
||||||
|
alertDialogBuilder.setTitle(context.getResources().getString(R.string.areYouSure));
|
||||||
|
alertDialogBuilder.setPositiveButton(context.getResources().getString(R.string.yes), new DialogInterface.OnClickListener()
|
||||||
|
{
|
||||||
|
@Override
|
||||||
|
public void onClick(DialogInterface dialog, int which)
|
||||||
|
{
|
||||||
|
if (Settings.initializeSettings(context, true))
|
||||||
|
Toast.makeText(context, context.getResources().getString(R.string.settingsSetToDefault), Toast.LENGTH_LONG).show();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
alertDialogBuilder.setNegativeButton(context.getResources().getString(R.string.no), null);
|
||||||
|
AlertDialog alertDialog = alertDialogBuilder.create();
|
||||||
|
|
||||||
|
return alertDialog;
|
||||||
|
}
|
||||||
|
|
||||||
|
AlertDialog getShareConfigAndLogDialogue(final Context context)
|
||||||
|
{
|
||||||
|
AlertDialog.Builder alertDialogBuilder = new AlertDialog.Builder(context);
|
||||||
|
alertDialogBuilder.setTitle(context.getResources().getString(R.string.shareConfigAndLogFilesWithDev));
|
||||||
|
alertDialogBuilder.setMessage(context.getResources().getString(R.string.shareConfigAndLogExplanation));
|
||||||
|
alertDialogBuilder.setPositiveButton(context.getResources().getString(R.string.yes), new DialogInterface.OnClickListener()
|
||||||
|
{
|
||||||
|
@Override
|
||||||
|
public void onClick(DialogInterface dialog, int which)
|
||||||
|
{
|
||||||
|
File dstZipFile = new File(Miscellaneous.getAnyContext().getCacheDir() + "/" + Settings.zipFileName);
|
||||||
|
|
||||||
|
ArrayList<String> srcFilesList = new ArrayList<>();
|
||||||
|
srcFilesList.add(Miscellaneous.getWriteableFolder() + "/" + XmlFileInterface.settingsFileName);
|
||||||
|
|
||||||
|
String logFilePath = Miscellaneous.getWriteableFolder() + "/" + Miscellaneous.logFileName;
|
||||||
|
if((new File(logFilePath)).exists())
|
||||||
|
srcFilesList.add(logFilePath);
|
||||||
|
|
||||||
|
String logFilePathArchive = Miscellaneous.getWriteableFolder() + "/" + Miscellaneous.logFileName + "-old";
|
||||||
|
if((new File(logFilePathArchive)).exists())
|
||||||
|
srcFilesList.add(logFilePathArchive);
|
||||||
|
|
||||||
|
String[] srcFiles = srcFilesList.toArray(new String[srcFilesList.size()]);
|
||||||
|
|
||||||
|
if(dstZipFile.exists())
|
||||||
|
dstZipFile.delete();
|
||||||
|
|
||||||
|
Miscellaneous.zip(srcFiles, dstZipFile.getAbsolutePath());
|
||||||
|
|
||||||
|
/*
|
||||||
|
Without root the zip file in the cache directory is not directly accessible.
|
||||||
|
But have to route it through this content provider crap.
|
||||||
|
*/
|
||||||
|
|
||||||
|
String subject = "Automation logs";
|
||||||
|
|
||||||
|
StringBuilder emailBody = new StringBuilder();
|
||||||
|
emailBody.append("Device details" + Miscellaneous.lineSeparator);
|
||||||
|
emailBody.append("OS version: " + System.getProperty("os.version") + Miscellaneous.lineSeparator);
|
||||||
|
emailBody.append("API Level: " + android.os.Build.VERSION.SDK + Miscellaneous.lineSeparator);
|
||||||
|
emailBody.append("Device: " + android.os.Build.DEVICE + Miscellaneous.lineSeparator);
|
||||||
|
emailBody.append("Model: " + android.os.Build.MODEL + Miscellaneous.lineSeparator);
|
||||||
|
emailBody.append("Product: " + android.os.Build.PRODUCT);
|
||||||
|
|
||||||
|
Uri uri = Uri.parse("content://com.jens.automation2/" + Settings.zipFileName);
|
||||||
|
|
||||||
|
Miscellaneous.sendEmail(ActivityMaintenance.this, "android-development@gmx.de", "Automation logs", emailBody.toString(), uri);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
alertDialogBuilder.setNegativeButton(context.getResources().getString(R.string.no), null);
|
||||||
|
AlertDialog alertDialog = alertDialogBuilder.create();
|
||||||
|
|
||||||
|
return alertDialog;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onResume()
|
||||||
|
{
|
||||||
|
super.onResume();
|
||||||
|
|
||||||
|
String folder = Miscellaneous.getWriteableFolder();
|
||||||
|
if (folder != null && folder.length() > 0)
|
||||||
|
{
|
||||||
|
tvFileStoreLocation.setText(String.format(getResources().getString(R.string.filesStoredAt), folder));
|
||||||
|
tvFileStoreLocation.setOnClickListener(new View.OnClickListener()
|
||||||
|
{
|
||||||
|
@Override
|
||||||
|
public void onClick(View v)
|
||||||
|
{
|
||||||
|
Uri selectedUri = Uri.parse(folder);
|
||||||
|
Intent intent = new Intent(Intent.ACTION_VIEW);
|
||||||
|
intent.setDataAndType(selectedUri, "resource/folder");
|
||||||
|
|
||||||
|
if (intent.resolveActivityInfo(getPackageManager(), 0) != null)
|
||||||
|
{
|
||||||
|
startActivity(intent);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// if you reach this place, it means there is no any file
|
||||||
|
// explorer app installed on your device
|
||||||
|
Toast.makeText(ActivityMaintenance.this, getResources().getString(R.string.noFileManageInstalled), Toast.LENGTH_LONG).show();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -432,23 +432,28 @@ public class ActivityManageActionStartActivity extends Activity
|
|||||||
|
|
||||||
private void loadValuesIntoGui()
|
private void loadValuesIntoGui()
|
||||||
{
|
{
|
||||||
boolean selectionByActivity = resultingAction.getParameter1();
|
boolean selectionByAction = resultingAction.getParameter1();
|
||||||
rbStartAppSelectByActivity.setChecked(selectionByActivity);
|
rbStartAppSelectByActivity.setChecked(!selectionByAction);
|
||||||
rbStartAppSelectByAction.setChecked(!selectionByActivity);
|
rbStartAppSelectByAction.setChecked(selectionByAction);
|
||||||
|
|
||||||
String[] params = resultingAction.getParameter2().split(";");
|
String[] params = resultingAction.getParameter2().split(";");
|
||||||
|
|
||||||
int startIndex = -1;
|
int startIndex = -1;
|
||||||
|
|
||||||
if(selectionByActivity)
|
if(!selectionByAction)
|
||||||
{
|
{
|
||||||
etPackageName.setText(params[0]);
|
etPackageName.setText(params[0]);
|
||||||
|
if(params.length > 1) // should not occur, have fault tollerance
|
||||||
|
{
|
||||||
etActivityOrActionPath.setText(params[1]);
|
etActivityOrActionPath.setText(params[1]);
|
||||||
|
|
||||||
if (params.length >= 2)
|
if (params.length >= 2)
|
||||||
startIndex = 2;
|
startIndex = 2;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
else
|
else
|
||||||
|
{
|
||||||
|
if(params.length > 1) // should not occur, have fault tollerance
|
||||||
{
|
{
|
||||||
if(params[1].contains("/"))
|
if(params[1].contains("/"))
|
||||||
{
|
{
|
||||||
@ -462,6 +467,12 @@ public class ActivityManageActionStartActivity extends Activity
|
|||||||
startIndex = 2;
|
startIndex = 2;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
etActivityOrActionPath.setText(params[0]);
|
||||||
|
startIndex = 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if(startIndex > -1 && params.length > startIndex)
|
if(startIndex > -1 && params.length > startIndex)
|
||||||
{
|
{
|
||||||
@ -514,7 +525,7 @@ public class ActivityManageActionStartActivity extends Activity
|
|||||||
if(resultingAction == null)
|
if(resultingAction == null)
|
||||||
resultingAction = new Action();
|
resultingAction = new Action();
|
||||||
|
|
||||||
resultingAction.setParameter1(rbStartAppSelectByActivity.isChecked());
|
resultingAction.setParameter1(rbStartAppSelectByAction.isChecked());
|
||||||
|
|
||||||
resultingAction.setAction(Action_Enum.startOtherActivity);
|
resultingAction.setAction(Action_Enum.startOtherActivity);
|
||||||
|
|
||||||
|
@ -0,0 +1,16 @@
|
|||||||
|
package com.jens.automation2;
|
||||||
|
|
||||||
|
import android.app.Activity;
|
||||||
|
import android.os.Bundle;
|
||||||
|
|
||||||
|
import androidx.annotation.Nullable;
|
||||||
|
|
||||||
|
public class ActivityTriggerPhoneCall extends Activity
|
||||||
|
{
|
||||||
|
@Override
|
||||||
|
protected void onCreate(@Nullable Bundle savedInstanceState)
|
||||||
|
{
|
||||||
|
super.onCreate(savedInstanceState);
|
||||||
|
setContentView(R.layout.trigger_phone_call);
|
||||||
|
}
|
||||||
|
}
|
@ -90,6 +90,7 @@ import javax.xml.parsers.DocumentBuilderFactory;
|
|||||||
import javax.xml.parsers.ParserConfigurationException;
|
import javax.xml.parsers.ParserConfigurationException;
|
||||||
|
|
||||||
import androidx.core.app.NotificationCompat;
|
import androidx.core.app.NotificationCompat;
|
||||||
|
import androidx.documentfile.provider.DocumentFile;
|
||||||
|
|
||||||
import static android.provider.CalendarContract.CalendarCache.URI;
|
import static android.provider.CalendarContract.CalendarCache.URI;
|
||||||
import static com.jens.automation2.AutomationService.NOTIFICATION_CHANNEL_ID;
|
import static com.jens.automation2.AutomationService.NOTIFICATION_CHANNEL_ID;
|
||||||
@ -1214,6 +1215,37 @@ public class Miscellaneous extends Service
|
|||||||
return returnValue;
|
return returnValue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static String copyDocumentFile(String inputPath, String inputFile, Uri treeUri)
|
||||||
|
{
|
||||||
|
InputStream in = null;
|
||||||
|
OutputStream out = null;
|
||||||
|
String error = null;
|
||||||
|
DocumentFile pickedDir = DocumentFile.fromTreeUri(getActivity(), treeUri);
|
||||||
|
String extension = inputFile.substring(inputFile.lastIndexOf(".")+1,inputFile.length());
|
||||||
|
|
||||||
|
try {
|
||||||
|
DocumentFile newFile = pickedDir.createFile("audio/"+extension, inputFile);
|
||||||
|
out = getActivity().getContentResolver().openOutputStream(newFile.getUri());
|
||||||
|
in = new FileInputStream(inputPath + inputFile);
|
||||||
|
|
||||||
|
byte[] buffer = new byte[1024];
|
||||||
|
int read;
|
||||||
|
while ((read = in.read(buffer)) != -1) {
|
||||||
|
out.write(buffer, 0, read);
|
||||||
|
}
|
||||||
|
in.close();
|
||||||
|
// write the output file (You have now copied the file)
|
||||||
|
out.flush();
|
||||||
|
out.close();
|
||||||
|
|
||||||
|
} catch (FileNotFoundException fnfe1) {
|
||||||
|
error = fnfe1.getMessage();
|
||||||
|
} catch (Exception e) {
|
||||||
|
error = e.getMessage();
|
||||||
|
}
|
||||||
|
return error;
|
||||||
|
}
|
||||||
|
|
||||||
public static boolean googleToBlameForLocation(boolean checkExistingRules)
|
public static boolean googleToBlameForLocation(boolean checkExistingRules)
|
||||||
{
|
{
|
||||||
if(Build.VERSION.SDK_INT >= Build.VERSION_CODES.Q)
|
if(Build.VERSION.SDK_INT >= Build.VERSION_CODES.Q)
|
||||||
|
59
app/src/main/res/layout/activity_maintenance.xml
Normal file
59
app/src/main/res/layout/activity_maintenance.xml
Normal file
@ -0,0 +1,59 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<androidx.appcompat.widget.LinearLayoutCompat
|
||||||
|
xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
android:orientation="vertical"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_margin="@dimen/default_margin">
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:textAppearance="@style/TextAppearance.AppCompat.Headline"
|
||||||
|
android:text="@string/settings" />
|
||||||
|
|
||||||
|
<Button
|
||||||
|
android:id="@+id/bImportConfiguration"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="@string/importConfiguration" />
|
||||||
|
|
||||||
|
<Button
|
||||||
|
android:id="@+id/bExportConfiguration"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="@string/exportConfiguration" />
|
||||||
|
|
||||||
|
<Button
|
||||||
|
android:id="@+id/bVolumeTest"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="@string/volumeTest" />
|
||||||
|
|
||||||
|
<Button
|
||||||
|
android:id="@+id/bMoreSettings"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="@string/moreSettings" />
|
||||||
|
|
||||||
|
<Button
|
||||||
|
android:id="@+id/bSettingsSetToDefault"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="@string/defaultSettings" />
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/tvFileStoreLocation"
|
||||||
|
android:layout_marginVertical="@dimen/default_margin"
|
||||||
|
android:layout_gravity="center_horizontal"
|
||||||
|
android:gravity="center_horizontal"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content" />
|
||||||
|
|
||||||
|
<Button
|
||||||
|
android:id="@+id/bShareConfigAndLog"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="@string/shareConfigAndLogFilesWithDev" />
|
||||||
|
|
||||||
|
</androidx.appcompat.widget.LinearLayoutCompat>
|
@ -306,84 +306,35 @@
|
|||||||
<LinearLayout
|
<LinearLayout
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:orientation="horizontal"
|
android:orientation="vertical"
|
||||||
android:layout_margin="10dp"
|
android:layout_margin="10dp"
|
||||||
android:layout_marginTop="30dp"
|
android:layout_marginTop="30dp"
|
||||||
android:gravity="top" >
|
android:gravity="center_horizontal" >
|
||||||
|
|
||||||
<Button
|
<Button
|
||||||
android:id="@+id/bShowHelp"
|
android:id="@+id/bShowHelp"
|
||||||
android:layout_gravity="center_vertical"
|
android:layout_gravity="center_vertical"
|
||||||
android:layout_width="fill_parent"
|
android:layout_width="fill_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:text="@string/showHelp"
|
android:text="@string/showHelp" />
|
||||||
android:layout_weight="1" />
|
|
||||||
|
|
||||||
<Button
|
|
||||||
android:id="@+id/bVolumeTest"
|
|
||||||
android:layout_gravity="center_vertical"
|
|
||||||
android:layout_width="fill_parent"
|
|
||||||
android:layout_height="wrap_content"
|
|
||||||
android:text="@string/volumeTest"
|
|
||||||
android:layout_weight="1" />
|
|
||||||
|
|
||||||
<Button
|
<Button
|
||||||
android:id="@+id/bPrivacy"
|
android:id="@+id/bPrivacy"
|
||||||
android:layout_width="fill_parent"
|
android:layout_width="fill_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_gravity="center_vertical"
|
android:layout_gravity="center_vertical"
|
||||||
android:layout_weight="1"
|
|
||||||
android:enabled="true"
|
android:enabled="true"
|
||||||
android:text="@string/privacy" />
|
android:text="@string/privacy" />
|
||||||
|
|
||||||
</LinearLayout>
|
|
||||||
|
|
||||||
<LinearLayout
|
|
||||||
android:layout_width="match_parent"
|
|
||||||
android:layout_height="wrap_content"
|
|
||||||
android:orientation="horizontal"
|
|
||||||
android:layout_margin="10dp"
|
|
||||||
android:layout_marginTop="30dp"
|
|
||||||
android:gravity="center_horizontal" >
|
|
||||||
|
|
||||||
<Button
|
<Button
|
||||||
android:id="@+id/bSettings"
|
android:id="@+id/bSettings"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="fill_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_gravity="top"
|
android:layout_gravity="top"
|
||||||
android:layout_weight="1"
|
|
||||||
android:text="@string/menu_settings" />
|
android:text="@string/menu_settings" />
|
||||||
|
|
||||||
<!-- <Button
|
|
||||||
android:id="@+id/bSettingsErase"
|
|
||||||
android:layout_width="wrap_content"
|
|
||||||
android:layout_height="wrap_content"
|
|
||||||
android:text="@string/eraseSettings" /> -->
|
|
||||||
|
|
||||||
<Button
|
|
||||||
android:id="@+id/bSettingsSetToDefault"
|
|
||||||
android:layout_width="wrap_content"
|
|
||||||
android:layout_height="wrap_content"
|
|
||||||
android:layout_weight="1"
|
|
||||||
android:text="@string/defaultSettings" />
|
|
||||||
|
|
||||||
</LinearLayout>
|
</LinearLayout>
|
||||||
|
|
||||||
<TextView
|
|
||||||
android:id="@+id/tvFileStoreLocation"
|
|
||||||
android:layout_marginVertical="@dimen/default_margin"
|
|
||||||
android:layout_gravity="center_horizontal"
|
|
||||||
android:gravity="center_horizontal"
|
|
||||||
android:layout_width="wrap_content"
|
|
||||||
android:layout_height="wrap_content" />
|
|
||||||
|
|
||||||
<Button
|
|
||||||
android:id="@+id/bShareConfigAndLog"
|
|
||||||
android:layout_gravity="center_horizontal"
|
|
||||||
android:layout_width="wrap_content"
|
|
||||||
android:layout_height="wrap_content"
|
|
||||||
android:text="@string/shareConfigAndLogFilesWithDev" />
|
|
||||||
|
|
||||||
</LinearLayout>
|
</LinearLayout>
|
||||||
|
|
||||||
</ScrollView>
|
</ScrollView>
|
113
app/src/main/res/layout/trigger_phone_call.xml
Normal file
113
app/src/main/res/layout/trigger_phone_call.xml
Normal file
@ -0,0 +1,113 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<androidx.appcompat.widget.LinearLayoutCompat
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
android:layout_margin="@dimen/default_margin"
|
||||||
|
android:orientation="vertical"
|
||||||
|
xmlns:android="http://schemas.android.com/apk/res/android">
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:textAppearance="@style/TextAppearance.AppCompat.Headline"
|
||||||
|
android:text="@string/phoneCall" />
|
||||||
|
|
||||||
|
<TableLayout
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:shrinkColumns="1"
|
||||||
|
android:stretchColumns="1" >
|
||||||
|
|
||||||
|
<TableRow
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content" >
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="@string/state" />
|
||||||
|
|
||||||
|
<RadioGroup
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content" >
|
||||||
|
|
||||||
|
<RadioButton
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="@string/started" />
|
||||||
|
|
||||||
|
<RadioButton
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="@string/stopped" />
|
||||||
|
|
||||||
|
</RadioGroup>
|
||||||
|
|
||||||
|
</TableRow>
|
||||||
|
|
||||||
|
<TableRow
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content" >
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="@string/phoneDirection" />
|
||||||
|
|
||||||
|
<RadioGroup
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content" >
|
||||||
|
|
||||||
|
<RadioButton
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="@string/incoming" />
|
||||||
|
|
||||||
|
<RadioButton
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="@string/outgoing" />
|
||||||
|
|
||||||
|
</RadioGroup>
|
||||||
|
|
||||||
|
</TableRow>
|
||||||
|
|
||||||
|
<TableRow
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content" >
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="@string/phoneNumber" />
|
||||||
|
|
||||||
|
<EditText
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content" />
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="@string/phoneNumberExplanation" />
|
||||||
|
|
||||||
|
</TableRow>
|
||||||
|
|
||||||
|
<TableRow
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content" >
|
||||||
|
|
||||||
|
<Button
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="@string/importNumberFromContacts" />
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="@string/phoneNumberExplanation" />
|
||||||
|
|
||||||
|
</TableRow>
|
||||||
|
|
||||||
|
</TableLayout>
|
||||||
|
|
||||||
|
</androidx.appcompat.widget.LinearLayoutCompat>
|
@ -645,4 +645,9 @@
|
|||||||
<string name="startAppByAction">by action</string>
|
<string name="startAppByAction">by action</string>
|
||||||
<string name="enterValidAction">Enter a valid action</string>
|
<string name="enterValidAction">Enter a valid action</string>
|
||||||
<string name="enterPackageName">Enter a valid package name.</string>
|
<string name="enterPackageName">Enter a valid package name.</string>
|
||||||
|
<string name="state">State</string>
|
||||||
|
<string name="phoneNumberExplanation">You can enter a specific phone number, but you don\'t have to. If you want to specify one you can either pick one from your address book or enter it manually. Also regular expressions are supported if you want the rule to apply to an entire number block for example.</string>
|
||||||
|
<string name="importConfiguration">Import configuration</string>
|
||||||
|
<string name="exportConfiguration">Export configuration</string>
|
||||||
|
<string name="moreSettings">More settings</string>
|
||||||
</resources>
|
</resources>
|
Loading…
Reference in New Issue
Block a user