2018-05-22 19:38:15 +08:00
'use strict' ;
2017-09-25 15:36:23 +08:00
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 ;
2018-05-22 19:38:15 +08:00
var _react = require ( 'react' ) ;
2017-09-25 15:36:23 +08:00
var _react2 = _interopRequireDefault ( _react ) ;
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 ; }
2018-04-02 19:35:15 +08:00
function _toConsumableArray ( arr ) { if ( Array . isArray ( arr ) ) { for ( var i = 0 , arr2 = Array ( arr . length ) ; i < arr . length ; i ++ ) { arr2 [ i ] = arr [ i ] ; } return arr2 ; } else { return Array . from ( arr ) ; } }
2017-09-25 15:36:23 +08:00
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 ) ; }
2018-05-22 19:38:15 +08:00
function indexOf ( array , val ) {
for ( var i = 0 ; i < array . length ; i ++ ) {
if ( array [ i ] === val ) return i ;
}
return - 1 ;
} ;
function remove ( array , val ) {
var index = indexOf ( array , val ) ;
if ( index > - 1 ) {
array . splice ( index , 1 ) ;
}
} ;
2017-09-25 15:36:23 +08:00
/ * *
* multiSelect = {
* type -- 默认值为checkbox
* param -- 可以设置返回的选中的数据属性 ; 默认值 : null ;
* }
* getSelectedDataFunc -- function , 能获取到选中的数据
* 使用全选时得注意 , data中的key值一定要是唯一值
* /
2018-05-22 19:38:15 +08:00
function multiSelect ( Table , Checkbox ) {
2018-04-02 14:22:39 +08:00
var _class , _temp , _initialiseProps ;
return _temp = _class = function ( _Component ) {
2018-05-22 19:38:15 +08:00
_inherits ( MultiSelect , _Component ) ;
2017-09-25 15:36:23 +08:00
2018-05-22 19:38:15 +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-04-02 14:22:39 +08:00
_initialiseProps . call ( _this ) ;
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-05-22 19:38:15 +08:00
MultiSelect . prototype . componentDidMount = function componentDidMount ( ) {
2018-04-02 14:22:39 +08:00
this . setState ( this . initCheckedObj ( this . props ) ) ;
2018-03-28 10:37:18 +08:00
} ;
2018-05-22 19:38:15 +08:00
MultiSelect . prototype . componentWillReceiveProps = function componentWillReceiveProps ( nextProps ) {
2018-01-03 14:19:24 +08:00
var props = this . props ,
selectDisabled = props . selectDisabled ,
selectedRow = props . selectedRow ,
data = props . data ,
2018-04-02 14:38:00 +08:00
selIds = void 0 ,
obj = void 0 ,
2018-01-03 14:19:24 +08:00
checkedObj = { } ;
if ( nextProps . data !== data || nextProps . selectDisabled !== selectDisabled || nextProps . selectedRow !== selectedRow ) {
2018-04-02 14:38:00 +08:00
obj = this . initCheckedObj ( nextProps ) ;
checkedObj = obj . checkedObj ;
selIds = obj . selIds ;
2018-01-03 14:19:24 +08:00
this . setState ( {
checkedAll : false ,
checkedObj : checkedObj ,
2018-04-02 14:38:00 +08:00
selIds : selIds ,
2018-01-03 14:19:24 +08:00
data : nextProps . data
} ) ;
}
} ;
2018-05-22 19:38:15 +08:00
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 = [ {
2018-05-22 19:38:15 +08:00
title : _react2 [ "default" ] . createElement ( Checkbox , {
className : 'table-checkbox' ,
2017-09-25 15:36:23 +08:00
checked : this . state . checkedAll ,
indeterminate : indeterminate _bool && ! this . state . checkedAll ,
onChange : this . onAllCheckChange
} ) ,
key : "checkbox" ,
dataIndex : "checkbox" ,
2018-10-11 14:12:19 +08:00
width : "55" ,
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 ) ;
2018-05-22 19:38:15 +08:00
return _react2 [ "default" ] . createElement ( Checkbox , {
className : 'table-checkbox' ,
2018-01-16 17:18:12 +08:00
checked : checkedObj [ rowKey ] ,
2018-01-03 14:19:24 +08:00
disabled : ! bool ,
2018-04-11 14:34:18 +08:00
onClick : _this2 . handleClick ,
2017-09-25 15:36:23 +08:00
onChange : _this2 . onCheckboxChange . bind ( _this2 , text , record , index )
} ) ;
}
} ] ;
columns = defaultColumns . concat ( columns ) ;
}
return columns ;
} ;
2018-05-22 19:38:15 +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-05-22 19:38:15 +08:00
return MultiSelect ;
2018-04-02 14:22:39 +08:00
} ( _react . Component ) , _initialiseProps = function _initialiseProps ( ) {
var _this4 = this ;
this . getRowKey = function ( record , index ) {
var rowKey = _this4 . props . rowKey || 'key' ;
var key = typeof rowKey === 'function' ? rowKey ( record , index ) : record [ rowKey ] ;
return key ;
} ;
this . initCheckedObj = function ( props ) {
var checkedObj = { } ,
selectDisabled = props . selectDisabled ,
selectedRow = props . selectedRow ,
data = props . data ,
2018-04-02 19:35:15 +08:00
selIds _ = [ ] . concat ( _toConsumableArray ( _this4 . state . selIds ) ) ,
selIds _length = selIds _ . length ;
2018-04-02 14:22:39 +08:00
for ( var i = 0 ; i < data . length ; i ++ ) {
var bool = selectDisabled && selectDisabled ( data [ i ] , i ) || false ;
var rowKey = data [ i ] [ "key" ] ? data [ i ] [ "key" ] : _this4 . getRowKey ( data [ i ] , i ) ;
if ( ! bool ) {
if ( selectedRow && selectedRow ( data [ i ] , i ) ) {
2018-04-02 19:35:15 +08:00
if ( selIds _length > 0 ) {
for ( var index = 0 ; index < selIds _length ; index ++ ) {
var selid = selIds _ [ index ] ;
if ( selid [ rowKey ] !== data [ i ] [ rowKey ] ) {
selIds _ . push ( data [ i ] ) ;
}
}
} else {
selIds _ . push ( data [ i ] ) ;
}
2018-04-02 14:22:39 +08:00
checkedObj [ rowKey ] = true ;
} else {
checkedObj [ rowKey ] = false ;
}
}
}
return {
checkedObj : checkedObj ,
selIds : selIds _
} ;
} ;
this . onAllCheckChange = function ( ) {
var self = _this4 ;
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" ] : _this4 . 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 = _this4 ;
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" ] : _this4 . getRowKey ( record , i ) ;
if ( checkedObj [ rowKey ] ) {
2018-05-22 19:38:15 +08:00
remove ( selIds , id ) ;
2018-04-02 14:22:39 +08:00
} 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 ) ;
}
} ;
2018-04-11 14:34:18 +08:00
this . handleClick = function ( e ) {
e . stopPropagation ( ) ;
} ;
2018-04-02 14:22:39 +08:00
} , _temp ;
2017-11-29 16:51:07 +08:00
}
2018-05-22 19:38:15 +08:00
module . exports = exports [ 'default' ] ;