95 lines
3.7 KiB
TypeScript
95 lines
3.7 KiB
TypeScript
|
import { refreshable, Group, Panel, pullable, text, gravity, Color, Stack, LayoutSpec, list, NativeCall, listItem, log, vlayout, Gravity, hlayout, Text, scroller, layoutConfig, image, IView, IVLayout, ScaleType, modal, IText, network, navigator, stack, Image } from "doric";
|
||
|
import { title, label, colors, icon_refresh } from "./utils";
|
||
|
|
||
|
@Entry
|
||
|
class RefreshableDemo extends Panel {
|
||
|
build(rootView: Group): void {
|
||
|
let refreshImage: Image
|
||
|
let refreshView = refreshable({
|
||
|
layoutConfig: layoutConfig().atmost(),
|
||
|
onRefresh: () => {
|
||
|
log('onRefresh')
|
||
|
setTimeout(() => {
|
||
|
refreshView.setRefreshing(context, false)
|
||
|
}, 5000)
|
||
|
},
|
||
|
header: pullable(context,
|
||
|
stack([
|
||
|
image({
|
||
|
layoutConfig: layoutConfig().exactly().m({ top: 50, bottom: 10, }),
|
||
|
width: 30,
|
||
|
height: 30,
|
||
|
imageBase64: icon_refresh,
|
||
|
}).also(v => {
|
||
|
refreshImage = v
|
||
|
}),
|
||
|
]),
|
||
|
{
|
||
|
startAnimation: () => {
|
||
|
log('startAnimation')
|
||
|
},
|
||
|
stopAnimation: () => {
|
||
|
log('stopAnimation')
|
||
|
},
|
||
|
setPullingDistance: (distance: number) => {
|
||
|
refreshImage.rotation = distance / 30
|
||
|
},
|
||
|
}),
|
||
|
content: (vlayout([
|
||
|
title("Refreshable Demo"),
|
||
|
label('start Refresh').apply({
|
||
|
width: 300,
|
||
|
height: 50,
|
||
|
backgroundColor: colors[0],
|
||
|
textSize: 30,
|
||
|
textColor: Color.WHITE,
|
||
|
layoutConfig: layoutConfig().exactly(),
|
||
|
onClick: () => {
|
||
|
refreshView.setRefreshing(context, true)
|
||
|
}
|
||
|
} as IText),
|
||
|
label('stop Refresh').apply({
|
||
|
width: 300,
|
||
|
height: 50,
|
||
|
backgroundColor: colors[0],
|
||
|
textSize: 30,
|
||
|
textColor: Color.WHITE,
|
||
|
layoutConfig: layoutConfig().exactly(),
|
||
|
onClick: () => {
|
||
|
refreshView.setRefreshing(context, false)
|
||
|
}
|
||
|
} as IText),
|
||
|
|
||
|
label('Enable Refresh').apply({
|
||
|
width: 300,
|
||
|
height: 50,
|
||
|
backgroundColor: colors[0],
|
||
|
textSize: 30,
|
||
|
textColor: Color.WHITE,
|
||
|
layoutConfig: layoutConfig().exactly(),
|
||
|
onClick: () => {
|
||
|
refreshView.setRefreshable(context, true)
|
||
|
}
|
||
|
} as IText),
|
||
|
|
||
|
label('Disable Refresh').apply({
|
||
|
width: 300,
|
||
|
height: 50,
|
||
|
backgroundColor: colors[0],
|
||
|
textSize: 30,
|
||
|
textColor: Color.WHITE,
|
||
|
layoutConfig: layoutConfig().exactly(),
|
||
|
onClick: () => {
|
||
|
refreshView.setRefreshable(context, false)
|
||
|
}
|
||
|
} as IText),
|
||
|
]).apply({
|
||
|
layoutConfig: layoutConfig().atmost().h(LayoutSpec.WRAP_CONTENT),
|
||
|
gravity: gravity().centerX(),
|
||
|
space: 10,
|
||
|
} as IVLayout))
|
||
|
}).apply({
|
||
|
backgroundColor: Color.YELLOW
|
||
|
}).in(rootView)
|
||
|
}
|
||
|
}
|