package jp.juggler.subwaytooter import android.content.Intent import android.text.SpannableStringBuilder import android.view.View import android.widget.Button import android.widget.TextView import jp.juggler.subwaytooter.action.Action_Account import jp.juggler.subwaytooter.action.Action_Instance import jp.juggler.subwaytooter.api.entity.TootInstance import jp.juggler.subwaytooter.util.DecodeOptions import jp.juggler.subwaytooter.view.MyLinkMovementMethod import jp.juggler.subwaytooter.view.MyNetworkImageView import jp.juggler.util.LogCategory import jp.juggler.util.showToast import org.conscrypt.OpenSSLX509Certificate import java.util.* import java.util.regex.Pattern internal class ViewHolderHeaderInstance( arg_activity : ActMain, viewRoot : View ) : ViewHolderHeaderBase(arg_activity, viewRoot) , View.OnClickListener { companion object { private val log = LogCategory("ViewHolderHeaderInstance") private val reWhitespaceBeforeLineFeed = Pattern.compile("[ \t\r]+\n") } private val btnInstance : TextView = viewRoot.findViewById(R.id.btnInstance) private val tvVersion : TextView = viewRoot.findViewById(R.id.tvVersion) private val tvTitle : TextView= viewRoot.findViewById(R.id.tvTitle) private val btnEmail : TextView = viewRoot.findViewById(R.id.btnEmail) private val tvDescription : TextView= viewRoot.findViewById(R.id.tvDescription) private val tvUserCount : TextView = viewRoot.findViewById(R.id.tvUserCount) private val tvTootCount : TextView = viewRoot.findViewById(R.id.tvTootCount) private val tvDomainCount : TextView = viewRoot.findViewById(R.id.tvDomainCount) private val ivThumbnail : MyNetworkImageView = viewRoot.findViewById(R.id.ivThumbnail) private val btnContact : TextView= viewRoot.findViewById(R.id.btnContact) private val tvLanguages : TextView= viewRoot.findViewById(R.id.tvLanguages) private val tvHandshake : TextView = viewRoot.findViewById(R.id.tvHandshake) private val btnAbout : Button = viewRoot.findViewById(R.id.btnAbout) private val btnAboutMore : Button = viewRoot.findViewById(R.id.btnAboutMore) private val btnExplore : Button = viewRoot.findViewById(R.id.btnExplore) private var instance : TootInstance? = null init { // // CharSequence sv = HTMLDecoder.decodeHTML( activity, access_info, html, false, true, null ); // // TextView tvSearchDesc = (TextView) viewRoot.findViewById( R.id.tvSearchDesc ); // tvSearchDesc.setVisibility( View.VISIBLE ); // tvSearchDesc.setMovementMethod( MyLinkMovementMethod.getInstance() ); // tvSearchDesc.setText( sv ); btnInstance.setOnClickListener(this) btnEmail.setOnClickListener(this) btnContact.setOnClickListener(this) ivThumbnail.setOnClickListener(this) btnAbout.setOnClickListener(this) btnAboutMore.setOnClickListener(this) btnExplore.setOnClickListener(this) tvDescription.movementMethod = MyLinkMovementMethod } override fun showColor() { // } override fun bindData(column : Column) { super.bindData(column) val instance = column.instance_information val handshake = column.handshake this.instance = instance if(instance == null) { btnInstance.text = "?" tvVersion.text = "?" tvTitle.text = "?" btnEmail.text = "?" btnEmail.isEnabled = false tvDescription.text = "?" ivThumbnail.setImageUrl(App1.pref, 0f, null) tvLanguages.text = "?" btnContact.text = "?" btnContact.isEnabled = false btnAbout.isEnabled = false btnAboutMore.isEnabled = false btnExplore.isEnabled = false } else { val uri = instance.uri ?: "" val hasUri = uri.isNotEmpty() btnInstance.text = uri btnInstance.isEnabled = hasUri btnAbout.isEnabled = hasUri btnAboutMore.isEnabled = hasUri btnExplore.isEnabled = hasUri tvVersion.text = instance.version ?: "" tvTitle.text = instance.title ?: "" val email = instance.email ?: "" btnEmail.text = email btnEmail.isEnabled = email.isNotEmpty() val contact_acct = instance.contact_account?.let { who -> "@" + who.username + "@" + who.host } ?: "" btnContact.text = contact_acct btnContact.isEnabled = contact_acct.isNotEmpty() tvLanguages.text = instance.languages?.joinToString(", ") ?: "" val sb = DecodeOptions(activity, access_info, decodeEmoji = true) .decodeHTML("
" + (instance.description ?: "") + "
") // 行末の空白を除去 val m = reWhitespaceBeforeLineFeed.matcher(sb) val matchList = LinkedList