Admin Extension SDK
The admin-extension-sdk
is a JavaScript library for all Shopware 6 App and Plugin developer which want an easy way to extend and customize the administration.
See Documentation
Installation
Using NPM:
Install it to your package.json
npm i --save @shopware-ag/admin-extension-sdk
and import it in your app:
import * as sw from '@shopware-ag/admin-extension-sdk';
import { notification } from '@shopware-ag/admin-extension-sdk';
Using CDN:
Import the source from the CDN
<script src="https://unpkg.com/@shopware-ag/admin-extension-sdk/cdn"></script>
<script src="https://unpkg.com/@shopware-ag/admin-extension-sdk@1.2.3/cdn"></script>
and then you can access it with the global variable sw
.
sw.notification.dispatch({
title: 'My first notification',
message: 'This was really easy to do'
})
Features
- 🏗 Works with Shopware 6 Apps and Plugins: you can use the SDK for your plugins or apps. API usage is identical.
- 🎢 Shallow learning curve: you don't need to have extensive knowledge about the internals of the Shopware 6 Administration. Our SDK hides the complicated stuff behind a beautiful API.
- 🧰 Many extension capabilities: from throwing notifications, accessing context information or extending the current UI. The feature set of the SDK will gradually be extended, providing more possibilities and flexibility for your ideas and solutions.
- 🪨 A stable API with great backwards compatibility: don't fear Shopware updates anymore. Breaking changes in this SDK are an exception. If you use the SDK, your apps and plugins will stay stable for a longer time, without any need for code maintenance.
- 🧭 Type safety: the whole SDK is written in TypeScript which provides great autocompletion support and more safety for your apps and plugins.
- 💙 Developer experience: have a great development experience right from the start. And it will become better and better in the future.
- 🪶 Lightweight: the whole library is completely tree-shakable and dependency-free. Every functionality can be imported granularly to keep your bundle as small and fast as possible.
Examples
Throw a notification:
sw.notification.dispatch({
title: 'My first notification',
message: 'This was really easy to do'
})
Get the system currency:
const currency = await sw.context.getCurrency();
Subscribe for UI locale changes:
let currentLocale = 'en-GB';
sw.context.subscribeLocale(({ locale }) => {
currentLocale = locale;
})
See more examples in the Documentation.
[3.0.0] - 23.12.2022
Added
- Added type safety to all repository methods and the general data handling.
Breaking Changes
- Removed the
any
type as a return value from the repository
methods
Upgrade Guide
You can get back the original behavior by adding the any
type to the global Entities
interface. You can
see the guide in Getting started → Installation → Adding types for Entities (TS only) → Using "any" fallback.
An additional package with auto-generated types will be released soon.