mirror of
https://github.com/gosticks/DefinitelyTyped.git
synced 2025-10-16 12:05:41 +00:00
* Add thStyle, tdStyle, tdAttr properties to TableHeaderColumn Also style apply TSLint rules where it was fast to implement without introducing issues. * Fix missed TSLint warnings
176 lines
6.8 KiB
TypeScript
176 lines
6.8 KiB
TypeScript
import * as React from 'react';
|
|
import { render } from 'react-dom';
|
|
import { BootstrapTable, TableHeaderColumn, ApplyFilterParameter, Filter } from 'react-bootstrap-table';
|
|
|
|
const products = [{
|
|
id: 1,
|
|
name: "Item name 1",
|
|
price: 100
|
|
}, {
|
|
id: 2,
|
|
name: "Item name 2",
|
|
price: 100
|
|
}];
|
|
|
|
// It's a data format example.
|
|
function priceFormatter(cell: any, row: any) {
|
|
return '<i class="glyphicon glyphicon-usd"></i> ' + cell;
|
|
}
|
|
|
|
render(
|
|
<BootstrapTable data={products} striped={true} hover={true} ignoreSinglePage>
|
|
<TableHeaderColumn dataField="id" isKey={true} dataAlign="center" dataSort={true}>Product ID</TableHeaderColumn>
|
|
<TableHeaderColumn dataField="name" dataSort={true} editable={{ type: 'textarea', rows: 10 }}>Product Name</TableHeaderColumn>
|
|
<TableHeaderColumn dataField="price" dataFormat={priceFormatter}>Product Price</TableHeaderColumn>
|
|
</BootstrapTable>,
|
|
document.getElementById("app")
|
|
);
|
|
|
|
const qualityType = {
|
|
0: 'good',
|
|
1: 'bad',
|
|
2: 'unknown'
|
|
};
|
|
|
|
function enumFormatter(cell: any, row: any, enumObject: any) {
|
|
return enumObject[cell];
|
|
}
|
|
|
|
class SelectFilterWithDefaultValue extends React.Component {
|
|
render() {
|
|
return (
|
|
<BootstrapTable data={products}>
|
|
<TableHeaderColumn dataField='id' isKey>Product ID</TableHeaderColumn>
|
|
<TableHeaderColumn dataField='name'>Product Name</TableHeaderColumn>
|
|
<TableHeaderColumn dataField='quality' filterFormatted dataFormat={enumFormatter}
|
|
formatExtraData={qualityType} filter={{ type: 'SelectFilter', options: qualityType, defaultValue: 1 }}>Product Quality</TableHeaderColumn>
|
|
</BootstrapTable>
|
|
);
|
|
}
|
|
}
|
|
|
|
class TextFilterWithCondition extends React.Component {
|
|
render() {
|
|
return (
|
|
<BootstrapTable data={products}>
|
|
<TableHeaderColumn dataField='id' isKey>Product ID</TableHeaderColumn>
|
|
<TableHeaderColumn dataField='name' filter={{ type: 'TextFilter', delay: 1000, condition: 'eq' }}>Product Name</TableHeaderColumn>
|
|
<TableHeaderColumn dataField='price'>Product Price</TableHeaderColumn>
|
|
</BootstrapTable>
|
|
);
|
|
}
|
|
}
|
|
|
|
function getCustomFilter(filterHandler: (parameters?: ApplyFilterParameter) => void, customFilterParameters: any) {
|
|
return (
|
|
<div />
|
|
);
|
|
}
|
|
|
|
class CustomFilter extends React.Component {
|
|
render() {
|
|
const filter: Filter = { type: 'CustomFilter', getElement: getCustomFilter, customFilterParameters: { textOK: 'yes', textNOK: 'no' } };
|
|
return (
|
|
<BootstrapTable data={products}>
|
|
<TableHeaderColumn dataField='id' isKey>Product ID</TableHeaderColumn>
|
|
<TableHeaderColumn dataField='name'>Product Name</TableHeaderColumn>
|
|
<TableHeaderColumn dataField='isInStock' filter={filter}>Product Is In Stock</TableHeaderColumn>
|
|
</BootstrapTable>
|
|
);
|
|
}
|
|
}
|
|
|
|
class RemoteProps extends React.Component {
|
|
render() {
|
|
const filter: Filter = { type: 'CustomFilter', getElement: getCustomFilter, customFilterParameters: { textOK: 'yes', textNOK: 'no' } };
|
|
return (
|
|
<BootstrapTable
|
|
data={products}
|
|
remote={(remoteObj) => {
|
|
remoteObj.cellEdit = true;
|
|
return remoteObj;
|
|
}}
|
|
options={{
|
|
onCellEdit: (row: any, fieldName: string, value: any) => { console.info(row); }
|
|
}}
|
|
>
|
|
<TableHeaderColumn dataField='id' isKey>Product ID</TableHeaderColumn>
|
|
<TableHeaderColumn dataField='name'>Product Name</TableHeaderColumn>
|
|
<TableHeaderColumn dataField='isInStock' filter={filter}>Product Is In Stock</TableHeaderColumn>
|
|
</BootstrapTable>
|
|
);
|
|
}
|
|
}
|
|
|
|
class RemoteBool extends React.Component {
|
|
render() {
|
|
const filter: Filter = { type: 'CustomFilter', getElement: getCustomFilter, customFilterParameters: { textOK: 'yes', textNOK: 'no' } };
|
|
return (
|
|
<BootstrapTable
|
|
data={products}
|
|
remote
|
|
>
|
|
<TableHeaderColumn dataField='id' isKey>Product ID</TableHeaderColumn>
|
|
<TableHeaderColumn dataField='name'>Product Name</TableHeaderColumn>
|
|
<TableHeaderColumn dataField='isInStock' filter={filter}>Product Is In Stock</TableHeaderColumn>
|
|
</BootstrapTable>
|
|
);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* See http://allenfang.github.io/react-bootstrap-table/docs.html#tdAttr
|
|
*/
|
|
const tdAttrExample = <BootstrapTable data={ products } search>
|
|
<TableHeaderColumn dataField='id' isKey>Product ID</TableHeaderColumn>
|
|
<TableHeaderColumn dataField='name' tdAttr={ { "data-attr": 'test' } }>Product Name</TableHeaderColumn>
|
|
<TableHeaderColumn dataField='price'>Product Price</TableHeaderColumn>
|
|
</BootstrapTable>;
|
|
|
|
/**
|
|
* See http://allenfang.github.io/react-bootstrap-table/docs.html#tdStyle
|
|
*/
|
|
const tdStyleExample = <BootstrapTable data={ products } search>
|
|
<TableHeaderColumn dataField='id' isKey>Product ID</TableHeaderColumn>
|
|
<TableHeaderColumn dataField='name' tdStyle={ { whiteSpace: 'normal' } }>Product Name</TableHeaderColumn>
|
|
<TableHeaderColumn dataField='price'>Product Price</TableHeaderColumn>
|
|
</BootstrapTable>;
|
|
|
|
/**
|
|
* See http://allenfang.github.io/react-bootstrap-table/docs.html#thStyle
|
|
*/
|
|
const thStyleExample = <BootstrapTable data={ products } search>
|
|
<TableHeaderColumn dataField='id' isKey>Product ID</TableHeaderColumn>
|
|
<TableHeaderColumn dataField='name' thStyle={ { fontWeight: 'lighter' } }>Product Name</TableHeaderColumn>
|
|
<TableHeaderColumn dataField='price'>Product Price</TableHeaderColumn>
|
|
</BootstrapTable>;
|
|
|
|
// Adopted from https://github.com/AllenFang/react-bootstrap-table/blob/master/examples/js/column-header-span/column-header-span-complex.js
|
|
export default class ColumnHeaderSpanComplex extends React.Component {
|
|
render() {
|
|
const selectRow = {
|
|
mode: 'checkbox',
|
|
bgColor: 'rgb(238, 193, 213)'
|
|
};
|
|
|
|
const cellEdit = {
|
|
mode: 'click',
|
|
blurToSave: true
|
|
};
|
|
return (
|
|
<BootstrapTable data={products}
|
|
insertRow deleteRow exportCSV>
|
|
<TableHeaderColumn row={0} rowSpan={2} dataField='id' isKey={true} >ID</TableHeaderColumn>
|
|
<TableHeaderColumn row={0} colSpan={3} dataSort csvHeader='Product' headerAlign='right'>Product</TableHeaderColumn>
|
|
<TableHeaderColumn row={1} dataField='name' width='175' dataAlign='center'>name</TableHeaderColumn>
|
|
<TableHeaderColumn row={1} dataField='price' dataSort>price</TableHeaderColumn>
|
|
<TableHeaderColumn row={1} dataField='coupon' width='70'>Coupon</TableHeaderColumn>
|
|
<TableHeaderColumn row={0} csvHeader='In stock' rowSpan={2} dataField='status'>In stock</TableHeaderColumn>
|
|
<TableHeaderColumn row={0} colSpan={2} csvHeader='Customer' filter={{ type: 'TextFilter', delay: 1000 }}>Customer</TableHeaderColumn>
|
|
<TableHeaderColumn row={1} csvHeader='name' dataField='customer'>name</TableHeaderColumn>
|
|
<TableHeaderColumn row={1} csvHeader='order' dataField='order' dataSort>order</TableHeaderColumn>
|
|
</BootstrapTable>
|
|
);
|
|
}
|
|
}
|