PDA

View Full Version : Display Field for Form



tomalex0
15 Sep 2010, 9:03 AM
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/showthread.php?108754-DISCUSS-Form-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


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


.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


{
xtype: 'displayfield',
name : 'name',
label: 'Name',
autoCapitalize : false,
value : 'test',
listeners :{
displaytap : function(o,v){
alert(o+"-----"+v);
}
}
}


Features


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.

tomalex0
8 Oct 2010, 8:19 AM
Have updated the display field code w.r.t to 0.96



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


.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.


Added tap event for whole field.
Tackled text overflow

armode
10 Feb 2012, 1:31 AM
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

tomalex0
10 Feb 2012, 10:00 AM
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.



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

armode
13 Feb 2012, 12:21 AM
Thanks that works fine!

Do you know how to insert the disclosure icon?

I appreciate your help...

diego.girotto
3 Mar 2012, 6:35 AM
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

armode
5 Mar 2012, 5:58 AM
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?

tomalex0
5 Mar 2012, 7:55 PM
Try this


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'
}
});




.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);
}

armode
6 Mar 2012, 5:13 AM
Thanks for your help, works fine! :D

RaykoComSC
24 Feb 2014, 12:05 AM
Thank you.