91 lines
3.6 KiB
Kotlin
91 lines
3.6 KiB
Kotlin
package sushi.hardcore.aira
|
|
|
|
import android.content.Context
|
|
import android.os.Binder
|
|
import android.os.Bundle
|
|
import androidx.fragment.app.Fragment
|
|
import android.view.LayoutInflater
|
|
import android.view.View
|
|
import android.view.ViewGroup
|
|
import android.widget.Toast
|
|
import androidx.appcompat.app.AppCompatActivity
|
|
import com.bumptech.glide.Glide
|
|
import sushi.hardcore.aira.databinding.FragmentCreateIdentityBinding
|
|
import sushi.hardcore.aira.utils.AvatarPicker
|
|
|
|
class CreateIdentityFragment(private val activity: AppCompatActivity) : Fragment() {
|
|
private external fun createNewIdentity(databaseFolder: String, name: String, password: ByteArray?): Boolean
|
|
|
|
companion object {
|
|
fun newInstance(activity: AppCompatActivity, binder: Binder): CreateIdentityFragment {
|
|
return CreateIdentityFragment(activity).apply {
|
|
arguments = Bundle().apply {
|
|
putBinder(LoginActivity.BINDER_ARG, binder)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
private val avatarPicker = AvatarPicker(activity) { avatar ->
|
|
AIRADatabase.setIdentityAvatar(Constants.getDatabaseFolder(activity), avatar)
|
|
Glide.with(this).load(avatar).circleCrop().into(binding.avatar)
|
|
}
|
|
private lateinit var binding: FragmentCreateIdentityBinding
|
|
|
|
override fun onAttach(context: Context) {
|
|
super.onAttach(context)
|
|
avatarPicker.register()
|
|
}
|
|
|
|
override fun onCreateView(inflater: LayoutInflater, container: ViewGroup?, savedInstanceState: Bundle?): View {
|
|
binding = FragmentCreateIdentityBinding.inflate(inflater, container, false)
|
|
return binding.root
|
|
}
|
|
|
|
override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
|
|
binding.buttonSetAvatar.setOnClickListener {
|
|
avatarPicker.launch()
|
|
}
|
|
binding.checkboxEnablePassword.setOnCheckedChangeListener { _, isChecked ->
|
|
if (isChecked) {
|
|
binding.editPassword.visibility = View.VISIBLE
|
|
binding.editPasswordConfirm.visibility = View.VISIBLE
|
|
} else {
|
|
binding.editPassword.visibility = View.GONE
|
|
binding.editPasswordConfirm.visibility = View.GONE
|
|
}
|
|
}
|
|
binding.buttonCreate.setOnClickListener {
|
|
val identityName = binding.editName.text.toString()
|
|
val password = binding.editPassword.text.toString().toByteArray()
|
|
if (password.isEmpty()) {
|
|
createIdentity(identityName, null)
|
|
} else {
|
|
val passwordConfirm = binding.editPasswordConfirm.text.toString().toByteArray()
|
|
if (password.contentEquals(passwordConfirm)) {
|
|
createIdentity(identityName, password)
|
|
} else {
|
|
Toast.makeText(activity, R.string.password_mismatch, Toast.LENGTH_SHORT).show()
|
|
}
|
|
passwordConfirm.fill(0)
|
|
password.fill(0)
|
|
}
|
|
}
|
|
}
|
|
|
|
private fun createIdentity(identityName: String, password: ByteArray?) {
|
|
var success = false
|
|
arguments?.let { bundle ->
|
|
bundle.getBinder(LoginActivity.BINDER_ARG)?.let { binder ->
|
|
val databaseFolder = Constants.getDatabaseFolder(requireContext())
|
|
if (createNewIdentity(databaseFolder, identityName, password)) {
|
|
(binder as LoginActivity.ActivityLauncher).launch()
|
|
success = true
|
|
}
|
|
}
|
|
}
|
|
if (!success) {
|
|
Toast.makeText(activity, R.string.identity_create_failed, Toast.LENGTH_SHORT).show()
|
|
}
|
|
}
|
|
} |