| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297 |
- window.checkData = []; //全选 数据池
- window.sort=require('../utilities/sort');//排序组件
- window.Header = function getHeader(object) {
- let _targetDom = object.el ? document.getElementById(object.el) : document.getElementsByTagName("table")[0];//基点元素
- let _columns = object.column; //列名
- let _fixedTop = object.fixedTop || 0; //同级浮动元素高度,使当前元素追加该元素高度浮动
- let _isCheckAllBox = object.isCheckAllBox || true;//是否开启全选框
- let _data = object.data || []; //被排序数据
- let _restorationColumn = object.restorationColumn || 'id'; //恢复原数据基准字段
- let _is_restorationColumn_asc = object.is_restorationColumn_asc || false; //恢复原数据基准字段的排序类型 true:asc false:desc
- let _before = object.before;//前置元素
- let _name = object.name ? object.name+"." : "";//唯一名称 用于区别模块 本地存储
- let _isForbidDrag = object.isForbidDrag;
- let sortType = {}; //排序类型
- let columnArr = []; //列数组
- let moveTd = {}; //移动列
- let isNested = _targetDom.getElementsByTagName("table").length>0;
- function getTargetChildNode(dom) { //递归获取input子节点
- if (!dom || dom.tagName==='INPUT')return dom;
- return getTargetChildNode(dom.firstElementChild);
- }
- function createHeaderBefore() {//生成前置元素
- let tr = document.createElement("tr");
- tr.className = "text-center";
- _before.forEach(be=>{
- let th = document.createElement("th");
- if (be.colspan)th.colSpan = be.colspan;
- if (be.font){
- let font = document.createElement("span");
- font.className = be.font;
- th.appendChild(font);
- }
- if (be.value)th.appendChild(document.createTextNode(be.value));
- if (be.class)th.className = be.class;
- tr.appendChild(th);
- });
- _targetDom.insertBefore(tr, _targetDom.firstChild);
- }
- function appendFloat(div,cla="") {
- div.style.overflowX = "hidden";
- div.className="m-0 p-0";
- let th = document.createElement("th");
- th.className = "pl-2 pr-2 header-float "+cla;
- th.style.top = _fixedTop+"px";
- th.appendChild(div);
- return th;
- }
- function createHeader() {//生成表头列
- let tr = document.createElement("tr");
- tr.className = "text-nowrap";
- let firstTr = _targetDom.getElementsByTagName("tr")[0];
- let tds = [];
- if (firstTr)tds = firstTr.children;
- if (_isCheckAllBox){//是否开启全选
- let div = document.createElement("div");
- let check = document.createElement("input");
- check.type = "checkbox";
- check.id = "checkAll";
- if (firstTr)bindCheckbox(check);
- div.appendChild(check);
- tr.appendChild(appendFloat(div,"text-left"));
- }
- let i = (_isCheckAllBox && firstTr) ? 1 : 0;
- for (i;i<(tds.length>0 ? tds.length : _columns.length);i++){
- let div = document.createElement("div");
- let th = appendFloat(div);
- let column = _columns[(_isCheckAllBox && firstTr) ? i-1 : i];
- let wid = localStorage.getItem(_name+column.name);
- if (wid){
- div.style.width = wid+"px";
- th.style.minWidth = wid+"px";
- let trs = _targetDom.children;
- while(trs[0] && trs[0].tagName !== 'TR')trs = trs[0].children;
- if (trs[0]){
- for (let j=0;j<trs.length;j++){
- trs[j].children[i].firstChild.style.width = wid+"px";
- trs[j].children[i].style.minWidth = wid+"px";
- }
- }
- }
- if (column){
- if (column.type === 'multi') multiColumn(div,column);
- else defaultColumn(div,column);
- }
- tr.appendChild(th);
- }
- bindMove(tr);
- if (_targetDom.firstChild)_targetDom.insertBefore(tr, _targetDom.firstChild);
- else _targetDom.appendChild(tr);
- }
- function multiColumn(th,column) { //多列样式的生成
- if (column.title){
- let div = document.createElement("div");
- div.className="w-100 text-center";
- div.appendChild(document.createTextNode(column.title));
- th.appendChild(div);
- }
- let div = document.createElement("div");
- div.className="row text-center";
- if (column.rows){
- column.rows.forEach(row=>{
- let node = document.createElement("div");
- node.className = "col-"+(row.col ? row.col : 1);
- node.appendChild(document.createTextNode(row.value));
- div.appendChild(node);
- });
- th.appendChild(div);
- }
- }
- function defaultColumn(th,column) { //默认列样式的生成
- if (column.style)for (let key in column.style)if (column.style.hasOwnProperty(key)) th.parentElement.style[key] = column.style[key];
- if (column.class)th.parentElement.className += column.class;
- let span = document.createElement("span");
- span.style.display = "inline-block";
- if (!column.neglect){
- span.style.cursor = "pointer";
- let font = document.createElement("span");
- font.className = "fa fa-sort";
- span.appendChild(font);
- span.onclick = rule(column,font); //绑定排序事件
- }
- span.appendChild(document.createTextNode((column.value ? column.value : '')));
- th.appendChild(span);
- }
- //点击事件触发的排序规则
- function rule(column,columnSort) {
- return function () {
- if (!sortType[column.name]){
- sortType[column.name] = 'asc';
- columnArr.push(column.name);
- columnSort.className = "fa fa-sort-asc";
- let columnArrTemp = [];
- columnArrTemp.push.apply(columnArrTemp,columnArr);
- window.sort.sort(_data,columnArrTemp,sortType);
- return ;
- }
- if (sortType[column.name] === 'asc'){
- sortType[column.name] = 'desc';
- columnSort.className = "fa fa-sort-desc";
- let columnArrTemp = [];
- columnArrTemp.push.apply(columnArrTemp,columnArr);
- window.sort.sort(_data,columnArrTemp,sortType);
- return ;
- }
- if (sortType[column.name] === 'desc'){
- delete sortType[column.name];
- columnArr.some(function (name, index) {
- if (name === column.name){
- columnArr.splice(index,1);
- return true;
- }
- });
- columnSort.className = "fa fa-sort";
- if (columnArr.length === 0){
- //希尔排序
- let arr = [];
- arr.push.apply(arr,_data);
- let len = arr.length;
- for(let gap = Math.floor(len / 2); gap > 0; gap = Math.floor(gap / 2)) {
- for(let i = gap; i < len; i++) {
- let j = i;
- let current = arr[i];
- if (_is_restorationColumn_asc){
- while(j - gap >= 0 && Number(current[_restorationColumn]) < Number(arr[j - gap][_restorationColumn])) {
- arr[j] = arr[j - gap];
- j = j - gap;
- }
- }else{
- while(j - gap >= 0 && Number(current[_restorationColumn]) > Number(arr[j - gap][_restorationColumn])) {
- arr[j] = arr[j - gap];
- j = j - gap;
- }
- }
- arr[j] = current;
- }
- }
- _data.length = 0;
- _data.push.apply(_data,arr);
- return;
- }
- let columnArrTemp = [];
- columnArrTemp.push.apply(columnArrTemp,columnArr);
- window.sort.sort(_data,columnArrTemp,sortType);
- }
- }
- }
- function bindCheckbox(check) {
- let trs = _targetDom.children;
- while(trs[0].tagName !== 'TR')trs = trs[0].children;
- check.onchange = function () {
- if (event.target.checked){
- for (let i=0;i<trs.length;i++){
- let checkbox = getTargetChildNode(trs[i].children[0]);
- if (checkbox && !checkbox.checked){
- checkData.push(checkbox.value);
- checkbox.checked = true;
- }
- }
- }else{
- checkData = [];
- for (let i=0;i<trs.length;i++){
- let checkbox = getTargetChildNode(trs[i].children[0]);
- if (checkbox && checkbox.checked)checkbox.checked = false;
- }
- }
- };
- for (let i=0;i<trs.length;i++){
- let checkbox = getTargetChildNode(trs[i].children[0]);
- if (checkbox) checkbox.onchange = function () {
- if (event.target.checked)checkData.push(checkbox.value);
- else checkData.splice(checkData.indexOf(checkbox.value),1);
- if (checkData.length === _data.length && !check.checked)check.checked=true;
- if (checkData.length !== _data.length && check.checked) check.checked=false;
- }
- }
- }
- function bindMove(tr) {
- if (_isForbidDrag)return;
- for (let j=0;j<tr.children.length;j++){ //为首列绑定拖拽列宽事件
- tr.children[j].onmousedown = function (){
- if (j===0 && event.offsetX<10)return;
- if(event.offsetX<10)moveTd = {oldX:event.clientX,dom:tr.children[j-1],index:j-1};
- if (event.offsetX > tr.children[j].offsetWidth-10)moveTd = {oldX:event.clientX,dom:tr.children[j],index:j};
- };
- tr.children[j].onmousemove = function () {
- if (j===0 && event.offsetX<10)return;
- if(event.offsetX<10 || event.offsetX > tr.children[j].offsetWidth-10)
- this.style.cursor = 'w-resize';
- else this.style.cursor = 'default';
- }
- }
- document.onmouseup = function (){ //全局监听拖拽列宽的发生 作用域设为全局是为了防抖动
- if (moveTd.oldX){
- event.stopPropagation();
- moveTd.dom.style.cursor = 'default';
- moveTd.oldX = undefined;
- setTimeout(function () {
- let column = _columns[(_isCheckAllBox && _targetDom.firstChild) ? moveTd.index-1 : moveTd.index];
- if (column) localStorage.setItem(_name+column.name, moveTd.dom.offsetWidth);
- });
- }
- }; //移动时调整表头与表身的列宽
- document.onmousemove = function(){
- if (moveTd.oldX){
- event.stopPropagation();
- let diff = event.clientX-moveTd.oldX;
- let newWidth = moveTd.dom.firstChild.offsetWidth+diff+"px";
- if (diff!==0){
- let trs = _targetDom.getElementsByTagName("tr");
- for (let j=(_before ? 1 : 0);j<trs.length;j++){
- if (isNested){
- let table = trs[j].parentElement;
- while (table.tagName!=='TABLE') table = table.parentElement;
- if (table.id!==object.el)continue;
- }
- trs[j].children[moveTd.index].firstChild.style.width = newWidth;
- trs[j].children[moveTd.index].style.minWidth = newWidth;
- }
- moveTd.oldX = event.clientX;
- }
- }
- };
- }
- function repaintDom() {
- let trs = _targetDom.getElementsByTagName("tr");
- for (let i=0;i<trs.length;i++){
- if (isNested){
- let table = trs[i].parentElement;
- while (table.tagName!=='TABLE') table = table.parentElement;
- if (table.id!==object.el)continue;
- }
- let tds = trs[i].children;
- for (let j=0;j<tds.length;j++){
- let div = document.createElement("div");
- div.style.overflowX = "hidden";
- let count = tds[j].childNodes.length;
- for (let k=0;k<count;k++){div.appendChild(tds[j].childNodes[0]);}
- tds[j].appendChild(div);
- tds[j].className += " pl-2 pr-2";
- }
- }
- }
- //初始化
- this.init = function() {
- if (!_isForbidDrag)repaintDom();
- createHeader();
- if (_before)createHeaderBefore();
- };
- };
|