Read the statement by Michael Teeuw here.
MMM-ProfileSwitcher, A Profile/User/Layout Switching Module
-
@tosti007 Thanks for the updates, still looks like lines 214 & 218 contain the “=>” were these supposed to be switched to >== also?
So just getting those error so far, but still no luck on the switcher. Im really not sure what I’m doing wrong. I’ve simplified my config file to the following to try make it load the default profile and just switch to ‘PAGE2’. But when the MM loads I get both the clock and weather still on the screen.
modules: [ { module: 'alert', }, { module: "updatenotification", position: "top_bar" }, { module: 'MMM-ProfileSwitcher', config: { // See 'Configuration options' for more information. } }, { module: 'MMM-Buttons', config: { buttons: [ { pin: 5, name: "power", shortPress: { notification: "PROFILE_SWITCH", payload: {action: "PAGE2"} } } ] } }, { module: 'clock', classes: 'default', position: 'top_left', }, { module: 'currentweather', classes: 'PAGE2', position: 'top_right', config: { location: '...', locationID: '...', appid: '...' } }, ]and when i press the button pm2 logs only shows this but nothing happens on the screen.
0|mm | ** Message: console message: [native code] @0: clock received a module notification: PROFILE_SWITCH from sender: MMM-Buttonsedit: On the main HDMI cable monitor the mirror is showing both modules, but if i go via chrome on my laptop it only shows the clock (but still doesnt switch when pressing the button). The inspector in Chrome shows that its hiding non-default modules…seems like Midori doesnt get to this (but I have no way to check)
-
@Mar
=>are big arrow functions from ecmascript6, which is the newest standard of javascript -
@strawberry-3.141 Thanks, I never seem to have had any issues with these before but only on my pi zero. Loading up the latest profile switcher (using my simple 2 module) i get this error relating to that line
0|mm | ** Message: console message: http://localhost:8080/modules/MMM-ProfileSwitcher//MMM-ProfileSwitcher.js @214: SyntaxError: Unexpected token '>'But it seems to work via a remote browser (i.e chrome but switching doesnt work) and not the pi’s midori which still shows both modules.
-
@Mar for me electron is supporting all those es6 features, just heard of that some users had problems with some of my modules with the midori browser
-
@strawberry-3.141 Yeah seems to be a midori thing, unfortunately I’m using a pi zero so need to use midori as it runs pretty amazing with the pi. Electron really slows it down.
Wondering if there is a way around this at all? Maybe breaking out the arrow functions to normal one might work?
-
So ive broken out those functions to the following and now get no errors:
*OLD* value = value.map((x) => { return x === true ? translated : x; }); *NEW* value = value.map( function(x){ return x === true ? translated :x; } ); *OLD* classes.split(" ").forEach((key) => { if (result[key] === undefined) { result[key] = []; } result[key] = result[key].concat(value); }); *NEW* classes.split(" ").forEach( function(key) { if (result[key] === undefined) { result[key] = []; } result[key] = result[key].concat(value); } );Now the only error i am getting is on line 89
TypeError: undefined is not a function (evaluating 'classes.includes(self.current_profile)')But im not sure how to fix this one. And this is the function that decides what to show which could be where Midori cannot parse it properly.
-
@Mar that is also an es6 feature try
classes.indexOf(self.current_profile) !== -1 -
@strawberry-3.141 Thanks, I couldnt figure that one out.
return classes.indexOf(self.current_profile) !== -1;Along with the changes in the previous post I’ve have fully loaded ProfileSwitcher Midori without any errors. It also is showing the correct modules on load (classes = default).
Thanks for the help through this @strawberry-3-141
Managed to figure this all out so thanks to everyone!
-
-
@all I pushed a small update so that older browers should also be able to use this module.
@Mar They are the same changes that you made. -
@tosti007 Thanks for updating your module so quickly! and obviously thanks for taking the time to respond and maintain.
-
@all Thanks to @roramirez we now have Spanish translations! :D
-
@tosti007 When switching between profiles, there is a short timespan where both the modules of the old profile and of the new profile, is present at the screen at the same time. Is there a way to ensure that the old modules fadeout first, and once they are gone, the new modules will fade in?
-
@mortenbirkelund Yes there is, however that would mean that the code has to loop over the modules twice, which isn’t a great thing to do performance wise. I will write a bit of code that does it for you and post it here soon.
Edit: here is the code, all you need to do it replace the whole
set_profilefunction inside theMMM-ProfileSwitcher.jsfile.The code:
// Change the current layout into the new layout given the current profile set_profile: function (useEveryone) { var self = this; var options = {}; if (self.config.useLockStrings) { options.lockString = self.identifier; } MM.getModules().exceptWithClass(self.config.ignoreModules).enumerate(function (module) { if (!self.isVisible(self, useEveryone, module.data.classes)) { module.hide(self.config.animationDuration, function () { Log.log(module.name + " is hidden."); }, options); } }); MM.getModules().exceptWithClass(self.config.ignoreModules).enumerate(function (module) { if (self.isVisible(self, useEveryone, module.data.classes)) { module.show(self.config.animationDuration, function () { Log.log(module.name + " is shown."); }, options); } }); },Note: Once again this is not so great performance wise, but I dont think you will notice much of it
-
@tosti007 Thank you very much. Very kind of you to create the code for me.
I am new to using Git. How do i alter your my copy of your module, without risking that it will be overwritten on an update? Or is that not something that i should be concerned about?
-
@tosti007 In case anybody is interested, the block of codes that enables the modules, should be altered a bit in order to take the animationDuration into account.
setTimeout(function() { MM.getModules().exceptWithClass(self.config.ignoreModules).enumerate(function (module) { if (self.isVisible(self, useEveryone, module.data.classes)) { module.show(self.config.animationDuration, function () { Log.log(module.name + " is shown."); }, options); } }); }, self.config.animationDuration); -
@mortenbirkelund By altering the code git won’t allow you to pull the new updates, in case of an update you will have to clone it manually again. And thank you for sharing the timeout :)
-
Another side note I just realised, if you do use that setTimeout and you swap between profiles in rapid succession I am not sure and cannot quarantee that some of the modules will be shown properly
-
@tosti007 I’ve just tried it, and I don’t experience any problems.
-
Feature request: Schedule profiles throughout time of day and day of the week. I’m thinking of this not as personal profiles, but rather a way to have the mirror show only the relevant panels at any given time. For instance, at lunch time, a lunch menu or out of office message, but at the end of the day, commuting info
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