Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -2,18 +2,16 @@ package com.jeeldobariya.passcodes.flags

import android.content.Context
import androidx.core.content.edit
import com.jeeldobariya.passcodes.utils.Constant

class FeatureFlagManager private constructor(context: Context) {
private val prefs = context.getSharedPreferences(PREFS_NAME, Context.MODE_PRIVATE)
private val prefs = context.getSharedPreferences(Constant.FEATURE_FLAGS_PREFS_NAME, Context.MODE_PRIVATE)

var latestFeaturesEnabled: Boolean
get() = prefs.getBoolean(KEY_LATEST_FEATURES, false)
set(value) { prefs.edit { putBoolean(KEY_LATEST_FEATURES, value) } }
get() = prefs.getBoolean(Constant.LATEST_FEATURES_KEY, false)
set(value) { prefs.edit { putBoolean(Constant.LATEST_FEATURES_KEY, value) } }

companion object {
private const val PREFS_NAME = "feature_flags"
private const val KEY_LATEST_FEATURES = "latest_features_enabled"

@Volatile private var INSTANCE: FeatureFlagManager? = null

fun get(context: Context): FeatureFlagManager {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -6,12 +6,14 @@ import android.content.Intent
import android.os.Bundle
import androidx.appcompat.app.AppCompatActivity
import androidx.core.net.toUri
import com.jeeldobariya.passcodes.utils.CommonUtils

class AboutUsActivity : AppCompatActivity() {

private lateinit var binding: ActivityAboutUsBinding

override fun onCreate(savedInstanceState: Bundle?) {
CommonUtils.updateCurrTheme(this)
super.onCreate(savedInstanceState)
binding = ActivityAboutUsBinding.inflate(layoutInflater)
setContentView(binding.root)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -5,12 +5,14 @@ import android.os.Bundle
import androidx.appcompat.app.AppCompatActivity
import com.google.android.gms.oss.licenses.OssLicensesMenuActivity
import com.jeeldobariya.passcodes.databinding.ActivityLicenseBinding
import com.jeeldobariya.passcodes.utils.CommonUtils
import java.io.BufferedReader
import java.io.InputStreamReader

class LicenseActivity : AppCompatActivity() {

override fun onCreate(savedInstanceState: Bundle?) {
CommonUtils.updateCurrTheme(this)
super.onCreate(savedInstanceState)
var binding = ActivityLicenseBinding.inflate(layoutInflater)
setContentView(binding.root)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@ import com.jeeldobariya.passcodes.R
import com.jeeldobariya.passcodes.database.Password
import com.jeeldobariya.passcodes.databinding.ActivityLoadPasswordBinding
import com.jeeldobariya.passcodes.ui.adapter.PasswordAdapter
import com.jeeldobariya.passcodes.utils.CommonUtils
import com.jeeldobariya.passcodes.utils.Controller
import com.jeeldobariya.passcodes.utils.DatabaseOperationException
import kotlinx.coroutines.Dispatchers
Expand All @@ -25,10 +26,7 @@ class LoadPasswordActivity : AppCompatActivity() {
private lateinit var controller: Controller

override fun onCreate(savedInstanceState: Bundle?) {
val sharedPrefs = getSharedPreferences(SettingsActivity.THEME_PREFS_NAME, Context.MODE_PRIVATE)
val savedThemeStyle = sharedPrefs.getInt(SettingsActivity.THEME_KEY, R.style.PasscodesTheme_Default)
setTheme(savedThemeStyle)

CommonUtils.updateCurrTheme(this)
super.onCreate(savedInstanceState)
binding = ActivityLoadPasswordBinding.inflate(layoutInflater)
setContentView(binding.root)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,8 @@ import android.view.LayoutInflater

import com.jeeldobariya.passcodes.R
import com.jeeldobariya.passcodes.databinding.ActivityMainBinding
import com.jeeldobariya.passcodes.utils.CommonUtils

// import com.jeeldobariya.passcodes.utils.Permissions

class MainActivity : AppCompatActivity() {
Expand All @@ -18,10 +20,7 @@ class MainActivity : AppCompatActivity() {
private lateinit var binding: ActivityMainBinding

override fun onCreate(savedInstanceState: Bundle?) {
val sharedPrefs = getSharedPreferences(SettingsActivity.THEME_PREFS_NAME, Context.MODE_PRIVATE)
val savedThemeStyle = sharedPrefs.getInt(SettingsActivity.THEME_KEY, R.style.PasscodesTheme_Default)
setTheme(savedThemeStyle)

CommonUtils.updateCurrTheme(this)
super.onCreate(savedInstanceState)
binding = ActivityMainBinding.inflate(layoutInflater)
setContentView(binding.root)
Expand Down
Original file line number Diff line number Diff line change
@@ -1,27 +1,32 @@
package com.jeeldobariya.passcodes.ui

import android.content.Intent
import android.view.View.GONE
import android.os.Bundle
import android.widget.Toast
import androidx.appcompat.app.AppCompatActivity
import androidx.core.view.WindowCompat
import com.jeeldobariya.passcodes.R
import com.jeeldobariya.passcodes.databinding.ActivityPasswordManagerBinding
import com.jeeldobariya.passcodes.flags.FeatureFlagManager
import com.jeeldobariya.passcodes.utils.CommonUtils


class PasswordManagerActivity : AppCompatActivity() {

private lateinit var binding: ActivityPasswordManagerBinding // Use late init for binding

override fun onCreate(savedInstanceState: Bundle?) {
val sharedPrefs = getSharedPreferences(SettingsActivity.THEME_PREFS_NAME, MODE_PRIVATE)
val savedThemeStyle = sharedPrefs.getInt(SettingsActivity.THEME_KEY, R.style.PasscodesTheme_Default)
setTheme(savedThemeStyle)

CommonUtils.updateCurrTheme(this)
super.onCreate(savedInstanceState)
binding = ActivityPasswordManagerBinding.inflate(layoutInflater)
setContentView(binding.root)

if (!FeatureFlagManager.get(this).latestFeaturesEnabled) {
binding.importPasswordBtn.visibility = GONE
binding.exportPasswordBtn.visibility = GONE
}

// Add event onclick listener
addOnClickListenerOnButton(binding)

Expand Down
Original file line number Diff line number Diff line change
@@ -1,13 +1,13 @@
package com.jeeldobariya.passcodes.ui

import android.content.Context
import android.os.Bundle
import android.widget.Toast
import androidx.appcompat.app.AppCompatActivity
import androidx.core.view.WindowCompat
import androidx.lifecycle.lifecycleScope
import com.jeeldobariya.passcodes.R
import com.jeeldobariya.passcodes.databinding.ActivitySavePasswordBinding
import com.jeeldobariya.passcodes.utils.CommonUtils
import com.jeeldobariya.passcodes.utils.Controller
import com.jeeldobariya.passcodes.utils.DatabaseOperationException
import com.jeeldobariya.passcodes.utils.InvalidInputException
Expand All @@ -21,10 +21,7 @@ class SavePasswordActivity : AppCompatActivity() {
private lateinit var binding: ActivitySavePasswordBinding

override fun onCreate(savedInstanceState: Bundle?) {
val sharedPrefs = getSharedPreferences(SettingsActivity.THEME_PREFS_NAME, Context.MODE_PRIVATE)
val savedThemeStyle = sharedPrefs.getInt(SettingsActivity.THEME_KEY, R.style.PasscodesTheme_Default)
setTheme(savedThemeStyle)

CommonUtils.updateCurrTheme(this)
super.onCreate(savedInstanceState)
binding = ActivitySavePasswordBinding.inflate(layoutInflater)
setContentView(binding.root)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -15,15 +15,12 @@ import com.jeeldobariya.passcodes.R
import com.jeeldobariya.passcodes.databinding.ActivitySettingsBinding
import com.jeeldobariya.passcodes.flags.FeatureFlagManager
import androidx.core.content.edit
import com.jeeldobariya.passcodes.utils.CommonUtils
import com.jeeldobariya.passcodes.utils.Constant

class SettingsActivity : AppCompatActivity() {

private lateinit var binding: ActivitySettingsBinding

companion object {
const val THEME_PREFS_NAME = "theme_prefs"
const val THEME_KEY = "selected_theme"
}


// List of available themes to cycle through
Expand All @@ -36,10 +33,7 @@ class SettingsActivity : AppCompatActivity() {
)

override fun onCreate(savedInstanceState: Bundle?) {
val sharedPrefs = getSharedPreferences(SettingsActivity.THEME_PREFS_NAME, Context.MODE_PRIVATE)
val savedThemeStyle = sharedPrefs.getInt(SettingsActivity.THEME_KEY, R.style.PasscodesTheme_Default)
setTheme(savedThemeStyle)

CommonUtils.updateCurrTheme(this)
super.onCreate(savedInstanceState)
binding = ActivitySettingsBinding.inflate(layoutInflater)
setContentView(binding.root)
Expand Down Expand Up @@ -86,15 +80,15 @@ class SettingsActivity : AppCompatActivity() {
}

binding.toggleThemeBtn.setOnClickListener {
val sharedPrefs = getSharedPreferences(SettingsActivity.THEME_PREFS_NAME, Context.MODE_PRIVATE)
val currentThemeStyle = sharedPrefs.getInt(SettingsActivity.THEME_KEY, R.style.PasscodesTheme_Default)
val sharedPrefs = getSharedPreferences(Constant.APP_PREFS_NAME, Context.MODE_PRIVATE)
val currentThemeStyle = sharedPrefs.getInt(Constant.THEME_KEY, R.style.PasscodesTheme_Default)

val currentIndex = THEMES.indexOf(currentThemeStyle)
val nextIndex = (currentIndex + 1) % THEMES.size
val newThemeStyle = THEMES[nextIndex]

// Save the new theme and restart the application to apply it
sharedPrefs.edit { putInt(THEME_KEY, newThemeStyle) }
sharedPrefs.edit { putInt(Constant.THEME_KEY, newThemeStyle) }
recreate()

Toast.makeText(this@SettingsActivity, getString(R.string.restart_app_require), Toast.LENGTH_SHORT).show()
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@ import androidx.lifecycle.lifecycleScope
import com.jeeldobariya.passcodes.R
import com.jeeldobariya.passcodes.database.Password
import com.jeeldobariya.passcodes.databinding.ActivityUpdatePasswordBinding
import com.jeeldobariya.passcodes.utils.CommonUtils
import com.jeeldobariya.passcodes.utils.Controller
import com.jeeldobariya.passcodes.utils.DatabaseOperationException
import com.jeeldobariya.passcodes.utils.InvalidInputException
Expand All @@ -29,10 +30,7 @@ class UpdatePasswordActivity : AppCompatActivity() {
private lateinit var binding: ActivityUpdatePasswordBinding

override fun onCreate(savedInstanceState: Bundle?) {
val sharedPrefs = getSharedPreferences(SettingsActivity.THEME_PREFS_NAME, Context.MODE_PRIVATE)
val savedThemeStyle = sharedPrefs.getInt(SettingsActivity.THEME_KEY, R.style.PasscodesTheme_Default)
setTheme(savedThemeStyle)

CommonUtils.updateCurrTheme(this)
super.onCreate(savedInstanceState)
binding = ActivityUpdatePasswordBinding.inflate(layoutInflater)
setContentView(binding.root)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@ import com.jeeldobariya.passcodes.R
import com.jeeldobariya.passcodes.database.Password
import com.jeeldobariya.passcodes.databinding.ActivityViewPasswordBinding
import com.jeeldobariya.passcodes.flags.FeatureFlagManager
import com.jeeldobariya.passcodes.utils.CommonUtils
import com.jeeldobariya.passcodes.utils.Controller
import com.jeeldobariya.passcodes.utils.DatabaseOperationException
import com.jeeldobariya.passcodes.utils.DateTimeUtils
Expand All @@ -33,10 +34,7 @@ class ViewPasswordActivity : AppCompatActivity() {
private lateinit var passwordEntity: Password

override fun onCreate(savedInstanceState: Bundle?) {
val sharedPrefs = getSharedPreferences(SettingsActivity.THEME_PREFS_NAME, Context.MODE_PRIVATE)
val savedThemeStyle = sharedPrefs.getInt(SettingsActivity.THEME_KEY, R.style.PasscodesTheme_Default)
setTheme(savedThemeStyle)

CommonUtils.updateCurrTheme(this)
super.onCreate(savedInstanceState)
binding = ActivityViewPasswordBinding.inflate(layoutInflater)
setContentView(binding.root)
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
package com.jeeldobariya.passcodes.utils

import android.content.Context
import android.content.Context.MODE_PRIVATE
import com.jeeldobariya.passcodes.R

class CommonUtils {
companion object {
fun getCurrTheme(context: Context): Int {
val sharedPrefs = context.getSharedPreferences(Constant.APP_PREFS_NAME, MODE_PRIVATE)
val savedThemeStyle = sharedPrefs.getInt(Constant.THEME_KEY, R.style.PasscodesTheme_Default)
return savedThemeStyle
}

fun updateCurrTheme(context: Context) {
context.setTheme(getCurrTheme(context.applicationContext))
}
}
}
Original file line number Diff line number Diff line change
@@ -1,9 +1,18 @@
package com.jeeldobariya.passcodes.utils

object Constant {
// Url Constants
const val REPO_URL = "https://github.com/JeelDobariya38/Passcodes"
const val REPORT_BUG_URL = "https://github.com/JeelDobariya38/password-manager/issues/new?template=bug-report.md"
const val RELEASE_NOTE_URL = "https://github.com/JeelDobariya38/Passcodes/blob/main/docs/release-notes.md"
const val SECURITY_GUIDE_URL = "https://github.com/JeelDobariya38/Passcodes/blob/main/docs/security-guide.md"
const val TELEGRAM_COMMUNITY_URL = "https://t.me/passcodescommunity"


// Shared Preferences Constants
const val APP_PREFS_NAME = "app_prefs"
const val THEME_KEY = "selected_theme"

const val FEATURE_FLAGS_PREFS_NAME = "feature_flags_prefs"
const val LATEST_FEATURES_KEY = "latest_features_enabled"
}
2 changes: 2 additions & 0 deletions app/src/main/res/layout/activity_main.xml
Original file line number Diff line number Diff line change
Expand Up @@ -47,13 +47,15 @@

<com.google.android.material.button.MaterialButton
android:id="@+id/setting_btn"
style="@style/Widget.Material3.Button.OutlinedButton"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="@string/setting_button_text"
android:textSize="14dp" />

<com.google.android.material.button.MaterialButton
android:id="@+id/about_us_btn"
style="@style/Widget.Material3.Button.OutlinedButton"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="@string/about_us_button_text"
Expand Down
4 changes: 2 additions & 2 deletions app/src/main/res/layout/activity_password_manager.xml
Original file line number Diff line number Diff line change
Expand Up @@ -38,16 +38,16 @@
android:textSize="14dp" />

<com.google.android.material.button.MaterialButton
android:enabled="false"
android:id="@+id/import_password_btn"
style="@style/Widget.Material3.Button.OutlinedButton"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="@string/import_password_button_text"
android:textSize="14dp" />

<com.google.android.material.button.MaterialButton
android:enabled="false"
android:id="@+id/export_password_btn"
style="@style/Widget.Material3.Button.OutlinedButton"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="@string/export_password_button_text"
Expand Down
14 changes: 7 additions & 7 deletions app/src/main/res/values/strings.xml
Original file line number Diff line number Diff line change
Expand Up @@ -21,12 +21,12 @@
<string name="hint_username">Username</string>
<string name="hint_password">Password</string>
<string name="hint_notes">Notes</string>
<string name="copy_success" translatable="false">Copied Successfully</string>
<string name="copy_success">Copied Successfully</string>
<string name="placeholder_domain_field">e.g. Google, Instagram, WhatsApp, etc.</string>
<string name="placeholder_username_field">e.g. Liam15, Noha, Olivia, Ava_25, etc.</string>
<string name="placeholder_password_field">e.g. 12345, abc123xyz, qwerty, etc.</string>
<string name="password_manager_button_text">Password Manager</string>
<string name="copy_password_button_text" translatable="false">Copy Password</string>
<string name="copy_password_button_text">Copy Password</string>
<string name="save_password_button_text">Save Password</string>
<string name="load_password_button_text">Load Password</string>
<string name="update_password_button_text">Update Password</string>
Expand All @@ -39,16 +39,16 @@
<string name="label_language_setting">Language: </string>
<string name="label_contributor">Contributor: </string>
<string name="label_theme_setting">Themes: </string>
<string name="latest_feature" translatable="false">Preview Features: </string>
<string name="latest_feature">Preview Features: </string>
<string name="about_us_button_text">About Us</string>

<!-- Hyper Text Link Buttons Text -->
<string name="view_report_bug_text">Report Bug</string>
<string name="view_security_guidelines_button_text">Security Guidelines</string>
<string name="view_release_notes_button_text">View Release Notes</string>
<string name="view_license_button_text">View License</string>
<string name="view_third_party_license_text" translatable="false">Third Party License</string>
<string name="view_telegram_community_text" translatable="false">Passcodes Telegram Community</string>
<string name="view_third_party_license_text">Third Party License</string>
<string name="view_telegram_community_text">Passcodes Telegram Community</string>

<!-- Headline of Activity -->
<string name="textview_passwordmanager_headline">Password Manager</string>
Expand Down Expand Up @@ -86,11 +86,11 @@
<string name="error_invalid_password_id">Something Went Wrong: Invalid ID!!</string>

<!-- Alert Dialog Message -->
<string name="copy_password_dialog_title" translatable="false">Copy to Clipboard?</string>
<string name="copy_password_dialog_title">Copy to Clipboard?</string>
<string name="update_password_dialog_title">Update password?</string>
<string name="delete_password_dialog_title">Delete password?</string>
<string name="irreversible_dialog_desc">This action cannot be undone.</string>
<string name="danger_copy_to_clipboard_desc" translatable="false">Copying sensitive data like passwords to clipboard is not so good for security!!!</string>
<string name="danger_copy_to_clipboard_desc">Copying sensitive data like passwords to clipboard is not so good for security!!!</string>
<string name="confirm_dialog_button_text">Confirm</string>
<string name="discard_dialog_button_text">Discard</string>
</resources>
4 changes: 3 additions & 1 deletion lint.xml
Original file line number Diff line number Diff line change
Expand Up @@ -3,4 +3,6 @@
<issue id="Range">
<ignore path="**/Controller.java" />
</issue>
</lint>

<issue id="MissingTranslation" severity="warning" />
</lint>