8dda1027b3
* Adding Release Notes to SDK * Making release notes brief and not doing version update * Minor adjustment * Adding import * as SDK for ES --------- Co-authored-by: TFS MiniLab Admin <tfsmladm@microsoft.com> |
||
---|---|---|
src | ||
.gitignore | ||
.npmignore | ||
LICENSE | ||
README.md | ||
SECURITY.md | ||
buildpackage.js | ||
package-lock.json | ||
package.json | ||
rollup.config.js | ||
tsconfig.amd.json | ||
tsconfig.esm.json | ||
tsconfig.json |
README.md
Azure DevOps Web Extension SDK
Release Notes
New major version, v4.*.*
provides multiple module support to the SDK.
Details
-
ES Module Support: SDK now supports ES (ECMAScript) modules in addition to the existing AMD (Asynchronous Module Definition) modules. You can now import SDK using the ES module syntax, which provides performance improvements and reduces the application size.
-
Backward Compatibility for AMD Modules: Existing support for AMD modules remains intact. If your project is using AMD modules, you can continue to use them as before without any changes.
How to Use
If you're using AMD modules, you can continue to import SDK using the require
function:
require(['azure-devops-extension-sdk'], function(SDK) {
// Use the module here
});
For ES modules, you can import our modules using the import
statement:
import * as SDK from 'azure-devops-extension-sdk';
// Use the module here
Get started with a new extension
See the Develop a web extension for Azure DevOps documentation for instructions on getting started with a new extension. You can also refer to the azure-devops-extension-sample repository as a working reference.
Overview
Client SDK for developing Azure DevOps extensions.
The client SDK enables web extensions to communicate to the host frame. It can be used to:
- Notify the host that the extension is loaded or has errors
- Get basic contextual information about the current page (current user, host and extension information)
- Get theme information
- Obtain an authorization token to use in REST calls back to Azure DevOps
- Get remote services offered by the host frame
A full API reference of can be found here.
Get started with a new extension
See the Develop a web extension for Azure DevOps documentation for instructions on getting started with a new extension. You can also refer to the azure-devops-extension-sample repository as a working reference.
Import the SDK within your extension project
- Add
azure-devops-extension-sdk
to the list of dependencies in your package.json - Add
import * as SDK from "azure-devops-extension-sdk"
to your TypeScript code
Initialize the SDK
When you have rendered your extension content, call SDK.init()
. Your extension content will not be displayed until you have notified the host frame that you are ready. There are two options for doing this:
- Call
SDK.init()
with noloaded
option - Call
SDK.init({ loaded: false })
to start initializing the SDK. Then callSDK.notifyLoadSucceeded()
once you have finished your initial rendering. This allows you to make other SDK calls while your content is still loading (and hidden behind a spinner).
Example:
import * as SDK from "azure-devops-extension-sdk";
SDK.init();
API
A full API reference of can be found here.
Code of Conduct
This project has adopted the Microsoft Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact opencode@microsoft.com with any additional questions or comments.