/**
 * Project      : AMDA-NG4
 * Name         : TableDefPlugUI.js
 * @class   amdaUI.TableDefPlugUI 
 * @extends Ext.util.Observable
 * @brief   Table definition Plugin used in MyDataUI
 * @author  benjamin
 * @version 
 *
 ******************************************************************************
 *    FT Id     :   Date   : Name - Description
 ******************************************************************************
 *
 *	:           :10/06/2015: BRE - Creation
 */


/**
 * @plugin tabledef
 * @extends Ext.util.Observable 
 * @ptype tabledef
 */

Ext.define('amdaUI.TableDefPlugUI', {
	extend: 'Ext.util.Observable',
	
	alias: 'plugin.tabledef',
	
	win: null,
	
	tableDefTypeCombo: null,
	channelsDefTypeCombo: null,
	defMainPanel: null,
	
	manualDefGrid: null,
	
	constructor: function(config) { 
		Ext.apply(this, config);  
		this.callParent(arguments);
	},

	init: function(cmp) 
	{  
	    this.hostCmp = cmp;
	    this.hostCmp.on({
	        scope: this,		 	       
	        added: function(){
		    this.hostCmp.ownerCt.on({
		      render: this.onRender,
	          hide : this.onHide,
		      scope: this });		   
	        }
	    }); 
	   
	    var tableDefTypeStore = Ext.create('Ext.data.Store', {
            fields: ['value', 'name'],
            data : [
                {"value": "NONE", "name":"None"},
                {"value": "MANUAL", "name":"Manual"},
                {"value": "SELECT", "name":"Select in file"}
            ]
        }); 
		
		this.tableDefTypeCombo = Ext.create('Ext.form.ComboBox', {
			fieldLabel: 'Table definition type',
	        store: tableDefTypeStore,
	        queryMode: 'local',
	        displayField: 'name',
	        valueField: 'value',
	        editable: false,
            value: 'NONE',
            listeners: {
            	scope: this,
            	'change' : function (combo, newValue, oldValue, eOpts) {
            		this.selectTableDefType(newValue);
            	}
            }
		});
		
		var channelsDefTypeStore = Ext.create('Ext.data.Store', {
            fields: ['value', 'name'],
            data : [
                {"value": "MINMAX", "name":"Min & Max"},
                {"value": "BOUND", "name":"Bound"},
                {"value": "CENTER", "name":"Center & Constant width"},
                {"value": "CENTERWIDTH", "name":"Center & Width"}
            ]
        });
		
		this.channelsDefTypeCombo = Ext.create('Ext.form.ComboBox', {
			fieldLabel: 'Channels definition type',
	        store: channelsDefTypeStore,
	        queryMode: 'local',
	        displayField: 'name',
	        valueField: 'value',
	        editable: false,
            value: 'MINMAX',
            listeners: {
            	scope: this,
            	'change' : function (combo, newValue, oldValue, eOpts) {
            		this.reconfigureDefPanel(this.tableDefTypeCombo.getValue(), newValue);
            	}
            }
		});
		
		this.defMainPanel = Ext.create('Ext.form.Panel', {
			border: false, frame: true, plain: true,
			flex: 1,
			layout: {
		        type: 'vbox',
		        align : 'stretch'
		    }
		});
	},
	
	onRender: function() 
	{
		this.win = new Ext.Window({
			width: 400, 
			height: 400,
			x: 380, y: 0,
			baseCls:'x-panel',	 
			title: 'Table definition',
			layout: 'fit',
			closable: false,
			collapsible: true,
			constrain: true,
			floating: true,
			ghost: false,
			renderTo: this.hostCmp.id,
			items: this.getFormConfig(),
			listeners : {
				boxready: function (w) 
				{
					if (w.y + w.height > myDesktopApp.desktop.el.getHeight())
						w.el.setY((myDesktopApp.desktop.el.getHeight()-w.height > 0) ? myDesktopApp.desktop.el.getHeight()-w.height : 0);
        		}
			},
			getConstrainVector: function(constrainTo){
				var me = this;
		        if (me.constrain || me.constrainHeader) {
		            constrainTo = constrainTo || (me.floatParent && me.floatParent.getTargetEl()) || me.container || me.el.getScopeParent();
		            return (me.constrainHeader ? me.header.el : me.el).getConstrainVector(constrainTo);
		        }
		    }
		});	
	},
	
	show: function() {
		this.win.show(); 
	},
	
	hide: function() {
		this.win.hide(); 
	},
	
	showHide: function() {
		if (this.win.isVisible())
			this.hide();
		else
			this.show();
	},
	
	onHide : function()
	{
		this.hide(); 
	},
 	
	getFormConfig: function(){
		return {
			xtype: 'panel',
			border: false, frame: true, plain: true,
			layout: {
		        type: 'vbox',
		        align : 'stretch'
		    },
		    items: [
		            this.tableDefTypeCombo,
		            this.channelsDefTypeCombo,
		            this.defMainPanel
		    ]
		};					 
	},
	
	selectTableDefType : function (type)
	{
		switch (type)
		{
		case 'MANUAL' :
			this.channelsDefTypeCombo.setDisabled(false);
			break;
		case 'SELECT' :
			this.channelsDefTypeCombo.setDisabled(false);
			break;
		default:
			this.channelsDefTypeCombo.setDisabled(true);
		}
		
		this.reconfigureDefPanel(type,this.channelsDefTypeCombo.getValue());
	},
	
	reconfigureDefPanel : function (tableDefType, channelsDefType)
	{
		if (this.defMainPanel == null)
			return;
		
		this.defMainPanel.removeAll(false);
		
		if (channelsDefType == 'CENTER')
		{
			this.defMainPanel.add(Ext.create('Ext.form.field.Number',{
				fieldLabel: 'Constant width',
		        name: 'width',
		        value: 1,
		        minValue: 0,
		        allowDecimals : true,
		        hideTrigger: true
			}));
		}
		
		switch (tableDefType)
		{
		case 'MANUAL' :
			this.defMainPanel.add(this.getManualDefGrid());
			this.reconfigureManualDefGrid(channelsDefType);
			break;
		case 'SELECT' :
			switch (channelsDefType)
			{
			case 'MINMAX' :
				this.defMainPanel.add(Ext.create('Ext.form.field.Text',{
					fieldLabel: 'Min',
			        name: 'min'
				}));
				this.defMainPanel.add(Ext.create('Ext.form.field.Text',{
					fieldLabel: 'Max',
			        name: 'max'
				}));
				break;
			case 'BOUND' :
				this.defMainPanel.add(Ext.create('Ext.form.field.Text',{
					fieldLabel: 'Bound',
			        name: 'bound'
				}));
				break;
			case 'CENTER' :
				this.defMainPanel.add(Ext.create('Ext.form.field.Text',{
					fieldLabel: 'Center',
			        name: 'center'
				}));
				break;
			case 'CENTERWIDTH' :
				this.defMainPanel.add(Ext.create('Ext.form.field.Text',{
					fieldLabel: 'Center',
			        name: 'center'
				}));
				this.defMainPanel.add(Ext.create('Ext.form.field.Text',{
					fieldLabel: 'Width',
			        name: 'width'
				}));
				break;
			default:
				//Nothing to do
			}
			break;
		default:
			//Nothing to do
		}
		this.defMainPanel.doLayout();
	},
	
	getManualDefGrid : function ()
	{
		if (this.manualDefGrid != null)
			return this.manualDefGrid;
		
		var store = Ext.create('Ext.data.Store', {
		    fields: ['index']
		});
		
		this.manualDefGrid = Ext.create('Ext.grid.Panel', {
			title: 'Manual channels definition',
			autoScroll: true,
			sortableColumns: false,
			store: store,
			flex: 1,
		    columns: [{ text: 'Index',  dataIndex: 'index' }],
		    plugins: [
		              Ext.create('Ext.grid.plugin.CellEditing', {
		            	  clicksToEdit: 1
		              })
		    ]
		});
		
		return this.manualDefGrid;
	},
	
	reconfigureManualDefGrid: function(type)
	{
		if (this.manualDefGrid == null)
			return;
		
		var fields = ['index'];
		var columns = [{text: 'Index',  dataIndex: 'index'}];
		
		switch (type)
		{
		case 'MINMAX' :
			fields.push({'name' : 'min', type: 'number'});
			fields.push({'name' : 'max', type: 'number'});
			columns.push({text: 'Min.',  dataIndex: 'min', editor: { xtype: 'numberfield', allowDecimals : true, hideTrigger: true}});
			columns.push({text: 'Max.',  dataIndex: 'max', editor: { xtype: 'numberfield', allowDecimals : true, hideTrigger: true}});
			break;
		case 'BOUND' :
			fields.push({'name' : 'bound', type: 'number'});
			columns.push({text: 'Bound',  dataIndex: 'bound', editor: { xtype: 'numberfield', allowDecimals : true, hideTrigger: true}});
			break;
		case 'CENTER' :
			fields.push({'name' : 'center', type: 'number'});
			columns.push({text: 'Center',  dataIndex: 'center', editor: { xtype: 'numberfield', allowDecimals : true, hideTrigger: true}});
			break;
		case 'CENTERWIDTH' :
			fields.push({'name' : 'center', type: 'number'});
			fields.push({'name' : 'width', type: 'number'});
			columns.push({text: 'Center',  dataIndex: 'center', editor: { xtype: 'numberfield', allowDecimals : true, hideTrigger: true}});
			columns.push({text: 'Width',  dataIndex: 'width', editor: { xtype: 'numberfield', allowDecimals : true, hideTrigger: true}});
			break;
		}
		
		var store = Ext.create('Ext.data.Store', {
		    fields: fields
		});
		
		this.manualDefGrid.reconfigure(store, columns);
		
		this.loadManualGridData(type, null);
	},
	
	loadManualGridData: function(type, data)
	{
		if (this.manualDefGrid == null)
			return;
		
		this.manualDefGrid.getStore().removeAll();
		
		if (!this.hostCmp.getParameterSize())
			return;	
		
		var paramSize = this.hostCmp.getParameterSize();
		
		switch (type)
		{
		case 'MINMAX' :
			var minData, maxData = null;
			if (data && data['min'])
				minData = data['min'].split(',');
			if (data && data['max'])
				maxData = data['max'].split(',');
			for (i = 0; i < paramSize; ++i)
			{
				if (minData && maxData && (i < minData.length) && (i < maxData.length))
					this.manualDefGrid.getStore().add({'index' : i, 'min' : parseFloat(minData[i]), 'max' : parseFloat(maxData[i])});
				else
					this.manualDefGrid.getStore().add({'index' : i, 'min' : i, 'max' : i+1});
			}
			break;
		case 'BOUND' :
			var boundData = null;
			if (data && data['bound'])
				boundData = data['bound'].split(',');
			for (i = 0; i < paramSize + 1; ++i)
			{
				if (boundData && (i < boundData.length))
					this.manualDefGrid.getStore().add({'index' : i, 'bound' : parseFloat(boundData[i])});
				else
					this.manualDefGrid.getStore().add({'index' : i, 'bound' : i});
			}
			break;
		case 'CENTER' :
			var centerData = null;
			if (data && data['center'])
				centerData = data['center'].split(',');
			for (i = 0; i < paramSize; ++i)
			{
				if (centerData && (i < centerData.length))
					this.manualDefGrid.getStore().add({'index' : i, 'center' : parseFloat(centerData[i])});
				else
					this.manualDefGrid.getStore().add({'index' : i, 'center' : i+0.5});
			}
			break;
		case 'CENTERWIDTH' :
			var centerData, widthData = null;
			if (data && data['center'])
				centerData = data['center'].split(',');
			if (data && data['width'])
				widthData = data['width'].split(',');
			for (i = 0; i < paramSize; ++i)
			{
				if (centerData && widthData && (i < centerData.length) && (i < widthData.length))
					this.manualDefGrid.getStore().add({'index' : i, 'center' : parseFloat(centerData[i]), 'width' : parseFloat(widthData[i])});
				else
					this.manualDefGrid.getStore().add({'index' : i, 'center' : i+0.5, 'width' : 1});
			}
			break;
		}
			
		this.manualDefGrid.getView().refresh();
	},
	
	loadSelectData : function(data)
	{
		this.defMainPanel.getForm().getFields().each(function (item, index, len) {
			if (data[item.name])
				item.setValue(data[item.name]);
		});
	},
	
	getTableDefinitionObject : function()
	{
		var obj = {
				'tableDefType' : this.tableDefTypeCombo.getValue(),
				'channelsDefType' : this.channelsDefTypeCombo.getValue(),
				'data' : {}
		};
		
		if (obj.tableDefType == 'NONE')
			return obj;
		
		this.defMainPanel.getForm().getFields().each(function (item, index, len) {
			obj.data[item.name] = item.getValue();
		});
		
		if (obj.tableDefType == 'MANUAL')
		{
			if (this.manualDefGrid.getStore().getCount() > 0)
			{
				var firstData = this.manualDefGrid.getStore().getAt(0);
				for (i = 0; i < firstData.fields.items.length; ++i)
				{
					if ((firstData.fields.items[i].name == 'index') || (firstData.fields.items[i].name == 'id'))
						continue;
					var crtFieldName = firstData.fields.items[i].name;
					obj.data[crtFieldName] = "";
					for (j = 0; j < this.manualDefGrid.getStore().getCount(); ++j)
					{
						if (j > 0)
							obj.data[crtFieldName] += ', ';
						obj.data[crtFieldName] += this.manualDefGrid.getStore().getAt(j).get(crtFieldName);
					}
				}
			}
		}
		
		return obj;
	},
	
	setTableDefinition : function(tableDef)
	{
		this.tableDefTypeCombo.setValue(tableDef['tableDefType']);
		this.channelsDefTypeCombo.setValue(tableDef['channelsDefType']);
		this.selectTableDefType(tableDef['tableDefType']);
		this.loadManualGridData(tableDef['channelsDefType'], tableDef['data']);
		this.loadSelectData(tableDef['data']);
	}
});