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.

    Bathroom mirror

    Scheduled Pinned Locked Moved Show your Mirror
    13 Posts 7 Posters 5.7k Views 10 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.
    • S Offline
      stephanvdplas
      last edited by stephanvdplas

      We did a total make over of our bathroom last month, including all new custom made furniture. This was the opportunity to build in a magic mirror!
      it was pretty exciting to see everything come together, the 32 inch display, the 80x80 cm 80%/20% mirror, the raspberry pi (also functioning as LMS player, synchronised with the rest of the house), the 6 inch speakers, the hue lights, all in a self-designed bathroom cabinet.
      But the result is sublime. In the attached video and pictures, you can see the result.

      Used modules in standard mode:
      Clock - RSS feed - Weather

      When clicking a (z-wave) button (which runs a script on a domoticz server) the other modules become visible:

      clock      -    MMM-RSS-FEED       -       Weather
      calendar                                   Weather (upcoming hours)
                                                 Weather (upcoming days)
                                                 MMM-JsonTable
      MMM-iFrame                                 nstreinen
                        Newsfeed
      

      The RSS feed is used for the bibleverse of the day.
      The iFrame is used for a now playing frame for the LMS player.
      The JSON tables show who is at home (and since when) and the train departure times to my office’s town.

      Hope it inspirese you. Leave your questions in the replies.

      alt text
      alt text
      alt text
      alt text
      alt text
      alt text
      alt text
      https://photos.app.goo.gl/SUtsBfW13a42gFFMA

      KristjanESPERANTOK W 2 Replies Last reply Reply Quote 10
      • KristjanESPERANTOK Offline
        KristjanESPERANTO Module Developer @stephanvdplas
        last edited by

        Really nice work! 👏

        S 1 Reply Last reply Reply Quote 1
        • S Offline
          stephanvdplas @KristjanESPERANTO
          last edited by

          @KristjanESPERANTO said in Bathroom mirror:

          Really nice work! 👏

          Thanks!

          1 Reply Last reply Reply Quote 0
          • zdenekZ Offline
            zdenek
            last edited by

            @stephanvdplas said in Bathroom mirror:

            https://photos.app.goo.gl/SUtsBfW13a42gFFMA

            Amazing. Just few questions:

            • cau u please post the JSON, how you did it?
            • how you make it on/off by switch?
            • and the most important - do u have some pics/videos of the “wood” part? (mountinng, cabling…)

            thanks

            S 2 Replies Last reply Reply Quote 0
            • S Offline
              stephanvdplas @zdenek
              last edited by

              @zdenek said in Bathroom mirror:

              @stephanvdplas said in Bathroom mirror:

              https://photos.app.goo.gl/SUtsBfW13a42gFFMA

              Amazing. Just few questions:

              • cau u please post the JSON, how you did it?
              • how you make it on/off by switch?
              • and the most important - do u have some pics/videos of the “wood” part? (mountinng, cabling…)

              thanks

              • I will post the JSON in the next post together with screendumps.

              • The switching is done via MMM-remote setting modules on/off. The button triggers a scene in Domoticz which sets the modules on (and automatically off after 45 minutes) or off via commands like http://192.168.x.y:8080/remote?action=SHOW&module=module_5_weather and http://192.168.x.y:8080/remote?action=HIDE&module=module_5_weather.

              • I have no pics of vids of the creation and as such cannot show you how the monitor is hung up. All I know is that a painted-black wooden panel is set behind the mirror (with dual side mirror tape), where the screen fits in perfectly and something is clamping the screen to the glass.
                The pi and the power wall outlets are in the cabinet above the mirror, so only 2 cables (power ande hdmi) are drawn from the screen to that cabinet.

              1 Reply Last reply Reply Quote 0
              • S Offline
                stephanvdplas @zdenek
                last edited by stephanvdplas

                @zdenek

                /* MagicMirror² Config Sample
                 * By Michael Teeuw https://michaelteeuw.nl
                 * MIT Licensed.
                 */
                let config = {
                	address: "0.0.0.0",	
                	port: 8080,
                	basePath: "/",			
                	useHttps: false, 		// Support HTTPS or not, default "false" will use HTTP
                	httpsPrivateKey: "", 	// HTTPS private key path, only require when useHttps is true
                	httpsCertificate: "", 	// HTTPS Certificate path, only require when useHttps is true
                
                	language: "nl",
                	locale: "nl-NL",
                	logLevel: ["INFO", "LOG", "WARN", "ERROR"], // Add "DEBUG" for even more logging
                	timeFormat: 24,
                	units: "metric",
                
                	modules: [
                		{
                			module: "alert",
                		},
                		{
                			module: 'MMM-Remote-Control',
                			config: {
                				apiKey: '01***d4',
                                customCommand: {
                                        monitorOnCommand: "sudo /usr/bin/vcgencmd display_power 1",
                                        monitorOffCommand: "sudo /usr/bin/vcgencmd display_power 0"
                                },
                                showModuleApiMenu: false,				
                			}
                		},		
                		{
                			module: "newsfeed",
                			position: "bottom_bar",
                			config: {
                				feeds: [
                					{
                						title: "Nu.nl Algemeen",
                						url: "https://www.nu.nl/rss/Algemeen"
                					},
                					{
                						title: "RTV Oost",
                						url: "http://rss.rtvoost.nl/"
                					},
                					{
                						title: "Stentor Zwolle",
                						url: "https://www.destentor.nl/zwolle/rss.xml"
                					},
                					{
                						title: "Stadshagen Nieuws",
                						url: "https://www.stadshagennieuws.nl/feed"
                					},
                					{
                						title: "Christelijk Nieuws",
                						url: "https://christelijknieuws.nl/feed/"
                					},
                				],
                				showSourceTitle: true,
                				showPublishDate: true,
                				showDescription: true,
                				wrapDescription: false,
                				ignoreOldItems: true,
                				ignoreOlderThan: 4 * 60 * 60 * 1000,
                				broadcastNewsFeeds: true,
                				broadcastNewsUpdates: true,
                				hideLoading: true,
                				updateInterval: 20000,
                				animationSpeed: 1000,
                			}
                		},
                		{
                			module: "weather",
                			position: "top_right",
                			config: {
                				weatherProvider: "openweathermap",
                				type: "current",
                				location: "Zwolle",
                				locationID: "2743476", //ID from http://bulk.openweathermap.org/sample/city.list.json.gz; unzip the gz file and find your city
                				apiKey: "06***d7",
                				showPrecipitationAmount: true,
                				appendLocationNameToHeader: false,
                				roundTemp: true,
                				windUnits: "beaufort",
                			}
                		},
                		{
                			module: "weather",
                			position: "top_right",
                			header: "komende uren",
                			config: {
                				weatherProvider: "openweathermap",
                				type: "hourly",
                				weatherEndpoint: "/onecall",
                				lat: 52.5125,
                				lon: 6.09444,
                				apiKey: "06***d7",
                				maxEntries: 16,
                				showPrecipitationAmount: true,
                				colored: true,
                				appendLocationNameToHeader: false,
                				roundTemp: true,
                			}
                		},
                		{
                			module: "weather",
                			position: "top_right",
                			header: "komende dagen",
                			config: {
                				weatherProvider: "openweathermap",
                				type: "daily",
                				location: "Zwolle",
                				locationID: "2743476", //ID from http://bulk.openweathermap.org/sample/city.list.json.gz; unzip the gz file and find your city
                				apiKey: "06***d7",
                				maxNumberOfDays : 11,
                				showPrecipitationAmount: true,
                				colored: false,
                				appendLocationNameToHeader: false,
                				roundTemp: true,
                			}
                		},
                		{
                			module: "clock",
                			position: "top_left",
                			config: {
                				clockBold: false,
                				displayType: "digital",
                				showSunTimes: false,
                				lat: 52.5125,
                				long: 6.09444,
                			}
                		},
                		{
                			module: "calendar",
                			header: "Agenda",
                			position: "top_left",
                			config: {
                				fetchInterval: 60 * 60 * 1000,
                				maximumEntries: 18,
                				displaySymbol: true,
                				coloredSymbol: true,
                				calendars: [
                					{
                						maximumNumberOfDays: 31,
                						symbol: "calendar-check",
                						url: "https://calendar.google.com/calendar/ical/vdplas.net_***%40group.calendar.google.com/public/basic.ics",
                						color: "white",
                					},
                					{
                						maximumNumberOfDays: 31,
                						symbol: "toggle-off",
                						url: "https://calendar.google.com/calendar/ical/nl.dutch%23holiday%40group.v.calendar.google.com/public/basic.ics",
                						color: "green",
                					},
                				{
                						maximumNumberOfDays: 3,
                						symbol: "cake-candles",
                						url: "https://calendar.google.com/calendar/ical/***%40group.calendar.google.com/public/basic.ics",
                						color: "#5e0817",
                					},
                				]
                			}
                		},
                		{
                			module: 'MMM-JsonTable',
                			position: 'bottom_right',
                			header: 'Aanwezig',
                			config: {
                				url: 'https://server.vdplas.net:8083/thuis.json', // Required
                				arrayName: 'items', // Optional
                				tryFormatDate: true,
                			}
                		},
                		{
                			module: 'MMM-iFrame',
                			header: 'Speelt nu',
                			position: 'bottom_left',	// This can be any of the regions.
                			config: {
                				// See 'Configuration options' for more information.
                					url: ["https://server.vdplas.net:8999/material/?player=dc:a6:32:18:b6:fd&layout=desktop&action=expandNowPlaying/true&css=msk--np-only&js=msk--np-only&single=true&theme=Black"],  // as many URLs you want or you can just ["ENTER IN URL"] if single URL.
                					updateInterval: 500 * 60 * 1000, // rotate URLs every 30 seconds
                					width: "400", // width of iframe
                					height: "800", // height of iframe
                					frameWidth: "200" // width of embedded iframe, height is beeing calculated by aspect ratio of iframe
                				}
                		},
                		{
                			module: 'nstreinen',
                			position: 'bottom_right',
                			header: 'Treinen naar Deventer',
                			config: {
                				apiKey:'35***17',
                				fromStation: 'ZL',
                				toStation: 'DV',
                				maxEntries: 4
                			}
                		},
                		{
                			module: 'MMM-RSS-FEED',
                			position: 'top_center',
                			config: {
                			url: 'https://feed.dagelijkswoord.nl/rss2'
                			}
                		},
                	]
                };
                
                /*************** DO NOT EDIT THE LINE BELOW ***************/
                if (typeof module !== "undefined") {module.exports = config;}
                
                

                Schermafbeelding 2024-01-17 110446.jpg
                1.jpg
                2.jpg
                3.jpg

                zdenekZ 1 Reply Last reply Reply Quote 1
                • zdenekZ Offline
                  zdenek @stephanvdplas
                  last edited by

                  @stephanvdplas magic, super, thanks

                  1 Reply Last reply Reply Quote 2
                  • W Offline
                    Wilbert61 @stephanvdplas
                    last edited by

                    @stephanvdplas Mooi werkje Stephan, goed gedaan!!!

                    1 Reply Last reply Reply Quote 1
                    • J Offline
                      JeanMichelC
                      last edited by

                      Really awesome work, congrats. It looks great!!!

                      1 Reply Last reply Reply Quote 2
                      • S stephanvdplas referenced this topic on
                      • bdeelmanB Offline
                        bdeelman
                        last edited by

                        Hi,

                        Really nice done!

                        What kind of mirror did you use? Glass? Foil?

                        Groeten,
                        Bert

                        S 1 Reply Last reply Reply Quote 0
                        • 1
                        • 2
                        • 1 / 2
                        • 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