2017-09-25 15:36:23 +08:00
"use strict" ;
2017-11-29 16:51:07 +08:00
Object . defineProperty ( exports , "__esModule" , {
value : true
} ) ;
2017-09-25 15:36:23 +08:00
var _extends = Object . assign || function ( target ) { for ( var i = 1 ; i < arguments . length ; i ++ ) { var source = arguments [ i ] ; for ( var key in source ) { if ( Object . prototype . hasOwnProperty . call ( source , key ) ) { target [ key ] = source [ key ] ; } } } return target ; } ;
2017-11-29 16:51:07 +08:00
exports [ "default" ] = multiSelect ;
2017-09-25 15:36:23 +08:00
var _react = require ( "react" ) ;
var _react2 = _interopRequireDefault ( _react ) ;
var _beeCheckbox = require ( "bee-checkbox" ) ;
var _beeCheckbox2 = _interopRequireDefault ( _beeCheckbox ) ;
function _interopRequireDefault ( obj ) { return obj && obj . _ _esModule ? obj : { "default" : obj } ; }
function _defaults ( obj , defaults ) { var keys = Object . getOwnPropertyNames ( defaults ) ; for ( var i = 0 ; i < keys . length ; i ++ ) { var key = keys [ i ] ; var value = Object . getOwnPropertyDescriptor ( defaults , key ) ; if ( value && value . configurable && obj [ key ] === undefined ) { Object . defineProperty ( obj , key , value ) ; } } return obj ; }
function _classCallCheck ( instance , Constructor ) { if ( ! ( instance instanceof Constructor ) ) { throw new TypeError ( "Cannot call a class as a function" ) ; } }
function _possibleConstructorReturn ( self , call ) { if ( ! self ) { throw new ReferenceError ( "this hasn't been initialised - super() hasn't been called" ) ; } return call && ( typeof call === "object" || typeof call === "function" ) ? call : self ; }
function _inherits ( subClass , superClass ) { if ( typeof superClass !== "function" && superClass !== null ) { throw new TypeError ( "Super expression must either be null or a function, not " + typeof superClass ) ; } subClass . prototype = Object . create ( superClass && superClass . prototype , { constructor : { value : subClass , enumerable : false , writable : true , configurable : true } } ) ; if ( superClass ) Object . setPrototypeOf ? Object . setPrototypeOf ( subClass , superClass ) : _defaults ( subClass , superClass ) ; }
/ * *
* multiSelect = {
* type -- 默认值为checkbox
* param -- 可以设置返回的选中的数据属性 ; 默认值 : null ;
* }
* getSelectedDataFunc -- function , 能获取到选中的数据
* 使用全选时得注意 , data中的key值一定要是唯一值
* /
2017-11-29 16:51:07 +08:00
function multiSelect ( Table ) {
2017-09-25 15:36:23 +08:00
Array . prototype . indexOf = function ( val ) {
for ( var i = 0 ; i < this . length ; i ++ ) {
if ( this [ i ] == val ) return i ;
}
return - 1 ;
} ;
Array . prototype . remove = function ( val ) {
var index = this . indexOf ( val ) ;
if ( index > - 1 ) {
this . splice ( index , 1 ) ;
}
} ;
2018-03-28 10:37:18 +08:00
return function ( _Component ) {
2018-01-03 14:19:24 +08:00
_inherits ( multiSelect , _Component ) ;
2017-09-25 15:36:23 +08:00
2018-01-03 14:19:24 +08:00
function multiSelect ( props ) {
_classCallCheck ( this , multiSelect ) ;
2017-09-25 15:36:23 +08:00
var _this = _possibleConstructorReturn ( this , _Component . call ( this , props ) ) ;
2018-03-28 10:37:18 +08:00
_this . getRowKey = function ( record , index ) {
var rowKey = _this . props . rowKey || 'key' ;
var key = typeof rowKey === 'function' ? rowKey ( record , index ) : record [ rowKey ] ;
return key ;
} ;
_this . initCheckedObj = function ( ) {
var checkedObj = { } ,
_this$props = _this . props ,
selectDisabled = _this$props . selectDisabled ,
selectedRow = _this$props . selectedRow ,
data = _this$props . data ,
selIds _ = _this . state . selIds ;
for ( var i = 0 ; i < data . length ; i ++ ) {
var bool = selectDisabled && selectDisabled ( data [ i ] , i ) || false ;
var rowKey = data [ i ] [ "key" ] ? data [ i ] [ "key" ] : _this . getRowKey ( data [ i ] , i ) ;
if ( ! bool ) {
if ( selectedRow && selectedRow ( data [ i ] , i ) ) {
selIds _ . push ( data [ i ] ) ;
checkedObj [ rowKey ] = true ;
} else {
checkedObj [ rowKey ] = false ;
}
}
}
return {
checkedObj : checkedObj ,
selIds : selIds _
} ;
} ;
2017-09-25 15:36:23 +08:00
2018-03-28 10:37:18 +08:00
_this . onAllCheckChange = function ( ) {
var self = _this ;
var listData = self . state . data . concat ( ) ;
var checkedObj = _extends ( { } , self . state . checkedObj ) ;
var data = self . props . data ;
var selIds = [ ] ;
var id = self . props . multiSelect . param ;
if ( self . state . checkedAll ) {
selIds = [ ] ;
} else {
for ( var i = 0 ; i < listData . length ; i ++ ) {
if ( id ) {
selIds [ i ] = listData [ i ] [ id ] ;
} else {
selIds [ i ] = listData [ i ] ;
}
}
}
for ( var i = 0 ; i < data . length ; i ++ ) {
var rowKey = data [ i ] [ "key" ] ? data [ i ] [ "key" ] : _this . getRowKey ( data [ i ] , i ) ;
var bool = checkedObj . hasOwnProperty ( rowKey ) ;
if ( ! bool ) {
selIds . splice ( i , 1 ) ;
} else {
checkedObj [ rowKey ] = ! self . state . checkedAll ;
}
}
self . setState ( {
checkedAll : ! self . state . checkedAll ,
checkedObj : checkedObj ,
selIds : selIds
} ) ;
self . props . getSelectedDataFunc ( selIds ) ;
} ;
_this . onCheckboxChange = function ( text , record , index ) {
var self = _this ;
var allFlag = false ;
var selIds = self . state . selIds ;
var id = self . props . multiSelect ? self . props . multiSelect . param ? record [ self . props . multiSelect . param ] : record : record ;
var checkedObj = _extends ( { } , self . state . checkedObj ) ;
var checkedArray = Object . keys ( checkedObj ) ;
var getSelectedDataFunc = self . props . getSelectedDataFunc ;
var rowKey = record [ "key" ] ? record [ "key" ] : _this . getRowKey ( record , i ) ;
if ( checkedObj [ rowKey ] ) {
selIds . remove ( id ) ;
} else {
selIds . push ( id ) ;
}
checkedObj [ rowKey ] = ! checkedObj [ rowKey ] ;
for ( var i = 0 ; i < checkedArray . length ; i ++ ) {
if ( ! checkedObj [ checkedArray [ i ] ] ) {
allFlag = false ;
break ;
} else {
allFlag = true ;
}
}
self . setState ( {
checkedAll : allFlag ,
checkedObj : checkedObj ,
selIds : selIds
} ) ;
if ( typeof getSelectedDataFunc === "function" ) {
getSelectedDataFunc ( selIds ) ;
}
} ;
2017-09-25 15:36:23 +08:00
_this . state = {
checkedAll : false ,
2018-03-28 10:37:18 +08:00
checkedObj : { } ,
2017-09-25 15:36:23 +08:00
selIds : [ ] ,
2018-03-28 10:37:18 +08:00
data : props . data
2017-09-25 15:36:23 +08:00
} ;
return _this ;
}
2018-03-28 10:37:18 +08:00
multiSelect . prototype . componentDidMount = function componentDidMount ( ) {
this . setState ( this . initCheckedObj ( ) ) ;
} ;
2018-01-03 14:19:24 +08:00
multiSelect . prototype . componentWillReceiveProps = function componentWillReceiveProps ( nextProps ) {
var props = this . props ,
selectDisabled = props . selectDisabled ,
selectedRow = props . selectedRow ,
data = props . data ,
checkedObj = { } ;
if ( nextProps . data !== data || nextProps . selectDisabled !== selectDisabled || nextProps . selectedRow !== selectedRow ) {
2018-03-28 10:37:18 +08:00
checkedObj = this . initCheckedObj ( nextProps ) . checkedObj ;
2018-01-03 14:19:24 +08:00
this . setState ( {
checkedAll : false ,
checkedObj : checkedObj ,
selIds : [ ] ,
data : nextProps . data
} ) ;
}
} ;
multiSelect . prototype . renderColumnsMultiSelect = function renderColumnsMultiSelect ( columns ) {
2017-09-25 15:36:23 +08:00
var _this2 = this ;
var data = this . state . data ;
var checkedObj = _extends ( { } , this . state . checkedObj ) ;
var checkedArray = Object . keys ( checkedObj ) ;
var multiSelect = this . props . multiSelect ;
var select _column = { } ;
var indeterminate _bool = false ;
if ( ! multiSelect || ! multiSelect . type ) {
multiSelect = _extends ( { } , multiSelect , { type : "checkbox" } ) ;
}
if ( multiSelect && multiSelect . type === "checkbox" ) {
var i = checkedArray . length ;
while ( i -- ) {
if ( checkedObj [ checkedArray [ i ] ] ) {
indeterminate _bool = true ;
break ;
}
}
var defaultColumns = [ {
title : _react2 [ "default" ] . createElement ( _beeCheckbox2 [ "default" ] , {
className : "table-checkbox" ,
checked : this . state . checkedAll ,
indeterminate : indeterminate _bool && ! this . state . checkedAll ,
onChange : this . onAllCheckChange
} ) ,
key : "checkbox" ,
dataIndex : "checkbox" ,
2018-01-03 14:19:24 +08:00
width : "100px" ,
2017-09-25 15:36:23 +08:00
render : function render ( text , record , index ) {
2018-01-16 17:18:12 +08:00
var rowKey = record [ "key" ] ? record [ "key" ] : _this2 . getRowKey ( record , i ) ;
var bool = checkedObj . hasOwnProperty ( rowKey ) ;
2017-09-25 15:36:23 +08:00
return _react2 [ "default" ] . createElement ( _beeCheckbox2 [ "default" ] , {
className : "table-checkbox" ,
2018-01-16 17:18:12 +08:00
checked : checkedObj [ rowKey ] ,
2018-01-03 14:19:24 +08:00
disabled : ! bool ,
2017-09-25 15:36:23 +08:00
onChange : _this2 . onCheckboxChange . bind ( _this2 , text , record , index )
} ) ;
}
} ] ;
columns = defaultColumns . concat ( columns ) ;
}
return columns ;
} ;
2018-01-03 14:19:24 +08:00
multiSelect . prototype . render = function render ( ) {
2018-01-16 17:18:12 +08:00
var _this3 = this ;
2017-09-25 15:36:23 +08:00
var columns = this . renderColumnsMultiSelect ( this . props . columns ) . concat ( ) ;
2018-01-16 17:18:12 +08:00
return _react2 [ "default" ] . createElement ( Table , _extends ( { ref : function ref ( table _ref ) {
_this3 . table _ref = table _ref ;
} } , this . props , { columns : columns } ) ) ;
2017-09-25 15:36:23 +08:00
} ;
2018-01-03 14:19:24 +08:00
return multiSelect ;
2018-03-28 10:37:18 +08:00
} ( _react . Component ) ;
2017-11-29 16:51:07 +08:00
}
module . exports = exports [ "default" ] ;