X-Git-Url: https://git.ktnx.net/?a=blobdiff_plain;f=app%2Fsrc%2Fmain%2Fjava%2Fnet%2Fktnx%2Fmobileledger%2Fui%2Ftemplates%2FTemplatesActivity.java;h=410b7d62878ac4027ce418f55280a5175674ea23;hb=346b3c8e74a12b1822239481f807479fa81fc706;hp=7bcece63d7e17f3e0aa67937e4cc6a23f41b85b5;hpb=d95839304defead7c7d605cab2e612f1227cbfed;p=mobile-ledger.git diff --git a/app/src/main/java/net/ktnx/mobileledger/ui/templates/TemplatesActivity.java b/app/src/main/java/net/ktnx/mobileledger/ui/templates/TemplatesActivity.java index 7bcece63..410b7d62 100644 --- a/app/src/main/java/net/ktnx/mobileledger/ui/templates/TemplatesActivity.java +++ b/app/src/main/java/net/ktnx/mobileledger/ui/templates/TemplatesActivity.java @@ -18,9 +18,10 @@ package net.ktnx.mobileledger.ui.templates; import android.os.Bundle; -import android.view.Menu; import android.view.MenuItem; +import androidx.activity.result.ActivityResultLauncher; +import androidx.annotation.NonNull; import androidx.appcompat.app.ActionBar; import androidx.lifecycle.ViewModelProvider; import androidx.lifecycle.ViewModelStoreOwner; @@ -28,25 +29,34 @@ import androidx.navigation.NavController; import androidx.navigation.NavDestination; import androidx.navigation.fragment.NavHostFragment; +import com.google.android.material.snackbar.BaseTransientBottomBar; +import com.google.android.material.snackbar.Snackbar; + import net.ktnx.mobileledger.R; +import net.ktnx.mobileledger.dao.TemplateHeaderDAO; import net.ktnx.mobileledger.databinding.ActivityTemplatesBinding; +import net.ktnx.mobileledger.db.DB; +import net.ktnx.mobileledger.db.TemplateWithAccounts; +import net.ktnx.mobileledger.ui.QR; import net.ktnx.mobileledger.ui.activity.CrashReportingActivity; import net.ktnx.mobileledger.utils.Logger; import java.util.Objects; public class TemplatesActivity extends CrashReportingActivity - implements TemplateListFragment.OnTemplateListFragmentInteractionListener { + implements TemplateListFragment.OnTemplateListFragmentInteractionListener, + TemplateDetailsFragment.InteractionListener, QR.QRScanResultReceiver, QR.QRScanTrigger { public static final String ARG_ADD_TEMPLATE = "add-template"; private ActivityTemplatesBinding b; private NavController navController; - @Override - public boolean onCreateOptionsMenu(Menu menu) { - super.onCreateOptionsMenu(menu); - getMenuInflater().inflate(R.menu.template_list_menu, menu); - - return true; - } + private ActivityResultLauncher qrScanLauncher; + // @Override +// public boolean onCreateOptionsMenu(Menu menu) { +// super.onCreateOptionsMenu(menu); +// getMenuInflater().inflate(R.menu.template_list_menu, menu); +// +// return true; +// } @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); @@ -79,6 +89,8 @@ public class TemplatesActivity extends CrashReportingActivity b.fabAdd.setOnClickListener(v -> onEditTemplate(null)); b.fabSave.setOnClickListener(v -> onSaveTemplate()); + + qrScanLauncher = QR.registerLauncher(this, this); } @Override public boolean onOptionsItemSelected(MenuItem item) { @@ -94,7 +106,12 @@ public class TemplatesActivity extends CrashReportingActivity } return super.onOptionsItemSelected(item); } - + @Override + public void onDuplicateTemplate(long id) { + DB.get() + .getTemplateDAO() + .duplicateTemplateWitAccounts(id, null); + } @Override public void onEditTemplate(Long id) { if (id == null) { @@ -122,4 +139,35 @@ public class TemplatesActivity extends CrashReportingActivity public NavController getNavController() { return navController; } + @Override + public void onDeleteTemplate(@NonNull Long templateId) { + Objects.requireNonNull(templateId); + TemplateHeaderDAO dao = DB.get() + .getTemplateDAO(); + + dao.getTemplateWithAccountsAsync(templateId, template -> { + TemplateWithAccounts copy = TemplateWithAccounts.from(template); + dao.deleteAsync(template.header, () -> { + navController.popBackStack(R.id.templateListFragment, false); + + Snackbar.make(b.getRoot(), String.format( + TemplatesActivity.this.getString(R.string.template_xxx_deleted), + template.header.getName()), BaseTransientBottomBar.LENGTH_LONG) + .setAction(R.string.action_undo, v -> dao.insertAsync(copy, null)) + .show(); + }); + }); + } + @Override + public void onQRScanResult(String scanned) { + Logger.debug("PatDet_fr", String.format("Got scanned text '%s'", scanned)); + TemplateDetailsViewModel model = new ViewModelProvider( + navController.getViewModelStoreOwner(R.id.template_list_navigation)).get( + TemplateDetailsViewModel.class); + model.setTestText(scanned); + } + @Override + public void triggerQRScan() { + qrScanLauncher.launch(null); + } } \ No newline at end of file