summaryrefslogtreecommitdiff
path: root/fw/fe310/phone/app/status.c
diff options
context:
space:
mode:
Diffstat (limited to 'fw/fe310/phone/app/status.c')
-rw-r--r--fw/fe310/phone/app/status.c68
1 files changed, 68 insertions, 0 deletions
diff --git a/fw/fe310/phone/app/status.c b/fw/fe310/phone/app/status.c
new file mode 100644
index 0000000..fec391b
--- /dev/null
+++ b/fw/fe310/phone/app/status.c
@@ -0,0 +1,68 @@
+#include <stdio.h>
+#include <stdlib.h>
+#include <unistd.h>
+#include <string.h>
+
+#include <eos.h>
+#include <dev/net.h>
+#include <net/cell.h>
+
+#include <eve/eve.h>
+#include <eve/eve_kbd.h>
+#include <eve/eve_font.h>
+
+#include <eve/screen/window.h>
+#include <eve/screen/page.h>
+#include <eve/screen/form.h>
+
+#include "app.h"
+#include "status.h"
+
+void app_status_init(EVEView *view, EVEWindow *win) {
+ eve_view_init(view, win, app_status_draw, app_status_touch, NULL, NULL);
+ eve_view_set_color_bg(view, 0x20, 0x20, 0x20);
+}
+
+int app_status_touch(EVEView *view, EVETouch *touch, uint16_t evt, uint8_t tag0) {
+ unsigned char state = 0;
+ int8_t touch_idx;
+
+ /* only first touch */
+ touch_idx = eve_touch_get_idx(touch);
+ if (touch_idx != 0) return 0;
+
+ evt = eve_touch_evt(touch, evt, tag0, view->tag, 2);
+ if (evt & EVE_TOUCH_ETYPE_POINT_UP) {
+ view->param = NULL;
+ return 1;
+ }
+ return 0;
+}
+
+uint8_t app_status_draw(EVEView *view, uint8_t tag0) {
+ uint8_t tag_opt = EVE_TOUCH_OPT_TRACK | EVE_TOUCH_OPT_TRACK_XY;
+ char *status_msg = view->param;
+
+ tag0 = eve_view_clear(view, tag0, tag_opt);
+
+ if (tag0 != EVE_NOTAG) {
+ eve_touch_set_opt(tag0, eve_touch_get_opt(tag0) | tag_opt);
+ eve_cmd_dl(TAG(tag0));
+ tag0++;
+ }
+
+ if (status_msg) eve_cmd(CMD_TEXT, "hhhhs", 0, 0, 31, 0, status_msg);
+
+ return tag0;
+}
+
+void app_status_set_msg(char *msg) {
+ EVEView *status;
+
+ status = app_search_view("status");
+ if (status == NULL) return;
+
+ status->param = msg;
+
+ if (!eve_selected()) app_refresh();
+}