/**
 * This is the window that allows field settings configuration.
 */
Ext.define('Ext.pivot.plugin.configurator.window.FieldSettings', {
    extend: 'Ext.pivot.plugin.configurator.window.Window',
 
    requires: [
        'Ext.form.field.Display'
    ],
 
    title: 'Field settings',
 
    formatText: 'Format as',
    summarizeByText: 'Summarize by',
    customNameText: 'Custom name',
    sourceNameText: 'Source name',
    alignText: 'Align',
    alignLeftText: 'Left',
    alignCenterText: 'Center',
    alignRightText: 'Right',
 
    field: null,
 
    getSettingsForm: function() {
        var me = this,
            dataFormatters = [],
            dataAggregators = [],
            settings = me.field.getSettings(),
            formatters = settings.getFormatters(),
            renderers = settings.getRenderers(),
            fns = settings.getAggregators(),
            length, i, list;
 
        length = fns.length;
 
        for (= 0; i < length; i++) {
            dataAggregators.push([
                me.field.getAggText(fns[i]),
                fns[i]
            ]);
        }
 
        list = Ext.Object.getAllKeys(formatters || {});
        length = list.length;
 
        for (= 0; i < length; i++) {
            dataFormatters.push([
                list[i],
                formatters[list[i]],
                1
            ]);
        }
 
        list = Ext.Object.getAllKeys(renderers || {});
        length = list.length;
 
        for (= 0; i < length; i++) {
            dataFormatters.push([
                list[i],
                renderers[list[i]],
                2
            ]);
        }
 
        return Ext.apply(me.callParent(arguments), {
            items: [{
                xtype: 'displayfield',
                fieldLabel: me.sourceNameText,
                name: 'dataIndex'
            }, {
                xtype: 'textfield',
                fieldLabel: me.customNameText,
                name: 'header',
                allowBlank: false
            }, {
                xtype: 'combo',
                fieldLabel: me.alignText,
                editable: false,
                queryMode: 'local',
                valueField: 'value',
                name: 'align',
                store: new Ext.data.ArrayStore({
                    fields: ['text', 'value'],
                    data: [
                        [me.alignLeftText, 'left'],
                        [me.alignCenterText, 'center'],
                        [me.alignRightText, 'right']
                    ]
                })
            }, {
                xtype: 'combo',
                fieldLabel: me.formatText,
                editable: false,
                queryMode: 'local',
                valueField: 'value',
                name: 'formatter',
                store: new Ext.data.ArrayStore({
                    fields: ['text', 'value', 'type'],
                    data: dataFormatters
                })
            }, {
                xtype: 'combo',
                fieldLabel: me.summarizeByText,
                editable: false,
                queryMode: 'local',
                valueField: 'value',
                name: 'aggregator',
                store: new Ext.data.ArrayStore({
                    fields: ['text', 'value'],
                    data: dataAggregators
                })
            }]
        });
    },
 
    beforeApplySettings: function(settings) {
        var formatAs = this.down('[name=formatter]'),
            store, item;
 
        if (formatAs) {
            store = formatAs.getStore();
            item = store.findRecord('value', settings.formatter, 0, false, true, true);
 
            if (item) {
                if (item.get('type') === 1) {
                    settings.formatter = item.get('value');
                    settings.renderer = null;
                }
                else {
                    settings.renderer = item.get('value');
                    settings.formatter = null;
                }
            }
        }
    },
 
    loadSettings: function(settings) {
        var format = settings.formatter;
 
        if (Ext.isFunction(format)) {
            format = null;
        }
 
        if (!format && !Ext.isFunction(settings.renderer)) {
            format = settings.renderer;
        }
 
        settings.formatter = format;
        this.callParent([settings]);
    }
});