gnome:extensions:extension.js
Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
gnome:extensions:extension.js [2022/07/23 11:39] – 194.32.120.95 | gnome:extensions:extension.js [2022/07/23 12:24] (current) – 194.32.120.105 | ||
---|---|---|---|
Line 5: | Line 5: | ||
* It is the core of the extension and contains the function hooks **init()**, **enable()** and **disable()** used by GNOME Shell to load, enable and disable your extension. | * It is the core of the extension and contains the function hooks **init()**, **enable()** and **disable()** used by GNOME Shell to load, enable and disable your extension. | ||
- | * The file can use top-level functions, or an extension object. | ||
- | * Use whichever pattern best suits. | ||
---- | ---- | ||
- | ===== Using top-level functions ===== | + | ===== extension.js ===== |
+ | |||
+ | The file can use top-level functions, or an extension object. | ||
+ | |||
+ | * Use whichever pattern best suits. | ||
+ | |||
+ | |||
+ | ==== Using top-level functions | ||
<file javascript extension.js> | <file javascript extension.js> | ||
Line 34: | Line 39: | ||
---- | ---- | ||
- | ===== Using extension object | + | ==== Using extension object ==== |
<file javascript extension.js> | <file javascript extension.js> | ||
Line 87: | Line 92: | ||
} | } | ||
</ | </ | ||
+ | |||
+ | ---- | ||
+ | |||
+ | <WRAP info> | ||
+ | **NOTE: | ||
+ | |||
+ | * You will have access to live code running in GNOME Shell, but fatal errors or mistakes will affect the stability of the desktop. | ||
+ | |||
+ | * It also means you will be using the [[https:// | ||
+ | |||
+ | </ | ||
+ | |||
+ | |||
+ | ---- | ||
+ | |||
+ | |||
+ | ===== Extension Meta Object ===== | ||
+ | |||
+ | An object describing the extension and various properties is available for extensions to use. | ||
+ | |||
+ | * This is passed to the **init()** function when an extension is loaded and can be retrieved by calling **ExtensionUtils.getCurrentExtension()**. | ||
+ | |||
+ | <code javascript> | ||
+ | /** | ||
+ | * @typedef ExtensionMeta | ||
+ | * @type {object} | ||
+ | * @property {object} metadata - the metadata.json file, parsed as JSON | ||
+ | * @property {string} uuid - the extension UUID | ||
+ | * @property {number} type - the extension type; `1` for system, `2` for user | ||
+ | * @property {Gio.File} dir - the extension directory | ||
+ | * @property {string} path - the extension directory path | ||
+ | * @property {string} error - an error message or an empty string if no error | ||
+ | * @property {boolean} hasPrefs - whether the extension has a preferences dialog | ||
+ | * @property {boolean} hasUpdate - whether the extension has a pending update | ||
+ | * @property {boolean} canChange - whether the extension can be enabled/ | ||
+ | * @property {string[]} sessionModes - a list of supported session modes | ||
+ | */ | ||
+ | </ | ||
+ | |||
+ | <WRAP important> | ||
+ | **WARNING: | ||
+ | |||
+ | * All properties should be considered read-only. | ||
+ | |||
+ | </ | ||
+ | |||
---- | ---- | ||
Line 94: | Line 145: | ||
https:// | https:// | ||
+ | https:// |
gnome/extensions/extension.js.1658576356.txt.gz · Last modified: 2022/07/23 11:39 by 194.32.120.95