Skip to content

Commit

Permalink
add example for externally managed selection state
Browse files Browse the repository at this point in the history
  • Loading branch information
Fatih committed Jan 24, 2016
1 parent 4c44c2a commit a332728
Show file tree
Hide file tree
Showing 2 changed files with 73 additions and 0 deletions.
10 changes: 10 additions & 0 deletions examples/js/selection/demo.js
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ import SelectHookTable from './select-hook-table';
import HideSelectionColumnTable from './hide-selection-col-table';
import RowClickTable from './row-click-table';
import OnlySelectedTable from './only-show-selected-table';
import ExternallyManagedSelection from './externally-managed-selection';

class Demo extends React.Component {
render() {
Expand Down Expand Up @@ -94,6 +95,15 @@ class Demo extends React.Component {
</div>
</div>
</div>
<div className="col-md-offset-1 col-md-8">
<div className="panel panel-default">
<div className="panel-heading">Externally Managed Selection State (max 2)</div>
<div className="panel-body">
<h5>Source in externally-managed-selection.js</h5>
<ExternallyManagedSelection />
</div>
</div>
</div>
</div>
);
}
Expand Down
63 changes: 63 additions & 0 deletions examples/js/selection/externally-managed-selection.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,63 @@
'use strict';
import React from 'react';
import {BootstrapTable, TableHeaderColumn} from 'react-bootstrap-table';


var products = [];

function addProducts(quantity) {
var startId = products.length;
for (var i = 0; i < quantity; i++) {
var id = startId + i;
products.push({
id: id,
name: "Item name " + id,
price: 2100 + i
});
}
}

addProducts(100);

export default class ExternallyManagedSelection extends React.Component{
constructor(props){
super(props);
this.state = {
selected: []
};
}

render(){
let onRowSelect = ({id}, isSelected) => {
if (isSelected && this.state.selected.length !== 2) {
this.setState({ selected: [...this.state.selected, id].sort() });
}
else {
this.setState({ selected: this.state.selected.filter(it => it !== id) });
}
return false;
}

var selectRowProp = {
mode: "checkbox",
clickToSelect: true,
onSelect: onRowSelect,
selected: this.state.selected
};

var options = {
sizePerPageList: [5, 10, 15, 20],
sizePerPage: 10,
sortName: 'id',
sortOrder: 'desc'
}

return (
<BootstrapTable data={products} selectRow={selectRowProp} pagination={true} options={options}>
<TableHeaderColumn dataField="id" isKey={true}>Product ID</TableHeaderColumn>
<TableHeaderColumn dataField="name">Product Name</TableHeaderColumn>
<TableHeaderColumn dataField="price">Product Price</TableHeaderColumn>
</BootstrapTable>
);
}
};

0 comments on commit a332728

Please sign in to comment.