import term.ui as tui

const (
	colors = [
		tui.Color{33, 150, 243}
		tui.Color{0, 150, 136}
		tui.Color{205, 220, 57}
		tui.Color{255, 152, 0}
		tui.Color{244, 67, 54}
		tui.Color{156, 39, 176}
	]
)

struct Point {
	x int
	y int
}

struct App {
mut:
	tui       &tui.Context = 0
	points    []Point
	color     tui.Color = colors[0]
	color_idx int
	cut_rate  f64 = 5
}

fn frame(x voidptr) {
	mut app := &App(x)

	app.tui.clear()

	if app.points.len > 0 {
		app.tui.set_bg_color(app.color)
		mut last := app.points[0]
		for point in app.points {
			// if the cursor moves quickly enough, different events are not
			// necessarily touching, so we need to draw a line between them
			app.tui.draw_line(last.x, last.y, point.x, point.y)
			last = point
		}
		app.tui.reset()

		l := int(app.points.len / app.cut_rate) + 1
		app.points = app.points[l..].clone()
	}

	ww := app.tui.window_width

	app.tui.bold()
	app.tui.draw_text(ww / 6, 2, 'V term.input: cursor chaser demo')
	app.tui.draw_text((ww - ww / 6) - 14, 2, 'cut rate: ${(100 / app.cut_rate):3.0f}%')
	app.tui.horizontal_separator(3)
	app.tui.reset()
	app.tui.flush()
}

fn event(e &tui.Event, x voidptr) {
	mut app := &App(x)

	match e.typ {
		.key_down {
			match e.code {
				.escape {
					exit(0)
				}
				.space, .enter {
					app.color_idx++
					if app.color_idx == colors.len { app.color_idx = 0 }
					app.color = colors[app.color_idx]
				} else {}
			}
		} .mouse_move, .mouse_drag, .mouse_down {
			app.points << Point{ e.x, e.y }
		} .mouse_scroll {
			d := if e.direction == .up { 0.1 } else { -0.1 }
			app.cut_rate += d
			if app.cut_rate < 1 { app.cut_rate = 1 }
		} else {}
	}
}

mut app := &App{}
app.tui = tui.init(
	user_data: app,
	frame_fn: frame,
	event_fn: event,

	hide_cursor: true
)

app.tui.run()