jaehyun pushed a commit to branch master.

http://git.enlightenment.org/core/efl.git/commit/?id=dca1581b032014845d1ca590aaad101dd590a5bf

commit dca1581b032014845d1ca590aaad101dd590a5bf
Author: YeongJong Lee <[email protected]>
Date:   Mon Feb 26 21:11:58 2018 +0900

    efl.ui.slider: change signal name for icon/text
    
    Summary:
    See also 73f8b3b78f0ff92ddfc1c16426bf7c176f10293a
    
    because slider use "elm.swallow.icon" part name, it don't need to edit .c 
file.
    
    Test Plan:
    1. elementary_test -to efl.ui.slider
    2. check that icon and text are visible
    
    Reviewers: cedric, woohyun, Jaehyun_Cho
    
    Reviewed By: Jaehyun_Cho
    
    Differential Revision: https://phab.enlightenment.org/D5822
---
 data/elementary/themes/edc/efl/slider.edc | 2953 ++++++++++++++++++++++++++++-
 src/bin/elementary/test_ui_slider.c       |    8 +-
 2 files changed, 2946 insertions(+), 15 deletions(-)

diff --git a/data/elementary/themes/edc/efl/slider.edc 
b/data/elementary/themes/edc/efl/slider.edc
index 20b479b1f1..8bd19ec16f 100644
--- a/data/elementary/themes/edc/efl/slider.edc
+++ b/data/elementary/themes/edc/efl/slider.edc
@@ -3,71 +3,2996 @@ group { "efl/slider/hidden/limit";
 }
 
 group { "efl/slider/horizontal/indicator";
-   inherit: "elm/slider/horizontal/indicator/default";
    alias: "efl/slider/horizontal/indicator:disabled";
    alias: "efl/slider/horizontal/popup";
    alias: "efl/slider_interval/horizontal/indicator";
    alias: "efl/slider_interval/horizontal/popup";
+   images.image: "darken_rounded_square.png" COMP;
+   parts {
+      part { name: "base"; type: SPACER;
+         scale: 1;
+         description { state: "default" 0.0;
+            fixed: 1 1;
+            min: 16 16;
+         }
+         description { state: "disabled" 0.0;
+            inherit: "default" 0.0;
+         }
+      }
+      part { name: "clip"; type: RECT;
+         description { state: "default" 0.0;
+            fixed: 1 1;
+            rel1.to: "elm.indicator";
+            rel1.offset: -100 -100;
+            rel2.to: "elm.indicator";
+            rel2.offset: 99 99;
+            visible: 0;
+         }
+         description { state: "visible" 0.0;
+            inherit: "default" 0.0;
+            visible: 1;
+         }
+      }
+      part { name: "bevel"; mouse_events: 0;
+         clip_to: "clip";
+         description { state: "default" 0.0;
+            rel1.offset: -12 -12;
+            rel1.to: "elm.indicator";
+            rel2.offset: 11 11;
+            rel2.to: "elm.indicator";
+            image.normal: "darken_rounded_square.png";
+            image.border: 15 15 15 15;
+            fill.smooth: 0;
+            visible: 0;
+         }
+         description { state: "visible" 0.0;
+            inherit: "default" 0.0;
+            visible: 1;
+         }
+      }
+      part { name: "elm.indicator"; type: TEXT; mouse_events: 0;
+         clip_to: "clip";
+         effect: SHADOW BOTTOM;
+         scale: 1;
+         description { state: "default" 0.0;
+            fixed: 1 1;
+            align: 0.5 1.0;
+            rel1.to: "base";
+            rel1.relative: 0.0 -0.1;
+            rel1.offset: 0 -12;
+            rel2.to: "base";
+            rel2.relative: 1.0 -0.1;
+            rel2.offset: -1 -12;
+            color_class: "slider_indicator";
+            color: FN_COL_DEFAULT;
+            text { font: FNBD; size: 10;
+               min: 1 1;
+               align: 0.5 1.0;
+               text_class: "slider_indicator";
+               ellipsis: -1;
+            }
+            visible: 0;
+         }
+         description { state: "visible" 0.0;
+            inherit: "default" 0.0;
+            visible: 1;
+         }
+      }
+   }
+   programs {
+      program {
+         signal: "elm,popup,show"; source: "elm";
+         action:  STATE_SET "visible" 0.0;
+         target:  "elm.indicator";
+         target:  "bevel";
+      }
+      program {
+         signal: "elm,popup,hide"; source: "elm";
+         action:  STATE_SET "default" 0.0;
+         target:  "elm.indicator";
+         target:  "bevel";
+      }
+      program {
+         signal: "elm,popup,hide"; source: "elm";
+         action:  SIGNAL_EMIT "elm,popup,hide,done" "elm";
+      }
+      program {
+         signal: "elm,state,val,show"; source: "elm";
+         action:  STATE_SET "visible" 0.0;
+         target: "clip";
+      }
+      program {
+         signal: "elm,state,val,hide"; source: "elm";
+         action:  STATE_SET "default" 0.0;
+         target: "clip";
+      }
+      program {
+         signal: "elm,state,indicator,show"; source: "elm";
+         action:  STATE_SET "visible" 0.0;
+         target:  "elm.indicator";
+         target:  "bevel";
+      }
+      program {
+         signal: "elm,state,indicator,hide"; source: "elm";
+         action:  STATE_SET "visible" 0.0;
+         target:  "elm.indicator";
+         target:  "bevel";
+      }
+      program {
+         signal:  "elm,state,disabled"; source: "elm";
+         action:  STATE_SET "disabled" 0.0;
+         target:  "base";
+      }
+      program {
+         signal: "elm,state,enabled"; source: "elm";
+         action:  STATE_SET "default" 0.0;
+         target:  "base";
+      }
+   }
 }
 
 group { "efl/slider/vertical/indicator";
-   inherit: "elm/slider/vertical/indicator/default";
    alias: "efl/slider/vertical/indicator:disabled";
    alias: "efl/slider/vertical/popup";
    alias: "efl/slider_interval/vertical/indicator";
    alias: "efl/slider_interval/vertical/popup";
+   images.image: "darken_rounded_square.png" COMP;
+   parts {
+      part { name: "base"; type: SPACER;
+         scale: 1;
+         description { state: "default" 0.0;
+            fixed: 1 1;
+            min: 16 16;
+         }
+         description { state: "disabled" 0.0;
+            inherit: "default" 0.0;
+         }
+      }
+      part { name: "clip"; type: RECT;
+         description { state: "default" 0.0;
+            fixed: 1 1;
+            rel1.to: "elm.indicator";
+            rel1.offset: -100 -100;
+            rel2.to: "elm.indicator";
+            rel2.offset: 99 99;
+            visible: 0;
+         }
+         description { state: "visible" 0.0;
+            inherit: "default" 0.0;
+            visible: 1;
+         }
+      }
+      part { name: "bevel"; mouse_events: 0;
+         clip_to: "clip";
+         description { state: "default" 0.0;
+            rel1.offset: -12 -12;
+            rel1.to: "elm.indicator";
+            rel2.offset: 11 11;
+            rel2.to: "elm.indicator";
+            image.normal: "darken_rounded_square.png";
+            image.border: 15 15 15 15;
+            fill.smooth: 0;
+            visible: 0;
+         }
+         description { state: "visible" 0.0;
+            inherit: "default" 0.0;
+            visible: 1;
+         }
+      }
+      part { name: "elm.indicator"; type: TEXT; mouse_events: 0;
+         clip_to: "clip";
+         effect: SHADOW BOTTOM;
+         scale: 1;
+         description { state: "default" 0.0;
+            fixed: 1 1;
+            align: 0.0 0.5;
+            rel1.to: "base";
+            rel1.relative: 1.1 0.0;
+            rel1.offset: 11 0;
+            rel2.to: "base";
+            rel2.relative: 1.1 1.0;
+            rel2.offset: 11 -1;
+            color_class: "slider_indicator";
+            color: FN_COL_DEFAULT;
+            text { font: FNBD; size: 10;
+               min: 1 1;
+               align: 0.0 0.5;
+               text_class: "slider_indicator";
+               ellipsis: -1;
+            }
+            visible: 0;
+         }
+         description { state: "visible" 0.0;
+            inherit: "default" 0.0;
+            visible: 1;
+         }
+      }
+   }
+   programs {
+      program {
+         signal: "elm,popup,show"; source: "elm";
+         action:  STATE_SET "visible" 0.0;
+         target:  "elm.indicator";
+         target:  "bevel";
+      }
+      program {
+         signal: "elm,popup,hide"; source: "elm";
+         action:  STATE_SET "default" 0.0;
+         target:  "elm.indicator";
+         target:  "bevel";
+      }
+      program {
+         signal: "elm,popup,hide"; source: "elm";
+         action:  SIGNAL_EMIT "elm,popup,hide,done" "elm";
+      }
+      program {
+         signal: "elm,state,val,show"; source: "elm";
+         action:  STATE_SET "visible" 0.0;
+         target: "clip";
+      }
+      program {
+         signal: "elm,state,val,hide"; source: "elm";
+         action:  STATE_SET "default" 0.0;
+         target: "clip";
+      }
+      program {
+         signal: "elm,state,indicator,show"; source: "elm";
+         action:  STATE_SET "visible" 0.0;
+         target:  "elm.indicator";
+         target:  "bevel";
+      }
+      program {
+         signal: "elm,state,indicator,hide"; source: "elm";
+         action:  STATE_SET "visible" 0.0;
+         target:  "elm.indicator";
+         target:  "bevel";
+      }
+      program {
+         signal:  "elm,state,disabled"; source: "elm";
+         action:  STATE_SET "disabled" 0.0;
+         target:  "base";
+      }
+      program {
+         signal: "elm,state,enabled"; source: "elm";
+         action:  STATE_SET "default" 0.0;
+         target:  "base";
+      }
+   }
 }
 
 group { "efl/slider/horizontal";
-   inherit: "elm/slider/horizontal/default";
    alias: "efl/slider/horizontal:disabled";
+   images.image: "slider_run_base_horiz.png" COMP;
+   images.image: "slider_run_bevel_horiz.png" COMP;
+   images.image: "slider_run_base_light_horiz.png" COMP;
+   images.image: "horiz_glow_run.png" COMP;
+   images.image: "horiz_glow_run_rev.png" COMP;
+   images.image: "knob_round_small_normal.png" COMP;
+   images.image: "knob_round_small_selected.png" COMP;
+   set { name: "knob";
+      // XXX: add more sizes (at least up to 128x128)
+      image { image: "knob_sz_24.png"  COMP; size: 31 31 32 32; }
+      image { image: "knob_sz_22.png"  COMP; size: 29 29 30 30; }
+      image { image: "knob_sz_20.png"  COMP; size: 27 27 28 28; }
+      image { image: "knob_sz_18.png"  COMP; size: 25 25 26 26; }
+      image { image: "knob_sz_16.png"  COMP; size: 23 23 24 24; }
+      image { image: "knob_sz_14.png"  COMP; size: 21 21 22 22; }
+      image { image: "knob_sz_12.png"  COMP; size: 19 19 20 20; }
+      image { image: "knob_sz_10.png"  COMP; size: 17 17 18 18; }
+      image { image: "knob_sz_08.png"  COMP; size: 15 15 16 16; }
+      image { image: "knob_sz_06.png"  COMP; size: 13 13 14 14; }
+      image { image: "knob_sz_04.png"  COMP; size:  0  0 12 12; }
+   }
+#define ICON    1
+#define LABEL   2
+#define END     4
+#define UNITS   8
+#define MASK    15
+#define INVERT  16
+#define DISABLE 32
+   script {
+      public slmode;
+      public eval_mode(m) {
+         new ic = m & ICON;
+         new l = m & LABEL;
+         new e = m & END;
+         new u = m & UNITS;
+         new d = m & DISABLE;
+         new i = m & INVERT;
+         if (i) {
+            if (!d) {
+               set_state(PART:"base", "default", 0.0);
+               set_state(PART:"glow", "inverted", 0.0);
+            } else {
+               set_state(PART:"base", "disabled", 0.0);
+               set_state(PART:"glow", "disabled_inverted", 0.0);
+            }
+         } else {
+            if (!d) {
+               set_state(PART:"base", "default", 0.0);
+               set_state(PART:"glow", "default", 0.0);
+            } else {
+               set_state(PART:"base", "disabled", 0.0);
+               set_state(PART:"glow", "disabled", 0.0);
+            }
+         }
+         if (l) {
+            if (!d) {
+               set_state(PART:"elm.text", "visible", 0.0);
+            } else {
+               set_state(PART:"elm.text", "disabled_visible", 0.0);
+            }
+         } else {
+            set_state(PART:"elm.text", "default", 0.0);
+         }
+         if (u) {
+            if (!d) {
+               set_state(PART:"elm.units", "visible", 0.0);
+               set_state(PART:"limits", "visible", 0.0);
+            } else {
+               set_state(PART:"elm.units", "disabled_visible", 0.0);
+               set_state(PART:"limits", "disabled_visible", 0.0);
+            }
+         } else {
+            set_state(PART:"elm.units", "default", 0.0);
+            set_state(PART:"limits", "default", 0.0);
+         }
+         if (ic) {
+            set_state(PART:"elm.swallow.icon", "visible", 0.0);
+            set_state(PART:"sizer.content", "visible", 0.0);
+         } else {
+            set_state(PART:"elm.swallow.icon", "default", 0.0);
+            set_state(PART:"sizer.content", "default", 0.0);
+         }
+         if (e) {
+            set_state(PART:"elm.swallow.end", "visible", 0.0);
+            set_state(PART:"sizer.content.end", "visible", 0.0);
+         } else {
+            set_state(PART:"elm.swallow.end", "default", 0.0);
+            set_state(PART:"sizer.content.end", "default", 0.0);
+         }
+         if (!d) {
+            set_state(PART:"event", "default", 0.0);
+            set_state(PART:"dis_clip", "default", 0.0);
+         } else {
+            set_state(PART:"event", "disabled", 0.0);
+            set_state(PART:"dis_clip", "disabled", 0.0);
+         }
+      }
+   }
    parts {
-      part { "limits";
+      part { name: "elm.swallow.bar"; type: SWALLOW;
+         scale: 1;
+         description { state: "default" 0.0;
+            min: 42 21;
+            max: 99999 21;
+            align: 1.0 0.5;
+            rel1.to_x: "elm.text";
+            rel1.relative: 1.0 0.0;
+            rel1.offset: 2 0;
+            rel2.to_x: "limits";
+            rel2.relative: 0.0 1.0;
+            rel2.offset: -3 -1;
+         }
+      }
+      part { name: "base"; mouse_events: 0;
+         description { state: "default" 0.0;
+            rel1.to: "elm.swallow.bar";
+            rel2.to: "elm.swallow.bar";
+            image.normal: "slider_run_base_horiz.png";
+            image.border: 4 4 0 0;
+            fill.smooth: 0;
+            min: 8 5;
+            max: 99999 5;
+            fixed: 0 1;
+         }
+         description { state: "disabled" 0.0;
+            inherit: "default" 0.0;
+            image.normal: "slider_run_base_light_horiz.png";
+         }
+      }
+      part { name: "glow"; mouse_events: 0;
+         description { state: "default" 0.0;
+            image.normal: "horiz_glow_run.png";
+            rel1.offset: 1 1;
+            rel1.to: "base";
+            rel2.relative: 0.5 1.0;
+            rel2.offset: -1 -2;
+            rel2.to_x: "button";
+            rel2.to_y: "base";
+            image.border: 0 4 0 0;
+         }
+         description { state: "disabled" 0.0;
+            inherit: "default" 0.0;
+            color: 255 255 255 64;
+         }
+         description { state: "inverted" 0.0;
+            image.normal: "horiz_glow_run_rev.png";
+            rel1.relative: 0.5 0.0;
+            rel1.offset: 0 1;
+            rel1.to_x: "button";
+            rel1.to_y: "base";
+            rel2.offset: -2 -2;
+            rel2.to: "base";
+            image.border: 4 0 0 0;
+         }
+         description { state: "disabled_inverted" 0.0;
+            inherit: "inverted" 0.0;
+            color: 255 255 255 64;
+         }
+      }
+      part { name: "bevel"; mouse_events: 0;
+         description { state: "default" 0.0;
+            rel1.to: "base";
+            rel2.to: "base";
+            image.normal: "slider_run_bevel_horiz.png";
+            image.border: 5 5 0 0;
+            fill.smooth: 0;
+         }
+      }
+      part { name: "dis_clip"; type: RECT;
+         description { state: "default" 0.0;
+            rel1.to: "elm.swallow.icon";
+            rel2.to: "elm.swallow.end";
+         }
+         description { state: "disabled" 0.0;
+            inherit: "default" 0.0;
+            color: 255 255 255 64;
+         }
+      }
+      part { name: "elm.swallow.icon"; type: SWALLOW;
+         clip_to: "dis_clip";
+         required;
+         description { state: "default" 0.0;
+            fixed: 1 0;
+            visible: 0;
+            align: 0.0 0.5;
+            rel1.offset: 0 2;
+            rel1.to_y: "elm.swallow.bar";
+            rel2.offset: -1 -3;
+            rel2.relative: 0.0 1.0;
+            rel2.to_y: "elm.swallow.bar";
+         }
+         description { state: "visible" 0.0;
+            inherit: "default" 0.0;
+            visible: 1;
+            aspect: 1.0 1.0; aspect_preference: VERTICAL;
+            rel1.offset: 2 2;
+            rel2.offset: 2 -3;
+         }
+      }
+      part { name: "sizer.content"; type: TEXT; mouse_events:  0;
+         scale: 1;
+         description { state: "default" 0.0;
+            fixed: 1 1;
+            visible: 0;
+            text { font: FN; size: 10;
+               min: 0 0;
+               text_class: "slider_text";
+            }
+         }
+         description { state: "visible" 0.0;
+            inherit: "default" 0.0;
+            rel1.to: "elm.swallow.icon";
+            rel2.to: "elm.swallow.icon";
+            text {
+               min: 1 1;
+               ellipsis: -1;
+               text: "M";
+            }
+         }
+      }
+      part { name: "elm.text"; type: TEXT; mouse_events: 0;
+         effect: SHADOW BOTTOM;
+         scale: 1;
+         required;
+         description { state: "default" 0.0;
+            fixed: 1 1;
+            align: 0.0 0.5;
+            rel1.to_x: "elm.swallow.icon";
+            rel1.relative: 1.0 0.0;
+            rel1.offset: -1 2;
+            rel2.to_x: "elm.swallow.icon";
+            rel2.relative: 1.0 1.0;
+            rel2.offset: -1 -3;
+            color: FN_COL_DEFAULT;
+            color_class: "slider_text";
+            text { font: FN; size: 10;
+               text_class: "slider";
+               min: 0 0;
+               align: 0.0 0.5;
+            }
+            visible: 0;
+         }
+         description { state: "visible" 0.0;
+            inherit: "default" 0.0;
+            fixed: 1 0;
+            visible: 1;
+            rel1.offset: 2 2;
+            rel2.offset: 2 -3;
+            text.min: 1 1;
+            text.ellipsis: -1;
+         }
+         description { state: "disabled_visible" 0.0;
+            inherit: "visible" 0.0;
+            color_class: "slider_text_disabled";
+            color3: 255 255 255 255;
+         }
+      }
+      part { name: "elm.swallow.end"; type: SWALLOW;
+         clip_to: "dis_clip";
+         description { state: "default" 0.0;
+            fixed: 1 0;
+            visible: 0;
+            align: 1.0 0.5;
+            rel1.offset: 0 2;
+            rel1.relative: 1.0 0.0;
+            rel2.offset: -1 -3;
+         }
+         description { state: "visible" 0.0;
+            inherit: "default" 0.0;
+            visible: 1;
+            aspect: 1.0 1.0;
+            aspect_preference: VERTICAL;
+            rel1.offset: -3 2;
+            rel2.offset: -3 -3;
+         }
+      }
+      part { name: "sizer.content.end"; type: TEXT; mouse_events:  0;
+         scale: 1;
+         description { state: "default" 0.0;
+            fixed: 1 1;
+            visible: 0;
+            text { font: FN; size: 10;
+               min: 0 0;
+               text_class: "slider_text";
+            }
+         }
+         description { state: "visible" 0.0;
+            inherit: "default" 0.0;
+            rel1.to: "elm.swallow.end";
+            rel2.to: "elm.swallow.end";
+            text {
+               min: 1 1;
+               ellipsis: -1;
+               text: "M";
+            }
+         }
+      }
+      alias: "elm.units.min" "limits:elm.units.min";
+      alias: "elm.units.max" "limits:elm.units.max";
+      part { name: "limits"; type: GROUP; mouse_events: 0;
          source: "efl/slider/hidden/limit";
+         scale: 1;
+         description { state: "default" 0.0;
+            visible: 0;
+            align: 1.0 0.5;
+            min: SOURCE;
+            fixed: 1 1;
+            rel1.to_x: "elm.swallow.end";
+            rel1.relative: 0.0 0.0;
+            rel1.offset: 0 2;
+            rel2.to_x: "elm.swallow.end";
+            rel2.relative: 0.0 1.0;
+            rel2.offset: -1 -3;
+         }
+         description { state: "visible" 0.0;
+            inherit: "default" 0.0;
+            rel1.offset: -3 2;
+            rel2.offset: -3 -3;
+         }
+         description { state: "disabled_visible" 0.0;
+            inherit: "default" 0.0;
+            rel1.offset: -3 2;
+            rel2.offset: -3 -3;
+            color: 255 255 255 64;
+         }
+      }
+      part { name: "elm.units"; type: TEXT; mouse_events: 0;
+         effect: SHADOW BOTTOM;
+         scale: 1;
+         description { state: "default" 0.0;
+            visible: 0;
+            fixed: 1 1;
+            rel1.to_x: "limits";
+            rel2.to_x: "limits";
+            color: FN_COL_DEFAULT;
+            color_class: "slider_text";
+            text { font: FN; size: 10;
+               text_class: "slider";
+               align: 1.0 0.5;
+               min: 1 1;
+               ellipsis: -1;
+            }
+         }
+         description { state: "visible" 0.0;
+            inherit: "default" 0.0;
+            visible: 1;
+         }
+         description { state: "disabled_visible" 0.0;
+            inherit: "visible" 0.0;
+            color_class: "slider_text_disabled";
+            color3: 255 255 255 255;
+         }
       }
-      part { "button";
+      part { name: "button"; type: GROUP; mouse_events: 0;
          source: "efl/slider/horizontal/indicator";
+         description { state: "default" 0.0;
+            fixed: 1 1;
+            rel1.to: "elm.dragable.slider";
+            rel2.to: "elm.dragable.slider";
+         }
+         description { state: "hidden" 0.0;
+            inherit: "default" 0.0;
+            visible: 0;
+         }
+      }
+      part { name: "elm.dragable.slider"; type: RECT;
+         scale: 1;
+         dragable.x: 1 1 0;
+         dragable.y: 0 0 0;
+         dragable.confine: "elm.swallow.bar";
+         description { state: "default" 0.0;
+            color: 0 0 0 0;
+            min: 16 16;
+            max: 16 16;
+            fixed: 1 1;
+            rel1.relative: 0.5 0.0;
+            rel1.to_x: "elm.swallow.bar";
+            rel2.relative: 0.5 1.0;
+            rel2.to_x: "elm.swallow.bar";
+         }
+      }
+      part { name: "knob";
+         description { state: "default" 0.0;
+            image.normal: "knob";
+            fixed: 1 1;
+            min: 12 12;
+            step: 2 2;
+            max: 32 32; // XXX allow bigger sizes with more knob images
+            rel1.to: "elm.dragable.slider";
+            rel1.offset: -4 -4;
+            rel2.to: "elm.dragable.slider";
+            rel2.offset: 3 3;
+         }
+         description { state: "clicked" 0.0;
+            inherit: "default" 0.0;
+         }
+      }
+      part { name: "slideevent"; type: RECT; repeat_events: 1;
+         scale: 1;
+         ignore_flags: ON_HOLD;
+         dragable.events: "elm.dragable.slider";
+         description { state: "default" 0.0;
+            fixed: 1 1;
+            rel1.to: "elm.dragable.slider";
+            rel2.to: "elm.dragable.slider";
+            color: 0 0 0 0;
+         }
+      }
+      part { name: "elm.track.slider"; type: SWALLOW; mouse_events: 0;
+         description { state: "default" 0.0;
+            max: 0 0;
+            rel1.to: "elm.dragable.slider";
+            rel2.to: "elm.dragable.slider";
+         }
+      }
+      part { name: "event"; type: RECT;
+         description { state: "default" 0.0;
+            color: 0 0 0 0;
+            visible: 0;
+         }
+         description { state: "disabled" 0.0;
+            inherit: "default" 0.0;
+            visible: 1;
+         }
       }
    }
+   programs {
+      program {
+         signal: "mouse,down,1"; source: "elm.dragable.slider";
+         action:  STATE_SET "clicked" 0.0;
+         target: "knob";
+      }
+      program {
+         signal: "mouse,up,1"; source: "elm.dragable.slider";
+         action:  STATE_SET "default" 0.0;
+         target: "knob";
+      }
+      program {
+         signal: "elm,state,indicator,show"; source: "elm";
+         action:  SIGNAL_EMIT "elm,popup,show" "elm";
+         after: "popup_show2";
+      }
+      program {
+         signal: "elm,state,indicator,hide"; source: "elm";
+         action:  SIGNAL_EMIT "elm,popup,hide" "elm";
+         after: "popup_hide2";
+      }
+      program {
+         signal: "mouse,down,1"; source: "slideevent";
+         action:  SIGNAL_EMIT "elm,popup,show" "elm";
+         after: "popup_show2";
+      }
+      program { name: "popup_show2";
+         action:  STATE_SET "hidden" 0.0;
+         target: "button";
+      }
+      program {
+         signal: "mouse,up,1"; source: "slideevent";
+         action:  SIGNAL_EMIT "elm,popup,hide" "elm";
+         after: "popup_hide2";
+      }
+      program { name: "popup_hide2";
+         action:  STATE_SET "default" 0.0;
+         target: "button";
+      }
+      program {
+         signal: "elm,state,elm.text,set"; source: "elm";
+         script {
+            new m = get_int(slmode);
+            m |= LABEL; set_int(slmode, m);
+            eval_mode(m);
+         }
+      }
+      program {
+         signal: "elm,state,elm.text,unset"; source: "elm";
+         script {
+            new m = get_int(slmode);
+            m &= ~LABEL; set_int(slmode, m);
+            eval_mode(m);
+         }
+      }
+      program {
+         signal: "elm,state,icon,set"; source: "elm";
+         script {
+            new m = get_int(slmode);
+            m |= ICON; set_int(slmode, m);
+            eval_mode(m);
+         }
+      }
+      program {
+         signal: "elm,state,icon,unset"; source: "elm";
+         script {
+            new m = get_int(slmode);
+            m &= ~ICON; set_int(slmode, m);
+            eval_mode(m);
+         }
+      }
+      program { name: "end_show";
+         signal: "elm,state,end,visible"; source: "elm";
+         script {
+            new m = get_int(slmode);
+            m |= END; set_int(slmode, m);
+            eval_mode(m);
+         }
+      }
+      program { name: "end_hide";
+         signal: "elm,state,end,hidden"; source: "elm";
+         script {
+            new m = get_int(slmode);
+            m &= ~END; set_int(slmode, m);
+            eval_mode(m);
+         }
+      }
+      program {
+         signal: "elm,state,units,visible"; source: "elm";
+         script {
+            new m = get_int(slmode);
+            m |= UNITS; set_int(slmode, m);
+            eval_mode(m);
+         }
+      }
+      program {
+         signal: "elm,state,units,visible"; source: "elm";
+         action: SIGNAL_EMIT "limits,visible" "elm";
+         target: "limits";
+      }
+      program {
+         signal: "elm,state,units,hidden"; source: "elm";
+         action:  STATE_SET "default" 0.0;
+         script {
+            new m = get_int(slmode);
+            m &= ~UNITS; set_int(slmode, m);
+            eval_mode(m);
+         }
+      }
+      program {
+         signal: "elm,state,units,hidden"; source: "elm";
+         action: SIGNAL_EMIT "limits,hide" "elm";
+         target: "limits";
+      }
+      program {
+         signal: "elm,state,inverted,on"; source: "elm";
+         script {
+            new m = get_int(slmode);
+            m |= INVERT; set_int(slmode, m);
+            eval_mode(m);
+         }
+      }
+      program {
+         signal: "elm,state,inverted,off"; source: "elm";
+         script {
+            new m = get_int(slmode);
+            m &= ~INVERT; set_int(slmode, m);
+            eval_mode(m);
+         }
+      }
+      program {
+         signal: "elm,state,disabled"; source: "elm";
+         script {
+            new m = get_int(slmode);
+            m |= DISABLE; set_int(slmode, m);
+            eval_mode(m);
+         }
+      }
+      program {
+         signal: "elm,state,enabled"; source: "elm";
+         script {
+            new m = get_int(slmode);
+            m &= ~DISABLE; set_int(slmode, m);
+            eval_mode(m);
+         }
+      }
+   }
+#undef ICON
+#undef LABEL
+#undef END
+#undef UNITS
+#undef MASK
+#undef INVERT
+#undef DISABLE
 }
 
 group { "efl/slider/vertical";
-   inherit: "elm/slider/vertical/default";
    alias: "efl/slider/vertical:disabled";
+   images.image: "slider_run_base_vert.png" COMP;
+   images.image: "slider_run_bevel_vert.png" COMP;
+   images.image: "slider_run_base_light_vert.png" COMP;
+   images.image: "vert_glow_run.png" COMP;
+   images.image: "vert_glow_run_rev.png" COMP;
+   images.image: "knob_round_small_normal.png" COMP;
+   images.image: "knob_round_small_selected.png" COMP;
+   set { name: "knob";
+      // XXX: add more sizes (at least up to 128x128)
+      image { image: "knob_sz_24.png"  COMP; size: 31 31 32 32; }
+      image { image: "knob_sz_22.png"  COMP; size: 29 29 30 30; }
+      image { image: "knob_sz_20.png"  COMP; size: 27 27 28 28; }
+      image { image: "knob_sz_18.png"  COMP; size: 25 25 26 26; }
+      image { image: "knob_sz_16.png"  COMP; size: 23 23 24 24; }
+      image { image: "knob_sz_14.png"  COMP; size: 21 21 22 22; }
+      image { image: "knob_sz_12.png"  COMP; size: 19 19 20 20; }
+      image { image: "knob_sz_10.png"  COMP; size: 17 17 18 18; }
+      image { image: "knob_sz_08.png"  COMP; size: 15 15 16 16; }
+      image { image: "knob_sz_06.png"  COMP; size: 13 13 14 14; }
+      image { image: "knob_sz_04.png"  COMP; size:  0  0 12 12; }
+   }
+#define ICON    1
+#define LABEL   2
+#define END     4
+#define UNITS   8
+#define MASK    15
+#define INVERT  16
+#define DISABLE 32
+   script {
+      public slmode;
+      public eval_mode(m) {
+         new ic = m & ICON;
+         new l = m & LABEL;
+         new e = m & END;
+         new u = m & UNITS;
+         new d = m & DISABLE;
+         new i = m & INVERT;
+         if (i) {
+            if (!d) {
+               set_state(PART:"base", "default", 0.0);
+               set_state(PART:"glow", "inverted", 0.0);
+            } else {
+               set_state(PART:"base", "disabled", 0.0);
+               set_state(PART:"glow", "disabled_inverted", 0.0);
+            }
+         } else {
+            if (!d) {
+               set_state(PART:"base", "default", 0.0);
+               set_state(PART:"glow", "default", 0.0);
+            } else {
+               set_state(PART:"base", "disabled", 0.0);
+               set_state(PART:"glow", "disabled", 0.0);
+            }
+         }
+         if (l) {
+            if (!d) {
+               set_state(PART:"elm.text", "visible", 0.0);
+            } else {
+               set_state(PART:"elm.text", "disabled_visible", 0.0);
+            }
+         } else {
+            set_state(PART:"elm.text", "default", 0.0);
+         }
+         if (u) {
+            if (!d) {
+               set_state(PART:"elm.units", "visible", 0.0);
+               set_state(PART:"limits", "visible", 0.0);
+            } else {
+               set_state(PART:"elm.units", "disabled_visible", 0.0);
+               set_state(PART:"limits", "disabled_visible", 0.0);
+            }
+         } else {
+            set_state(PART:"elm.units", "default", 0.0);
+            set_state(PART:"limits", "default", 0.0);
+         }
+         if (ic) {
+            set_state(PART:"elm.swallow.icon", "visible", 0.0);
+            set_state(PART:"sizer.content", "visible", 0.0);
+         } else {
+            set_state(PART:"elm.swallow.icon", "default", 0.0);
+            set_state(PART:"sizer.content", "default", 0.0);
+         }
+         if (e) {
+            set_state(PART:"elm.swallow.end", "visible", 0.0);
+            set_state(PART:"sizer.content.end", "visible", 0.0);
+         } else {
+            set_state(PART:"elm.swallow.end", "default", 0.0);
+            set_state(PART:"sizer.content.end", "default", 0.0);
+         }
+         if (!d) {
+            set_state(PART:"event", "default", 0.0);
+            set_state(PART:"dis_clip", "default", 0.0);
+         } else {
+            set_state(PART:"event", "disabled", 0.0);
+            set_state(PART:"dis_clip", "disabled", 0.0);
+         }
+      }
+   }
    parts {
-      part { "limits";
+      part { name: "elm.swallow.bar"; type: SWALLOW;
+         scale: 1;
+         description { state: "default" 0.0;
+            min: 21 42;
+            max: 21 99999;
+            align: 0.5 1.0;
+            rel1.to_y: "elm.text";
+            rel1.relative: 0.0 1.0;
+            rel1.offset: 0 2;
+            rel2.to_y: "limits";
+            rel2.relative: 1.0 0.0;
+            rel2.offset: -1 -3;
+         }
+      }
+      part { name: "base"; mouse_events: 0;
+         description { state: "default" 0.0;
+            rel1.to: "elm.swallow.bar";
+            rel2.to: "elm.swallow.bar";
+            image.normal: "slider_run_base_vert.png";
+            image.border: 0 0 4 4;
+            fill.smooth: 0;
+            min: 5 8;
+            max: 5 99999;
+            fixed: 1 0;
+         }
+         description { state: "disabled" 0.0;
+            inherit: "default" 0.0;
+            image.normal: "slider_run_base_light_vert.png";
+         }
+      }
+      part { name: "glow"; mouse_events: 0;
+         description { state: "default" 0.0;
+            image.normal: "vert_glow_run.png";
+            rel1.offset: 1 1;
+            rel1.to: "base";
+            rel2.relative: 1.0 0.5;
+            rel2.offset: -2 -1;
+            rel2.to_y: "button";
+            rel2.to_x: "base";
+            image.border: 0 0 0 4;
+         }
+         description { state: "disabled" 0.0;
+            inherit: "default" 0.0;
+            color: 255 255 255 64;
+         }
+         description { state: "inverted" 0.0;
+            image.normal: "vert_glow_run_rev.png";
+            rel1.relative: 0.0 0.5;
+            rel1.offset: 1 0;
+            rel1.to_y: "button";
+            rel1.to_x: "base";
+            rel2.offset: -2 -2;
+            rel2.to: "base";
+            image.border: 0 0 4 0;
+         }
+         description { state: "disabled_inverted" 0.0;
+            inherit: "inverted" 0.0;
+            color: 255 255 255 64;
+         }
+      }
+      part { name: "bevel"; mouse_events: 0;
+         description { state: "default" 0.0;
+            rel1.to: "base";
+            rel2.to: "base";
+            image.normal: "slider_run_bevel_vert.png";
+            image.border: 0 0 5 5;
+            fill.smooth: 0;
+         }
+      }
+      part { name: "dis_clip"; type: RECT;
+         description { state: "default" 0.0;
+            rel1.to: "elm.swallow.icon";
+            rel2.to: "elm.swallow.end";
+         }
+         description { state: "disabled" 0.0;
+            inherit: "default" 0.0;
+            color: 255 255 255 64;
+         }
+      }
+      part { name: "elm.swallow.icon"; type: SWALLOW;
+         clip_to: "dis_clip";
+         required;
+         description { state: "default" 0.0;
+            fixed: 0 1;
+            visible: 0;
+            align: 0.5 0.0;
+            rel1.offset: 2 0;
+            rel1.to_x: "elm.swallow.bar";
+            rel2.offset: -3 -1;
+            rel2.relative: 1.0 0.0;
+            rel2.to_x: "elm.swallow.bar";
+         }
+         description { state: "visible" 0.0;
+            inherit: "default" 0.0;
+            visible: 1;
+            aspect: 1.0 1.0; aspect_preference: VERTICAL;
+            rel1.offset: 2 2;
+            rel2.offset: -3 2;
+         }
+      }
+      part { name: "sizer.content"; type: TEXT; mouse_events:  0;
+         scale: 1;
+         description { state: "default" 0.0;
+            fixed: 1 1;
+            visible: 0;
+            text { font: FN; size: 10;
+               min: 0 0;
+               text_class: "slider_text";
+            }
+         }
+         description { state: "visible" 0.0;
+            inherit: "default" 0.0;
+            rel1.to: "elm.swallow.icon";
+            rel2.to: "elm.swallow.icon";
+            text {
+               min: 1 1;
+               ellipsis: -1;
+               text: "M";
+            }
+         }
+      }
+      part { name: "elm.text"; type: TEXT; mouse_events: 0;
+         effect: SHADOW BOTTOM;
+         scale: 1;
+         required;
+         description { state: "default" 0.0;
+            fixed: 0 1;
+            align: 0.5 0.0;
+            rel1.to_y: "elm.swallow.icon";
+            rel1.relative: 0.0 1.0;
+            rel1.offset: 2 -1;
+            rel2.to_y: "elm.swallow.icon";
+            rel2.relative: 1.0 1.0;
+            rel2.offset: -3 -1;
+            color: FN_COL_DEFAULT;
+            color_class: "slider_text";
+            text { font: FN; size: 10;
+               text_class: "slider";
+               min: 1 0;
+               ellipsis: -1;
+               align: 0.5 0.0;
+            }
+            visible: 0;
+         }
+         description { state: "visible" 0.0;
+            inherit: "default" 0.0;
+            visible: 1;
+            rel1.offset: 2 2;
+            rel2.offset: -3 2;
+            text.min: 1 1;
+            text.ellipsis: -1;
+
+         }
+         description { state: "disabled_visible" 0.0;
+            inherit: "visible" 0.0;
+            color_class: "slider_text_disabled";
+            color3: 255 255 255 255;
+         }
+      }
+      part { name: "elm.swallow.end"; type: SWALLOW;
+         clip_to: "dis_clip";
+         description { state: "default" 0.0;
+            fixed: 0 1;
+            visible: 0;
+            align: 0.5 1.0;
+            rel1.offset: 2 0;
+            rel1.relative: 0.0 1.0;
+            rel2.offset: -3 -1;
+         }
+         description { state: "visible" 0.0;
+            inherit: "default" 0.0;
+            visible: 1;
+            aspect: 1.0 1.0;
+            aspect_preference: VERTICAL;
+            rel2.offset: 2 -3;
+            rel2.offset: -3 -3;
+         }
+      }
+      part { name: "sizer.content.end"; type: TEXT; mouse_events:  0;
+         scale: 1;
+         description { state: "default" 0.0;
+            fixed: 1 1;
+            visible: 0;
+            text { font: FN; size: 10;
+               min: 0 0;
+               text_class: "slider_text";
+            }
+         }
+         description { state: "visible" 0.0;
+            inherit: "default" 0.0;
+            rel1.to: "elm.swallow.end";
+            rel2.to: "elm.swallow.end";
+            text {
+               min: 1 1;
+               ellipsis: -1;
+               text: "M";
+            }
+         }
+      }
+      alias: "elm.units.min" "limits:elm.units.min";
+      alias: "elm.units.max" "limits:elm.units.max";
+      part { name: "limits"; type: GROUP; mouse_events: 0;
          source: "efl/slider/hidden/limit";
+         scale: 1;
+         description { state: "default" 0.0;
+            align: 0.5 1.0;
+            fixed: 1 1;
+            max: 0 0;
+            rel1.to_y: "elm.swallow.end";
+            rel1.relative: 0.0 0.0;
+            rel1.offset: 2 1;
+            rel2.to_y: "elm.swallow.end";
+            rel2.relative: 1.0 0.0;
+            rel2.offset: -3 0;
+         }
+         description { state: "visible" 0.0;
+            inherit: "default" 0.0;
+            min: SOURCE;
+            rel1.offset: 2 -3;
+            rel2.offset: -3 -3;
+         }
+         description { state: "disabled_visible" 0.0;
+            inherit: "default" 0.0;
+            rel1.offset: 2 -3;
+            rel2.offset: -3 -3;
+            color: 255 255 255 64;
+         }
+      }
+      part { name: "elm.units"; type: TEXT; mouse_events: 0;
+         effect: SHADOW BOTTOM;
+         scale: 1;
+         description { state: "default" 0.0;
+            visible: 0;
+            fixed: 1 1;
+            rel1.to_y: "limits";
+            rel2.to_y: "limits";
+            color: FN_COL_DEFAULT;
+            color_class: "slider_text";
+            text { font: FN; size: 10;
+               text_class: "slider";
+               min: 0 0;
+               align: 0.5 1.0;
+               ellipsis: -1;
+            }
+         }
+         description { state: "visible" 0.0;
+            inherit: "default" 0.0;
+            visible: 1;
+            text.min: 1 1;
+            text.ellipsis: -1;
+         }
+         description { state: "disabled_visible" 0.0;
+            inherit: "visible" 0.0;
+            color_class: "slider_text_disabled";
+            color3: 255 255 255 255;
+         }
       }
-      part { "button";
+      part { name: "button"; type: GROUP; mouse_events: 0;
          source: "efl/slider/vertical/indicator";
+         description { state: "default" 0.0;
+            fixed: 1 1;
+            rel1.to: "elm.dragable.slider";
+            rel2.to: "elm.dragable.slider";
+         }
+         description { state: "hidden" 0.0;
+            inherit: "default" 0.0;
+            visible: 0;
+         }
+      }
+      part { name: "elm.dragable.slider"; type: RECT;
+         scale: 1;
+         dragable.x: 0 0 0;
+         dragable.y: 1 1 0;
+         dragable.confine: "elm.swallow.bar";
+         description { state: "default" 0.0;
+            color: 0 0 0 0;
+            min: 16 16;
+            max: 16 16;
+            fixed: 1 1;
+            rel1.relative: 0.0 0.5;
+            rel1.to_x: "elm.swallow.bar";
+            rel2.relative: 1.0 0.5;
+            rel2.to_x: "elm.swallow.bar";
+         }
+      }
+      part { name: "knob";
+         description { state: "default" 0.0;
+            image.normal: "knob";
+            fixed: 1 1;
+            min: 12 12;
+            step: 2 2;
+            max: 32 32; // XXX allow bigger sizes with more knob images
+            rel1.to: "elm.dragable.slider";
+            rel1.offset: -4 -4;
+            rel2.to: "elm.dragable.slider";
+            rel2.offset: 3 3;
+         }
+         description { state: "clicked" 0.0;
+            inherit: "default" 0.0;
+         }
+      }
+      part { name: "slideevent"; type: RECT; repeat_events: 1;
+         scale: 1;
+         ignore_flags: ON_HOLD;
+         dragable.events: "elm.dragable.slider";
+         description { state: "default" 0.0;
+            fixed: 1 1;
+            rel1.to: "elm.dragable.slider";
+            rel2.to: "elm.dragable.slider";
+            color: 0 0 0 0;
+         }
+      }
+      part { name: "elm.track.slider"; type: SWALLOW; mouse_events: 0;
+         description { state: "default" 0.0;
+            max: 0 0;
+            rel1.to: "elm.dragable.slider";
+            rel2.to: "elm.dragable.slider";
+         }
+      }
+      part { name: "event"; type: RECT;
+         description { state: "default" 0.0;
+            color: 0 0 0 0;
+            visible: 0;
+         }
+         description { state: "disabled" 0.0;
+            inherit: "default" 0.0;
+            visible: 1;
+         }
       }
    }
+   programs {
+      program {
+         signal: "mouse,down,1"; source: "elm.dragable.slider";
+         action:  STATE_SET "clicked" 0.0;
+         target: "knob";
+      }
+      program {
+         signal: "mouse,up,1"; source: "elm.dragable.slider";
+         action:  STATE_SET "default" 0.0;
+         target: "knob";
+      }
+      program {
+         signal: "elm,state,indicator,show"; source: "elm";
+         action:  SIGNAL_EMIT "elm,popup,show" "elm";
+         after: "popup_show2";
+      }
+      program {
+         signal: "elm,state,indicator,hide"; source: "elm";
+         action:  SIGNAL_EMIT "elm,popup,hide" "elm";
+         after: "popup_hide2";
+      }
+      program {
+         signal: "mouse,down,1"; source: "slideevent";
+         action:  SIGNAL_EMIT "elm,popup,show" "elm";
+         after: "popup_show2";
+      }
+      program { name: "popup_show2";
+         action:  STATE_SET "hidden" 0.0;
+         target: "button";
+      }
+      program {
+         signal: "mouse,up,1"; source: "slideevent";
+         action:  SIGNAL_EMIT "elm,popup,hide" "elm";
+         after: "popup_hide2";
+      }
+      program { name: "popup_hide2";
+         action:  STATE_SET "default" 0.0;
+         target: "button";
+      }
+      program {
+         signal: "elm,state,elm.text,set"; source: "elm";
+         script {
+            new m = get_int(slmode);
+            m |= LABEL; set_int(slmode, m);
+            eval_mode(m);
+         }
+      }
+      program {
+         signal: "elm,state,elm.text,unset"; source: "elm";
+         script {
+            new m = get_int(slmode);
+            m &= ~LABEL; set_int(slmode, m);
+            eval_mode(m);
+         }
+      }
+      program {
+         signal: "elm,state,icon,set"; source: "elm";
+         script {
+            new m = get_int(slmode);
+            m |= ICON; set_int(slmode, m);
+            eval_mode(m);
+         }
+      }
+      program {
+         signal: "elm,state,icon,unset"; source: "elm";
+         script {
+            new m = get_int(slmode);
+            m &= ~ICON; set_int(slmode, m);
+            eval_mode(m);
+         }
+      }
+      program { name: "end_show";
+         signal: "elm,state,end,visible"; source: "elm";
+         script {
+            new m = get_int(slmode);
+            m |= END; set_int(slmode, m);
+            eval_mode(m);
+         }
+      }
+      program { name: "end_hide";
+         signal: "elm,state,end,hidden"; source: "elm";
+         script {
+            new m = get_int(slmode);
+            m &= ~END; set_int(slmode, m);
+            eval_mode(m);
+         }
+      }
+      program {
+         signal: "elm,state,units,visible"; source: "elm";
+         script {
+            new m = get_int(slmode);
+            m |= UNITS; set_int(slmode, m);
+            eval_mode(m);
+         }
+      }
+      program {
+         signal: "elm,state,units,visible"; source: "elm";
+         action: SIGNAL_EMIT "limits:limits,visible" "elm";
+      }
+      program {
+         signal: "elm,state,units,hidden"; source: "elm";
+         action:  STATE_SET "default" 0.0;
+         script {
+            new m = get_int(slmode);
+            m &= ~UNITS; set_int(slmode, m);
+            eval_mode(m);
+         }
+      }
+      program {
+         signal: "elm,state,units,hidden"; source: "elm";
+         action: SIGNAL_EMIT "limits:limits,hide" "elm";
+      }
+      program {
+         signal: "elm,state,inverted,on"; source: "elm";
+         script {
+            new m = get_int(slmode);
+            m |= INVERT; set_int(slmode, m);
+            eval_mode(m);
+         }
+      }
+      program {
+         signal: "elm,state,inverted,off"; source: "elm";
+         script {
+            new m = get_int(slmode);
+            m &= ~INVERT; set_int(slmode, m);
+            eval_mode(m);
+         }
+      }
+      program {
+         signal: "elm,state,disabled"; source: "elm";
+         script {
+            new m = get_int(slmode);
+            m |= DISABLE; set_int(slmode, m);
+            eval_mode(m);
+         }
+      }
+      program {
+         signal: "elm,state,enabled"; source: "elm";
+         script {
+            new m = get_int(slmode);
+            m &= ~DISABLE; set_int(slmode, m);
+            eval_mode(m);
+         }
+      }
+   }
+#undef ICON
+#undef LABEL
+#undef END
+#undef UNITS
+#undef MASK
+#undef INVERT
+#undef DISABLE
 }
 
 //Range
 
 group { "efl/slider_interval/horizontal";
-   inherit: "elm/slider/range/horizontal/default";
    alias: "efl/slider/horizontal:disabled";
+   images.image: "slider_run_base_horiz.png" COMP;
+   images.image: "slider_run_bevel_horiz.png" COMP;
+   images.image: "slider_run_base_light_horiz.png" COMP;
+   images.image: "horiz_glow_run.png" COMP;
+   images.image: "horiz_glow_range.png" COMP;
+   images.image: "horiz_glow_run_rev.png" COMP;
+   images.image: "knob_round_small_normal.png" COMP;
+   images.image: "knob_round_small_selected.png" COMP;
+   set { name: "knob";
+      // XXX: add more sizes (at least up to 128x128)
+      image { image: "knob_sz_24.png"  COMP; size: 31 31 32 32; }
+      image { image: "knob_sz_22.png"  COMP; size: 29 29 30 30; }
+      image { image: "knob_sz_20.png"  COMP; size: 27 27 28 28; }
+      image { image: "knob_sz_18.png"  COMP; size: 25 25 26 26; }
+      image { image: "knob_sz_16.png"  COMP; size: 23 23 24 24; }
+      image { image: "knob_sz_14.png"  COMP; size: 21 21 22 22; }
+      image { image: "knob_sz_12.png"  COMP; size: 19 19 20 20; }
+      image { image: "knob_sz_10.png"  COMP; size: 17 17 18 18; }
+      image { image: "knob_sz_08.png"  COMP; size: 15 15 16 16; }
+      image { image: "knob_sz_06.png"  COMP; size: 13 13 14 14; }
+      image { image: "knob_sz_04.png"  COMP; size:  0  0 12 12; }
+   }
+#define ICON    1
+#define LABEL   2
+#define END     4
+#define UNITS   8
+#define MASK    15
+#define INVERT  16
+#define DISABLE 32
+   script {
+      public slmode;
+      public range;
+      public g_timer_id;
+      public update_glow()
+        {
+           new x1,y1,w1,h1;
+           new x2,y2,w2,h2;
+           get_geometry(PART:"knob", x1, y1, w1, h1);
+           get_geometry(PART:"knob2", x2, y2, w2, h2);
+           if(x2 < x1)
+             set_state(PART:"glow", "range_reverse", 0.0);
+           else
+             set_state(PART:"glow", "range", 0.0);
+        }
+      public eval_mode(m) {
+         new ic = m & ICON;
+         new l = m & LABEL;
+         new e = m & END;
+         new u = m & UNITS;
+         new d = m & DISABLE;
+         new i = m & INVERT;
+         new r = get_int(range);
+         if (!r) {
+           if (i) {
+                if (!d) {
+                     set_state(PART:"base", "default", 0.0);
+                     set_state(PART:"glow", "inverted", 0.0);
+                } else {
+                     set_state(PART:"base", "disabled", 0.0);
+                     set_state(PART:"glow", "disabled_inverted", 0.0);
+                }
+           } else {
+                if (!d) {
+                     set_state(PART:"base", "default", 0.0);
+                     set_state(PART:"glow", "default", 0.0);
+                } else {
+                     set_state(PART:"base", "disabled", 0.0);
+                     set_state(PART:"glow", "disabled", 0.0);
+                }
+           }
+         } else if (d) {
+              new x1,y1,w1,h1;
+              new x2,y2,w2,h2;
+              get_geometry(PART:"knob", x1, y1, w1, h1);
+              get_geometry(PART:"knob2", x2, y2, w2, h2);
+              set_state(PART:"base", "disabled", 0.0);
+              if(x2 < x1)
+                set_state(PART:"glow", "disabled_range_reverse", 0.0);
+              else
+                set_state(PART:"glow", "disabled_range", 0.0);
+
+         }
+         if (l) {
+            if (!d) {
+               set_state(PART:"elm.text", "visible", 0.0);
+            } else {
+               set_state(PART:"elm.text", "disabled_visible", 0.0);
+            }
+         } else {
+            set_state(PART:"elm.text", "default", 0.0);
+         }
+         if (u) {
+            if (!d) {
+               set_state(PART:"elm.units", "visible", 0.0);
+               set_state(PART:"limits", "visible", 0.0);
+            } else {
+               set_state(PART:"elm.units", "disabled_visible", 0.0);
+               set_state(PART:"limits", "disabled_visible", 0.0);
+            }
+         } else {
+            set_state(PART:"elm.units", "default", 0.0);
+            set_state(PART:"limits", "default", 0.0);
+         }
+         if (ic) {
+            set_state(PART:"elm.swallow.icon", "visible", 0.0);
+            set_state(PART:"sizer.content", "visible", 0.0);
+         } else {
+            set_state(PART:"elm.swallow.icon", "default", 0.0);
+            set_state(PART:"sizer.content", "default", 0.0);
+         }
+         if (e) {
+            set_state(PART:"elm.swallow.end", "visible", 0.0);
+            set_state(PART:"sizer.content.end", "visible", 0.0);
+         } else {
+            set_state(PART:"elm.swallow.end", "default", 0.0);
+            set_state(PART:"sizer.content.end", "default", 0.0);
+         }
+         if (!d) {
+            set_state(PART:"event", "default", 0.0);
+            set_state(PART:"dis_clip", "default", 0.0);
+         } else {
+            set_state(PART:"event", "disabled", 0.0);
+            set_state(PART:"dis_clip", "disabled", 0.0);
+         }
+      }
+   }
    parts {
-      part { "limits";
+      part { name: "elm.swallow.bar"; type: SWALLOW;
+         scale: 1;
+         description { state: "default" 0.0;
+            min: 42 21;
+            max: 99999 21;
+            align: 1.0 0.5;
+            rel1.to_x: "elm.text";
+            rel1.relative: 1.0 0.0;
+            rel1.offset: 2 0;
+            rel2.to_x: "limits";
+            rel2.relative: 0.0 1.0;
+            rel2.offset: -3 -1;
+         }
+      }
+      part { name: "base"; mouse_events: 0;
+         description { state: "default" 0.0;
+            rel1.to: "elm.swallow.bar";
+            rel2.to: "elm.swallow.bar";
+            image.normal: "slider_run_base_horiz.png";
+            image.border: 4 4 0 0;
+            fill.smooth: 0;
+            min: 8 5;
+            max: 99999 5;
+            fixed: 0 1;
+         }
+         description { state: "disabled" 0.0;
+            inherit: "default" 0.0;
+            image.normal: "slider_run_base_light_horiz.png";
+         }
+      }
+      part { name: "glow"; mouse_events: 0;
+         description { state: "default" 0.0;
+            image.normal: "horiz_glow_run.png";
+            rel1.offset: 1 1;
+            rel1.to: "base";
+            rel2.relative: 0.5 1.0;
+            rel2.offset: -1 -2;
+            rel2.to_x: "button";
+            rel2.to_y: "base";
+            image.border: 0 4 0 0;
+         }
+         description { state: "disabled" 0.0;
+            inherit: "default" 0.0;
+            color: 255 255 255 64;
+         }
+         description { state: "inverted" 0.0;
+            image.normal: "horiz_glow_run_rev.png";
+            rel1.relative: 0.5 0.0;
+            rel1.offset: 0 1;
+            rel1.to_x: "button";
+            rel1.to_y: "base";
+            rel2.offset: -2 -2;
+            rel2.to: "base";
+            image.border: 4 0 0 0;
+         }
+         description { state: "range" 0.0;
+            image.normal: "horiz_glow_range.png";
+            rel1.relative: 0.5 1.0;
+            rel1.offset: -1 -2;
+            rel1.to_x: "button";
+            rel1.to_y: "base";
+            rel2.relative: 0.5 1.0;
+            rel2.offset: -1 -2;
+            rel2.to_x: "button2";
+            rel2.to_y: "base";
+            fixed: 0 1;
+            image.border: 0 4 0 0;
+         }
+         description { state: "disabled_range" 0.0;
+            inherit: "range" 0.0;
+            color: 255 255 255 64;
+         }
+         description { state: "range_reverse" 0.0;
+            inherit: "range" 0.0;
+            rel1.to_x: "button2";
+            rel2.to_x: "button";
+         }
+         description { state: "disabled_range_reverse" 0.0;
+            inherit: "range_reverse" 0.0;
+            color: 255 255 255 64;
+         }
+         description { state: "disabled_inverted" 0.0;
+            inherit: "inverted" 0.0;
+            color: 255 255 255 64;
+         }
+      }
+      part { name: "bevel"; mouse_events: 0;
+         description { state: "default" 0.0;
+            rel1.to: "base";
+            rel2.to: "base";
+            image.normal: "slider_run_bevel_horiz.png";
+            image.border: 5 5 0 0;
+            fill.smooth: 0;
+         }
+      }
+      part { name: "dis_clip"; type: RECT;
+         description { state: "default" 0.0;
+            rel1.to: "elm.swallow.icon";
+            rel2.to: "elm.swallow.end";
+         }
+         description { state: "disabled" 0.0;
+            inherit: "default" 0.0;
+            color: 255 255 255 64;
+         }
+      }
+      part { name: "elm.swallow.icon"; type: SWALLOW;
+         clip_to: "dis_clip";
+         required;
+         description { state: "default" 0.0;
+            visible: 0;
+            align: 0.0 0.5;
+            rel1.offset: 0 2;
+            rel1.to_y: "elm.swallow.bar";
+            rel2.offset: -1 -3;
+            rel2.relative: 0.0 1.0;
+            rel2.to_y: "elm.swallow.bar";
+            fixed: 1 0;
+         }
+         description { state: "visible" 0.0;
+            inherit: "default" 0.0;
+            visible: 1;
+            aspect: 1.0 1.0; aspect_preference: VERTICAL;
+            rel1.offset: 2 2;
+            rel2.offset: 2 -3;
+         }
+      }
+      part { name: "sizer.content"; type: TEXT; mouse_events:  0;
+         scale: 1;
+         description { state: "default" 0.0;
+            fixed: 1 1;
+            visible: 0;
+            text { font: FN; size: 10;
+               min: 0 0;
+               text_class: "slider_text";
+            }
+         }
+         description { state: "visible" 0.0;
+            inherit: "default" 0.0;
+            rel1.to: "elm.swallow.icon";
+            rel2.to: "elm.swallow.icon";
+            text {
+               min: 1 1;
+               ellipsis: -1;
+               text: "M";
+            }
+         }
+      }
+      part { name: "elm.text"; type: TEXT; mouse_events: 0;
+         effect: SHADOW BOTTOM;
+         scale: 1;
+         required;
+         description { state: "default" 0.0;
+            fixed: 1 1;
+            align: 0.0 0.5;
+            rel1.to_x: "elm.swallow.icon";
+            rel1.relative: 1.0 0.0;
+            rel1.offset: -1 2;
+            rel2.to_x: "elm.swallow.icon";
+            rel2.relative: 1.0 1.0;
+            rel2.offset: -1 -3;
+            color: FN_COL_DEFAULT;
+            color_class: "slider_text";
+            text { font: FN; size: 10;
+               text_class: "slider";
+               min: 0 0;
+               align: 0.0 0.5;
+            }
+            visible: 0;
+         }
+         description { state: "visible" 0.0;
+            inherit: "default" 0.0;
+            fixed: 1 0;
+            visible: 1;
+            rel1.offset: 2 2;
+            rel2.offset: 2 -3;
+            text.min: 1 1;
+            text.ellipsis: -1;
+         }
+         description { state: "disabled_visible" 0.0;
+            inherit: "visible" 0.0;
+            color_class: "slider_text_disabled";
+            color3: 255 255 255 255;
+         }
+      }
+      part { name: "elm.swallow.end"; type: SWALLOW;
+         clip_to: "dis_clip";
+         description { state: "default" 0.0;
+            visible: 0;
+            align: 1.0 0.5;
+            rel1.offset: 0 2;
+            rel1.relative: 1.0 0.0;
+            rel2.offset: -1 -3;
+            fixed: 1 0;
+         }
+         description { state: "visible" 0.0;
+            inherit: "default" 0.0;
+            visible: 1;
+            aspect: 1.0 1.0;
+            aspect_preference: VERTICAL;
+            rel1.offset: -3 2;
+            rel2.offset: -3 -3;
+         }
+      }
+      part { name: "sizer.content.end"; type: TEXT; mouse_events:  0;
+         scale: 1;
+         description { state: "default" 0.0;
+            fixed: 1 1;
+            visible: 0;
+            text { font: FN; size: 10;
+               min: 0 0;
+               text_class: "slider_text";
+            }
+         }
+         description { state: "visible" 0.0;
+            inherit: "default" 0.0;
+            rel1.to: "elm.swallow.end";
+            rel2.to: "elm.swallow.end";
+            text {
+               min: 1 1;
+               ellipsis: -1;
+               text: "M";
+            }
+         }
+      }
+      alias: "elm.units.min" "limits:elm.units.min";
+      alias: "elm.units.max" "limits:elm.units.max";
+      part { name: "limits"; type: GROUP; mouse_events: 0;
          source: "efl/slider/hidden/limit";
+         scale: 1;
+         description { state: "default" 0.0;
+            visible: 0;
+            align: 1.0 0.5;
+            min: SOURCE;
+            fixed: 1 1;
+            rel1.to_x: "elm.swallow.end";
+            rel1.relative: 0.0 0.0;
+            rel1.offset: 0 2;
+            rel2.to_x: "elm.swallow.end";
+            rel2.relative: 0.0 1.0;
+            rel2.offset: -1 -3;
+         }
+         description { state: "visible" 0.0;
+            inherit: "default" 0.0;
+            rel1.offset: -3 2;
+            rel2.offset: -3 -3;
+         }
+         description { state: "disabled_visible" 0.0;
+            inherit: "default" 0.0;
+            rel1.offset: -3 2;
+            rel2.offset: -3 -3;
+            color: 255 255 255 64;
+         }
+      }
+      part { name: "elm.units"; type: TEXT; mouse_events: 0;
+         effect: SHADOW BOTTOM;
+         scale: 1;
+         description { state: "default" 0.0;
+            visible: 0;
+            fixed: 1 1;
+            rel1.to_x: "limits";
+            rel2.to_x: "limits";
+            color: FN_COL_DEFAULT;
+            color_class: "slider_text";
+            text { font: FN; size: 10;
+               text_class: "slider";
+               align: 1.0 0.5;
+               min: 1 1;
+               ellipsis: -1;
+            }
+         }
+         description { state: "visible" 0.0;
+            inherit: "default" 0.0;
+            visible: 1;
+         }
+         description { state: "disabled_visible" 0.0;
+            inherit: "visible" 0.0;
+            color_class: "slider_text_disabled";
+            color3: 255 255 255 255;
+         }
+      }
+      part { name: "button"; type: GROUP; mouse_events: 0;
+         source: "efl/slider_interval/horizontal/indicator";
+         description { state: "default" 0.0;
+            fixed: 1 1;
+            rel1.to: "elm.dragable.slider";
+            rel2.to: "elm.dragable.slider";
+         }
+         description { state: "hidden" 0.0;
+            inherit: "default" 0.0;
+            visible: 0;
+         }
+      }
+      part { name: "elm.dragable.slider"; type: RECT;
+         scale: 1;
+         dragable.x: 1 1 0;
+         dragable.y: 0 0 0;
+         dragable.confine: "elm.swallow.bar";
+         description { state: "default" 0.0;
+            color: 0 0 0 0;
+            min: 16 16;
+            max: 16 16;
+            fixed: 1 1;
+            rel1.relative: 0.5 0.0;
+            rel1.to_x: "elm.swallow.bar";
+            rel2.relative: 0.5 1.0;
+            rel2.to_x: "elm.swallow.bar";
+         }
+      }
+      part { name: "knob";
+         description { state: "default" 0.0;
+            image.normal: "knob";
+            fixed: 1 1;
+            min: 12 12;
+            step: 2 2;
+            max: 32 32; // XXX allow bigger sizes with more knob images
+            rel1.to: "elm.dragable.slider";
+            rel1.offset: -4 -4;
+            rel2.to: "elm.dragable.slider";
+            rel2.offset: 3 3;
+         }
+         description { state: "clicked" 0.0;
+            inherit: "default" 0.0;
+         }
+      }
+      part { name: "slideevent"; type: RECT; repeat_events: 1;
+         scale: 1;
+         ignore_flags: ON_HOLD;
+         dragable.events: "elm.dragable.slider";
+         description { state: "default" 0.0;
+            fixed: 1 1;
+            rel1.to: "elm.dragable.slider";
+            rel2.to: "elm.dragable.slider";
+            color: 0 0 0 0;
+         }
       }
-      part { "button";
+      part { name: "elm.track.slider"; type: SWALLOW; mouse_events: 0;
+         description { state: "default" 0.0;
+            max: 0 0;
+            rel1.to: "elm.dragable.slider";
+            rel2.to: "elm.dragable.slider";
+         }
+      }
+      part { name: "button2"; type: GROUP; mouse_events: 0;
          source: "efl/slider_interval/horizontal/indicator";
+         description { state: "default" 0.0;
+            fixed: 1 1;
+            rel1.to: "elm.dragable2.slider";
+            rel2.to: "elm.dragable2.slider";
+            visible: 0;
+         }
+         description { state: "show" 0.0;
+            inherit: "default" 0.0;
+            visible: 1;
+         }
+         description { state: "hidden" 0.0;
+            inherit: "default" 0.0;
+            visible: 0;
+         }
+      }
+      part { name: "elm.dragable2.slider"; type: RECT;
+         scale: 1;
+         dragable.x: 1 1 0;
+         dragable.y: 0 0 0;
+         dragable.confine: "elm.swallow.bar";
+         description { state: "default" 0.0;
+            color: 0 0 0 0;
+            min: 16 16;
+            max: 16 16;
+            fixed: 1 1;
+            rel1.relative: 0.5 0.0;
+            rel1.to_x: "elm.swallow.bar";
+            rel2.relative: 0.5 1.0;
+            rel2.to_x: "elm.swallow.bar";
+            visible: 0;
+         }
+         description { state: "show" 0.0;
+            inherit: "default" 0.0;
+            visible: 1;
+         }
+      }
+      part { name: "knob2";
+         description { state: "default" 0.0;
+            image.normal: "knob";
+            fixed: 1 1;
+            min: 12 12;
+            step: 2 2;
+            max: 32 32; // XXX allow bigger sizes with more knob images
+            rel1.to: "elm.dragable2.slider";
+            rel1.offset: -4 -4;
+            rel2.to: "elm.dragable2.slider";
+            rel2.offset: 3 3;
+            visible: 0;
+         }
+         description { state: "show" 0.0;
+            inherit: "default" 0.0;
+            visible: 1;
+         }
+         description { state: "clicked" 0.0;
+            inherit: "default" 0.0;
+         }
+      }
+      part { name: "slideevent2"; type: RECT; repeat_events: 1;
+         scale: 1;
+         ignore_flags: ON_HOLD;
+         dragable.events: "elm.dragable2.slider";
+         description { state: "default" 0.0;
+            fixed: 1 1;
+            rel1.to: "elm.dragable2.slider";
+            rel2.to: "elm.dragable2.slider";
+            color: 0 0 0 0;
+            visible: 0;
+         }
+         description { state: "show" 0.0;
+            inherit: "default" 0.0;
+            visible: 1;
+         }
+      }
+      part { name: "elm.track2.slider"; type: SWALLOW; mouse_events: 0;
+         description { state: "default" 0.0;
+            max: 0 0;
+            rel1.to: "elm.dragable2.slider";
+            rel2.to: "elm.dragable2.slider";
+            visible: 0;
+         }
+         description { state: "show" 0.0;
+            inherit: "default" 0.0;
+            visible: 1;
+         }
+      }
+      part { name: "event"; type: RECT;
+         description { state: "default" 0.0;
+            color: 0 0 0 0;
+            visible: 0;
+         }
+         description { state: "disabled" 0.0;
+            inherit: "default" 0.0;
+            visible: 1;
+         }
+      }
+   }
+   programs {
+      program {
+         signal: "mouse,down,1"; source: "elm.dragable.slider";
+         action:  STATE_SET "clicked" 0.0;
+         target: "knob";
+      }
+      program {
+         signal: "mouse,up,1"; source: "elm.dragable.slider";
+         action:  STATE_SET "default" 0.0;
+         target: "knob";
+      }
+      program {
+         signal: "elm,slider,range,enable";
+         source: "elm";
+         script {
+              set_int(range, 1);
+              set_state(PART:"button2", "show", 0.0);
+              set_state(PART:"elm.dragable2.slider", "show", 0.0);
+              set_state(PART:"knob2", "show", 0.0);
+              set_state(PART:"slideevent2", "show", 0.0);
+              set_state(PART:"elm.track2.slider", "show", 0.0);
+              update_glow();
+              new m = get_int(slmode);
+              eval_mode(m);
+         }
+      }
+      program {
+         signal: "elm,slider,range,disable";
+         source: "elm";
+         script {
+              set_int(range, 0);
+              set_state(PART:"button2", "default", 0.0);
+              set_state(PART:"elm.dragable2.slider", "default", 0.0);
+              set_state(PART:"knob2", "default", 0.0);
+              set_state(PART:"slideevent2", "default", 0.0);
+              set_state(PART:"elm.track2.slider", "default", 0.0);
+              set_state(PART:"glow", "default", 0.0);
+              new m = get_int(slmode);
+              eval_mode(m);
+         }
+      }
+      program {
+         signal: "drag";
+         source: "elm.dragable*";
+         script {
+              new r;
+              r = get_int(range);
+              if (r)
+                 update_glow();
+         }
+      }
+      program {
+         signal: "elm,state,indicator,show"; source: "elm";
+         action:  SIGNAL_EMIT "elm,popup,show" "elm";
+         after: "popup_show2";
+      }
+      program {
+         signal: "elm,state,indicator,hide"; source: "elm";
+         action:  SIGNAL_EMIT "elm,popup,hide" "elm";
+         after: "popup_hide2";
+      }
+      program {
+         signal: "mouse,down,1"; source: "slideevent";
+         action:  SIGNAL_EMIT "elm,popup,show" "elm";
+         after: "popup_show2";
+      }
+      program { name: "popup_show2";
+         action:  STATE_SET "hidden" 0.0;
+         target: "button";
+      }
+      program {
+         signal: "mouse,up,1"; source: "slideevent";
+         action:  SIGNAL_EMIT "elm,popup,hide" "elm";
+         after: "popup_hide2";
+      }
+      program { name: "popup_hide2";
+         action:  STATE_SET "default" 0.0;
+         target: "button";
+      }
+      program {
+         signal: "mouse,down,1"; source: "slideevent2";
+         action:  SIGNAL_EMIT "elm,popup,show" "elm";
+         after: "popup2_show2";
+      }
+      program { name: "popup2_show2";
+         action:  STATE_SET "show" 0.0;
+         target: "button2";
+      }
+      program {
+         signal: "mouse,up,1"; source: "slideevent2";
+         action:  SIGNAL_EMIT "elm,popup,hide" "elm";
+         after: "popup2_hide2";
+      }
+      program { name: "popup2_hide2";
+         action:  STATE_SET "hidden" 0.0;
+         target: "button2";
+      }
+      program {
+         signal: "elm,state,elm.text,set"; source: "elm";
+         script {
+            new m = get_int(slmode);
+            m |= LABEL; set_int(slmode, m);
+            eval_mode(m);
+         }
+      }
+      program {
+         signal: "elm,state,elm.text,unset"; source: "elm";
+         script {
+            new m = get_int(slmode);
+            m &= ~LABEL; set_int(slmode, m);
+            eval_mode(m);
+         }
+      }
+      program {
+         signal: "elm,state,icon,set"; source: "elm";
+         script {
+            new m = get_int(slmode);
+            m |= ICON; set_int(slmode, m);
+            eval_mode(m);
+         }
+      }
+      program {
+         signal: "elm,state,icon,unset"; source: "elm";
+         script {
+            new m = get_int(slmode);
+            m &= ~ICON; set_int(slmode, m);
+            eval_mode(m);
+         }
+      }
+      program { name: "end_show";
+         signal: "elm,state,end,visible"; source: "elm";
+         script {
+            new m = get_int(slmode);
+            m |= END; set_int(slmode, m);
+            eval_mode(m);
+         }
+      }
+      program { name: "end_hide";
+         signal: "elm,state,end,hidden"; source: "elm";
+         script {
+            new m = get_int(slmode);
+            m &= ~END; set_int(slmode, m);
+            eval_mode(m);
+         }
+      }
+      program {
+         signal: "elm,state,units,visible"; source: "elm";
+         script {
+            new m = get_int(slmode);
+            m |= UNITS; set_int(slmode, m);
+            eval_mode(m);
+         }
+      }
+      program {
+         signal: "elm,state,units,visible"; source: "elm";
+         action: SIGNAL_EMIT "limits,visible" "elm";
+         target: "limits";
+      }
+      program {
+         signal: "elm,state,units,hidden"; source: "elm";
+         action:  STATE_SET "default" 0.0;
+         script {
+            new m = get_int(slmode);
+            m &= ~UNITS; set_int(slmode, m);
+            eval_mode(m);
+         }
+      }
+      program {
+         signal: "elm,state,units,hidden"; source: "elm";
+         action: SIGNAL_EMIT "limits,hide" "elm";
+         target: "limits";
+      }
+      program {
+         signal: "elm,state,inverted,on"; source: "elm";
+         script {
+            new m = get_int(slmode);
+            m |= INVERT; set_int(slmode, m);
+            eval_mode(m);
+         }
+      }
+      program {
+         signal: "elm,state,inverted,off"; source: "elm";
+         script {
+            new m = get_int(slmode);
+            m &= ~INVERT; set_int(slmode, m);
+            eval_mode(m);
+         }
+      }
+      program {
+         signal: "elm,state,disabled"; source: "elm";
+         script {
+            new m = get_int(slmode);
+            m |= DISABLE; set_int(slmode, m);
+            eval_mode(m);
+         }
+      }
+      program {
+         signal: "elm,state,enabled"; source: "elm";
+         script {
+            new m = get_int(slmode);
+            m &= ~DISABLE; set_int(slmode, m);
+            eval_mode(m);
+         }
       }
    }
+#undef ICON
+#undef LABEL
+#undef END
+#undef UNITS
+#undef MASK
+#undef INVERT
+#undef DISABLE
 }
 
 group { "efl/slider_interval/vertical";
-   inherit: "elm/slider/range/vertical/default";
    alias: "efl/slider/vertical:disabled";
+   images.image: "slider_run_base_vert.png" COMP;
+   images.image: "slider_run_bevel_vert.png" COMP;
+   images.image: "slider_run_base_light_vert.png" COMP;
+   images.image: "vert_glow_run.png" COMP;
+   images.image: "vert_glow_range.png" COMP;
+   images.image: "vert_glow_run_rev.png" COMP;
+   images.image: "knob_round_small_normal.png" COMP;
+   images.image: "knob_round_small_selected.png" COMP;
+   set { name: "knob";
+      // XXX: add more sizes (at least up to 128x128)
+      image { image: "knob_sz_24.png"  COMP; size: 31 31 32 32; }
+      image { image: "knob_sz_22.png"  COMP; size: 29 29 30 30; }
+      image { image: "knob_sz_20.png"  COMP; size: 27 27 28 28; }
+      image { image: "knob_sz_18.png"  COMP; size: 25 25 26 26; }
+      image { image: "knob_sz_16.png"  COMP; size: 23 23 24 24; }
+      image { image: "knob_sz_14.png"  COMP; size: 21 21 22 22; }
+      image { image: "knob_sz_12.png"  COMP; size: 19 19 20 20; }
+      image { image: "knob_sz_10.png"  COMP; size: 17 17 18 18; }
+      image { image: "knob_sz_08.png"  COMP; size: 15 15 16 16; }
+      image { image: "knob_sz_06.png"  COMP; size: 13 13 14 14; }
+      image { image: "knob_sz_04.png"  COMP; size:  0  0 12 12; }
+   }
+#define ICON    1
+#define LABEL   2
+#define END     4
+#define UNITS   8
+#define MASK    15
+#define INVERT  16
+#define DISABLE 32
+   script {
+      public slmode;
+      public range;
+      public g_timer_id;
+      public update_glow()
+        {
+           new x1,y1,w1,h1;
+           new x2,y2,w2,h2;
+           get_geometry(PART:"knob", x1, y1, w1, h1);
+           get_geometry(PART:"knob2", x2, y2, w2, h2);
+           if(y2 < y1)
+             set_state(PART:"glow", "range_reverse", 0.0);
+           else
+             set_state(PART:"glow", "range", 0.0);
+        }
+      public eval_mode(m) {
+         new ic = m & ICON;
+         new l = m & LABEL;
+         new e = m & END;
+         new u = m & UNITS;
+         new d = m & DISABLE;
+         new i = m & INVERT;
+         new r = get_int(range);
+         if (!r) {
+            if (i) {
+               if (!d) {
+                  set_state(PART:"base", "default", 0.0);
+                  set_state(PART:"glow", "inverted", 0.0);
+               } else {
+                  set_state(PART:"base", "disabled", 0.0);
+                  set_state(PART:"glow", "disabled_inverted", 0.0);
+               }
+            } else {
+               if (!d) {
+                  set_state(PART:"base", "default", 0.0);
+                  set_state(PART:"glow", "default", 0.0);
+               } else {
+                  set_state(PART:"base", "disabled", 0.0);
+                  set_state(PART:"glow", "disabled", 0.0);
+               }
+            }
+         } else if (d) {
+              new x1,y1,w1,h1;
+              new x2,y2,w2,h2;
+              get_geometry(PART:"knob", x1, y1, w1, h1);
+              get_geometry(PART:"knob2", x2, y2, w2, h2);
+              set_state(PART:"base", "disabled", 0.0);
+              if(y2 < y1)
+                set_state(PART:"glow", "disabled_range_reverse", 0.0);
+              else
+                set_state(PART:"glow", "disabled_range", 0.0);
+         }
+         if (l) {
+            if (!d) {
+               set_state(PART:"elm.text", "visible", 0.0);
+            } else {
+               set_state(PART:"elm.text", "disabled_visible", 0.0);
+            }
+         } else {
+            set_state(PART:"elm.text", "default", 0.0);
+         }
+         if (u) {
+            if (!d) {
+               set_state(PART:"elm.units", "visible", 0.0);
+               set_state(PART:"limits", "visible", 0.0);
+            } else {
+               set_state(PART:"elm.units", "disabled_visible", 0.0);
+               set_state(PART:"limits", "disabled_visible", 0.0);
+            }
+         } else {
+            set_state(PART:"elm.units", "default", 0.0);
+            set_state(PART:"limits", "default", 0.0);
+         }
+         if (ic) {
+            set_state(PART:"elm.swallow.icon", "visible", 0.0);
+            set_state(PART:"sizer.content", "visible", 0.0);
+         } else {
+            set_state(PART:"elm.swallow.icon", "default", 0.0);
+            set_state(PART:"sizer.content", "default", 0.0);
+         }
+         if (e) {
+            set_state(PART:"elm.swallow.end", "visible", 0.0);
+            set_state(PART:"sizer.content.end", "visible", 0.0);
+         } else {
+            set_state(PART:"elm.swallow.end", "default", 0.0);
+            set_state(PART:"sizer.content.end", "default", 0.0);
+         }
+         if (!d) {
+            set_state(PART:"event", "default", 0.0);
+            set_state(PART:"dis_clip", "default", 0.0);
+         } else {
+            set_state(PART:"event", "disabled", 0.0);
+            set_state(PART:"dis_clip", "disabled", 0.0);
+         }
+      }
+   }
    parts {
-      part { "limits";
+      part { name: "elm.swallow.bar"; type: SWALLOW;
+         scale: 1;
+         description { state: "default" 0.0;
+            min: 21 42;
+            max: 21 99999;
+            align: 0.5 1.0;
+            rel1.to_y: "elm.text";
+            rel1.relative: 0.0 1.0;
+            rel1.offset: 0 2;
+            rel2.to_y: "limits";
+            rel2.relative: 1.0 0.0;
+            rel2.offset: -1 -3;
+         }
+      }
+      part { name: "base"; mouse_events: 0;
+         description { state: "default" 0.0;
+            rel1.to: "elm.swallow.bar";
+            rel2.to: "elm.swallow.bar";
+            image.normal: "slider_run_base_vert.png";
+            image.border: 0 0 4 4;
+            fill.smooth: 0;
+            min: 5 8;
+            max: 5 99999;
+            fixed: 1 0;
+         }
+         description { state: "disabled" 0.0;
+            inherit: "default" 0.0;
+            image.normal: "slider_run_base_light_vert.png";
+         }
+      }
+      part { name: "glow"; mouse_events: 0;
+         description { state: "default" 0.0;
+            image.normal: "vert_glow_run.png";
+            rel1.offset: 1 1;
+            rel1.to: "base";
+            rel2.relative: 1.0 0.5;
+            rel2.offset: -2 -1;
+            rel2.to_y: "button";
+            rel2.to_x: "base";
+            image.border: 0 0 0 4;
+         }
+         description { state: "disabled" 0.0;
+            inherit: "default" 0.0;
+            color: 255 255 255 64;
+         }
+         description { state: "inverted" 0.0;
+            image.normal: "vert_glow_run_rev.png";
+            rel1.relative: 0.0 0.5;
+            rel1.offset: 1 0;
+            rel1.to_y: "button";
+            rel1.to_x: "base";
+            rel2.offset: -2 -2;
+            rel2.to: "base";
+            image.border: 0 0 4 0;
+         }
+         description { state: "range" 0.0;
+            image.normal: "vert_glow_range.png";
+            rel1.relative: 0.5 1.0;
+            rel1.offset: -1 -2;
+            rel1.to_x: "base";
+            rel1.to_y: "button";
+            rel2.relative: 0.5 1.0;
+            rel2.offset: -1 -2;
+            rel2.to_x: "base";
+            rel2.to_y: "button2";
+            fixed: 1 0;
+            image.border: 0 4 0 0;
+         }
+         description { state: "disabled_range" 0.0;
+            inherit: "range" 0.0;
+            color: 255 255 255 64;
+         }
+         description { state: "range_reverse" 0.0;
+            inherit: "range" 0.0;
+            rel1.to_y: "button2";
+            rel2.to_y: "button";
+         }
+         description { state: "disabled_range_reverse" 0.0;
+            inherit: "range_reverse" 0.0;
+            color: 255 255 255 64;
+         }
+         description { state: "disabled_inverted" 0.0;
+            inherit: "inverted" 0.0;
+            color: 255 255 255 64;
+         }
+      }
+      part { name: "bevel"; mouse_events: 0;
+         description { state: "default" 0.0;
+            rel1.to: "base";
+            rel2.to: "base";
+            image.normal: "slider_run_bevel_vert.png";
+            image.border: 0 0 5 5;
+            fill.smooth: 0;
+         }
+      }
+      part { name: "dis_clip"; type: RECT;
+         description { state: "default" 0.0;
+            rel1.to: "elm.swallow.icon";
+            rel2.to: "elm.swallow.end";
+         }
+         description { state: "disabled" 0.0;
+            inherit: "default" 0.0;
+            color: 255 255 255 64;
+         }
+      }
+      part { name: "elm.swallow.icon"; type: SWALLOW;
+         clip_to: "dis_clip";
+         required;
+         description { state: "default" 0.0;
+            visible: 0;
+            align: 0.5 0.0;
+            rel1.offset: 2 0;
+            rel1.to_x: "elm.swallow.bar";
+            rel2.offset: -3 -1;
+            rel2.relative: 1.0 0.0;
+            rel2.to_x: "elm.swallow.bar";
+            fixed: 0 1;
+         }
+         description { state: "visible" 0.0;
+            inherit: "default" 0.0;
+            visible: 1;
+            aspect: 1.0 1.0; aspect_preference: VERTICAL;
+            rel1.offset: 2 2;
+            rel2.offset: -3 2;
+         }
+      }
+      part { name: "sizer.content"; type: TEXT; mouse_events:  0;
+         scale: 1;
+         description { state: "default" 0.0;
+            fixed: 1 1;
+            visible: 0;
+            text { font: FN; size: 10;
+               min: 0 0;
+               text_class: "slider_text";
+            }
+         }
+         description { state: "visible" 0.0;
+            inherit: "default" 0.0;
+            rel1.to: "elm.swallow.icon";
+            rel2.to: "elm.swallow.icon";
+            text {
+               min: 1 1;
+               ellipsis: -1;
+               text: "M";
+            }
+         }
+      }
+      part { name: "elm.text"; type: TEXT; mouse_events: 0;
+         effect: SHADOW BOTTOM;
+         scale: 1;
+         required;
+         description { state: "default" 0.0;
+            fixed: 0 1;
+            align: 0.5 0.0;
+            rel1.to_y: "elm.swallow.icon";
+            rel1.relative: 0.0 1.0;
+            rel1.offset: 2 -1;
+            rel2.to_y: "elm.swallow.icon";
+            rel2.relative: 1.0 1.0;
+            rel2.offset: -3 -1;
+            color: FN_COL_DEFAULT;
+            color_class: "slider_text";
+            text { font: FN; size: 10;
+               text_class: "slider";
+               min: 1 0;
+               ellipsis: -1;
+               align: 0.5 0.0;
+            }
+            visible: 0;
+         }
+         description { state: "visible" 0.0;
+            inherit: "default" 0.0;
+            visible: 1;
+            rel1.offset: 2 2;
+            rel2.offset: -3 2;
+            text.min: 1 1;
+            text.ellipsis: -1;
+
+         }
+         description { state: "disabled_visible" 0.0;
+            inherit: "visible" 0.0;
+            color_class: "slider_text_disabled";
+            color3: 255 255 255 255;
+         }
+      }
+      part { name: "elm.swallow.end"; type: SWALLOW;
+         clip_to: "dis_clip";
+         description { state: "default" 0.0;
+            visible: 0;
+            align: 0.5 1.0;
+            rel1.offset: 2 0;
+            rel1.relative: 0.0 1.0;
+            rel2.offset: -3 -1;
+            fixed: 0 1;
+         }
+         description { state: "visible" 0.0;
+            inherit: "default" 0.0;
+            visible: 1;
+            aspect: 1.0 1.0;
+            aspect_preference: VERTICAL;
+            rel2.offset: 2 -3;
+            rel2.offset: -3 -3;
+         }
+      }
+      part { name: "sizer.content.end"; type: TEXT; mouse_events:  0;
+         scale: 1;
+         description { state: "default" 0.0;
+            fixed: 1 1;
+            visible: 0;
+            text { font: FN; size: 10;
+               min: 0 0;
+               text_class: "slider_text";
+            }
+         }
+         description { state: "visible" 0.0;
+            inherit: "default" 0.0;
+            rel1.to: "elm.swallow.end";
+            rel2.to: "elm.swallow.end";
+            text {
+               min: 1 1;
+               ellipsis: -1;
+               text: "M";
+            }
+         }
+      }
+      alias: "elm.units.min" "limits:elm.units.min";
+      alias: "elm.units.max" "limits:elm.units.max";
+      part { name: "limits"; type: GROUP; mouse_events: 0;
          source: "efl/slider/hidden/limit";
+         scale: 1;
+         description { state: "default" 0.0;
+            align: 0.5 1.0;
+            fixed: 1 1;
+            max: 0 0;
+            rel1.to_y: "elm.swallow.end";
+            rel1.relative: 0.0 0.0;
+            rel1.offset: 2 1;
+            rel2.to_y: "elm.swallow.end";
+            rel2.relative: 1.0 0.0;
+            rel2.offset: -3 0;
+         }
+         description { state: "visible" 0.0;
+            inherit: "default" 0.0;
+            min: SOURCE;
+            rel1.offset: 2 -3;
+            rel2.offset: -3 -3;
+         }
+         description { state: "disabled_visible" 0.0;
+            inherit: "default" 0.0;
+            rel1.offset: -3 2;
+            rel2.offset: -3 -3;
+            color: 255 255 255 64;
+         }
       }
-      part { "button";
+      part { name: "elm.units"; type: TEXT; mouse_events: 0;
+         effect: SHADOW BOTTOM;
+         scale: 1;
+         description { state: "default" 0.0;
+            visible: 0;
+            fixed: 1 1;
+            rel1.to_y: "limits";
+            rel2.to_y: "limits";
+            color: FN_COL_DEFAULT;
+            color_class: "slider_text";
+            text { font: FN; size: 10;
+               text_class: "slider";
+               min: 0 0;
+               align: 0.5 1.0;
+               ellipsis: -1;
+            }
+         }
+         description { state: "visible" 0.0;
+            inherit: "default" 0.0;
+            visible: 1;
+            text.min: 1 1;
+            text.ellipsis: -1;
+         }
+         description { state: "disabled_visible" 0.0;
+            inherit: "visible" 0.0;
+            color_class: "slider_text_disabled";
+            color3: 255 255 255 255;
+         }
+      }
+      part { name: "button"; type: GROUP; mouse_events: 0;
+         source: "efl/slider_interval/vertical/indicator";
+         description { state: "default" 0.0;
+            fixed: 1 1;
+            rel1.to: "elm.dragable.slider";
+            rel2.to: "elm.dragable.slider";
+         }
+         description { state: "hidden" 0.0;
+            inherit: "default" 0.0;
+            visible: 0;
+         }
+      }
+      part { name: "elm.dragable.slider"; type: RECT;
+         scale: 1;
+         dragable.x: 0 0 0;
+         dragable.y: 1 1 0;
+         dragable.confine: "elm.swallow.bar";
+         description { state: "default" 0.0;
+            color: 0 0 0 0;
+            min: 16 16;
+            max: 16 16;
+            fixed: 1 1;
+            rel1.relative: 0.0 0.5;
+            rel1.to_x: "elm.swallow.bar";
+            rel2.relative: 1.0 0.5;
+            rel2.to_x: "elm.swallow.bar";
+         }
+      }
+      part { name: "knob";
+         description { state: "default" 0.0;
+            image.normal: "knob";
+            fixed: 1 1;
+            min: 12 12;
+            step: 2 2;
+            max: 32 32; // XXX allow bigger sizes with more knob images
+            rel1.to: "elm.dragable.slider";
+            rel1.offset: -4 -4;
+            rel2.to: "elm.dragable.slider";
+            rel2.offset: 3 3;
+         }
+         description { state: "clicked" 0.0;
+            inherit: "default" 0.0;
+         }
+      }
+      part { name: "slideevent"; type: RECT; repeat_events: 1;
+         scale: 1;
+         ignore_flags: ON_HOLD;
+         dragable.events: "elm.dragable.slider";
+         description { state: "default" 0.0;
+            fixed: 1 1;
+            rel1.to: "elm.dragable.slider";
+            rel2.to: "elm.dragable.slider";
+            color: 0 0 0 0;
+         }
+      }
+      part { name: "elm.track.slider"; type: SWALLOW; mouse_events: 0;
+         description { state: "default" 0.0;
+            max: 0 0;
+            rel1.to: "elm.dragable.slider";
+            rel2.to: "elm.dragable.slider";
+         }
+      }
+      part { name: "button2"; type: GROUP; mouse_events: 0;
          source: "efl/slider_interval/vertical/indicator";
+         description { state: "default" 0.0;
+            fixed: 1 1;
+            rel1.to: "elm.dragable2.slider";
+            rel2.to: "elm.dragable2.slider";
+            visible: 0;
+         }
+         description { state: "hidden" 0.0;
+            inherit: "default" 0.0;
+            visible: 0;
+         }
+         description { state: "show" 0.0;
+            inherit: "default" 0.0;
+            visible: 1;
+         }
+      }
+      part { name: "elm.dragable2.slider"; type: RECT;
+         scale: 1;
+         dragable.x: 0 0 0;
+         dragable.y: 1 1 0;
+         dragable.confine: "elm.swallow.bar";
+         description { state: "default" 0.0;
+            color: 0 0 0 0;
+            min: 16 16;
+            max: 16 16;
+            fixed: 1 1;
+            rel1.relative: 0.0 0.5;
+            rel1.to_x: "elm.swallow.bar";
+            rel2.relative: 1.0 0.5;
+            rel2.to_x: "elm.swallow.bar";
+            visible: 0;
+         }
+         description { state: "show" 0.0;
+            inherit: "default" 0.0;
+            visible: 1;
+         }
+      }
+      part { name: "knob2";
+         description { state: "default" 0.0;
+            image.normal: "knob";
+            fixed: 1 1;
+            min: 12 12;
+            step: 2 2;
+            max: 32 32; // XXX allow bigger sizes with more knob images
+            rel1.to: "elm.dragable2.slider";
+            rel1.offset: -4 -4;
+            rel2.to: "elm.dragable2.slider";
+            rel2.offset: 3 3;
+            visible: 0;
+         }
+         description { state: "show" 0.0;
+            inherit: "default" 0.0;
+            visible: 1;
+         }
+         description { state: "clicked" 0.0;
+            inherit: "default" 0.0;
+         }
+      }
+      part { name: "slideevent2"; type: RECT; repeat_events: 1;
+         scale: 1;
+         ignore_flags: ON_HOLD;
+         dragable.events: "elm.dragable2.slider";
+         description { state: "default" 0.0;
+            fixed: 1 1;
+            rel1.to: "elm.dragable2.slider";
+            rel2.to: "elm.dragable2.slider";
+            color: 0 0 0 0;
+            visible: 0;
+         }
+         description { state: "show" 0.0;
+            inherit: "default" 0.0;
+            visible: 1;
+         }
+      }
+      part { name: "elm.track2.slider"; type: SWALLOW; mouse_events: 0;
+         description { state: "default" 0.0;
+            max: 0 0;
+            rel1.to: "elm.dragable2.slider";
+            rel2.to: "elm.dragable2.slider";
+            visible: 0;
+         }
+         description { state: "show" 0.0;
+            inherit: "default" 0.0;
+            visible: 1;
+         }
+      }
+      part { name: "event"; type: RECT;
+         description { state: "default" 0.0;
+            color: 0 0 0 0;
+            visible: 0;
+         }
+         description { state: "disabled" 0.0;
+            inherit: "default" 0.0;
+            visible: 1;
+         }
+      }
+   }
+   programs {
+      program {
+         signal: "mouse,down,1"; source: "elm.dragable.slider";
+         action:  STATE_SET "clicked" 0.0;
+         target: "knob";
+      }
+      program {
+         signal: "mouse,up,1"; source: "elm.dragable.slider";
+         action:  STATE_SET "default" 0.0;
+         target: "knob";
+      }
+      program {
+         signal: "elm,slider,range,enable";
+         source: "elm";
+         script {
+              set_int(range, 1);
+              set_state(PART:"button2", "show", 0.0);
+              set_state(PART:"elm.dragable2.slider", "show", 0.0);
+              set_state(PART:"knob2", "show", 0.0);
+              set_state(PART:"slideevent2", "show", 0.0);
+              set_state(PART:"elm.track2.slider", "show", 0.0);
+              update_glow();
+              new m = get_int(slmode);
+              eval_mode(m);
+         }
+      }
+      program {
+         signal: "elm,slider,range,disable";
+         source: "elm";
+         script {
+              set_int(range, 0);
+              set_state(PART:"button2", "default", 0.0);
+              set_state(PART:"elm.dragable2.slider", "default", 0.0);
+              set_state(PART:"knob2", "default", 0.0);
+              set_state(PART:"slideevent2", "default", 0.0);
+              set_state(PART:"elm.track2.slider", "default", 0.0);
+              set_state(PART:"glow", "default", 0.0);
+              new m = get_int(slmode);
+              eval_mode(m);
+         }
+      }
+      program {
+         signal: "drag";
+         source: "elm.dragable*";
+         script {
+              new r;
+              r = get_int(range);
+              if (r)
+                 update_glow();
+         }
+      }
+      program {
+         signal: "elm,state,indicator,show"; source: "elm";
+         action:  SIGNAL_EMIT "elm,popup,show" "elm";
+         after: "popup_show2";
+      }
+      program {
+         signal: "elm,state,indicator,hide"; source: "elm";
+         action:  SIGNAL_EMIT "elm,popup,hide" "elm";
+         after: "popup_hide2";
+      }
+      program {
+         signal: "mouse,down,1"; source: "slideevent";
+         action:  SIGNAL_EMIT "elm,popup,show" "elm";
+         after: "popup_show2";
+      }
+      program { name: "popup_show2";
+         action:  STATE_SET "hidden" 0.0;
+         target: "button";
+      }
+      program {
+         signal: "mouse,up,1"; source: "slideevent";
+         action:  SIGNAL_EMIT "elm,popup,hide" "elm";
+         after: "popup_hide2";
+      }
+      program { name: "popup_hide2";
+         action:  STATE_SET "default" 0.0;
+         target: "button";
+      }
+      program {
+         signal: "mouse,down,1"; source: "slideevent2";
+         action:  SIGNAL_EMIT "elm,popup,show" "elm";
+         after: "popup2_show2";
+      }
+      program { name: "popup2_show2";
+         action:  STATE_SET "show" 0.0;
+         target: "button2";
+      }
+      program {
+         signal: "mouse,up,1"; source: "slideevent2";
+         action:  SIGNAL_EMIT "elm,popup,hide" "elm";
+         after: "popup2_hide2";
+      }
+      program { name: "popup2_hide2";
+         action:  STATE_SET "hidden" 0.0;
+         target: "button2";
+      }
+      program {
+         signal: "elm,state,elm.text,set"; source: "elm";
+         script {
+            new m = get_int(slmode);
+            m |= LABEL; set_int(slmode, m);
+            eval_mode(m);
+         }
+      }
+      program {
+         signal: "elm,state,elm.text,unset"; source: "elm";
+         script {
+            new m = get_int(slmode);
+            m &= ~LABEL; set_int(slmode, m);
+            eval_mode(m);
+         }
+      }
+      program {
+         signal: "elm,state,icon,set"; source: "elm";
+         script {
+            new m = get_int(slmode);
+            m |= ICON; set_int(slmode, m);
+            eval_mode(m);
+         }
+      }
+      program {
+         signal: "elm,state,icon,unset"; source: "elm";
+         script {
+            new m = get_int(slmode);
+            m &= ~ICON; set_int(slmode, m);
+            eval_mode(m);
+         }
+      }
+      program { name: "end_show";
+         signal: "elm,state,end,visible"; source: "elm";
+         script {
+            new m = get_int(slmode);
+            m |= END; set_int(slmode, m);
+            eval_mode(m);
+         }
+      }
+      program { name: "end_hide";
+         signal: "elm,state,end,hidden"; source: "elm";
+         script {
+            new m = get_int(slmode);
+            m &= ~END; set_int(slmode, m);
+            eval_mode(m);
+         }
+      }
+      program {
+         signal: "elm,state,units,visible"; source: "elm";
+         script {
+            new m = get_int(slmode);
+            m |= UNITS; set_int(slmode, m);
+            eval_mode(m);
+         }
+      }
+      program {
+         signal: "elm,state,units,visible"; source: "elm";
+         action: SIGNAL_EMIT "limits:limits,visible" "elm";
+      }
+      program {
+         signal: "elm,state,units,hidden"; source: "elm";
+         action:  STATE_SET "default" 0.0;
+         script {
+            new m = get_int(slmode);
+            m &= ~UNITS; set_int(slmode, m);
+            eval_mode(m);
+         }
+      }
+      program {
+         signal: "elm,state,units,hidden"; source: "elm";
+         action: SIGNAL_EMIT "limits:limits,hide" "elm";
+      }
+      program {
+         signal: "elm,state,inverted,on"; source: "elm";
+         script {
+            new m = get_int(slmode);
+            m |= INVERT; set_int(slmode, m);
+            eval_mode(m);
+         }
+      }
+      program {
+         signal: "elm,state,inverted,off"; source: "elm";
+         script {
+            new m = get_int(slmode);
+            m &= ~INVERT; set_int(slmode, m);
+            eval_mode(m);
+         }
+      }
+      program {
+         signal: "elm,state,disabled"; source: "elm";
+         script {
+            new m = get_int(slmode);
+            m |= DISABLE; set_int(slmode, m);
+            eval_mode(m);
+         }
+      }
+      program {
+         signal: "elm,state,enabled"; source: "elm";
+         script {
+            new m = get_int(slmode);
+            m &= ~DISABLE; set_int(slmode, m);
+            eval_mode(m);
+         }
       }
    }
+#undef ICON
+#undef LABEL
+#undef END
+#undef UNITS
+#undef MASK
+#undef INVERT
+#undef DISABLE
 }
diff --git a/src/bin/elementary/test_ui_slider.c 
b/src/bin/elementary/test_ui_slider.c
index 8fe7047778..a47fa09675 100644
--- a/src/bin/elementary/test_ui_slider.c
+++ b/src/bin/elementary/test_ui_slider.c
@@ -29,8 +29,9 @@ _slider_changed_cb(void *data EINA_UNUSED, const Efl_Event 
*ev)
 void
 test_ui_slider(void *data EINA_UNUSED, Evas_Object *obj EINA_UNUSED, void 
*event_info EINA_UNUSED)
 {
-   Eo *win, *bx, *hbx;
+   Eo *win, *bx, *hbx, *ic;
    double step;
+   char buf[PATH_MAX];
 
    win = efl_add(EFL_UI_WIN_CLASS, NULL,
                  efl_ui_win_type_set(efl_added, EFL_UI_WIN_BASIC),
@@ -40,8 +41,13 @@ test_ui_slider(void *data EINA_UNUSED, Evas_Object *obj 
EINA_UNUSED, void *event
    bx = efl_add(EFL_UI_BOX_CLASS, win,
                 efl_content_set(win, efl_added));
 
+   snprintf(buf, sizeof(buf), "%s/images/logo_small.png", 
elm_app_data_dir_get());
+   ic = efl_add(EFL_UI_IMAGE_CLASS, win,
+                efl_file_set(efl_added, buf, NULL));
+
    efl_add(EFL_UI_SLIDER_CLASS, bx,
            efl_text_set(efl_added, "Horizontal"),
+           efl_content_set(efl_added, ic),
            efl_ui_slider_part_indicator_visible_mode_set(efl_part(efl_added, 
"indicator"),
                                                          
EFL_UI_SLIDER_INDICATOR_VISIBLE_MODE_NONE),
            efl_gfx_size_hint_min_set(efl_added, EINA_SIZE2D(160, 0)),

-- 


Reply via email to