ColorMap.js 2.59 KB
Ext.define('amdaUI.ColorMap', {
    extend: 'Ext.form.ComboBox',
    alias: 'widget.colormap',
   

    data : [],

    constructor:function(config){
        this.getData();
        this.init(config);
		this.callParent();
    },

    getData:function(){
        var me = this;
        amdaDefaultConfigs.availableColorMaps.forEach(function(color){
			me.data.push({key:color.key,name:color.value, iconUrl:'generic_data/colormaps/'+ color.svgFile})
		});
    },
    init: function(config){
        var me = this;
        var size = (typeof config !== "undefined" && config.size) ? config.size : '12';
        Ext.apply(this,{
            xtype:'combobox',
            name: (typeof config !== "undefined" && config.name) ? config.name:null,
        fieldLabel: (typeof config !== "undefined" && config.fieldLabel) ? config.fieldLabel:null,
        store: new Ext.data.Store({
            fields: ['key','name', 'iconUrl'],
            data: me.data
        }),
        displayField: 'name',
        valueField: 'key',
        tpl: '<tpl for="."><div class="x-boundlist-item"><span data-qtip="{name}"> \
                <img src="{iconUrl}" class="svg-icon" style="height:'+size+'px;"> \
                </span>\
            </div></tpl>',
        editable: false,
        queryMode: 'local',
        listeners: {
            change: function (combo, newValue, oldValue, eOpts) {
                var iconUrl="";
                me.data.forEach(function(colorData){
                    if(colorData.key == newValue ){
                        iconUrl= colorData.iconUrl;
                    }
                });
                combo.inputEl.setStyle('background-image', 'url(' + iconUrl + ')');
                combo.inputEl.setStyle('background-size', '100%');
                combo.inputEl.setStyle('background-repeat', 'no-repeat');
                combo.inputEl.setStyle('background-position', 'center');
                combo.inputEl.setStyle('font-size', '0');
                if(typeof me.up().object !== 'undefined')
                    me.up().object.set('axis-color-map', newValue);
            },
            click: {
                element: 'el',
                fn: function(e,t) { 
                    var me = t,
                    text = me.getAttribute('amda_clicktip');
                    if (text) {
                        e.preventDefault();
                        AmdaAction.getInfo({name : text}, function(res,e) {
                            if (res.success) myDesktopApp.infoMsg(res.result);
                        });
                    }
                }
            },
            scope:this
        },
        })
    }
});