Search code examples
androidandroid-studiokotlinandroid-fragmentsparcelable

Kotlin AndroidStudio Type Mismatch


I get some error in my code, Type mismatch. Required : FavoriteData, Found : FavoriteData? for the lines dataFavorite = activity!!.intent.getParcelableExtra(EXTRA_NOTE) as FavoriteData and Type mismatch. Required : UserData, Found : UserData? for the lines dataUser = activity!!.intent.getParcelableExtra(EXTRA_DATA) as UserData.

Here is my class :

class FollowersFragment : Fragment() {

private var listUser: ArrayList<UserData> = ArrayList()
private lateinit var adapter: FollowersAdapter
private var favorite: FavoriteData? = null
private lateinit var dataFavorite: FavoriteData
private lateinit var dataUser: UserData
private lateinit var progressBarFollowers: ProgressBar
private lateinit var recyclerViewFollowers: RecyclerView

companion object {
    private val TAG = FollowersFragment::class.java.simpleName
    const val EXTRA_DATA = "extra_data"
    const val EXTRA_NOTE = "extra_note"
}

override fun onCreateView(
    inflater: LayoutInflater, container: ViewGroup?,
    savedInstanceState: Bundle?
): View? {
    // Inflate the layout for this fragment
    return inflater.inflate(R.layout.fragment_followers, container, false)
}

override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
    super.onViewCreated(view, savedInstanceState)
    progressBarFollowers = getView()!!.findViewById(R.id.progressBarFollowers)
    recyclerViewFollowers = getView()!!.findViewById(R.id.recyclerViewFollowers)

    adapter = FollowersAdapter(listUser)
    listUser.clear()

    favorite = activity!!.intent.getParcelableExtra(UserDetailActivity.EXTRA_NOTE)
    if (favorite != null) {
        dataFavorite = activity!!.intent.getParcelableExtra(EXTRA_NOTE) as FavoriteData
        showUserFollowers(dataFavorite.username.toString())
    } else {
        dataUser = activity!!.intent.getParcelableExtra(EXTRA_DATA) as UserData
        showUserFollowers(dataUser.username.toString())
    }

}

private fun showUserFollowers(id: String) {
    progressBarFollowers.visibility = View.VISIBLE
    val client = AsyncHttpClient()
    client.addHeader("User-Agent", "request")
    client.addHeader("Authorization", "token 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")
    val url = "https://api.github.com/users/$id/followers"
    client.get(url, object : AsyncHttpResponseHandler(){
        override fun onSuccess(
            statusCode: Int,
            headers: Array<Header>,
            responseBody: ByteArray
        ) {
            progressBarFollowers.visibility = View.INVISIBLE
            val result = String(responseBody)
            Log.d(TAG, result)
            try {
                val jsonArray = JSONArray(result)
                for (i in 0 until jsonArray.length()) {
                    val jsonObject = jsonArray.getJSONObject(i)
                    val username: String = jsonObject.getString("login")
                    showUserDetail(username)
                }
            } catch (e: Exception) {
                Toast.makeText(activity, e.message, Toast.LENGTH_SHORT)
                        .show()
                e.printStackTrace()
            }
        }

        override fun onFailure(
            statusCode: Int,
            headers: Array<Header>,
            responseBody: ByteArray,
            error: Throwable
        ) {
            progressBarFollowers.visibility = View.INVISIBLE
            val errorMessage = when (statusCode) {
                401 -> "$statusCode : Bad Request"
                403 -> "$statusCode : Forbidden"
                404 -> "$statusCode : Not Found"
                else -> "$statusCode : ${error.message}"
            }
            Toast.makeText(activity, errorMessage, Toast.LENGTH_LONG)
                    .show()
        }

    })
}

private fun showUserDetail(id: String){
    progressBarFollowers.visibility = View.VISIBLE
    val client = AsyncHttpClient()
    client.addHeader("User-Agent", "request")
    client.addHeader("Authorization", "token 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")
    val url = "https://api.github.com/users/$id"
    client.get(url, object : AsyncHttpResponseHandler(){
        override fun onSuccess(statusCode: Int, headers: Array<Header>, responseBody: ByteArray) {
            progressBarFollowers.visibility = View.INVISIBLE
            val result = String(responseBody)
            Log.d(TAG, result)
            try {
                val jsonObject = JSONObject(result)
                val username: String = jsonObject.getString("login").toString()
                val name: String = jsonObject.getString("name").toString()
                val avatar: String = jsonObject.getString("avatar_url").toString()
                val company: String = jsonObject.getString("company").toString()
                val location: String = jsonObject.getString("location").toString()
                val repository: String? = jsonObject.getString("public_repos")
                val followers: String? = jsonObject.getString("followers")
                val following: String? = jsonObject.getString("following")
                listUser.add(
                        UserData(
                                username,
                                name,
                                avatar,
                                company,
                                location,
                                repository,
                                followers,
                                following
                        )
                )
                showRecyclerList()
            } catch (e: Exception) {
                Toast.makeText(activity, e.message, Toast.LENGTH_SHORT)
                        .show()
                e.printStackTrace()
            }
        }

        override fun onFailure(statusCode: Int, headers: Array<Header>, responseBody: ByteArray, error: Throwable) {
            progressBarFollowers.visibility = View.INVISIBLE
            val errorMessage = when (statusCode) {
                401 -> "$statusCode : Bad Request"
                403 -> "$statusCode : Forbidden"
                404 -> "$statusCode : Not Found"
                else -> "$statusCode : ${error.message}"
            }
            Toast.makeText(activity, errorMessage, Toast.LENGTH_LONG)
                    .show()
        }

    })

}

private fun showRecyclerList() {
    recyclerViewFollowers.layoutManager = LinearLayoutManager(activity)
    val listAdapter = FollowersAdapter(followerFilter)
    recyclerViewFollowers.adapter = adapter

    listAdapter.setOnItemClickCallback(object : FollowersAdapter.OnItemClickCallback{
        override fun onItemClicked(UserData: UserData) {

        }
    })
}

}

I dont understand how to fix this, thanks for your attention :)


Solution

  • I'm just taking one example out of your question:

    You have declared:

    private lateinit var dataFavorite: FavoriteData
    

    which means that FavoriteData can't be assined a null value.

    So when you fetch a data from parcelable it can be null for some reason so it gives you a type FavoriteData? which is nullable that can't be assigned directly.

    There are 2 ways you can solve this

    1.) Add Non-Null assertion (!!) which will throw NullPointter if the data is NULL

    dataFavorite = (intent.getParcelableExtra(YOUR_KEY) as FavoriteData?)!!
    

    2.) Make your variable Nullable

    private var dataFavorite: FavoriteData? = null
    

    Assign as

    dataFavorite = intent.getParcelableExtra("") as FavoriteData?
    

    Choose according to your use case and do the same for others as well