/** * Project : AMDA-NG * Name : PlotStandardForm.js * @class amdaPlotComp.PlotStandardForm * @extends Ext.form.Panel * @brief Standard Form used to define some options for a plot element * @author Benjamin Renard * @version $Id: PlotStandardForm.js benjamin $ */ Ext.define('amdaPlotComp.PlotStandardForm', { extend: 'Ext.form.Panel', requires : [ 'amdaPlotObj.PlotObjectConfig', 'amdaPlotComp.EraseTrigger' ], //Object associated to this form object: null, //Link to the tree crtTree: null, constructor: function(config) { this.init(config); this.callParent(arguments); }, setObject : function(object) { this.object = object; this.loadRecord(this.object); }, //To override to add form components getFormItems: function() { return []; }, //Function called after element creation by PlotElementPanel updateElement: function(onAfterUpdate) { if (onAfterUpdate) onAfterUpdate(); }, // addStandardText: function(name, label, onChange) { return { xtype: 'textfield', name: name, fieldLabel: label, listeners: { change: function(field, newValue, oldValue, eOpts) { this.object.set(name, newValue); if (onChange != null) onChange(name, newValue, oldValue); }, scope: this } }; }, addStandardFloat: function(name, label, min, max, allowBlank, onChange) { allowBlank = (typeof allowBlank !== 'undefined') ? allowBlank : false; return { xtype: 'numberfield', name: name, fieldLabel: label, decimalPrecision : 20, minValue : min, maxValue : max, allowBlank : allowBlank, listeners: { change: function(field, newValue, oldValue, eOpts) { this.object.set(name, newValue); if (onChange != null) onChange(name, newValue, oldValue); }, scope: this } }; }, addStandardFloat2: function(name, label, min, max, allowBlank, onChange) { allowBlank = (typeof allowBlank !== 'undefined') ? allowBlank : false; return { xtype: 'textfield', name: name, fieldLabel: label, regex : /[-+]?(?:\d*\.?\d+|\d+\.?\d*)(?:[eE][-+]?\d+)?/, validator: function (val) { var errMsg = null; if (!allowBlank && Ext.isEmpty(val)) { errMsg = 'Blank value not allowed'; } else if ((typeof min !== 'undefined') && (parseFloat(val) < min)) { errMsg = 'Min. allowed value is ' + min; } else if ((typeof max !== 'undefined') && (parseFloat(val) > max)) { errMsg = 'Max. allowed value is ' + max; } return errMsg ? errMsg : true; }, listeners: { change: function(field, newValue, oldValue, eOpts) { this.object.set(name, newValue); if (onChange != null) onChange(name, newValue, oldValue); }, scope: this } }; }, addStandardCombo: function(name, label, availableData, onChange) { var comboStore = Ext.create('Ext.data.Store', { fields: ['key', 'value'], data : availableData }); return { xtype: 'combo', name: name, fieldLabel: label, store: comboStore, queryMode: 'local', displayField: 'value', valueField: 'key', editable: false, listeners: { change: function(combo, newValue, oldValue, eOpts) { if (onChange != null) onChange(name, newValue, oldValue); this.object.set(name, newValue); }, scope: this } }; }, addStandardCheck: function(name, label, onChange) { return { xtype: 'checkbox', name: name, boxLabel: label, listeners: { change: function(combo, newValue, oldValue, eOpts) { this.object.set(name, newValue); if (onChange != null) onChange(name, newValue, oldValue); }, scope: this } }; }, addStandardFieldSet: function(title, checkboxName, items, onChangeCheck) { return { xtype: 'fieldset', cls : 'child-fieldset', title: title, collapsible: true, collapsed: true, checkboxName: checkboxName, checkboxToggle: checkboxName != '', layout: { type: 'vbox', pack: 'start', align: 'stretch' }, items: items, listeners: { expand: function(fieldset, eOpts) { if (checkboxName != '') { this.object.set(checkboxName, true); if (onChangeCheck != null) onChangeCheck(checkboxName, true, false); } }, collapse: function(fieldset, eOpts) { if (checkboxName != '') { this.object.set(checkboxName, false); if (onChangeCheck != null) onChangeCheck(checkboxName, false, true); } }, scope: this } }; }, addStandardFont: function(namePrefix) { var fontItems = [ this.addStandardCombo(namePrefix+'-name', 'Name', amdaPlotObj.PlotObjectConfig.availableFontNames), { xtype : 'toolbar', bodyStyle: { background : '#dfe8f6' }, border: false, items : [ { xtype: 'numberfield', name: namePrefix+'-size', fieldLabel: 'Size', labelWidth: 60, width: 150, maxValue: 32, minValue: 6, value: 12, listeners: { change: function(field, newValue, oldValue, eOpts) { this.object.set(namePrefix+'-size', newValue); }, scope: this } }, ' ', { xtype: 'checkbox', name: namePrefix+'-bold', boxLabel: '<b>B</b>', width: 30, listeners: { change: function(combo, newValue, oldValue, eOpts) { this.object.set(namePrefix+'-bold', newValue); }, scope: this } }, { xtype: 'checkbox', name: namePrefix+'-italic', boxLabel: '<i>I</i>', width: 30, listeners: { change: function(combo, newValue, oldValue, eOpts) { this.object.set(namePrefix+'-italic', newValue); }, scope: this } } ] } ]; return this.addStandardFieldSet('Font', namePrefix+'-activated', fontItems); }, addStandardColor: function(name, label, availableData, onChange) { var comboStore = Ext.create('Ext.data.Store', { fields: ['color', 'value'], data : availableData }); return { xtype: 'combo', name: name, fieldLabel: label, store: comboStore, queryMode: 'local', displayField: 'value', valueField: 'color', editable: false, tpl: Ext.create('Ext.XTemplate', '<ul class="x-list-plain"><tpl for=".">', '<li role="option" class="x-boundlist-item" style="color: {color};">{value}</li>', '</tpl></ul>' ), // template for the content inside text field displayTpl: Ext.create('Ext.XTemplate', '<tpl for=".">', '{value}', '</tpl>' ), listeners: { change: function(combo, newValue, oldValue, eOpts) { this.object.set(name, newValue); if (onChange != null) onChange(name, newValue, oldValue); }, scope: this } }; }, addStandardParamDropTarget: function(name, label, onChange) { return { xtype: 'erasetrigger', name: name, fieldLabel: label, emptyText: 'Drop a parameter', listeners: { change: function(field, newValue, oldValue, eOpts) { this.object.set(name, newValue); if (onChange != null) onChange(name, newValue, oldValue); }, afterrender: function(field, eOpts ){ var paramTarget = new Ext.dd.DropTarget(field.el.dom, { ddGroup: 'explorerTree', notifyEnter: function(ddSource, e, data) { }, notifyDrop: function(ddSource, e, data) { var selectedRecord = ddSource.dragData.records[0]; switch (selectedRecord.$className) { case 'amdaModel.LocalParamNode' : case 'amdaModel.RemoteParamNode' : case 'amdaModel.RemoteSimuParamNode' : if (!selectedRecord.get('isParameter') || selectedRecord.get('disable')) return false; if (selectedRecord.get('alias') != "" ) field.setValue("#"+selectedRecord.get('alias')); else field.setValue(selectedRecord.get('id')); return true; case 'amdaModel.AliasNode' : if (!selectedRecord.isLeaf()) return false; field.setValue("#"+selectedRecord.get('text')); return true; case 'amdaModel.DerivedParamNode' : if (!selectedRecord.isLeaf()) return false; field.setValue("ws_"+selectedRecord.get('text')); return true; case 'amdaModel.MyDataParamNode' : if (!selectedRecord.isLeaf()) return false; field.setValue("wsd_"+selectedRecord.get('text')); return true; default : return false; } return true; } } ); }, scope: this } }; }, addStandardDate: function(name, label, onChange) { return { xtype: 'datefield', name: name, format: 'Y/m/d H:i:s', enforceMaxLength : true, maxLength: 19, fieldLabel: label, listeners: { change: function(field, newValue, oldValue, eOpts) { this.object.set(name, newValue); if (onChange != null) onChange(name, newValue, oldValue); }, scope : this } }; }, addStandardLineItems: function(namePrefix) { return [ this.addStandardCombo(namePrefix+'-style', 'Style', amdaPlotObj.PlotObjectConfig.availableLinesStyles), this.addStandardFloat(namePrefix+'-width', 'Width', 1, 10), this.addStandardColor(namePrefix+'-color', 'Color', amdaPlotObj.PlotObjectConfig.availableColors) ]; }, addStandardSymbolsItems: function(namePrefix) { return [ this.addStandardCombo(namePrefix+'-type', 'Type', amdaPlotObj.PlotObjectConfig.availableSymbolsTypes), this.addStandardFloat(namePrefix+'-size', 'Size', 1, 10), this.addStandardColor(namePrefix+'-color', 'Color', amdaPlotObj.PlotObjectConfig.availableColors) ]; }, init : function(config) { var me = this; var myConf = { bodyPadding: 5, bodyStyle: { background : '#dfe8f6' }, border: false, layout: { type: 'vbox', pack: 'start', align: 'stretch' }, items: this.getFormItems() }; Ext.apply (this , Ext.apply (arguments, myConf)); } });