Interface: IExtensionService
molecule.IExtensionService
Implemented by
Methods
activate
▸ activate(extensions
): void
Activate the extensions (includes contributes
type).
Notice: this method only do the activate
work, not store the data into ExtensionService,
which means you can't get the Extension by the ExtensionService. getExtension
method.
Parameters
Name | Type |
---|---|
extensions | IExtension [] |
Returns
void
Defined in
services/extensionService.ts:40
add
▸ add(extensions
): null
| IExtension
[]
Add the extensions to ExtensionService, but no activated.
Parameters
Name | Type | Description |
---|---|---|
extensions | IExtension [] | The Extensions wait to added |
Returns
null
| IExtension
[]
Unload Extensions
Defined in
services/extensionService.ts:33
dispose
▸ dispose(extensionId
): void
Dispose the specific extension, and remove it from the ExtensionService
Parameters
Name | Type |
---|---|
extensionId | UniqueId |
Returns
void
Defined in
services/extensionService.ts:55
disposeAll
▸ disposeAll(): void
Dispose all extensions, and reset the ExtensionService
Returns
void
Defined in
services/extensionService.ts:59
executeCommand
▸ executeCommand(id
, ...args
): void
Execute the registered command
Parameters
Name | Type | Description |
---|---|---|
id | string | The command ID |
...args | any |
Returns
void
Defined in
services/extensionService.ts:92
getAllExtensions
▸ getAllExtensions(): IExtension
[]
Get All loaded extensions
Returns
Extension Array
Defined in
services/extensionService.ts:50
getExtension
▸ getExtension(id
): undefined
| IExtension
Get an extension by the ID
Parameters
Name | Type |
---|---|
id | UniqueId |
Returns
undefined
| IExtension
Defined in
services/extensionService.ts:45
inactive
▸ inactive(predicate
): void
Disable to activate some extensions, make use of it to filter some extensions no need to activate. You need register the inactive event before the MoleculeProvider declaration.
example
molecule.extension.inactive((extension: IExtension) => {
if (/^(idA|idB)$/.test(extension.id)) {
return true;
}
});
<MoleculeProvider extensions={[]}></MoleculeProvider>
Parameters
Name | Type | Description |
---|---|---|
predicate | (extension : IExtension ) => boolean | The predicate function |
Returns
void
Defined in
services/extensionService.ts:74
isLoaded
▸ isLoaded(): boolean
whether the extensions are loaded
Returns
boolean
Defined in
services/extensionService.ts:106
load
▸ load(extensions
): void
Load the extension instances and then activate them.
Notice: The ExtensionService doesn't load an existed Extension, if you want inactivate
someone extension, there can use the ExtensionService.inactive
method, also if you want
remove a extension, you can use the ExtensionService.dispose
method.
Parameters
Name | Type | Description |
---|---|---|
extensions | IExtension [] | The extension array |
Returns
void
Defined in
services/extensionService.ts:27
registerAction
▸ registerAction(actionClass
): IDisposable
Register a new action which is extends the Action2, and return a disposable instance.
example
const action = class Action extends Action2 {};
const disposableAction = registerAction(action);
disposableAction.dispose(); // Dispose the action
Parameters
Name | Type | Description |
---|---|---|
actionClass | () => Action2 | The action class |
Returns
IDisposable
IDisposable The Disposable instance
Defined in
services/extensionService.ts:86
reset
▸ reset(): void
Reset the extensions to []
Returns
void
Defined in
services/extensionService.ts:96
setLoaded
▸ setLoaded(flag?
): void
Set the extensions are loaded
Parameters
Name | Type |
---|---|
flag? | boolean |
Returns
void
Defined in
services/extensionService.ts:110
splitLanguagesExts
▸ splitLanguagesExts(extensions
): [IExtension
[], IExtension
[]]
Distinguish the language extensions from extensions
Parameters
Name | Type |
---|---|
extensions | IExtension [] |
Returns
[IExtension
[], IExtension
[]]