summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJaeun Choi <jaeun12.choi@samsung.com>2014-04-17 16:03:48 +0900
committerChunEon Park <hermet@hermet.pe.kr>2014-04-17 16:03:48 +0900
commitc9755bd3c828bcd2453a50542331b201089a7160 (patch)
treec58056e7de402e9dab391197180fb845f89af10a
parent9279d3a161b49d1b0106c92cf663e6b810cde42c (diff)
downloadelementary-c9755bd3c828bcd2453a50542331b201089a7160.tar.gz
spinner: apply key binding
Summary: This patch applies key binding to elm_spinner. Test Plan: None Reviewers: Hermet, raster Differential Revision: https://phab.enlightenment.org/D752
-rw-r--r--config/default/base.src71
-rw-r--r--config/mobile/base.src71
-rw-r--r--config/standard/base.src71
-rw-r--r--src/lib/elm_spinner.c87
4 files changed, 259 insertions, 41 deletions
diff --git a/config/default/base.src b/config/default/base.src
index 61e043802..0f7176bfc 100644
--- a/config/default/base.src
+++ b/config/default/base.src
@@ -1943,6 +1943,77 @@ group "Elm_Config" struct {
}
}
group "Elm_Config_Bindings_Widget" struct {
+ value "name" string: "Elm_Spinner";
+ group "key_bindings" list {
+ group "Elm_Config_Binding_Key" struct {
+ value "context" int: 0;
+ value "key" string: "Left";
+ value "action" string: "spin";
+ value "params" string: "dec";
+ }
+ group "Elm_Config_Binding_Key" struct {
+ value "context" int: 0;
+ value "key" string: "KP_Left";
+ value "action" string: "spin";
+ value "params" string: "dec";
+ }
+ group "Elm_Config_Binding_Key" struct {
+ value "context" int: 0;
+ value "key" string: "Down";
+ value "action" string: "spin";
+ value "params" string: "dec";
+ }
+ group "Elm_Config_Binding_Key" struct {
+ value "context" int: 0;
+ value "key" string: "KP_Down";
+ value "action" string: "spin";
+ value "params" string: "dec";
+ }
+ group "Elm_Config_Binding_Key" struct {
+ value "context" int: 0;
+ value "key" string: "Right";
+ value "action" string: "spin";
+ value "params" string: "inc";
+ }
+ group "Elm_Config_Binding_Key" struct {
+ value "context" int: 0;
+ value "key" string: "KP_Right";
+ value "action" string: "spin";
+ value "params" string: "inc";
+ }
+ group "Elm_Config_Binding_Key" struct {
+ value "context" int: 0;
+ value "key" string: "Up";
+ value "action" string: "spin";
+ value "params" string: "inc";
+ }
+ group "Elm_Config_Binding_Key" struct {
+ value "context" int: 0;
+ value "key" string: "KP_Up";
+ value "action" string: "spin";
+ value "params" string: "inc";
+ }
+ group "Elm_Config_Binding_Key" struct {
+ value "context" int: 0;
+ value "key" string: "Return";
+ value "action" string: "toggle";
+ value "params" string: "";
+ }
+ group "Elm_Config_Binding_Key" struct {
+ value "context" int: 0;
+ value "key" string: "KP_Enter";
+ value "action" string: "toggle";
+ value "params" string: "";
+ }
+ group "Elm_Config_Binding_Key" struct {
+ value "context" int: 0;
+ value "key" string: "space";
+ value "action" string: "toggle";
+ value "params" string: "";
+ }
+ }
+ }
+ group "Elm_Config_Bindings_Widget" struct {
value "name" string: "Elm_Toolbar";
group "key_bindings" list {
group "Elm_Config_Binding_Key" struct {
diff --git a/config/mobile/base.src b/config/mobile/base.src
index a40d3766d..26cc01322 100644
--- a/config/mobile/base.src
+++ b/config/mobile/base.src
@@ -1947,6 +1947,77 @@ group "Elm_Config" struct {
}
}
group "Elm_Config_Bindings_Widget" struct {
+ value "name" string: "Elm_Spinner";
+ group "key_bindings" list {
+ group "Elm_Config_Binding_Key" struct {
+ value "context" int: 0;
+ value "key" string: "Left";
+ value "action" string: "spin";
+ value "params" string: "dec";
+ }
+ group "Elm_Config_Binding_Key" struct {
+ value "context" int: 0;
+ value "key" string: "KP_Left";
+ value "action" string: "spin";
+ value "params" string: "dec";
+ }
+ group "Elm_Config_Binding_Key" struct {
+ value "context" int: 0;
+ value "key" string: "Down";
+ value "action" string: "spin";
+ value "params" string: "dec";
+ }
+ group "Elm_Config_Binding_Key" struct {
+ value "context" int: 0;
+ value "key" string: "KP_Down";
+ value "action" string: "spin";
+ value "params" string: "dec";
+ }
+ group "Elm_Config_Binding_Key" struct {
+ value "context" int: 0;
+ value "key" string: "Right";
+ value "action" string: "spin";
+ value "params" string: "inc";
+ }
+ group "Elm_Config_Binding_Key" struct {
+ value "context" int: 0;
+ value "key" string: "KP_Right";
+ value "action" string: "spin";
+ value "params" string: "inc";
+ }
+ group "Elm_Config_Binding_Key" struct {
+ value "context" int: 0;
+ value "key" string: "Up";
+ value "action" string: "spin";
+ value "params" string: "inc";
+ }
+ group "Elm_Config_Binding_Key" struct {
+ value "context" int: 0;
+ value "key" string: "KP_Up";
+ value "action" string: "spin";
+ value "params" string: "inc";
+ }
+ group "Elm_Config_Binding_Key" struct {
+ value "context" int: 0;
+ value "key" string: "Return";
+ value "action" string: "toggle";
+ value "params" string: "";
+ }
+ group "Elm_Config_Binding_Key" struct {
+ value "context" int: 0;
+ value "key" string: "KP_Enter";
+ value "action" string: "toggle";
+ value "params" string: "";
+ }
+ group "Elm_Config_Binding_Key" struct {
+ value "context" int: 0;
+ value "key" string: "space";
+ value "action" string: "toggle";
+ value "params" string: "";
+ }
+ }
+ }
+ group "Elm_Config_Bindings_Widget" struct {
value "name" string: "Elm_Toolbar";
group "key_bindings" list {
group "Elm_Config_Binding_Key" struct {
diff --git a/config/standard/base.src b/config/standard/base.src
index 4b58b5334..6266ab1f5 100644
--- a/config/standard/base.src
+++ b/config/standard/base.src
@@ -1944,6 +1944,77 @@ group "Elm_Config" struct {
}
}
group "Elm_Config_Bindings_Widget" struct {
+ value "name" string: "Elm_Spinner";
+ group "key_bindings" list {
+ group "Elm_Config_Binding_Key" struct {
+ value "context" int: 0;
+ value "key" string: "Left";
+ value "action" string: "spin";
+ value "params" string: "dec";
+ }
+ group "Elm_Config_Binding_Key" struct {
+ value "context" int: 0;
+ value "key" string: "KP_Left";
+ value "action" string: "spin";
+ value "params" string: "dec";
+ }
+ group "Elm_Config_Binding_Key" struct {
+ value "context" int: 0;
+ value "key" string: "Down";
+ value "action" string: "spin";
+ value "params" string: "dec";
+ }
+ group "Elm_Config_Binding_Key" struct {
+ value "context" int: 0;
+ value "key" string: "KP_Down";
+ value "action" string: "spin";
+ value "params" string: "dec";
+ }
+ group "Elm_Config_Binding_Key" struct {
+ value "context" int: 0;
+ value "key" string: "Right";
+ value "action" string: "spin";
+ value "params" string: "inc";
+ }
+ group "Elm_Config_Binding_Key" struct {
+ value "context" int: 0;
+ value "key" string: "KP_Right";
+ value "action" string: "spin";
+ value "params" string: "inc";
+ }
+ group "Elm_Config_Binding_Key" struct {
+ value "context" int: 0;
+ value "key" string: "Up";
+ value "action" string: "spin";
+ value "params" string: "inc";
+ }
+ group "Elm_Config_Binding_Key" struct {
+ value "context" int: 0;
+ value "key" string: "KP_Up";
+ value "action" string: "spin";
+ value "params" string: "inc";
+ }
+ group "Elm_Config_Binding_Key" struct {
+ value "context" int: 0;
+ value "key" string: "Return";
+ value "action" string: "toggle";
+ value "params" string: "";
+ }
+ group "Elm_Config_Binding_Key" struct {
+ value "context" int: 0;
+ value "key" string: "KP_Enter";
+ value "action" string: "toggle";
+ value "params" string: "";
+ }
+ group "Elm_Config_Binding_Key" struct {
+ value "context" int: 0;
+ value "key" string: "space";
+ value "action" string: "toggle";
+ value "params" string: "";
+ }
+ }
+ }
+ group "Elm_Config_Bindings_Widget" struct {
value "name" string: "Elm_Toolbar";
group "key_bindings" list {
group "Elm_Config_Binding_Key" struct {
diff --git a/src/lib/elm_spinner.c b/src/lib/elm_spinner.c
index b9ce420d3..273935745 100644
--- a/src/lib/elm_spinner.c
+++ b/src/lib/elm_spinner.c
@@ -34,6 +34,15 @@ static const Evas_Smart_Cb_Description _smart_callbacks[] = {
{NULL, NULL}
};
+static Eina_Bool _key_action_spin(Evas_Object *obj, const char *params);
+static Eina_Bool _key_action_toggle(Evas_Object *obj, const char *params);
+
+static const Elm_Action key_actions[] = {
+ {"spin", _key_action_spin},
+ {"toggle", _key_action_toggle},
+ {NULL, NULL}
+};
+
static void
_entry_show(Elm_Spinner_Data *sd)
{
@@ -441,6 +450,38 @@ _elm_spinner_elm_layout_sizing_eval(Eo *obj, Elm_Spinner_Data *_pd EINA_UNUSED)
evas_object_size_hint_max_set(obj, -1, -1);
}
+static Eina_Bool
+_key_action_spin(Evas_Object *obj, const char *params)
+{
+ const char *dir = params;
+ Eina_Bool horz = !!strncmp(elm_widget_style_get(obj), "vertical", 8);
+
+ if ((!strcmp(dir, "dec")) && horz)
+ {
+ _val_dec_start(obj);
+ elm_layout_signal_emit(obj, "elm,left,anim,activate", "elm");
+ }
+ else if ((!strcmp(dir, "inc")) && horz)
+ {
+ _val_inc_start(obj);
+ elm_layout_signal_emit(obj, "elm,right,anim,activate", "elm");
+ }
+ else return EINA_FALSE;
+
+ return EINA_TRUE;
+}
+
+static Eina_Bool
+_key_action_toggle(Evas_Object *obj, const char *params EINA_UNUSED)
+{
+ ELM_SPINNER_DATA_GET(obj, sd);
+
+ if (sd->spin_timer) _spin_stop(obj);
+ else _entry_toggle_cb(NULL, obj, NULL, NULL);
+
+ return EINA_FALSE;
+}
+
EOLIAN static Eina_Bool
_elm_spinner_elm_widget_event(Eo *obj, Elm_Spinner_Data *sd EINA_UNUSED, Evas_Object *src, Evas_Callback_Type type, void *event_info)
{
@@ -448,56 +489,22 @@ _elm_spinner_elm_widget_event(Eo *obj, Elm_Spinner_Data *sd EINA_UNUSED, Evas_Ob
Evas_Event_Mouse_Wheel *mev;
(void) src;
- Eina_Bool horz = !!strncmp(elm_widget_style_get(obj), "vertical", 8);
-
if (ev->event_flags & EVAS_EVENT_FLAG_ON_HOLD) return EINA_FALSE;
if (type == EVAS_CALLBACK_KEY_DOWN)
{
- if (( (!strcmp(ev->key, "Left") ||
- ((!strcmp(ev->key, "KP_Left")) && (!ev->string)))
- && horz )
- ||
- ( (!strcmp(ev->key, "Down") ||
- ((!strcmp(ev->key, "KP_Down")) && (!ev->string)))
- && !horz )
- )
- {
- _val_dec_start(obj);
- elm_layout_signal_emit(obj, "elm,left,anim,activate", "elm");
-
- goto success;
- }
- else if (
- ( (!strcmp(ev->key, "Right") ||
- ((!strcmp(ev->key, "KP_Right")) && (!ev->string)))
- && horz )
- ||
- ( (!strcmp(ev->key, "Up") ||
- ((!strcmp(ev->key, "KP_Up")) && (!ev->string)))
- && !horz )
- )
- {
- _val_inc_start(obj);
- elm_layout_signal_emit(obj, "elm,right,anim,activate", "elm");
-
- goto success;
- }
- else if ((!strcmp(ev->key, "Return")) ||
- (!strcmp(ev->key, "KP_Enter")) ||
- (!strcmp(ev->key, "space")))
+ Eina_Bool ret;
+ ret = _elm_config_key_binding_call(obj, ev, key_actions);
+ if (!ret)
{
if (sd->spin_timer) _spin_stop(obj);
- else _entry_toggle_cb(NULL, obj, NULL, NULL);
+ else return EINA_FALSE;
}
- else if (sd->spin_timer) _spin_stop(obj);
}
else if (type == EVAS_CALLBACK_KEY_UP)
{
if (sd->spin_timer) _spin_stop(obj);
else return EINA_FALSE;
-
- goto success;
}
else if (type == EVAS_CALLBACK_MOUSE_WHEEL)
{
@@ -515,10 +522,8 @@ _elm_spinner_elm_widget_event(Eo *obj, Elm_Spinner_Data *sd EINA_UNUSED, Evas_Ob
}
_spin_value(obj);
}
+ else return EINA_FALSE;
- return EINA_FALSE;
-
-success:
ev->event_flags |= EVAS_EVENT_FLAG_ON_HOLD;
return EINA_TRUE;
}