Wikimedia Developer Summit/2017/Global preferences

Chronology: Ryan is kicking off

  • Extension lego built: https://www.mediawiki.org/wiki/Extension:GlobalPreferences
    • This extension is currently in-use at ShoutWiki. E.g. http://commandos.shoutwiki.com/wiki/Special:GlobalPreferences
    • It creates a new page, Special:GlobalPreferences and leaves the normal Special:Preferences alone, except for adding a single new option in the "User Profile" tab, for "Set your global preferences".
  • You have to check every setting to mark them as global. This means hundreds of clicks, if I want almost everything to be global and non-default.
  • Would it be better to have 1 button to make everything global, with "don't make this global overrides" ?
  • Needs some design work :)
  • Kunal suggested doing a pass at the preferences structure
  • Has some downsides
  • Could spiral out of control (manageability-wise).
  • What are some use cases for global preference
  • Max: When travelling it is really annoying to have to change my timezone on every wiki
  • Roan: I want my interface English in every wiki except those where I speak/understand the content language
  • Ryan: Right, so then this extension would currently not suit your needs.
  • Ryan: I'd like to turn off global notifications on all wikis except my local wiki....
  • Erica: I'd like global preferences to turn on/off products and beta features on all wikis.
  • Quiddity: Watchlist for enhanced etc
  • Quiddity: Preferences for searching namespaces, which (the namespaces available) can be different on every single wiki

Problems:

  • Not all preferences exist on all wikis, e.g. Education extension. or PageTriage
  • Ryan: It quickly becomes really complicated...
  • TheDJ: What if we show a pop-up/dialog where we tell them existing global settings and ask them if they want to switch?
  • MaxS: How about killing off most preferences? :)

Ideas:

  • Research UI ideas, ask people who voted.

If you set a global preference, it shows this at a local special:preferences page: https://i.imgur.com/nOvlTfX.png The problem here, is you can set a global preference, but cannot override it per-wiki. It does cover the simplest use-case, which is perhaps the majority of the needs? But it might not cover the most far-reaching edge-cases. E.g. polyglot users who want one global language preference in most places, but overrides at 1 or more wikis.

We don't currently create new projects very often (last was Wikivoyage in 2013). New languages are frequently created, but are primarily visited by stewards/SWMT folk.

Maybe we should experiment with this using a much more limited form of implementation in Gadget UI, just copying preferences to every wiki using JS and api.

  • Gets us data about how much this is actually used
  • Not disruptive
  • Link from the Special:Preferences page (use a hook )
  • More freedom to experiment with UI concepts for this, which seems to be a rather complex part.
  • Could have 'sets of preferences' that users could override and allow you to specify on which wikis