3e4fd4b67a
Extensions now must export a class that conforms to a particular interface both for the actual extension as well as for prefs: enable()/disable() methods for the former, fillPreferencesWindow() for the latter. This is quite similar to the previous method-based entry points, but it also gives us a more structured way of providing convenience API in form of base classes. Do that in form of Extension and ExtensionPreferences classes on top of a common ExtensionBase base class. getSettings(), initTranslations() and the gettext wrappers are now methods of the common base, while openPreferences() moves to the Extension class. Based on an original suggestion from Evan Welsh. Part-of: <https://gitlab.gnome.org/GNOME/gnome-shell/-/merge_requests/2838>
22 lines
476 B
JavaScript
22 lines
476 B
JavaScript
import {ExtensionBase, setExtensionManager} from './sharedInternals.js';
|
|
|
|
export {gettext, ngettext, pgettext} from './sharedInternals.js';
|
|
|
|
const {extensionManager} = imports.ui.main;
|
|
setExtensionManager(extensionManager);
|
|
|
|
export class Extension extends ExtensionBase {
|
|
enable() {
|
|
}
|
|
|
|
disable() {
|
|
}
|
|
|
|
/**
|
|
* Open the extension's preferences window
|
|
*/
|
|
openPreferences() {
|
|
extensionManager.openExtensionPrefs(this.uuid, '', {});
|
|
}
|
|
}
|