aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/ui/src/main/java/com/wireguard/android/widget/TvCardView.kt
blob: 9f7d70117433405e34cf1c277e7e8f4bee6341de (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
/*
 * Copyright © 2017-2023 WireGuard LLC. All Rights Reserved.
 * SPDX-License-Identifier: Apache-2.0
 */

package com.wireguard.android.widget

import android.content.Context
import android.util.AttributeSet
import android.view.View
import com.google.android.material.card.MaterialCardView
import com.wireguard.android.R

class TvCardView(context: Context?, attrs: AttributeSet?) : MaterialCardView(context, attrs) {
    var isUp: Boolean = false
        set(value) {
            field = value
            refreshDrawableState()
        }
    var isDeleting: Boolean = false
        set(value) {
            field = value
            refreshDrawableState()
        }

    override fun onCreateDrawableState(extraSpace: Int): IntArray {
        if (isUp || isDeleting) {
            val drawableState = super.onCreateDrawableState(extraSpace + (if (isUp) 1 else 0) + (if (isDeleting) 1 else 0))
            if (isUp) {
                View.mergeDrawableStates(drawableState, STATE_IS_UP)
            }
            if (isDeleting) {
                View.mergeDrawableStates(drawableState, STATE_IS_DELETING)
            }
            return drawableState
        }
        return super.onCreateDrawableState(extraSpace)
    }

    companion object {
        private val STATE_IS_UP = intArrayOf(R.attr.state_isUp)
        private val STATE_IS_DELETING = intArrayOf(R.attr.state_isDeleting)
    }
}