1、先将插件源码进行下载,新建 tableTree.js
文件,将源码放进去
2、将 tableTree.js
文件 配置之后,在需要使用的页面进行引入:
layui. define ( [ "tableTree" ] , function ( exports ) { var tableTree = layui. tableTree; var handleList = function ( ) { let tableData = [ { "pid" : "0" , "title" : "1" , "parentTitle" : null , "sid" : "1111111111" , "children" : null } , { "pid" : "1111111111" , "title" : "1-1" , "parentTitle" : "1" , "sid" : "2" } , { "pid" : "1111111111" , "title" : "1-2" , "parentTitle" : "1" , "sid" : "3" } , { "pid" : "0" , "title" : "2" , "parentTitle" : null , "sid" : "2222222" } , { "pid" : "0" , "title" : "3" , "parentTitle" : null , "sid" : "3333333" } , { "pid" : "0" , "title" : "4" , "parentTitle" : null , "sid" : "44444" } , { "pid" : "0" , "title" : "5" , "parentTitle" : null , "sid" : "5555" } , { "pid" : "5555" , "title" : "5" , "parentTitle" : "5" , "sid" : "6" } ] renderTable ( tableData) } var renderTable = function ( tableData ) { tableTree. render ( { id : 'test' , tree : { iconIndex : 3 , isPidData : true , idName : 'sid' , pidName : 'pid' , openName : 'open' , } , elem : '#test' , skin : 'line' , page : false , limit : 100 , cols : [ [ { field : 'sid' , hide : true } , { type : 'radio' } , { field : 'title' , title : '名称' , align : 'left' , width : 200 } , { field : 'opt' , title : '操作' , templet : function ( item ) { if ( item. sid < 100000 ) { return '<a class="layui-btn layui-btn-normal layui-btn-xs" lay-event="edit"><i class="layui-icon layui-icon-edit"></i> </a>' } return '<a class="layui-btn layui-btn-normal layui-btn-xs" lay-event="edit"><i class="layui-icon layui-icon-edit"></i> </a><a class="layui-btn layui-btn-danger layui-btn-xs" lay-event="del"><i class="layui-icon layui-icon-delete"></i></a>' } } ] ] , data : tableData, done : function ( ) { } , event : true } ) } ; tableTree. on ( 'checkbox(LAY-model-manager)' , function ( obj ) { var data = obj. data; console. log ( '拿到的当前行的数据' , data) } ) ; tableTree. on ( "tool(LAY-model-manager)" , function ( obj ) { var data = obj. data; var layEvent = obj. event; var tr = obj. tr; if ( "del" === layEvent) { console. log ( 删除的数据', data) } else if ( "edit" === layEvent) { console. log ( 操作的数据', data) } } ) ; var Class = { init : function ( ) { handleList ( ) return this ; } , } ; }
) ;
效果图:
插件源码如下:
layui. define ( [ 'laytpl' , 'form' , 'util' ] , function ( exports ) { var $ = layui. jquery; var laytpl = layui. laytpl; var form = layui. form; var util = layui. util; var device = layui. device ( ) ; var MOD_NAME = 'treeTable' ; var _instances = { } ; var defaultOption = { elem : undefined , cols : undefined , url : undefined , method : undefined , where : undefined , contentType : undefined , headers : undefined , parseData : undefined , request : { pidName : 'pid' } , toolbar : undefined , defaultToolbar : undefined , width : undefined , height : undefined , cellMinWidth : 90 , done : undefined , data : undefined , title : undefined , skin : undefined , even : undefined , size : undefined , text : { none : '无数据' } , reqData : undefined , useAdmin : false , tree : { idName : 'id' , pidName : 'pid' , childName : 'children' , haveChildName : 'haveChild' , openName : 'open' , iconIndex : 0 , arrowType : undefined , onlyIconControl : undefined , getIcon : function ( d ) { var haveChild = d[ this . haveChildName] ; if ( haveChild !== undefined ) haveChild = haveChild === true || haveChild === 'true' ; else if ( d[ this . childName] ) haveChild = d[ this . childName] . length > 0 ; if ( haveChild) return '<i class="ew-tree-icon layui-icon layui-icon-layer"></i>' ; else return '<i class="ew-tree-icon layui-icon layui-icon-file"></i>' ; } } } ; var colDefaultOption = { field : undefined , title : undefined , width : undefined , minWidth : undefined , type : 'normal' , fixed : undefined , hide : undefined , unresize : undefined , style : undefined , align : undefined , colspan : undefined , rowspan : undefined , templet : undefined , toolbar : undefined , 'class' : undefined , singleLine : undefined } ; var TreeTable = function ( options ) { _instances[ options. elem. substring ( 1 ) ] = this ; this . reload ( options) ; } ; TreeTable . prototype. initOptions = function ( opt ) { var that = this ; function initCol ( item ) { if ( ! item. INIT_OK ) item = $. extend ( { INIT_OK : true } , colDefaultOption, item) ; if ( item. type === 'space' ) { if ( ! item. width) item. width = 15 ; item. minWidth = item. width; } else if ( item. type === 'numbers' ) { if ( ! item. width) item. width = 40 ; item. minWidth = item. width; if ( ! item. singleLine) item. singleLine = false ; if ( ! item. unresize) item. unresize = true ; if ( ! item. align) item. align = 'center' ; } else if ( item. type === 'checkbox' || item. type === 'radio' ) { if ( ! item. width) item. width = 48 ; item. minWidth = item. width; if ( ! item. singleLine) item. singleLine = false ; if ( ! item. unresize) item. unresize = true ; if ( ! item. align) item. align = 'center' ; } if ( item. toolbar) item. type = 'tool' ; return item; } if ( 'Array' !== isClass ( opt. cols[ 0 ] ) ) opt. cols = [ opt. cols] ; for ( var m = 0 ; m < opt. cols. length; m++ ) { for ( var n = 0 ; n < opt. cols[ m] . length; n++ ) { opt. cols[ m] [ n] . INIT_OK = undefined ; opt. cols[ m] [ n] . key = undefined ; opt. cols[ m] [ n] . colGroup = undefined ; opt. cols[ m] [ n] . HAS_PARENT = undefined ; opt. cols[ m] [ n] . parentKey = undefined ; opt. cols[ m] [ n] . PARENT_COL_INDEX = undefined ; } } var colArrays = [ ] , colIndex = 0 ; for ( var i1 = 0 ; i1 < opt. cols. length; i1++ ) { var item1 = opt. cols[ i1] ; for ( var i2 = 0 ; i2 < item1. length; i2++ ) { var item2 = item1[ i2] ; if ( ! item2) { item1. splice ( i2, 1 ) ; continue ; } item2 = initCol ( item2) ; item2. key = i1 + '-' + i2; var CHILD_COLS = undefined ; if ( item2. colGroup || item2. colspan > 1 ) { item2. colGroup = true ; item2. type = 'group' ; CHILD_COLS = [ ] ; colIndex++ ; var childIndex = 0 ; for ( var i22 = 0 ; i22 < opt. cols[ i1 + 1 ] . length; i22++ ) { var item22 = $. extend ( { INIT_OK : true } , colDefaultOption, opt. cols[ i1 + 1 ] [ i22] ) ; if ( item22. HAS_PARENT || ( childIndex > 1 && childIndex == item2. colspan) ) { opt. cols[ i1 + 1 ] [ i22] = item22; continue ; } item22. HAS_PARENT = true ; item22. parentKey = i1 + '-' + i2; item22. key = ( i1 + 1 ) + '-' + i22; item22. PARENT_COL_INDEX = colIndex; item22 = initCol ( item22) ; CHILD_COLS . push ( item22) ; childIndex = childIndex + parseInt ( item22. colspan > 1 ? item22. colspan : 1 ) ; opt. cols[ i1 + 1 ] [ i22] = item22; } } item2. CHILD_COLS = CHILD_COLS ; if ( ! item2. PARENT_COL_INDEX ) colArrays. push ( item2) ; opt. cols[ i1] [ i2] = item2; } } this . options = $. extend ( true , { } , defaultOption, opt) ; this . options. colArrays = colArrays; if ( this . options. url) { this . options. reqData = function ( data, callback ) { if ( ! that. options. where) that. options. where = { } ; if ( data) that. options. where[ that. options. request. pidName] = data[ that. options. tree. idName] ; ( that. options. useAdmin ? layui. admin : $) . ajax ( { url : that. options. url, data : that. options. contentType && that. options. contentType. indexOf ( 'application/json' ) === 0 ? JSON . stringify ( that. options. where) : that. options. where, headers : that. options. headers, type : that. options. method, dataType : 'json' , contentType : that. options. contentType, success : function ( res ) { if ( that. options. parseData) res = that. options. parseData ( res) ; if ( res. code == 0 ) callback ( res. data) ; else callback ( res. msg || '加载失败' ) ; } , error : function ( xhr ) { callback ( xhr. status + ' - ' + xhr. statusText) ; } } ) ; } ; } else if ( this . options. data && this . options. data. length > 0 && this . options. tree. isPidData) { this . options. data = tt. pidToChildren ( this . options. data, this . options. tree. idName, this . options. tree. pidName, this . options. tree. childName) ; } if ( 'default' === this . options. toolbar) { this . options. toolbar = [ '<div>' , ' <div class="ew-tree-table-tool-item" title="添加" lay-event="add">' , ' <i class="layui-icon layui-icon-add-1"></i>' , ' </div>' , ' <div class="ew-tree-table-tool-item" title="修改" lay-event="update">' , ' <i class="layui-icon layui-icon-edit"></i>' , ' </div>' , ' <div class="ew-tree-table-tool-item" title="删除" lay-event="delete">' , ' <i class="layui-icon layui-icon-delete"></i>' , ' </div>' , '</div>' ] . join ( '' ) ; } if ( this . options. defaultToolbar === undefined ) this . options. defaultToolbar = [ 'filter' , 'exports' , 'print' ] ; if ( typeof this . options. tree. getIcon === 'string' ) { var icon = this . options. tree. getIcon; this . options. tree. getIcon = function ( d ) { if ( icon !== 'ew-tree-icon-style2' ) return icon; var haveChild = d[ this . haveChildName] ; if ( haveChild !== undefined ) haveChild = haveChild === true || haveChild === 'true' ; else if ( d[ this . childName] ) haveChild = d[ this . childName] . length > 0 ; if ( haveChild) return '<i class="ew-tree-icon ew-tree-icon-folder"></i>' ; else return '<i class="ew-tree-icon ew-tree-icon-file"></i>' ; } } } ; TreeTable . prototype. init = function ( ) { var options = this . options; var $elem = $ ( options. elem) ; var tbFilter = options. elem. substring ( 1 ) ; $elem. removeAttr ( 'lay-filter' ) ; if ( $elem. next ( '.ew-tree-table' ) . length === 0 ) { $elem. css ( 'display' , 'none' ) ; $elem. after ( [ '<div class="layui-form ew-tree-table" lay-filter="' , tbFilter, '" style="' , options. style || '' , '">' , ' <div class="ew-tree-table-tool" style="display: none;"></div>' , ' <div class="ew-tree-table-head">' , ' <table class="layui-table"></table>' , ' </div>' , ' <div class="ew-tree-table-box">' , ' <table class="layui-table"></table>' , ' <div class="ew-tree-table-loading">' , ' <i class="layui-icon layui-icon-loading layui-anim layui-anim-rotate layui-anim-loop"></i>' , ' </div>' , ' <div class="ew-tree-table-empty">' , options. text. none || '' , '</div>' , ' </div>' , '</div>' ] . join ( '' ) ) ; } var components = this . getComponents ( ) ; if ( options. skin) components. $table. attr ( 'lay-skin' , options. skin) ; if ( options. size) components. $table. attr ( 'lay-size' , options. size) ; if ( options. even) components. $table. attr ( 'lay-even' , options. even) ; components. $toolbar. empty ( ) ; if ( options. toolbar === false || options. toolbar === undefined ) { components. $toolbar. hide ( ) ; } else { components. $toolbar. show ( ) ; if ( typeof options. toolbar === 'string' ) { laytpl ( $ ( options. toolbar) . html ( ) ) . render ( { } , function ( html ) { components. $toolbar. html ( '<div style="display: inline-block;">' + html + '</div>' ) ; } ) ; } var tbRights = [ '<div class="ew-tree-table-tool-right">' ] ; for ( var i = 0 ; i < options. defaultToolbar. length; i++ ) { var tbItem; if ( 'filter' === options. defaultToolbar[ i] ) { tbItem = { title : '筛选' , layEvent : 'LAYTABLE_COLS' , icon : 'layui-icon-cols' } ; } else if ( 'exports' === options. defaultToolbar[ i] ) { tbItem = { title : '导出' , layEvent : 'LAYTABLE_EXPORT' , icon : 'layui-icon-export' } ; } else if ( 'print' === options. defaultToolbar[ i] ) { tbItem = { title : '打印' , layEvent : 'LAYTABLE_PRINT' , icon : 'layui-icon-print' } ; } else { tbItem = options. defaultToolbar[ i] ; } if ( tbItem) { tbRights. push ( '<div class="ew-tree-table-tool-item"' ) ; tbRights. push ( ' title="' + tbItem. title + '"' ) ; tbRights. push ( ' lay-event="' + tbItem. layEvent + '">' ) ; tbRights. push ( '<i class="layui-icon ' + tbItem. icon + '"></i></div>' ) ; } } components. $toolbar. append ( tbRights. join ( '' ) + '</div>' ) ; } if ( options. width) { components. $view. css ( 'width' , options. width) ; components. $tHeadGroup. css ( 'width' , options. width) ; components. $tBodyGroup. css ( 'width' , options. width) ; } var colgroupHtml = this . resize ( true ) ; var headHtml = '<thead>' + this . renderBodyTh ( ) + '</thead>' ; components. $tBodyGroup. children ( 'style' ) . remove ( ) ; if ( options. height) { components. $tHead. html ( colgroupHtml + headHtml) ; components. $tBody. html ( colgroupHtml + '<tbody></tbody>' ) ; if ( options. height. indexOf ( 'full-' ) === 0 ) { var h = parseFloat ( options. height. substring ( 5 ) ) + components. $toolbar. outerHeight ( ) + components. $tHeadGroup. outerHeight ( ) + 1 ; components. $tBodyGroup. append ( [ '<style>[lay-filter="' , tbFilter, '"] .ew-tree-table-box {' , ' height: ' , getPageHeight ( ) - h, 'px;' , ' height: -moz-calc(100vh - ' , h, 'px);' , ' height: -webkit-calc(100vh - ' , h, 'px);' , ' height: calc(100vh - ' , h, 'px);' , '}</style>' ] . join ( '' ) ) ; components. $tBodyGroup. data ( 'full' , h) ; components. $tBodyGroup. css ( 'height' , '' ) ; } else { components. $tBodyGroup. css ( 'height' , options. height) ; components. $tBodyGroup. data ( 'full' , '' ) ; } components. $tHeadGroup. show ( ) ; } else { components. $tHeadGroup. hide ( ) ; var trH = { lg : 50 , sm : 30 , md : 38 } ; components. $tBodyGroup. append ( [ '<style>[lay-filter="' , tbFilter, '"] .ew-tree-table-box:before {' , ' content: "";' , ' position: absolute;' , ' top: 0; left: 0; right: 0;' , ' height: ' + ( trH[ options. size || 'md' ] * options. cols. length) + 'px;' , ' background-color: #f2f2f2;' , ' border-bottom: 1px solid #e6e6e6;' , '}</style>' ] . join ( '' ) ) ; components. $tBody. html ( colgroupHtml + headHtml + '<tbody></tbody>' ) ; } form. render ( 'checkbox' , tbFilter) ; function patchHide ( $tr ) { var parentKey = $tr. data ( 'parent' ) , pCol; if ( ! parentKey) return ; var $parent = components. $table. children ( 'thead' ) . children ( 'tr' ) . children ( '[data-key="' + parentKey + '"]' ) ; var colspan = $parent. attr ( 'colspan' ) - 1 ; $parent. attr ( 'colspan' , colspan) ; if ( colspan === 0 ) $parent. addClass ( 'layui-hide' ) ; patchHide ( $parent) ; } components. $table. children ( 'thead' ) . children ( 'tr' ) . children ( 'th.layui-hide' ) . each ( function ( ) { patchHide ( $ ( this ) ) ; } ) ; if ( options. reqData) { this . options. data = undefined ; this . renderBodyAsync ( ) ; } else if ( options. data && options. data. length > 0 ) { this . renderBodyData ( options. data) ; } else { components. $loading. hide ( ) ; components. $empty. show ( ) ; } } ; TreeTable . prototype. bindEvents = function ( ) { var that = this ; var options = this . options; var components = this . getComponents ( ) ; var $allBody = components. $table. children ( 'tbody' ) ; var member = function ( ext ) { var $tr = $ ( this ) ; if ( ! $tr. is ( 'tr' ) ) { var $temp = $tr. parent ( 'tr' ) ; if ( $temp. length > 0 ) $tr = $temp; else $tr = $tr. parentsUntil ( 'tr' ) . last ( ) . parent ( ) ; } var data = that. getDataByTr ( $tr) ; var obj = { tr : $tr, data : data, del : function ( ) { var index = $tr. data ( 'index' ) ; var indent = parseInt ( $tr. data ( 'indent' ) ) ; $tr. nextAll ( 'tr' ) . each ( function ( ) { if ( parseInt ( $ ( this ) . data ( 'indent' ) ) <= indent) return false ; $ ( this ) . remove ( ) ; } ) ; var indexLength = ( typeof index === 'number' ? 1 : index. split ( '-' ) . length) ; $tr. nextAll ( 'tr' ) . each ( function ( ) { var $this = $ ( this ) ; if ( parseInt ( $this . data ( 'indent' ) ) < indent) return false ; var _index = $this . data ( 'index' ) . toString ( ) . split ( '-' ) ; _index[ indexLength - 1 ] = parseInt ( _index[ indexLength - 1 ] ) - 1 ; $this . data ( 'index' , _index. join ( '-' ) ) ; } ) ; var $pTr = $tr. prevAll ( 'tr' ) ; that. del ( undefined , index) ; $tr. remove ( ) ; that. renderNumberCol ( ) ; $pTr. each ( function ( ) { var tInd = parseInt ( $ ( this ) . data ( 'indent' ) ) ; if ( tInd >= indent) return true ; that. checkParentCB ( $ ( this ) ) ; indent = tInd; } ) ; that. checkChooseAllCB ( ) ; if ( options. data. length === 0 ) components. $empty. show ( ) ; updateFixedTbHead ( components. $view) ; } , update : function ( fields ) { data = $. extend ( true , data, fields) ; var indent = parseInt ( $tr. data ( 'indent' ) ) ; that. renderBodyTr ( data, indent, undefined , $tr) ; form. render ( null , components. filter) ; that. renderNumberCol ( ) ; $tr. prevAll ( 'tr' ) . each ( function ( ) { var tInd = parseInt ( $ ( this ) . data ( 'indent' ) ) ; if ( tInd >= indent) return true ; that. checkParentCB ( $ ( this ) ) ; indent = tInd; } ) ; that. checkChooseAllCB ( ) ; } } ; return $. extend ( obj, ext) ; } ; $allBody. off ( 'click.fold' ) . on ( 'click.fold' , '.ew-tree-pack' , function ( e ) { layui. stope ( e) ; var $tr = $ ( this ) . parentsUntil ( 'tr' ) . last ( ) . parent ( ) ; if ( $tr. hasClass ( 'ew-tree-table-loading' ) ) return ; var haveChild = $tr. data ( 'have-child' ) ; if ( haveChild !== true && haveChild !== 'true' ) return ; var open = $tr. hasClass ( 'ew-tree-table-open' ) ; var data = that. getDataByTr ( $tr) ; if ( ! open && ! data[ options. tree. childName] ) { that. renderBodyAsync ( data, $tr) ; } else { data[ options. tree. openName] = toggleRow ( $tr) ; } } ) ; $allBody. off ( 'click.tool' ) . on ( 'click.tool' , '*[lay-event]' , function ( e ) { layui. stope ( e) ; var $this = $ ( this ) ; layui. event . call ( this , MOD_NAME , 'tool(' + components. filter + ')' , member . call ( this , { event : $this . attr ( 'lay-event' ) } ) ) ; } ) ; form. on ( 'radio(' + components. radioFilter + ')' , function ( data ) { var d = that. getDataByTr ( $ ( data. elem) . parentsUntil ( 'tr' ) . last ( ) . parent ( ) ) ; that. removeAllChecked ( ) ; d. LAY_CHECKED = true ; d. LAY_INDETERMINATE = false ; layui. event . call ( this , MOD_NAME , 'checkbox(' + components. filter + ')' , { checked : true , data : d, type : 'one' } ) ; } ) ; form. on ( 'checkbox(' + components. checkboxFilter + ')' , function ( data ) { var checked = data. elem. checked; var $cb = $ ( data. elem) ; var $layCb = $cb. next ( '.layui-form-checkbox' ) ; if ( ! checked && $cb. hasClass ( 'ew-form-indeterminate' ) ) { checked = true ; $cb. prop ( 'checked' , checked) ; $layCb. addClass ( 'layui-form-checked' ) ; $cb. removeClass ( 'ew-form-indeterminate' ) ; } var $tr = $cb. parentsUntil ( 'tr' ) . last ( ) . parent ( ) ; var d = that. getDataByTr ( $tr) ; d. LAY_CHECKED = checked; d. LAY_INDETERMINATE = false ; if ( d[ options. tree. childName] && d[ options. tree. childName] . length > 0 ) { that. checkSubCB ( $tr, checked) ; } var indent = parseInt ( $tr. data ( 'indent' ) ) ; $tr. prevAll ( 'tr' ) . each ( function ( ) { var tInd = parseInt ( $ ( this ) . data ( 'indent' ) ) ; if ( tInd < indent) { that. checkParentCB ( $ ( this ) ) ; indent = tInd; } } ) ; that. checkChooseAllCB ( ) ; layui. event . call ( this , MOD_NAME , 'checkbox(' + components. filter + ')' , { checked : checked, data : d, type : 'more' } ) ; } ) ; form. on ( 'checkbox(' + components. chooseAllFilter + ')' , function ( data ) { var checked = data. elem. checked; var $cb = $ ( data. elem) ; var $layCb = $cb. next ( '.layui-form-checkbox' ) ; if ( ! options. data || options. data. length === 0 ) { $cb. prop ( 'checked' , false ) ; $layCb. removeClass ( 'layui-form-checked' ) ; $cb. removeClass ( 'ew-form-indeterminate' ) ; return ; } if ( ! checked && $cb. hasClass ( 'ew-form-indeterminate' ) ) { checked = true ; $cb. prop ( 'checked' , checked) ; $layCb. addClass ( 'layui-form-checked' ) ; $cb. removeClass ( 'ew-form-indeterminate' ) ; } layui. event . call ( this , MOD_NAME , 'checkbox(' + components. filter + ')' , { checked : checked, type : 'all' } ) ; that. checkSubCB ( components. $tBody. children ( 'tbody' ) , checked) ; } ) ; $allBody. off ( 'click.row' ) . on ( 'click.row' , 'tr' , function ( ) { layui. event . call ( this , MOD_NAME , 'row(' + components. filter + ')' , member . call ( this , { } ) ) ; } ) ; $allBody. off ( 'dblclick.rowDouble' ) . on ( 'dblclick.rowDouble' , 'tr' , function ( ) { layui. event . call ( this , MOD_NAME , 'rowDouble(' + components. filter + ')' , member . call ( this , { } ) ) ; } ) ; $allBody. off ( 'click.cell' ) . on ( 'click.cell' , 'td' , function ( e ) { var $td = $ ( this ) ; var type = $td. data ( 'type' ) ; if ( type === 'checkbox' || type === 'radio' ) return layui. stope ( e) ; var edit = $td. data ( 'edit' ) ; var field = $td. data ( 'field' ) ; if ( edit) { layui. stope ( e) ; if ( $allBody. find ( '.ew-tree-table-edit' ) . length > 0 ) return ; var index = $td. data ( 'index' ) ; var indent = $td. find ( '.ew-tree-table-indent' ) . length; var d = that. getDataByTr ( $td. parent ( ) ) ; if ( 'text' === edit || 'number' === edit) { var $input = $ ( '<input type="' + edit + '" class="layui-input ew-tree-table-edit"/>' ) ; $input[ 0 ] . value = d[ field] ; $td. append ( $input) ; $input. focus ( ) ; $input. blur ( function ( ) { var value = $ ( this ) . val ( ) ; if ( value == d[ field] ) return $ ( this ) . remove ( ) ; var rs = layui. event . call ( this , MOD_NAME , 'edit(' + components. filter + ')' , member . call ( this , { value : value, field : field} ) ) ; if ( rs === false ) { $ ( this ) . addClass ( 'layui-form-danger' ) ; $ ( this ) . focus ( ) ; } else { d[ field] = value; var keys = $td. data ( 'key' ) . split ( '-' ) ; that. renderBodyTd ( d, indent, index, $td, options. cols[ keys[ 0 ] ] [ keys[ 1 ] ] ) ; } } ) ; } else { console. error ( '不支持的单元格编辑类型:' + edit) ; } } else { var rs = layui. event . call ( this , MOD_NAME , 'cell(' + components. filter + ')' , member . call ( this , { td : $td, field : field} ) ) ; if ( rs === false ) layui. stope ( e) ; } } ) ; $allBody. off ( 'dblclick.cellDouble' ) . on ( 'dblclick.cellDouble' , 'td' , function ( e ) { var $td = $ ( this ) ; var type = $td. data ( 'type' ) ; if ( type === 'checkbox' || type === 'radio' ) return layui. stope ( e) ; var edit = $td. data ( 'edit' ) ; var field = $td. data ( 'field' ) ; if ( edit) return layui. stope ( e) ; var rs = layui. event . call ( this , MOD_NAME , 'cellDouble(' + components. filter + ')' , member . call ( this , { td : $td, field : field} ) ) ; if ( rs === false ) layui. stope ( e) ; } ) ; components. $toolbar. off ( 'click.toolbar' ) . on ( 'click.toolbar' , '*[lay-event]' , function ( e ) { layui. stope ( e) ; var $this = $ ( this ) ; var event = $this . attr ( 'lay-event' ) ; if ( 'LAYTABLE_COLS' === event) that. toggleCol ( ) ; else if ( 'LAYTABLE_EXPORT' === event) that. exportData ( 'show' ) ; else if ( 'LAYTABLE_PRINT' === event) that. printTable ( ) ; else layui. event . call ( this , MOD_NAME , 'toolbar(' + components. filter + ')' , { event : event, elem : $this } ) ; } ) ; components. $tBodyGroup. on ( 'scroll' , function ( ) { var $this = $ ( this ) ; components. $tHeadGroup. scrollLeft ( $this . scrollLeft ( ) ) ; } ) ; components. $toolbar. off ( 'click.export' ) . on ( 'click.export' , '.layui-table-tool-panel>[data-type]' , function ( ) { var type = $ ( this ) . data ( 'type' ) ; if ( 'csv' === type || 'xls' === type) that. exportData ( type) ; } ) ; components. $toolbar. off ( 'click.panel' ) . on ( 'click.panel' , '.layui-table-tool-panel' , function ( e ) { layui. stope ( e) ; } ) ; form. on ( 'checkbox(' + components. colsToggleFilter + ')' , function ( data ) { that. toggleCol ( data. elem. checked, undefined , data. value) ; } ) ; } ; TreeTable . prototype. getComponents = function ( ) { var $view = $ ( this . options. elem) . next ( '.ew-tree-table' ) ; var filter = $view. attr ( 'lay-filter' ) ; var $tHeadGroup = $view. children ( '.ew-tree-table-head' ) ; var $tBodyGroup = $view. children ( '.ew-tree-table-box' ) ; return { $view : $view, filter : filter, $tHeadGroup : $tHeadGroup, $tBodyGroup : $tBodyGroup, $tHead : $tHeadGroup. children ( '.layui-table' ) , $tBody : $tBodyGroup. children ( '.layui-table' ) , $table : $view. find ( '.layui-table' ) , $toolbar : $view. children ( '.ew-tree-table-tool' ) , $empty : $tBodyGroup. children ( '.ew-tree-table-empty' ) , $loading : $tBodyGroup. children ( '.ew-tree-table-loading' ) , checkboxFilter : 'ew_tb_checkbox_' + filter, radioFilter : 'ew_tb_radio_' + filter, chooseAllFilter : 'ew_tb_choose_all_' + filter, colsToggleFilter : 'ew_tb_toggle_cols' + filter } ; } ; TreeTable . prototype. eachCols = function ( callback, obj ) { if ( ! obj) obj = this . options. colArrays; for ( var i = 0 ; i < obj. length; i++ ) { var item = obj[ i] ; callback && callback ( i, item) ; if ( item. CHILD_COLS ) this . eachCols ( callback, item. CHILD_COLS ) ; } } ; TreeTable . prototype. eachData = function ( callback, data ) { if ( ! data) data = this . options. data; for ( var i = 0 ; i < data. length; i++ ) { var item = data[ i] ; callback && callback ( i, item) ; if ( item[ this . options. tree. childName] ) this . eachData ( callback, item[ this . options. tree. childName] ) ; } } ; TreeTable . prototype. renderBodyAsync = function ( d, $tr ) { var that = this ; var options = this . options; var components = this . getComponents ( ) ; if ( $tr) { $tr. addClass ( 'ew-tree-table-loading' ) ; $tr. find ( '.ew-tree-pack' ) . children ( '.ew-tree-table-arrow' ) . addClass ( 'layui-anim layui-anim-rotate layui-anim-loop' ) ; } else { components. $empty. hide ( ) ; if ( options. data && options. data. length > 0 ) components. $loading. addClass ( 'ew-loading-float' ) ; components. $loading. show ( ) ; } options. reqData ( d, function ( data ) { if ( typeof data !== 'string' && data && data. length > 0 && options. tree. isPidData) { data = tt. pidToChildren ( data, options. tree. idName, options. tree. pidName, options. tree. childName) ; } that. renderBodyData ( data, d, $tr) ; } ) ; } ; TreeTable . prototype. renderBodyData = function ( data, d, $tr ) { var msg; if ( typeof data === 'string' ) { msg = data; data = [ ] ; } var that = this ; var options = this . options; var components = this . getComponents ( ) ; if ( d === undefined ) options. data = data; else d[ options. tree. childName] = data; var indent; if ( $tr) { indent = parseInt ( $tr. data ( 'indent' ) ) + 1 ; d[ options. tree. openName] = true ; } var htmlStr = this . renderBody ( data, indent, d) ; if ( $tr) { $tr. nextAll ( 'tr' ) . each ( function ( ) { if ( parseInt ( $ ( this ) . data ( 'indent' ) ) <= ( indent - 1 ) ) return false ; $ ( this ) . remove ( ) ; } ) ; $tr. after ( htmlStr) . addClass ( 'ew-tree-table-open' ) ; } else { components. $tBody. children ( 'tbody' ) . html ( htmlStr) ; } form. render ( null , components. filter) ; this . renderNumberCol ( ) ; if ( $tr) { this . checkParentCB ( $tr) ; $tr. prevAll ( 'tr' ) . each ( function ( ) { var tInd = parseInt ( $ ( this ) . data ( 'indent' ) ) ; if ( tInd < ( indent - 1 ) ) { that. checkParentCB ( $ ( this ) ) ; indent = tInd + 1 ; } } ) ; $tr. removeClass ( 'ew-tree-table-loading' ) ; var $arrow = $tr. find ( '.ew-tree-pack' ) . children ( '.ew-tree-table-arrow' ) ; $arrow. removeClass ( 'layui-anim layui-anim-rotate layui-anim-loop' ) ; if ( msg) { $tr. removeClass ( 'ew-tree-table-open' ) ; } else if ( data && data. length === 0 ) { d[ options. tree. haveChildName] = false ; $tr. data ( 'have-child' , false ) ; $arrow. addClass ( 'ew-tree-table-arrow-hide' ) ; $arrow. next ( '.ew-tree-icon' ) . after ( options. tree. getIcon ( d) ) . remove ( ) ; } } else { components. $loading. hide ( ) ; components. $loading. removeClass ( 'ew-loading-float' ) ; if ( data && data. length > 0 ) { components. $empty. hide ( ) ; } else { components. $empty. show ( ) ; if ( msg) components. $empty. text ( msg) ; else components. $empty. html ( options. text. none) ; } } this . checkChooseAllCB ( ) ; updateFixedTbHead ( components. $view) ; options. done && options. done ( data) ; } ; TreeTable . prototype. renderBody = function ( data, indent, parent, h ) { var options = this . options; if ( ! indent) indent = 0 ; var html = '' ; if ( ! data || data. length === 0 ) return html; var hide = parent ? ! parent[ options. tree. openName] : undefined ; if ( h) hide = h; for ( var i = 0 ; i < data. length; i++ ) { var d = data[ i] ; d. LAY_INDEX = ( parent ? parent. LAY_INDEX + '-' : '' ) + i; html += this . renderBodyTr ( d, indent, hide) ; html += this . renderBody ( d[ options. tree. childName] , indent + 1 , d, h) ; } return html; } ; TreeTable . prototype. renderBodyTr = function ( d, indent, hide, $tr ) { var that = this ; var options = this . options; if ( ! indent) indent = 0 ; var haveChild = d[ options. tree. haveChildName] ; if ( haveChild === undefined ) haveChild = d[ options. tree. childName] && d[ options. tree. childName] . length > 0 ; if ( $tr) { $tr. data ( 'have-child' , haveChild ? 'true' : 'false' ) ; $tr. data ( 'indent' , indent) ; $tr. removeClass ( 'ew-tree-table-loading' ) ; } var html = '<tr' ; var classNames = '' ; if ( haveChild && d[ options. tree. openName] ) classNames += 'ew-tree-table-open' ; if ( hide) classNames += 'ew-tree-tb-hide' ; html += ( ' class="' + classNames + '"' ) ; if ( haveChild) html += ( ' data-have-child="' + haveChild + '"' ) ; html += ( ' data-index="' + d. LAY_INDEX + '"' ) ; html += ( ' data-indent="' + indent + '">' ) ; var index = 0 ; this . eachCols ( function ( i, col ) { if ( col. colGroup) return ; html += that. renderBodyTd ( d, indent, index, $tr ? $tr. children ( 'td' ) . eq ( index) : undefined , col) ; index++ ; } ) ; html += '</tr>' ; return html; } ; TreeTable . prototype. renderBodyTd = function ( d, indent, index, $td, col ) { if ( ! col|| col. colGroup) return '' ; var options = this . options; var components = this . getComponents ( ) ; if ( ! indent) indent = 0 ; var content = '' , cell = '' , icon = '' ; if ( col. type === 'numbers' ) { content = '<span class="ew-tree-table-numbers"></span>' ; } else if ( col. type === 'checkbox' ) { content = [ '<input type="checkbox"' , d. LAY_CHECKED ? ' checked="checked"' : '' , ' lay-filter="' , components. checkboxFilter, '"' , ' lay-skin="primary" class="ew-tree-table-checkbox' , d. LAY_INDETERMINATE ? ' ew-form-indeterminate' : '' , '" />' ] . join ( '' ) ; } else if ( col. type === 'radio' ) { content = [ '<input type="radio"' , d. LAY_CHECKED ? ' checked="checked"' : '' , ' lay-filter="' , components. radioFilter, '"' , ' name="' , components. radioFilter, '"' , ' class="ew-tree-table-radio" />' ] . join ( '' ) ; } else if ( col. templet) { if ( typeof col. templet === 'function' ) { content = col. templet ( d) ; } else if ( typeof col. templet === 'string' ) { laytpl ( $ ( col. templet) . html ( ) ) . render ( d, function ( html ) { content = html; } ) ; } } else if ( col. toolbar) { if ( typeof col. toolbar === 'function' ) { content = col. toolbar ( d) ; } else if ( typeof col. toolbar === 'string' ) { laytpl ( $ ( col. toolbar) . html ( ) ) . render ( d, function ( html ) { content = html; } ) ; } } else if ( col. field && d[ col. field] !== undefined && d[ col. field] !== null ) { content = util. escape ( d[ col. field] === 0 ? '0' : d[ col. field] ) ; } if ( index === options. tree. iconIndex) { for ( var i = 0 ; i < indent; i++ ) icon += '<span class="ew-tree-table-indent"></span>' ; icon += '<span class="ew-tree-pack">' ; var haveChild = d[ options. tree. haveChildName] ; if ( haveChild === undefined ) haveChild = d[ options. tree. childName] && d[ options. tree. childName] . length > 0 ; icon += ( '<i class="ew-tree-table-arrow layui-icon' + ( haveChild ? '' : ' ew-tree-table-arrow-hide' ) ) ; icon += ( ' ' + ( options. tree. arrowType || '' ) + '"></i>' ) ; icon += options. tree. getIcon ( d) ; content = '<span>' + content + '</span>' ; if ( options. tree. onlyIconControl) content = icon + '</span>' + content; else content = icon + content + '</span>' ; } cell = [ '<div class="ew-tree-table-cell' , col. singleLine === undefined || col. singleLine ? ' single-line' : '' , '"' , col. align ? ' align="' + col. align + '"' : '' , '>' , ' <div class="ew-tree-table-cell-content">' , content, '</div>' , ' <i class="layui-icon layui-icon-close ew-tree-tips-c"></i>' , ' <div class="layui-table-grid-down" style="display: none;"><i class="layui-icon layui-icon-down"></i></div>' , '</div>' ] . join ( '' ) ; if ( $td) $td. html ( cell) ; var html = '<td' ; if ( col. field) html += ( ' data-field="' + col. field + '"' ) ; if ( col. edit) html += ( ' data-edit="' + col. edit + '"' ) ; if ( col. type) html += ( ' data-type="' + col. type + '"' ) ; if ( col. key) html += ( ' data-key="' + col. key + '"' ) ; if ( col. style) html += ( ' style="' + col. style + '"' ) ; if ( col[ 'class' ] ) html += ( ' class="' + col[ 'class' ] + ( col. hide ? ' layui-hide' : '' ) + '"' ) ; else if ( col. hide) html += ( ' class="layui-hide"' ) ; html += ( '>' + cell + '</td>' ) ; return html; } ; TreeTable . prototype. renderBodyTh = function ( ) { var options = this . options; var components = this . getComponents ( ) ; var html = [ ] ; $. each ( options. cols, function ( i1, item1 ) { html. push ( '<tr>' ) ; $. each ( item1, function ( i2, item2 ) { html. push ( '<th' ) ; if ( item2. colspan) html. push ( ' colspan="' + item2. colspan + '"' ) ; if ( item2. rowspan) html. push ( ' rowspan="' + item2. rowspan + '"' ) ; if ( item2. type) html. push ( ' data-type="' + item2. type + '"' ) ; if ( item2. key) html. push ( ' data-key="' + item2. key + '"' ) ; if ( item2. parentKey) html. push ( ' data-parent="' + item2. parentKey + '"' ) ; if ( item2. hide) html. push ( ' class="layui-hide"' ) ; html. push ( '>' ) ; html. push ( '<div class="ew-tree-table-cell' + ( item2. singleLine === undefined || item2. singleLine ? ' single-line' : '' ) + '"' ) ; if ( item2. thAlign || item2. align) html. push ( ' align="' + ( item2. thAlign || item2. align) + '"' ) ; html. push ( '>' ) ; html. push ( '<div class="ew-tree-table-cell-content">' ) ; var ca = '<input type="checkbox" lay-filter="' + components. chooseAllFilter + '" lay-skin="primary" class="ew-tree-table-checkbox"/>' ; if ( item2. type === 'checkbox' ) html. push ( ca) ; else html. push ( item2. title || '' ) ; html. push ( '</div><i class="layui-icon layui-icon-close ew-tree-tips-c"></i>' ) ; html. push ( '<div class="layui-table-grid-down" style="display: none;"><i class="layui-icon layui-icon-down"></i></div></div>' ) ; if ( ! item2. colGroup && ! item2. unresize) html. push ( '<span class="ew-tb-resize"></span>' ) ; html. push ( '</th>' ) ; } ) ; html. push ( '</tr>' ) ; } ) ; return html. join ( '' ) ; } ; TreeTable . prototype. resize = function ( returnColgroup ) { var options = this . options; var components = this . getComponents ( ) ; var minWidth = 1 , width = 1 , needSetWidth = true , mwPercent = 0 ; this . eachCols ( function ( i, item ) { if ( item. colGroup || item. hide) return ; if ( item. width) { width += ( item. width + 1 ) ; if ( item. minWidth) { if ( item. width < item. minWidth) item. width = item. minWidth; } else if ( item. width < options. cellMinWidth) item. width = options. cellMinWidth; } else needSetWidth = false ; if ( item. width) minWidth += ( item. width + 1 ) ; else if ( item. minWidth) { minWidth += ( item. minWidth + 1 ) ; mwPercent += item. minWidth; } else { minWidth += ( options. cellMinWidth + 1 ) ; mwPercent += options. cellMinWidth; } } ) ; if ( minWidth) { components. $tHead. css ( 'min-width' , minWidth) ; components. $tBody. css ( 'min-width' , minWidth) ; } else { components. $tHead. css ( 'min-width' , 'auto' ) ; components. $tBody. css ( 'min-width' , 'auto' ) ; } if ( needSetWidth) { components. $tHead. css ( 'width' , width) ; components. $tBody. css ( 'width' , width) ; } else { components. $tHead. css ( 'width' , '100%' ) ; components. $tBody. css ( 'width' , '100%' ) ; } var colgroupHtml = [ ] ; this . eachCols ( function ( i, item ) { if ( item. colGroup || item. hide) return ; colgroupHtml. push ( '<col' ) ; if ( item. width) colgroupHtml. push ( ' width="' + item. width + '"' ) ; else if ( item. minWidth) colgroupHtml. push ( ' width="' + ( item. minWidth / mwPercent * 100 ) . toFixed ( 2 ) + '%"' ) ; else colgroupHtml. push ( ' width="' + ( options. cellMinWidth / mwPercent * 100 ) . toFixed ( 2 ) + '%"' ) ; if ( item. type) colgroupHtml. push ( ' data-type="' + item. type + '"' ) ; if ( item. key) colgroupHtml. push ( ' data-key="' + item. key + '"' ) ; colgroupHtml. push ( '/>' ) ; } ) ; colgroupHtml = colgroupHtml. join ( '' ) ; if ( returnColgroup) return '<colgroup>' + colgroupHtml + '</colgroup>' ; components. $table. children ( 'colgroup' ) . html ( colgroupHtml) ; } ; TreeTable . prototype. getDataByTr = function ( $tr ) { var data, index; if ( typeof $tr !== 'string' && typeof $tr !== 'number' ) { if ( $tr) index = $tr. data ( 'index' ) ; } else index = $tr; if ( index === undefined ) return ; if ( typeof index === 'number' ) index = [ index] ; else index = index. split ( '-' ) ; for ( var i = 0 ; i < index. length; i++ ) { if ( data) data = data[ this . options. tree. childName] [ index[ i] ] ; else data = this . options. data[ index[ i] ] ; } return data; } ; TreeTable . prototype. checkSubCB = function ( $tr, checked ) { var that = this ; var components = this . getComponents ( ) ; var indent = - 1 , $trList; if ( $tr. is ( 'tbody' ) ) { $trList = $tr. children ( 'tr' ) ; } else { indent = parseInt ( $tr. data ( 'indent' ) ) ; $trList = $tr. nextAll ( 'tr' ) ; } $trList. each ( function ( ) { if ( parseInt ( $ ( this ) . data ( 'indent' ) ) <= indent) return false ; var $cb = $ ( this ) . children ( 'td' ) . find ( 'input[lay-filter="' + components. checkboxFilter + '"]' ) ; $cb. prop ( 'checked' , checked) ; $cb. removeClass ( 'ew-form-indeterminate' ) ; if ( checked) $cb. next ( '.layui-form-checkbox' ) . addClass ( 'layui-form-checked' ) ; else $cb. next ( '.layui-form-checkbox' ) . removeClass ( 'layui-form-checked' ) ; var d = that. getDataByTr ( $ ( this ) ) ; d. LAY_CHECKED = checked; d. LAY_INDETERMINATE = false ; } ) ; } ; TreeTable . prototype. checkParentCB = function ( $tr ) { var options = this . options; var components = this . getComponents ( ) ; var d = this . getDataByTr ( $tr) ; var ckNum = 0 , unCkNum = 0 ; if ( d[ options. tree. childName] ) { function checkNum ( data ) { for ( var i = 0 ; i < data. length; i++ ) { if ( data[ i] . LAY_CHECKED ) ckNum++ ; else unCkNum++ ; if ( data[ i] [ options. tree. childName] ) checkNum ( data[ i] [ options. tree. childName] ) ; } } checkNum ( d[ options. tree. childName] ) ; } var $cb = $tr. children ( 'td' ) . find ( 'input[lay-filter="' + components. checkboxFilter + '"]' ) ; if ( ckNum > 0 && unCkNum === 0 ) { $cb. prop ( 'checked' , true ) ; $cb. removeClass ( 'ew-form-indeterminate' ) ; $cb. next ( '.layui-form-checkbox' ) . addClass ( 'layui-form-checked' ) ; d. LAY_CHECKED = true ; d. LAY_INDETERMINATE = false ; } else if ( ckNum === 0 && unCkNum > 0 ) { $cb. prop ( 'checked' , false ) ; $cb. removeClass ( 'ew-form-indeterminate' ) ; $cb. next ( '.layui-form-checkbox' ) . removeClass ( 'layui-form-checked' ) ; d. LAY_CHECKED = false ; d. LAY_INDETERMINATE = false ; } else if ( ckNum > 0 && unCkNum > 0 ) { $cb. prop ( 'checked' , true ) ; $cb. data ( 'indeterminate' , 'true' ) ; $cb. addClass ( 'ew-form-indeterminate' ) ; $cb. next ( '.layui-form-checkbox' ) . addClass ( 'layui-form-checked' ) ; d. LAY_CHECKED = true ; d. LAY_INDETERMINATE = true ; } } ; TreeTable . prototype. checkChooseAllCB = function ( ) { var options = this . options; var components = this . getComponents ( ) ; var ckNum = 0 , unCkNum = 0 ; function checkNum ( data ) { for ( var i = 0 ; i < data. length; i++ ) { if ( data[ i] . LAY_CHECKED ) ckNum++ ; else unCkNum++ ; if ( data[ i] [ options. tree. childName] ) checkNum ( data[ i] [ options. tree. childName] ) ; } } checkNum ( options. data) ; var $cb = components. $view. find ( 'input[lay-filter="' + components. chooseAllFilter + '"]' ) ; if ( ckNum > 0 && unCkNum === 0 ) { $cb. prop ( 'checked' , true ) ; $cb. removeClass ( 'ew-form-indeterminate' ) ; $cb. next ( '.layui-form-checkbox' ) . addClass ( 'layui-form-checked' ) ; } else if ( ( ckNum === 0 && unCkNum > 0 ) || ( ckNum === 0 && unCkNum === 0 ) ) { $cb. prop ( 'checked' , false ) ; $cb. removeClass ( 'ew-form-indeterminate' ) ; $cb. next ( '.layui-form-checkbox' ) . removeClass ( 'layui-form-checked' ) ; } else if ( ckNum > 0 && unCkNum > 0 ) { $cb. prop ( 'checked' , true ) ; $cb. addClass ( 'ew-form-indeterminate' ) ; $cb. next ( '.layui-form-checkbox' ) . addClass ( 'layui-form-checked' ) ; } } ; TreeTable . prototype. renderNumberCol = function ( ) { this . getComponents ( ) . $tBody. children ( 'tbody' ) . children ( 'tr' ) . each ( function ( i ) { $ ( this ) . children ( 'td' ) . find ( '.ew-tree-table-numbers' ) . text ( i + 1 ) ; } ) ; } ; TreeTable . prototype. getIndexById = function ( id ) { var options = this . options; function each ( data, pi ) { for ( var i = 0 ; i < data. length; i++ ) { if ( data[ i] [ options. tree. idName] === id) return pi !== undefined ? pi + '-' + i : i; if ( data[ i] [ options. tree. childName] ) { var res = each ( data[ i] [ options. tree. childName] , pi !== undefined ? pi + '-' + i : i) ; if ( res) return res; } } } return each ( options. data) ; } ; TreeTable . prototype. expand = function ( id, cascade ) { var components = this . getComponents ( ) ; var $tr = components. $table. children ( 'tbody' ) . children ( 'tr[data-index="' + this . getIndexById ( id) + '"]' ) ; if ( ! $tr. hasClass ( 'ew-tree-table-open' ) ) $tr. children ( 'td' ) . find ( '.ew-tree-pack' ) . trigger ( 'click' ) ; if ( cascade === false ) return ; var indent = parseInt ( $tr. data ( 'indent' ) ) ; $tr. prevAll ( 'tr' ) . each ( function ( ) { var tInd = parseInt ( $ ( this ) . data ( 'indent' ) ) ; if ( tInd < indent) { if ( ! $ ( this ) . hasClass ( 'ew-tree-table-open' ) ) { $ ( this ) . children ( 'td' ) . find ( '.ew-tree-pack' ) . trigger ( 'click' ) ; } indent = tInd; } } ) ; } ; TreeTable . prototype. fold = function ( id ) { var components = this . getComponents ( ) ; var $tr = components. $table. children ( 'tbody' ) . children ( 'tr[data-index="' + this . getIndexById ( id) + '"]' ) ; if ( $tr. hasClass ( 'ew-tree-table-open' ) ) $tr. children ( 'td' ) . find ( '.ew-tree-pack' ) . trigger ( 'click' ) ; } ; TreeTable . prototype. expandAll = function ( ) { this . getComponents ( ) . $table. children ( 'tbody' ) . children ( 'tr' ) . each ( function ( ) { if ( ! $ ( this ) . hasClass ( 'ew-tree-table-open' ) ) $ ( this ) . children ( 'td' ) . find ( '.ew-tree-pack' ) . trigger ( 'click' ) ; } ) ; } ; TreeTable . prototype. foldAll = function ( ) { this . getComponents ( ) . $table. children ( 'tbody' ) . children ( 'tr' ) . each ( function ( ) { if ( $ ( this ) . hasClass ( 'ew-tree-table-open' ) ) $ ( this ) . children ( 'td' ) . find ( '.ew-tree-pack' ) . trigger ( 'click' ) ; } ) ; } ; TreeTable . prototype. getData = function ( ) { return this . options. data; } ; TreeTable . prototype. reload = function ( opt ) { this . initOptions ( this . options ? $. extend ( true , this . options, opt) : opt) ; this . init ( ) ; this . bindEvents ( ) ; } ; TreeTable . prototype. checkStatus = function ( needIndeterminate ) { if ( needIndeterminate === undefined ) needIndeterminate = true ; var list = [ ] ; this . eachData ( function ( i, item ) { if ( ( needIndeterminate || ! item. LAY_INDETERMINATE ) && item. LAY_CHECKED ) list. push ( $. extend ( { isIndeterminate : item. LAY_INDETERMINATE } , item) ) ; } ) ; return list; } ; TreeTable . prototype. setChecked = function ( ids ) { var that = this ; var components = this . getComponents ( ) ; var $radio = components. $table. find ( 'input[lay-filter="' + components. radioFilter + '"]' ) ; if ( $radio. length > 0 ) { $radio. each ( function ( ) { var d = that. getDataByTr ( $ ( this ) . parentsUntil ( 'tr' ) . parent ( ) ) ; if ( d && ids[ ids. length - 1 ] == d[ that. options. tree. idName] ) { $ ( this ) . next ( '.layui-form-radio' ) . trigger ( 'click' ) ; return false ; } } ) ; } else { components. $table. find ( 'input[lay-filter="' + components. checkboxFilter + '"]' ) . each ( function ( ) { var $cb = $ ( this ) ; var $layCb = $cb. next ( '.layui-form-checkbox' ) ; var checked = $cb. prop ( 'checked' ) ; var indeterminate = $cb. hasClass ( 'ew-form-indeterminate' ) ; var d = that. getDataByTr ( $cb. parentsUntil ( 'tr' ) . parent ( ) ) ; for ( var i = 0 ; i < ids. length; i++ ) { if ( d && ids[ i] == d[ that. options. tree. idName] ) { if ( d[ that. options. tree. childName] && d[ that. options. tree. childName] . length > 0 ) continue ; if ( ! checked || indeterminate) $layCb. trigger ( 'click' ) ; } } } ) ; } } ; TreeTable . prototype. removeAllChecked = function ( ) { this . checkSubCB ( this . getComponents ( ) . $table. children ( 'tbody' ) , false ) ; } ; TreeTable . prototype. exportData = function ( type ) { var components = this . getComponents ( ) ; if ( 'show' === type) { components. $toolbar. find ( '.layui-table-tool-panel' ) . remove ( ) ; components. $toolbar. find ( '[lay-event="LAYTABLE_EXPORT"]' ) . append ( [ '<ul class="layui-table-tool-panel">' , ' <li data-type="csv">导出到 Csv 文件</li>' , ' <li data-type="xls">导出到 Excel 文件</li>' , '</ul>' ] . join ( '' ) ) ; } else { if ( device. ie) return layer. msg ( '不支持ie导出' ) ; if ( ! type) type = 'xls' ; var head = [ ] , body = [ ] ; this . eachCols ( function ( i, item ) { if ( item. type !== 'normal' || item. hide) return ; head. push ( item. title || '' ) ; } ) ; components. $tBody. children ( 'tbody' ) . children ( 'tr' ) . each ( function ( ) { var items = [ ] ; $ ( this ) . children ( 'td' ) . each ( function ( ) { var $this = $ ( this ) ; if ( $this . data ( 'type' ) !== 'normal' || $this . hasClass ( 'layui-hide' ) ) return true ; items. push ( $this . text ( ) . trim ( ) . replace ( / , / g , ',' ) ) ; } ) ; body. push ( items. join ( ',' ) ) ; } ) ; var alink = document. createElement ( 'a' ) ; var content = encodeURIComponent ( head. join ( ',' ) + '\r\n' + body. join ( '\r\n' ) ) ; var contentType = ( { csv : 'text/csv' , xls : 'application/vnd.ms-excel' } ) [ type] ; alink. href = 'data:' + contentType + ';charset=utf-8,\ufeff' + content; alink. download = ( this . options. title || 'table' ) + '.' + type; document. body. appendChild ( alink) ; alink. click ( ) ; document. body. removeChild ( alink) ; } } ; TreeTable . prototype. printTable = function ( ) { var components = this . getComponents ( ) ; var head = components. $tHead. children ( 'thead' ) . html ( ) ; if ( ! head) head = components. $tBody. children ( 'thead' ) . html ( ) ; var body = components. $tBody. children ( 'tbody' ) . html ( ) ; var colgroup = components. $tBody. children ( 'colgroup' ) . html ( ) ; var $html = $ ( [ '<table class="ew-tree-table-print">' , ' <colgroup>' , colgroup, '</colgroup>' , ' <thead>' , head, '</thead>' , ' <tbody>' , body, '</tbody>' , '</table>' ] . join ( '' ) ) ; $html. find ( 'col[data-type="checkbox"],col[data-type="radio"],col[data-type="tool"]' ) . remove ( ) ; $html. find ( 'td[data-type="checkbox"],td[data-type="radio"],td[data-type="tool"],.layui-hide' ) . remove ( ) ; function hideCol ( $temp ) { var parentKey = $temp. data ( 'parent' ) , pCol; if ( ! parentKey) return ; var $parent = $html. children ( 'thead' ) . children ( 'tr' ) . children ( '[data-key="' + parentKey + '"]' ) ; var colspan = parseInt ( $parent. attr ( 'colspan' ) ) - 1 ; $parent. attr ( 'colspan' , colspan) ; if ( colspan === 0 ) $parent. remove ( ) ; hideCol ( $parent) ; } $html. find ( 'th[data-type="checkbox"],th[data-type="radio"],th[data-type="tool"]' ) . each ( function ( ) { hideCol ( $ ( this ) ) ; } ) . remove ( ) ; var style = [ '<style>' , ' /* 打印表格样式 */' , ' .ew-tree-table-print {' , ' border: none;' , ' border-collapse: collapse;' , ' width: 100%;' , ' table-layout: fixed;' , ' }' , ' .ew-tree-table-print td, .ew-tree-table-print th {' , ' color: #555;' , ' font-size: 14px;' , ' padding: 9px 15px;' , ' word-break: break-all;' , ' border: 1px solid #888;' , ' text-align: left;' , ' }' , ' .ew-tree-table-print .ew-tree-table-cell {' , ' min-height: 20px;' , ' }' , ' /* 序号列样式 */' , ' .ew-tree-table-print td[data-type="numbers"], .ew-tree-table-print th[data-type="numbers"] {' , ' padding-left: 0;' , ' padding-right: 0;' , ' }' , ' /* 单/复选框列样式 */' , ' .ew-tree-table-print td[data-type="tool"], .ew-tree-table-print th[data-type="tool"], ' , ' .ew-tree-table-print td[data-type="checkbox"], .ew-tree-table-print th[data-type="checkbox"], ' , ' .ew-tree-table-print td[data-type="radio"], .ew-tree-table-print th[data-type="radio"] {' , ' border: none;' , ' }' , ' .ew-tree-table-print td.layui-hide + td, .ew-tree-table-print th.layui-hide + th, ' , ' .ew-tree-table-print td[data-type="tool"] + td, .ew-tree-table-print th[data-type="tool"] + th, ' , ' .ew-tree-table-print td[data-type="checkbox"] + td, .ew-tree-table-print th[data-type="checkbox"] + th, ' , ' .ew-tree-table-print td[data-type="radio"] + td, .ew-tree-table-print th[data-type="radio"] + th {' , ' border-left: none;' , ' }' , ' /* 不显示的元素 */' , ' .layui-hide, ' , ' .ew-tree-table-print td[data-type="tool"] *, .ew-tree-table-print th[data-type="tool"] *, ' , ' .ew-tree-table-print td[data-type="checkbox"] *, .ew-tree-table-print th[data-type="checkbox"] *, ' , ' .ew-tree-table-print td[data-type="radio"] *, .ew-tree-table-print th[data-type="radio"] *, ' , ' .layui-table-grid-down, .ew-tree-tips-c, .ew-tree-icon, .ew-tree-table-arrow.ew-tree-table-arrow-hide {' , ' display: none;' , ' }' , ' /* tree缩进 */' , ' .ew-tree-table-indent {' , ' padding-left: 13px;' , ' }' , ' /* 箭头 */' , ' .ew-tree-table-arrow {' , ' position: relative;' , ' padding-left: 13px;' , ' }' , ' .ew-tree-table-arrow:before {' , ' content: "";' , ' border: 5px solid transparent;' , ' border-top-color: #666;' , ' position: absolute;' , ' left: 0;' , ' top: 6px;' , ' }' , '</style>' ] . join ( '' ) ; var pWindow = window. open ( '' , '_blank' ) ; pWindow. focus ( ) ; var pDocument = pWindow. document; pDocument. open ( ) ; pDocument. write ( $html[ 0 ] . outerHTML + style) ; pDocument. close ( ) ; pWindow. print ( ) ; pWindow. close ( ) ; } ; TreeTable . prototype. toggleCol = function ( show, field, key ) { var components = this . getComponents ( ) ; if ( show === undefined ) { components. $toolbar. find ( '.layui-table-tool-panel' ) . remove ( ) ; var cols = [ '<ul class="layui-table-tool-panel">' ] ; this . eachCols ( function ( i, item ) { if ( item. type !== 'normal' ) return ; cols. push ( '<li><input type="checkbox" lay-skin="primary"' ) ; cols. push ( ' lay-filter="' + components. colsToggleFilter + '"' ) ; cols. push ( ' value="' + item. key + '" title="' + util. escape ( item. title || '' ) + '"' ) ; cols. push ( ( item. hide ? '' : ' checked' ) + '></li>' ) ; } ) ; components. $toolbar. find ( '[lay-event="LAYTABLE_COLS"]' ) . append ( cols. join ( '' ) + '</ul>' ) ; form. render ( 'checkbox' , components. filter) ; } else { if ( key) { var $td = components. $table. children ( 'tbody' ) . children ( 'tr' ) . children ( '[data-key="' + key + '"]' ) ; var $th = components. $table. children ( 'thead' ) . children ( 'tr' ) . children ( '[data-key="' + key + '"]' ) ; if ( show) { $td. removeClass ( 'layui-hide' ) ; $th. removeClass ( 'layui-hide' ) ; } else { $td. addClass ( 'layui-hide' ) ; $th. addClass ( 'layui-hide' ) ; } var ks = key. split ( '-' ) ; var col = this . options. cols[ ks[ 0 ] ] [ ks[ 1 ] ] ; col. hide = ! show; function changeParent ( $temp ) { var parentKey = $temp. data ( 'parent' ) , pCol; if ( ! parentKey) return ; var $parent = components. $table. children ( 'thead' ) . children ( 'tr' ) . children ( '[data-key="' + parentKey + '"]' ) ; var colspan = $parent. attr ( 'colspan' ) ; show ? colspan++ : colspan-- ; $parent. attr ( 'colspan' , colspan) ; if ( colspan === 0 ) $parent. addClass ( 'layui-hide' ) ; else $parent. removeClass ( 'layui-hide' ) ; changeParent ( $parent) ; } changeParent ( $th) ; this . eachCols ( function ( i, item ) { if ( item. key === key) item. hide = col. hide; } ) ; this . resize ( ) ; } } } ; TreeTable . prototype. filterData = function ( ids ) { var components = this . getComponents ( ) ; components. $loading. show ( ) ; if ( this . options. data. length > 0 ) components. $loading. addClass ( 'ew-loading-float' ) ; var $trList = components. $table. children ( 'tbody' ) . children ( 'tr' ) ; var indexList = [ ] ; if ( typeof ids === 'string' ) { $trList. each ( function ( ) { var index = $ ( this ) . data ( 'index' ) ; $ ( this ) . children ( 'td' ) . each ( function ( ) { if ( $ ( this ) . text ( ) . indexOf ( ids) !== - 1 ) { indexList. push ( index) ; return false ; } } ) ; } ) ; } else { for ( var i = 0 ; i < ids. length; i++ ) { indexList. push ( this . getIndexById ( ids[ i] ) ) ; } } $trList. addClass ( 'ew-tree-table-filter-hide' ) ; for ( var j = 0 ; j < indexList. length; j++ ) { var $tr = $trList. filter ( '[data-index="' + indexList[ j] + '"]' ) ; $tr. removeClass ( 'ew-tree-table-filter-hide' ) ; var indent = parseInt ( $tr. data ( 'indent' ) ) ; $tr. nextAll ( 'tr' ) . each ( function ( ) { if ( parseInt ( $ ( this ) . data ( 'indent' ) ) <= indent) return false ; $ ( this ) . removeClass ( 'ew-tree-table-filter-hide' ) ; } ) ; if ( $tr. hasClass ( 'ew-tree-table-open' ) ) toggleRow ( $tr) ; $tr. prevAll ( 'tr' ) . each ( function ( ) { var tInd = parseInt ( $ ( this ) . data ( 'indent' ) ) ; if ( tInd < indent) { $ ( this ) . removeClass ( 'ew-tree-table-filter-hide' ) ; if ( ! $ ( this ) . hasClass ( 'ew-tree-table-open' ) ) toggleRow ( $ ( this ) ) ; indent = tInd; } } ) ; } components. $loading. hide ( ) ; components. $loading. removeClass ( 'ew-loading-float' ) ; if ( indexList. length === 0 ) components. $empty. show ( ) ; updateFixedTbHead ( components. $view) ; } ; TreeTable . prototype. clearFilter = function ( ) { var components = this . getComponents ( ) ; components. $table. children ( 'tbody' ) . children ( 'tr' ) . removeClass ( 'ew-tree-table-filter-hide' ) ; if ( this . options. data. length > 0 ) components. $empty. hide ( ) ; updateFixedTbHead ( components. $view) ; } ; TreeTable . prototype. refresh = function ( id, data ) { if ( isClass ( id) === 'Array' ) { data = id; id = undefined ; } var components = this . getComponents ( ) ; var d, $tr; if ( id !== undefined ) { $tr = components. $table. children ( 'tbody' ) . children ( 'tr[data-index="' + this . getIndexById ( id) + '"]' ) ; d = this . getDataByTr ( $tr) ; } if ( data) { if ( data. length > 0 ) components. $loading. addClass ( 'ew-loading-float' ) ; components. $loading. show ( ) ; if ( data. length > 0 && this . options. tree. isPidData) { this . renderBodyData ( tt. pidToChildren ( data, this . options. tree. idName, this . options. tree. pidName, this . options. tree. childName) , d, $tr) ; } else { this . renderBodyData ( data, d, $tr) ; } } else { this . renderBodyAsync ( d, $tr) ; } } ; TreeTable . prototype. del = function ( id, index ) { if ( index === undefined ) index = this . getIndexById ( id) ; var indexList = ( typeof index === 'number' ? [ index] : index. split ( '-' ) ) ; var d = this . options. data; if ( indexList. length > 1 ) { for ( var i = 0 ; i < indexList. length - 1 ; i++ ) { d = d[ parseInt ( indexList[ i] ) ] [ this . options. tree. childName] ; } } d. splice ( indexList[ indexList. length - 1 ] , 1 ) ; } ; TreeTable . prototype. update = function ( id, fields ) { $. extend ( true , this . getDataByTr ( this . getIndexById ( id) ) , fields) ; } ; function toggleRow ( $tr ) { var indent = parseInt ( $tr. data ( 'indent' ) ) ; var open = $tr. hasClass ( 'ew-tree-table-open' ) ; if ( open) { $tr. removeClass ( 'ew-tree-table-open' ) ; $tr. nextAll ( 'tr' ) . each ( function ( ) { if ( parseInt ( $ ( this ) . data ( 'indent' ) ) <= indent) return false ; $ ( this ) . addClass ( 'ew-tree-tb-hide' ) ; } ) ; } else { $tr. addClass ( 'ew-tree-table-open' ) ; var hideInd; $tr. nextAll ( 'tr' ) . each ( function ( ) { var ind = parseInt ( $ ( this ) . data ( 'indent' ) ) ; if ( ind <= indent) return false ; if ( hideInd !== undefined && ind > hideInd) return true ; $ ( this ) . removeClass ( 'ew-tree-tb-hide' ) ; if ( ! $ ( this ) . hasClass ( 'ew-tree-table-open' ) ) hideInd = parseInt ( $ ( this ) . data ( 'indent' ) ) ; else hideInd = undefined ; } ) ; } updateFixedTbHead ( $tr. parentsUntil ( '.ew-tree-table' ) . last ( ) . parent ( ) ) ; return open; } function updateFixedTbHead ( $view ) { var $headBox = $view. children ( '.ew-tree-table-head' ) ; var $tbBox = $view. children ( '.ew-tree-table-box' ) ; var sWidth = $tbBox. width ( ) - $tbBox. prop ( 'clientWidth' ) ; $headBox. css ( 'border-right' , ( sWidth > 0 ? sWidth : 0 ) + 'px solid #f2f2f2' ) ; } $ ( window) . resize ( function ( ) { $ ( '.ew-tree-table' ) . each ( function ( ) { updateFixedTbHead ( $ ( this ) ) ; var $tbBox = $ ( this ) . children ( '.ew-tree-table-box' ) ; var full = $tbBox. data ( 'full' ) ; if ( full && device. ie && device. ie < 10 ) { $tbBox. css ( 'height' , getPageHeight ( ) - full) ; } } ) ; } ) ; $ ( document) . on ( 'mouseenter' , '.ew-tree-table-cell.single-line' , function ( ) { var $content = $ ( this ) . children ( '.ew-tree-table-cell-content' ) ; if ( $content. prop ( 'scrollWidth' ) > $content. outerWidth ( ) ) $ ( this ) . children ( '.layui-table-grid-down' ) . show ( ) ; } ) . on ( 'mouseleave' , '.ew-tree-table-cell.single-line' , function ( ) { $ ( this ) . children ( '.layui-table-grid-down' ) . hide ( ) ; } ) ; $ ( document) . on ( 'click' , '.ew-tree-table-cell>.layui-table-grid-down' , function ( e ) { e. stopPropagation ( ) ; hideAllTdTips ( ) ; var $cell = $ ( this ) . parent ( ) ; $cell. addClass ( 'ew-tree-tips-open' ) ; $cell. children ( '.layui-table-grid-down' ) . hide ( ) ; var tw = $cell. parent ( ) . outerWidth ( ) + 4 ; if ( $cell. outerWidth ( ) < tw) $cell. children ( '.ew-tree-table-cell-content' ) . css ( { 'width' : tw, 'max-width' : tw} ) ; var $box = $cell. parents ( ) . filter ( '.ew-tree-table-box' ) ; if ( $box. length === 0 ) $box = $cell. parents ( ) . filter ( '.ew-tree-table-head' ) ; if ( $box. length === 0 ) return ; if ( ( $cell. outerWidth ( ) + $cell. offset ( ) . left) + 20 > $box. offset ( ) . left + $box. outerWidth ( ) ) { $cell. addClass ( 'ew-show-left' ) ; } if ( ( $cell. outerHeight ( ) + $cell. offset ( ) . top + 10 ) > $box. offset ( ) . top + $box. outerHeight ( ) ) { $cell. addClass ( 'ew-show-bottom' ) ; } } ) ; $ ( document) . on ( 'click' , '.ew-tree-table-cell>.ew-tree-tips-c' , function ( ) { hideAllTdTips ( ) ; } ) ; $ ( document) . on ( 'click' , function ( ) { hideAllTdTips ( ) ; $ ( '.ew-tree-table .layui-table-tool-panel' ) . remove ( ) ; } ) ; $ ( document) . on ( 'click' , '.ew-tree-table-cell.ew-tree-tips-open' , function ( e ) { e. stopPropagation ( ) ; } ) ; function hideAllTdTips ( ) { $ ( '.ew-tree-table-cell' ) . removeClass ( 'ew-tree-tips-open ew-show-left ew-show-bottom' ) ; $ ( '.ew-tree-table-cell>.ew-tree-table-cell-content' ) . css ( { 'width' : '' , 'max-width' : '' } ) ; } $ ( document) . on ( 'mousedown' , '.ew-tb-resize' , function ( e ) { layui. stope ( e) ; var $this = $ ( this ) ; $this . attr ( 'move' , 'true' ) ; var key = $this . parent ( ) . data ( 'key' ) ; $this . data ( 'x' , e. clientX) ; var w = $this . parent ( ) . parent ( ) . parent ( ) . parent ( ) . children ( 'colgroup' ) . children ( 'col[data-key="' + key + '"]' ) . attr ( 'width' ) ; if ( ! w || w. toString ( ) . indexOf ( '%' ) !== - 1 ) w = $this . parent ( ) . outerWidth ( ) ; $this . data ( 'width' , w) ; $ ( 'body' ) . addClass ( 'ew-tree-table-resizing' ) ; } ) . on ( 'mousemove' , function ( e ) { var $rs = $ ( '.ew-tree-table .ew-tb-resize[move="true"]' ) ; if ( $rs. length === 0 ) return ; layui. stope ( e) ; var x = $rs. data ( 'x' ) ; var w = $rs. data ( 'width' ) ; var nw = parseFloat ( w) + e. clientX - parseFloat ( x) ; if ( nw <= 0 ) nw = 1 ; var ins = _instances[ $rs. parentsUntil ( '.ew-tree-table' ) . last ( ) . parent ( ) . attr ( 'lay-filter' ) ] ; var key = $rs. parent ( ) . data ( 'key' ) ; var ks = key. split ( '-' ) ; ins. options. cols[ ks[ 0 ] ] [ ks[ 1 ] ] . width = nw; ins. eachCols ( function ( i, item ) { if ( item. key === key) item. width = nw; } ) ; ins. resize ( ) ; } ) . on ( 'mouseup' , function ( e ) { $ ( '.ew-tree-table .ew-tb-resize[move="true"]' ) . attr ( 'move' , 'false' ) ; $ ( 'body' ) . removeClass ( 'ew-tree-table-resizing' ) ; } ) . on ( 'mouseleave' , function ( e ) { $ ( '.ew-tree-table .ew-tb-resize[move="true"]' ) . attr ( 'move' , 'false' ) ; $ ( 'body' ) . removeClass ( 'ew-tree-table-resizing' ) ; } ) ; function getPids ( data, idName, pidName ) { var pids = [ ] ; for ( var i = 0 ; i < data. length; i++ ) { var hasPid = false ; for ( var j = 0 ; j < data. length; j++ ) { if ( data[ i] [ pidName] == data[ j] [ idName] ) { hasPid = true ; break ; } } if ( ! hasPid) pids. push ( data[ i] [ pidName] ) ; } return pids; } function pidEquals ( pId, pIds ) { if ( isClass ( pIds) === 'Array' ) { for ( var i = 0 ; i < pIds. length; i++ ) if ( pId == pIds[ i] ) return true ; } return pId == pIds; } function isClass ( o ) { if ( o === null ) return 'Null' ; if ( o === undefined ) return 'Undefined' ; return Object . prototype. toString . call ( o) . slice ( 8 , - 1 ) ; } function getPageHeight ( ) { return document. documentElement. clientHeight || document. body. clientHeight; } var tt = { render : function ( options ) { return new TreeTable ( options) ; } , reload : function ( id, opt ) { _instances[ id] . reload ( opt) ; } , on : function ( events, callback ) { return layui. onevent . call ( this , MOD_NAME , events, callback) ; } , pidToChildren : function ( data, idName, pidName, childName, pId ) { if ( ! childName) childName = 'children' ; var newList = [ ] ; for ( var i = 0 ; i < data. length; i++ ) { if ( data[ i] [ idName] == data[ i] [ pidName] ) return console. error ( '第' + i + '条数据的' + idName + '与' + pidName + '相同' , data[ i] ) ; if ( pId === undefined ) pId = getPids ( data, idName, pidName) ; if ( pidEquals ( data[ i] [ pidName] , pId) ) { var children = this . pidToChildren ( data, idName, pidName, childName, data[ i] [ idName] ) ; if ( children. length > 0 ) data[ i] [ childName] = children; newList. push ( data[ i] ) ; } } return newList; } } ; $ ( 'head' ) . append ( [ '<style id="ew-tree-table-css">' , '/** 最外层容器 */' , '.ew-tree-table {' , ' margin: 10px 0;' , ' position: relative;' , ' border: 1px solid #e6e6e6;' , ' border-bottom: none;' , ' border-right: none;' , '}' , '.ew-tree-table:before, .ew-tree-table:after, .ew-tree-table .ew-tree-table-head:after {' , ' content: "";' , ' background-color: #e6e6e6;' , ' position: absolute;' , ' right: 0;' , ' bottom: 0;' , '}' , '.ew-tree-table:before {' , ' width: 1px;' , ' top: 0;' , ' z-index: 1;' , '}' , '.ew-tree-table:after, .ew-tree-table .ew-tree-table-head:after {' , ' height: 1px;' , ' left: 0;' , '}' , '.ew-tree-table .layui-table {' , ' margin: 0;' , ' position: relative;' , ' table-layout: fixed;' , '}' , '/** 表格 */' , '.ew-tree-table .layui-table td, .ew-tree-table .layui-table th {' , ' border-top: none;' , ' border-left: none;' , ' padding: 0 !important;' , '}' , '.ew-tree-table .ew-tree-table-box {' , ' overflow: auto;' , ' position: relative;' , '}' , '.ew-tree-table .ew-tree-table-head {' , ' overflow: hidden;' , ' box-sizing: border-box;' , ' background-color: #f2f2f2;' , ' position: relative;' , '}' , '/** loading */' , '.ew-tree-table div.ew-tree-table-loading {' , ' padding: 10px 0;' , ' text-align: center;' , '}' , '.ew-tree-table div.ew-tree-table-loading > i {' , ' color: #999;' , ' font-size: 30px;' , '}' , '.ew-tree-table div.ew-tree-table-loading.ew-loading-float {' , ' position: absolute;' , ' top: 0;' , ' left: 0;' , ' right: 0;' , '}' , '/** 空数据 */' , '.ew-tree-table .ew-tree-table-empty {' , ' color: #666;' , ' font-size: 14px;' , ' padding: 18px 0;' , ' text-align: center;' , ' display: none;' , '}' , '/** 单元格 */' , '.ew-tree-table-cell.ew-tree-tips-open {' , ' position: absolute;' , ' top: 0;' , ' left: 0;' , ' padding: 0;' , ' z-index: 9999;' , ' background-color: #fff;' , ' box-shadow: 3px 3px 8px rgba(0, 0, 0, .15);' , '}' , 'thead .ew-tree-table-cell.ew-tree-tips-open {' , ' background-color: #f2f2f2;' , '}' , '.ew-tree-table-cell.ew-tree-tips-open.ew-show-left {' , ' right: 0;' , ' left: auto;' , ' box-shadow: -3px 3px 8px rgba(0, 0, 0, .15);' , '}' , '.ew-tree-table-cell.ew-tree-tips-open.ew-show-bottom {' , ' bottom: 0;' , ' top: auto;' , ' box-shadow: 3px -3px 8px rgba(0, 0, 0, .15);' , '}' , '.ew-tree-table-cell.ew-tree-tips-open.ew-show-left.ew-show-bottom {' , ' box-shadow: -3px -3px 8px rgba(0, 0, 0, .15);' , '}' , '.ew-tree-table-cell > .ew-tree-tips-c {' , ' position: absolute;' , ' right: -6px;' , ' top: -3px;' , ' width: 22px;' , ' height: 22px;' , ' line-height: 22px;' , ' font-size: 16px;' , ' color: #fff;' , ' background-color: #666;' , ' border-radius: 50%;' , ' text-align: center;' , ' cursor: pointer;' , ' display: none;' , '}' , 'table tr:first-child .ew-tree-table-cell > .ew-tree-tips-c {' , ' top: 0;' , '}' , '.ew-tree-table-cell.ew-tree-tips-open > .ew-tree-tips-c {' , ' display: block;' , '}' , '.ew-tree-table-cell.ew-tree-tips-open.ew-show-left > .ew-tree-tips-c {' , ' left: -6px;' , ' right: auto;' , '}' , '.ew-tree-table-cell > .ew-tree-table-cell-content {' , ' padding: 5px 15px;' , ' line-height: 28px;' , '}' , '[lay-size="lg"] .ew-tree-table-cell > .ew-tree-table-cell-content {' , ' line-height: 40px;' , '}' , '[lay-size="sm"] .ew-tree-table-cell > .ew-tree-table-cell-content {' , ' padding: 1px 15px;' , '}' , '.ew-tree-table-cell.single-line > .ew-tree-table-cell-content {' , ' overflow: hidden;' , ' white-space: nowrap;' , ' text-overflow: ellipsis;' , '}' , '.ew-tree-table-cell.ew-tree-tips-open > .ew-tree-table-cell-content {' , ' overflow: auto;' , ' padding: 9px 15px;' , ' height: auto;' , ' min-height: 100%;' , ' max-height: 110px;' , ' line-height: inherit;' , ' max-width: 260px;' , ' width: 200px;' , ' width: max-content;' , ' width: -moz-max-content;' , ' box-sizing: border-box;' , ' white-space: normal;' , '}' , '.ew-tree-table-cell > .layui-table-grid-down {' , ' box-sizing: border-box;' , '}' , '/** 图标列 */' , '.ew-tree-table .ew-tree-pack {' , ' cursor: pointer;' , ' line-height: 16px;' , '}' , '.ew-tree-table .ew-tree-pack > .layui-icon, .ew-tree-table .ew-tree-pack > .ew-tree-icon {' , ' margin-right: 5px;' , '}' , '.ew-tree-table .ew-tree-pack > * {' , ' vertical-align: middle;' , '}' , '/* 缩进 */' , '.ew-tree-table .ew-tree-table-indent {' , ' margin-right: 5px;' , ' padding-left: 16px;' , '}' , '/* 箭头 */' , '.ew-tree-table .ew-tree-table-arrow:before {' , ' content: "\\e623";' , '}' , '.ew-tree-table .ew-tree-table-open .ew-tree-table-arrow:before {' , ' content: "\\e625";' , '}' , '.ew-tree-table .ew-tree-table-arrow.arrow2 {' , ' font-size: 12px;' , ' font-weight: 600;' , ' line-height: 16px;' , ' height: 16px;' , ' width: 16px;' , ' display: inline-block;' , ' text-align: center;' , ' color: #888;' , '}' , '.ew-tree-table .ew-tree-table-arrow.arrow2:before {' , ' content: "\\e602";' , '}' , '.ew-tree-table .ew-tree-table-open .ew-tree-table-arrow.arrow2:before {' , ' content: "\\e61a";' , '}' , '.ew-tree-table-arrow.ew-tree-table-arrow-hide {' , ' visibility: hidden;' , '}' , '/* 箭头变加载中状态 */' , '.ew-tree-table tr.ew-tree-table-loading > td .ew-tree-table-arrow:before {' , ' content: "\\e63d" !important;' , '}' , '.ew-tree-table tr.ew-tree-table-loading > td .ew-tree-table-arrow {' , ' margin-right: 0;' , '}' , '.ew-tree-table tr.ew-tree-table-loading > td .ew-tree-table-arrow + * {' , ' margin-left: 5px;' , '}' , '.ew-tree-table tr.ew-tree-table-loading * {' , ' pointer-events: none !important;' , '}' , '/** 折叠行 */' , '.ew-tree-table .ew-tree-tb-hide {' , ' display: none;' , '}' , '/** 特殊列调整 */' , '.ew-tree-table td[data-type="numbers"] > .ew-tree-table-cell,' , '.ew-tree-table th[data-type="numbers"] > .ew-tree-table-cell,' , '.ew-tree-table td[data-type="checkbox"] > .ew-tree-table-cell,' , '.ew-tree-table th[data-type="checkbox"] > .ew-tree-table-cell,' , '.ew-tree-table td[data-type="radio"] > .ew-tree-table-cell,' , '.ew-tree-table th[data-type="radio"] > .ew-tree-table-cell,' , '.ew-tree-table td[data-type="space"] > .ew-tree-table-cell,' , '.ew-tree-table th[data-type="space"] > .ew-tree-table-cell {' , ' padding-left: 0;' , ' padding-right: 0;' , '}' , '/* 单元格内表单元素样式调整 */' , '.ew-tree-table .layui-form-switch' , '.ew-tree-table .layui-form-radio {' , ' margin: 0;' , '}' , '/* checkbox列调整 */' , '.ew-tree-table-checkbox + .layui-form-checkbox {' , ' padding: 0;' , '}' , '.ew-tree-table-checkbox + .layui-form-checkbox > .layui-icon {' , ' font-weight: 600;' , ' color: transparent;' , ' transition: background-color .1s linear;' , ' -webkit-transition: background-color .1s linear;' , '}' , '.ew-tree-table-checkbox + .layui-form-checkbox.layui-form-checked > .layui-icon {' , ' color: #fff;' , '}' , '/* checkbox半选状态 */' , '.ew-form-indeterminate + .layui-form-checkbox .layui-icon:before {' , ' content: "";' , ' width: 10px;' , ' height: 2px;' , ' background-color: #f1f1f1;' , ' position: absolute;' , ' top: 50%;' , ' left: 50%;' , ' margin: -1px 0 0 -5px;' , '}' , '/* radio列调整 */' , '.ew-tree-table-radio + .layui-form-radio {' , ' margin: 0;' , ' padding: 0;' , ' height: 20px;' , ' line-height: 20px;' , '}' , '.ew-tree-table-radio + .layui-form-radio > i {' , ' margin: 0;' , ' height: 20px;' , ' font-size: 20px;' , ' line-height: 20px;' , '}' , '/** 单元格编辑 */' , '.ew-tree-table .layui-table td[data-edit] {' , ' cursor: text;' , '}' , '.ew-tree-table .ew-tree-table-edit {' , ' position: absolute;' , ' left: 0;' , ' top: 0;' , ' width: 100%;' , ' height: 100%;' , ' border-radius: 0;' , ' box-shadow: 1px 1px 20px rgba(0, 0, 0, .15);' , '}' , '.ew-tree-table .ew-tree-table-edit:focus {' , ' border-color: #5FB878 !important;' , '}' , '.ew-tree-table .ew-tree-table-edit.layui-form-danger {' , ' border-color: #FF5722 !important;' , '}' , '/** 搜索数据隐藏行 */' , '.ew-tree-table tr.ew-tree-table-filter-hide {' , ' display: none !important;' , '}' , '/** 头部工具栏 */' , '.ew-tree-table .ew-tree-table-tool {' , ' min-height: 50px;' , ' line-height: 30px;' , ' padding: 10px 15px;' , ' box-sizing: border-box;' , ' background-color: #f2f2f2;' , ' border-bottom: 1px solid #e6e6e6;' , '}' , '.ew-tree-table .ew-tree-table-tool .ew-tree-table-tool-right {' , ' float: right;' , '}' , '.ew-tree-table .ew-tree-table-tool .ew-tree-table-tool-item {' , ' position: relative;' , ' color: #333;' , ' width: 26px;' , ' height: 26px;' , ' line-height: 26px;' , ' text-align: center;' , ' margin-left: 10px;' , ' display: inline-block;' , ' border: 1px solid #ccc;' , ' box-sizing: border-box;' , ' vertical-align: middle;' , ' -webkit-transition: .3s all;' , ' transition: .3s all;' , ' cursor: pointer;' , '}' , '.ew-tree-table .ew-tree-table-tool .ew-tree-table-tool-item:first-child {' , ' margin-left: 0;' , '}' , '.ew-tree-table .ew-tree-table-tool .ew-tree-table-tool-item:hover {' , ' border-color: #999;' , '}' , '.ew-tree-table .ew-tree-table-tool-right .layui-table-tool-panel {' , ' left: auto;' , ' right: -1px;' , ' z-index: 9999;' , '}' , '/* 列宽拖拽调整 */' , '.ew-tree-table .ew-tb-resize {' , ' position: absolute;' , ' right: 0;' , ' top: 0;' , ' bottom: 0;' , ' width: 10px;' , ' cursor: col-resize;' , '}' , '.ew-tree-table-resizing {' , ' cursor: col-resize;' , ' -ms-user-select: none;' , ' -moz-user-select: none;' , ' -webkit-user-select: none;' , ' user-select: none;' , '}' , '/* 辅助样式 */' , '.ew-tree-table .layui-form-switch {' , ' margin: 0;' , '}' , '.ew-tree-table .pd-tb-0 {' , ' padding-top: 0 !important;' , ' padding-bottom: 0 !important;' , '}' , '.ew-tree-table .break-all {' , ' word-break: break-all !important;' , '}' , '/** 扩展图标 */' , '.ew-tree-table .ew-tree-icon-folder:after, .ew-tree-table .ew-tree-icon-file:after {' , ' content: "";' , ' padding: 2px 10px;' , ' -webkit-background-size: cover;' , ' -moz-background-size: cover;' , ' -o-background-size: cover;' , ' background-size: cover;' , ' background-repeat: no-repeat;' , ' background-image: url("");' , '}' , '.ew-tree-table tr.ew-tree-table-open > td .ew-tree-icon-folder:after {' , ' background-image: url("");' , '}' , '.ew-tree-table .ew-tree-icon-file:after {' , ' background-image: url("");' , '}' , '</style>' ] . join ( '' ) ) ; exports ( 'tableTree' , tt) ;
} ) ;