An implementation of the cross-origin communication via postMessage at Angular2 [4.3.1 compatible].
The implementation is based on the PostMessageBusSource & PostMessageBusSink implementation of the @angular/platform-webworker package. At the current implementation of the wrapper, a bridge term is equivalent the Angular2 channel.
First you need to install the npm module:
npm install ngx-post-message --save
main.ts
import {PostMessageModule} from 'ngx-post-message/ngx-post-message';
// import {PostMessageModule} from 'ngx-post-message'
@NgModule({
bootstrap: [ApplicationComponent],
imports: [
PostMessageModule,
...
],
...
})
export class ApplicationModule {
}
AppRootPostMessageModule.ts - Root application module
@NgModule()
export class AppRootPostMessageModule {
constructor(@Inject(PostMessageBridgeFactory) private bridgeFactory: PostMessageBridgeFactory) {
/**
* Root context
*/
const iFrame: IPostMessageEventTarget = window.frames[0];
const currentWindow: IPostMessageEventTarget = window;
// The main usage scenario
bridgeFactory.makeInstance()
.setEnableLogging(false) // By default, the smart logger is enabled
.connect(currentWindow, iFrame)
.makeBridge('Logout')
.makeBridge('ChangeLanguage')
.addListener('Logout', (message: any) => console.log('The iframe has sent a message to the parent: LOGOUT'))
.sendMessage('ChangeLanguage', 'ru');
// The additional usage scenario
// You can also use the direct native mechanism of sending the message (if the external application does not use Angular2)
window.frames[0].postMessage([{channel: 'ChangeLanguage', message: 'de'}], '*');
}
}
AppFramePostMessageModule.ts - IFrame application module.
@NgModule()
export class AppFramePostMessageModule {
constructor(@Inject(PostMessageBridgeFactory) private bridgeFactory: PostMessageBridgeFactory) {
/**
* IFrame context
*/
const iFrame: IPostMessageEventTarget = window;
const parentWindow: IPostMessageEventTarget = window.top;
// The main usage scenario
bridgeFactory.makeInstance()
.setEnableLogging(false) // By default, the smart logger is enabled
.connect(iFrame, parentWindow)
.makeBridge('Logout')
.makeBridge('ChangeLanguage')
.addListener('ChangeLanguage', (message: any) => console.log(`The parent has sent a message to the iframe - set a new language as: ${message}`))
.sendMessage('Logout');
// The additional usage scenario
// You can also use the direct native mechanism of sending the message (if the external application does not use Angular2)
window.top.postMessage([{channel: 'Logout'}], '*');
}
}
npm start
Then go to http://localhost:4200
npm start
Licensed under MIT.