Почему мой наблюдатель всегда получает пустой список, если я анализирую все данные в процессе инициализации? - PullRequest
0 голосов
/ 04 ноября 2019

Я делаю маленькое Tasker для Android с kotlin и местом для хранения. Я разделил основное действие на несколько фрагментов, а затем создал ViewModel для каждого. Теперь в процессе инициализации мне нужна моя программа, чтобы проанализировать все задачи из базы данных, а затем создать несколько радиокнопок в ListFragment. Наблюдатель работает довольно хорошо, но переменная List<Task> всегда поставляется с пустым списком ... Наблюдатель работает хорошо, потому что Log.i("ListFragment", "List is empty!") существует. Так в чем же проблема?

Вот код:

class ListFragment : Fragment() {

    override fun onCreateView(
        inflater: LayoutInflater, container: ViewGroup?,
        savedInstanceState: Bundle?): View? {

        val binding: FragmentListBinding = DataBindingUtil.inflate(
            inflater, R.layout.fragment_list, container, false)

        val application = requireNotNull(this.activity).application

        val dataSource = TaskDatabase.getInstance(application).taskDatabaseDao

        val viewModelFactory = ListViewModelFactory(dataSource, application)

        val listViewModel =
            ViewModelProviders.of(this, viewModelFactory).get(ListViewModel::class.java)

        binding.listViewModel = listViewModel

        binding.setLifecycleOwner(this)

        binding.addButton.setOnClickListener {
            findNavController().navigate(R.id.action_listFragment_to_createTaskFragment)
        }

        listViewModel.tasks.observe(this, Observer {
            Log.i("ListFragment", "List is empty!")
            it?.forEach {
                Log.i("ListFragment", "tasks exist")
                val radioButton = RadioButton(context)
                radioButton.text = it.title
                radioButton.visibility = View.VISIBLE
                radioButton.setOnClickListener {
                    Toast.makeText(context, "Working", Toast.LENGTH_SHORT).show()
                }
            }
        })

        return binding.root
    }
}
class ListViewModel(
    val database: TaskDao,
    application: Application) : AndroidViewModel(application) {

    private val viewModelJob = Job()

    private val uiScope = CoroutineScope(Dispatchers.Main + viewModelJob)

    private val _tasks = MutableLiveData<List<Task>>()
    val tasks: LiveData<List<Task>>
        get() = _tasks

    init {
        initializeTasks()
    }

    private fun initializeTasks() {
        uiScope.launch {
            _tasks.value = getTasksFromDatabase()?.value
            Log.i("ListViewModel", "something")
        }
    }

    private suspend fun getTasksFromDatabase(): LiveData<List<Task>>? {
        return withContext(Dispatchers.IO) {
            database.getAllTasks()
        }
    }

    override fun onCleared() {
        super.onCleared()
        viewModelJob.cancel()
    }
}

Заранее спасибо за помощь!

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...