Changes for page Industry meets ErUM-Data

Last modified by Benjamin Fischer on 2025/03/26 10:08

From version 28.1
edited by admin
on 2024/10/23 12:47
Change comment: There is no comment for this version
To version 28.14
edited by admin
on 2024/10/23 14:09
Change comment: There is no comment for this version

Summary

Details

XWiki.JavaScriptExtension[0]
Caching policy
... ... @@ -1,0 +1,1 @@
1 +default
Code
... ... @@ -1,0 +1,86 @@
1 +const tabName = "research groups";
2 +const tagCols = [
3 + ["Community", "KAT", "KET", "KfB", "KFN", "KFS", "KFSI", "KHuK", "RDS", "beyond ErUM"],
4 + ["Experiment", "CMS", "ATLAS", "Belle2", "CTA", "Auger"],
5 + ["Tags", true],
6 +]
7 +
8 +document.observe('xwiki:livetable:loading', () => {
9 + const mats = document.getElementById(tabName);
10 +
11 + // coulmn data sources
12 + const conf = JSON.parse(mats.dataset.settings);
13 + tagCols.forEach(([name], i) => {
14 + const cn = `tags-${i}`;
15 + conf.columns.splice(conf.columns.indexOf("tags"), 1, cn);
16 + conf.columnDescriptors[cn] = {
17 + displayName: name,
18 + headerClass: "tagsCol",
19 + html: true,
20 + sortable: false,
21 + };
22 + });
23 + mats.dataset.settings = JSON.stringify(conf);
24 +
25 + // column headers
26 + mats.querySelectorAll(".xwiki-livetable-display-header .tagsCol").forEach(
27 + (v, i) => v.textContent = tagCols[i][0]
28 + );
29 +
30 + // handle clicks for tags
31 + document.getElementById(`${tabName}-display`).addEventListener("click", ev => {
32 + if (ev.button) return; // only left click
33 + if (ev.target.nodeName !== "SPAN") return;
34 + if (!ev.target.classList.contains("ltTag")) return;
35 + const tag = ev.target.textContent;
36 + ev.preventDefault();
37 + const lt = mats.__liveTable;
38 + const st = lt.tagCloud.selectedTags;
39 + if (tag in st) delete st[tag];
40 + else st[tag] = {};
41 + lt.tags = Object.keys(st);
42 + lt.clearCache();
43 + lt.showRows(1, lt.limit);
44 + })
45 +});
46 +
47 +document.observe(`xwiki:livetable:${tabName}:receivedEntries`, ({memo: {data}}) => {
48 + for (const row of data.rows) {
49 + const a = new Element("a", { href: row.URL });
50 + a.innerHTML = row.affiliation_value.split("\n").map((a, i) => i ? a : `<b class="wikiexternallink">${a}</b>`).join("<br/>");
51 + a.title = row.doc_title;
52 + if (row.content !== "-") {
53 + a.dataset.content = row.content;
54 + a.dataset.toggle = "popover"; //"tooltip";
55 + }
56 +
57 + row.affiliation = a.outerHTML;
58 + delete a;
59 +
60 + // tags
61 + const tags = new Set(row.tags_value.slice(1, -1).split(", "));
62 + tagCols.forEach(([name, ...want], i) =>
63 + row[`tags-${i}`] = (
64 + want[0] === true
65 + ? Array.from(tags)
66 + : want.filter(tag => tags.delete(tag))
67 + ).sort().map(tag => `<span class="ltTag" style="cursor:pointer;">${tag}</span>`).join(", ")
68 + );
69 + }
70 +});
71 +
72 +require(['jquery', 'bootstrap'], function($) {
73 + const ttApply = () => {
74 + $(`[id='${tabName}'] [data-toggle="tooltip"]`).popover({
75 + html: true,
76 + container: "body",
77 + trigger: "hover",
78 + }) // tooltip({ html: true, placement: "right" });
79 + };
80 +
81 + document.observe(`xwiki:livetable:${tabName}:displayComplete`, ttApply);
82 + ttApply();
83 +});
84 +
85 +
86 +
Name
... ... @@ -1,0 +1,1 @@
1 +Live Table - Research Groups
Parse content
... ... @@ -1,0 +1,1 @@
1 +No
Use this extension
... ... @@ -1,0 +1,1 @@
1 +currentPage