Porting Ubuntu custom settings to gnome-control-center (“System Settings”)
Over the years, Ubuntu has accumulated interfaces for various settings that are not associated with any particular application, including:
* Software Sources (software-
* Language Support (gnome-
* "Apply System-Wide" button in gnome-keyboard-
* Login Screen (gdmsetup)
* Time & Date (indicator-
* Ubuntu One Control Panel (ubuntuone-
Gnome 3 has greatly simplified gnome-control-
Unfortunately, gnome-control-
* settings panels cannot be implemented in Python;
* in 3.2, the library for writing settings panels will become private, blocking third-party panels.
We need to work out solutions to these problems, and plan the porting of settings to avoid regressions. And there are other settings that Gnome 3 has dropped but that we will want to retain, for example theme (Ambiance vs. Radiance) and screensaver.
Related:
* https:/
* https:/
* https:/
* https:/
Blueprint information
- Status:
- Complete
- Approver:
- Martin Pitt
- Priority:
- Medium
- Drafter:
- Matthew Paul Thomas
- Direction:
- Approved
- Assignee:
- Sebastien Bacher
- Definition:
- Obsolete
- Series goal:
- Accepted for oneiric
- Implementation:
- Not started
- Milestone target:
- ubuntu-11.10-beta-1
- Started by
- Completed by
- Martin Pitt
Related branches
Related bugs
Bug #787694: GNOME 3 System Settings: Provide stub icons for launching Ubuntu specific capplets | Fix Released |
Whiteboard
Work items (oneiric-alpha-2):
Follow up on upstream discussion about dropping public API for "Other" settings panels vs. whitelist: DONE
Work items (oneiric-alpha-3):
[mterry] Integrate Ubuntu's and Gnome Shell's Time & Date settings (indicator-
[mterry] Teach OnlyShowIn to the control center: DONE
[rodrigo-moya] Either embed Ubuntu One Control Panel (ubuntuone-
Work items:
[andreas] get the HIG to document the recommendations for where to put settings: POSTPONED
Integrate Software Sources (software-
Work items for ubuntu-
[robert-ancell] Evaluate how "Login Screen" (gdmsetup) works with gdm vs. lightdm: DROPPED
Work items for ubuntu-11.10:
[rodrigo-moya] Upstream "Apply System-Wide" button in gnome-keyboard-
seb128, 2011-06-21:
upstream stated that they are not interested to keep the api public but that distro can distro patch it to be public if they want:
pitti, 2011-05-18:
- There was a proposal for a compromise on desktop-devel@: Upstream won't generally allow third-party hooks, but downstreams can argue for individually justified "placeholders", like package management (which is what upstream doesn't do).
- Removed "Upstream Language Support" work item, that's already covered in desktop-
2011-05-20, amano:
mpt, is it really helpful to mess with gnome-control-
-- In Gnome 3, the System Settings window presents the settings themselves, not just the categories of settings (because that reduces the overall actions required to find, change, and dismiss a setting). A Dash lens would be an inappropriate way of presenting settings, for many reasons. They often use secondary dialogs, which the Dash doesn't do. The Dash uses a dark theme, which would make complex things harder to read (that's why it uses a larger font). The Dash either covers the whole screen or disappears when you click outside it, which would be unhelpful if you are getting advice from elsewhere on the computer while changing settings. And on a practical level, it would be a large effort to port the settings interfaces from GTK to the Nux toolkit used in the Dash, especially since Nux would need several new widgets. Finally, putting System Settings in the session menu was a management decision, not a design decision. In Ubuntu 11.10, System Settings will be in the launcher by default. -mpt
== UDS session notes ==
Gnome 2 had a lot of third-party applications dropping a .desktop file in gnome-control-
Need a clear separation between system settings and application settings
Switchboard is an alternative control center option and is developed as part of the Elementary project, see https:/
- allows embedding of Qt panels
- allows embedding Python easily also
Some of the current Ubuntu settings could go upstream
- e.g. ability to propagate keyboard layout settings to other user accounts
Others may be different temporarily or because of differences of opinion
- e.g. Appearance settings
- e.g. Screensaver settings
Others will probably always be a bit different
- e.g. Ubuntu One in Ubuntu only
- Gnome's "Online Accounts" settings overlaps with a small part of this
- e.g. Gnome Shell settings in Gnome only
- e.g. Unity settings in Ubuntu only
Possibilities for including items:
- public library
- public library and a distribution-
- public library and a "brightlist" of items that appear in the standard categories
- third-party items appear in "Other" or similar
put guidelines into the HIG that if you're a visible application with its own settings, don't have a control panel
Possibilities for Python panels:
- loader
- X embedding
Possibilities for handling gnome shell / unity switches:
Plan of action:
- follow on the upstream discussion about dropping the public api and argue on having a public api and a whitelist in the code for the capplets to list by default, other ones would go in an "others" categorie at the bottom
- [andreas] get the HIG to document the recommendations for where to put settings
- [rodrigo-moya] work on getting a python loader:
- teach OnlyShowOnly to the control center
30.01.12, Petko:...GNOME discussion
08.02.2012, Petko:...discussion finished
10.02.12 Petko : A page on the topic of adding distro-specific stuff was started: https:/
Review of Ubuntu patches:
* Software Sources (software-
* Language Support (gnome-
* "Apply System-Wide" button in gnome-keyboard-
* Login Screen (gdmsetup): how does it play with gdm and lightdm?
* Time & Date (indicator-
* Ubuntu One Control Panel (ubuntuone-