2023-02-05 01:56:04 +00:00
|
|
|
package lib.ui.elements;
|
|
|
|
|
|
|
|
import lib.ui.elements.UIElement;
|
|
|
|
|
|
|
|
class TextElement implements UIElement {
|
|
|
|
public var text:String;
|
|
|
|
|
|
|
|
private final uiEvents:UIEvents;
|
2023-07-11 11:17:33 +00:00
|
|
|
private final style:Style;
|
2023-02-05 01:56:04 +00:00
|
|
|
|
2023-07-11 11:17:33 +00:00
|
|
|
public function new(text:String, ?props: {?style:Style, ?uiEvents:UIEvents}) {
|
2023-02-05 01:56:04 +00:00
|
|
|
this.text = text;
|
2023-07-11 11:17:33 +00:00
|
|
|
this.uiEvents = props?.uiEvents;
|
|
|
|
this.style = props?.style ?? {fgColor: White, bgColor: Black};
|
2023-02-05 01:56:04 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public function set(text:String) {
|
|
|
|
this.text = text;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function get():String {
|
|
|
|
return this.text;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getEventHandlers():UIEvents {
|
|
|
|
return uiEvents;
|
|
|
|
}
|
|
|
|
|
2023-07-08 12:01:38 +00:00
|
|
|
public function render(bounds: Pos):Canvas {
|
2023-02-05 01:56:04 +00:00
|
|
|
var canvas = new Canvas();
|
|
|
|
for (i in 0...this.text.length) {
|
|
|
|
var c = this.text.charAt(i);
|
2023-07-11 11:17:33 +00:00
|
|
|
canvas.set({x: i, y: 0}, {bg: style.bgColor ?? Black, textColor: style.fgColor ?? White, char: c});
|
2023-02-05 01:56:04 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return canvas;
|
|
|
|
}
|
|
|
|
}
|