'use strict'; import React from 'react'; import jQuery from 'jquery'; import Table from 'rc-table'; import Menu from 'rc-menu'; import Dropdown from '../dropdown'; 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' }; }, renderMenus(items) { let menuItems = items.map((item) => { return {item.text}; }); return menuItems; }, toggleSortOrder(order, column) { if (column.sortOrder === order) { column.sortOrder = ''; } else { column.sortOrder = order; } if (this.mode === 'local') { let sorter = function() { let result = column.sorter.apply(this, arguments); if (column.sortOrder === 'ascend') { return result; } else if (column.sortOrder === 'descend') { return -result; } }; if (column.sortOrder) { this.props.dataSource = this.props.dataSource.sort(sorter); } else { this.props.dataSource = this.originDataSource.slice(); } } 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(); }, handleSelectFilter(column, selected) { column.selectedFilters.push(selected); }, handleDeselectFilter(column, key) { var index = column.selectedFilters.indexOf(key); if (index !== -1) { column.selectedFilters.splice(index, 1); } }, handleClearFilters(column) { column.selectedFilters = []; this.fetch(); }, handleSelect(e) { let checked = e.currentTarget.checked; let currentRowIndex = e.currentTarget.parentElement.parentElement.rowIndex; let selectedRow = this.state.data[currentRowIndex - 1]; if (checked) { this.state.selectedRowKeys.push(currentRowIndex); } else { this.state.selectedRowKeys = this.state.selectedRowKeys.filter(function(i) { return currentRowIndex !== i; }); } this.setState({ selectedRowKeys: this.state.selectedRowKeys }); if (this.props.rowSelection.onSelect) { this.props.rowSelection.onSelect(selectedRow, checked); } }, handleSelectAllRow(e) { let checked = e.currentTarget.checked; this.setState({ selectedRowKeys: checked ? this.state.data.map(function(item, i) { return i + 1; }) : [] }); if (this.props.rowSelection.onSelectAll) { this.props.rowSelection.onSelectAll(checked); } }, handlePageChange: function(current) { this.state.pagination.current = current || 1; this.fetch(); }, renderSelectionCheckBox(value, record, index) { let checked = this.state.selectedRowKeys.indexOf(index + 1) >= 0; let checkbox = ; return checkbox; }, 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 = {this.renderMenus(column.filters)} 确定 清空 ; let dropdownSelectedClass = ''; if (column.selectedFilters && column.selectedFilters.length > 0) { dropdownSelectedClass = 'ant-table-filter-selected'; } filterDropdown = ; } if (column.sorter) { 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 sorters = {}; 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 (column.dataIndex && column.sorter && column.sortOrder) { sorters[column.dataIndex] = column.sortOrder; } }); return [pagination, filters, sorters]; }, 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; } }), pagination: this.state.pagination }); } }, 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;