/*
- * Copyright © 2019 Damyan Ivanov.
+ * Copyright © 2021 Damyan Ivanov.
* This file is part of MoLe.
* MoLe is free software: you can distribute it and/or modify it
* under the term of the GNU General Public License as published by
import androidx.annotation.Nullable;
+import net.ktnx.mobileledger.App;
+import net.ktnx.mobileledger.dao.BaseDAO;
+import net.ktnx.mobileledger.dao.ProfileDAO;
+import net.ktnx.mobileledger.db.DB;
+import net.ktnx.mobileledger.db.Profile;
import net.ktnx.mobileledger.model.Data;
-import net.ktnx.mobileledger.model.MobileLedgerProfile;
import net.ktnx.mobileledger.utils.Colors;
-import net.ktnx.mobileledger.utils.GetOptCallback;
-import net.ktnx.mobileledger.utils.MLDB;
+import net.ktnx.mobileledger.utils.Logger;
+
+import java.util.Locale;
@SuppressLint("Registered")
public class ProfileThemedActivity extends CrashReportingActivity {
- static final int waitSlice = 200;
- protected MobileLedgerProfile mProfile;
- protected void setupProfileColors() {
- Colors.setupTheme(this, mProfile);
+ public static final String TAG = "prf-thm-act";
+ protected static final String PARAM_PROFILE_ID = "profile-id";
+ protected static final String PARAM_THEME = "theme";
+ protected Profile mProfile;
+ private boolean themeSetUp = false;
+ private boolean mIgnoreProfileChange;
+ private int mThemeHue;
+ protected void setupProfileColors(int newHue) {
+ if (themeSetUp && newHue == mThemeHue) {
+ Logger.debug(TAG,
+ String.format(Locale.ROOT, "Ignore request to set theme to the same value (%d)",
+ newHue));
+ return;
+ }
+
+ Logger.debug(TAG,
+ String.format(Locale.ROOT, "Changing theme from %d to %d", mThemeHue, newHue));
+
+ mThemeHue = newHue;
+ Colors.setupTheme(this, mThemeHue);
+
+ if (themeSetUp) {
+ Logger.debug(TAG, "setupProfileColors(): theme already set up, recreating activity");
+ this.recreate();
+ }
+ themeSetUp = true;
+
+ Colors.profileThemeId = mThemeHue;
}
@Override
protected void onStart() {
}
protected void onCreate(@Nullable Bundle savedInstanceState) {
initProfile();
- super.onCreate(savedInstanceState);
- Data.profile.observe(this, mobileLedgerProfile -> {
- mProfile = mobileLedgerProfile;
- setupProfileColors();
+
+ Data.observeProfile(this, profile -> {
+ if (profile == null) {
+ Logger.debug(TAG, "No current profile, leaving");
+ return;
+ }
+
+ mProfile = profile;
+ int hue = profile.getTheme();
+
+ if (hue != mThemeHue) {
+ storeProfilePref(profile);
+ setupProfileColors(hue);
+ }
});
+
+ super.onCreate(savedInstanceState);
+ }
+ public void storeProfilePref(Profile profile) {
+ App.storeStartupProfileAndTheme(profile.getId(), profile.getTheme());
}
protected void initProfile() {
- mProfile = Data.profile.getValue();
- if (mProfile == null) {
- MLDB.getOption(MLDB.OPT_PROFILE_UUID, null, new GetOptCallback() {
- @Override
- protected void onResult(String profileUUID) {
- MobileLedgerProfile startupProfile;
-
-
- startupProfile = Data.getProfile(profileUUID);
- Data.setCurrentProfile(startupProfile);
- }
- });
+ long profileId = App.getStartupProfile();
+ int hue = App.getStartupTheme();
+ if (profileId == -1)
+ mThemeHue = Colors.DEFAULT_HUE_DEG;
+
+ setupProfileColors(hue);
+
+ initProfile(profileId);
+ }
+ protected void initProfile(long profileId) {
+ BaseDAO.runAsync(() -> initProfileSync(profileId));
+ }
+ private void initProfileSync(long profileId) {
+ ProfileDAO dao = DB.get()
+ .getProfileDAO();
+ Profile profile = dao.getByIdSync(profileId);
+
+ if (profile == null) {
+ Logger.debug(TAG, String.format(Locale.ROOT, "Profile %d not found. Trying any other",
+ profileId));
+
+ profile = dao.getAnySync();
}
+
+ if (profile == null)
+ Logger.debug(TAG, "No profile could be loaded");
+ else
+ Logger.debug(TAG, String.format(Locale.ROOT, "Profile %d loaded. posting", profileId));
+ Data.postCurrentProfile(profile);
}
}