|
| 1 | +package com.termux.api.activities; |
| 2 | + |
| 3 | +import android.content.Intent; |
| 4 | +import android.os.Bundle; |
| 5 | +import android.os.Environment; |
| 6 | +import android.view.Menu; |
| 7 | +import android.view.MenuItem; |
| 8 | +import android.widget.TextView; |
| 9 | + |
| 10 | +import androidx.appcompat.app.AppCompatActivity; |
| 11 | + |
| 12 | +import com.termux.shared.activities.ReportActivity; |
| 13 | +import com.termux.shared.activity.ActivityUtils; |
| 14 | +import com.termux.shared.activity.media.AppCompatActivityUtils; |
| 15 | +import com.termux.shared.android.AndroidUtils; |
| 16 | +import com.termux.shared.file.FileUtils; |
| 17 | +import com.termux.shared.logger.Logger; |
| 18 | +import com.termux.shared.models.ReportInfo; |
| 19 | +import com.termux.shared.termux.TermuxConstants; |
| 20 | +import com.termux.shared.termux.TermuxUtils; |
| 21 | +import com.termux.shared.termux.theme.TermuxThemeUtils; |
| 22 | +import com.termux.shared.theme.NightMode; |
| 23 | +import com.termux.api.R; |
| 24 | + |
| 25 | +public class TermuxAPIActivity extends AppCompatActivity { |
| 26 | + |
| 27 | + private static final String LOG_TAG = "TermuxAPIActivity"; |
| 28 | + |
| 29 | + @Override |
| 30 | + protected void onCreate(Bundle savedInstanceState) { |
| 31 | + Logger.logDebug(LOG_TAG, "onCreate"); |
| 32 | + |
| 33 | + super.onCreate(savedInstanceState); |
| 34 | + setContentView(R.layout.activity_termux_api); |
| 35 | + |
| 36 | + // Set NightMode.APP_NIGHT_MODE |
| 37 | + TermuxThemeUtils.setAppNightMode(this); |
| 38 | + AppCompatActivityUtils.setNightMode(this, NightMode.getAppNightMode().getName(), true); |
| 39 | + |
| 40 | + AppCompatActivityUtils.setToolbar(this, R.id.toolbar); |
| 41 | + AppCompatActivityUtils.setToolbarTitle(this, R.id.toolbar, TermuxConstants.TERMUX_API_APP_NAME, 0); |
| 42 | + |
| 43 | + TextView pluginInfo = findViewById(R.id.textview_plugin_info); |
| 44 | + pluginInfo.setText(getString(R.string.plugin_info, TermuxConstants.TERMUX_GITHUB_REPO_URL, |
| 45 | + TermuxConstants.TERMUX_API_GITHUB_REPO_URL, TermuxConstants.TERMUX_API_APT_PACKAGE_NAME, |
| 46 | + TermuxConstants.TERMUX_API_APT_GITHUB_REPO_URL)); |
| 47 | + } |
| 48 | + |
| 49 | + |
| 50 | + @Override |
| 51 | + public boolean onCreateOptionsMenu(Menu menu) { |
| 52 | + super.onCreateOptionsMenu(menu); |
| 53 | + getMenuInflater().inflate(R.menu.activity_termux_api, menu); |
| 54 | + return true; |
| 55 | + } |
| 56 | + |
| 57 | + @Override |
| 58 | + public boolean onOptionsItemSelected(MenuItem item) { |
| 59 | + int id = item.getItemId(); |
| 60 | + |
| 61 | + if (id == R.id.menu_info) { |
| 62 | + showInfo(); |
| 63 | + return true; |
| 64 | + } else if (id == R.id.menu_settings) { |
| 65 | + openSettings(); |
| 66 | + return true; |
| 67 | + } |
| 68 | + |
| 69 | + return super.onOptionsItemSelected(item); |
| 70 | + } |
| 71 | + |
| 72 | + private void showInfo() { |
| 73 | + new Thread() { |
| 74 | + @Override |
| 75 | + public void run() { |
| 76 | + String title = "About"; |
| 77 | + |
| 78 | + StringBuilder aboutString = new StringBuilder(); |
| 79 | + aboutString.append(TermuxUtils.getAppInfoMarkdownString(TermuxAPIActivity.this, TermuxUtils.AppInfoMode.TERMUX_AND_PLUGIN_PACKAGE)); |
| 80 | + aboutString.append("\n\n").append(AndroidUtils.getDeviceInfoMarkdownString(TermuxAPIActivity.this)); |
| 81 | + aboutString.append("\n\n").append(TermuxUtils.getImportantLinksMarkdownString(TermuxAPIActivity.this)); |
| 82 | + |
| 83 | + ReportInfo reportInfo = new ReportInfo(title, |
| 84 | + TermuxConstants.TERMUX_APP.TERMUX_SETTINGS_ACTIVITY_NAME, title); |
| 85 | + reportInfo.setReportString(aboutString.toString()); |
| 86 | + reportInfo.setReportSaveFileLabelAndPath(title, |
| 87 | + Environment.getExternalStorageDirectory() + "/" + |
| 88 | + FileUtils.sanitizeFileName(TermuxConstants.TERMUX_APP_NAME + "-" + title + ".log", true, true)); |
| 89 | + |
| 90 | + ReportActivity.startReportActivity(TermuxAPIActivity.this, reportInfo); |
| 91 | + } |
| 92 | + }.start(); |
| 93 | + } |
| 94 | + |
| 95 | + private void openSettings() { |
| 96 | + ActivityUtils.startActivity(this, new Intent().setClassName(TermuxConstants.TERMUX_PACKAGE_NAME, TermuxConstants.TERMUX_APP.TERMUX_SETTINGS_ACTIVITY_NAME)); |
| 97 | + } |
| 98 | + |
| 99 | +} |
0 commit comments