Lamptest pinned header of table

for stick header of table when scrolling

  1. // ==UserScript==
  2. // @name Lamptest pinned header of table
  3. // @name:ru Прилепленный заголовок таблицы для результатов тестирования ламп Lamptest
  4. // @description:ru При прокрутке страницы и уходе заголовка из вьюпорта становится видимым прилепленный заголовок
  5. // @grant none
  6. // @version 2.2019.4.29
  7. // @namespace spmbt.github.com
  8. // @include http://lamptest.ru/*
  9. // @include https://lamptest.ru/*
  10. // @description for stick header of table when scrolling
  11. // ==/UserScript==
  12. d=document;
  13. $q=(q,E)=>(E||d).querySelector(q);
  14. $qA=(q,E)=>(E||d).querySelectorAll(q);
  15. $x=(E,h,i)=>{if(h)for(i in h)E[i]=h[i];return E};
  16. $e=(g,el,cl,ht,at,x,o)=>{ //===создать или использовать имеющийся элемент===
  17. if(el)g.el=el; if(cl)g.cl=cl; if(ht)g.ht=ht; //(оптимизации записей на позиционные)
  18. o = g.el = g.el|| g.clone && g.clone.cloneNode(!0)||'DIV';
  19. o = g.el = typeof o =='string'? /\W/.test(o) ? $q(o, g.blck) : d.createElement(o) : o;
  20. if(o){
  21. if(g.cl) o.className = g.cl;
  22. if(g.cs) $x(o.style, g.cs);
  23. if(g.ht || g.at){at = g.at ||{}; if(g.ht) at.innerHTML = g.ht;}
  24. if(at) for(x in at){
  25. if(x=='innerHTML') o[x] = at[x];
  26. else o.setAttribute(x, at[x]);}
  27. if(g.ap) o.appendChild(g.ap);
  28. g.apT && g.apT.appendChild(o);
  29. g.aft && ((x=g.aft.nextSibling)?g.aft.parentNode.insertBefore(o,x):g.aft.parentNode.appendChild(o));
  30. g.remove && g.remove.parentNode.removeChild(g.remove);
  31. }
  32. return o};
  33. var $tFix, wW, wX, $tNL, $TQuery = '#ajax_search_results', $T0 = $q($TQuery), $T;
  34. setInterval(() => {
  35. $T0 = $q($TQuery);
  36. if(!$T0) return;
  37. $T = $T0;
  38. if(wW !== innerWidth || wX !== pageXOffset || !$qA('.tFix').length)
  39. wW = innerWidth,
  40. wX = pageXOffset,
  41. $sav = $q('.tFix tr:not(:first-child)'),
  42. $THCopy = $qA('th', $q('#ajax_results_table', $T)),
  43. $tFix = $e({cs:{position:'fixed', top:0, left: $T.getBoundingClientRect().x +'px',
  44. minWidth:'120px', minHeight:'20px', maxWidth:'none', width: ($T.offsetWidth + $THCopy.length * 2 - 5)+'px',
  45. paddingBottom:'1px', background:'rgba(183, 191, 234, 0.85)', fontSize:'0.8em'},
  46. apT:$q('body')},'TABLE','tFix','<tr style="text-align: center"></tr>'),
  47. $THCopy.forEach(el => $e({el:$q('tr', $tFix),
  48. ap: $e({clone: el, cs: {width: el.offsetWidth +'px', border:'1px solid #D5D5D5'}}) })),
  49. $e({aft: $sav},$q('tr', $tFix));
  50. if(($tNL = $qA('.tFix:not(:last-child)')).length)
  51. $e({remove: $tNL[0]});
  52. $e({cs:{display: $qA('tr', $tFix).length > 1 || $T.getBoundingClientRect().y < 0 ?'block':'none'}},$tFix);
  53. }, 1330);