Skip to content
Open
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
13 changes: 10 additions & 3 deletions app/src/main/java/me/tangobee/weathernaut/MainActivity.kt
Original file line number Diff line number Diff line change
@@ -1,8 +1,8 @@
package me.tangobee.weathernaut

import android.content.Intent
import android.content.res.Configuration
import android.os.Bundle
import android.util.Log
import android.widget.Toast
import androidx.appcompat.app.AppCompatActivity
import androidx.core.splashscreen.SplashScreen.Companion.installSplashScreen
Expand All @@ -22,6 +22,7 @@ import me.tangobee.weathernaut.utils.WeatherHelper
import me.tangobee.weathernaut.viewmodels.WeatherViewModel
import me.tangobee.weathernaut.viewmodels.WeatherViewModelFactory
import java.net.UnknownHostException
import java.util.Locale
import kotlin.system.exitProcess

class MainActivity : AppCompatActivity() {
Expand Down Expand Up @@ -59,11 +60,12 @@ class MainActivity : AppCompatActivity() {

val settingsModel = SharedPreferencesHelper(this).getSettings()
if(settingsModel?.isMusicOn != false) {
val startMusicIntent = Intent(this, WeatherMusicService::class.java)
var startMusicIntent = Intent(this, WeatherMusicService::class.java)
startService(startMusicIntent)
}

fetchData()
setLanguage()
splashScreen.setKeepOnScreenCondition { (weatherViewModel.weatherLiveData.value == null) }

setContentView(binding.root)
Expand Down Expand Up @@ -96,7 +98,12 @@ class MainActivity : AppCompatActivity() {
}
}
}

private fun setLanguage(){
Locale.setDefault(Locale(sharedPreferencesHelper.getSettings()?.Language ?:""))
val config = Configuration()
config.locale = Locale(sharedPreferencesHelper.getSettings()?.Language ?:"")
resources.updateConfiguration(config, resources.displayMetrics)
}
private fun createLocalDB(weatherData: WeatherData) {
val currentSettings = sharedPreferencesHelper.getSettings()
if (currentSettings != null) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,5 +4,7 @@ data class SettingsModel(
var tempUnit: String = "celsius",
var windSpeedUnit: String = "kmh",
var pressureUnit: String = "hpa",
var isMusicOn: Boolean = true
var isMusicOn: Boolean = true,
var Language: String= "",
var LanguageName: String=""
)
53 changes: 52 additions & 1 deletion app/src/main/java/me/tangobee/weathernaut/ui/SettingsFragment.kt
Original file line number Diff line number Diff line change
@@ -1,9 +1,9 @@
package me.tangobee.weathernaut.ui

import android.content.Intent
import android.content.res.Configuration
import android.net.Uri
import android.os.Bundle
import androidx.fragment.app.Fragment
import android.view.LayoutInflater
import android.view.MenuItem
import android.view.View
Expand All @@ -12,6 +12,7 @@ import android.widget.ScrollView
import android.widget.Toast
import androidx.appcompat.widget.PopupMenu
import androidx.core.content.ContextCompat
import androidx.fragment.app.Fragment
import androidx.fragment.app.activityViewModels
import me.tangobee.weathernaut.R
import me.tangobee.weathernaut.constants.UnitsMapper
Expand All @@ -22,6 +23,8 @@ import me.tangobee.weathernaut.services.WeatherMusicService
import me.tangobee.weathernaut.utils.SharedPreferencesHelper
import me.tangobee.weathernaut.utils.WeatherHelper
import me.tangobee.weathernaut.viewmodels.WeatherViewModel
import java.util.Locale


class SettingsFragment : Fragment() {

Expand Down Expand Up @@ -68,6 +71,7 @@ class SettingsFragment : Fragment() {
binding.temperatureUnit.setOnClickListener {showTemperatureUnitPopup(binding.temperatureSpinner)}
binding.windSpeedUnit.setOnClickListener {showWindSpeedUnitPopup(binding.windSpeedSpinner)}
binding.atmosphericPressureUnit.setOnClickListener {showAtmosphericPressureUnitPopup(binding.atmosphericPressureSpinner)}
binding.weatherLanguageWrapper.setOnClickListener{showLanguagePopup(binding.languageSpinner)}

binding.backButton.setOnClickListener {
requireActivity().onBackPressedDispatcher.onBackPressed()
Expand Down Expand Up @@ -111,6 +115,7 @@ class SettingsFragment : Fragment() {
binding.atmosphericPressureSpinner.text = UnitsMapper.getShorthandUnit(settingsModel.pressureUnit)

binding.weatherMusicSwitch.setChecked(settingsModel.isMusicOn)
binding.languageSpinner.text=settingsModel.LanguageName
}

private fun weatherMusicToggle(musicFlag: Boolean) {
Expand Down Expand Up @@ -248,6 +253,52 @@ class SettingsFragment : Fragment() {
popup.show()
}

//language update
private fun showLanguagePopup(view: View) {
val popup = PopupMenu(requireContext(), view)
popup.inflate(R.menu.language_menu)
popup.setOnMenuItemClickListener { item: MenuItem? ->
when (item!!.itemId) {
R.id.english -> {
binding.languageSpinner.text = item.title
Locale.setDefault(Locale(""))
val config = Configuration()
config.locale = Locale("")
resources.updateConfiguration(config, resources.displayMetrics)
sharedPreferencesHelper.updateSettings {
it.Language = ""
it.LanguageName= item.title.toString()
it
}

val currentSettings = sharedPreferencesHelper.getSettings()
updateWeatherData(currentSettings)
}
R.id.hindi -> {
binding.languageSpinner.text = item.title
Locale.setDefault(Locale("hi"))
val config = Configuration()
config.locale = Locale("hi")
resources.updateConfiguration(config, resources.displayMetrics)

sharedPreferencesHelper.updateSettings {
it.Language = "hi"
it.LanguageName=item.title.toString()
it
}

val currentSettings = sharedPreferencesHelper.getSettings()
updateWeatherData(currentSettings)
}

}

true
}

popup.show()
}

private fun updateWeatherData(currentSettings: SettingsModel?) {
if(currentSettings != null) {
val weatherHelper = WeatherHelper(currentSettings, weatherData)
Expand Down
Loading