Вызов DialogFragment во фрагменте Kotlin - PullRequest
0 голосов
/ 26 мая 2019

Я пытаюсь вызвать свой диалоговый фрагмент в свой логин-фрагмент и показать диалоговое окно с предупреждением, метод show говорит, что:

Ни одна из следующих функций не может быть вызвана с предоставленными аргументами.show (FragmentManager !, String!) определено в org.greenstand.android.TreeTracker.fragments.CustomDialogFragment show (FragmentTransaction !, String!) определено в org.greenstand.android.TreeTracker.fragments.CustomDialogFragment

val newFragment = CustomDialogFragment.newInstance("pass content here")

val fm = fragmentManager
newFragment.show(fm, "look")

Вот мой код CustomDialogFragment:

import android.app.Activity
import android.content.Intent
import android.content.pm.PackageManager
import android.os.Bundle
import android.view.LayoutInflater
import android.view.View
import android.view.ViewGroup
import android.widget.Toast
import androidx.fragment.app.Fragment
import androidx.lifecycle.Observer
import kotlinx.android.synthetic.main.activity_main.*
import kotlinx.android.synthetic.main.fragment_login.*
import kotlinx.coroutines.Dispatchers
import kotlinx.coroutines.GlobalScope
import kotlinx.coroutines.launch
import kotlinx.coroutines.withContext
import org.greenstand.android.TreeTracker.R
import org.greenstand.android.TreeTracker.application.Permissions
import org.greenstand.android.TreeTracker.utilities.*
import org.greenstand.android.TreeTracker.viewmodels.LoginViewModel
import org.koin.android.viewmodel.ext.android.viewModel
import timber.log.Timber
class CustomDialogFragment : DialogFragment()
{
    private var content: String? = null

    override fun onCreate(savedInstanceState: Bundle?)
    {
        super.onCreate(savedInstanceState)
        content = arguments!!.getString("content")

        val style = DialogFragment.STYLE_NO_FRAME
        val theme = R.style.DialogTheme
        setStyle(style, theme)
    }


    override fun onAttach(context: Context) {
        super.onAttach(context)
    }

    override fun onCreateView(inflater: LayoutInflater, container: ViewGroup, savedInstanceState: Bundle): View
    {
        val view = inflater!!.inflate(R.layout.layout_dialog, container, false)

        val btnAccept = view.findViewById<View>(R.id.buttonAccept) as Button

        val textViewContent = view.findViewById<View>(R.id.textViewContent) as TextView
        textViewContent.text = content;

        btnAccept.setOnClickListener{
            dismiss();
        }

        return view;
    }

    companion object
    {
        fun newInstance(content: String) : CustomDialogFragment
        {
            val f = CustomDialogFragment()

            val args = Bundle()
            args.putString("content", content)
            f.arguments = args

            return f
        }
    }

}

Может кто-нибудь указать, что именно мне нужно передать в метод show?Любая помощь приветствуется, спасибо:)

Ответы [ 3 ]

1 голос
/ 27 мая 2019

[ОБНОВЛЕНИЕ] Проблема в том, что метод может получить FragmentManager, но это должно быть не спасибо, взгляните на ошибку и не спасибо, символ Котлина

FragmentManager!

Так что вы можете сделать

fm?.let {newFragment.show(fm, "your tag")}

Пожалуйста, смотрите комментарии в ответе Нушада Хасана

Вы передаете FragmentManager методу, ему нужны FragmentTransaction и a String в виде тега:

val transaction = supportFragmentManager.beginTransaction()
newFragment.show(transaction, "SOME_TAG")

Пара предложений:

Вы можете сделать DialogFragment больше kotliny , используя стандартные функции Kotlin

companion object {

        private const val KEY = "param1"

        @JvmStatic
        fun newInstance(param1: String) =
            ExampleDialogFragment().apply {
                arguments = Bundle().apply {
                    putString(KEY, param1)
                }
            }
    }

Хороший пример можно получить, создав Fragment с помощью мастера Android Studio и проверив параметр фабричного метода.

Кроме того, поскольку этот тег предназначен для DialogFragment васможет сделать его общедоступной константой:

 companion object {
        const val TAG = "TAG"
 }

И, возможно, вы захотите дважды проверить, присутствует ли фрагмент диалога, и удалить его, чтобы фактически работать как свежий диалог

        val transaction = supportFragmentManager.beginTransaction()
        val previous = supportFragmentManager.findFragmentByTag(ExampleDialogFragment.TAG)
        if (previous != null) {
            transaction.remove(previous)
        }
        transaction.addToBackStack(null)

        val dialogFragment = ExampleDialogFragment.newInstance("parameter")
        dialogFragment.show(transaction, ExampleDialogFragment.TAG)
0 голосов
/ 27 мая 2019

Я не вижу DialogFragment импорта в вашем классе customDialog().На самом деле импорт фрагментов есть на line no: 9.Вы уверены, что расширяете от правильного DialogFragment?

0 голосов
/ 26 мая 2019

Убедитесь, что ваша активность является дочерней по отношению к https://developer.android.com/reference/androidx/fragment/app/FragmentActivity.html,. Например, вы можете использовать https://developer.android.com/reference/androidx/appcompat/app/AppCompatActivity в качестве родительской операции.

Затем, чтобы получить фрагментManager, используйте getSupportFragment()метод или просто val fm = supportFragmentManager

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