feat(platform-server): use EventManagerPlugin on the server (#24132)
Previously event handlers on the server were setup directly. This change makes it so that the event registration on the server go through EventManagerPlugin just like on client. This allows us to add custom event registration handlers on the server which allows us to hook up preboot event handlers cleanly. PR Close #24132
This commit is contained in:

committed by
Victor Berchet

parent
5b25c07795
commit
d6595ebd39
30
packages/platform-server/src/server_events.ts
Normal file
30
packages/platform-server/src/server_events.ts
Normal file
@ -0,0 +1,30 @@
|
||||
/**
|
||||
* @license
|
||||
* Copyright Google Inc. All Rights Reserved.
|
||||
*
|
||||
* Use of this source code is governed by an MIT-style license that can be
|
||||
* found in the LICENSE file at https://angular.io/license
|
||||
*/
|
||||
|
||||
import {Inject, Injectable} from '@angular/core';
|
||||
import {DOCUMENT, ɵgetDOM as getDOM} from '@angular/platform-browser';
|
||||
|
||||
@Injectable()
|
||||
export class ServerEventManagerPlugin /* extends EventManagerPlugin which is private */ {
|
||||
constructor(@Inject(DOCUMENT) private doc: any) {}
|
||||
|
||||
// Handle all events on the server.
|
||||
supports(eventName: string) { return true; }
|
||||
|
||||
addEventListener(element: HTMLElement, eventName: string, handler: Function): Function {
|
||||
return getDOM().onAndCancel(element, eventName, handler);
|
||||
}
|
||||
|
||||
addGlobalEventListener(element: string, eventName: string, handler: Function): Function {
|
||||
const target: HTMLElement = getDOM().getGlobalEventTarget(this.doc, element);
|
||||
if (!target) {
|
||||
throw new Error(`Unsupported event target ${target} for event ${eventName}`);
|
||||
}
|
||||
return this.addEventListener(target, eventName, handler);
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user