DefinitelyTyped/webcomponents.js/index.d.ts
Reuben Pasquini 9cf9e12c10 webcomponents.js/ augment window.customeElements.register (#13842)
the custome elements v1 standard introduces a new mechanism for registering custome elements:
     https://developers.google.com/web/fundamentals/getting-started/primers/customelements
2017-01-17 21:52:34 -08:00

71 lines
1.8 KiB
TypeScript

// Type definitions for webcomponents.js 0.6.0
// Project: https://github.com/webcomponents/webcomponentsjs
// Definitions by: Adi Dahiya <https://github.com/adidahiya>
// Definitions: https://github.com/DefinitelyTyped/DefinitelyTyped
declare namespace webcomponents {
export interface CustomElementInit {
prototype: HTMLElement;
extends?: string;
}
export interface CustomElementConstructor {
new(): HTMLElement;
}
export interface CustomElementsPolyfill {
hasNative: boolean;
flags: any;
ready: boolean;
useNative: boolean;
}
export interface HTMLImportsPolyfill {
IMPORT_LINK_TYPE: string;
isIE: boolean;
flags: any;
ready: boolean;
rootDocument: Document;
useNative: boolean;
whenReady(callback: () => void): void;
}
export interface ShadowRootPolyfill extends DocumentFragment {
innerHTML: string;
readonly host: Element;
}
export interface Polyfill {
flags: any;
}
/**
* I just slapped this in here - sure it could be better ... :-)
*/
export interface CustomElements {
define( tagName:string, elementClass:any ):void;
}
}
declare module "webcomponents.js" {
export = webcomponents;
}
interface Element {
createShadowRoot(): webcomponents.ShadowRootPolyfill;
readonly shadowRoot?: webcomponents.ShadowRootPolyfill;
}
interface Document {
registerElement(name: string, prototype: webcomponents.CustomElementInit): webcomponents.CustomElementConstructor;
}
interface Window {
CustomElements: webcomponents.CustomElementsPolyfill;
HTMLImports: webcomponents.HTMLImportsPolyfill;
WebComponents: webcomponents.Polyfill;
customElements: webcomponents.CustomElements;
}