Changes for page Home
Last modified by Benjamin Fischer on 2025/06/04 14:20
From version 72.26
edited by Benjamin Fischer
on 2024/11/06 13:17
on 2024/11/06 13:17
Change comment:
There is no comment for this version
To version 72.45
edited by Benjamin Fischer
on 2024/11/07 11:55
on 2024/11/07 11:55
Change comment:
There is no comment for this version
Summary
-
Page properties (1 modified, 0 added, 0 removed)
-
Objects (1 modified, 0 added, 0 removed)
Details
- Page properties
-
- Content
-
... ... @@ -20,9 +20,8 @@ 20 20 21 21 {{velocity output="false"}} 22 22 $xwiki.ssx.use("Calendar.FullCalendar") 23 -$xwiki.ssx.use("MoccaCalendar.Code.Macro") 24 24 $xwiki.jsx.use("Calendar.FullCalendar", {'defer': false}) 25 -$xwiki.jsx.use("M occaCalendar.Code.Macro", {'defer': false})24 +$xwiki.jsx.use("Main.WebHome", {'defer': false, 'minify': false}) 26 26 {{/velocity}} 27 27 28 28 (% id="calendarCustom" %)
- XWiki.JavaScriptExtension[0]
-
- Code
-
... ... @@ -1,14 +1,88 @@ 1 1 require(["jquery", "fullcalendar"], function (jq) { 2 2 const FC = jq.fullCalendar; 3 + const E = (tag, ...childs) => { 4 + const attrs = childs[0]?.constructor === Object ? childs.shift() : {}; 5 + const ret = Element(tag, attrs); 6 + ret.append(...childs.flat().filter(e => e)); 7 + return ret; 8 + }; 9 + const range = num => Array(num).fill().map((_, i) => i); 3 3 FC.defineView('monthCols', { 4 4 class: FC.View.extend({ 5 - initialize() { 6 - console.log("foo bar"); 12 + render() {}, 13 + renderEvents(events) { 14 + const cf = this.opt("columnFormat") ?? "MMM"; 15 + const rf = this.opt("rowFormat") ?? "dd"; 16 + const df = this.opt("cellFormat") ?? "ddd"; 17 + const wf = this.opt("weekFormat") ?? "w"; 18 + const colspan = (df || wf) ? (1 + !!df + !!wf) : null; 19 + 20 + const ys = this.start; 21 + const ye = this.end; 22 + const yv = events.slice().sort((a,b) => a.start.diff(b.start) || a.end.diff(b.end)); 23 + 24 + const head = []; 25 + const days = Array(31).fill().map(_ => []); 26 + 27 + if (rf) { 28 + head.push(E("th")); 29 + days.forEach((arr, day) => arr.push(E("th", {class: "fc-axis"}, ys.clone().add({day}).format(rf)))); 30 + } 31 + 32 + for (const month in Array(12).fill()) { 33 + const ms = ys.clone().add({month}) 34 + const me = ms.clone().add({month: 1}); 35 + const md = me.diff(ms, "days"); 36 + const mv = yv.filter(t => ms.isBefore(t.end) || t.start.isBefore(me)); 37 + 38 + head.push(E("th", {colspan}, ms.format(cf))); 39 + 40 + const bgc = new Array(md); 41 + 42 + for (let day = 0; i < 31; i++) { 43 + if (i < md) { 44 + const ds = ms.clone().add({day}); 45 + const de = ds.clone().add({day: 1}); 46 + 47 + const oc = []; 48 + while(mv[0]?.isBefore(de)) { 49 + const v = mv.shift(); 50 + const d = Math.ceil(v.end.min(me).diff(ds, "days", true)); 51 + if (t.rendering == "background") 52 + if (t.color) 53 + for (let i=0; i<d; i++) 54 + bgc[day + i] = t.color; 55 + else { 56 + const e = E("div", t.title); 57 + e.style.height = `${100 * d}%`; 58 + if (t.color) e.style.borderColor = e.style.backgroundColor = t.color; 59 + if (t.textColor) e.style.color = t.textColor; 60 + oc.push(e); 61 + // TODO: soft-columns 62 + } 63 + } 64 + 65 + const da = {class: this.getDayClasses(d).join(" ")}; 66 + if (df) days[i].push(E("td", da, ds.format(df))); 67 + if (bgc[day]) da.style = `background-color: ${bgc[day]};`; 68 + days[i].push(E("td", da, oc)); 69 + if (wf) days[i].oush(E("td", ds.weekday() ? "" : ds.format(wf))); 70 + } else 71 + days[i].push(E("td", {colspan})); 72 + } 73 + } 74 + 75 + 76 + this.el.addClass("fc-month-cols-view").html( 77 + E( 78 + "table", 79 + E("thead", {class: "fc-head"}, E("tr", head)), 80 + E("tbody", {class: "fc-body"}, days.map(d => E("tr", d))), 81 + ) 82 + ); 83 + 84 + //debugger; 7 7 }, 8 - renderSekeleton() { 9 - this.el.addClass("fc-month-cols-view").html(""); 10 - debugger; 11 - }, 12 12 }), 13 13 duration: { year: 1 }, 14 14 }); - Use this extension
-
... ... @@ -1,1 +1,1 @@ 1 - currentPage1 +onDemand