import * as React from 'react';
 

import JqxChart, { IChartProps } from 'jqwidgets-scripts/jqwidgets-react-tsx/jqxchart';

class App extends React.PureComponent<{}, IChartProps> {

    constructor(props: {}) {
        super(props);

        const sampleData: any[] = [
            { a: 0.35, b: 14.5 },
            { a: 1, b: 2.5 },
            { a: 10, b: 0.2 },
            { a: 100, b: 205 },
            { a: 1, b: 100 },
            { a: 5.11, b: 10.13 },
            { a: 20.13, b: 10.13 },
            { a: 600, b: 300 }
        ];

        this.state = {
            description: 'Sample logarithmic scale axis with base 2',
            padding: { left: 5, top: 5, right: 5, bottom: 5 },
            seriesGroups: [
                {
                    series: [
                        { dataField: 'a', displayText: 'A' },
                        { dataField: 'b', displayText: 'B' }
                    ],
                    type: 'column'
                },
                {
                    series: [
                        { dataField: 'a', displayText: 'A2' },
                        { dataField: 'b', displayText: 'B2' }
                    ],
                    type: 'line'
                }
            ],
            source: sampleData,
            title: 'Logarithmic Scale Axis Example',
            titlePadding: { left: 0, top: 0, right: 0, bottom: 10 },
            valueAxis: {
                labels: {
                    formatSettings: { decimalPlaces: 3 },
                    horizontalAlignment: 'right'
                },
                logarithmicScale: true,
                logarithmicScaleBase: 2,
                title: { text: 'Value' },
                unitInterval: 1
            }
        };
    }

    public render() {
        return (
            <JqxChart style={{ width: '850px', height: '500px' }}
                title={this.state.title} description={this.state.description}
                enableAnimations={true} padding={this.state.padding}
                titlePadding={this.state.titlePadding} source={this.state.source}
                valueAxis={this.state.valueAxis} seriesGroups={this.state.seriesGroups} />
        );
    }
}

export default App; 