&spacer, &settings_view, &help_view
};
-/* Global data */
+/* Config data */
int COMPACT = 0;
+/* Global data */
+edit_t EDIT = EDIT_NONE;
+
/* Local data */
view_t *view = &day_view;
view_t *active = &day_view;
mvwaddch(win, y, x++, ACS_BLOCK);
if (color) wattroff(win, COLOR_PAIR(color));
- if (flags & SHOW_ACTIVE)
+ if (flags & SHOW_ACTIVE && event == EVENT)
wattron(win, A_REVERSE | A_BOLD);
if (flags & SHOW_DETAILS) {
if (all_day(&event->start, &event->end))
if (flags & SHOW_DETAILS && event->loc) {
mvwprintw(win, y, x, " @ %s", event->loc);
}
- if (flags & SHOW_ACTIVE)
+ if (flags & SHOW_ACTIVE && event == EVENT)
wattroff(win, A_REVERSE | A_BOLD);
}
x += 2;
/* Set background */
- if (flags & SHOW_ACTIVE)
+ if (flags & SHOW_ACTIVE && todo == TODO)
wattron(win, A_REVERSE | A_BOLD);
mvwhline(win, y, x, ' ', COLS-x);
mvwprintw(win, y, x, "%s", desc);
/* Reset flags */
- if (flags & SHOW_ACTIVE)
+ if (flags & SHOW_ACTIVE && todo == TODO)
wattroff(win, A_REVERSE | A_BOLD);
}
/* Pass key to active view */
return view->run(key, btn, row, col);
}
+
+/* View event */
+void view_edit(edit_t mode)
+{
+ EDIT = mode;
+ set_view(active, &edit_view);
+}
#define SHOW_DETAILS 0x1
#define SHOW_ACTIVE 0x2
+/* Edit modes */
+typedef enum {
+ EDIT_NONE,
+ EDIT_CAL,
+ EDIT_EVENT,
+ EDIT_TODO,
+} edit_t;
+
/* Config data */
-extern int COMPACT;
+extern int COMPACT; // reduce layout spacing
+
+/* Global data */
+extern edit_t EDIT; // edit mode 0=cal 1=event 3=todo
/* Curses functions */
void wmvresize(WINDOW *win, int top, int left, int rows, int cols);
void view_resize(void);
void view_draw(void);
int view_run(int key, mmask_t btn, int row, int col);
+void view_edit(edit_t mode);