60 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			60 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import { text, vlayout, ViewHolder, VMPanel, ViewModel, Gravity, NativeCall, Text, Color, log, logw, loge, Group, LayoutSpec, layoutConfig, } from "doric"
 | |
| 
 | |
| interface CountModel {
 | |
|     count: number
 | |
| }
 | |
| class CounterView extends ViewHolder {
 | |
|     number!: Text
 | |
|     counter!: Text
 | |
|     build(root: Group) {
 | |
|         vlayout(
 | |
|             [
 | |
|                 this.number = text({
 | |
|                     textSize: 40,
 | |
|                 }),
 | |
| 
 | |
|                 this.counter = text({
 | |
|                     text: "Click To Count",
 | |
|                     textSize: 20,
 | |
|                 }),
 | |
|             ],
 | |
|             {
 | |
|                 layoutConfig: layoutConfig().most(),
 | |
|                 gravity: Gravity.Center,
 | |
|                 space: 20,
 | |
|             }
 | |
|         ).in(root)
 | |
|     }
 | |
| }
 | |
| 
 | |
| class CounterVM extends ViewModel<CountModel, CounterView> {
 | |
|     onAttached(s: CountModel, vh: CounterView) {
 | |
|         vh.counter.onClick = () => {
 | |
|             this.updateState(state => {
 | |
|                 state.count++
 | |
|             })
 | |
|         }
 | |
|     }
 | |
|     onBind(s: CountModel, vh: CounterView) {
 | |
|         vh.number.text = `${s.count}`
 | |
|     }
 | |
| }
 | |
| 
 | |
| @Entry
 | |
| class MyPage extends VMPanel<CountModel, CounterView>{
 | |
| 
 | |
| 
 | |
|     getViewHolderClass() {
 | |
|         return CounterView
 | |
|     }
 | |
| 
 | |
|     getViewModelClass() {
 | |
|         return CounterVM
 | |
|     }
 | |
| 
 | |
|     getState(): CountModel {
 | |
|         return {
 | |
|             count: 0
 | |
|         }
 | |
|     }
 | |
| } |