1. #1
    Sencha User tomalex0's Avatar
    Join Date
    Apr 2009
    Location
    San Jose, CA
    Posts
    589
    Vote Rating
    16
    tomalex0 will become famous soon enough

      0  

    Default Display Field for Form

    Display Field for Form


    I was looking for DisplayField inside in form, so i made a try to Extend. So far its working fine for me.

    I have posted my earlier code in
    http://www.sencha.com/forum/showthre...-Display-Field.

    Main thing if found interesting was that when the form is posted the value associated with displayfield could be passed to server side.


    Extension
    Code:
    Ext.form.DisplayField = Ext.extend(Ext.form.Field,  {
        ui: 'slider',
         /**
         * Set to true on all Ext.form.Field subclasses. This is used by {@link Ext.form.FormPanel#getValues} to determine which
         * components inside a form are fields.
         * @property isField
         * @type Boolean
         */
        isField: true,
        
        isFormField : true,
        
        /**
         * @cfg {Boolean/Function/Object} disclosure
         * True to display a disclosure icon on each list item.
         * This is just to show the disclosure icon to indicate a list is associated with the displayfield
         */
        disclosure : true,
        
        /**
         * @cfg {String} disclosureCls The CSS class to use to change disclosure icon image and its properties)
         */
        disclosureCls : 'x-field-disclosure',
         /**
         * @cfg {String} inputCls Overrides {@link Ext.form.Field}'s inputCls. Defaults to 'x-slider'
         */
        inputCls: 'x-displayfield',
        
        initComponent : function() {
            this.addEvents('displaytap');
            Ext.form.DisplayField.superclass.initComponent.call(this);
          
        },
        
        afterRender: function() {
            Ext.form.DisplayField.superclass.afterRender.call(this);
            this.mon(this.fieldEl, {
                tap: this.onTap,
                scope: this
            });
            if(this.disclosure){
              this.tagspec = {tag : 'div',cls : 'x-disclosure '+this.disclosureCls}
              Ext.DomHelper.insertAfter(this.fieldEl,this.tagspec);
            }
        },
        
       
        onTap : function(e){
            this.fireEvent('displaytap',this.originalValue,this.getValue());
        },
        
        /**
         * True to set the field DOM element autocorrect attribute to "on", false to set to "off". Defaults to undefined, leaving the attribute unset.
         * @cfg {Boolean} autoCorrect
         */
    
        renderTpl: [
            '<tpl if="label">',
                '<label <tpl if="fieldEl">for="{inputId}"</tpl>>{label}</label>',
            '</tpl>',
            '<div>',
            '<tpl if="fieldEl">',
                '<div id="{inputId}" name="{name}"  class="{fieldCls}""',
                '<tpl if="style">style="{style}" </tpl>',
            '></div></tpl>',
            '</div>',
            '<div class="x-field-mask"></div>'
        ],
        
        
        /**
         * Returns the normalized data value (undefined or emptyText will be returned as '').  To return the raw value see {@link #getRawValue}.
         * @return {Mixed} value The field value
         */
        getValue : function(){
            if (!this.rendered || !this.fieldEl) {
               
                return this.dom.innerHTML;
            }
            
            return this.fieldEl.dom.innerHTML || '';
        },
    
        /**
         * Sets a data value into the field and validates it.  To set the value directly without validation see {@link #setRawValue}.
         * @param {Mixed} value The value to set
         * @return {Ext.form.DisplayField} this
         */
        setValue : function(v){
            this.value = v;
            if (this.rendered && this.fieldEl) {
                this.fieldEl.dom.innerHTML = (Ext.isEmpty(v) ? '' : v);
            }
            return this;
        }
    });
    
    Ext.reg('displayfield', Ext.form.DisplayField);
    CSS
    Code:
    .x-field-slider .x-displayfield {
      position: relative;
      overflow: hidden;
      height: 2.5em;
      width:100%;
      margin: 0 .5em;
      padding-top : 0.7em;
      float:left;
      z-index:1;
    }
    .x-field-disclosure{
        position:absolute;
        top:0;
        right:0.3em;
        margin-top:0.4em;
    }
    Examples
    Code:
    {
                            xtype: 'displayfield',
                            name : 'name',
                            label: 'Name',
                            autoCapitalize : false,
                            value : 'test',
                            listeners :{
                                displaytap : function(o,v){
                                    alert(o+"-----"+v);
                                }
                            }
                        }
    Features
    Code:
    1. Tap Event for  displayfield
    2. Disclosure image similar to List.
    My actual requirement was to show a List when tapped on the displayField and after selecting value from the list the displayfield will be updated with that value.

  2. #2
    Sencha User tomalex0's Avatar
    Join Date
    Apr 2009
    Location
    San Jose, CA
    Posts
    589
    Vote Rating
    16
    tomalex0 will become famous soon enough

      0  

    Default Modified Display Field With respect to 0.96 version

    Modified Display Field With respect to 0.96 version


    Have updated the display field code w.r.t to 0.96

    Code:
    Ext.form.DisplayField = Ext.extend(Ext.form.Field,  {
         /**
         * Set to true on all Ext.form.Field subclasses. This is used by {@link Ext.form.FormPanel#getValues} to determine which
         * components inside a form are fields.
         * @property isField
         * @type Boolean
         */
        isField: true,
        
        isFormField : true,
        
        /**
         * @cfg {Boolean/Function/Object} disclosure
         * True to display a disclosure icon on each list item.
         * This is just to show the disclosure icon to indicate a list is associated with the displayfield
         */
        disclosure : true,
        
        /**
         * @cfg {String} disclosureCls The CSS class to use to change disclosure icon image and its properties)
         */
        disclosureCls : 'x-field-disclosure',
         /**
         * @cfg {String} inputCls Overrides {@link Ext.form.Field}'s inputCls. Defaults to 'x-slider'
         */
        inputCls: 'x-displayfield',
        
        initComponent : function() {
            this.addEvents('displaytap');
            Ext.form.DisplayField.superclass.initComponent.call(this);
          
        },
        
        afterRender: function() {
            Ext.form.DisplayField.superclass.afterRender.call(this);
            this.mon(this.el, {
                tap: this.onTap,
                scope: this
            });
            if(this.disclosure){
              this.tagspec = {tag : 'div',cls : 'x-disclosure '+this.disclosureCls}
              Ext.DomHelper.insertAfter(this.fieldEl,this.tagspec);
            }
        },
        
       
        onTap : function(e){
            this.fireEvent('displaytap',this.originalValue,this.getValue());
        },
        
        /**
         * True to set the field DOM element autocorrect attribute to "on", false to set to "off". Defaults to undefined, leaving the attribute unset.
         * @cfg {Boolean} autoCorrect
         */
    
        renderTpl: [
            '<tpl if="label">',
                '<label <tpl if="fieldEl">for="{inputId}"</tpl> class="x-form-label"><span>{label}</span></label>',
            '</tpl>',
            '<tpl if="fieldEl">',
                '<div id="{inputId}" name="{name}"  class="{fieldCls}"',
                '<tpl if="style">style="{style}" </tpl>',
            '></div></tpl>',
            '<div class="x-field-mask"></div>'
        ],
        
        
        /**
         * Returns the normalized data value (undefined or emptyText will be returned as '').  To return the raw value see {@link #getRawValue}.
         * @return {Mixed} value The field value
         */
        getValue : function(){
            if (!this.rendered || !this.fieldEl) {
               
                return this.dom.innerHTML;
            }
            
            return this.fieldEl.dom.innerHTML || '';
        },
    
        /**
         * Sets a data value into the field and validates it.  To set the value directly without validation see {@link #setRawValue}.
         * @param {Mixed} value The value to set
         * @return {Ext.form.DisplayField} this
         */
        setValue : function(v){
            this.value = v;
            if (this.rendered && this.fieldEl) {
                this.fieldEl.dom.innerHTML = (Ext.isEmpty(v) ? '' : v);
            }
            return this;
        }
    });
    
    Ext.reg('displayfield', Ext.form.DisplayField);
    CSS
    Code:
     .x-displayfield {
                    background-color:white;
                    padding: 0 .5em;
                    padding-top : 0.7em;
                    text-overflow: ellipsis;
                    overflow:hidden;
                    white-space: nowrap;
                    display: block;
                    font-weight:100 !important;
                }
                .x-field-disclosure{
                    position:absolute;
                    top:0;
                    right:0.8em;
                    margin-top:0.4em;
                }

    Updated Features.
    Code:
    Added tap event for whole field.
    Tackled text overflow

  3. #3
    Sencha User armode's Avatar
    Join Date
    Nov 2011
    Location
    Germany / Darmstadt
    Posts
    64
    Vote Rating
    4
    armode is on a distinguished road

      0  

    Default Displayfield for Sencha Touch 2?

    Displayfield for Sencha Touch 2?


    Hi,

    how can I get a displayfield working in ST2?
    There are several things deprecated and at the moment I got an error at the DomHelper element....

    Is there another way in ST2 to get a "displayfield" or has someone fixed it?

    Thanks

  4. #4
    Sencha User tomalex0's Avatar
    Join Date
    Apr 2009
    Location
    San Jose, CA
    Posts
    589
    Vote Rating
    16
    tomalex0 will become famous soon enough

      0  

    Default


    I dont' think we need something complex as above mentioned to implement a displayfield. You can use readOnly property to implement this. If you want it more like a component in ST2.

    Code:
    Ext.define('Ext.ux.displayfield', {
        extend : 'Ext.field.Text',
        alias : 'widget.displayfield',
        xtype : 'displayfield',
        config : {
            readOnly : true,
            clearIcon: false
        }
    });
    Sencha Touch Demos

    IosToggleField Forum - Github
    Form Validation
    Forum - Github
    Iphone Settings Menu
    Forum
    Sqlite Storage & Login Manifest
    Forum
    KitchenSink MVC
    Forum - Github
    SqliteProxy-v1 Forum - Github
    SqliteProxy-v2
    Forum - Github
    Arshaw Fullcalendar Forum - Github






  5. #5
    Sencha User armode's Avatar
    Join Date
    Nov 2011
    Location
    Germany / Darmstadt
    Posts
    64
    Vote Rating
    4
    armode is on a distinguished road

      0  

    Default


    Thanks that works fine!

    Do you know how to insert the disclosure icon?

    I appreciate your help...

  6. #6
    Sencha User
    Join Date
    Feb 2008
    Posts
    1
    Vote Rating
    0
    diego.girotto is on a distinguished road

      0  

    Default


    add a css to your page like this

    .x-field-disclosure{
    position:absolute;
    top:0;
    right:0.8em;
    margin-top:0.4em;
    overflow:visible;
    background-image:url(../images/image.png) !important;
    -webkit-mask: 0 0 url(../images/image.png) !important;
    background-color:transparent !important;
    -webkit-mask-size: 1.7em;
    width: 1.7em;
    height: 1.7em;
    }

    you have to change the "image.png" with the right image

  7. #7
    Sencha User armode's Avatar
    Join Date
    Nov 2011
    Location
    Germany / Darmstadt
    Posts
    64
    Vote Rating
    4
    armode is on a distinguished road

      0  

    Default


    Thanks for your help, but there's no div with a class named 'x-field-disclosure' at the moment, so I have to add one via the config part?

  8. #8
    Sencha User tomalex0's Avatar
    Join Date
    Apr 2009
    Location
    San Jose, CA
    Posts
    589
    Vote Rating
    16
    tomalex0 will become famous soon enough

      0  

    Default


    Try this
    Code:
    Ext.define('Ext.ux.displayfield', {
        extend : 'Ext.field.Text',
        alias : 'widget.displayfield',
        xtype : 'displayfield',
        config : {
            readOnly : true,
            clearIcon: false,
            component: {
                useMask: true
            },
            ui : 'select disclose'
        }
    });
    Code:
    .x-field-disclose .x-component-outer::after {
                    content: "";
                    position: absolute;
                    width: 1.7em;
                    height: 1.7em;
                    top: 37%;
                    left: auto;
                    right: 0.7em;
                    -webkit-mask-size: 1.7em;
                    -webkit-mask-image: url('');
                    margin-top: -0.5em;
                    background-color: #006BB6;
                    background-image: -webkit-gradient(linear, 50% 0%, 50% 100%, color-stop(0%, #50B7FF), color-stop(2%, #0080DA), color-stop(100%, #005692));
                    background-image: -webkit-linear-gradient(#50B7FF,#0080DA 2%,#005692);
                    background-image: linear-gradient(#50B7FF,#0080DA 2%,#005692);
                }
    Sencha Touch Demos

    IosToggleField Forum - Github
    Form Validation
    Forum - Github
    Iphone Settings Menu
    Forum
    Sqlite Storage & Login Manifest
    Forum
    KitchenSink MVC
    Forum - Github
    SqliteProxy-v1 Forum - Github
    SqliteProxy-v2
    Forum - Github
    Arshaw Fullcalendar Forum - Github






  9. #9
    Sencha User armode's Avatar
    Join Date
    Nov 2011
    Location
    Germany / Darmstadt
    Posts
    64
    Vote Rating
    4
    armode is on a distinguished road

      0  

    Default


    Thanks for your help, works fine!

  10. #10
    Sencha User
    Join Date
    Jan 2014
    Posts
    1
    Vote Rating
    0
    RaykoComSC is on a distinguished road

      0  

    Default


    Thank you.

Similar Threads

  1. Form Display Field
    By tomalex0 in forum Ext 2.x: Help & Discussion
    Replies: 1
    Last Post: 30 Aug 2010, 6:16 AM
  2. [Solved] form field gets value but does not display it
    By madkris in forum Ext 3.x: Help & Discussion
    Replies: 4
    Last Post: 13 Jul 2009, 1:13 AM
  3. How to display a store field as label in a form
    By impactmedia in forum Ext 2.x: Help & Discussion
    Replies: 1
    Last Post: 10 Sep 2008, 2:04 AM
  4. How to render custom display in form field?
    By comm in forum Ext 1.x: Help & Discussion
    Replies: 4
    Last Post: 18 Jun 2007, 7:23 AM

Thread Participants: 3