Changes for page Home
Last modified by Benjamin Fischer on 2025/06/04 14:20
From version 72.93
edited by Benjamin Fischer
on 2024/11/07 15:38
on 2024/11/07 15:38
Change comment:
There is no comment for this version
To version 72.42
edited by Benjamin Fischer
on 2024/11/06 15:18
on 2024/11/06 15:18
Change comment:
There is no comment for this version
Summary
-
Objects (2 modified, 0 added, 0 removed)
Details
- XWiki.JavaScriptExtension[0]
-
- Code
-
... ... @@ -3,102 +3,35 @@ 3 3 const E = (tag, ...childs) => { 4 4 const attrs = childs[0]?.constructor === Object ? childs.shift() : {}; 5 5 const ret = Element(tag, attrs); 6 - ret.append(...childs.flat() .filter(e => e));6 + ret.append(...childs.flat()); 7 7 return ret; 8 8 }; 9 - const range = num => Array(num).fill().map((_, i) => i); 10 10 FC.defineView('monthCols', { 11 11 class: FC.View.extend({ 12 - renderEvents(events) { 13 - console.debug("renderEvents", events); 11 + render() { 14 14 debugger; 15 - try { 16 - this._renderFun(events); 17 - } catch (e) { 18 - console.exception(e); 19 - } 20 - }, 21 - _renderFun(events) { 22 - const cf = this.opt("columnFormat") ?? "MMM"; 23 - const rf = this.opt("rowFormat") ?? "D"; 24 - const df = this.opt("cellFormat") ?? "dd"; 25 - const wf = this.opt("weekFormat") ?? "w"; 26 - const colspan = (df || wf) ? (1 + !!df + !!wf) : null; 13 + const chf = this.opt("columnFormat") ?? "MMM"; 14 + const start = this.start ?? FC.moment({year: FC.moment().year()}); 15 + const months = Array(12).fill().map((_, month) => start.clone().add({month})); 27 27 28 - const ys = this.start; 29 - const ye = this.end; 30 - const yv = events.slice().sort((a,b) => a.start.diff(b.start) || a.end.diff(b.end)); 31 - 32 - const cols = []; 33 - const head = []; 34 - const days = Array(31).fill().map(_ => []); 35 - 36 - if (rf) { 37 - cols.push(E("col", {class: "fc-fitCol"})); 38 - head.push(E("th")); 39 - days.forEach((arr, day) => arr.push(E("th", {class: "fc-axis"}, ys.clone().add({day}).format(rf)))); 40 - } 41 - 42 - for (const month of range(12)) { 43 - const ms = ys.clone().add({month}) 44 - const me = ms.clone().add({month: 1}); 45 - const md = me.diff(ms, "days"); 46 - const mv = yv.filter(t => ms.isBefore(t.end) && t.start.isBefore(me)); 47 - 48 - if (df) cols.push(E("col", {class: "fc-fitCol fc-fade fc-borderLeft"})); 49 - cols.push(E("col", {class: df ? null : "fc-borderLeft"})); 50 - if (wf) cols.push(E("col", {class: "fc-fitCol fc-fade"})); 51 - head.push(E("th", {colspan}, ms.format(cf))); 52 - 53 - const bgc = new Array(md); 54 - 55 - for (const day of range(31)) { 56 - if (day < md) { 57 - const ds = ms.clone().add({day}); 58 - const de = ds.clone().add({day: 1}); 59 - 60 - const oc = []; 61 - while(mv[0]?.start.isBefore(de)) { 62 - const v = mv.shift(); 63 - const d = Math.ceil(v.end.max(me).diff(ds, "days", true)); 64 - if (v.rendering == "background") { 65 - if (v.color) 66 - for (const i of range(d)) 67 - bgc[day + i] = v.color; 68 - } else { 69 - const href = v.html.match(/<span class="wikiexternallink"><a href="([^"]+)">\1</)?.[1] ?? v.url; 70 - const e = E("div", E("a", {href}, v.title)); 71 - e.style.height = `${100 * d}%`; 72 - if (v.color) e.style.borderColor = e.style.backgroundColor = v.color; 73 - if (v.textColor) e.style.color = v.textColor; 74 - if (v.start.isBefore(ms)) e.classList.add("fc-cut-start"); 75 - if (me.isBefore(v.end)) e.classList.add("fc-cut-end"); 76 - oc.push(e); 77 - // TODO: soft-columns 78 - } 79 - } 80 - 81 - const style = bgc[day] && `background-color: ${bgc[day]};`; 82 - const dc = this.getDayClasses(ds); 83 - const da = sub => ({class: dc.concat(sub).join(" "), style}); 84 - if (df) days[day].push(E("td", da("fc-dayVal"), ds.format(df))); 85 - days[day].push(E("td", da("fc-mainVal"), oc)); 86 - if (wf) days[day].push(E("td", da("fc-weekVal"), ds.weekday() ? "" : ds.format(wf))); 87 - } else 88 - days[day].push(E("td", {colspan})); 89 - } 90 - } 91 - 92 - 93 93 this.el.addClass("fc-month-cols-view").html( 94 94 E( 95 95 "table", 96 - E("colgroup", cols), 97 - E("thead", {class: "fc-head"}, E("tr", head)), 98 - E("tbody", {class: "fc-body"}, days.map(d => E("tr", d))), 20 + E("thead", {class: "fc-head"}, 21 + E("tr", E("th"), months.map(m => E("th", m.format(chf))))), 22 + E("tbody", {class: "fc-body"}, 23 + Array(31).fill().map((_, day) => E("tr", 24 + E("th", {class: "fc-axis"}, `${day + 1}`), 25 + months.map(m => m.clone().add({day})).map(d => 26 + d.date() === day + 1 27 + ? E("td", {class: this.getDayClasses(d).join(" ")}, [d.format("dd")]) 28 + : E("td") 29 + ))) 30 + ), 99 99 ) 100 100 ); 101 - } 33 + 34 + }, 102 102 }), 103 103 duration: { year: 1 }, 104 104 }); ... ... @@ -113,7 +113,6 @@ 113 113 }, 114 114 monthCols: { 115 115 columnFormat: "MMM", 116 - weekFormat: "W", 117 117 titleFormat: "YYYY", 118 118 buttonText: "year", 119 119 }, ... ... @@ -130,7 +130,7 @@ 130 130 right: "month,monthCols", 131 131 }, 132 132 timeFormat: "H:mm", 133 - defaultView: "month Cols",65 + defaultView: "month", 134 134 firstDay: "1", 135 135 minTime: "8:00", 136 136 maxTime: "23:00",
- XWiki.StyleSheetExtension[0]
-
- Code
-
... ... @@ -1,63 +1,5 @@ 1 -#calendarCustom .fc{1 +#calendarCustom { 2 2 td.fc-sat, td.fc-sun { 3 3 background-color: #f5f5f5; 4 - &.fc-dayVal { 5 - background-color: #f5f5f5 !important; 6 - } 7 7 } 8 - .fc-month-cols-view > table { 9 - table-layout: auto; 10 - td, th { 11 - border-width: 0px; 12 - } 13 - col.fc-fitCol { 14 - width: 1px; 15 - } 16 - .fc-body { 17 - tr:nth-child(4n+3) > * { 18 - border-top: 1px solid #ddd; 19 - } 20 - tr:nth-child(4n+5) > * { 21 - border-top: 1px solid #bbb; 22 - } 23 - tr:hover { 24 - filter: brightness(0.95); 25 - } 26 - td.fc-mainVal { 27 - position: relative; 28 - & > div { 29 - z-index: 5; 30 - position: absolute; 31 - width: 100%; 32 - overflow: hidden; 33 - border-radius: 4px; 34 - &.fc-cut-start { 35 - border-top-left-radius: 0px; 36 - border-top-right-radius: 0px; 37 - } 38 - &.fc-cut-end { 39 - border-bottom-left-radius: 0px; 40 - border-bottom-right-radius: 0px; 41 - } 42 - &:hover { 43 - width: auto; 44 - max-width: 10vw; 45 - height: auto !important; 46 - z-index: 10; 47 - } 48 - & > a { 49 - display: block; 50 - color: inherit; 51 - background-color: inherit; 52 - } 53 - } 54 - } 55 - td.fc-weekVal { 56 - text-align: right; 57 - } 58 - .fc-fade2 { 59 - opacity: 0.3; 60 - } 61 - } 62 - } 63 63 }