Fossil

Diff
Login

Differences From Artifact [77f4e2875f]:

To Artifact [a2ff92931b]:


1
2









3
4
5
6
7
8

9
10

11
12
13
14





15
16
17
18
19
20
21


22
23
24
25
26
27
28

29
30
31
32
33

34
35
36
37
38
39
40
41










42
43



44
45
46

47
48
49
50
51
52




53
54









55
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16

17
18

19
20



21
22
23
24
25
26






27
28







29





30








31
32
33
34
35
36
37
38
39
40


41
42
43
44
45

46
47
48
49
50


51
52
53
54
55

56
57
58
59
60
61
62
63
64
65


+
+
+
+
+
+
+
+
+





-
+

-
+

-
-
-
+
+
+
+
+

-
-
-
-
-
-
+
+
-
-
-
-
-
-
-
+
-
-
-
-
-
+
-
-
-
-
-
-
-
-
+
+
+
+
+
+
+
+
+
+
-
-
+
+
+


-
+




-
-
+
+
+
+

-
+
+
+
+
+
+
+
+
+

/*
 * This script adds multiselect facility for the list of branches.
 *
 * Some info on 'const':
 *   https://caniuse.com/const
 *   https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements/const#browser_compatibility
 *
 * According to MDN 'const' requires Android's WebView 37,
 * which may not be available.
 * For the time being, continueing without 'const' and 'indexOf'
 * (but that may be reconsidered later).
*/
window.addEventListener( 'load', function() {

var anchor = document.querySelector("div.submenu > a.label" );
if( !anchor || anchor.innerText != "Timeline" ) return;
var prefix = anchor.href.toString() + "?ms=regexp&rel&t=";
var prefix   = anchor.href.toString() + "?ms=regexp&rel&t=";
anchor.classList.add('timeline-link');
const selectedCheckboxes = []/*currently-selected checkboxes*/;

var onChange = function( event ){
  const cbx = event.target;
  const tag = cbx.parentElement.children[0].innerText;
  var re = anchor.href.substr(prefix.length);
  var cbx = event.target;
  var tr  = cbx.parentElement.parentElement;
  var tag = cbx.parentElement.children[0].innerText;
  var re  = anchor.href.substr(prefix.length);
  var selected = ( re != "" ? re.split("|") : [] );
  if( cbx.checked ){
    if( re != "" ){
      re += "|";
    }
    re += tag;
    selectedCheckboxes.push(cbx);
    anchor.classList.add('selected'); 
    selected.push(tag);
    tr.classList.add('selected');
  }else{
    const ndx = selectedCheckboxes.indexOf(cbx);
    if(ndx>=0){
      selectedCheckboxes.splice(ndx,1);
      if(!selectedCheckboxes.length){
        anchor.classList.remove('selected');
      }
  }
    }
    if( re == tag ){
      re = "";
      removeSelected(cbx);
    }else {
  else {
      var a = re.split("|");
      var i = a.length;
      while( --i >= 0 ){
        if( a[i] == tag )
          a.splice(i,1);
      }
      re = a.join("|");
    }
    tr.classList.remove('selected');
    for( var i = selected.length; --i >= 0 ;)
      if( selected[i] == tag )
        selected.splice(i,1);
  }
  if( selected.length >= 2 )
    anchor.classList.add('selected');
  else
    anchor.classList.remove('selected');

  }
  anchor.href = prefix + re;
  anchor.href = prefix + selected.join("|");
  anchor.innerHTML = "View " + selected.length + " branches";
  // console.log("Link:",anchor.href);
}

var selected = [];
var stags = []; /* initially selected tags, not used above */
document.querySelectorAll("div.brlist > table td:first-child > input")
  .forEach( function( cbx ){
    cbx.onchange = onChange;
    cbx.disabled = false;
    if( cbx.checked )
      selected.push(cbx.parentElement.children[0].innerText);
    if( cbx.checked ){
      stags.push(cbx.parentElement.children[0].innerText);
      cbx.parentElement.parentElement.classList.add('selected');
    }
  });
anchor.href = selected.length != 0 ? prefix + selected.join("|") : "#";

if( stags.length != 0 ){
  anchor.href =  prefix + stags.join("|");
  if( stags.length >= 2 ) {
    anchor.innerHTML = "View " + stags.length + " branches";
    anchor.classList.add('selected');
  }
}

}); // window.addEventListener( 'load' ...