Changes for page Material Collection

Last modified by Judith Steinfeld on 2025/06/03 11:13

From version 55.3
edited by admin
on 2024/10/23 12:09
Change comment: There is no comment for this version
To version 55.9
edited by admin
on 2024/10/23 14:57
Change comment: There is no comment for this version

Summary

Details

XWiki.JavaScriptExtension[0]
Code
... ... @@ -1,10 +1,11 @@
1 +const tabName = "materials";
1 1  const tagCols = [
2 - ["Tag1", "CERN", "CHEP", "GPU", "VISPA"],
3 + ["Type", "lecture", "exercise", "hands-on", "solution", "tutorial"],
3 3   ["Tags", true],
4 4  ]
5 5  
6 6  document.observe('xwiki:livetable:loading', () => {
7 - const mats = document.getElementById("materials");
8 + const mats = document.getElementById(tabName);
8 8  
9 9   // coulmn data sources
10 10   const conf = JSON.parse(mats.dataset.settings);
... ... @@ -26,7 +26,7 @@
26 26   );
27 27  
28 28   // handle clicks for tags
29 - document.getElementById("materials-display").addEventListener("click", ev => {
30 + document.getElementById(`${tabName}-display`).addEventListener("click", ev => {
30 30   if (ev.button) return; // only left click
31 31   if (ev.target.nodeName !== "SPAN") return;
32 32   if (!ev.target.classList.contains("ltTag")) return;
... ... @@ -42,7 +42,7 @@
42 42   })
43 43  });
44 44  
45 -document.observe("xwiki:livetable:materials:receivedEntries", ({memo: {data}}) => {
46 +document.observe(`xwiki:livetable:${tabName}:receivedEntries`, ({memo: {data}}) => {
46 46   for (const row of data.rows) {
47 47   const ol = new DOMParser().parseFromString(row.doc_location, "text/xml").documentElement;
48 48   const li = ol.children;
... ... @@ -52,11 +52,16 @@
52 52   li[i].textContent = li[i].textContent; // remove link
53 53  
54 54   const a = li[li.length - 1].children[0];
56 + const b = a.ownerDocument.createElement("b");
57 + a.replaceWith(b);
58 + b.appendChild(a);
59 +
55 55   const u = new URL(row.link_value);
56 56   let icon;
57 - if (u.pathname.endsWith(".pdf")) icon = "file-pdf-o";
58 58   if (u.hostname.includes("github")) icon = "github";
59 59   if (u.hostname.includes("gitlab")) icon = "gitlab";
64 + if (u.hostname.includes("google")) icon = "google";
65 + if (u.pathname.endsWith(".pdf")) icon = "file-pdf-o";
60 60   if (icon) {
61 61   const s = a.ownerDocument.createElement("span");
62 62   s.textContent = " ";
... ... @@ -66,6 +66,8 @@
66 66   }
67 67   a.setAttribute("class", "wikiexternallink");
68 68   a.setAttribute("href", u.href);
75 +
76 + a.parentNode
69 69  
70 70   row.doc_location = ol.outerHTML;
71 71