mirror of
https://github.com/ckaczor/azuredatastudio.git
synced 2026-01-31 17:23:31 -05:00
* Merge from vscode a348d103d1256a06a2c9b3f9b406298a9fef6898 * Fixes and cleanup * Distro * Fix hygiene yarn * delete no yarn lock changes file * Fix hygiene * Fix layer check * Fix CI * Skip lib checks * Remove tests deleted in vs code * Fix tests * Distro * Fix tests and add removed extension point * Skip failing notebook tests for now * Disable broken tests and cleanup build folder * Update yarn.lock and fix smoke tests * Bump sqlite * fix contributed actions and file spacing * Fix user data path * Update yarn.locks Co-authored-by: ADS Merger <karlb@microsoft.com>
43 lines
1.4 KiB
TypeScript
43 lines
1.4 KiB
TypeScript
/*---------------------------------------------------------------------------------------------
|
|
* Copyright (c) Microsoft Corporation. All rights reserved.
|
|
* Licensed under the Source EULA. See License.txt in the project root for license information.
|
|
*--------------------------------------------------------------------------------------------*/
|
|
|
|
import { Event as BaseEvent, Emitter } from 'vs/base/common/event';
|
|
|
|
export type EventHandler = HTMLElement | HTMLDocument | Window;
|
|
|
|
export interface IDomEvent {
|
|
<K extends keyof HTMLElementEventMap>(element: EventHandler, type: K, useCapture?: boolean): BaseEvent<HTMLElementEventMap[K]>;
|
|
(element: EventHandler, type: string, useCapture?: boolean): BaseEvent<unknown>;
|
|
}
|
|
|
|
export const domEvent: IDomEvent = (element: EventHandler, type: string, useCapture?: boolean) => {
|
|
const fn = (e: Event) => emitter.fire(e);
|
|
const emitter = new Emitter<Event>({
|
|
onFirstListenerAdd: () => {
|
|
element.addEventListener(type, fn, useCapture);
|
|
},
|
|
onLastListenerRemove: () => {
|
|
element.removeEventListener(type, fn, useCapture);
|
|
}
|
|
});
|
|
|
|
return emitter.event;
|
|
};
|
|
|
|
export interface CancellableEvent {
|
|
preventDefault(): void;
|
|
stopPropagation(): void;
|
|
}
|
|
|
|
export function stopEvent<T extends CancellableEvent>(event: T): T {
|
|
event.preventDefault();
|
|
event.stopPropagation();
|
|
return event;
|
|
}
|
|
|
|
export function stop<T extends CancellableEvent>(event: BaseEvent<T>): BaseEvent<T> {
|
|
return BaseEvent.map(event, stopEvent);
|
|
}
|