package jackall.moncalc.viewmodel
import android.arch.lifecycle.ViewModel
import android.arch.lifecycle.ViewModelProvider
import android.databinding.BindingAdapter
import android.databinding.ObservableField
import android.graphics.Color
import android.support.v7.widget.LinearLayoutManager
import android.support.v7.widget.RecyclerView
import com.github.mikephil.charting.charts.PieChart
import com.github.mikephil.charting.components.Legend
import com.github.mikephil.charting.data.Entry
import com.github.mikephil.charting.data.PieData
import com.github.mikephil.charting.data.PieEntry
import com.github.mikephil.charting.formatter.IValueFormatter
import com.github.mikephil.charting.utils.ViewPortHandler
import io.reactivex.schedulers.Schedulers
import jackall.moncalc.App
import jackall.moncalc.R
import jackall.moncalc.adapter.AnalyzeTempleAdapter
import jackall.moncalc.common.Notification
import jackall.moncalc.db.MonstDataRealmHelper
import jackall.moncalc.db.QuestRecordRealmHelper
import jackall.moncalc.model.PieChartModel
import jackall.moncalc.utils.RxBus
import jackall.moncalc.vo.Temple
import kotlin.concurrent.thread
/**
* Created by matsumoto_k on 2017/11/04.
*/
class TempleAnalyzeViewModel : LifecycleViewModel() {
val baseTempleName by lazy { App.instance.resources.getStringArray(R.array.base_temple_name) }
val pieData = ObservableField<PieData>()
val pieChartModel = ObservableField<PieChartModel>()
val items = ObservableField<ArrayList<TempleAnalyzeItemViewModel>>()
init {
thread {
setTempleAnalyzeList()
setTempleAnalyzePie()
}
RxBus.observe<Notification>().observeOn(Schedulers.newThread()).subscribe {
when (it.name) {
Notification.DATACHANGED.name -> {
thread {
setTempleAnalyzeList()
setTempleAnalyzePie()
}
}
}
}
}
fun setTempleAnalyzeList() {
val questRealmHelper = QuestRecordRealmHelper()
val monstDataRealmHelper = MonstDataRealmHelper()
val items = ArrayList<TempleAnalyzeItemViewModel>()
val specialPercent = questRealmHelper.getAllSpecialPercent()
items.add(
TempleAnalyzeItemViewModel(
"総合",
questRealmHelper.findAll().size.toString(),
"${if (specialPercent.isNaN()) 0 else String.format("%.1f", specialPercent)}%"
)
)
monstDataRealmHelper.findAll(Temple::class.java).forEach {
val count = questRealmHelper.countById(it.id)
if (count == 0)
return@forEach
items.add(
TempleAnalyzeItemViewModel(
monstDataRealmHelper.findNameById(Temple::class.java, it.id),
count.toString(),
"${String.format("%.1f", questRealmHelper.getSpecialPercent(it.id))}%"
)
)
}
this.items.set(items.apply { sortByDescending { it.count() } })
questRealmHelper.close()
monstDataRealmHelper.close()
}
fun setTempleAnalyzePie() {
val questRealmHelper = QuestRecordRealmHelper()
val entries = ArrayList<PieEntry>()
for (attribute in 0..4) {
val count = questRealmHelper.countByAttribute(attribute)
if (count > 0) {
entries.add(PieEntry(count.toFloat(), baseTempleName.get(attribute)))
}
}
pieChartModel.set(PieChartModel(entries.apply { sortByDescending { it.value } }, ""))
this.pieData.set(pieChartModel.get().pieData)
questRealmHelper.close()
}
object Adapter {
@JvmStatic
@BindingAdapter("android:pieChart")
fun hoge(mChart: PieChart, pieData: PieData?) {
if (pieData == null)
return
val start = System.currentTimeMillis()
mChart.setEntryLabelColor(Color.BLACK)
mChart.isDrawHoleEnabled = false
mChart.legend.verticalAlignment = Legend.LegendVerticalAlignment.TOP
mChart.legend.horizontalAlignment = Legend.LegendHorizontalAlignment.RIGHT
mChart.legend.orientation = Legend.LegendOrientation.VERTICAL
mChart.isRotationEnabled = false
pieData.setValueFormatter(object : IValueFormatter {
override fun getFormattedValue(value: Float, entry: Entry?, dataSetIndex: Int, viewPortHandler: ViewPortHandler?): String {
return String.format("%.0f", value)
}
})
mChart.description.text = "神殿周回割合"
mChart.data = pieData
mChart.invalidate()
}
@JvmStatic
@BindingAdapter("android:setAnalyzeTempleList")
fun setAnalyzeTempleList(view: RecyclerView, items: ArrayList<TempleAnalyzeItemViewModel>?) {
if (items == null)
return
view.layoutManager = LinearLayoutManager(App.instance)
view.adapter = AnalyzeTempleAdapter(App.instance, items)
view.adapter.notifyDataSetChanged()
}
}
override fun onDestroy() {
super.onDestroy()
}
class Factory() : ViewModelProvider.NewInstanceFactory() {
override fun <T : ViewModel?> create(modelClass: Class<T>): T {
return TempleAnalyzeViewModel() as T
}
}
}