'use strict'; import React from 'react'; import jQuery from 'jquery'; import Table from 'rc-table'; import Dropdown from '../dropdown'; import Checkbox from '../checkbox'; import FilterMenu from './filterMenu'; import Pagination from '../pagination'; import objectAssign from 'object-assign'; let AntTable = React.createClass({ getInitialState() { // 支持两种模式 if (Array.isArray(this.props.dataSource)) { this.mode = 'local'; // 保留原来的数据 this.originDataSource = this.props.dataSource.slice(0); } else { this.mode = 'remote'; this.props.dataSource = objectAssign({ resolve: function(data) { return data || []; }, getParams: function() {}, getPagination: function() {} }, this.props.dataSource); } var pagination; if (this.props.pagination === false) { pagination = false; } else { pagination = objectAssign({ pageSize: 10, total: this.props.dataSource.length }, this.props.pagination); } return { selectedRowKeys: [], loading: false, pagination: pagination, data: [] }; }, getDefaultProps() { return { prefixCls: 'ant-table', useFixedHeader: false, rowSelection: null, size: 'normal' }; }, toggleSortOrder(order, column) { let sortColumn = this.state.sortColumn; let sortOrder = this.state.sortOrder; // 同时允许一列进行排序,否则会导致排序顺序的逻辑问题 if (sortColumn) { sortColumn.className = ''; } if (sortColumn !== column) { // 当前列未排序 sortOrder = order; sortColumn = column; sortColumn.className = 'ant-table-column-sort'; } else { // 当前列已排序 if (sortOrder === order) { // 切换为未排序状态 sortOrder = ''; sortColumn = null; } else { // 切换为排序状态 sortOrder = order; sortColumn.className = 'ant-table-column-sort'; } } if (this.mode === 'local') { let sorter = function() { let result = column.sorter.apply(this, arguments); if (sortOrder === 'ascend') { return result; } else if (sortOrder === 'descend') { return -result; } }; if (sortOrder) { this.props.dataSource = this.props.dataSource.sort(sorter); } else { this.props.dataSource = this.originDataSource.slice(); } } this.setState({ sortOrder: sortOrder, sortColumn: sortColumn }, this.fetch); }, handleFilter(column) { if (this.mode === 'local') { this.props.dataSource = this.originDataSource.slice().filter(function(record) { if (column.selectedFilters.length === 0) { return true; } return column.selectedFilters.some(function(value) { return column.onFilter.call(this, value, record); }); }); } this.fetch(); }, handleSelect(rowIndex, checked) { if (checked) { this.state.selectedRowKeys.push(rowIndex); } else { this.state.selectedRowKeys = this.state.selectedRowKeys.filter(function(i) { return rowIndex !== i; }); } this.setState({ selectedRowKeys: this.state.selectedRowKeys }); if (this.props.rowSelection.onSelect) { let currentRow = this.state.data[rowIndex - 1]; let selectedRows = this.state.data.filter((row, i) => { return this.state.selectedRowKeys.indexOf(i + 1) >= 0; }); this.props.rowSelection.onSelect(currentRow, checked, selectedRows); } }, handleSelectAllRow(checked) { var selectedRowKeys = checked ? this.state.data.map(function(item, i) { return i + 1; }) : []; this.setState({ selectedRowKeys: selectedRowKeys }); if (this.props.rowSelection.onSelectAll) { let selectedRows = this.state.data.filter((row, i) => { return selectedRowKeys.indexOf(i + 1) >= 0; }); this.props.rowSelection.onSelectAll(checked, selectedRows); } }, handlePageChange: function(current) { let pagination = this.state.pagination; pagination.current = current || 1; this.setState({ pagination: pagination }, this.fetch); }, renderSelectionCheckBox(value, record, index) { let rowIndex = index + 1; // 从 1 开始 let checked = this.state.selectedRowKeys.indexOf(rowIndex) >= 0; return ; }, renderRowSelection() { var columns = this.props.columns; if (this.props.rowSelection) { let checked = this.state.data.every(function(item, i) { return this.state.selectedRowKeys.indexOf(i + 1) >= 0; }, this); let checkboxAll = ; let selectionColumn = { key: 'selection-column', title: checkboxAll, width: 60, render: this.renderSelectionCheckBox, className: 'ant-table-selection-column' }; if (columns[0] && columns[0].key === 'selection-column') { columns[0] = selectionColumn; } else { columns.unshift(selectionColumn); } // 加上选中行的样式 this.props.rowClassName = (record, i) => { return this.state.selectedRowKeys.indexOf(i + 1) >= 0 ? 'ant-table-row-selected' : ''; }; } return columns; }, renderColumnsDropdown() { return this.props.columns.map((column) => { if (!column.originTitle) { column.originTitle = column.title; } let filterDropdown, menus, sortButton; if (column.filters && column.filters.length > 0) { column.selectedFilters = column.selectedFilters || []; menus = ; let dropdownSelectedClass = ''; if (column.selectedFilters && column.selectedFilters.length > 0) { dropdownSelectedClass = 'ant-table-filter-selected'; } filterDropdown = ; } if (column.sorter) { let isSortColumn = (this.state.sortColumn === column); sortButton =
; } column.title = [ column.originTitle, sortButton, filterDropdown ]; return column; }); }, renderPagination() { // 强制不需要分页 if (this.state.pagination === false) { return ''; } let classString = 'ant-table-pagination'; if (this.props.size === 'small') { classString += ' mini'; } return ; }, prepareParamsArguments() { // 准备筛选、排序、分页的参数 let pagination; let filters = {}; let sorter = {}; pagination = this.state.pagination; this.props.columns.forEach(function(column) { if (column.dataIndex && column.selectedFilters && column.selectedFilters.length > 0) { filters[column.dataIndex] = column.selectedFilters; } }); if (this.state.sortColumn && this.state.sortOrder && this.state.sortColumn.dataIndex) { sorter.field = this.state.sortColumn.dataIndex; sorter.order = this.state.sortOrder; } return [pagination, filters, sorter]; }, fetch: function() { let dataSource = this.props.dataSource; if (this.mode === 'remote') { this.setState({ loading: true }); jQuery.ajax({ url: dataSource.url, data: dataSource.getParams.apply(this, this.prepareParamsArguments()) || {}, headers: dataSource.headers, dataType: 'json', success: (result) => { if (this.isMounted()) { let pagination = objectAssign( this.state.pagination, dataSource.getPagination.call(this, result) ); this.setState({ data: dataSource.resolve.call(this, result), pagination: pagination, loading: false }); } }, error: () => { this.setState({ loading: false }); } }); } else { let pageSize = this.state.pagination.pageSize; let current = this.state.pagination.current; this.setState({ data: this.props.dataSource.filter(function(item, i) { if (i >= (current - 1) * pageSize && i < current * pageSize) { return item; } }) }); } }, componentDidMount() { this.handlePageChange(); }, render() { this.props.columns = this.renderRowSelection(); var classString = ''; if (this.state.loading) { classString += ' ant-table-loading'; } if (this.props.size === 'small') { classString += ' ant-table-small'; } return
{this.renderPagination()} ; } }); export default AntTable;