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 }, }) }