data:image/s3,"s3://crabby-images/b37ef/b37efd152c54ec8ea9501c45e74ec94416284293" alt="npm"
<pwa-install>
Installation dialog for Progressive web application. Provides more convenience user experience and fix lack of native dialogs in some browsers. 13.5kB brotli compressed bundle. Translation/localization is supported.
Use it as Web Component with any modern framework. No polyfill is required.
Gallery
iOS default | Install instruction | App gallery |
---|
data:image/s3,"s3://crabby-images/beb86/beb86632f3ac44630cfed611a6ec00804cf59c5e" alt="iOS example default" | data:image/s3,"s3://crabby-images/122c0/122c08979b705b8c554452249fbf38811ed6bebf" alt="iOS example install instruction" | data:image/s3,"s3://crabby-images/1c575/1c5756c4f8d42ce12ee1e40b451fd7796174ee02" alt="iOS example gallery" |
iPadOS |
---|
data:image/s3,"s3://crabby-images/0eac2/0eac2f31b944be4193656d495f2368a43402f03c" alt="iPadOS example white" |
Android | App gallery | White theme |
---|
data:image/s3,"s3://crabby-images/66904/66904edaf6ba3855be679f989bc30b40ce642b77" alt="Android example default" | data:image/s3,"s3://crabby-images/305c6/305c628ffcadecabc5185f6dd09d56f7112d6b47" alt="Android example gallery" | data:image/s3,"s3://crabby-images/beeb3/beeb31edd9e980a2d10a7319da8bac30013fefbe" alt="Android example white" |
Chrome | App Gallery |
---|
data:image/s3,"s3://crabby-images/e2859/e285916af77dee6c2aae88a69fb18edab8029529" alt="Chrome example default" | data:image/s3,"s3://crabby-images/f2d31/f2d31ac5665e5102e3f9de1e38c2d41eee8a807a" alt="Chrome example gallery" |
Install
npm i @khmyznikov/pwa-install
Alternatively, you can use unpkg.
Import
import '@khmyznikov/pwa-install';
Use
<pwa-install></pwa-install>
Supported params
<pwa-install
manual-apple="true"
manual-chrome="true"
disable-chrome="true"
install-description="Custom call to install text"
disable-install-description="true"
manifest-url="/manifest.json"
name="PWA"
description="Progressive web application"
icon="/icon.png">
</pwa-install>
Make a good manifest file and don't use name/descr/icon params. Boolean attributes needs to be removed to act like "false"
Supported events
- pwa-install-success-event
- pwa-install-fail-event
- pwa-install-available-event
- pwa-user-choice-result-event
<script type="text/javascript">
var pwaInstall = document.getElementsByTagName('pwa-install')[0];
pwaInstall.addEventListener('pwa-install-success-event', (event) => {console.log(event.detail.message)});
</script>
⚠️ success/fail/choice events is Chromium only, iOS don't have them.
Supported properties (readonly)
- userChoiceResult: string;
- isDialogHidden: boolean
- isInstallAvailable: boolean
- isAppleMobilePlatform: boolean
- isUnderStandaloneMode: boolean
- isRelatedAppsInstalled: boolean
<script type="text/javascript">
var pwaInstall = document.getElementsByTagName('pwa-install')[0];
console.log(pwaInstall.isUnderStandaloneMode);
</script>
Supported methods
- install
- hideDialog
- showDialog
- getInstalledRelatedApps: async
<script type="text/javascript">
var pwaInstall = document.getElementsByTagName('pwa-install')[0];
pwaInstall.install();
</script>
getInstalledRelatedApps is Chromium only, always empty on iOS.
Supported localization
Translations available:
- EN
- RU
- TR
- DE
- ES
- NL
- EL
- FR
- SR
- PL
- ZH/ZH-CN
- IT
- UK
Language should change automatically based on browser settings. Please create the pull-request if you want to help with translation to your language. It's an easy process.
Contribution Guidelines
ROADMAP