import * as React from 'react'; import { generatedata } from './generatedata'; import JqxGrid, { IGridProps, jqx } from 'jqwidgets-scripts/jqwidgets-react-tsx/jqxgrid'; class App extends React.PureComponent<{}, IGridProps> { private theme = jqx.theme; constructor(props: {}) { super(props); const source: any = { datafields: [ { name: 'firstname', type: 'string' }, { name: 'lastname', type: 'string' }, { name: 'productname', type: 'string' }, { name: 'available', type: 'bool' }, { name: 'quantity', type: 'number' }, { name: 'price', type: 'number' } ], datatype: 'array', localdata: generatedata(200, false), updaterow: (rowid: any, rowdata: any, commit: any): any => { // synchronize with the server - send update command commit(true); } }; const columns: IGridProps['columns'] = [ { aggregatesrenderer: (aggregates: any, column: any, element: any): string => { const renderstring = '
'; return renderstring; }, columntype: 'textbox', datafield: 'firstname', text: 'First Name', width: 190 }, { aggregatesrenderer: (aggregates: any, column: any, element: any): string => { const renderstring = ''; return renderstring; }, columntype: 'textbox', datafield: 'lastname', text: 'Last Name', width: 190 }, { aggregatesrenderer: (aggregates: any, column: any, element: any): string => { const renderstring = ''; return renderstring; }, datafield: 'productname', text: 'Product', width: 170 }, { aggregates: ['min', 'max'], aggregatesrenderer: (aggregates: any, column: any, element: any): string => { let renderstring = ' '; return renderstring; }, cellsalign: 'right', cellsformat: 'n2', datafield: 'quantity', text: 'Quantity', width: 85 }, { aggregates: ['sum', 'avg'], aggregatesrenderer: (aggregates: any, column: any, element: any, summaryData: any): string => { let renderstring = ' '; return renderstring; }, cellsalign: 'right', cellsformat: 'c2', datafield: 'price', text: 'Price' } ]; this.state = { columns, source: new jqx.dataAdapter(source) } } public render() { return (