MagicMirror Forum
    • Recent
    • Tags
    • Unsolved
    • Solved
    • MagicMirror² Repository
    • Documentation
    • 3rd-Party-Modules
    • Donate
    • Discord
    • Register
    • Login
    A New Chapter for MagicMirror: The Community Takes the Lead
    Read the statement by Michael Teeuw here.

    MMM-CalendarExt3

    Scheduled Pinned Locked Moved Utilities
    689 Posts 82 Posters 2.8m Views 86 Watching
    Loading More Posts
    • Oldest to Newest
    • Newest to Oldest
    • Most Votes
    Reply
    • Reply as topic
    Log in to reply
    This topic has been deleted. Only users with topic management privileges can see it.
    • M Offline
      MMRIZE @CurlyQ12391
      last edited by

      @CurlyQ12391
      I think it is possible with “manipulateDateCell”. I will show example after my return from a business trip in a few days.

      1 Reply Last reply Reply Quote 0
      • M Offline
        MMRIZE @CurlyQ12391
        last edited by MMRIZE

        @CurlyQ12391

        {
          module: "MMM-CalendarExt3",
          position: "bottom_bar",
          config: {
            mode: 'month',
            manipulateDateCell: (dom, events) => {
              let date = new Date(+dom.dataset.date)
              if (date.getMonth() == 8 && date.getDate() == 2) { // specific cell by absolute date
                dom.classList.add('specialHoliday')
                dom.style.backgroundColor = 'red'
                // do whatever you want.
              }
        
              if (events.some(e => e.title.search("Gelber") > -1)){ // specific cell by event
                dom.classList.add('specialEvent')
                dom.style.backgroundColor = 'yellow'
                // do whatever you want.
              }
            }
          }
        },
        

        107e15de-2d5a-4b38-bab6-0eb97f9dbe53-image.png

        1 Reply Last reply Reply Quote 0
        • N Offline
          nekreg9
          last edited by

          How can I delay the start of the MMM-CalendarExt3 module? I have the default calendar module showing and I can see the 3 calendars load events into it. The problem is CalendarExt3 starts while the calendars are still loading. I changed the refreshInterval to more frequent to deal with that, but really a delay start would be more efficient.

          I supposed this would only be a problem while I am troubleshooting.

          M 1 Reply Last reply Reply Quote 0
          • M Offline
            MMRIZE @nekreg9
            last edited by

            @nekreg9
            There is a configurable option “waitFetch”.
            But I doubt your real issue would be that. Because, CX3 starts rendering after one calendar which has at least one event have fetched successfully. (and in a “waitFetch”, no more calendar is fetched)
            So if your CX3 starts late, It means your events source provider(usually default calendar module) might have timing issue to fetch calendars(e.g. too frequent fetch cycles or something else)

            1 Reply Last reply Reply Quote 0
            • K Offline
              Kaisies 0
              last edited by

              Is it at all possible to alter the grid to only divide the screen into 5 sections? I was able to alter code to only show m-f, but the sat and sun sections are still there. Just completely blank. For the life of me I can’t figure out where in the code it sets this part up.

              M 2 Replies Last reply Reply Quote 0
              • M Offline
                MMRIZE @Kaisies 0
                last edited by

                @Kaisies-0
                1f6f210b-dd20-4887-b394-f2525233ad7b-image.png

                1 Reply Last reply Reply Quote 0
                • M Offline
                  MMRIZE @Kaisies 0
                  last edited by MMRIZE

                  @Kaisies-0
                  Anyway,
                  For the firstDayOfWeek: 1 (Week starts from Monday), It could be achieved like below;

                  .CX3 .weekGrid {
                    grid-template-columns: repeat(5, [cell-start] 1fr [cell-end]) 0fr 0fr;
                  }
                  
                  .CX3 .weekday.weekday_6,
                  .CX3 .weekday.weekday_0 {
                    display: none;
                  }
                  
                  .CX3 .cell.weekday_6,
                  .CX3 .cell.weekday_0 {
                    display: none;
                  }
                  

                  This will work.
                  ca91b736-4bef-46da-8af9-93877ca4a0e0-image.png
                  But for the firstDayOfWeek:0 or another case, .weekGrid should be adjusted more heavily. And not sure side-effects.

                  BKeyportB 1 Reply Last reply Reply Quote 0
                  • BKeyportB Offline
                    BKeyport Module Developer @MMRIZE
                    last edited by

                    @MMRIZE I wanna do things a little different (of course) - what I’d like is to have CX3 display the calendar symbol only. No title, preferably horizontally. I can get the title out of the way, but the rest of it I’m not quite sure how - for some reason I’m having a hard time deconstructing how you build.

                    Thanks!

                    The "E" in "Javascript" stands for "Easy"

                    M 2 Replies Last reply Reply Quote 0
                    • M Offline
                      MMRIZE @BKeyport
                      last edited by

                      @BKeyport

                      Is this what you want?
                      ff1c0f88-fc4b-4def-b904-2e49216dc86e-image.png

                      BKeyportB 1 Reply Last reply Reply Quote 0
                      • M Offline
                        MMRIZE @BKeyport
                        last edited by MMRIZE

                        @BKeyport
                        What a coincidence.
                        Yesterday, a user asked me how to manipulate day-cell and remove events together at the same time. It is ideally the same with your purpose.

                        To reach your goal; 1) extracting an icon from an event and 2) putting it into the daycell would be needed.
                        However, manipulateDayCell is executed after all events processes are done, so it cannot be achieved with CX3 alone. With manipulateDayCell, you can extract icons and inject them into the daycell, but you cannot remove original events together easily.

                        With MMM-ModuleMonkeyPatch, you can remove events after rendering (before revealing)

                        /* In MMM-CalendarExt3 config */
                          manipulateDateCell: (cellDom, events) => {
                            let body = cellDom.querySelector('.cellBody')
                            Array.from(events).forEach((e) => {
                              if (Array.isArray(e.symbol) && e.symbol.length > 0) {
                                let icon = document.createElement('span') 
                                icon.className = e.symbol
                                body.appendChild(icon)
                                icon.style.color = e.color
                              }
                              
                            })
                          },
                          maxEventLines: 1,
                        
                        /* MMM-ModuleMonkeyPatch */
                        {
                          module: "MMM-ModuleMonkeyPatch",
                          config: {
                            patches: [
                              {
                                module: "MMM-CalendarExt3",
                                method: "getDom",
                                patch: function (original, args) {
                                  let dom = original(args)
                                  let target = Array.from(dom.querySelectorAll('.event')) || []
                                  target.forEach((e) => {
                                    e.style.display = 'none'
                                  })
                                  return dom
                                }
                              }
                            ]
                          }
                        },
                        
                        

                        These codes are just concept-proof. There are many holes like overflowed events, order of events, … I bet you can improve codes for your purpose.

                        BKeyportB 1 Reply Last reply Reply Quote 0
                        • BKeyportB Offline
                          BKeyport Module Developer @MMRIZE
                          last edited by

                          @MMRIZE that would be perfect, yes.

                          The "E" in "Javascript" stands for "Easy"

                          1 Reply Last reply Reply Quote 0
                          • BKeyportB Offline
                            BKeyport Module Developer @MMRIZE
                            last edited by

                            @MMRIZE actually, I don’t need to extract - the symbols are set by default Calendar app, so I’d be using “useSymbol:True” to get them only.

                            The "E" in "Javascript" stands for "Easy"

                            1 Reply Last reply Reply Quote 0
                            • X Offline
                              XDmToter
                              last edited by

                              I am having trouble integrating MMM-CalendarExt3 with MMM-GoogleCalendar.
                              I’m not sure what else is required other than adding a “name” to the Google Calendar and then listing that in the “calendarSet” parameter in CalendarExt3.

                              Can anyone point out what I am missing?

                              Here is my config:

                              {
                                          module: 'MMM-GoogleCalendar',
                                          header: "Family Calendar",
                                          position: "top_left",
                                          config: {
                                              maximumEntries: 4,
                                              broadcastPastEvents: true,
                                              calendars: [
                                                {
                                                  symbol: "calendar-week",
                                                  calendarID: "XXXXXXXXXXXXXXXXXXXX@group.calendar.google.com",
                                                  name: 'famCal',
                                                },
                                              ],
                                          }
                                      },
                                      {
                                          module: "MMM-CalendarExt3",
                                          position: "bottom_bar",
                                          title: "Family Calendar",
                                          config: {
                                              mode: "week",
                                              instanceId: "basicCalendar",
                                              calendarSet: ['famCal'],
                                          }
                                      },
                              

                              I see the List view from MMM-GoogleCalendar, but I just get a blank calendar from MMM-CalendarExt3

                              MM-Blank-Calendar.png

                              M 2 Replies Last reply Reply Quote 0
                              • M Offline
                                MMRIZE @XDmToter
                                last edited by

                                @XDmToter
                                Read this. https://github.com/MMRIZE/MMM-CalendarExt3#compatible-with-randombrainstormermmm-googlecalendar

                                By the way, this is a pure question.
                                Google Calendar provides iCAL format(.ics), so the default calendar module can also parse it. Why people use MMM-GoogleCalendar instead of the default calendar? Is there any special thing?
                                I ask this because one of the most frequently asked issues is how to use with MMM-GoogleCalendar.

                                X 1 Reply Last reply Reply Quote 0
                                • M Offline
                                  MMRIZE @XDmToter
                                  last edited by

                                  @XDmToter
                                  Anyway, I requested PR of MMM-GoogleCalendar to solve this incompatible broadcasting. When @randomBrainstorm adopts the PR, this issue will be solved.

                                  1 Reply Last reply Reply Quote 0
                                  • X Offline
                                    XDmToter @MMRIZE
                                    last edited by

                                    @MMRIZE Thank you for your reply. As I understand it, in order to use an ICal URL from Google Calendar, you have to make your calendar Public. Using MMM-GoogleCalendar is Authenticated using an API Token, so your calendar does Not need to be public.

                                    I tried adding the “preProcessor” settings, but I still get a blank calendar. Does this get added to the “config” section, or the “module” section? I put it inside the config array.

                                            {
                                                module: "MMM-CalendarExt3",
                                                position: "bottom_bar",
                                                title: "Family Calendar",
                                                config: {
                                                    mode: "week",
                                                    instanceId: "basicCalendar",
                                                    calendarSet: ['famCal'],
                                                    preProcessor: (e) => {
                                                        if (e.start?.dateTime) {
                                                            e.startDate = new Date(e.start.dateTime).valueOf()
                                                        } else if (e.start?.date) {
                                                            e.startDate = new Date(`${e.start.date}T00:00:00`).valueOf()
                                                        }
                                     
                                                        if (e.end?.dateTime) {
                                                            e.endDate = new Date(e.end.dateTime).valueOf()
                                                        } else if (e.end?.date) {
                                                            e.endDate = new Date(`${e.end.date}T00:00:00`).valueOf()
                                                        }
                                     
                                                        e.title = e.summary
                                                        e.fullDayEvent = (e.start?.date) ? true : false
                                                        return e
                                                        }
                                                }
                                            }
                                    
                                    M G 2 Replies Last reply Reply Quote 0
                                    • M Offline
                                      MMRIZE @XDmToter
                                      last edited by

                                      @XDmToter
                                      Your configuration seems all right unless you may be missing some brackets matching or commas at the end of the continuous module definitions.

                                      In MM screen, Ctrl+Shift+i will open dev console. You may see suspicious error messages if they happen.

                                      X 1 Reply Last reply Reply Quote 0
                                      • G Offline
                                        gonzonia @XDmToter
                                        last edited by

                                        @XDmToter
                                        There’s a way to get an iCal URL without making it public. I see this in my “Settings and Sharing” section of Google Calendar. Screenshot 2023-10-11 at 2.28.40 PM.png

                                        M 1 Reply Last reply Reply Quote 0
                                        • M Offline
                                          MMRIZE @gonzonia
                                          last edited by

                                          @gonzonia @XDmToter
                                          But anyway, for shared-calendar (e.g. Family calendar), MMM-GoogleCalendar is worthy. (And there would be the possibility to implement a reminder feature also.)

                                          I discussed this issue with @randomBrainstorm, and I can bet the fixed version of MMM-GoogleCalendar will be released soon. At that time, the need for conversion will be gone.

                                          BKeyportB 1 Reply Last reply Reply Quote 0
                                          • BKeyportB Offline
                                            BKeyport Module Developer @MMRIZE
                                            last edited by

                                            @MMRIZE So, I’ve expanded my calendar larger for a DakBoard like setup, and noticed some cosmetic problems, mostly in background highlighting. Can you take a look and see what’s up?

                                            Also, I’d like the icons (using the symbols from calendar) to be row flexed not column flexed.

                                            Thanks.

                                            https://ibb.co/VL3qnsk

                                            		{
                                            			module: "MMM-CalendarExt3",
                                            			//disabled: true,
                                            			position: "top_right",
                                            			config: {
                                            				fontSize: '31.5px',
                                            				eventHeight: '36px',
                                            				animationSpeed: 0, 
                                            				mode: "month",
                                            				headerTitleOptions: {
                                            					month: 'long',
                                            					year: 'numeric', 
                                            				},
                                            				minimalDaysOfNewYear: 1,
                                            				refreshInterval: 60000,
                                            				useWeather: false,
                                            				useSymbol: true,
                                            				maxEventLines: 4,
                                            				firstDayOfWeek: 0,
                                            				calendarSet: ["Main", "Holidays", "Seahawks", "Sounders", "Bluejays", "Mariners", "Kraken", "XFL"],
                                            			},
                                            		},
                                            ``` css
                                            /* CalendarExt3 */
                                            .CX3 {
                                              --celllinecolor: #666;
                                              --cellbgcolor: rgba(0, 0, 0, 0.5);
                                              --cellheaderheight: 25px;
                                              --cellfooterheight: 2px;
                                              --defaultcolor: #FFF;
                                              --eventheight: calc(var(--fontsize) + 4px);
                                              --totalheight: calc(var(--eventheight) * var(--maxeventlines));
                                              --displayEndTime: none;
                                              --displayWeatherTemp: none;
                                              font-size: var(--fontsize);
                                              color: var(--defaultcolor);
                                              line-height: calc(var(--eventheight));
                                              min-width: 1280px; 
                                            }
                                            
                                            .module.MMM-CalendarExt3 .module-header {
                                            	color: white;
                                            	background-color: green;
                                            	border-radius: 8px;
                                            	text-transform: unset;
                                            	font-size: var(--font-size-medium);
                                            	line-height: var(--font-size-small)+5;
                                            	border: none;
                                              }
                                            
                                            .CX3 .thisMonth {
                                              background-color: rgba(0, 0, 0, 0.2);
                                            }
                                            
                                            /* get rid of unwanted elements */
                                            .CX3 .event.singleday .headline:not(.useSymbol)::before,
                                            .CX3 .event.singleday .headline.useSymbol .symbol.noSymbol::before {
                                              content: '⬤';
                                              color: var(--calendarColor);
                                              display: none;
                                              padding-right: 2px;
                                              font-size: 75%;
                                            }
                                            
                                            .CX3 .event:not(.fullday) .headline .time {
                                              display: none;
                                              padding-right: 2px;
                                              font-size: 75%;
                                              color: #EEE;
                                            }
                                            
                                            .CX3 .weekday_0 {
                                              color: #FFF;
                                            }
                                            
                                            .CX3 .weekday_6 {
                                              color: #FFF;
                                            }
                                            
                                            .CX3 .cw {
                                              font-size: 80%;
                                              color: goldenrod;
                                              display: none;
                                            }
                                            
                                            .CX3 .cw::before {
                                              content: 'CW '
                                            }
                                            
                                            .CX3 .title {
                                            	display: none;
                                            }
                                            

                                            The "E" in "Javascript" stands for "Easy"

                                            M 2 Replies Last reply Reply Quote 0

                                            Hello! It looks like you're interested in this conversation, but you don't have an account yet.

                                            Getting fed up of having to scroll through the same posts each visit? When you register for an account, you'll always come back to exactly where you were before, and choose to be notified of new replies (either via email, or push notification). You'll also be able to save bookmarks and upvote posts to show your appreciation to other community members.

                                            With your input, this post could be even better 💗

                                            Register Login
                                            • 1
                                            • 2
                                            • 16
                                            • 17
                                            • 18
                                            • 19
                                            • 20
                                            • 34
                                            • 35
                                            • 18 / 35
                                            • First post
                                              Last post
                                            Enjoying MagicMirror? Please consider a donation!
                                            MagicMirror created by Michael Teeuw.
                                            Forum managed by Sam, technical setup by Karsten.
                                            This forum is using NodeBB as its core | Contributors
                                            Contact | Privacy Policy