123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188 |
- /**
- * A {@link Ext.ux.statusbar.StatusBar} plugin that provides automatic error
- * notification when the associated form contains validation errors.
- */
- Ext.define('Ext.ux.statusbar.ValidationStatus', {
- extend: 'Ext.Component',
- requires: ['Ext.util.MixedCollection'],
- /**
- * @cfg {String} errorIconCls
- * The {@link Ext.ux.statusbar.StatusBar#iconCls iconCls} value to be applied
- * to the status message when there is a validation error.
- */
- errorIconCls : 'x-status-error',
- /**
- * @cfg {String} errorListCls
- * The css class to be used for the error list when there are validation errors.
- */
- errorListCls : 'x-status-error-list',
- /**
- * @cfg {String} validIconCls
- * The {@link Ext.ux.statusbar.StatusBar#iconCls iconCls} value to be applied
- * to the status message when the form validates.
- */
- validIconCls : 'x-status-valid',
-
- /**
- * @cfg {String} showText
- * The {@link Ext.ux.statusbar.StatusBar#text text} value to be applied when
- * there is a form validation error.
- */
- showText : 'The form has errors (click for details...)',
- /**
- * @cfg {String} hideText
- * The {@link Ext.ux.statusbar.StatusBar#text text} value to display when
- * the error list is displayed.
- */
- hideText : 'Click again to hide the error list',
- /**
- * @cfg {String} submitText
- * The {@link Ext.ux.statusbar.StatusBar#text text} value to be applied when
- * the form is being submitted.
- */
- submitText : 'Saving...',
-
- // private
- init : function(sb){
- sb.on('render', function(){
- this.statusBar = sb;
- this.monitor = true;
- this.errors = Ext.create('Ext.util.MixedCollection');
- this.listAlign = (sb.statusAlign === 'right' ? 'br-tr?' : 'bl-tl?');
-
- if (this.form) {
- this.formPanel = Ext.getCmp(this.form);
- this.basicForm = this.formPanel.getForm();
- this.startMonitoring();
- this.basicForm.on('beforeaction', function(f, action){
- if(action.type === 'submit'){
- // Ignore monitoring while submitting otherwise the field validation
- // events cause the status message to reset too early
- this.monitor = false;
- }
- }, this);
- var startMonitor = function(){
- this.monitor = true;
- };
- this.basicForm.on('actioncomplete', startMonitor, this);
- this.basicForm.on('actionfailed', startMonitor, this);
- }
- }, this, {single:true});
- sb.on({
- scope: this,
- afterlayout:{
- single: true,
- fn: function(){
- // Grab the statusEl after the first layout.
- sb.statusEl.getEl().on('click', this.onStatusClick, this, {buffer:200});
- }
- },
- beforedestroy:{
- single: true,
- fn: this.onDestroy
- }
- });
- },
-
- // private
- startMonitoring : function() {
- this.basicForm.getFields().each(function(f){
- f.on('validitychange', this.onFieldValidation, this);
- }, this);
- },
-
- // private
- stopMonitoring : function(){
- this.basicForm.getFields().each(function(f){
- f.un('validitychange', this.onFieldValidation, this);
- }, this);
- },
-
- // private
- onDestroy : function(){
- this.stopMonitoring();
- this.statusBar.statusEl.un('click', this.onStatusClick, this);
- this.callParent(arguments);
- },
-
- // private
- onFieldValidation : function(f, isValid){
- if (!this.monitor) {
- return false;
- }
- var msg = f.getErrors()[0];
- if (msg) {
- this.errors.add(f.id, {field:f, msg:msg});
- } else {
- this.errors.removeAtKey(f.id);
- }
- this.updateErrorList();
- if(this.errors.getCount() > 0) {
- if(this.statusBar.getText() !== this.showText){
- this.statusBar.setStatus({text:this.showText, iconCls:this.errorIconCls});
- }
- }else{
- this.statusBar.clearStatus().setIcon(this.validIconCls);
- }
- },
-
- // private
- updateErrorList : function(){
- if(this.errors.getCount() > 0){
- var msg = '<ul>';
- this.errors.each(function(err){
- msg += ('<li id="x-err-'+ err.field.id +'"><a href="#">' + err.msg + '</a></li>');
- }, this);
- this.getMsgEl().update(msg+'</ul>');
- }else{
- this.getMsgEl().update('');
- }
- // reset msgEl size
- this.getMsgEl().setSize('auto', 'auto');
- },
-
- // private
- getMsgEl : function(){
- if(!this.msgEl){
- this.msgEl = Ext.DomHelper.append(Ext.getBody(), {
- cls: this.errorListCls
- }, true);
- this.msgEl.hide();
- this.msgEl.on('click', function(e){
- var t = e.getTarget('li', 10, true);
- if(t){
- Ext.getCmp(t.id.split('x-err-')[1]).focus();
- this.hideErrors();
- }
- }, this, {stopEvent:true}); // prevent anchor click navigation
- }
- return this.msgEl;
- },
-
- // private
- showErrors : function(){
- this.updateErrorList();
- this.getMsgEl().alignTo(this.statusBar.getEl(), this.listAlign).slideIn('b', {duration: 300, easing:'easeOut'});
- this.statusBar.setText(this.hideText);
- this.formPanel.el.on('click', this.hideErrors, this, {single:true}); // hide if the user clicks directly into the form
- },
-
- // private
- hideErrors : function(){
- var el = this.getMsgEl();
- if(el.isVisible()){
- el.slideOut('b', {duration: 300, easing:'easeIn'});
- this.statusBar.setText(this.showText);
- }
- this.formPanel.el.un('click', this.hideErrors, this);
- },
-
- // private
- onStatusClick : function(){
- if(this.getMsgEl().isVisible()){
- this.hideErrors();
- }else if(this.errors.getCount() > 0){
- this.showErrors();
- }
- }
- });
|