bugfix: sometimes image shown when textonly setted & dim move from evas_rect(c) to...
[framework/uifw/cbhm.git] / src / clipdrawer.c
index 82307d3..68911ab 100644 (file)
 #include "xcnphandler.h"
 #include "clipdrawer.h"
 
-#define IM     "/mnt/ums/Images/Photo/"
+#define DELETE_ICON_PATH "/usr/share/cbhm/icons/05_delete.png"
+#define IM     "/usr/share/cbhm/icons/"
 static const char *g_images_path[] = {
-       IM"1_photo.jpg",
-       IM"2_photo.jpg",
-       IM"3_photo.jpg",
-       IM"4_photo.jpg",
-       IM"5_photo.jpg",
-       IM"6_photo.jpg",
+       IM"cbhm_default_img.png",
 };
-#define N_IMAGES (6)
+#define N_IMAGES (1)
 
-// FIXME: how to remove main_ad? 
-//        it's mainly used at 'clipdrawer_add_image_item'
-struct appdata *g_main_ad = NULL;
+#define GRID_ITEM_SPACE_W 6
+#define GRID_ITEM_SINGLE_W 185
+#define GRID_ITEM_SINGLE_H 161
+#define GRID_ITEM_W (GRID_ITEM_SINGLE_W+(GRID_ITEM_SPACE_W*2))
+#define GRID_ITEM_H (GRID_ITEM_SINGLE_H)
+#define GRID_IMAGE_LIMIT_W 91
+#define GRID_IMAGE_LIMIT_H 113
+
+#define ANIM_DURATION 30 // 1 seconds
+#define ANIM_FLOPS (0.5/30)
 
 // gic should live at gengrid callback functions
 Elm_Gengrid_Item_Class gic;
+static Ecore_Timer *anim_timer = NULL;
 
-typedef struct tag_gridimgitem
+typedef struct tag_griditem
 {
+       int itype;
        Elm_Gengrid_Item *item;
-       const char *path;
-} gridimgitem_t;
+       const char *ipathdata;
+       Eina_Strbuf *istrdata;
+       Evas_Object *delbtn;
+       Evas_Object *ilayout;
+} griditem_t;
+
+const char *
+remove_tags(const char *p)
+{
+   char *q,*ret;
+   int i;
+   if (!p) return NULL;
+
+   q = malloc(strlen(p) + 1);
+   if (!q) return NULL;
+   ret = q;
+
+   while (*p)
+     {
+        if ((*p != '<')) *q++ = *p++;
+        else if (*p == '<')
+          {
+             if ((p[1] == 'b') && (p[2] == 'r') &&
+                 ((p[3] == ' ') || (p[3] == '/') || (p[3] == '>')))
+               *q++ = '\n';
+             while ((*p) && (*p != '>')) p++;
+             p++;
+          }
+     }
+   *q = 0;
+
+   return ret;
+}
 
-static void _list_click( void *data, Evas_Object *obj, void *event_info )
+const char* clipdrawer_get_plain_string_from_escaped(char *escstr)
 {
-       struct appdata *ad = data;
-    Elm_List_Item *it = (Elm_List_Item *) elm_list_selected_item_get(obj);
-       if (it == NULL)
-               return;
+       /* NOTE : return string should be freed */
+       return remove_tags(escstr);
+}
 
-    elm_list_item_selected_set(it, 0);
+static char* _get_string_for_entry(char *str)
+{
+       if (!str)
+               return NULL;
 
-       char *p = NULL;
-       int cplen;
+       Eina_Strbuf *strbuf = eina_strbuf_new();
+       if (!strbuf)
+               return strdup(str);
+       eina_strbuf_prepend(strbuf, "<font_size=18>");
 
-       char *cpdata = NULL;
-       cpdata = elm_list_item_label_get(it);
-       if (cpdata == NULL)
-               return;
-       cplen = strlen(cpdata);
-       p = malloc(cplen + 1);
-       snprintf(p, cplen+1, "%s", cpdata);
-       elm_selection_set(1, obj, /*ELM_SEL_FORMAT_TEXT*/1, p);
-//     elm_selection_set(1, obj, /*ELM_SEL_FORMAT_MARKUP*/2, p);
+       char *trail = str;
+
+       while (trail && *trail)
+       {
+               char *pretrail = trail;
+               unsigned long length;
+               char *temp;
+               char *endtag;
+
+               trail = strchr(trail, '<');
+               if (!trail)
+               {
+                       eina_strbuf_append(strbuf, pretrail);
+                       break;
+               }
+               endtag = strchr(trail, '>');
+               if (!endtag)
+                       break;
+
+               length = trail - pretrail;
+
+               temp = strndup(pretrail, length);
+               if (!temp)
+               {
+                       trail++;
+                       continue;
+               }
+
+               DTRACE("temp str: %s \n", temp);
+               eina_strbuf_append(strbuf, temp);
+               free(temp);
+               trail++;
+
+               if (trail[0] == '/')
+               {
+                       trail = endtag + 1;
+                       continue;
+               }
+
+               if (strncmp(trail, "br", 2) == 0)
+               {
+                       eina_strbuf_append(strbuf, "<br>");
+                       trail = endtag + 1;
+                       continue;
+               }
+
+               if (strncmp(trail, "img", 3) == 0)
+               {
+                       char *src = strstr(trail, "file://");
+                       char *src_endtag = strchr(trail, '>');
+                       if (!src || !src_endtag || src_endtag < src)
+                               continue;
+
+                       length = src_endtag - src;
+
+                       src = strndup(src, length);
+                       if (!src)
+                       {
+                               trail = endtag + 1;
+                               continue;
+                       }
+                       temp = src;
+                       while(*temp)
+                       {
+                               if (*temp == '\"' || *temp == '>')
+                                       *temp = '\0';
+                               else
+                                       temp++;
+                       }
+
+                       eina_strbuf_append_printf(strbuf, "<item absize=66x62 href=%s></item>", src);
+                       DTRACE("src str: %s \n", src);
+                       free(src);
+               }
+               trail = endtag + 1;
+       }
 
-       clipdrawer_lower_view(ad);
+       char *ret = eina_strbuf_string_steal(strbuf);
+       eina_strbuf_free(strbuf);
+       DTRACE("result str: %s \n", ret);
+       return ret;
 }
 
-int clipdrawer_update_contents(void *data)
+static void _grid_del_response_cb(void *data, Evas_Object *obj, void *event_info)
 {
-       struct appdata *ad = data;
-       int i, pos;
+       Elm_Gengrid_Item *it = (Elm_Gengrid_Item *)data;
+       evas_object_del(obj);
 
-       elm_list_clear(ad->txtlist);
-       for (i = 0; i < HISTORY_QUEUE_NUMBER; i++)
+       if((int)event_info == ELM_POPUP_RESPONSE_OK)
        {
-               pos = get_current_history_position()+i;
-               if (pos > HISTORY_QUEUE_NUMBER-1)
-                       pos = pos-HISTORY_QUEUE_NUMBER;
-               if (get_item_contents_by_pos(pos) != NULL && strlen(get_item_contents_by_pos(pos)) > 0)
+               struct appdata *ad = g_get_main_appdata();
+               elm_gengrid_item_del(it);
+               ad->hicount--;
+               if (ad->hicount < 0)
                {
-                       elm_list_item_append(ad->txtlist, get_item_contents_by_pos(pos), NULL, NULL, NULL, ad);
+                       int cnt = 0;
+                       Elm_Gengrid_Item *trail = elm_gengrid_first_item_get(ad->hig);
+                       while(trail)
+                       {
+                               cnt++;
+                               elm_gengrid_item_next_get(trail);
+                       }
+                       ad->hicount = cnt;
+                       DTRACE("ERR: cbhm history cnt < 0, gengrid item cnt: %d\n", cnt);
                }
        }
-       elm_list_go(ad->txtlist);
-
-       /* FIXME : sometimes when list update, screen isn't updated */
+}
 
-       return 0;
+static void _grid_click_delete(void *data, Evas_Object *obj, void *event_info)
+{
+       struct appdata *ad = data;
 }
 
-const char* clipdrawer_get_plain_string_from_escaped(char *escstr)
+static void
+_grid_item_ly_clicked(void *data, Evas_Object *obj, const char *emission, const char *source)
 {
-       /* TODO : is it should be here? besides, remove dependency for entry */
-       /* NOTE : return string should be freed */
-       return elm_entry_markup_to_utf8(escstr);
+       struct appdata *ad = g_get_main_appdata();
+
+       if (ad->anim_status != STATUS_NONE)
+               return;
+
+       Elm_Gengrid_Item *sgobj = NULL;
+       sgobj = elm_gengrid_selected_item_get(ad->hig);
+       griditem_t *ti = NULL;
+       ti = elm_gengrid_item_data_get(sgobj);
+
+       #define EDJE_DELBTN_PART_PREFIX "delbtn"
+       if (strncmp(source, EDJE_DELBTN_PART_PREFIX, strlen(EDJE_DELBTN_PART_PREFIX)))
+       {
+               if (!sgobj || !ti)
+               {
+                       DTRACE("ERR: cbhm can't get the selected image\n");
+                       return;
+               }
+
+               elm_gengrid_item_selected_set(sgobj, EINA_FALSE);
+
+               if (ti->itype == GI_TEXT)
+               {
+                       char *p = strdup(eina_strbuf_string_get(ti->istrdata));
+
+                       elm_selection_set(1, ad->hig, /*ELM_SEL_FORMAT_HTML*/0x10, p);
+               }
+               else //if (ti->itype == GI_IMAGE)
+               {
+                       if (!clipdrawer_paste_textonly_get(ad))
+                       {
+                               int len = strlen(ti->ipathdata);
+                               char *p = malloc(len + 10);
+                               snprintf(p,len+10, "file:///%s", ti->ipathdata);
+
+                               elm_selection_set(/*secondary*/1, ad->hig,/*ELM_SEL_FORMAT_IMAGE*/4,p);
+                       }
+                       else
+                       {
+                               DTRACE("ERR: cbhm image paste mode is false\n");
+                       }
+               }
+               return;
+       }
+
+       if (!sgobj)
+       {
+               DTRACE("ERR: cbhm can't get the selected item\n");
+               return;
+       }
+
+       elm_gengrid_item_selected_set(sgobj, EINA_FALSE);
+
+       Evas_Object *popup = elm_popup_add(ad->win_main);
+       elm_popup_timeout_set(popup, 5);
+       evas_object_size_hint_weight_set(popup, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+       elm_popup_desc_set(popup, "Are you sure delete this?");
+       elm_popup_buttons_add(popup, 2,
+                                                 "Yes", ELM_POPUP_RESPONSE_OK,
+                                                 "No", ELM_POPUP_RESPONSE_CANCEL,
+                                                 NULL);
+       evas_object_smart_callback_add(popup, "response", _grid_del_response_cb, sgobj);
+       evas_object_show(popup);
 }
 
-Evas_Object* grid_icon_get(const void *data, Evas_Object *obj, const char *part)
+Evas_Object* _grid_icon_get(const void *data, Evas_Object *obj, const char *part)
 {
-       gridimgitem_t *ti = (gridimgitem_t *)data;
+       griditem_t *ti = (griditem_t *)data;
+
        if (!strcmp(part, "elm.swallow.icon"))
        {
-               Evas_Object *icon = elm_icon_add(obj);
-               elm_icon_file_set(icon, ti->path, NULL);
-               evas_object_size_hint_aspect_set(icon, EVAS_ASPECT_CONTROL_VERTICAL, 1, 1);
-               evas_object_show(icon);
-               return icon;
+               if (ti->itype == GI_TEXT)
+               {
+                       Evas_Object *layout = elm_layout_add (obj);
+                       elm_layout_theme_set(layout, "gengrid", "widestyle", "horizontal_layout");
+                       edje_object_signal_callback_add(elm_layout_edje_get(layout), 
+                                                                                       "mouse,up,1", "*", _grid_item_ly_clicked, data);
+                       Evas_Object *rect = evas_object_rectangle_add(evas_object_evas_get(obj));
+                       evas_object_resize(rect, GRID_ITEM_W, GRID_ITEM_H);
+                       evas_object_color_set(rect, 242, 233, 183, 255);
+                       evas_object_show(rect);
+                       elm_layout_content_set(layout, "elm.swallow.icon", rect);
+
+                       // FIXME: add string length check
+                       Evas_Object *ientry = elm_entry_add(obj);
+                       evas_object_size_hint_weight_set(ientry, 0, 0);
+                       Eina_Strbuf *strent = NULL;
+                       char *strdata = eina_strbuf_string_get(ti->istrdata);
+                       int i, skipflag, strcnt;
+                       
+                       strent = eina_strbuf_new();
+                       skipflag = 0;
+                       strcnt = 0;
+                       for (i = 0; i < eina_strbuf_length_get(ti->istrdata); i++)
+                       {
+                               switch (strdata[i])
+                               {
+                                       case '>':
+                                               skipflag = 0;
+                                               break;
+                                       case '<':
+                                               skipflag = 1;
+                                               break;
+                                       default:
+                                               if (!skipflag)
+                                                       strcnt++;
+                                               break;
+                               }
+                               if (strcnt > 100)
+                                       break;
+                       }
+                       eina_strbuf_append_n(strent, strdata, i);
+                       eina_strbuf_replace_all(strent, " absize=240x180 ", " absize=52x39 ");
+                       if (strcnt > 100)
+                               eina_strbuf_append(strent, "...");
+                       elm_entry_scrollable_set(ientry, EINA_TRUE);
+                       char *entry_text = eina_strbuf_string_get(strent);
+                       entry_text = _get_string_for_entry(entry_text);
+                       if (entry_text)
+                       {
+                               elm_object_text_part_set(ientry, NULL, entry_text);
+                               free(entry_text);
+                       }
+                       elm_entry_editable_set(ientry, EINA_FALSE);
+                       elm_entry_context_menu_disabled_set(ientry, EINA_TRUE);
+                       evas_object_show(ientry);
+                       elm_layout_content_set(layout, "elm.swallow.inner", ientry);
+
+                       eina_strbuf_free(strent);
+
+                       return layout;
+               }
+               else// if (ti->itype == GI_IMAGE)
+               {
+                       Evas_Object *layout = elm_layout_add (obj);
+                       elm_layout_theme_set(layout, "gengrid", "widestyle", "horizontal_layout");
+                       edje_object_signal_callback_add(elm_layout_edje_get(layout), 
+                                                                                       "mouse,up,1", "*", _grid_item_ly_clicked, data);
+
+                       Evas_Object *sicon;
+                       sicon = evas_object_image_add(evas_object_evas_get(obj));
+                       evas_object_image_load_size_set(sicon, GRID_ITEM_SINGLE_W, GRID_ITEM_SINGLE_H);
+                       evas_object_image_file_set(sicon, ti->ipathdata, NULL);
+                       evas_object_image_fill_set(sicon, 0, 0, GRID_ITEM_SINGLE_W, GRID_ITEM_SINGLE_H);
+                       evas_object_resize(sicon, GRID_ITEM_SINGLE_W, GRID_ITEM_SINGLE_H);
+                       elm_layout_content_set(layout, "elm.swallow.icon", sicon);
+
+                       struct appdata *ad = g_get_main_appdata();
+                       
+                       if (clipdrawer_paste_textonly_get(ad))
+                               edje_object_signal_emit(elm_layout_edje_get(layout), "elm,state,show,dim", "elm");
+                       else
+                               edje_object_signal_emit(elm_layout_edje_get(layout), "elm,state,hide,dim", "elm");
+
+                       ti->ilayout = layout;
+                       return layout;
+               }
        }
+
        return NULL;
 }
 
-static void grid_selected(void *data, Evas_Object *obj, void *event_info)
+static void _grid_longpress(void *data, Evas_Object *obj, void *event_info)
 {
        struct appdata *ad = data;
-       char *file, *p;
-       int len;
+}
+
+static void _grid_click_paste(void *data, Evas_Object *obj, void *event_info)
+{
+       struct appdata *ad = data;
+       if (ad->anim_status != STATUS_NONE)
+               return;
+
        Elm_Gengrid_Item *sgobj = NULL;
-       sgobj = elm_gengrid_selected_item_get(ad->imggrid);
-       gridimgitem_t *ti = NULL;
+       sgobj = elm_gengrid_selected_item_get(ad->hig);
+       griditem_t *ti = NULL;
        ti = elm_gengrid_item_data_get(sgobj);
+}
 
-       if (!sgobj || !ti)
-       {
-               DTRACE("ERR: cbhm can't get the selected image\n");
-               return;
-       }
-       len = strlen(ti->path);
-       p = malloc(len + 10);
-       snprintf(p,len+10, "file:///%s", ti->path);
+void _grid_del(const void *data, Evas_Object *obj)
+{
+       griditem_t *ti = (griditem_t *)data;
+       if (ti->itype == GI_TEXT)
+               eina_strbuf_free(ti->istrdata);
+       else
+               eina_stringshare_del(ti->ipathdata);
+       free(ti);
+}
 
-       fprintf(stderr, "## sel path = %s_\n", p);
+char* clipdrawer_get_item_data(void *data, int pos)
+{
+       struct appdata *ad = data;
+       griditem_t *ti = NULL;
+       griditem_t *newgi = NULL;
+       int count = 0;
 
-       elm_selection_set(/*secondary*/1,obj,/*ELM_SEL_FORMAT_IMAGE*/4,p);
+       if (pos < 0 || pos > ad->hicount)
+               return NULL;
 
-       clipdrawer_lower_view(ad);
+       Elm_Gengrid_Item *item = elm_gengrid_first_item_get(ad->hig);
+       while (item)
+       {
+               ti = elm_gengrid_item_data_get(item);
+               if (count == pos)
+               {
+                       if (!ti)
+                               break;
+                       if (ti->itype == GI_TEXT)
+                               return (char*)eina_strbuf_string_get(ti->istrdata);
+                       else
+                               return ti->ipathdata;
+               }
+               count++;
+               item = elm_gengrid_item_next_get(item);
+       }
 
-       elm_gengrid_item_selected_set(sgobj, EINA_FALSE);
+       return NULL;
 }
 
-void grid_del(const void *data, Evas_Object *obj)
+// FIXME: how to remove calling g_get_main_appdata()? 
+//        it's mainly used at 'clipdrawer_image_item'
+int clipdrawer_add_item(char *idata, int type)
 {
-       gridimgitem_t *ti = (gridimgitem_t *)data;
-       eina_stringshare_del(ti->path);
-       free(ti);
-}
+       struct appdata *ad = g_get_main_appdata();
+       griditem_t *newgi = NULL;
 
-// FIXME: how to remove main_ad? 
-//        it's mainly used at 'clipdrawer_add_image_item'
-int clipdrawer_add_image_item(char *imagepath)
-{
-//     struct appdata *ad = data;
-       gridimgitem_t *newgenimg = NULL;
-       char* filepath = NULL;
-       filepath = &imagepath[7]; // skip 'file://'
+       newgi = malloc(sizeof(griditem_t));
+       newgi->itype = type;
+
+       fprintf(stderr, "## add - %d : %s\n", newgi->itype, idata);
+       if (type == GI_TEXT)
+       {
+               newgi->istrdata = eina_strbuf_new();
+               eina_strbuf_append(newgi->istrdata, idata);
+       }
+       else //if (type == GI_IMAGE)
+       {
+               Elm_Gengrid_Item *item = elm_gengrid_first_item_get(ad->hig);
+               griditem_t *ti = NULL;
+
+               if (!check_regular_file(idata))
+               {
+                       DTRACE("Error : it isn't normal file = %s\n", idata);
+                       return -1;
+               }
 
-       fprintf(stderr, "## image_path = %s_\n", filepath);
-       newgenimg = malloc(sizeof(gridimgitem_t));
-       newgenimg->path = eina_stringshare_add(filepath);
-       newgenimg->item = elm_gengrid_item_append(g_main_ad->imggrid, &gic, newgenimg, NULL, NULL);
+               while (item)
+               {
+                       ti = elm_gengrid_item_data_get(item);
+                       if ((ti->itype == type) && !strcmp(ti->ipathdata, idata))
+                       {
+                               DTRACE("Error : duplicated file path = %s\n", idata);
+                               return -1;
+                       }
+                       item = elm_gengrid_item_next_get(item);
+               }
+               newgi->ipathdata = eina_stringshare_add(idata);
+       }
+
+       if (ad->hicount >= HISTORY_QUEUE_MAX_ITEMS)
+       {
+               ad->hicount--;
+               // FIXME: add routine that is removing its elements
+               elm_gengrid_item_del(elm_gengrid_last_item_get(ad->hig));
+       }
+
+       ad->hicount++;
+       newgi->item = elm_gengrid_item_prepend(ad->hig, &gic, newgi, NULL, NULL);
 
        return TRUE;
 }
@@ -154,81 +473,154 @@ clipdrawer_ly_clicked(void *data, Evas_Object *obj, const char *emission, const
 {
        struct appdata *ad = data;
 
-       #define EDJE_CLOSE_PART_PREFIX "closebutton/"
+       if (ad->anim_status != STATUS_NONE)
+               return;
+
+       #define EDJE_CLOSE_PART_PREFIX "background/close"
        if (!strncmp(source, EDJE_CLOSE_PART_PREFIX, strlen(EDJE_CLOSE_PART_PREFIX)))
        {
                clipdrawer_lower_view(ad);
        }
 }
 
+static void set_sliding_win_geometry(void *data)
+{
+       struct appdata *ad = data;
+       Ecore_X_Window zone, xwin;
+       Evas_Coord x, y, w, h;
+       xwin = elm_win_xwindow_get(ad->win_main);
+       zone = ecore_x_e_illume_zone_get(xwin);
+       DTRACE("[CBHM] xwin:%x, zone:%x\n", xwin, zone);
+
+//     ecore_evas_geometry_get(ecore_evas_ecore_evas_get(evas_object_evas_get(ad->win_main)), &x, &y, &w, &h);
+
+       if (ad->o_degree == 90 || ad->o_degree == 270)
+       {
+               h = ad->anim_count/30.0 * CLIPDRAWER_HEIGHT_LANDSCAPE;
+               x = 0;
+               y = ad->root_w - h;
+               w = ad->root_h;
+       }
+       else
+       {
+               h = ad->anim_count/30.0 * CLIPDRAWER_HEIGHT;
+               x = 0;
+               y = ad->root_h - h;
+               w = ad->root_w;
+       }
+
+       if (!h)
+               w = 0;
+
+       DTRACE("[CBHM] change degree geometry... (%d, %d, %d x %d)\n", x, y, w, h);
+       ecore_x_e_illume_sliding_win_geometry_set(zone, x, y, w, h);
+       ecore_x_e_illume_sliding_win_state_set(zone, ad->anim_count != 0);
+}
+
+void set_rotation_to_clipdrawer(void *data)
+{
+       struct appdata *ad = data;
+       double wh, wy;
+       int wposx, wwidth;
+       int angle = ad->o_degree;
+
+       if (angle == 180) // reverse
+       {
+               wh = (1.0*CLIPDRAWER_HEIGHT/SCREEN_HEIGHT)*ad->root_h;
+               wy = 0;
+               wwidth = ad->root_w;
+               wposx = CLIPDRAWER_POS_X;
+       }
+       else if (angle == 90) // right rotate
+       {
+               wh = (1.0*CLIPDRAWER_HEIGHT_LANDSCAPE/SCREEN_WIDTH)*ad->root_w;
+               wy = (1.0*CLIPDRAWER_POS_X/SCREEN_WIDTH)*ad->root_w;
+               wwidth = ad->root_h;
+               wposx = CLIPDRAWER_WIDTH-CLIPDRAWER_HEIGHT_LANDSCAPE;
+       }
+       else if (angle == 270) // left rotate
+       {
+               wh = (1.0*CLIPDRAWER_HEIGHT_LANDSCAPE/SCREEN_WIDTH)*ad->root_w;
+               wy = (1.0*CLIPDRAWER_POS_X/SCREEN_WIDTH)*ad->root_w;
+               wwidth = ad->root_h;
+               wposx = CLIPDRAWER_POS_X;
+       }
+       else // angle == 0
+       {
+               wh = (1.0*CLIPDRAWER_HEIGHT/SCREEN_HEIGHT)*ad->root_h;
+               wy = (1.0*CLIPDRAWER_POS_Y/SCREEN_HEIGHT)*ad->root_h;
+               wwidth = ad->root_w;
+               wposx = CLIPDRAWER_POS_X;
+       }
+
+       evas_object_resize(ad->win_main, wwidth, (int)wh);
+       evas_object_move(ad->win_main, wposx, (int)wy);
+       if (ad->anim_count == ANIM_DURATION)
+               set_sliding_win_geometry(data);
+}
+
 int clipdrawer_init(void *data)
 {
        struct appdata *ad = data;
-       g_main_ad = ad;
+       double cdy, cdw;
 
-       evas_object_resize(ad->win_main, CLIPDRAWER_WIDTH, CLIPDRAWER_HEIGHT);
-       evas_object_move(ad->win_main, CLIPDRAWER_POS_X, CLIPDRAWER_POS_Y);
-       evas_object_resize(ad->ly_main, CLIPDRAWER_WIDTH, CLIPDRAWER_HEIGHT);
-       evas_object_move(ad->ly_main, CLIPDRAWER_POS_X, CLIPDRAWER_POS_Y);
+       ad->windowshow = EINA_FALSE;
+       ad->hicount = 0;
+       ad->pastetextonly = EINA_TRUE;
+       ad->anim_status = STATUS_NONE;
+       ad->anim_count = 0;
 
-       edje_object_signal_callback_add(elm_layout_edje_get(ad->ly_main), "mouse,up,1", "*", clipdrawer_ly_clicked, ad);
+       // for elm_check
+       elm_theme_extension_add(NULL, APP_EDJ_FILE);
 
-       ad->imggrid = NULL;
-       ad->imggrid = elm_gengrid_add(ad->win_main);
-       elm_layout_content_set(ad->ly_main, "imagehistory/list", ad->imggrid);
-       elm_gengrid_item_size_set(ad->imggrid, 100, 100+3);
-       elm_gengrid_align_set(ad->imggrid, 0.5, 0.0);
-       elm_gengrid_horizontal_set(ad->imggrid, EINA_TRUE);
-       elm_gengrid_bounce_set(ad->imggrid, EINA_TRUE, EINA_FALSE);
-       elm_gengrid_multi_select_set(ad->imggrid, EINA_FALSE);
-       evas_object_smart_callback_add(ad->imggrid, "selected", grid_selected, ad);
-       evas_object_size_hint_weight_set(ad->imggrid, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+       edje_object_signal_callback_add(elm_layout_edje_get(ad->ly_main), 
+                                                                       "mouse,up,1", "*", clipdrawer_ly_clicked, ad);
 
+       ad->hig = NULL;
+       ad->hig = elm_gengrid_add(ad->win_main);
+       elm_layout_content_set(ad->ly_main, "historyitems", ad->hig);
+       elm_gengrid_item_size_set(ad->hig, GRID_ITEM_W+2, GRID_ITEM_H);
+       elm_gengrid_align_set(ad->hig, 0.5, 0.5);
+       elm_gengrid_horizontal_set(ad->hig, EINA_TRUE);
+       elm_gengrid_bounce_set(ad->hig, EINA_TRUE, EINA_FALSE);
+       elm_gengrid_multi_select_set(ad->hig, EINA_FALSE);
+       evas_object_smart_callback_add(ad->hig, "selected", _grid_click_paste, ad);
+//     evas_object_smart_callback_add(ad->hig, "longpressed", _grid_longpress, ad);
+       evas_object_size_hint_weight_set(ad->hig, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
 
-       elm_gengrid_clear(ad->imggrid);
+       elm_gengrid_clear(ad->hig);
 
        gic.item_style = "default_grid";
        gic.func.label_get = NULL;
-       gic.func.icon_get = grid_icon_get;
+       gic.func.icon_get = _grid_icon_get;
        gic.func.state_get = NULL;
-       gic.func.del = grid_del;
+       gic.func.del = _grid_del;
 
        int i;
-       gridimgitem_t *newgenimg;
+       griditem_t *newgi;
 
        for (i = 0; i < N_IMAGES; i++)
        {
-               newgenimg = malloc(sizeof(gridimgitem_t));
-               newgenimg->path = eina_stringshare_add(g_images_path[i]);
-               newgenimg->item = elm_gengrid_item_append(ad->imggrid, &gic, newgenimg, NULL, NULL);
-//             evas_object_data_set(newgenimg->item, "URI", g_images_path[i]);
+               clipdrawer_add_item(g_images_path[0], GI_IMAGE);
        }
 
-       evas_object_show (ad->imggrid);
+       clipdrawer_add_item("clipboard history", GI_TEXT);
+
+       evas_object_show (ad->hig);
 
-// for debugging, calc image history pos
+// for debugging, calc history pos
 /*
    Evas_Coord x, y, w, h;
    Evas_Coord vx, vy, vw, vh;
 
    edje_object_part_geometry_get(elm_layout_edje_get(ad->ly_main),"imagehistory/list",&x,&y,&w,&h);
-   evas_object_geometry_get (ad->imggrid, &vx,&vy,&vw,&vh);
+   evas_object_geometry_get (ad->hig, &vx,&vy,&vw,&vh);
    fprintf(stderr, "## x = %d, y = %d, w = %d, h = %d\n", x, y, w, h);
    fprintf(stderr, "## vx = %d, vy = %d, vw = %d, vh = %d\n", vx, vy, vw, vh);
 */
 
-       ad->txtlist = elm_list_add(ad->win_main);
-       elm_layout_content_set(ad->ly_main, "texthistory/list", ad->txtlist);
-       elm_theme_extension_add(NULL, APP_EDJ_FILE);
-       elm_object_style_set(ad->txtlist, "extended/historylist");
-       evas_object_size_hint_weight_set(ad->txtlist, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
-       evas_object_smart_callback_add(ad->txtlist, "selected", _list_click, ad);
-       elm_list_item_append(ad->txtlist, "default", NULL, NULL, NULL, ad);
-
-       elm_list_go(ad->txtlist);
-
-       if (get_item_counts() != 0)
-               clipdrawer_update_contents(ad);
+//     if (get_item_counts() != 0)
+//             clipdrawer_update_contents(ad);
 
        return 0;
 }
@@ -246,14 +638,174 @@ int clipdrawer_create_view(void *data)
        return 0;
 }
 
-void clipdrawer_activate_view(void *data)
+Eina_Bool _get_anim_pos(void *data, int *sp, int *ep)
+{
+       if (!sp || !ep)
+               return EINA_FALSE;
+
+       struct appdata *ad = data;
+       int angle = ad->o_degree;
+       int anim_start, anim_end, delta;
+
+       if (angle == 180) // reverse
+       {
+               anim_start = (int)(((double)CLIPDRAWER_HEIGHT/SCREEN_HEIGHT)*ad->root_h);
+               anim_start = ad->root_h - anim_start;
+               anim_start = -anim_start;
+               anim_end = 0;
+       }
+       else if (angle == 90) // right rotate
+       {
+               anim_start = ad->root_w;
+               anim_end = (int)(((double)CLIPDRAWER_HEIGHT_LANDSCAPE/SCREEN_WIDTH)*ad->root_w);
+               anim_end = anim_start-anim_end;
+       }
+       else if (angle == 270) // left rotate
+       {
+               anim_start = (int)(((double)CLIPDRAWER_HEIGHT_LANDSCAPE/SCREEN_WIDTH)*ad->root_w);
+               anim_start = ad->root_w-anim_start;
+               anim_start = -anim_start;
+               anim_end = 0;
+       }
+       else // angle == 0
+       {
+               anim_start = ad->root_h;
+               anim_end = (int)(((double)CLIPDRAWER_HEIGHT/SCREEN_HEIGHT)*ad->root_h);
+               anim_end = anim_start-anim_end;
+       }
+
+       *sp = anim_start;
+       *ep = anim_end;
+       return EINA_TRUE;
+}
+
+Eina_Bool _do_anim_delta_pos(void *data, int sp, int ep, int ac, int *dp)
 {
+       if (!dp)
+               return EINA_FALSE;
+
        struct appdata *ad = data;
+       int angle = ad->o_degree;
+       int delta;
+       double posprop;
+       posprop = 1.0*ac/ANIM_DURATION;
+
+       if (angle == 180) // reverse
+       {
+               delta = (int)((ep-sp)*posprop);
+               evas_object_move(ad->win_main, 0, sp+delta);
+       }
+       else if (angle == 90) // right rotate
+       {
+               delta = (int)((ep-sp)*posprop);
+               evas_object_move(ad->win_main, sp+delta, 0);
+       }
+       else if (angle == 270) // left rotate
+       {
+               delta = (int)((ep-sp)*posprop);
+               evas_object_move(ad->win_main, sp+delta, 0);
+       }
+       else // angle == 0
+       {
+               delta = (int)((sp-ep)*posprop);
+               evas_object_move(ad->win_main, 0, sp-delta);
+       }
        
+       *dp = delta;
+
+       return EINA_TRUE;
+}
+
+static void stop_animation(void *data)
+{
+       struct appdata *ad = data;
+
+       ad->anim_status = STATUS_NONE;
+       if (anim_timer)
+       {
+               ecore_timer_del(anim_timer);
+               anim_timer = NULL;
+       }
+
+       set_sliding_win_geometry(data);
+}
+
+Eina_Bool anim_pos_calc_cb(void *data)
+{
+       struct appdata *ad = data;
+
+       int anim_start, anim_end, delta;
+
+       _get_anim_pos(ad, &anim_start, &anim_end);
+
+       if (ad->anim_status == SHOW_ANIM)
+       {
+               if (ad->anim_count > ANIM_DURATION)
+               {
+                       ad->anim_count = ANIM_DURATION;
+                       stop_animation(data);
+                       return EINA_FALSE;
+               }
+               _do_anim_delta_pos(ad, anim_start, anim_end, ad->anim_count, &delta);
+               ad->anim_count++;
+       }
+       else if (ad->anim_status == HIDE_ANIM)
+       {
+               if (ad->anim_count < 0)
+               {
+                       ad->anim_count = 0;
+                       evas_object_hide(ad->win_main);
+                       elm_win_lower(ad->win_main);
+                       unset_transient_for(ad);
+                       stop_animation(data);
+                       return EINA_FALSE;
+               }
+               _do_anim_delta_pos(ad, anim_start, anim_end, ad->anim_count, &delta);
+               ad->anim_count--;
+       }
+       else
+       {
+               stop_animation(data);
+               return EINA_FALSE;
+       }
+
+       return EINA_TRUE;
+}
+
+Eina_Bool clipdrawer_anim_effect(void *data, anim_status_t atype)
+{
+       struct appdata *ad = data;
+
+       if (atype == ad->anim_status)
+       {
+               DTRACE("Warning: Animation effect is already in progress. \n");
+               return EINA_FALSE;
+       }
+
+       ad->anim_status = atype;
+
+       if (anim_timer)
+               ecore_timer_del(anim_timer);
+
+       anim_timer = ecore_timer_add(ANIM_FLOPS, anim_pos_calc_cb, ad);
+
+       return EINA_TRUE;
+}
+
+void clipdrawer_activate_view(void *data)
+{
+       struct appdata *ad = data;
+
        if (ad->win_main)
        {
+               set_transient_for(ad);
+               ad->o_degree = get_active_window_degree(ad->active_win);
+               elm_win_rotation_set(ad->win_main, ad->o_degree);
+               set_rotation_to_clipdrawer(data);
                evas_object_show(ad->win_main);
                elm_win_activate(ad->win_main);
+               if (clipdrawer_anim_effect(ad, SHOW_ANIM))
+                       ad->windowshow = EINA_TRUE;
        }
 }
 
@@ -261,9 +813,48 @@ void clipdrawer_lower_view(void *data)
 {
        struct appdata *ad = data;
        
-       if (ad->win_main)
+       if (ad->win_main && ad->windowshow)
+       {
+               if (clipdrawer_anim_effect(ad, HIDE_ANIM))
+                       ad->windowshow = EINA_FALSE;
+       }
+}
+
+void _change_gengrid_paste_textonly_mode(void *data)
+{
+       struct appdata *ad = data;
+
+       griditem_t *ti = NULL;
+
+       Elm_Gengrid_Item *item = elm_gengrid_first_item_get(ad->hig);
+
+       while (item)
        {
-               evas_object_hide(ad->win_main);
-               elm_win_lower(ad->win_main);
+               ti = elm_gengrid_item_data_get(item);
+               if ((ti->itype == GI_IMAGE) && (ti->ilayout))
+               {
+                       if (clipdrawer_paste_textonly_get(ad))
+                               edje_object_signal_emit(elm_layout_edje_get(ti->ilayout), "elm,state,show,dim", "elm");
+                       else
+                               edje_object_signal_emit(elm_layout_edje_get(ti->ilayout), "elm,state,hide,dim", "elm");
+               }
+               item = elm_gengrid_item_next_get(item);
        }
 }
+
+void clipdrawer_paste_textonly_set(void *data, Eina_Bool textonly)
+{
+       struct appdata *ad = data;
+       textonly = !!textonly;
+       if (ad->pastetextonly != textonly)
+               ad->pastetextonly = textonly;
+       DTRACE("paste textonly mode = %d\n", textonly);
+
+       _change_gengrid_paste_textonly_mode(ad);
+}
+
+Eina_Bool clipdrawer_paste_textonly_get(void *data)
+{
+       struct appdata *ad = data;
+       return ad->pastetextonly;
+}