header.js 27 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622
  1. window.checkData = []; //全选 数据池
  2. window.sort=require('../utilities/sort');//排序组件
  3. window.Header = function getHeader(object) {
  4. let _targetDom = object.el ? document.getElementById(object.el) : document.getElementsByTagName("table")[0];//基点元素
  5. let _columns = object.column; //列名
  6. let _fixedTop = object.fixedTop || 0; //同级浮动元素高度,使当前元素追加该元素高度浮动
  7. let _isCheckAllBox = object.isCheckAllBox!==false;//是否开启全选框
  8. let _data = object.data || []; //被排序数据
  9. let _restorationColumn = object.restorationColumn || 'id'; //恢复原数据基准字段
  10. let _isRestorationColumnAsc = object.isRestorationColumnAsc || false; //恢复原数据基准字段的排序类型 true:asc false:desc
  11. let _before = object.before;//前置元素
  12. let _name = "header:"+(object.name ? object.name+"." : "");//唯一名称 用于区别模块 本地存储
  13. let _isForbidDrag = object.isForbidDrag;
  14. let sortType = {}; //排序类型
  15. let columnArr = []; //列数组
  16. let moveTd = {}; //移动列
  17. let isNested = _targetDom.getElementsByTagName("table").length>0;
  18. let setting = "setting-column";
  19. let settingInfo = localStorage.getItem("settingInfo") ? JSON.parse(localStorage.getItem("settingInfo")) : {
  20. isCopyWrap : true
  21. };
  22. let keyCode = false;
  23. let settingCheck = true;
  24. function getTargetChildNode(dom) { //递归获取input子节点
  25. if (!dom || dom.tagName==='INPUT')return dom;
  26. return getTargetChildNode(dom.firstElementChild);
  27. }
  28. function createHeaderBefore() {//生成前置元素
  29. let tr = document.createElement("tr");
  30. tr.className = "text-center";
  31. _before.forEach(be=>{
  32. let th = document.createElement("th");
  33. if (be.colspan)th.colSpan = be.colspan;
  34. if (be.font){
  35. let font = document.createElement("span");
  36. font.className = be.font;
  37. th.appendChild(font);
  38. }
  39. if (be.value)th.appendChild(document.createTextNode(be.value));
  40. if (be.class)th.className = be.class;
  41. tr.appendChild(th);
  42. });
  43. _targetDom.insertBefore(tr, _targetDom.firstElementChild);
  44. }
  45. function appendFloat(div,cla="") {
  46. div.style.overflowX = "hidden";
  47. div.className="m-0 p-0";
  48. let th = document.createElement("th");
  49. th.className = "pl-2 pr-2 header-float "+cla;
  50. th.style.top = _fixedTop+"px";
  51. th.appendChild(div);
  52. return th;
  53. }
  54. function createHeader() {//生成表头列
  55. let tr = document.createElement("tr");
  56. tr.className = "text-nowrap";
  57. let firstTr = _targetDom.getElementsByTagName("tr")[0];
  58. let tds = [];
  59. if (firstTr)tds = firstTr.children;
  60. if (_isCheckAllBox){//是否开启全选
  61. let div = document.createElement("div");
  62. let check = document.createElement("input");
  63. check.type = "checkbox";
  64. check.id = "checkAll";
  65. if (firstTr)bindCheckbox(check);
  66. div.appendChild(check);
  67. tr.appendChild(appendFloat(div,"text-left"));
  68. }
  69. let i = (_isCheckAllBox && firstTr) ? 1 : 0;
  70. for (i;i<(tds.length>0 ? tds.length : _columns.length);i++){
  71. let div = document.createElement("div");
  72. let th = appendFloat(div);
  73. let column = _columns[(_isCheckAllBox && firstTr) ? i-1 : i];
  74. let wid = column ? localStorage.getItem(_name+column.name) : null;
  75. if (wid){
  76. div.style.width = wid+"px";
  77. th.style.minWidth = wid+"px";
  78. let trs = _targetDom.children;
  79. while(trs[0] && trs[0].tagName !== 'TR')trs = trs[0].children;
  80. if (trs[0]){
  81. for (let j=0;j<trs.length;j++){
  82. if (trs[j].children[i]){
  83. trs[j].children[i].firstElementChild.style.width = wid+"px";
  84. trs[j].children[i].style.minWidth = wid+"px";
  85. }
  86. }
  87. }
  88. }
  89. if (column){
  90. if (column.type === 'multi') multiColumn(div,column);
  91. else defaultColumn(div,column);
  92. }
  93. tr.appendChild(th);
  94. }
  95. bindMove(tr);
  96. if (_targetDom.firstElementChild)_targetDom.insertBefore(tr, _targetDom.firstElementChild);
  97. else _targetDom.appendChild(tr);
  98. }
  99. function multiColumn(th,column) { //多列样式的生成
  100. if (column.title){
  101. let div = document.createElement("div");
  102. div.className="w-100 text-center";
  103. div.appendChild(document.createTextNode(column.title));
  104. th.appendChild(div);
  105. }
  106. let div = document.createElement("div");
  107. div.className="row text-center";
  108. if (column.rows){
  109. column.rows.forEach(row=>{
  110. let node = document.createElement("div");
  111. node.className = "col-"+(row.col ? row.col : 1);
  112. node.appendChild(document.createTextNode(row.value));
  113. div.appendChild(node);
  114. });
  115. th.appendChild(div);
  116. }
  117. }
  118. function defaultColumn(th,column) { //默认列样式的生成
  119. if (column.style)for (let key in column.style)if (column.style.hasOwnProperty(key)) th.parentElement.style[key] = column.style[key];
  120. if (column.class)th.parentElement.className += column.class;
  121. let span = document.createElement("span");
  122. span.style.display = "inline-block";
  123. if (!column.neglect){
  124. span.style.cursor = "pointer";
  125. let font = document.createElement("span");
  126. font.className = "fa fa-sort";
  127. span.appendChild(font);
  128. span.onclick = rule(column,font); //绑定排序事件
  129. }
  130. span.appendChild(document.createTextNode((column.value ? column.value : '')));
  131. th.appendChild(span);
  132. }
  133. //点击事件触发的排序规则
  134. function rule(column,columnSort) {
  135. return function () {
  136. if (!sortType[column.name]){
  137. sortType[column.name] = 'asc';
  138. columnArr.push(column.name);
  139. columnSort.className = "fa fa-sort-asc";
  140. let columnArrTemp = [];
  141. columnArrTemp.push.apply(columnArrTemp,columnArr);
  142. window.sort.sort(_data,columnArrTemp,sortType);
  143. return ;
  144. }
  145. if (sortType[column.name] === 'asc'){
  146. sortType[column.name] = 'desc';
  147. columnSort.className = "fa fa-sort-desc";
  148. let columnArrTemp = [];
  149. columnArrTemp.push.apply(columnArrTemp,columnArr);
  150. window.sort.sort(_data,columnArrTemp,sortType);
  151. return ;
  152. }
  153. if (sortType[column.name] === 'desc'){
  154. delete sortType[column.name];
  155. columnArr.some(function (name, index) {
  156. if (name === column.name){
  157. columnArr.splice(index,1);
  158. return true;
  159. }
  160. });
  161. columnSort.className = "fa fa-sort";
  162. if (columnArr.length === 0){
  163. //希尔排序
  164. let arr = [];
  165. arr.push.apply(arr,_data);
  166. let len = arr.length;
  167. for(let gap = Math.floor(len / 2); gap > 0; gap = Math.floor(gap / 2)) {
  168. for(let i = gap; i < len; i++) {
  169. let j = i;
  170. let current = arr[i];
  171. if (_isRestorationColumnAsc){
  172. while(j - gap >= 0 && Number(current[_restorationColumn]) < Number(arr[j - gap][_restorationColumn])) {
  173. arr[j] = arr[j - gap];
  174. j = j - gap;
  175. }
  176. }else{
  177. while(j - gap >= 0 && Number(current[_restorationColumn]) > Number(arr[j - gap][_restorationColumn])) {
  178. arr[j] = arr[j - gap];
  179. j = j - gap;
  180. }
  181. }
  182. arr[j] = current;
  183. }
  184. }
  185. _data.length = 0;
  186. _data.push.apply(_data,arr);
  187. return;
  188. }
  189. let columnArrTemp = [];
  190. columnArrTemp.push.apply(columnArrTemp,columnArr);
  191. window.sort.sort(_data,columnArrTemp,sortType);
  192. }
  193. }
  194. }
  195. function bindCheckbox(check) {
  196. let trs = _targetDom.children;
  197. while(trs[0].tagName !== 'TR')trs = trs[0].children;
  198. check.onchange = function () {
  199. if (event.target.checked){
  200. for (let i=0;i<trs.length;i++){
  201. let checkbox = getTargetChildNode(trs[i].children[0]);
  202. if (checkbox && !checkbox.checked){
  203. checkData.push(checkbox.value);
  204. checkbox.checked = true;
  205. }
  206. }
  207. }else{
  208. checkData = [];
  209. for (let i=0;i<trs.length;i++){
  210. let checkbox = getTargetChildNode(trs[i].children[0]);
  211. if (checkbox && checkbox.checked)checkbox.checked = false;
  212. }
  213. }
  214. };
  215. for (let i=0;i<trs.length;i++){
  216. let checkbox = getTargetChildNode(trs[i].children[0]);
  217. if (checkbox) checkbox.onchange = function () {
  218. if (event.target.checked)checkData.push(checkbox.value);
  219. else checkData.splice(checkData.indexOf(checkbox.value),1);
  220. if (checkData.length === _data.length && !check.checked)check.checked=true;
  221. if (checkData.length !== _data.length && check.checked) check.checked=false;
  222. }
  223. }
  224. }
  225. function bindMove(tr) {
  226. if (_isForbidDrag)return;
  227. for (let j=0;j<tr.children.length;j++){ //为首列绑定拖拽列宽事件
  228. tr.children[j].onmousedown = function (){
  229. if (j===0 && event.offsetX<10)return;
  230. if(event.offsetX<10)moveTd = {oldX:event.clientX,dom:tr.children[j-1],index:j-1};
  231. if (event.offsetX > tr.children[j].offsetWidth-10)moveTd = {oldX:event.clientX,dom:tr.children[j],index:j};
  232. };
  233. tr.children[j].onmousemove = function () {
  234. if (j===0 && event.offsetX<10)return;
  235. if(event.offsetX<10 || event.offsetX > tr.children[j].offsetWidth-10)
  236. this.style.cursor = 'w-resize';
  237. else this.style.cursor = 'default';
  238. }
  239. }
  240. document.onmouseup = function (){ //全局监听拖拽列宽的发生 作用域设为全局是为了防抖动
  241. if (moveTd.oldX){
  242. event.stopPropagation();
  243. moveTd.dom.style.cursor = 'default';
  244. moveTd.oldX = undefined;
  245. setTimeout(function () {
  246. let column = _columns[(_isCheckAllBox && _targetDom.firstElementChild) ? moveTd.index-1 : moveTd.index];
  247. if (column) localStorage.setItem(_name+column.name, moveTd.dom.offsetWidth);
  248. });
  249. }
  250. }; //移动时调整表头与表身的列宽
  251. document.onmousemove = function(){
  252. if (moveTd.oldX){
  253. event.stopPropagation();
  254. let diff = event.clientX-moveTd.oldX;
  255. let newWidth = moveTd.dom.firstElementChild.offsetWidth+diff+"px";
  256. if (diff!==0){
  257. let trs = _targetDom.getElementsByTagName("tr");
  258. for (let j=(_before ? 1 : 0);j<trs.length;j++){
  259. if (isNested){
  260. let table = trs[j].parentElement;
  261. while (table.tagName!=='TABLE') table = table.parentElement;
  262. if (table.id!==object.el)continue;
  263. }
  264. if (trs[j].children[moveTd.index]){
  265. trs[j].children[moveTd.index].firstElementChild.style.width = newWidth;
  266. trs[j].children[moveTd.index].style.minWidth = newWidth;
  267. }
  268. }
  269. _targetDom.style.width = _targetDom.offsetWidth+diff+"px";
  270. moveTd.oldX = event.clientX;
  271. }
  272. }
  273. };
  274. }
  275. function repaintDom() {
  276. let trs = _targetDom.getElementsByTagName("tr");
  277. for (let i=0;i<trs.length;i++){
  278. if (isNested){
  279. let table = trs[i].parentElement;
  280. while (table.tagName!=='TABLE') table = table.parentElement;
  281. if (table.id!==object.el)continue;
  282. }
  283. let tds = trs[i].children;
  284. for (let j=0;j<tds.length;j++){
  285. let count = tds[j].children.length;
  286. let div = document.createElement("div");
  287. div.style.overflowX = "hidden";
  288. for (let k=0;k<count;k++){div.appendChild(tds[j].children[0]);}
  289. tds[j].appendChild(div);
  290. tds[j].className += " pl-2 pr-2";
  291. }
  292. }
  293. }
  294. function showSetting(type) {
  295. return function (){
  296. let type2 = type === "setting-1" ? "setting-2" : "setting-1";
  297. document.getElementById(type2).style.display = "";
  298. document.getElementById(type).style.display = "none";
  299. };
  300. }
  301. function _createSetting1() {
  302. /*
  303. * <div id="setting-1" onclick="tt()" style="position: fixed;bottom: 0;left: 0;background-color: #1b1e21;width: 50px;height: 50px;cursor: pointer;text-align: center;border-radius: 3px">
  304. <h1><span class="fa fa-spin fa-gear" style="color: white;"></span></h1>
  305. </div>
  306. * */
  307. let div = document.createElement("div");
  308. div.id = "setting-1";
  309. div.style.position = "fixed";
  310. div.style.bottom = 0;
  311. div.style.left = 0;
  312. div.style.backgroundColor = "#1b1e21";
  313. div.style.width = "50px";
  314. div.style.height = "50px";
  315. div.style.cursor = "pointer";
  316. div.style.textAlign = "center";
  317. div.style.borderRadius = "3px";
  318. let h1 = document.createElement("h1");
  319. let span = document.createElement("span");
  320. span.className = "fa fa-gear";
  321. span.style.color = "white";
  322. div.onclick = showSetting("setting-1");
  323. h1.appendChild(span);
  324. div.appendChild(h1);
  325. document.body.appendChild(div);
  326. }
  327. function _createSettingHeader(text,id) {
  328. let div = document.createElement("div");
  329. div.style.width = "5%";
  330. div.style.display = "inline-block";
  331. div.style.borderLeft = "1px solid #aaaaaa";
  332. div.style.textAlign = "center";
  333. div.style.cursor = "pointer";
  334. div.innerText = text;
  335. div.id = id;
  336. div.onclick = function () {
  337. if (event.target.id===setting)return;
  338. let old = document.getElementById(setting);
  339. old.style.backgroundColor = "";
  340. old.style.color = "";
  341. document.getElementById(setting+"-body").style.display = "none";
  342. event.target.style.backgroundColor ="#3490dc";
  343. event.target.style.color ="white";
  344. document.getElementById(event.target.id+"-body").style.display = "";
  345. setting = event.target.id;
  346. };
  347. return div;
  348. }
  349. function bindColumnEvent() {
  350. return function(){
  351. let storage = localStorage.getItem("column:"+object.name);
  352. let arr = storage ? storage.split(',') : [];
  353. localStorage.setItem("column:"+object.name,_exeHid(arr).toString());
  354. };
  355. }
  356. function _exeHid(arr) {
  357. let nodes = document.getElementById("setting-column-body").getElementsByTagName("input");
  358. let show = [];
  359. let hid = [];
  360. let newArr = [];
  361. for (let i=0;i<nodes.length;i++){
  362. let value = nodes[i].value;
  363. let index = nodes[i].dataset.index;
  364. let checked = nodes[i].checked;
  365. if (checked && arr.indexOf(value)!==-1) show.push(index);
  366. if (!checked){
  367. newArr.push(value);
  368. if (arr.indexOf(value)===-1)hid.push(index);
  369. }
  370. }
  371. let trs = _targetDom.getElementsByTagName("tr"); //所有行
  372. let total = trs[_before ? 1 : 0].children.length; //最大列
  373. for (let i=0;i<trs.length;i++){
  374. if (isNested){ //排除表格嵌套
  375. let table = trs[i].parentElement;
  376. while (table.tagName!=='TABLE') table = table.parentElement;
  377. if (table.id!==object.el)continue;
  378. }
  379. if (total!==trs[i].children.length){ //存在合并行/列
  380. let pointer = [];//建立一个指针数组 用于存储下标指向真实element
  381. for (let j=0;j<trs[i].children.length;j++){
  382. if (trs[i].children[j] && trs[i].children[j].colSpan>1){
  383. for (let k=0;k<trs[i].children[j].colSpan;k++)pointer.push(j);
  384. }else pointer.push(j);
  385. }
  386. for (let j=0;j<show.length;j++)showOrHiddenDom(trs[i].children[pointer[show[j]]]);
  387. for (let j=0;j<hid.length;j++)showOrHiddenDom(trs[i].children[pointer[hid[j]]],"hid");
  388. }else {
  389. for (let j=0;j<show.length;j++)showOrHiddenDom(trs[i].children[show[j]]);
  390. for (let j=0;j<hid.length;j++)showOrHiddenDom(trs[i].children[hid[j]],"hid");
  391. }
  392. }
  393. return newArr;
  394. }
  395. function showOrHiddenDom(dom,type="show") {
  396. if (!dom)return;
  397. if (type==="show"){
  398. if (dom.colSpan>1)dom.colSpan++;
  399. else dom.style.display = "";
  400. }else{
  401. if (dom.colSpan>1)dom.colSpan--;
  402. else dom.style.display = "none";
  403. }
  404. }
  405. function appendCheckboxList(div) {
  406. let storage = localStorage.getItem("column:"+object.name);
  407. let arr = storage ? storage.split(',') : [];
  408. _columns.forEach(function (column,index) {
  409. let key = "setting-column-"+column.name;
  410. let label = document.createElement("label");
  411. label.style.float = "left";
  412. let input = document.createElement("input");
  413. input.type="checkbox";
  414. input.id=key;
  415. input.className = "fixed-checkbox";
  416. input.dataset.index = _isCheckAllBox ? index+1 : index;
  417. input.value = column.name;
  418. if (arr.indexOf(column.name)===-1)input.checked = true;
  419. label.appendChild(input);
  420. let la = document.createElement("label");
  421. la.setAttribute("for",key);
  422. label.appendChild(la);
  423. label.appendChild(document.createTextNode(column.type ? column.title : column.value));
  424. let prentLabel = document.createElement("label");
  425. prentLabel.style.width = "10%";
  426. prentLabel.appendChild(label);
  427. div.appendChild(prentLabel);
  428. });
  429. }
  430. function bindClearEvent(need) {
  431. return function() {
  432. for (let i = 0; i < localStorage.length; i++) {
  433. let key = localStorage.key(i);
  434. if (need === key.substring(0,need.length))localStorage.removeItem(key);
  435. }
  436. };
  437. }
  438. function bindCheckAllEvent() {
  439. return function () {
  440. settingCheck = !settingCheck;
  441. let nodes = document.getElementById("setting-column-body").getElementsByTagName("input");
  442. for (let i=0;i<nodes.length;i++){
  443. if (nodes[i].checked!==settingCheck) nodes[i].checked=settingCheck;
  444. }
  445. }
  446. }
  447. function bindReverseEvent() {
  448. return function () {
  449. let nodes = document.getElementById("setting-column-body").getElementsByTagName("input");
  450. for (let i=0;i<nodes.length;i++)nodes[i].checked=!nodes[i].checked;
  451. }
  452. }
  453. function _createSetting2() {
  454. /*
  455. * <div id="setting-2" style="background-color: white;position: fixed;bottom: 0;left: 0;width: 100%;display: none">
  456. <div style="width: 100%;background-color: RGB(245,245,200);border-top: 1px solid #1b1e21">
  457. <div style="width: 30px;display:inline-block;text-align: center"><span class="fa fa-gear w-100 h-100"></span></div>
  458. <div style="width: 5%;display:inline-block;border-left: 1px solid #aaaaaa;text-align: center;cursor: pointer;background-color: #3490dc;color: white">显示列</div>
  459. <div style="width: 5%;display:inline-block;border-left: 1px solid #aaaaaa;text-align: center;cursor: pointer">表头设置</div>
  460. <b style="float: right;margin-right:10px;cursor: pointer;font-size: 18px">&times;</b>
  461. </div>
  462. <div style="width: 100%;min-height: 50px;">
  463. <div style="margin: 10px 50px 20px 50px;width: 100%;" id="setting-data">
  464. <div id="setting-column">
  465. <label style="margin-right: 10px">
  466. 测试<input type="checkbox" id="column-x" class="fixed-checkbox" value="1" onclick="test()">
  467. <label for="column-x"></label>
  468. </label>
  469. <div>
  470. <button class="btn btn-sm btn-success">保存</button>
  471. </div>
  472. </div>
  473. <div id="setting-header">
  474. 清除本地列宽设置:
  475. <button type="button" class="btn btn-sm btn-outline-danger">清除全部</button>
  476. <button type="button" class="btn btn-sm btn-outline-danger">清除本页</button>
  477. </div>
  478. </div>
  479. </div>
  480. </div>
  481. * */
  482. let div = document.createElement("div");
  483. div.id = "setting-2";
  484. div.style.backgroundColor = "white";
  485. div.style.position = "fixed";
  486. div.style.bottom = 0;
  487. div.style.left = 0;
  488. div.style.width = "100%";
  489. div.style.display = "none";
  490. let div1 = document.createElement("div");
  491. div1.style.width = "100%";
  492. div1.style.backgroundColor = "RGB(245,245,220)";
  493. div1.style.borderTop = "1px solid #1b1e21";
  494. let div11 = document.createElement("div");
  495. div11.style.width = "30px";
  496. div11.style.display = "inline-block";
  497. div11.style.textAlign = "center";
  498. let span = document.createElement("span");
  499. span.className = "fa fa-gear";
  500. span.style.cursor = "pointer";
  501. span.onclick = showSetting("setting-2");
  502. div11.appendChild(span);
  503. div1.appendChild(div11);
  504. let div12 = _createSettingHeader("显示列","setting-column");
  505. div12.style.backgroundColor = "#3490dc";
  506. div12.style.color = "white";
  507. div1.appendChild(div12);
  508. div1.appendChild(_createSettingHeader("表头设置","setting-header"));
  509. let b = document.createElement("b");
  510. b.style.float="right";
  511. b.style.marginRight="10px";
  512. b.style.cursor="pointer";
  513. b.style.fontSize="18px";
  514. b.innerHTML="&times;";
  515. b.onclick = showSetting("setting-2");
  516. div1.appendChild(b);
  517. div.appendChild(div1);
  518. //body
  519. let div2 = document.createElement("div");
  520. div2.style.width = "100%";
  521. div2.style.minHeight = "50px";
  522. div2.style.margin = "10px 50px 20px 50px";
  523. let div21 = document.createElement("div");
  524. div21.id = "setting-column-body";
  525. appendCheckboxList(div21);
  526. let btn = document.createElement("button");
  527. btn.className = "btn btn-sm btn-success";
  528. btn.type = "button";
  529. btn.innerText="保存设置";
  530. btn.onclick = bindColumnEvent();
  531. let div211 = document.createElement("div");
  532. div211.appendChild(btn);
  533. let btn1 = document.createElement("button");
  534. btn1.className = "btn btn-sm btn-outline-info ml-1";
  535. btn1.type = "button";
  536. btn1.innerText = "全选/取消";
  537. btn1.onclick = bindCheckAllEvent();
  538. div211.appendChild(btn1);
  539. let btn2 = document.createElement("button");
  540. btn2.className = "btn btn-sm btn-outline-info ml-1";
  541. btn2.type = "button";
  542. btn2.innerText = "反选";
  543. btn2.onclick = bindReverseEvent();
  544. div211.appendChild(btn2);
  545. div21.appendChild(div211);
  546. div2.appendChild(div21);
  547. let div22 = document.createElement("div");
  548. div22.id = "setting-header-body";
  549. div22.style.display="none";
  550. let div221 = document.createElement("div");
  551. div221.className = "row";
  552. let text = document.createElement("label");
  553. text.innerText = "清除本地列宽设置:";
  554. text.className = "text-right col-3";
  555. div221.appendChild(text);
  556. let btnA = document.createElement("button");
  557. btnA.className = "btn btn-sm btn-outline-danger";
  558. btnA.innerText = "清除全部";
  559. btnA.onclick = bindClearEvent("header:");
  560. div221.appendChild(btnA);
  561. let btnB = document.createElement("button");
  562. btnB.className = "ml-1 btn btn-sm btn-outline-danger";
  563. btnB.innerText = "清除本页";
  564. btnB.onclick = bindClearEvent(_name);
  565. div221.appendChild(btnB);
  566. let div222 = document.createElement("div");
  567. div222.className = "row mt-2";
  568. let text2 = document.createElement("label");
  569. text2.innerText = "禁止复制换行:";
  570. text2.className = "text-right col-3";
  571. div222.appendChild(text2);
  572. let input = document.createElement("input");
  573. input.type = "checkbox";
  574. input.className = "switch";
  575. input.checked = settingInfo.isCopyNoWrap;
  576. input.onchange = function(){
  577. settingInfo.isCopyNoWrap = event.target.checked;
  578. localStorage.setItem("settingInfo",JSON.stringify(settingInfo));
  579. };
  580. div222.appendChild(input);
  581. div22.appendChild(div221);
  582. div22.appendChild(div222);
  583. div2.appendChild(div22);
  584. div.appendChild(div2);
  585. document.body.appendChild(div);
  586. }
  587. function createSetting() {
  588. _createSetting1();
  589. _createSetting2();
  590. }
  591. function bindGlobalEvent() {
  592. document.onkeydown = (e) => {
  593. if (e.ctrlKey && e.keyCode===67)keyCode = true;
  594. };
  595. document.oncopy = (e)=>{
  596. if (keyCode && settingInfo.isCopyNoWrap){
  597. e.preventDefault();
  598. let content = window.getSelection().toString();
  599. e.clipboardData.setData("text", content.replace(/[\n\r]/g,' '));
  600. keyCode = false;
  601. }
  602. };
  603. }
  604. //初始化
  605. this.init = function() {
  606. if (!_isForbidDrag)repaintDom();
  607. createHeader();
  608. if (_before)createHeaderBefore();
  609. createSetting();
  610. _exeHid([]);
  611. bindGlobalEvent();
  612. _targetDom.style.width = _targetDom.offsetWidth+"px";
  613. };
  614. };