summaryrefslogtreecommitdiffstats
path: root/MetersPanel.c
diff options
context:
space:
mode:
authorHisham Muhammad <hisham@gobolinux.org>2015-02-03 22:32:07 +0100
committerHisham Muhammad <hisham@gobolinux.org>2015-02-03 22:32:07 +0100
commitd7c843c23bf73655df201e95fffef36c7e57c298 (patch)
treed23217b5f5cbd0c76601ea68a56dc1de7af98b4a /MetersPanel.c
parent14bd77c5f4ac968e9d6f0a5a9be29d49c5588f6d (diff)
Complete cursor-based movement of headers.
Diffstat (limited to 'MetersPanel.c')
-rw-r--r--MetersPanel.c45
1 files changed, 42 insertions, 3 deletions
diff --git a/MetersPanel.c b/MetersPanel.c
index ee25b0d1..39753ac2 100644
--- a/MetersPanel.c
+++ b/MetersPanel.c
@@ -15,14 +15,18 @@ in the source distribution for its full text.
#include "Settings.h"
#include "ScreenManager.h"
-typedef struct MetersPanel_ {
+typedef struct MetersPanel_ MetersPanel;
+
+struct MetersPanel_ {
Panel super;
Settings* settings;
Vector* meters;
ScreenManager* scr;
+ MetersPanel* leftNeighbor;
+ MetersPanel* rightNeighbor;
bool moving;
-} MetersPanel;
+};
}*/
@@ -33,11 +37,34 @@ static void MetersPanel_delete(Object* object) {
free(this);
}
+static inline bool moveToNeighbor(MetersPanel* this, MetersPanel* neighbor, int selected) {
+ Panel* super = (Panel*) this;
+ if (this->moving) {
+ this->moving = false;
+ ((ListItem*)Panel_getSelected(super))->moving = false;
+ if (neighbor) {
+ if (selected < Vector_size(this->meters)) {
+ Meter* meter = (Meter*) Vector_take(this->meters, selected);
+ Panel_remove(super, selected);
+ Vector_insert(neighbor->meters, selected, meter);
+ Panel_insert(&(neighbor->super), selected, (Object*) Meter_toListItem(meter));
+ Panel_setSelected(&(neighbor->super), selected);
+
+ neighbor->moving = true;
+ ((ListItem*)Panel_getSelected((Panel*)neighbor))->moving = true;
+ return true;
+ }
+ }
+ }
+ return false;
+}
+
static HandlerResult MetersPanel_eventHandler(Panel* super, int ch) {
MetersPanel* this = (MetersPanel*) super;
int selected = Panel_getSelectedIndex(super);
HandlerResult result = IGNORED;
+ bool sideMove = false;
switch(ch) {
case 0x0a:
@@ -93,6 +120,18 @@ static HandlerResult MetersPanel_eventHandler(Panel* super, int ch) {
result = HANDLED;
break;
}
+ case KEY_RIGHT:
+ {
+ sideMove = moveToNeighbor(this, this->rightNeighbor, selected);
+ // don't set HANDLED; let ScreenManager handle focus.
+ break;
+ }
+ case KEY_LEFT:
+ {
+ sideMove = moveToNeighbor(this, this->leftNeighbor, selected);
+ // don't set HANDLED; let ScreenManager handle focus.
+ break;
+ }
case KEY_F(9):
case KEY_DC:
{
@@ -104,7 +143,7 @@ static HandlerResult MetersPanel_eventHandler(Panel* super, int ch) {
break;
}
}
- if (result == HANDLED) {
+ if (result == HANDLED || sideMove) {
Header* header = (Header*) this->scr->header;
this->settings->changed = true;
Header_calculateHeight(header);

© 2014-2024 Faster IT GmbH | imprint | privacy policy