{
TIME_HOUR,
TIME_MIN,
+ TIME_AMPM,
TIME_MAX
};
Evas_Object *time[TIME_MAX];
Ecore_Event_Handler *handler;
Ecore_Idler *idler;
- int layout;
+ unsigned int layout;
int year, month, day, hour, min;
int y_max, m_max, d_max;
static void _del_hook(Evas_Object *obj);
static void _theme_hook(Evas_Object *obj);
static void _sizing_eval(Evas_Object *obj);
-static void _on_focus_hook(void *data, Evas_Object *obj);
+static void _on_focus_hook(void *data __UNUSED__, Evas_Object *obj);
-static void _signal_rect_mouse_down(void *data, Evas_Object *obj, const char *emission, const char *source);
-static void _signal_ampm_clicked(void *data, Evas_Object *obj, const char *emission, const char *source);
-static void _entry_focused_cb(void *data, Evas_Object *obj, void *event_info);
-static void _entry_unfocused_cb(void *data, Evas_Object *obj, void *event_info);
-static void _entry_key_up_cb(void *data, Evas *e , Evas_Object *obj , void *event_info);
-static Eina_Bool _imf_event_commit_cb(void *data, int type, void *event);
-static void _input_panel_event_callback(void *data, Ecore_IMF_Context *ctx, int value);
+static void _signal_rect_mouse_down(void *data, Evas_Object *obj __UNUSED__, const char *emission __UNUSED__, const char *source);
+static void _entry_focused_cb(void *data, Evas_Object *obj, void *event_info __UNUSED__);
+static void _entry_unfocused_cb(void *data, Evas_Object *obj, void *event_info __UNUSED__);
+static void _entry_key_up_cb(void *data __UNUSED__, Evas *e __UNUSED__, Evas_Object *obj , void *event_info);
+static Eina_Bool _imf_event_commit_cb(void *data, int type __UNUSED__, void *event);
+static void _input_panel_event_callback(void *data, Ecore_IMF_Context *ctx __UNUSED__, int value);
static void _date_entry_add(Evas_Object *obj);
static void _time_entry_add(Evas_Object *obj);
if (!wd) return ;
ecore_event_handler_del(wd->handler);
+ ecore_idler_del(wd->idler);
free(wd);
}
static void
-_on_focus_hook(void *data, Evas_Object *obj)
+_on_focus_hook(void *data __UNUSED__, Evas_Object *obj)
{
Widget_Data *wd = elm_widget_data_get(obj);
if (!wd || !wd->base) return ;
- if (elm_widget_focus_get(obj)) wd->idler = ecore_idler_add(_focus_idler_cb, obj);
+ if ((elm_widget_focus_get(obj))&&(!wd->idler)) wd->idler = ecore_idler_add(_focus_idler_cb, obj);
}
static void
Widget_Data *wd = elm_widget_data_get(obj);
char sig[32] = {0,};
int i;
+ char buf[1024];
if (!wd || !wd->base) return;
for (i = 0; i < DATE_MAX; i++)
elm_object_style_set(wd->date[i], "datefield/hybrid");
- for (i = 0; i < TIME_MAX; i++)
+ for (i = 0; i < TIME_MAX-1; i++)
elm_object_style_set(wd->time[i], "datefield/hybrid");
+
+ snprintf(buf, sizeof(buf), "datefield.ampm/%s", elm_widget_style_get(obj));
+ elm_object_style_set(wd->time[TIME_AMPM], buf);
}
else if (wd->layout == ELM_DATEFIELD_LAYOUT_DATE)
{
{
_elm_theme_object_set(obj, wd->base, "datefield", "time", elm_widget_style_get(obj));
- for (i = 0; i < TIME_MAX; i++)
+ for (i = 0; i < TIME_MAX-1; i++)
elm_object_style_set(wd->time[i], "datefield");
+ snprintf(buf, sizeof(buf), "datefield.ampm/%s", elm_widget_style_get(obj));
+ elm_object_style_set(wd->time[TIME_AMPM], buf);
+
for (i = 0; i < DATE_MAX; i++)
evas_object_hide(wd->date[i]);
}
{
edje_object_part_swallow(wd->base, "elm.swallow.time.hour", wd->time[TIME_HOUR]);
edje_object_part_swallow(wd->base, "elm.swallow.time.min", wd->time[TIME_MIN]);
+ edje_object_part_swallow(wd->base, "elm.swallow.time.ampm", wd->time[TIME_AMPM]);
edje_object_part_text_set(wd->base, "elm.text.colon", ":");
}
}
static void
-_signal_ampm_clicked(void *data, Evas_Object *obj, const char *emission, const char *source)
+_ampm_clicked_cb(void *data, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
{
Widget_Data *wd = elm_widget_data_get(data);
char *str;
str = _get_i18n_string(data, PM_STR);
if (str)
{
- edje_object_part_text_set(wd->base, "elm.text.ampm", str);
+ elm_button_label_set(wd->time[TIME_AMPM], str);
free(str);
}
wd->hour += HOUR_12H_MAXIMUM;
str = _get_i18n_string(data, AM_STR);
if (str)
{
- edje_object_part_text_set(wd->base, "elm.text.ampm", str);
+ elm_button_label_set(wd->time[TIME_AMPM], str);
free(str);
}
wd->hour -= HOUR_12H_MAXIMUM;
}
static void
-_signal_rect_mouse_down(void *data, Evas_Object *obj, const char *emission, const char *source)
+_signal_rect_mouse_down(void *data, Evas_Object *obj __UNUSED__, const char *emission __UNUSED__, const char *source)
{
Widget_Data *wd = elm_widget_data_get(data);
if (!wd) return;
elm_object_focus(wd->time[TIME_HOUR]);
else if (!strcmp(source, "elm.rect.time.min.over"))
elm_object_focus(wd->time[TIME_MIN]);
- else if (!strcmp(source, "elm.rect.date.left.pad"))
- {
- switch (wd->date_format)
- {
- case DATE_FORMAT_YYDDMM:
- case DATE_FORMAT_YYMMDD:
- elm_object_focus(wd->date[DATE_YEAR]);
- break;
- case DATE_FORMAT_MMDDYY:
- case DATE_FORMAT_MMYYDD:
- elm_object_focus(wd->date[DATE_MON]);
- break;
- case DATE_FORMAT_DDMMYY:
- case DATE_FORMAT_DDYYMM:
- elm_object_focus(wd->date[DATE_DAY]);
- }
- }
- else if (!strcmp(source, "elm.rect.date.right.pad"))
- {
- switch (wd->date_format)
- {
- case DATE_FORMAT_MMDDYY:
- case DATE_FORMAT_DDMMYY:
- elm_object_focus(wd->date[DATE_YEAR]);
- break;
- case DATE_FORMAT_DDYYMM:
- case DATE_FORMAT_YYDDMM:
- elm_object_focus(wd->date[DATE_MON]);
- break;
- case DATE_FORMAT_YYMMDD:
- case DATE_FORMAT_MMYYDD:
- elm_object_focus(wd->date[DATE_DAY]);
- }
- }
}
static Eina_Bool
}
static void
-_entry_focused_cb(void *data, Evas_Object *obj, void *event_info)
+_entry_focused_cb(void *data, Evas_Object *obj, void *event_info __UNUSED__)
{
Widget_Data *wd = elm_widget_data_get(data);
if (!wd || !wd->base) return;
}
static void
-_entry_unfocused_cb(void *data, Evas_Object *obj, void *event_info)
+_entry_unfocused_cb(void *data, Evas_Object *obj, void *event_info __UNUSED__)
{
Widget_Data *wd = elm_widget_data_get(data);
char str[YEAR_MAX_LENGTH+1] = {0,};
i18n_str = _get_i18n_string(data, PM_STR);
if (i18n_str)
{
- edje_object_part_text_set(wd->base, "elm.text.ampm", i18n_str);
+ elm_button_label_set(wd->time[TIME_AMPM], i18n_str);
free(i18n_str);
}
}
i18n_str = _get_i18n_string(data, AM_STR);
if (i18n_str)
{
- edje_object_part_text_set(wd->base, "elm.text.ampm", i18n_str);
+ elm_button_label_set(wd->time[TIME_AMPM], i18n_str);
free(i18n_str);
}
}
else if (focus_obj == wd->time[TIME_HOUR])
elm_object_focus(wd->time[TIME_MIN]);
else if (focus_obj == wd->time[TIME_MIN])
- elm_object_unfocus(wd->time[TIME_MIN]);
+ elm_object_focus(wd->time[TIME_AMPM]);
+ else if (focus_obj == wd->time[TIME_AMPM])
+ elm_object_unfocus(wd->time[TIME_AMPM]);
}
static int
Widget_Data *wd = elm_widget_data_get(obj);
if (flag == DATE_YEAR)
{
- if (num > wd->y_max) num = wd->y_max;
+ if ((num > wd->y_max)&&(wd->y_max > wd->y_min)) num = wd->y_max;
else if (num < wd->y_min) num = wd->y_min;
return num;
}
}
static void
-_entry_key_up_cb(void *data, Evas *e , Evas_Object *obj , void *event_info)
+_entry_key_up_cb(void *data __UNUSED__, Evas *e __UNUSED__, Evas_Object *obj , void *event_info)
{
Evas_Event_Key_Up *ev = (Evas_Event_Key_Up *) event_info;
}
static Eina_Bool
-_imf_event_commit_cb(void *data, int type, void *event)
+_imf_event_commit_cb(void *data , int type __UNUSED__, void *event)
{
Widget_Data *wd = elm_widget_data_get(data);
Ecore_IMF_Event_Commit *ev = (Ecore_IMF_Event_Commit *) event;
}
static void
-_input_panel_event_callback(void *data, Ecore_IMF_Context *ctx, int value)
+_input_panel_event_callback(void *data, Ecore_IMF_Context *ctx __UNUSED__, int value)
{
Widget_Data *wd = elm_widget_data_get(data);
i18n_str = _get_i18n_string(obj, PM_STR);
if (i18n_str)
{
- edje_object_part_text_set(wd->base, "elm.text.ampm", i18n_str);
+ elm_button_label_set(wd->time[TIME_AMPM], i18n_str);
free(i18n_str);
}
}
i18n_str = _get_i18n_string(obj, AM_STR);
if (i18n_str)
{
- edje_object_part_text_set(wd->base, "elm.text.ampm", i18n_str);
+ elm_button_label_set(wd->time[TIME_AMPM], i18n_str);
free(i18n_str);
}
}
filter_data.max_char_count = 0;
filter_data.max_byte_count = TIME_MAX_LENGTH;
- for (i = 0; i < TIME_MAX; i++)
+ for (i = 0; i < TIME_MAX-1; i++)
{
wd->time[i] = elm_entry_add(obj);
elm_entry_single_line_set(wd->time[i], EINA_TRUE);
evas_object_event_callback_add(wd->time[i], EVAS_CALLBACK_KEY_UP, _entry_key_up_cb, obj);
elm_widget_sub_object_add(obj, wd->time[i]);
}
+ wd->time[TIME_AMPM] = elm_button_add(obj);
+ evas_object_size_hint_weight_set(wd->time[TIME_AMPM], EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+ evas_object_size_hint_align_set(wd->time[TIME_AMPM], EVAS_HINT_FILL, EVAS_HINT_FILL);
+ evas_object_smart_callback_add(wd->time[TIME_AMPM], "clicked", _ampm_clicked_cb, obj);
+ elm_widget_sub_object_add(obj, wd->time[TIME_AMPM]);
}
/**
wd->base = edje_object_add(e);
elm_widget_resize_object_set(obj, wd->base);
- edje_object_signal_callback_add(wd->base, "mouse,down,1", "elm.rect.date.left.pad", _signal_rect_mouse_down, obj);
edje_object_signal_callback_add(wd->base, "mouse,down,1", "elm.rect.date.year.over", _signal_rect_mouse_down, obj);
edje_object_signal_callback_add(wd->base, "mouse,down,1", "elm.rect.date.month.over", _signal_rect_mouse_down, obj);
edje_object_signal_callback_add(wd->base, "mouse,down,1", "elm.rect.date.day.over", _signal_rect_mouse_down, obj);
- edje_object_signal_callback_add(wd->base, "mouse,down,1", "elm.rect.date.right.pad", _signal_rect_mouse_down, obj);
edje_object_signal_callback_add(wd->base, "mouse,down,1", "elm.rect.time.hour.over", _signal_rect_mouse_down, obj);
edje_object_signal_callback_add(wd->base, "mouse,down,1", "elm.rect.time.min.over", _signal_rect_mouse_down, obj);
- edje_object_signal_callback_add(wd->base, "mouse,clicked,1", "elm.rect.time.ampm.over", _signal_ampm_clicked, obj);
wd->handler = ecore_event_handler_add(ECORE_IMF_EVENT_COMMIT, _imf_event_commit_cb, obj);
_date_entry_add(obj);
wd->y_min = 1900;
wd->m_min = 1;
wd->d_min = 1;
- wd->y_max = 2099;
+ wd->y_max = -1;
wd->m_max = 12;
wd->d_max = 31;
wd->year = wd->y_min;
Widget_Data *wd = elm_widget_data_get(obj);
if (!wd) return;
- if (layout < ELM_DATEFIELD_LAYOUT_TIME ||layout > ELM_DATEFIELD_LAYOUT_DATEANDTIME) return;
+ if (layout > ELM_DATEFIELD_LAYOUT_DATEANDTIME) return;
if (wd->layout != layout)
{
ecore_imf_context_input_panel_event_callback_add(
elm_entry_imf_context_get(wd->date[i]), ECORE_IMF_INPUT_PANEL_STATE_EVENT, _input_panel_event_callback, obj);
- for (i = 0; i < TIME_MAX; i++)
+ for (i = 0; i < TIME_MAX-1; i++)
ecore_imf_context_input_panel_event_callback_add(
elm_entry_imf_context_get(wd->time[i]), ECORE_IMF_INPUT_PANEL_STATE_EVENT, _input_panel_event_callback, obj);
}
ecore_imf_context_input_panel_event_callback_del(
elm_entry_imf_context_get(wd->date[i]), ECORE_IMF_INPUT_PANEL_STATE_EVENT, _input_panel_event_callback);
- for (i = 0; i < TIME_MAX; i++)
+ for (i = 0; i < TIME_MAX-1; i++)
ecore_imf_context_input_panel_event_callback_del(
elm_entry_imf_context_get(wd->time[i]), ECORE_IMF_INPUT_PANEL_STATE_EVENT, _input_panel_event_callback);