Changes for page Home
Last modified by Benjamin Fischer on 2025/06/04 14:20
From version 72.13
edited by Benjamin Fischer
on 2024/11/06 11:49
on 2024/11/06 11:49
Change comment:
There is no comment for this version
To version 72.43
edited by Benjamin Fischer
on 2024/11/06 15:55
on 2024/11/06 15:55
Change comment:
There is no comment for this version
Summary
-
Page properties (1 modified, 0 added, 0 removed)
-
Objects (1 modified, 1 added, 0 removed)
Details
- Page properties
-
- Content
-
... ... @@ -19,18 +19,16 @@ 19 19 = ErUM-Data Calendar = 20 20 21 21 {{velocity output="false"}} 22 +$xwiki.ssx.use("Calendar.FullCalendar") 22 22 $xwiki.jsx.use("Calendar.FullCalendar", {'defer': false}) 23 -$xwiki.jsx.use("M occaCalendar.Code.Macro", {'defer': false})24 +$xwiki.jsx.use("Main.WebHome", {'defer': false, 'minify': false}) 24 24 {{/velocity}} 25 25 26 26 (% id="calendarCustom" %) 27 27 ((( 29 + 28 28 ))) 29 29 30 ----- 31 - 32 -{{calendar json="/bin/get/MoccaCalendar/Code/JSONService?xpage=plain&outputSyntax=plain&calendarDoc=Main.WebHome&filter=wiki&classname=MoccaCalendar.MoccaCalendarEventClass&startfield=startDate&endfield=endDate&durationfield=" right="month,plainList" editable="false"/}} 33 - 34 34 {{velocity}} 35 35 #set ($showcomments = false) 36 36 #set ($showannotations = false)
- XWiki.JavaScriptExtension[0]
-
- Code
-
... ... @@ -1,1 +1,84 @@ 1 -/* CUSTOM CALENDAR STUFF GOES HERE */ 1 +require(["jquery", "fullcalendar"], function (jq) { 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()); 7 + return ret; 8 + }; 9 + FC.defineView('monthCols', { 10 + class: FC.View.extend({ 11 + render() { 12 + const chf = this.opt("columnFormat") ?? "MMM"; 13 + const start = this.start ?? FC.moment({year: FC.moment().year()}); 14 + const months = Array(12).fill().map((_, month) => start.clone().add({month})); 15 + 16 + this.el.addClass("fc-month-cols-view").html( 17 + E( 18 + "table", 19 + E("thead", {class: "fc-head"}, 20 + E("tr", E("th"), months.map(m => E("th", m.format(chf))))), 21 + E("tbody", {class: "fc-body"}, 22 + Array(31).fill().map((_, day) => E("tr", 23 + E("th", {class: "fc-axis"}, `${day + 1}`), 24 + months.map(m => m.clone().add({day})).map(d => 25 + d.date() === day + 1 26 + ? E("td", {class: this.getDayClasses(d).join(" ")}, [d.format("dd")]) 27 + : E("td") 28 + ))) 29 + ), 30 + ) 31 + ); 32 + }, 33 + renderEvents(ev) { 34 + debugger; 35 + }, 36 + }), 37 + duration: { year: 1 }, 38 + }); 39 + 40 + const init = () => { 41 + jq("#calendarCustom").fullCalendar({ 42 + views: { 43 + month: { 44 + columnFormat: "ddd", 45 + titleFormat: "MMMM YYYY", 46 + buttonText: "month", 47 + }, 48 + monthCols: { 49 + columnFormat: "MMM", 50 + titleFormat: "YYYY", 51 + buttonText: "year", 52 + }, 53 + }, 54 + timeFormat: "h(:mm)t", 55 + axisFormat: "h(:mm)t", 56 + allDayText: "All day", 57 + eventSources: [ 58 + "/bin/get/MoccaCalendar/Code/JSONService?xpage=plain&outputSyntax=plain&calendarDoc=Main.WebHome&filter=wiki&classname=MoccaCalendar.MoccaCalendarEventClass&startfield=startDate&endfield=endDate&durationfield=&xpage=plain&outputSyntax=plain&classname=&startfield=datetime&endfield=&durationfield=&extraFields=", 59 + ], 60 + header: { 61 + left: "prev,next today", 62 + center: "title", 63 + right: "month,monthCols", 64 + }, 65 + timeFormat: "H:mm", 66 + defaultView: "month", 67 + firstDay: "1", 68 + minTime: "8:00", 69 + maxTime: "23:00", 70 + defaultDate: "2024-11-06", 71 + editable: false, 72 + eventDataTransform: event => { 73 + if (event.url.split("/")[4] === "Holidays") event.rendering = "background"; 74 + return event; 75 + }, 76 + eventRender: function (event, element) { 77 + // Render augmentation hook, use: event.html 78 + }, 79 + }); 80 + }; 81 + 82 + jq(document).ready(init); 83 +}); 84 + - Use this extension
-
... ... @@ -1,1 +1,1 @@ 1 - currentPage1 +onDemand
- XWiki.StyleSheetExtension[0]
-
- Caching policy
-
... ... @@ -1,0 +1,1 @@ 1 +default - Code
-
... ... @@ -1,0 +1,5 @@ 1 +#calendarCustom { 2 + td.fc-sat, td.fc-sun { 3 + background-color: #f5f5f5; 4 + } 5 +} - Content Type
-
... ... @@ -1,0 +1,1 @@ 1 +LESS - Parse content
-
... ... @@ -1,0 +1,1 @@ 1 +No - Use this extension
-
... ... @@ -1,0 +1,1 @@ 1 +currentPage