Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Feature request: initiliaze mob and other settings in URL which can be bookmarked #104

Open
rzijp opened this issue Aug 6, 2020 · 17 comments

Comments

@rzijp
Copy link

rzijp commented Aug 6, 2020

Initializing the mob timer is a repetitive process for us to fill in the names for the team and to set the sequence of roles. It would be great if we could add the names as URL parameters, such that we could bookmark that URL and skip the manual steps.

The initialization based on the parameters should only happen once though: when a timer is already in use, it shouldn't get reset when someone opens the bookmark by accident.

@mrozbarry
Copy link
Collaborator

@rzijp I'm just going to run down how I'd solve this, and you can tell me if this conforms to what you were thinking

Let's pretend that we have an endpoint mobti.me/_/timer?id=your-timer-slug&mob=...&goals=...&timerSettings[...]=....
...but I probably won't expose individual params like this, but I'm not sure yet

when the timer doesn't exist

  1. Set a cookie describing the timer build steps
  2. Redirect to timer url
  3. Client reads the cookie, and builds timer data.
  4. Client deletes the cookie

when a timer does exist

  1. Redirect to timer url

other stuff

Also, in the timer settings tab, provide a link that can be bookmarked that describes all of your timer settings.


Does that work for your use-case?

@rzijp
Copy link
Author

rzijp commented Aug 26, 2020 via email

@haraldreingruber
Copy link

Another idea would be changing the URL on the client-side via history.replaceState() and add the settings to the query string when they are updated. This means the current URL will always contain the current settings (at least the ones which should be exposed).
Similar to the example above, the URL might look for example like this: mobti.me/your-timer-slug?&mob=...&goals=...&timerSettings[...]=...

On initial load, if that timer doesn't exist yet, the app would have to check the query string params and initialize the settings.

This way, one could just bookmark and share the current URL.

What do you think about this approach?


This feature would be also very useful in our MobRetreat events. In our use-case the most important settings would be:

  • timer duration
  • mob order
  • sound notification

Just wanted to share our use case as well. I guess it could be solved either way.


Thanks a lot for continuously improving the app 🙏!

@mrozbarry
Copy link
Collaborator

Might be related to #133 , but this could be standalone, too.

I'm going to start a branch with just this, and it might evolve info a full client-side router integration ticket, we'll see.

Also, for the sound notification, that will probably end up in localstorage, since it's relative to the client and not the timer.

And it's my pleasure to build a tool that makes any developer's life better.

@mrozbarry
Copy link
Collaborator

What if you had something like this in a terminal:

$ npx some-mobtime-command yourTimerName init --mob "first mobber" --mob "second mobber" --goal "first goal" --goal "second goal" --timer-duration 8min

@rzijp
Copy link
Author

rzijp commented Sep 21, 2020 via email

@mrozbarry
Copy link
Collaborator

Yeah, I'm sure we could do --positions "Navigator,Driver" without much hassle

@haraldreingruber
Copy link

Another alternative or intermediate solution @mrozbarry and I discussed is offering an option to export/import settings probably via a text area field as a JSON string. Did I remember the idea correctly?
I kind of like the simplicity of this approach...

@tedyoung
Copy link

I'd like to see something that supports either a direct API endpoint (so I can create a timer from my mob session registration system), or be able to paste a JSON string. Something other than a command line would be desired.

I mean, I could probably kludge something together by sending compatible events over the websocket, but that seems, well, kludgey. 😄

@mrozbarry
Copy link
Collaborator

direct API endpoint (so I can create a timer from my mob session registration system)

what is your mob session registration system?

@tedyoung
Copy link

@mrozbarry It's a tool I'm developing to help me manage the private mobs I'm facilitating. Still in early stages.

@mrozbarry
Copy link
Collaborator

@mrozbarry It's a tool I'm developing to help me manage the private mobs I'm facilitating. Still in early stages.

Well, I am in the midst of a nodejs sdk and cli, so there may be an opportunity there. github.com/mobtimeapp/mobtime-sdk

@tedyoung
Copy link

I'm a little fuzzy on what the mobtime-sdk is doing, is it opening a websocket and sending message/commands to the remote mob timer? If so, is the websocket message content considered a "published" API for mobtime (which was basically my original question)? My tool is written in Java/Spring Boot which has direct support for Websockets, so I'd be fine with pushing messages over websocket if that got me what I wanted.

@mrozbarry
Copy link
Collaborator

Yeah, you could use the sdk or the vscode plugin as a reference. You could also use mobtime itself for reference, no biggy. As the sdk matures, and if you have time and want to extract it, I'm not opposed to having a java sdk version 😉

@mrozbarry
Copy link
Collaborator

Just wanted to note that this is half-done on https://dev.mobti.me/ . Currently, you can edit the timer, and choose to auto-save it, and it will commit the timer to local storage. On load, if you are the first person to open the timer (making you the owner), the app checks to see if there is a saved timer with the same timer slug, and will load it back in. I'm guessing this will best work if all people using the timer have the auto-save checked.

Some other pieces that could work to enhance whats on dev:

  • Load timer from file
  • Use an external thing, like (but it doesn't exist yet) https://create.mobti.me/desired-timer-slug?goals=...&mob=... , but this may be difficult since goals and mob participants have other attributes, like ids, avatars, completed, parentIds, etc. That's not to say it can't be done, but it may not be fully descriptive.

@rzijp
Copy link
Author

rzijp commented May 2, 2021 via email

@dpolivaev
Copy link

  • Use an external thing, like (but it doesn't exist yet) https://create.mobti.me/desired-timer-slug?goals=...&mob=... , but this may be difficult since goals and mob participants have other attributes, like ids, avatars, completed, parentIds, etc. That's not to say it can't be done, but it may not be fully descriptive.

I would be happy to be able to configure only timer settings (turn duration and mob order) using URL parameters. So I could give a preconfigured URL to all groups in a coding dojo so that they all use the same schema.

In my eyes having additional options to preset client settings or goals is a separate and less important feature.
I am afraid that loading all settings from local storage does not allow to distribute the settings over different teams.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

5 participants