72 lines
12 KiB
TypeScript
72 lines
12 KiB
TypeScript
import { Color, text, Stack, Text, layoutConfig, LayoutSpec, gravity, pullable, stack, image, Image, BridgeContext, log } from "doric";
|
|
export const icon_refresh = ''
|
|
|
|
export const colors = [
|
|
"#70a1ff",
|
|
"#7bed9f",
|
|
"#ff6b81",
|
|
"#a4b0be",
|
|
"#f0932b",
|
|
"#eb4d4b",
|
|
"#6ab04c",
|
|
"#e056fd",
|
|
"#686de0",
|
|
"#30336b",
|
|
].map(e => Color.parse(e))
|
|
|
|
export function label(str: string) {
|
|
return text({
|
|
text: str,
|
|
textSize: 16,
|
|
})
|
|
}
|
|
|
|
export function box(idx = 0) {
|
|
return (new Stack).also(it => {
|
|
it.width = it.height = 20
|
|
it.backgroundColor = colors[idx || 0]
|
|
})
|
|
}
|
|
export function boxStr(str: string, idx = 0) {
|
|
return (new Text).also(it => {
|
|
it.width = it.height = 20
|
|
it.text = str
|
|
it.textColor = Color.WHITE
|
|
it.backgroundColor = colors[idx || 0]
|
|
})
|
|
}
|
|
|
|
export function title(str: string) {
|
|
return text({
|
|
text: str,
|
|
layoutConfig: layoutConfig().configWidth(LayoutSpec.MOST),
|
|
textSize: 30,
|
|
textColor: Color.WHITE,
|
|
backgroundColor: colors[1],
|
|
textAlignment: gravity().center(),
|
|
height: 50,
|
|
})
|
|
}
|
|
|
|
export function rotatedArrow() {
|
|
let refreshImage: Image
|
|
return pullable(
|
|
stack([
|
|
image({
|
|
layoutConfig: layoutConfig().just().configMargin({ 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
|
|
},
|
|
})
|
|
} |