如何使用按钮对数据表列进行排序/过滤,而无需在primary react中设置sortable或filter?

时间:2018-11-27 08:15:48

标签: reactjs primereact

我试图创建一个表,其表头具有一个包含“排序”字段和过滤器的菜单。排序具有两个按钮,升序和降序对表中的数据进行排序,过滤器具有一个输入框。我想使用此菜单,而不是设置filter = true或sortable = true。 如何将表格中存在的数据传递给按钮进行排序或过滤?我该如何标记以仅根据聚焦的字段进行排序或过滤?

这是table.js

import React from 'react';
import PropTypes from 'prop-types';
import './table.css';
import {DataTable} from 'primereact/components/datatable/DataTable';
import {Column} from 'primereact/components/column/Column';
import {Header} from './Header';
import {TableService} from './TableService';


export class Table extends React.Component{
constructor(){
    super();

    this.state = {
        data:[],
        first: 0, 
        rows: 10
    };
    this.tableService= new TableService();
    this.onPageChange = this.onPageChange.bind(this);
}

onPageChange(event) {
    this.setState({
        first: event.first,
        rows: event.rows
    });
}
componentDidMount(){
    this.tableService.getSampleData().then(data=>this.setState({datas:data}));
}



render(){

    const columns = [
        {field: 'sno', header: (<Header field={this.field} header='sno'/>)},
        {field: 'name', header: (<Header field={this.field} header='Name'/>)},
        {field: 'unit', header: (<Header field={this.field} header='Unit'/>)},
        {field: 'status', header: (<div><Header field='status' header='Status'/></div>)}
    ];

    const dynamicColumns = columns.map((col,i) => {
    return (

    <Column key={col.field} field={col.field} header={col.header}/>
    );
    });

    return (
        <div>
            <DataTable sortField="ledgerName" ref={(el) => this.dt = el}  value={this.state.datas} paginator={true} rows={5}>
            {dynamicColumns}

            </DataTable>

        </div>
    );
}
}

Table.prototypes ={
  sno : PropTypes.string.isRequired,
  name :  PropTypes.string.isRequired,
  unit:  PropTypes.number.isRequired,
  status:  PropTypes.string.isRequired
};

这是Header.js

import React from 'react';
import {Menu} from './Menu';
import {OverlayPanel} from 'primereact/components/overlaypanel/OverlayPanel';
import {Button} from 'primereact/components/button/Button';


export class Header extends React.Component{



render(){

    return(
        <div>

    <Button id="menu" type="button" label={this.props.header} onClick={(e) => this.op.toggle(e)} iconPos="right" icon="fa fa-caret-down" />
    <OverlayPanel ref={(el) => this.op = el} appendTo={document.body}>
   <Menu field={this.props.field} />
  </OverlayPanel>
        </div>
    );
  }

 }

这是Menu.js

import React, {Component} from 'react';
import Dropdown from 'react-dropdown';

export class Menu extends Component {
constructor(){
    super();
    this.state={
        status:null
    };
    this.onStatusChange=this.onStatusChange.bind(this);
}

onStatusChange=(e)=>{
    const statusChange=e.value;
    this.setState({
        status: statusChange
        //status:e
    });
}


render() {

    const statusArr = [
        { label : 'Study', value: 'study'},
        { label : 'Finalized', value: 'finalized'},
        { label : 'Prospect', value: 'prospect'},
        { label : 'To Validate', value: 'To Validate'},
        { label : 'Authorized', value: 'authorized'},
        { label : 'Renewed', value: 'renewed'},
        { label : 'accepted', value: 'accepted'},
        { label : 'All', value: ''}
        ];
    return (
        <div>

     <h6>Sort</h6>
         <div class="p-grid">
             <div class="p-col-12 p-md-6">
        <button  className="a1" label="Ascending">Ascending
        </button>
    </div>
    <div class="p-col-12 p-md-6">
        <button pButton className="a1" label="Descending" >Descending
        </button>
    </div>

</div>

<h6>Filter</h6>
{this.props.field==='status'? <Dropdown className="b4" value={this.state.status} options={statusArr} onChange={this.onStatusChange} placeholder="Select"/>: <input id="search" className="in" onInput={(e) => this.setState({filter: e.target.value})} placeholder="Filter"  size="10" />}



       </div>
         );
      }
    }

这是tableservice.js

import axios from 'axios';

 export class TableService {
    getSampleData(){
    return axios.get("sampleData/sample.json").then(res => res.data.data);


  }

getStatus(){
    return [
      { label : 'Study', value: 'study'},
      { label : 'Finalized', value: 'finalized'},
      { label : 'Prospect', value: 'prospect'},
      { label : 'To Validate', value: 'To Validate'},
      { label : 'Authorized', value: 'authorized'},
      { label : 'Renewed', value: 'renewed'},
      { label : 'accepted', value: 'accepted'}
    ] 
  }
}

0 个答案:

没有答案