Read the statement by Michael Teeuw here.
MMM-CalendarExt3Agenda - how to hide days with no events and hide/filter out events with a keywords
-
.Dear Sam, @sdetweil ,
shame on me!
This is dumb.
thanks a lot for this hint.If you are doing it right - it works …
I’m terribly embarrassed.
Regards,
Ralf -
@rkorell we all learn new things every day…
-
@sdetweil , yes indeed.
After making a little bit of progress now I’m not able to understand why the module doosn’t do what I expect…
I try to change the icons as well as the color of the calendar events.
Icon works fine, color for icon as well but the “event” itself doesn’t change color.I’ve figured out that the searchword is found - because it triggers the icon color as well as the icon color (regardless that the current searchword contains an German “Umlaut” (‘ü’).
I found a code snippet here and modified it to my requirements.
ev.color is the attribute I’ve used - this seems the right one.
But It only changes the icon color…{ module: "MMM-CalendarExt3Agenda", position: "top_left", //header: "Wichtige Termine", config: { eventTransformer: (ev) => { const customEvents = [ { keyword: "Gelber Sack", symbol: ["fa-solid fa-arrows-spin"], color: "yellow" }, { keyword: "Restmüll", symbol: ["fa-regular fa-trash-can"], color: "green" }, { keyword: "Biomüll", symbol: ["fa-regular fa-trash-can"], color: "brown" }, { keyword: "Papier", symbol: ["fa-solid fa-dumbbell"], color: "blue" }, { keyword: "Urlaub", symbol: ["fa-solid fa-dumbbell"], color: "cyan" }, ] const found = customEvents.find((condition) => { return ev.title.search(condition.keyword) !== -1 }) if (found) { ev.icon = [ found.symbol ] ev.color = found.color } if (ev.title.search('Restmüll') !== -1) { ev.symbol = [ "fa-solid fa-cake-candles" ] } if (ev.title.search('Papier') !== -1) { ev.symbol = [ "fa-regular fa-trash-can" ] } if (ev.title.search('Gelber Sack') !== -1) { ev.symbol = [ "fa-solid fa-arrows-spin" ] } if (ev.title.search('Biomüll') !== -1) { ev.symbol = [ "fa-regular fa-trash-can" ] } if (ev.title.search('Geb.') !== -1) { ev.title = ev.title.replace('Geb.', '') ev.symbol = [ "fa-solid fa-cake-candles" ] } return ev }, // useWeather: false , showMiniMonthCalendar: false, //onlyEventDays: 10 -- Nur Tage mit terminen anzeigen ist in der custom.css eingetragen, DAS funktioniert... } },
Where is my error now?
:-)
TIA for any hint.
Regards,
Ralf -
-
@sdetweil , thanks anyway!
should I place a separate posting?
Regards,
Ralf -
@rkorell no, my reference of his userid will send him here when he has time. just understand that this is all volunteer, as time is available, no commitment for support.
maybe others will jump in.
-
@sdetweil , yes, I’m fully aware of volunteer.
So thanks a LOT!Ralf
-
Dear Sam (@sdetweil ),
short feedbacj from this end :-)
I was able to found a compromize.
I’ve found a months old thread with the guy whose mirror I saw and @MMRIZE regardins an equivalent “problem”.
The mentioned CSS solution doesn’t work for me - for whatever reason/* In your custom.css */ .CX3 .event.singleday .headline .title, .CX3 .event.singleday .headline .time { color: var(--calendarColor); }
Doesn’t colour the textline.
But in the same discoussion I identified the “idea” to use the fact that whole day events DO use the given color as I define in my config.
So now the apperance isO.K.For reference to others who might have same issues the whole block here:
{ module: "MMM-CalendarExt3Agenda", position: "top_left", //header: "Wichtige Termine", config: { eventTransformer: (ev) => { const customEvents = [ { keyword: "Restmüll", symbol: ["fa-regular fa-trash-can"], color: "grey" }, { keyword: "Papier", symbol: ["fa-solid fa-dumbbell"], color: "blue" }, { keyword: "Gelber Sack", symbol: ["fa-solid fa-arrows-spin"], color: "yellow" }, { keyword: "Biomüll", symbol: ["fa-regular fa-trash-can"], color: "brown" }, { keyword: "Restmüll & Papier & Gelber Sack", symbol: ["fa-regular fa-trash-can"], color: "fuchsia" }, { keyword: "Urlaub", symbol: ["fa-solid fa-dumbbell"], color: "cyan" }, ] const found = customEvents.find((condition) => { return ev.title.search(condition.keyword) !== -1 }) if (found) { ev.icon = [ found.symbol ] ev.color = found.color } if (ev.title.search("Restmüll") !== -1) { ev.symbol = [ "fa-regular fa-trash-can" ], ev.isFullday = [true], ev.color = "grey" } if (ev.title.search("Papier") !== -1) { ev.symbol = [ "fa-regular fa-trash-can" ], ev.isFullday = [true], ev.color = "blue" } if (ev.title.search("Gelber Sack") !== -1) { ev.symbol = [ "fa-solid fa-arrows-spin" ], ev.isFullday = [true], ev.color = "yellow" } if (ev.title.search("Biomüll") !== -1) { ev.symbol = [ "fa-regular fa-trash-can" ], ev.isFullday = [true], ev.color = "brown" } if (ev.title.search("Restmüll & Papier & Gelber Sack") !== -1) { ev.symbol = [ "fa-regular fa-trash-can" ], ev.isFullday = [true], ev.title = "Alle Tonnen", ev.color = "fuchsia" } if (ev.title.search("Urlaub") !== -1) { ev.symbol = [ "fa-regular fa-trash-can" ], ev.isFullday = [true], ev.color = "green" } return ev },
Thanks for your support!
Warmest regards,
Ralf -
@rkorell glad you have it working
-
@rkorell
CX3A is identified with CSS selector “.CX3A
” to be distinguished fromCX3
.