UNPKG

jqwidgets-scripts-custom

Version:

jQWidgets is an advanced jQuery, Angular 7, Vue, React, ASP .NET MVC, Custom Elements and HTML5 UI framework.

101 lines (89 loc) 4.39 kB
import React from 'react'; import ReactDOM from 'react-dom'; import JqxGrid from '../../../jqwidgets-react/react_jqxgrid.js'; class App extends React.Component { render() { var data = new Array(); data.push({ "Name": "Population", "Berlin": "3560154", "Boston": "3406829", "London": "8174100" }); data.push({ "Name": "Country", "Berlin": "Germany", "Boston": "United States", "London": "United Kingdom" }); data.push({ "Name": "Capital", "Berlin": "true", "Boston": "false", "London": "true" }); let source = { localdata: data, datatype: "array", updaterow: (rowid, rowdata, commit) => { // synchronize with the server - send update command // call commit with parameter true if the synchronization with the server is successful // and with parameter false if the synchronization failder. commit(true); }, datafields: [ { name: 'Name', type: 'string' }, { name: 'Berlin', type: 'string' }, { name: 'Boston', type: 'string' }, { name: 'London', type: 'string' } ] }; let dataAdapter = new $.jqx.dataAdapter(source); var createGridEditor = (row, cellValue, editor, cellText, width, height) => { // construct the editor. if (row == 0) { editor.jqxNumberInput({ decimalDigits: 0, inputMode: 'simple', width: width, height: height, spinButtons: true }); } else if (row == 1) { editor.jqxDropDownList({ autoDropDownHeight: true, width: width, height: height, source: ['United States', 'Germany', 'United Kingdom'] }); } else if (row == 2) { var element = $('<div tabIndex=0 style="position: absolute; top: 50%; left: 50%; margin-top: -7px; margin-left: -10px;"></div>'); editor.append(element); element.jqxCheckBox({ animationShowDelay: 0, animationHideDelay: 0, width: 18, height: 18 }); } } var initGridEditor = (row, cellValue, editor, cellText, width, height) => { // set the editor's current value. The callback is called each time the editor is displayed. if (row == 0) { editor.jqxNumberInput({ decimal: parseInt(cellValue) }); } else if (row == 1) { editor.jqxDropDownList('selectItem', cellValue); } else if (row == 2) { var checkBoxHTMLElement = editor.find('div:first'); checkBoxHTMLElement.jqxCheckBox({ checked: cellValue.toString() == "true" }); } } var gridEditorValue = (row, cellValue, editor) => { if (row == 2) { var checkBoxHTMLElement = editor.find('div:first'); return checkBoxHTMLElement.val(); } return editor.val(); } let columns = [ { text: 'Name', pinned: true, editable: false, datafield: 'Name', width: 150 }, { text: 'Boston', columntype: 'custom', datafield: 'Boston', width: 150, createeditor: createGridEditor, initeditor: initGridEditor, geteditorvalue: gridEditorValue }, { text: 'Berlin', columntype: 'custom', datafield: 'Berlin', width: 150, createeditor: createGridEditor, initeditor: initGridEditor, geteditorvalue: gridEditorValue }, { text: 'London', columntype: 'custom', datafield: 'London', createeditor: createGridEditor, initeditor: initGridEditor, geteditorvalue: gridEditorValue } ]; return ( <JqxGrid width={850} source={dataAdapter} selectionmode={'singlecell'} autoheight={true} editable={true} columns={columns} /> ) } } ReactDOM.render(<App />, document.getElementById('app'));