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

Turkiyenin en sevilen filmlerinin yer aldigi xnxx internet sitemiz olan ve porn sex tarzi bir site olan mobil porno izle sitemiz gercekten dillere destan bir durumda herkesin sevdigi bir site olarak tarihe gececege benziyor. Sitenin en belirgin ozelliklerinden birisi de Turkiyede gercekten kaliteli ve muntazam, duzenli porno izle siteleri olmamasidir. Bu yuzden iste. Ayrica en net goruntu kalitesine sahip adresinde yayinlanmaktadir. Mesela diğer sitelerimizden bahsedecek olursak, en iyi hd porno video arşivine sahip bir siteyiz. "The Best anal porn videos and slut anus, big asses movies set..." hd porno faketaxi