| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119 | Ext.require('Ext.chart.*');Ext.require(['Ext.Window', 'Ext.fx.target.Sprite', 'Ext.layout.container.Fit', 'Ext.window.MessageBox']);Ext.onReady(function () {    store1.loadData(generateData(8));        var chart = Ext.create('Ext.chart.Chart', {            xtype: 'chart',            style: 'background:#fff',            animate: true,            store: store1,            shadow: true,            theme: 'Category1',            legend: {                position: 'right'            },            axes: [{                type: 'Numeric',                minimum: 0,                position: 'left',                fields: ['data1', 'data2', 'data3'],                title: 'Number of Hits',                minorTickSteps: 1,                grid: {                    odd: {                        opacity: 1,                        fill: '#ddd',                        stroke: '#bbb',                        'stroke-width': 0.5                    }                }            }, {                type: 'Category',                position: 'bottom',                fields: ['name'],                title: 'Month of the Year'            }],            series: [{                type: 'line',                highlight: {                    size: 7,                    radius: 7                },                axis: 'left',                xField: 'name',                yField: 'data1',                markerConfig: {                    type: 'cross',                    size: 4,                    radius: 4,                    'stroke-width': 0                }            }, {                type: 'line',                highlight: {                    size: 7,                    radius: 7                },                axis: 'left',                smooth: true,                xField: 'name',                yField: 'data2',                markerConfig: {                    type: 'circle',                    size: 4,                    radius: 4,                    'stroke-width': 0                }            }, {                type: 'line',                highlight: {                    size: 7,                    radius: 7                },                axis: 'left',                smooth: true,                fill: true,                xField: 'name',                yField: 'data3',                markerConfig: {                    type: 'circle',                    size: 4,                    radius: 4,                    'stroke-width': 0                }            }]        });    var win = Ext.create('Ext.Window', {        width: 800,        height: 600,        minHeight: 400,        minWidth: 550,        hidden: false,        maximizable: true,        title: 'Line Chart',        renderTo: Ext.getBody(),        layout: 'fit',        tbar: [{            text: 'Save Chart',            handler: function() {                Ext.MessageBox.confirm('Confirm Download', 'Would you like to download the chart as an image?', function(choice){                    if(choice == 'yes'){                        chart.save({                            type: 'image/png'                        });                    }                });            }        }, {            text: 'Reload Data',            handler: function() {                store1.loadData(generateData(8));            }        }],        items: chart    });});
 |