diff --git a/TS.fsx b/TS.fsx index 112d913dc..d60b3f9f4 100644 --- a/TS.fsx +++ b/TS.fsx @@ -9,6 +9,7 @@ open System.Text.RegularExpressions open System.Web open Microsoft.FSharp.Reflection open FSharp.Data +open System.Linq module GlobalVars = let inputFolder = Path.Combine(__SOURCE_DIRECTORY__, "inputfiles") @@ -118,6 +119,31 @@ module Types = | Method of Browser.Method | Ctor of Browser.Constructor | CallBackFun of Browser.CallbackFunction + member self.Params = + match self with + | Method m -> m.Params + | Ctor ctor -> ctor.Params + | CallBackFun callback -> callback.Params + + type InterfaceOrNamespace = + | Interface of Browser.Interface + | Namespace of Browser.Namespace + member self.Name = + match self with + | Interface i -> i.Name + | Namespace n -> n.Name + member self.Exposed = + match self with + | Interface i -> i.Exposed + | Namespace n -> n.Exposed + member self.Properties = + match self with + | Interface i -> i.Properties + | Namespace n -> n.Properties + member self.Methods = + match self with + | Interface i -> i.Methods + | Namespace n -> n.Methods // Note: // Eventhandler's name and the eventName are not just off by "on". @@ -160,6 +186,7 @@ module InputJson = | SignatureOverload | TypeDef | Extends + | Namespace override x.ToString() = match x with | Property _ -> "property" @@ -172,6 +199,7 @@ module InputJson = | SignatureOverload _ -> "signatureoverload" | TypeDef _ -> "typedef" | Extends _ -> "extends" + | Namespace _ -> "namespace" let getItemByName (allItems: InputJsonType.Root []) (itemName: string) (kind: ItemKind) otherFilter = let filter (item: InputJsonType.Root) = @@ -271,102 +299,92 @@ module Data = let browser = (new StreamReader(Path.Combine(GlobalVars.inputFolder, "browser.webidl.xml"))).ReadToEnd() |> Browser.Parse - let worker = - (new StreamReader(Path.Combine(GlobalVars.inputFolder, "webworkers.specidl.xml"))).ReadToEnd() |> Browser.Parse + let knownExposures = + let asArray (k: string, v: JsonValue) = + match v with + | JsonValue.String s -> (k, s.Split [| ' ' |]) + | _ -> failwith "Incorrect format" + + File.ReadAllText(Path.Combine(GlobalVars.inputFolder, "knownExposures.json")) + |> JsonValue.Parse + |> JsonExtensions.Properties + |> Array.map asArray + |> Map.ofArray + + let WorkerTypes = [| "Worker"; "DedicatedWorker"; "SharedWorker"; "ServiceWorker" |] /// Check if the given element should be disabled or not /// reason is that ^a can be an interface, property or method, but they /// all share a 'tag' property - let inline ShouldKeep flavor (i: ^a when ^a: (member Tags: string option)) = + let inline ShouldKeep flavor (i: ^a when ^a: (member Exposed: string option)) = let filterByTag = - match (^a: (member Tags: string option) i) with - | Some tags -> + match (^a: (member Exposed: string option) i) with + | Some exposed -> + let exposedArray = exposed.Split [|' '|] match flavor with | Flavor.All -> true - | Flavor.Web -> tags <> "MSAppOnly" && tags <> "WinPhoneOnly" - | Flavor.Worker -> tags <> "IEOnly" - | _ -> true + | Flavor.Web -> Array.contains "Window" exposedArray + | Flavor.Worker -> (exposedArray.Intersect WorkerTypes).Count() <> 0 + | _ -> + match flavor with + | Flavor.All | Flavor.Web -> true + | Flavor.Worker -> false filterByTag + let inline ShouldKeepInherit flavor inheritedExposure (i: ^a when ^a: (member Exposed: string option)) = + let exposure = (^a: (member Exposed: string option) i); + if exposure.IsSome then ShouldKeep flavor i + else ShouldKeep flavor inheritedExposure + + let inline ShouldKeepUnexposed flavor name = + let exposure = knownExposures.TryFind name + match flavor with + | Flavor.All -> true + | Flavor.Web -> exposure.IsNone || Array.contains "Window" exposure.Value + | Flavor.Worker -> exposure.IsSome + + let inline getName ((i: ^a when ^a: (member Name: string))) = + (^a: (member Name: string) i) + + let inline getTypedefName ((i: ^a when ^a: (member NewType: string))) = + (^a: (member NewType: string) i) + // Global interfacename to interface object map let allWebNonCallbackInterfaces = Array.concat [| browser.Interfaces; browser.MixinInterfaces.Interfaces |] - let allWebInterfaces = - Array.concat [| browser.Interfaces; browser.CallbackInterfaces.Interfaces; browser.MixinInterfaces.Interfaces |] - - let allWorkerAdditionalInterfaces = - Array.concat [| worker.Interfaces; worker.MixinInterfaces.Interfaces |] - let allInterfaces = - Array.concat [| allWebInterfaces; allWorkerAdditionalInterfaces |] + Array.concat [| browser.Interfaces; browser.CallbackInterfaces.Interfaces; browser.MixinInterfaces.Interfaces |] let inline toNameMap< ^a when ^a: (member Name: string) > (data: array< ^a > ) = data |> Array.map (fun x -> ((^a: (member Name: string) x), x)) |> Map.ofArray - let allInterfacesMap = - allInterfaces |> toNameMap + let allInterfacesMap = allInterfaces |> toNameMap - let allDictionariesMap = - Array.concat [| browser.Dictionaries; worker.Dictionaries |] - |> toNameMap + let allDictionariesMap = browser.Dictionaries |> toNameMap - let allEnumsMap = - Array.concat [| browser.Enums; worker.Enums |] - |> toNameMap + let allEnumsMap = browser.Enums |> toNameMap - let allCallbackFuncs = - Array.concat [| browser.CallbackFunctions; worker.CallbackFunctions |] - |> toNameMap + let allCallbackFuncs = browser.CallbackFunctions |> toNameMap let GetInterfaceByName = allInterfacesMap.TryFind - type KnownWorkerInterfaceType = JsonProvider<"inputfiles/knownWorkerInterfaces.json", InferTypesFromValues=false> - let knownWorkerInterfaces = - File.ReadAllText(Path.Combine(GlobalVars.inputFolder, "knownWorkerInterfaces.json")) - |> KnownWorkerInterfaceType.Parse - |> set - - let knownWorkerEnums = - File.ReadAllText(Path.Combine(GlobalVars.inputFolder, "knownWorkerEnums.json")) - |> KnownWorkerInterfaceType.Parse - |> set - - let GetAllInterfacesByFlavor flavor = - match flavor with - | Flavor.Web -> allWebInterfaces |> Array.filter (ShouldKeep Web) - | Flavor.All -> allWebInterfaces |> Array.filter (ShouldKeep Flavor.All) - | Flavor.Worker -> - let isFromBrowserXml = allWebInterfaces |> Array.filter (fun i -> knownWorkerInterfaces.Contains i.Name) - Array.append isFromBrowserXml allWorkerAdditionalInterfaces - let GetNonCallbackInterfacesByFlavor flavor = - match flavor with - | Flavor.Web -> allWebNonCallbackInterfaces |> Array.filter (ShouldKeep Flavor.Web) - | Flavor.All -> allWebNonCallbackInterfaces |> Array.filter (ShouldKeep Flavor.All) - | Flavor.Worker -> - let isFromBrowserXml = allWebNonCallbackInterfaces |> Array.filter (fun i -> knownWorkerInterfaces.Contains i.Name) - Array.append isFromBrowserXml allWorkerAdditionalInterfaces - - let GetPublicInterfacesByFlavor flavor = - match flavor with - | Flavor.Web | Flavor.All -> browser.Interfaces |> Array.filter (ShouldKeep flavor) - | Flavor.Worker -> - let isFromBrowserXml = browser.Interfaces |> Array.filter (fun i -> knownWorkerInterfaces.Contains i.Name) - Array.append isFromBrowserXml worker.Interfaces + allWebNonCallbackInterfaces |> Array.filter (ShouldKeep flavor) let GetCallbackFuncsByFlavor flavor = - browser.CallbackFunctions - |> Array.filter (fun cb -> (flavor <> Flavor.Worker || knownWorkerInterfaces.Contains cb.Name) && ShouldKeep flavor cb) + browser.CallbackFunctions |> Array.filter (getName >> ShouldKeepUnexposed flavor) let GetEnumsByFlavor flavor = - match flavor with - | Flavor.Web | Flavor.All -> browser.Enums - | Flavor.Worker -> - let isFromBrowserXml = browser.Enums |> Array.filter (fun i -> knownWorkerEnums.Contains i.Name) - Array.append isFromBrowserXml worker.Enums + browser.Enums |> Array.filter (getName >> ShouldKeepUnexposed flavor) + + let GetNamespacesByFlavor flavor = + browser.Namespaces |> Array.filter (ShouldKeep flavor) + + let GetTypedefsByFlavor flavor = + browser.Typedefs |> Array.filter (getTypedefName >> ShouldKeepUnexposed flavor) /// Event name to event type map let eNameToEType = @@ -440,12 +458,11 @@ module Data = yield! [ for e in i.Elements do yield (e.Name, i.Name) ] ] |> Seq.groupBy fst - |> Seq.map (fun (key, group) -> (key, Seq.map snd group)) - |> Seq.map (fun (key, group) -> + |> Seq.map ((fun (key, group) -> (key, Seq.map snd group)) >> (fun (key, group) -> key, match Seq.length group with | 1 -> Seq.head group - | _ -> resolveElementConflict key group) + | _ -> resolveElementConflict key group)) |> Map.ofSeq /// Interface name to all its implemented / inherited interfaces name list map @@ -464,14 +481,14 @@ module Data = | Some i -> List.ofArray i.Implements | _ -> [] - Array.concat [| allWebNonCallbackInterfaces; worker.Interfaces; worker.MixinInterfaces.Interfaces |] + Array.concat [| allWebNonCallbackInterfaces |] |> Array.map (fun i -> (i.Name, List.concat [ (getExtendList i.Name); (getImplementList i.Name) ])) |> Map.ofArray /// Distinct event type list, used in the "createEvent" function let distinctETypeList = let usedEvents = - [ for i in GetNonCallbackInterfacesByFlavor Flavor.All do + [ for i in GetNonCallbackInterfacesByFlavor Flavor.Web do match i.Events with | Some es -> yield! es.Events | _ -> () ] @@ -479,7 +496,7 @@ module Data = |> List.distinct let unUsedEvents = - GetNonCallbackInterfacesByFlavor Flavor.All + GetNonCallbackInterfacesByFlavor Flavor.Web |> Array.choose (fun i -> if i.Extends = "Event" && i.Name.EndsWith("Event") && not (List.contains i.Name usedEvents) then Some(i.Name) else None) |> Array.distinct @@ -572,7 +589,7 @@ module Data = let GetGlobalPollutor flavor = match flavor with | Flavor.Web | Flavor.All -> browser.Interfaces |> Array.tryFind (fun i -> i.PrimaryGlobal.IsSome) - | Flavor.Worker -> worker.Interfaces |> Array.tryFind (fun i -> i.Global.IsSome) + | Flavor.Worker -> browser.Interfaces |> Array.tryFind (fun i -> i.Global.IsSome && i.Name = "DedicatedWorkerGlobalScope") let GetGlobalPollutorName flavor = match GetGlobalPollutor flavor with @@ -582,28 +599,12 @@ module Data = /// Return a sequence of returntype * HashSet tuple let GetOverloads (f : Function) (decomposeMultipleTypes : bool) = let getParams (f : Function) = - match f with - | Method m -> - [ for p in m.Params do - yield { Type = p.Type - Name = p.Name - Optional = p.Optional.IsSome - Variadic = p.Variadic.IsSome - Nullable = p.Nullable.IsSome } ] - | Ctor c -> - [ for p in c.Params do - yield { Type = p.Type - Name = p.Name - Optional = p.Optional.IsSome - Variadic = p.Variadic.IsSome - Nullable = p.Nullable.IsSome } ] - | CallBackFun cb -> - [ for p in cb.Params do - yield { Type = p.Type - Name = p.Name - Optional = p.Optional.IsSome - Variadic = p.Variadic.IsSome - Nullable = p.Nullable.IsSome } ] + [ for p in f.Params do + yield { Type = p.Type + Name = p.Name + Optional = p.Optional.IsSome + Variadic = p.Variadic.IsSome + Nullable = p.Nullable.IsSome } ] let getReturnType (f : Function) = match f with @@ -664,8 +665,8 @@ module Data = browser.Typedefs |> Array.map (fun td -> td.NewType) |> Set.ofArray let extendConflicts = [ - { BaseType = "AudioContext"; ExtendType = ["OfflineContext"]; MemberNames = ["suspend"] }; { BaseType = "HTMLCollection"; ExtendType = ["HTMLFormControlsCollection"]; MemberNames = ["namedItem"] }; + { BaseType = "HTMLHyperlinkElementUtils"; ExtendType = ["SVGAElement"]; MemberNames = ["href"] }; ] let extendConflictsBaseTypes = @@ -685,67 +686,11 @@ module Emit = // Extended types used but not defined in the spec let extendedTypes = - ["ArrayBuffer";"ArrayBufferView";"Int8Array";"Uint8Array";"Int16Array";"Uint16Array";"Int32Array";"Uint32Array";"Float32Array";"Float64Array"] + ["ArrayBuffer";"ArrayBufferView";"Int8Array";"Uint8Array";"Int16Array";"Uint16Array";"Int32Array";"Uint32Array";"Uint8ClampedArray";"Float32Array";"Float64Array";"DataView"] let integerTypes = ["byte";"octet";"short";"unsigned short";"long";"unsigned long";"long long";"unsigned long long"] - /// Get typescript type using object dom type, object name, and it's associated interface name - let rec DomTypeToTsType (objDomType: string) = - match objDomType.Trim('?') with - | "AbortMode" -> "String" - | "any" -> "any" - | "bool" | "boolean" | "Boolean" -> "boolean" - | "CanvasPixelArray" -> "number[]" - | "Date" -> "Date" - | "DOMHighResTimeStamp" -> "number" - | "DOMString" -> "string" - | "DOMTimeStamp" -> "number" - | "EndOfStreamError" -> "number" - | "EventListener" -> "EventListenerOrEventListenerObject" - | "double" | "float" -> "number" - | "Function" -> "Function" - | "object" -> "any" - | "Promise" -> "Promise" - | "ReadyState" -> "string" - | "sequence" -> "Array" - | "UnrestrictedDouble" | "unrestricted double" -> "number" - | "void" -> "void" - | integerType when List.contains integerType integerTypes -> "number" - | extendedType when List.contains extendedType extendedTypes -> extendedType - | _ -> - if ignoreDOMTypes && Seq.contains objDomType ["Element"; "Window"; "Document"] then "any" - else - // Name of an interface / enum / dict. Just return itself - if allInterfacesMap.ContainsKey objDomType || - allCallbackFuncs.ContainsKey objDomType || - allDictionariesMap.ContainsKey objDomType || - allEnumsMap.ContainsKey objDomType then - objDomType - // Name of a type alias. Just return itself - elif typeDefSet.Contains objDomType then objDomType - // Union types - elif objDomType.Contains(" or ") then - let allTypes = objDomType.Trim('(', ')').Split([|" or "|], StringSplitOptions.None) - |> Array.map (fun t -> DomTypeToTsType (t.Trim('?', ' '))) - if Seq.contains "any" allTypes then "any" else String.concat " | " allTypes - else - // Check if is array type, which looks like "sequence" - let unescaped = System.Web.HttpUtility.HtmlDecode(objDomType) - let genericMatch = Regex.Match(unescaped, @"^(\w+)<([\w, <>]+)>$") - if genericMatch.Success then - let tName = DomTypeToTsType (genericMatch.Groups.[1].Value) - let paramName = DomTypeToTsType (genericMatch.Groups.[2].Value) - match tName with - | _ -> - if tName = "Array" then paramName + "[]" - else tName + "<" + paramName + ">" - elif objDomType.EndsWith("[]") then - let elementType = objDomType.Replace("[]", "").Trim() |> DomTypeToTsType - elementType + "[]" - else "any" - - let makeNullable (originalType: string) = match originalType with | "any" -> "any" @@ -754,6 +699,67 @@ module Emit = | functionType when functionType.Contains "=>" -> "(" + functionType + ") | null" | _ -> originalType + " | null" + /// Get typescript type using object dom type, object name, and it's associated interface name + let rec DomTypeToTsType (objDomType: string) = + let nullable = objDomType.EndsWith "?" + let nonNullType = objDomType.Trim('?') + let resolvedType = + match nonNullType with + | "any" -> "any" + | "bool" | "boolean" | "Boolean" -> "boolean" + | "Date" -> "Date" + | "Error" -> "Error" + | "DOMException" -> "DOMException" + | "DOMHighResTimeStamp" -> "number" + | "DOMString" | "USVString" | "ByteString" -> "string" + | "DOMTimeStamp" -> "number" + | "double" | "float" | "unrestricted double" | "unrestricted float" -> "number" + | "Function" -> "Function" + | "FrozenArray" -> "ReadonlyArray" + | "object" -> "any" + | "Promise" -> "Promise" + | "sequence" -> "Array" + | "record" -> "record" + | "void" -> "void" + | integerType when List.contains integerType integerTypes -> "number" + | extendedType when List.contains extendedType extendedTypes -> extendedType + | _ -> + if ignoreDOMTypes && (Seq.contains nonNullType ["Element"; "Window"; "Document"; "WindowProxy"; "WebGLRenderingContext"] || nonNullType.StartsWith "HTML") then "never" + elif nonNullType = "WindowProxy" then "Window" + else + // Name of an interface / enum / dict. Just return itself + if allInterfacesMap.ContainsKey nonNullType || + allCallbackFuncs.ContainsKey nonNullType || + allDictionariesMap.ContainsKey nonNullType || + allEnumsMap.ContainsKey nonNullType then + nonNullType + // Name of a type alias. Just return itself + elif typeDefSet.Contains nonNullType then nonNullType + // Union types + elif nonNullType.Contains(" or ") then + let allTypes = nonNullType.Trim('(', ')').Split([|" or "|], StringSplitOptions.None) + |> Array.map DomTypeToTsType + if Seq.contains "any" allTypes then "any" else String.concat " | " allTypes + else + // Check if is array type, which looks like "sequence" + let unescaped = System.Web.HttpUtility.HtmlDecode(nonNullType) + let genericMatch = Regex.Match(unescaped, @"^(\w+)<(.+)>$") + if genericMatch.Success then + let tName = DomTypeToTsType (genericMatch.Groups.[1].Value) + let paramNames = + genericMatch.Groups.[2].Value.Split([| ", " |], StringSplitOptions.None) + |> Array.map DomTypeToTsType + match tName with + | "Array" -> if paramNames.[0].Contains "|" then "(" + paramNames.[0] + ")" + "[]" else paramNames.[0] + "[]" + | "record" -> "{ [key: string]: " + paramNames.[1] + " }" + | _ -> tName + "<" + (paramNames |> String.concat ", ") + ">" + elif nonNullType.EndsWith("[]") then + let elementType = nonNullType.Replace("[]", "").Trim() |> DomTypeToTsType + elementType + "[]" + else "any" + + if nullable then makeNullable resolvedType else resolvedType + let DomTypeToNullableTsType (objDomType: string) (nullable: bool) = let resolvedType = DomTypeToTsType objDomType if nullable then makeNullable resolvedType else resolvedType @@ -767,7 +773,7 @@ module Emit = | Some c' -> emitConstantFromJson c' | None -> Pt.Printl "readonly %s: %s;" c.Name (DomTypeToTsType c.Type) - let addedConstants = getAddedItems ItemKind.Constant Flavor.All + let addedConstants = getAddedItemsByInterfaceName ItemKind.Constant Flavor.All i.Name Array.iter emitConstantFromJson addedConstants if i.Constants.IsSome then @@ -787,9 +793,9 @@ module Emit = /// Emit overloads for the getElementsByTagName method let EmitGetElementsByTagNameOverloads (m: Browser.Method) = - if matchSingleParamMethodSignature m "getElementsByTagName" "NodeList" "string" then - Pt.Printl "getElementsByTagName(%s: K): ElementListTagNameMap[K];" m.Params.[0].Name - Pt.Printl "getElementsByTagName(%s: string): NodeListOf;" m.Params.[0].Name + if matchSingleParamMethodSignature m "getElementsByTagName" "HTMLCollection" "string" then + Pt.Printl "getElementsByTagName(%s: K): HTMLCollectionOf;" m.Params.[0].Name + Pt.Printl "getElementsByTagName(%s: string): HTMLCollectionOf;" m.Params.[0].Name /// Emit overloads for the querySelector method let EmitQuerySelectorOverloads (m: Browser.Method) = @@ -800,7 +806,7 @@ module Emit = /// Emit overloads for the querySelectorAll method let EmitQuerySelectorAllOverloads (m: Browser.Method) = if matchSingleParamMethodSignature m "querySelectorAll" "NodeList" "string" then - Pt.Printl "querySelectorAll(selectors: K): ElementListTagNameMap[K];" + Pt.Printl "querySelectorAll(selectors: K): NodeListOf;" Pt.Printl "querySelectorAll(selectors: string): NodeListOf;" let EmitHTMLElementTagNameMap () = @@ -823,12 +829,6 @@ module Emit = Pt.Printl "}" Pt.Printl "" - let EmitElementListTagNameMap () = - Pt.Printl "type ElementListTagNameMap = {" - Pt.PrintWithAddedIndent "[key in keyof ElementTagNameMap]: NodeListOf" - Pt.Printl "};" - Pt.Printl "" - /// Emit overloads for the createEvent method let EmitCreateEventOverloads (m: Browser.Method) = if matchSingleParamMethodSignature m "createEvent" "Event" "string" then @@ -848,16 +848,10 @@ module Emit = (if p.Variadic then "..." else "") + (AdjustParamName p.Name) + (if isOptional then "?: " else ": ") + - pType + + (if p.Variadic && pType.Contains(" | ") then "(" + pType + ")" else pType) + (if p.Variadic then "[]" else "") String.Join(", ", (List.map paramToString ps)) - let EmitCallBackInterface (i:Browser.Interface) = - Pt.Printl "interface %s {" i.Name - Pt.PrintWithAddedIndent "(evt: Event): void;" - Pt.Printl "}" - Pt.Printl "" - let EmitCallBackFunctions flavor = let emitCallbackFunctionsFromJson (cb: InputJson.InputJsonType.Root) = Pt.Printl "interface %s {" cb.Name.Value @@ -883,7 +877,8 @@ module Emit = let EmitEnums flavor = let emitEnum (e: Browser.Enum) = - Pt.Printl "type %s = %s;" e.Name (String.Join(" | ", e.Values |> Array.map (fun value -> "\"" + value + "\""))) + if not (Array.isEmpty e.Values) then + Pt.Printl "type %s = %s;" e.Name (String.Join(" | ", e.Values |> Array.map (fun value -> "\"" + value + "\""))) GetEnumsByFlavor flavor |> Array.iter emitEnum let EmitEventHandlerThis flavor (prefix: string) (i: Browser.Interface) = @@ -892,7 +887,7 @@ module Emit = | Some pollutor -> "this: " + pollutor.Name + ", " | _ -> "" - let EmitProperties flavor prefix (emitScope: EmitScope) (i: Browser.Interface) (conflictedMembers: Set) = + let EmitProperties flavor prefix (emitScope: EmitScope) (i: InterfaceOrNamespace) (conflictedMembers: Set) = let emitPropertyFromJson (p: InputJsonType.Root) = let readOnlyModifier = match p.Readonly with @@ -918,21 +913,26 @@ module Emit = | Some p' -> emitPropertyFromJson p' | None -> let pType = - match p.Type with - | "EventHandler" -> + match (i, p.Type) with + | (InterfaceOrNamespace.Interface it, "EventHandler") -> // Sometimes event handlers with the same name may actually handle different // events in different interfaces. For example, "onerror" handles "ErrorEvent" // normally, but in "SVGSVGElement" it handles "SVGError" event instead. let eType = if p.EventHandler.IsSome then - getEventTypeInInterface p.EventHandler.Value i + getEventTypeInInterface p.EventHandler.Value it else "Event" - String.Format("({0}ev: {1}) => any", EmitEventHandlerThis flavor prefix i, eType) + String.Format("({0}ev: {1}) => any", EmitEventHandlerThis flavor prefix it, eType) | _ -> DomTypeToTsType p.Type let pTypeAndNull = if p.Nullable.IsSome then makeNullable pType else pType - let readOnlyModifier = if p.ReadOnly.IsSome && prefix = "" then "readonly " else "" - printLine "%s%s%s: %s;" prefix readOnlyModifier p.Name pTypeAndNull + let modifierOrStatement = + match (p.ReadOnly, prefix, i) with + | (Some r, "", InterfaceOrNamespace.Interface it) -> "readonly " + | (None, "", InterfaceOrNamespace.Namespace n) -> "var " + | (Some r, "", InterfaceOrNamespace.Namespace n) -> "const " + | (_, _, _) -> "" + printLine "%s%s%s: %s;" prefix modifierOrStatement p.Name pTypeAndNull // Note: the schema file shows the property doesn't have "static" attribute, // therefore all properties are emited for the instance type. @@ -940,7 +940,7 @@ module Emit = match i.Properties with | Some ps -> ps.Properties - |> Array.filter (ShouldKeep flavor) + |> Array.filter (ShouldKeepInherit flavor i) |> Array.iter emitProperty | None -> () @@ -949,7 +949,7 @@ module Emit = emitCommentForProperty Pt.Printl addedItem.Name.Value emitPropertyFromJson addedItem - let EmitMethods flavor prefix (emitScope: EmitScope) (i: Browser.Interface) (conflictedMembers: Set) = + let EmitMethods flavor prefix (emitScope: EmitScope) (i: InterfaceOrNamespace) (conflictedMembers: Set) = // Note: two cases: // 1. emit the members inside a interface -> no need to add prefix // 2. emit the members outside to expose them (for "Window") -> need to add "declare" @@ -968,7 +968,7 @@ module Emit = matchScope emitScope m && not (prefix <> "" && OptionCheckValue "addEventListener" m.Name) - let emitMethod flavor prefix (i:Browser.Interface) (m:Browser.Method) = + let emitMethod flavor prefix (i: InterfaceOrNamespace) (m:Browser.Method) = let printLine content = if m.Name.IsSome && conflictedMembers.Contains m.Name.Value then Pt.PrintlToStack content else Pt.Printl content // print comment @@ -1013,6 +1013,7 @@ module Emit = if i.Methods.IsSome then i.Methods.Value.Methods + |> Array.filter (ShouldKeepInherit flavor i) |> Array.filter mFilter |> Array.iter (emitMethod flavor prefix i) @@ -1027,7 +1028,7 @@ module Emit = Pt.Printl "declare function toString(): string;" /// Emit the properties and methods of a given interface - let EmitMembers flavor (prefix: string) (emitScope: EmitScope) (i:Browser.Interface) = + let EmitMembers flavor (prefix: string) (emitScope: EmitScope) (i: InterfaceOrNamespace) = let conflictedMembers = match Map.tryFind i.Name extendConflictsBaseTypes with | Some conflict -> conflict.MemberNames @@ -1041,7 +1042,7 @@ module Emit = /// Called only once on the global polluter object let rec EmitAllMembers flavor (i:Browser.Interface) = let prefix = "declare var " - EmitMembers flavor prefix EmitScope.All i + EmitMembers flavor prefix EmitScope.All (InterfaceOrNamespace.Interface i) for relatedIName in iNameToIDependList.[i.Name] do match GetInterfaceByName relatedIName with @@ -1071,13 +1072,18 @@ module Emit = if shouldEmitStringEventHandler then Pt.Printl - "%saddEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void;" + "%saddEventListener(type: string, listener: EventListener, useCapture?: boolean): void;" fPrefix let EmitConstructorSignature flavor (i:Browser.Interface) = let emitConstructorSigFromJson (c: InputJsonType.Root) = c.Signatures |> Array.iter (Pt.Printl "%s;") + let emitConstructorSingleSignature (ctor: Browser.Constructor) = + for { ParamCombinations = pCombList } in GetOverloads (Ctor ctor) false do + let paramsString = ParamsToString pCombList + Pt.Printl "new(%s): %s;" paramsString i.Name + let removedCtor = getRemovedItems ItemKind.Constructor flavor |> Array.tryFind (matchInterface i.Name) if Option.isNone removedCtor then let overriddenCtor = getOverriddenItems ItemKind.Constructor flavor |> Array.tryFind (matchInterface i.Name) @@ -1085,15 +1091,12 @@ module Emit = | Some c' -> emitConstructorSigFromJson c' | _ -> //Emit constructor signature - match i.Constructor with - | Some ctor -> - for { ParamCombinations = pCombList } in GetOverloads (Ctor ctor) false do - let paramsString = ParamsToString pCombList - Pt.Printl "new(%s): %s;" paramsString i.Name - | _ -> Pt.Printl "new(): %s;" i.Name + if not (Array.isEmpty i.Constructors) then + i.Constructors |> Array.iter emitConstructorSingleSignature + else + Pt.Printl "new(): %s;" i.Name - getAddedItems ItemKind.Constructor flavor - |> Array.filter (matchInterface i.Name) + getAddedItemsByInterfaceName ItemKind.Constructor flavor i.Name |> Array.iter emitConstructorSigFromJson let EmitConstructor flavor (i:Browser.Interface) = @@ -1104,7 +1107,7 @@ module Emit = EmitConstructorSignature flavor i EmitConstants i let prefix = "" - EmitMembers flavor prefix EmitScope.StaticOnly i + EmitMembers flavor prefix EmitScope.StaticOnly (InterfaceOrNamespace.Interface i) Pt.DecreaseIndent() Pt.Printl "};" @@ -1123,10 +1126,15 @@ module Emit = Pt.Printl "declare var %s: { new(%s): %s; };" nc.Name (ParamsToString ncParams) i.Name) let EmitInterfaceDeclaration (i:Browser.Interface) = + let getConflict iName = Map.tryFind iName extendConflictsBaseTypes; let processIName iName = - match Map.tryFind iName extendConflictsBaseTypes with + match getConflict iName with | Some _ -> iName + "Base" | _ -> iName + let processExtendIName iName = + match getConflict iName with + | Some conflict -> if List.contains i.Name conflict.ExtendType then iName + "Base" else iName + | _ -> iName let processedIName = processIName i.Name if processedIName <> i.Name then @@ -1143,7 +1151,7 @@ module Emit = let extendsFromSpec = match i.Extends::(List.ofArray i.Implements) with | [""] | [] | ["Object"] -> [] - | specExtends -> specExtends + | specExtends -> List.filter allInterfacesMap.ContainsKey specExtends let extendsFromJson = InputJson.getAddedItemsByInterfaceName ItemKind.Extends Flavor.All i.Name |> Array.map (fun e -> e.BaseInterface.Value) |> List.ofArray @@ -1151,9 +1159,9 @@ module Emit = else overridenExtendsFromJson - combinedExtends |> List.map processIName + combinedExtends |> List.map processExtendIName - match finalExtends with + match finalExtends with | [] -> () | allExtends -> Pt.Print " extends %s" (String.Join(", ", allExtends)) Pt.Print " {" @@ -1252,7 +1260,7 @@ module Emit = Pt.IncreaseIndent() let prefix = "" - EmitMembers flavor prefix EmitScope.InstanceOnly i + EmitMembers flavor prefix EmitScope.InstanceOnly (InterfaceOrNamespace.Interface i) EmitConstants i EmitEventHandlers flavor prefix i EmitIndexers EmitScope.InstanceOnly i @@ -1311,7 +1319,7 @@ module Emit = Pt.IncreaseIndent() let prefix = "" - EmitMembers flavor prefix EmitScope.InstanceOnly i + EmitMembers flavor prefix EmitScope.InstanceOnly (InterfaceOrNamespace.Interface i) EmitEventHandlers flavor prefix i EmitIndexers EmitScope.InstanceOnly i @@ -1321,7 +1329,7 @@ module Emit = Pt.Printl "declare var %s: {" i.Name Pt.IncreaseIndent() EmitConstants i - EmitMembers flavor prefix EmitScope.StaticOnly i + EmitMembers flavor prefix EmitScope.StaticOnly (InterfaceOrNamespace.Interface i) emitAddedConstructor () Pt.DecreaseIndent() Pt.Printl "};" @@ -1333,7 +1341,7 @@ module Emit = Pt.IncreaseIndent() let prefix = "" - EmitMembers flavor prefix EmitScope.StaticOnly i + EmitMembers flavor prefix EmitScope.StaticOnly (InterfaceOrNamespace.Interface i) EmitConstants i EmitEventHandlers flavor prefix i EmitIndexers EmitScope.StaticOnly i @@ -1356,6 +1364,22 @@ module Emit = EmitInterface flavor i EmitConstructor flavor i + let EmitCallBackInterface flavor (i:Browser.Interface) = + if i.Exposed.IsNone || ShouldKeep flavor i then + let m = i.Methods.Value.Methods.[0] + let overload = (GetOverloads (Function.Method m) false).[0] + let paramsString = ParamsToString overload.ParamCombinations + let returnType = DomTypeToTsType m.Type + Pt.Printl "type %s = (%s) => %s | { %s(%s): %s; };" i.Name paramsString returnType m.Name.Value paramsString returnType + Pt.Printl "" + if i.Constants.IsSome then + Pt.Printl "declare var %s: {" i.Name + Pt.IncreaseIndent() + EmitConstants i + Pt.DecreaseIndent() + Pt.Printl "}" + Pt.Printl "" + let EmitDictionaries flavor = let emitDictionary (dict:Browser.Dictionary) = match dict.Extends with @@ -1391,12 +1415,9 @@ module Emit = Pt.Printl "" browser.Dictionaries - |> Array.filter (fun dict -> flavor <> Worker || knownWorkerInterfaces.Contains dict.Name) + |> Array.filter (getName >> ShouldKeepUnexposed flavor) |> Array.iter emitDictionary - if flavor = Worker then - worker.Dictionaries |> Array.iter emitDictionary - let EmitAddedInterface (ai: InputJsonType.Root) = match ai.Extends with | Some e -> Pt.Printl "interface %s extends %s {" ai.Name.Value ai.Extends.Value @@ -1418,10 +1439,13 @@ module Emit = | _ -> () m.Signatures |> Array.iter (Pt.PrintWithAddedIndent "%s;") + let emitConstant (c: InputJsonType.Constant) = + Pt.PrintWithAddedIndent "readonly %s: %s;" c.Name c.Type ai.Properties |> Array.iter emitProperty ai.Methods |> Array.iter emitMethod ai.Indexer |> Array.collect (fun i -> i.Signatures) |> Array.iter (Pt.PrintWithAddedIndent "%s;") + ai.Constants |> Array.iter emitConstant Pt.Printl "}" Pt.Printl "" @@ -1432,6 +1456,7 @@ module Emit = | Some comment -> Pt.PrintWithAddedIndent "%s" comment | _ -> () ai.ConstructorSignatures |> Array.iter (Pt.PrintWithAddedIndent "%s;") + ai.Constants |> Array.iter emitConstant Pt.Printl "};" Pt.Printl "" @@ -1441,18 +1466,24 @@ module Emit = let emitTypeDefFromJson (typeDef: InputJsonType.Root) = Pt.Printl "type %s = %s;" typeDef.Name.Value typeDef.Type.Value - match flavor with - | Flavor.Worker -> - browser.Typedefs - |> Array.filter (fun typedef -> knownWorkerInterfaces.Contains typedef.NewType) - |> Array.iter emitTypeDef - | _ -> - browser.Typedefs - |> Array.filter (fun typedef -> getRemovedItemByName typedef.NewType ItemKind.TypeDef "" |> Option.isNone) - |> Array.iter emitTypeDef + GetTypedefsByFlavor flavor + |> Array.filter (fun typedef -> getRemovedItemByName typedef.NewType ItemKind.TypeDef "" |> Option.isNone) + |> Array.iter emitTypeDef InputJson.getAddedItems ItemKind.TypeDef flavor |> Array.iter emitTypeDefFromJson + + let EmitNamespaces flavor = + let emitNamespace (n: Browser.Namespace) = + Pt.Printl "declare namespace %s {" n.Name + Pt.IncreaseIndent() + EmitProperties flavor "" EmitScope.All (InterfaceOrNamespace.Namespace n) Set.empty + EmitMethods flavor "function " EmitScope.All (InterfaceOrNamespace.Namespace n) Set.empty + Pt.DecreaseIndent() + Pt.Printl "}" + Pt.Printl "" + + GetNamespacesByFlavor flavor |> Array.iter emitNamespace let EmitTheWholeThing flavor (target:TextWriter) = Pt.Reset() @@ -1464,21 +1495,18 @@ module Emit = Pt.Printl "" EmitDictionaries flavor - browser.CallbackInterfaces.Interfaces |> Array.iter EmitCallBackInterface + browser.CallbackInterfaces.Interfaces |> Array.iter (EmitCallBackInterface flavor) EmitNonCallbackInterfaces flavor + EmitNamespaces flavor // Add missed interface definition from the spec InputJson.getAddedItems InputJson.Interface flavor |> Array.iter EmitAddedInterface - Pt.Printl "declare type EventListenerOrEventListenerObject = EventListener | EventListenerObject;" - Pt.Printl "" - EmitCallBackFunctions flavor if flavor <> Worker then EmitHTMLElementTagNameMap() EmitElementTagNameMap() - EmitElementListTagNameMap() EmitNamedConstructors() match GetGlobalPollutor flavor with @@ -1539,7 +1567,7 @@ module Emit = target.Close() let EmitDomWeb () = - EmitTheWholeThing Flavor.All GlobalVars.tsWebOutput + EmitTheWholeThing Flavor.Web GlobalVars.tsWebOutput EmitES6Thing GlobalVars.tsWebES6Output let EmitDomWorker () = diff --git a/baselines/dom.es6.generated.d.ts b/baselines/dom.es6.generated.d.ts index 6eaf13f32..2236a49be 100644 --- a/baselines/dom.es6.generated.d.ts +++ b/baselines/dom.es6.generated.d.ts @@ -7,20 +7,16 @@ interface AudioTrackList { [Symbol.iterator](): IterableIterator } -interface ClientRectList { - [Symbol.iterator](): IterableIterator -} - interface CSSRuleList { [Symbol.iterator](): IterableIterator } interface CSSStyleDeclaration { - [Symbol.iterator](): IterableIterator + [Symbol.iterator](): IterableIterator } interface DataTransferItemList { - [Symbol.iterator](): IterableIterator + [Symbol.iterator](): IterableIterator } interface DOMStringList { @@ -43,16 +39,20 @@ interface HTMLCollection { [Symbol.iterator](): IterableIterator } -interface MediaList { - [Symbol.iterator](): IterableIterator +interface HTMLFormElement { + [Symbol.iterator](): IterableIterator } -interface MimeTypeArray { - [Symbol.iterator](): IterableIterator +interface HTMLSelectElement { + [Symbol.iterator](): IterableIterator } -interface MSRangeCollection { - [Symbol.iterator](): IterableIterator +interface MediaList { + [Symbol.iterator](): IterableIterator +} + +interface MimeTypeArray { + [Symbol.iterator](): IterableIterator } interface NamedNodeMap { @@ -75,16 +75,40 @@ interface SourceBufferList { [Symbol.iterator](): IterableIterator } -interface Storage { - [Symbol.iterator](): IterableIterator +interface SpeechGrammarList { + [Symbol.iterator](): IterableIterator +} + +interface SpeechRecognitionResult { + [Symbol.iterator](): IterableIterator +} + +interface SpeechRecognitionResultList { + [Symbol.iterator](): IterableIterator } interface StyleSheetList { [Symbol.iterator](): IterableIterator } -interface StyleSheetPageList { - [Symbol.iterator](): IterableIterator +interface SVGLengthList { + [Symbol.iterator](): IterableIterator +} + +interface SVGNumberList { + [Symbol.iterator](): IterableIterator +} + +interface SVGPointList { + [Symbol.iterator](): IterableIterator +} + +interface SVGStringList { + [Symbol.iterator](): IterableIterator +} + +interface SVGTransformList { + [Symbol.iterator](): IterableIterator } interface TextTrackCueList { diff --git a/baselines/dom.generated.d.ts b/baselines/dom.generated.d.ts index 7768a5503..bf52dca1a 100644 --- a/baselines/dom.generated.d.ts +++ b/baselines/dom.generated.d.ts @@ -3,28 +3,135 @@ /// DOM APIs ///////////////////////////// -interface Account { - displayName: string; - id: string; - imageURL?: string; - name?: string; - rpDisplayName: string; +interface AddEventListenerOptions extends EventListenerOptions { + once?: boolean; + passive?: boolean; +} + +interface AesCbcParams extends Algorithm { + iv: BufferSource; +} + +interface AesCtrParams extends Algorithm { + counter: BufferSource; + length: number; +} + +interface AesDerivedKeyParams extends Algorithm { + length: number; +} + +interface AesGcmParams extends Algorithm { + additionalData?: BufferSource; + iv: BufferSource; + tagLength?: number; +} + +interface AesKeyAlgorithm extends KeyAlgorithm { + length: number; +} + +interface AesKeyGenParams extends Algorithm { + length: number; } interface Algorithm { name: string; } +interface AnalyserOptions extends AudioNodeOptions { + fftSize?: number; + maxDecibels?: number; + minDecibels?: number; + smoothingTimeConstant?: number; +} + interface AnimationEventInit extends EventInit { - animationName?: string; + animationName?: CSSOMString; elapsedTime?: number; + pseudoElement?: CSSOMString; +} + +interface AssignedNodesOptions { + flatten?: boolean; +} + +interface AudioBufferOptions { + length: number; + numberOfChannels?: number; + sampleRate: number; +} + +interface AudioBufferSourceOptions { + buffer?: AudioBuffer | null; + detune?: number; + loop?: boolean; + loopEnd?: number; + loopStart?: number; + playbackRate?: number; +} + +interface AudioContextInfo { + currentTime?: number; + sampleRate?: number; +} + +interface AudioContextOptions { + latencyHint?: AudioContextLatencyCategory | number; + sampleRate?: number; +} + +interface AudioNodeOptions { + channelCount?: number; + channelCountMode?: ChannelCountMode; + channelInterpretation?: ChannelInterpretation; +} + +interface AudioParamDescriptor { + defaultValue?: number; + maxValue?: number; + minValue?: number; + name?: string; +} + +interface AudioProcessingEventInit extends EventInit { + inputBuffer: AudioBuffer; + outputBuffer: AudioBuffer; + playbackTime: number; +} + +interface AudioTimestamp { + contextTime?: number; + performanceTime?: number; +} + +interface AudioWorkletNodeOptions extends AudioNodeOptions { + numberOfInputs?: number; + numberOfOutputs?: number; +} + +interface BiquadFilterOptions extends AudioNodeOptions { + detune?: number; + frequency?: number; + gain?: number; + Q?: number; + type?: BiquadFilterType; +} + +interface BlobPropertyBag { + type?: string; +} + +interface BoxQuadOptions { + box?: CSSBoxType; + relativeTo?: GeometryNode; } -interface AssertionOptions { - allowList?: ScopedCredentialDescriptor[]; - extensions?: WebAuthnExtensions; - rpId?: USVString; - timeoutSeconds?: number; +interface CacheBatchOperation { + options?: CacheQueryOptions; + request?: Request; + response?: Response; + type?: string; } interface CacheQueryOptions { @@ -34,13 +141,23 @@ interface CacheQueryOptions { ignoreVary?: boolean; } -interface ClientData { - challenge: string; - extensions?: WebAuthnExtensions; - hashAlg: string | Algorithm; - origin: string; - rpId: string; - tokenBinding?: string; +interface CanvasRenderingContext2DSettings { + alpha?: boolean; +} + +interface Capabilities { +} + +interface ChannelMergerOptions extends AudioNodeOptions { + numberOfInputs?: number; +} + +interface ChannelSplitterOptions extends AudioNodeOptions { + numberOfOutputs?: number; +} + +interface ClipboardEventInit extends EventInit { + clipboardData?: DataTransfer | null; } interface CloseEventInit extends EventInit { @@ -53,8 +170,8 @@ interface CompositionEventInit extends UIEventInit { data?: string; } -interface ConfirmSiteSpecificExceptionsInformation extends ExceptionInformation { - arrayOfDomainStrings?: string[]; +interface ConstantSourceOptions { + offset?: number; } interface ConstrainBooleanParameters { @@ -77,30 +194,48 @@ interface ConstrainLongRange extends LongRange { ideal?: number; } -interface ConstrainVideoFacingModeParameters { - exact?: VideoFacingModeEnum | VideoFacingModeEnum[]; - ideal?: VideoFacingModeEnum | VideoFacingModeEnum[]; +interface Constraints extends ConstraintSet { + advanced?: ConstraintSet[]; +} + +interface ConstraintSet { +} + +interface ConvertCoordinateOptions { + fromBox?: CSSBoxType; + toBox?: CSSBoxType; +} + +interface ConvolverOptions extends AudioNodeOptions { + buffer?: AudioBuffer | null; + disableNormalization?: boolean; +} + +interface CryptoKeyPair { + privateKey?: CryptoKey; + publicKey?: CryptoKey; } interface CustomEventInit extends EventInit { detail?: any; } -interface DeviceAccelerationDict { +interface DelayOptions extends AudioNodeOptions { + delayTime?: number; + maxDelayTime?: number; +} + +interface DeviceAccelerationInit { x?: number | null; y?: number | null; z?: number | null; } -interface DeviceLightEventInit extends EventInit { - value?: number; -} - interface DeviceMotionEventInit extends EventInit { - acceleration?: DeviceAccelerationDict | null; - accelerationIncludingGravity?: DeviceAccelerationDict | null; + acceleration?: DeviceAccelerationInit | null; + accelerationIncludingGravity?: DeviceAccelerationInit | null; interval?: number | null; - rotationRate?: DeviceRotationRateDict | null; + rotationRate?: DeviceRotationRateInit | null; } interface DeviceOrientationEventInit extends EventInit { @@ -110,12 +245,52 @@ interface DeviceOrientationEventInit extends EventInit { gamma?: number | null; } -interface DeviceRotationRateDict { +interface DeviceRotationRateInit { alpha?: number | null; beta?: number | null; gamma?: number | null; } +interface DOMMatrixInit { + a?: number; + b?: number; + c?: number; + d?: number; + e?: number; + f?: number; + is2D?: boolean; + m11?: number; + m12?: number; + m13?: number; + m14?: number; + m21?: number; + m22?: number; + m23?: number; + m24?: number; + m31?: number; + m32?: number; + m33?: number; + m34?: number; + m41?: number; + m42?: number; + m43?: number; + m44?: number; +} + +interface DOMPointInit { + w?: number; + x?: number; + y?: number; + z?: number; +} + +interface DOMQuadInit { + p1?: DOMPointInit; + p2?: DOMPointInit; + p3?: DOMPointInit; + p4?: DOMPointInit; +} + interface DOMRectInit { height?: number; width?: number; @@ -128,6 +303,46 @@ interface DoubleRange { min?: number; } +interface DragEventInit extends MouseEventInit { + dataTransfer?: DataTransfer | null; +} + +interface DynamicsCompressorOptions extends AudioNodeOptions { + attack?: number; + knee?: number; + ratio?: number; + release?: number; + threshold?: number; +} + +interface EcdhKeyDeriveParams extends Algorithm { + public: CryptoKey; +} + +interface EcdsaParams extends Algorithm { + hash: HashAlgorithmIdentifier; +} + +interface EcKeyAlgorithm extends KeyAlgorithm { + namedCurve: NamedCurve; +} + +interface EcKeyGenParams extends Algorithm { + namedCurve: NamedCurve; +} + +interface EcKeyImportParams extends Algorithm { + namedCurve: NamedCurve; +} + +interface ElementCreationOptions { + is?: string; +} + +interface ElementDefinitionOptions { + extends?: string; +} + interface ErrorEventInit extends EventInit { colno?: number; error?: any; @@ -140,6 +355,11 @@ interface EventInit { scoped?: boolean; bubbles?: boolean; cancelable?: boolean; + composed?: boolean; +} + +interface EventListenerOptions { + capture?: boolean; } interface EventModifierInit extends UIEventInit { @@ -152,7 +372,6 @@ interface EventModifierInit extends UIEventInit { modifierFnLock?: boolean; modifierHyper?: boolean; modifierNumLock?: boolean; - modifierOS?: boolean; modifierScrollLock?: boolean; modifierSuper?: boolean; modifierSymbol?: boolean; @@ -160,40 +379,58 @@ interface EventModifierInit extends UIEventInit { shiftKey?: boolean; } -interface ExceptionInformation { - domain?: string | null; +interface EventSourceInit { + withCredentials?: boolean; } -interface FocusEventInit extends UIEventInit { - relatedTarget?: EventTarget | null; +interface FilePropertyBag extends BlobPropertyBag { + lastModified?: number; } -interface FocusNavigationEventInit extends EventInit { - navigationReason?: string | null; - originHeight?: number; - originLeft?: number; - originTop?: number; - originWidth?: number; +interface FocusEventInit extends UIEventInit { + relatedTarget?: EventTarget | null; } -interface FocusNavigationOrigin { - originHeight?: number; - originLeft?: number; - originTop?: number; - originWidth?: number; +interface GainOptions extends AudioNodeOptions { + gain?: number; } interface GamepadEventInit extends EventInit { - gamepad?: Gamepad | null; + gamepad: Gamepad; } interface GetNotificationOptions { tag?: string; } +interface GetRootNodeOptions { + composed?: boolean; +} + interface HashChangeEventInit extends EventInit { - newURL?: string | null; - oldURL?: string | null; + newURL?: string; + oldURL?: string; +} + +interface HkdfParams extends Algorithm { + hash: HashAlgorithmIdentifier; + info: BufferSource; + salt: BufferSource; +} + +interface HmacImportParams extends Algorithm { + hash: HashAlgorithmIdentifier; + length?: number; +} + +interface HmacKeyAlgorithm extends KeyAlgorithm { + hash: KeyAlgorithm; + length: number; +} + +interface HmacKeyGenParams extends Algorithm { + hash: HashAlgorithmIdentifier; + length?: number; } interface IDBIndexParameters { @@ -203,13 +440,47 @@ interface IDBIndexParameters { interface IDBObjectStoreParameters { autoIncrement?: boolean; - keyPath?: IDBKeyPath | null; + keyPath?: string | string[] | null; +} + +interface IDBVersionChangeEventInit extends EventInit { + newVersion?: number | null; + oldVersion?: number; +} + +interface IIRFilterOptions extends AudioNodeOptions { + feedback: number[]; + feedforward: number[]; +} + +interface ImageBitmapOptions { + colorSpaceConversion?: ColorSpaceConversion; + imageOrientation?: ImageOrientation; + premultiplyAlpha?: PremultiplyAlpha; + resizeHeight?: number; + resizeQuality?: ResizeQuality; + resizeWidth?: number; +} + +interface ImageBitmapRenderingContextSettings { + alpha?: boolean; +} + +interface ImageEncodeOptions { + quality?: number; + type?: string; +} + +interface InputEventInit extends UIEventInit { + data?: string | null; + isComposing?: boolean; } interface IntersectionObserverEntryInit { - isIntersecting: boolean; boundingClientRect: DOMRectInit; + intersectionRatio: number; intersectionRect: DOMRectInit; + isIntersecting: boolean; rootBounds: DOMRectInit; target: Element; time: number; @@ -221,12 +492,34 @@ interface IntersectionObserverInit { threshold?: number | number[]; } +interface JsonWebKey { + alg?: string; + crv?: string; + d?: string; + dp?: string; + dq?: string; + e?: string; + ext?: boolean; + k?: string; + key_ops?: string[]; + kty?: string; + n?: string; + oth?: RsaOtherPrimesInfo[]; + p?: string; + q?: string; + qi?: string; + use?: string; + x?: string; + y?: string; +} + interface KeyAlgorithm { - name?: string; + name: string; } interface KeyboardEventInit extends EventModifierInit { code?: string; + isComposing?: boolean; key?: string; location?: number; repeat?: boolean; @@ -237,21 +530,27 @@ interface LongRange { min?: number; } +interface MediaElementAudioSourceOptions { + mediaElement: HTMLMediaElement; +} + interface MediaEncryptedEventInit extends EventInit { initData?: ArrayBuffer | null; initDataType?: string; } interface MediaKeyMessageEventInit extends EventInit { - message?: ArrayBuffer | null; - messageType?: MediaKeyMessageType; + message: ArrayBuffer; + messageType: MediaKeyMessageType; } interface MediaKeySystemConfiguration { audioCapabilities?: MediaKeySystemMediaCapability[]; distinctiveIdentifier?: MediaKeysRequirement; initDataTypes?: string[]; + label?: string; persistentState?: MediaKeysRequirement; + sessionTypes?: string[]; videoCapabilities?: MediaKeySystemMediaCapability[]; } @@ -260,35 +559,43 @@ interface MediaKeySystemMediaCapability { robustness?: string; } +interface MediaQueryListEventInit extends EventInit { + matches?: boolean; + media?: string; +} + +interface MediaStreamAudioSourceOptions { + mediaStream: MediaStream; +} + interface MediaStreamConstraints { audio?: boolean | MediaTrackConstraints; + peerIdentity?: string; video?: boolean | MediaTrackConstraints; } -interface MediaStreamErrorEventInit extends EventInit { - error?: MediaStreamError | null; -} - -interface MediaStreamEventInit extends EventInit { - stream?: MediaStream; +interface MediaStreamTrackAudioSourceOptions { + mediaStreamTrack: any; } interface MediaStreamTrackEventInit extends EventInit { - track?: MediaStreamTrack | null; + track: MediaStreamTrack; } interface MediaTrackCapabilities { - aspectRatio?: number | DoubleRange; + aspectRatio?: DoubleRange; + channelCount?: LongRange; deviceId?: string; echoCancellation?: boolean[]; - facingMode?: string; - frameRate?: number | DoubleRange; + facingMode?: string[]; + frameRate?: DoubleRange; groupId?: string; - height?: number | LongRange; - sampleRate?: number | LongRange; - sampleSize?: number | LongRange; - volume?: number | DoubleRange; - width?: number | LongRange; + height?: LongRange; + latency?: DoubleRange; + sampleRate?: LongRange; + sampleSize?: LongRange; + volume?: DoubleRange; + width?: LongRange; } interface MediaTrackConstraints extends MediaTrackConstraintSet { @@ -296,27 +603,31 @@ interface MediaTrackConstraints extends MediaTrackConstraintSet { } interface MediaTrackConstraintSet { - aspectRatio?: number | ConstrainDoubleRange; - deviceId?: string | string[] | ConstrainDOMStringParameters; - echoCancelation?: boolean | ConstrainBooleanParameters; - facingMode?: string | string[] | ConstrainDOMStringParameters; - frameRate?: number | ConstrainDoubleRange; - groupId?: string | string[] | ConstrainDOMStringParameters; - height?: number | ConstrainLongRange; - sampleRate?: number | ConstrainLongRange; - sampleSize?: number | ConstrainLongRange; - volume?: number | ConstrainDoubleRange; - width?: number | ConstrainLongRange; + aspectRatio?: ConstrainDouble; + channelCount?: ConstrainLong; + deviceId?: ConstrainDOMString; + echoCancellation?: ConstrainBoolean; + facingMode?: ConstrainDOMString; + frameRate?: ConstrainDouble; + groupId?: ConstrainDOMString; + height?: ConstrainLong; + latency?: ConstrainDouble; + sampleRate?: ConstrainLong; + sampleSize?: ConstrainLong; + volume?: ConstrainDouble; + width?: ConstrainLong; } interface MediaTrackSettings { aspectRatio?: number; + channelCount?: number; deviceId?: string; echoCancellation?: boolean; facingMode?: string; frameRate?: number; groupId?: string; height?: number; + latency?: number; sampleRate?: number; sampleSize?: number; volume?: number; @@ -325,12 +636,14 @@ interface MediaTrackSettings { interface MediaTrackSupportedConstraints { aspectRatio?: boolean; + channelCount?: boolean; deviceId?: boolean; echoCancellation?: boolean; facingMode?: boolean; frameRate?: boolean; groupId?: boolean; height?: boolean; + latency?: boolean; sampleRate?: boolean; sampleSize?: boolean; volume?: boolean; @@ -338,12 +651,12 @@ interface MediaTrackSupportedConstraints { } interface MessageEventInit extends EventInit { - lastEventId?: string; channel?: string; data?: any; + lastEventId?: string; origin?: string; ports?: MessagePort[]; - source?: Window; + source?: MessageEventSource | null; } interface MouseEventInit extends EventModifierInit { @@ -356,307 +669,6 @@ interface MouseEventInit extends EventModifierInit { screenY?: number; } -interface MSAccountInfo { - accountImageUri?: string; - accountName?: string; - rpDisplayName: string; - userDisplayName: string; - userId?: string; -} - -interface MSAudioLocalClientEvent extends MSLocalClientEventBase { - cpuInsufficientEventRatio?: number; - deviceCaptureNotFunctioningEventRatio?: number; - deviceClippingEventRatio?: number; - deviceEchoEventRatio?: number; - deviceGlitchesEventRatio?: number; - deviceHalfDuplexAECEventRatio?: number; - deviceHowlingEventCount?: number; - deviceLowSNREventRatio?: number; - deviceLowSpeechLevelEventRatio?: number; - deviceMultipleEndpointsEventCount?: number; - deviceNearEndToEchoRatioEventRatio?: number; - deviceRenderMuteEventRatio?: number; - deviceRenderNotFunctioningEventRatio?: number; - deviceRenderZeroVolumeEventRatio?: number; - networkDelayEventRatio?: number; - networkSendQualityEventRatio?: number; -} - -interface MSAudioRecvPayload extends MSPayloadBase { - burstLossLength1?: number; - burstLossLength2?: number; - burstLossLength3?: number; - burstLossLength4?: number; - burstLossLength5?: number; - burstLossLength6?: number; - burstLossLength7?: number; - burstLossLength8OrHigher?: number; - fecRecvDistance1?: number; - fecRecvDistance2?: number; - fecRecvDistance3?: number; - packetReorderDepthAvg?: number; - packetReorderDepthMax?: number; - packetReorderRatio?: number; - ratioCompressedSamplesAvg?: number; - ratioConcealedSamplesAvg?: number; - ratioStretchedSamplesAvg?: number; - samplingRate?: number; - signal?: MSAudioRecvSignal; -} - -interface MSAudioRecvSignal { - initialSignalLevelRMS?: number; - recvNoiseLevelCh1?: number; - recvSignalLevelCh1?: number; - renderLoopbackSignalLevel?: number; - renderNoiseLevel?: number; - renderSignalLevel?: number; -} - -interface MSAudioSendPayload extends MSPayloadBase { - audioFECUsed?: boolean; - samplingRate?: number; - sendMutePercent?: number; - signal?: MSAudioSendSignal; -} - -interface MSAudioSendSignal { - noiseLevel?: number; - sendNoiseLevelCh1?: number; - sendSignalLevelCh1?: number; -} - -interface MSConnectivity { - iceType?: MSIceType; - iceWarningFlags?: MSIceWarningFlags; - relayAddress?: MSRelayAddress; -} - -interface MSCredentialFilter { - accept?: MSCredentialSpec[]; -} - -interface MSCredentialParameters { - type?: MSCredentialType; -} - -interface MSCredentialSpec { - id?: string; - type: MSCredentialType; -} - -interface MSDelay { - roundTrip?: number; - roundTripMax?: number; -} - -interface MSDescription extends RTCStats { - connectivity?: MSConnectivity; - deviceDevName?: string; - localAddr?: MSIPAddressInfo; - networkconnectivity?: MSNetworkConnectivityInfo; - reflexiveLocalIPAddr?: MSIPAddressInfo; - remoteAddr?: MSIPAddressInfo; - transport?: RTCIceProtocol; -} - -interface MSFIDOCredentialParameters extends MSCredentialParameters { - algorithm?: string | Algorithm; - authenticators?: AAGUID[]; -} - -interface MSIceWarningFlags { - allocationMessageIntegrityFailed?: boolean; - alternateServerReceived?: boolean; - connCheckMessageIntegrityFailed?: boolean; - connCheckOtherError?: boolean; - fipsAllocationFailure?: boolean; - multipleRelayServersAttempted?: boolean; - noRelayServersConfigured?: boolean; - portRangeExhausted?: boolean; - pseudoTLSFailure?: boolean; - tcpNatConnectivityFailed?: boolean; - tcpRelayConnectivityFailed?: boolean; - turnAuthUnknownUsernameError?: boolean; - turnTcpAllocateFailed?: boolean; - turnTcpSendFailed?: boolean; - turnTcpTimedOut?: boolean; - turnTurnTcpConnectivityFailed?: boolean; - turnUdpAllocateFailed?: boolean; - turnUdpSendFailed?: boolean; - udpLocalConnectivityFailed?: boolean; - udpNatConnectivityFailed?: boolean; - udpRelayConnectivityFailed?: boolean; - useCandidateChecksFailed?: boolean; -} - -interface MSIPAddressInfo { - ipAddr?: string; - manufacturerMacAddrMask?: string; - port?: number; -} - -interface MSJitter { - interArrival?: number; - interArrivalMax?: number; - interArrivalSD?: number; -} - -interface MSLocalClientEventBase extends RTCStats { - networkBandwidthLowEventRatio?: number; - networkReceiveQualityEventRatio?: number; -} - -interface MSNetwork extends RTCStats { - delay?: MSDelay; - jitter?: MSJitter; - packetLoss?: MSPacketLoss; - utilization?: MSUtilization; -} - -interface MSNetworkConnectivityInfo { - linkspeed?: number; - networkConnectionDetails?: string; - vpn?: boolean; -} - -interface MSNetworkInterfaceType { - interfaceTypeEthernet?: boolean; - interfaceTypePPP?: boolean; - interfaceTypeTunnel?: boolean; - interfaceTypeWireless?: boolean; - interfaceTypeWWAN?: boolean; -} - -interface MSOutboundNetwork extends MSNetwork { - appliedBandwidthLimit?: number; -} - -interface MSPacketLoss { - lossRate?: number; - lossRateMax?: number; -} - -interface MSPayloadBase extends RTCStats { - payloadDescription?: string; -} - -interface MSPortRange { - max?: number; - min?: number; -} - -interface MSRelayAddress { - port?: number; - relayAddress?: string; -} - -interface MSSignatureParameters { - userPrompt?: string; -} - -interface MSTransportDiagnosticsStats extends RTCStats { - allocationTimeInMs?: number; - baseAddress?: string; - baseInterface?: MSNetworkInterfaceType; - iceRole?: RTCIceRole; - iceWarningFlags?: MSIceWarningFlags; - interfaces?: MSNetworkInterfaceType; - localAddress?: string; - localAddrType?: MSIceAddrType; - localInterface?: MSNetworkInterfaceType; - localMR?: string; - localMRTCPPort?: number; - localSite?: string; - msRtcEngineVersion?: string; - networkName?: string; - numConsentReqReceived?: number; - numConsentReqSent?: number; - numConsentRespReceived?: number; - numConsentRespSent?: number; - portRangeMax?: number; - portRangeMin?: number; - protocol?: RTCIceProtocol; - remoteAddress?: string; - remoteAddrType?: MSIceAddrType; - remoteMR?: string; - remoteMRTCPPort?: number; - remoteSite?: string; - rtpRtcpMux?: boolean; - stunVer?: number; -} - -interface MSUtilization { - bandwidthEstimation?: number; - bandwidthEstimationAvg?: number; - bandwidthEstimationMax?: number; - bandwidthEstimationMin?: number; - bandwidthEstimationStdDev?: number; - packets?: number; -} - -interface MSVideoPayload extends MSPayloadBase { - durationSeconds?: number; - resolution?: string; - videoBitRateAvg?: number; - videoBitRateMax?: number; - videoFrameRateAvg?: number; - videoPacketLossRate?: number; -} - -interface MSVideoRecvPayload extends MSVideoPayload { - lowBitRateCallPercent?: number; - lowFrameRateCallPercent?: number; - recvBitRateAverage?: number; - recvBitRateMaximum?: number; - recvCodecType?: string; - recvFpsHarmonicAverage?: number; - recvFrameRateAverage?: number; - recvNumResSwitches?: number; - recvReorderBufferMaxSuccessfullyOrderedExtent?: number; - recvReorderBufferMaxSuccessfullyOrderedLateTime?: number; - recvReorderBufferPacketsDroppedDueToBufferExhaustion?: number; - recvReorderBufferPacketsDroppedDueToTimeout?: number; - recvReorderBufferReorderedPackets?: number; - recvResolutionHeight?: number; - recvResolutionWidth?: number; - recvVideoStreamsMax?: number; - recvVideoStreamsMin?: number; - recvVideoStreamsMode?: number; - reorderBufferTotalPackets?: number; - videoFrameLossRate?: number; - videoPostFECPLR?: number; - videoResolutions?: MSVideoResolutionDistribution; -} - -interface MSVideoResolutionDistribution { - cifQuality?: number; - h1080Quality?: number; - h1440Quality?: number; - h2160Quality?: number; - h720Quality?: number; - vgaQuality?: number; -} - -interface MSVideoSendPayload extends MSVideoPayload { - sendBitRateAverage?: number; - sendBitRateMaximum?: number; - sendFrameRateAverage?: number; - sendResolutionHeight?: number; - sendResolutionWidth?: number; - sendVideoStreamsMax?: number; -} - -interface MsZoomToOptions { - animate?: string; - contentX?: number; - contentY?: number; - scaleFactor?: number; - viewportX?: string | null; - viewportY?: string | null; -} - interface MutationObserverInit { attributeFilter?: string[]; attributeOldValue?: boolean; @@ -667,16 +679,69 @@ interface MutationObserverInit { subtree?: boolean; } +interface NavigationPreloadState { + enabled?: boolean; + headerValue?: string; +} + +interface NotificationAction { + action: string; + icon?: string; + title: string; +} + interface NotificationOptions { + actions?: NotificationAction[]; + badge?: string; body?: string; + data?: any; dir?: NotificationDirection; icon?: string; + image?: string; lang?: string; + renotify?: boolean; + requireInteraction?: boolean; + silent?: boolean; + sound?: string; tag?: string; + timestamp?: number; + vibrate?: any; +} + +interface OfflineAudioCompletionEventInit extends EventInit { + renderedBuffer: AudioBuffer; +} + +interface OscillatorOptions extends AudioNodeOptions { + detune?: number; + frequency?: number; + periodicWave?: PeriodicWave; + type?: OscillatorType; +} + +interface OverconstrainedErrorEventInit extends EventInit { + error?: any; +} + +interface PageTransitionEventInit extends EventInit { + persisted?: boolean; } -interface ObjectURLOptions { - oneTimeOnly?: boolean; +interface PannerOptions extends AudioNodeOptions { + coneInnerAngle?: number; + coneOuterAngle?: number; + coneOuterGain?: number; + distanceModel?: DistanceModelType; + maxDistance?: number; + orientationX?: number; + orientationY?: number; + orientationZ?: number; + panningModel?: PanningModelType; + positionX?: number; + positionY?: number; + positionZ?: number; + refDistance?: number; + rolloffFactor?: number; } interface PaymentCurrencyAmount { @@ -685,12 +750,15 @@ interface PaymentCurrencyAmount { value: string; } -interface PaymentDetails { +interface PaymentDetailsBase { displayItems?: PaymentItem[]; - error?: string; modifiers?: PaymentDetailsModifier[]; shippingOptions?: PaymentShippingOption[]; - total?: PaymentItem; +} + +interface PaymentDetailsInit extends PaymentDetailsBase { + id?: string; + total: PaymentItem; } interface PaymentDetailsModifier { @@ -700,9 +768,14 @@ interface PaymentDetailsModifier { total?: PaymentItem; } -interface PaymentItem { - amount: PaymentCurrencyAmount; - label: string; +interface PaymentDetailsUpdate extends PaymentDetailsBase { + error?: string; + total?: PaymentItem; +} + +interface PaymentItem { + amount: PaymentCurrencyAmount; + label: string; pending?: boolean; } @@ -716,7 +789,7 @@ interface PaymentOptions { requestPayerName?: boolean; requestPayerPhone?: boolean; requestShipping?: boolean; - shippingType?: string; + shippingType?: PaymentShippingType; } interface PaymentRequestUpdateEventInit extends EventInit { @@ -729,10 +802,25 @@ interface PaymentShippingOption { selected?: boolean; } +interface Pbkdf2Params extends Algorithm { + hash: HashAlgorithmIdentifier; + iterations: number; + salt: BufferSource; +} + +interface PerformanceObserverInit { + entryTypes: string[]; +} + interface PeriodicWaveConstraints { disableNormalization?: boolean; } +interface PeriodicWaveOptions extends PeriodicWaveConstraints { + imag?: number[]; + real?: number[]; +} + interface PointerEventInit extends MouseEventInit { height?: number; isPrimary?: boolean; @@ -760,20 +848,31 @@ interface ProgressEventInit extends EventInit { total?: number; } +interface PromiseRejectionEventInit extends EventInit { + promise: Promise; + reason?: any; +} + interface PushSubscriptionOptionsInit { - applicationServerKey?: any; + applicationServerKey?: BufferSource | string | null; userVisibleOnly?: boolean; } interface RegistrationOptions { scope?: string; + type?: WorkerType; + useCache?: boolean; +} + +interface RelatedEventInit extends EventInit { + relatedTarget?: EventTarget | null; } interface RequestInit { - body?: any; + body?: BodyInit | null; cache?: RequestCache; credentials?: RequestCredentials; - headers?: Headers | string[][]; + headers?: HeadersInit; integrity?: string; keepalive?: boolean; method?: string; @@ -785,66 +884,128 @@ interface RequestInit { } interface ResponseInit { - headers?: Headers | string[][]; + headers?: HeadersInit; status?: number; statusText?: string; } +interface RsaHashedImportParams extends Algorithm { + hash: HashAlgorithmIdentifier; +} + +interface RsaHashedKeyAlgorithm extends RsaKeyAlgorithm { + hash: KeyAlgorithm; +} + +interface RsaHashedKeyGenParams extends RsaKeyGenParams { + hash: HashAlgorithmIdentifier; +} + +interface RsaKeyAlgorithm extends KeyAlgorithm { + modulusLength: number; + publicExponent: BigInteger; +} + +interface RsaKeyGenParams extends Algorithm { + modulusLength: number; + publicExponent: BigInteger; +} + +interface RsaOaepParams extends Algorithm { + label?: BufferSource; +} + +interface RsaOtherPrimesInfo { + d?: string; + r?: string; + t?: string; +} + +interface RsaPssParams extends Algorithm { + saltLength: number; +} + +interface RTCAnswerOptions extends RTCOfferAnswerOptions { +} + +interface RTCCertificateExpiration { + expires?: number; +} + +interface RTCCertificateStats extends RTCStats { + base64Certificate?: string; + fingerprint?: string; + fingerprintAlgorithm?: string; + issuerCertificateId?: string; +} + +interface RTCCodecStats extends RTCStats { + channels?: number; + clockRate?: number; + codec?: string; + implementation?: string; + parameters?: string; + payloadType?: number; +} + interface RTCConfiguration { bundlePolicy?: RTCBundlePolicy; + certificates?: RTCCertificate[]; + iceCandidatePoolSize?: number; iceServers?: RTCIceServer[]; iceTransportPolicy?: RTCIceTransportPolicy; peerIdentity?: string; + rtcpMuxPolicy?: RTCRtcpMuxPolicy; } -interface RTCDtlsFingerprint { - algorithm?: string; - value?: string; +interface RTCDataChannelEventInit extends EventInit { + channel: RTCDataChannel; } -interface RTCDtlsParameters { - fingerprints?: RTCDtlsFingerprint[]; - role?: RTCDtlsRole; +interface RTCDataChannelInit { + id?: number; + maxPacketLifeTime?: number; + maxRetransmits?: number; + negotiated?: boolean; + ordered?: boolean; + priority?: RTCPriorityType; + protocol?: string; } -interface RTCDTMFToneChangeEventInit extends EventInit { - tone?: string; +interface RTCDataChannelStats extends RTCStats { + bytesReceived?: number; + bytesSent?: number; + datachannelid?: number; + label?: string; + messagesReceived?: number; + messagesSent?: number; + protocol?: string; + state?: RTCDataChannelState; } -interface RTCIceCandidateAttributes extends RTCStats { - addressSourceUrl?: string; - candidateType?: RTCStatsIceCandidateType; - ipAddress?: string; - portNumber?: number; - priority?: number; - transport?: string; +interface RTCDtlsFingerprint { + algorithm?: string; + value?: string; } -interface RTCIceCandidateComplete { +interface RTCDTMFToneChangeEventInit extends EventInit { + tone: string; } -interface RTCIceCandidateDictionary { - foundation?: string; - ip?: string; - msMTurnSessionId?: string; - port?: number; - priority?: number; - protocol?: RTCIceProtocol; - relatedAddress?: string; - relatedPort?: number; - tcpType?: RTCIceTcpCandidateType; - type?: RTCIceCandidateType; +interface RTCErrorEventInit extends EventInit { + error?: any; } interface RTCIceCandidateInit { candidate?: string; - sdpMid?: string; - sdpMLineIndex?: number; + sdpMid?: string | null; + sdpMLineIndex?: number | null; + ufrag?: string; } interface RTCIceCandidatePair { - local?: RTCIceCandidateDictionary; - remote?: RTCIceCandidateDictionary; + local?: RTCIceCandidate; + remote?: RTCIceCandidate; } interface RTCIceCandidatePairStats extends RTCStats { @@ -852,47 +1013,108 @@ interface RTCIceCandidatePairStats extends RTCStats { availableOutgoingBitrate?: number; bytesReceived?: number; bytesSent?: number; + consentRequestsReceived?: number; + consentRequestsSent?: number; + consentResponsesReceived?: number; + consentResponsesSent?: number; + currentRoundTripTime?: number; localCandidateId?: string; nominated?: boolean; priority?: number; readable?: boolean; remoteCandidateId?: string; - roundTripTime?: number; + requestsReceived?: number; + requestsSent?: number; + responsesReceived?: number; + responsesSent?: number; + retransmissionsReceived?: number; + retransmissionsSent?: number; state?: RTCStatsIceCandidatePairState; + totalRoundTripTime?: number; transportId?: string; writable?: boolean; } -interface RTCIceGatherOptions { - gatherPolicy?: RTCIceGatherPolicy; - iceservers?: RTCIceServer[]; - portRange?: MSPortRange; +interface RTCIceCandidateStats extends RTCStats { + candidateType?: RTCIceCandidateType; + deleted?: boolean; + ip?: string; + isRemote?: boolean; + port?: number; + priority?: number; + protocol?: string; + transportId?: string; + url?: string; } interface RTCIceParameters { - iceLite?: boolean | null; password?: string; usernameFragment?: string; } interface RTCIceServer { - credential?: string | null; - urls?: any; - username?: string | null; + credential?: string | RTCOAuthCredential; + credentialType?: RTCIceCredentialType; + urls: string | string[]; + username?: string; +} + +interface RTCIdentityAssertionResult { + assertion: string; + idp: RTCIdentityProviderDetails; +} + +interface RTCIdentityProvider { + generateAssertion: GenerateAssertionCallback; + validateAssertion: ValidateAssertionCallback; +} + +interface RTCIdentityProviderDetails { + domain: string; + protocol?: string; +} + +interface RTCIdentityProviderOptions { + peerIdentity?: string; + protocol?: string; + usernameHint?: string; +} + +interface RTCIdentityValidationResult { + contents: string; + identity: string; } interface RTCInboundRTPStreamStats extends RTCRTPStreamStats { + burstDiscardCount?: number; + burstDiscardRate?: number; + burstLossCount?: number; + burstLossRate?: number; + burstPacketsDiscarded?: number; + burstPacketsLost?: number; bytesReceived?: number; fractionLost?: number; + framesDecoded?: number; + gapDiscardRate?: number; + gapLossRate?: number; jitter?: number; + packetsDiscarded?: number; packetsLost?: number; packetsReceived?: number; + packetsRepaired?: number; +} + +interface RTCMediaStreamStats extends RTCStats { + streamIdentifier?: string; + trackIds?: string[]; } interface RTCMediaStreamTrackStats extends RTCStats { audioLevel?: number; + detached?: boolean; echoReturnLoss?: number; echoReturnLossEnhancement?: number; + ended?: boolean; frameHeight?: number; framesCorrupted?: number; framesDecoded?: number; @@ -901,111 +1123,102 @@ interface RTCMediaStreamTrackStats extends RTCStats { framesReceived?: number; framesSent?: number; frameWidth?: number; + fullFramesLost?: number; + partialFramesLost?: number; remoteSource?: boolean; ssrcIds?: string[]; trackIdentifier?: string; } -interface RTCOfferOptions { - iceRestart?: boolean; - offerToReceiveAudio?: number; - offerToReceiveVideo?: number; +interface RTCOAuthCredential { + accessToken: string; + macKey: string; +} + +interface RTCOfferAnswerOptions { voiceActivityDetection?: boolean; } +interface RTCOfferOptions extends RTCOfferAnswerOptions { + iceRestart?: boolean; + offerToReceiveAudio?: boolean; + offerToReceiveVideo?: boolean; +} + interface RTCOutboundRTPStreamStats extends RTCRTPStreamStats { bytesSent?: number; + framesEncoded?: number; packetsSent?: number; roundTripTime?: number; targetBitrate?: number; } +interface RTCPeerConnectionIceErrorEventInit extends EventInit { + errorCode: number; + hostCandidate?: string; + statusText?: string; + url?: string; +} + interface RTCPeerConnectionIceEventInit extends EventInit { - candidate?: RTCIceCandidate; + candidate?: RTCIceCandidate | null; + url?: string | null; } -interface RTCRtcpFeedback { - parameter?: string; - type?: string; +interface RTCPeerConnectionStats extends RTCStats { + dataChannelsClosed?: number; + dataChannelsOpened?: number; } interface RTCRtcpParameters { cname?: string; - mux?: boolean; reducedSize?: boolean; - ssrc?: number; } interface RTCRtpCapabilities { codecs?: RTCRtpCodecCapability[]; - fecMechanisms?: string[]; - headerExtensions?: RTCRtpHeaderExtension[]; + headerExtensions?: RTCRtpHeaderExtensionCapability[]; } interface RTCRtpCodecCapability { + channels?: number; clockRate?: number; - kind?: string; - maxptime?: number; - maxSpatialLayers?: number; - maxTemporalLayers?: number; - name?: string; - numChannels?: number; - options?: any; - parameters?: any; - preferredPayloadType?: number; - ptime?: number; - rtcpFeedback?: RTCRtcpFeedback[]; - svcMultiStreamSupport?: boolean; + mimeType?: string; + sdpFmtpLine?: string; } interface RTCRtpCodecParameters { + channels?: number; clockRate?: number; - maxptime?: number; - name?: string; - numChannels?: number; - parameters?: any; - payloadType?: any; - ptime?: number; - rtcpFeedback?: RTCRtcpFeedback[]; -} - -interface RTCRtpContributingSource { - audioLevel?: number; - csrc?: number; - timestamp?: number; + mimeType?: string; + payloadType?: number; + sdpFmtpLine?: string; } interface RTCRtpEncodingParameters { active?: boolean; - codecPayloadType?: number; - dependencyEncodingIds?: string[]; - encodingId?: string; + dtx?: RTCDtxStatus; fec?: RTCRtpFecParameters; - framerateScale?: number; maxBitrate?: number; maxFramerate?: number; - minQuality?: number; - priority?: number; - resolutionScale?: number; + priority?: RTCPriorityType; + ptime?: number; + rid?: string; rtx?: RTCRtpRtxParameters; + scaleResolutionDownBy?: number; ssrc?: number; - ssrcRange?: RTCSsrcRange; } interface RTCRtpFecParameters { - mechanism?: string; ssrc?: number; } -interface RTCRtpHeaderExtension { - kind?: string; - preferredEncrypt?: boolean; - preferredId?: number; +interface RTCRtpHeaderExtensionCapability { uri?: string; } interface RTCRtpHeaderExtensionParameters { - encrypt?: boolean; + encrypted?: boolean; id?: number; uri?: string; } @@ -1015,8 +1228,8 @@ interface RTCRtpParameters { degradationPreference?: RTCDegradationPreference; encodings?: RTCRtpEncodingParameters[]; headerExtensions?: RTCRtpHeaderExtensionParameters[]; - muxId?: string; rtcp?: RTCRtcpParameters; + transactionId?: string; } interface RTCRtpRtxParameters { @@ -1029,52 +1242,43 @@ interface RTCRTPStreamStats extends RTCStats { firCount?: number; isRemote?: boolean; mediaTrackId?: string; + mediaType?: string; nackCount?: number; pliCount?: number; + qpSum?: number; sliCount?: number; ssrc?: string; transportId?: string; } -interface RTCRtpUnhandled { - muxId?: string; - payloadType?: number; - ssrc?: number; +interface RTCRtpTransceiverInit { + direction?: RTCRtpTransceiverDirection; + sendEncodings?: RTCRtpEncodingParameters[]; + streams?: MediaStream[]; } interface RTCSessionDescriptionInit { sdp?: string; - type?: RTCSdpType; -} - -interface RTCSrtpKeyParam { - keyMethod?: string; - keySalt?: string; - lifetime?: string; - mkiLength?: number; - mkiValue?: number; + type: RTCSdpType; } -interface RTCSrtpSdesParameters { - cryptoSuite?: string; - keyParams?: RTCSrtpKeyParam[]; - sessionParams?: string[]; - tag?: number; -} - -interface RTCSsrcRange { - max?: number; - min?: number; +interface RTCStats { + id?: string; + timestamp?: number; + type?: RTCStatsType; } interface RTCStats { id?: string; - msType?: MSStatsType; timestamp?: number; type?: RTCStatsType; } -interface RTCStatsReport { +interface RTCTrackEventInit extends EventInit { + receiver: RTCRtpReceiver; + streams?: MediaStream[]; + track: MediaStreamTrack; + transceiver: RTCRtpTransceiver; } interface RTCTransportStats extends RTCStats { @@ -1087,47 +1291,68 @@ interface RTCTransportStats extends RTCStats { selectedCandidatePairId?: string; } -interface ScopedCredentialDescriptor { - id: any; - transports?: Transport[]; - type: ScopedCredentialType; +interface ScrollIntoViewOptions extends ScrollOptions { + block?: ScrollLogicalPosition; + inline?: ScrollLogicalPosition; } -interface ScopedCredentialOptions { - excludeList?: ScopedCredentialDescriptor[]; - extensions?: WebAuthnExtensions; - rpId?: USVString; - timeoutSeconds?: number; +interface ScrollOptions { + behavior?: ScrollBehavior; } -interface ScopedCredentialParameters { - algorithm: string | Algorithm; - type: ScopedCredentialType; +interface ScrollToOptions extends ScrollOptions { + left?: number; + top?: number; } -interface ServiceWorkerMessageEventInit extends EventInit { - data?: any; - lastEventId?: string; - origin?: string; - ports?: MessagePort[] | null; - source?: ServiceWorker | MessagePort | null; +interface Settings { } -interface SpeechSynthesisEventInit extends EventInit { - charIndex?: number; - elapsedTime?: number; - name?: string; - utterance?: SpeechSynthesisUtterance | null; +interface ShadowRootInit { + mode: ShadowRootMode; +} + +interface StereoPannerOptions extends AudioNodeOptions { + pan?: number; +} + +interface StorageEventInit extends EventInit { + key?: string | null; + newValue?: string | null; + oldValue?: string | null; + storageArea?: Storage | null; + url?: string; } -interface StoreExceptionsInformation extends ExceptionInformation { - detailURI?: string | null; - explanationString?: string | null; - siteName?: string | null; +interface SVGBoundingBoxOptions { + clipped?: boolean; + fill?: boolean; + markers?: boolean; + stroke?: boolean; } -interface StoreSiteSpecificExceptionsInformation extends StoreExceptionsInformation { - arrayOfDomainStrings?: string[]; +interface TouchEventInit extends EventModifierInit { + changedTouches?: Touch[]; + targetTouches?: Touch[]; + touches?: Touch[]; +} + +interface TouchInit { + altitudeAngle?: number; + azimuthAngle?: number; + clientX?: number; + clientY?: number; + force?: number; + identifier: number; + pageX?: number; + pageY?: number; + radiusX?: number; + radiusY?: number; + rotationAngle?: number; + screenX?: number; + screenY?: number; + target: EventTarget; + touchType?: TouchType; } interface TrackEventInit extends EventInit { @@ -1136,7 +1361,8 @@ interface TrackEventInit extends EventInit { interface TransitionEventInit extends EventInit { elapsedTime?: number; - propertyName?: string; + propertyName?: CSSOMString; + pseudoElement?: CSSOMString; } interface UIEventInit extends EventInit { @@ -1144,17 +1370,20 @@ interface UIEventInit extends EventInit { view?: Window | null; } -interface WebAuthnExtensions { +interface WaveShaperOptions extends AudioNodeOptions { + curve?: number[]; + oversample?: OverSampleType; } interface WebGLContextAttributes { - failIfMajorPerformanceCaveat?: boolean; - alpha?: boolean; - antialias?: boolean; - depth?: boolean; - premultipliedAlpha?: boolean; - preserveDrawingBuffer?: boolean; - stencil?: boolean; + alpha?: GLboolean; + antialias?: GLboolean; + depth?: GLboolean; + failIfMajorPerformanceCaveat?: GLboolean; + powerPreference?: WebGLPowerPreference; + premultipliedAlpha?: GLboolean; + preserveDrawingBuffer?: GLboolean; + stencil?: GLboolean; } interface WebGLContextEventInit extends EventInit { @@ -1168,20 +1397,37 @@ interface WheelEventInit extends MouseEventInit { deltaZ?: number; } -interface EventListener { - (evt: Event): void; +interface WorkerOptions { + credentials?: RequestCredentials; + name?: string; + type?: WorkerType; } -interface WebKitEntriesCallback { - (evt: Event): void; +interface WorkletOptions { + credentials?: RequestCredentials; } -interface WebKitErrorCallback { - (evt: Event): void; -} +type EventListener = (event: Event) => void | { handleEvent(event: Event): void; }; + +type NodeFilter = (node: Node) => number | { acceptNode(node: Node): number; }; -interface WebKitFileCallback { - (evt: Event): void; +declare var NodeFilter: { + readonly FILTER_ACCEPT: number; + readonly FILTER_REJECT: number; + readonly FILTER_SKIP: number; + readonly SHOW_ALL: number; + readonly SHOW_ELEMENT: number; + readonly SHOW_ATTRIBUTE: number; + readonly SHOW_TEXT: number; + readonly SHOW_CDATA_SECTION: number; + readonly SHOW_ENTITY_REFERENCE: number; + readonly SHOW_ENTITY: number; + readonly SHOW_PROCESSING_INSTRUCTION: number; + readonly SHOW_COMMENT: number; + readonly SHOW_DOCUMENT: number; + readonly SHOW_DOCUMENT_TYPE: number; + readonly SHOW_DOCUMENT_FRAGMENT: number; + readonly SHOW_NOTATION: number; } interface AnalyserNode extends AudioNode { @@ -1198,31 +1444,18 @@ interface AnalyserNode extends AudioNode { declare var AnalyserNode: { prototype: AnalyserNode; - new(): AnalyserNode; -}; - -interface ANGLE_instanced_arrays { - drawArraysInstancedANGLE(mode: number, first: number, count: number, primcount: number): void; - drawElementsInstancedANGLE(mode: number, count: number, type: number, offset: number, primcount: number): void; - vertexAttribDivisorANGLE(index: number, divisor: number): void; - readonly VERTEX_ATTRIB_ARRAY_DIVISOR_ANGLE: number; -} - -declare var ANGLE_instanced_arrays: { - prototype: ANGLE_instanced_arrays; - new(): ANGLE_instanced_arrays; - readonly VERTEX_ATTRIB_ARRAY_DIVISOR_ANGLE: number; + new(context: BaseAudioContext, options?: AnalyserOptions): AnalyserNode; }; interface AnimationEvent extends Event { - readonly animationName: string; + readonly animationName: CSSOMString; readonly elapsedTime: number; - initAnimationEvent(typeArg: string, canBubbleArg: boolean, cancelableArg: boolean, animationNameArg: string, elapsedTimeArg: number): void; + readonly pseudoElement: CSSOMString; } declare var AnimationEvent: { prototype: AnimationEvent; - new(typeArg: string, eventInitDict?: AnimationEventInit): AnimationEvent; + new(type: CSSOMString, animationEventInitDict?: AnimationEventInit): AnimationEvent; }; interface ApplicationCacheEventMap { @@ -1256,7 +1489,7 @@ interface ApplicationCache extends EventTarget { readonly UNCACHED: number; readonly UPDATEREADY: number; addEventListener(type: K, listener: (this: ApplicationCache, ev: ApplicationCacheEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var ApplicationCache: { @@ -1271,8 +1504,10 @@ declare var ApplicationCache: { }; interface Attr extends Node { + readonly localName: string; readonly name: string; - readonly ownerElement: Element; + readonly namespaceURI: string | null; + readonly ownerElement: Element | null; readonly prefix: string | null; readonly specified: boolean; value: string; @@ -1295,75 +1530,43 @@ interface AudioBuffer { declare var AudioBuffer: { prototype: AudioBuffer; - new(): AudioBuffer; + new(options: AudioBufferOptions): AudioBuffer; }; -interface AudioBufferSourceNodeEventMap { - "ended": MediaStreamErrorEvent; -} - -interface AudioBufferSourceNode extends AudioNode { +interface AudioBufferSourceNode extends AudioScheduledSourceNode { buffer: AudioBuffer | null; readonly detune: AudioParam; loop: boolean; loopEnd: number; loopStart: number; - onended: (this: AudioBufferSourceNode, ev: MediaStreamErrorEvent) => any; readonly playbackRate: AudioParam; start(when?: number, offset?: number, duration?: number): void; - stop(when?: number): void; - addEventListener(type: K, listener: (this: AudioBufferSourceNode, ev: AudioBufferSourceNodeEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: AudioBufferSourceNode, ev: AudioScheduledSourceNodeEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var AudioBufferSourceNode: { prototype: AudioBufferSourceNode; - new(): AudioBufferSourceNode; + new(context: BaseAudioContext, options?: AudioBufferSourceOptions): AudioBufferSourceNode; }; -interface AudioContextEventMap { - "statechange": Event; -} - -interface AudioContextBase extends EventTarget { - readonly currentTime: number; - readonly destination: AudioDestinationNode; - readonly listener: AudioListener; - onstatechange: (this: AudioContext, ev: Event) => any; - readonly sampleRate: number; - readonly state: AudioContextState; +interface AudioContext extends BaseAudioContext { + readonly baseLatency: number; + readonly outputLatency: number; close(): Promise; - createAnalyser(): AnalyserNode; - createBiquadFilter(): BiquadFilterNode; - createBuffer(numberOfChannels: number, length: number, sampleRate: number): AudioBuffer; - createBufferSource(): AudioBufferSourceNode; - createChannelMerger(numberOfInputs?: number): ChannelMergerNode; - createChannelSplitter(numberOfOutputs?: number): ChannelSplitterNode; - createConvolver(): ConvolverNode; - createDelay(maxDelayTime?: number): DelayNode; - createDynamicsCompressor(): DynamicsCompressorNode; - createGain(): GainNode; - createIIRFilter(feedforward: number[], feedback: number[]): IIRFilterNode; createMediaElementSource(mediaElement: HTMLMediaElement): MediaElementAudioSourceNode; + createMediaStreamDestination(): MediaStreamAudioDestinationNode; createMediaStreamSource(mediaStream: MediaStream): MediaStreamAudioSourceNode; - createOscillator(): OscillatorNode; - createPanner(): PannerNode; - createPeriodicWave(real: Float32Array, imag: Float32Array, constraints?: PeriodicWaveConstraints): PeriodicWave; - createScriptProcessor(bufferSize?: number, numberOfInputChannels?: number, numberOfOutputChannels?: number): ScriptProcessorNode; - createStereoPanner(): StereoPannerNode; - createWaveShaper(): WaveShaperNode; - decodeAudioData(audioData: ArrayBuffer, successCallback?: DecodeSuccessCallback, errorCallback?: DecodeErrorCallback): Promise; - resume(): Promise; - addEventListener(type: K, listener: (this: AudioContext, ev: AudioContextEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; -} - -interface AudioContext extends AudioContextBase { + createMediaStreamTrackSource(mediaStreamTrack: any): MediaStreamTrackAudioSourceNode; + getOutputTimestamp(): AudioTimestamp; suspend(): Promise; + addEventListener(type: K, listener: (this: AudioContext, ev: BaseAudioContextEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var AudioContext: { prototype: AudioContext; + new(contextOptions?: AudioContextOptions): AudioContext; new(): AudioContext; }; @@ -1377,11 +1580,17 @@ declare var AudioDestinationNode: { }; interface AudioListener { - dopplerFactor: number; - speedOfSound: number; + readonly forwardX: AudioParam; + readonly forwardY: AudioParam; + readonly forwardZ: AudioParam; + readonly positionX: AudioParam; + readonly positionY: AudioParam; + readonly positionZ: AudioParam; + readonly upX: AudioParam; + readonly upY: AudioParam; + readonly upZ: AudioParam; setOrientation(x: number, y: number, z: number, xUp: number, yUp: number, zUp: number): void; setPosition(x: number, y: number, z: number): void; - setVelocity(x: number, y: number, z: number): void; } declare var AudioListener: { @@ -1393,14 +1602,18 @@ interface AudioNode extends EventTarget { channelCount: number; channelCountMode: ChannelCountMode; channelInterpretation: ChannelInterpretation; - readonly context: AudioContext; + readonly context: BaseAudioContext; readonly numberOfInputs: number; readonly numberOfOutputs: number; connect(destination: AudioNode, output?: number, input?: number): AudioNode; connect(destination: AudioParam, output?: number): void; - disconnect(output?: number): void; - disconnect(destination: AudioNode, output?: number, input?: number): void; - disconnect(destination: AudioParam, output?: number): void; + disconnect(): void; + disconnect(output: number): void; + disconnect(destination: AudioNode): void; + disconnect(destination: AudioNode, output: number): void; + disconnect(destination: AudioNode, output: number, input: number): void; + disconnect(destination: AudioParam): void; + disconnect(destination: AudioParam, output: number): void; } declare var AudioNode: { @@ -1410,8 +1623,11 @@ declare var AudioNode: { interface AudioParam { readonly defaultValue: number; + readonly maxValue: number; + readonly minValue: number; value: number; - cancelScheduledValues(startTime: number): AudioParam; + cancelAndHoldAtTime(cancelTime: number): AudioParam; + cancelScheduledValues(cancelTime: number): AudioParam; exponentialRampToValueAtTime(value: number, endTime: number): AudioParam; linearRampToValueAtTime(value: number, endTime: number): AudioParam; setTargetAtTime(target: number, startTime: number, timeConstant: number): AudioParam; @@ -1424,6 +1640,14 @@ declare var AudioParam: { new(): AudioParam; }; +interface AudioParamMap { +} + +declare var AudioParamMap: { + prototype: AudioParamMap; + new(): AudioParamMap; +}; + interface AudioProcessingEvent extends Event { readonly inputBuffer: AudioBuffer; readonly outputBuffer: AudioBuffer; @@ -1432,16 +1656,33 @@ interface AudioProcessingEvent extends Event { declare var AudioProcessingEvent: { prototype: AudioProcessingEvent; - new(): AudioProcessingEvent; + new(type: string, eventInitDict: AudioProcessingEventInit): AudioProcessingEvent; +}; + +interface AudioScheduledSourceNodeEventMap { + "ended": Event; +} + +interface AudioScheduledSourceNode extends AudioNode { + onended: (this: AudioScheduledSourceNode, ev: Event) => any; + start(when?: number): void; + stop(when?: number): void; + addEventListener(type: K, listener: (this: AudioScheduledSourceNode, ev: AudioScheduledSourceNodeEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; +} + +declare var AudioScheduledSourceNode: { + prototype: AudioScheduledSourceNode; + new(): AudioScheduledSourceNode; }; interface AudioTrack { enabled: boolean; readonly id: string; - kind: string; + readonly kind: string; readonly label: string; - language: string; - readonly sourceBuffer: SourceBuffer; + readonly language: string; + readonly sourceBuffer: SourceBuffer | null; } declare var AudioTrack: { @@ -1461,9 +1702,8 @@ interface AudioTrackList extends EventTarget { onchange: (this: AudioTrackList, ev: Event) => any; onremovetrack: (this: AudioTrackList, ev: TrackEvent) => any; getTrackById(id: string): AudioTrack | null; - item(index: number): AudioTrack; addEventListener(type: K, listener: (this: AudioTrackList, ev: AudioTrackListEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; [index: number]: AudioTrack; } @@ -1472,6 +1712,40 @@ declare var AudioTrackList: { new(): AudioTrackList; }; +interface AudioWorkletNodeEventMap { + "data": Event; +} + +interface AudioWorkletNode extends AudioNode { + ondata: (this: AudioWorkletNode, ev: Event) => any; + readonly parameters: AudioParamMap; + sendData(data: any): void; + addEventListener(type: K, listener: (this: AudioWorkletNode, ev: AudioWorkletNodeEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; +} + +declare var AudioWorkletNode: { + prototype: AudioWorkletNode; + new(context: BaseAudioContext, options?: any): AudioWorkletNode; +}; + +interface AudioWorkletProcessorEventMap { + "data": Event; +} + +interface AudioWorkletProcessor extends EventTarget { + readonly contextInfo: AudioContextInfo; + ondata: (this: AudioWorkletProcessor, ev: Event) => any; + sendData(data: any): void; + addEventListener(type: K, listener: (this: AudioWorkletProcessor, ev: AudioWorkletProcessorEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; +} + +declare var AudioWorkletProcessor: { + prototype: AudioWorkletProcessor; + new(): AudioWorkletProcessor; +}; + interface BarProp { readonly visible: boolean; } @@ -1481,7 +1755,47 @@ declare var BarProp: { new(): BarProp; }; -interface BeforeUnloadEvent extends Event { +interface BaseAudioContextEventMap { + "statechange": Event; +} + +interface BaseAudioContext extends EventTarget { + readonly currentTime: number; + readonly destination: AudioDestinationNode; + readonly listener: AudioListener; + onstatechange: (this: BaseAudioContext, ev: Event) => any; + readonly sampleRate: number; + readonly state: AudioContextState; + createAnalyser(): AnalyserNode; + createBiquadFilter(): BiquadFilterNode; + createBuffer(numberOfChannels: number, length: number, sampleRate: number): AudioBuffer; + createBufferSource(): AudioBufferSourceNode; + createChannelMerger(numberOfInputs?: number): ChannelMergerNode; + createChannelSplitter(numberOfOutputs?: number): ChannelSplitterNode; + createConstantSource(): ConstantSourceNode; + createConvolver(): ConvolverNode; + createDelay(maxDelayTime?: number): DelayNode; + createDynamicsCompressor(): DynamicsCompressorNode; + createGain(): GainNode; + createIIRFilter(feedforward: number[], feedback: number[]): IIRFilterNode; + createOscillator(): OscillatorNode; + createPanner(): PannerNode; + createPeriodicWave(real: Float32Array, imag: Float32Array, constraints?: PeriodicWaveConstraints): PeriodicWave; + createScriptProcessor(bufferSize?: number, numberOfInputChannels?: number, numberOfOutputChannels?: number): ScriptProcessorNode; + createStereoPanner(): StereoPannerNode; + createWaveShaper(): WaveShaperNode; + decodeAudioData(audioData: ArrayBuffer, successCallback?: DecodeSuccessCallback, errorCallback?: DecodeErrorCallback): Promise; + resume(): Promise; + addEventListener(type: K, listener: (this: BaseAudioContext, ev: BaseAudioContextEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; +} + +declare var BaseAudioContext: { + prototype: BaseAudioContext; + new(): BaseAudioContext; +}; + +interface BeforeUnloadEvent extends Event { returnValue: any; } @@ -1501,14 +1815,12 @@ interface BiquadFilterNode extends AudioNode { declare var BiquadFilterNode: { prototype: BiquadFilterNode; - new(): BiquadFilterNode; + new(context: BaseAudioContext, options?: BiquadFilterOptions): BiquadFilterNode; }; interface Blob { readonly size: number; readonly type: string; - msClose(): void; - msDetachStream(): any; slice(start?: number, end?: number, contentType?: string): Blob; } @@ -1517,12 +1829,32 @@ declare var Blob: { new (blobParts?: any[], options?: BlobPropertyBag): Blob; }; +interface BroadcastChannelEventMap { + "message": MessageEvent; + "messageerror": MessageEvent; +} + +interface BroadcastChannel extends EventTarget { + readonly name: string; + onmessage: (this: BroadcastChannel, ev: MessageEvent) => any; + onmessageerror: (this: BroadcastChannel, ev: MessageEvent) => any; + close(): void; + postMessage(message: any): void; + addEventListener(type: K, listener: (this: BroadcastChannel, ev: BroadcastChannelEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; +} + +declare var BroadcastChannel: { + prototype: BroadcastChannel; + new(name: string): BroadcastChannel; +}; + interface Cache { add(request: RequestInfo): Promise; addAll(requests: RequestInfo[]): Promise; delete(request: RequestInfo, options?: CacheQueryOptions): Promise; keys(request?: RequestInfo, options?: CacheQueryOptions): Promise; - match(request: RequestInfo, options?: CacheQueryOptions): Promise; + match(request: RequestInfo, options?: CacheQueryOptions): Promise; matchAll(request?: RequestInfo, options?: CacheQueryOptions): Promise; put(request: RequestInfo, response: Response): Promise; } @@ -1555,7 +1887,7 @@ declare var CanvasGradient: { }; interface CanvasPattern { - setTransform(matrix: SVGMatrix): void; + setTransform(transform?: DOMMatrixInit): void; } declare var CanvasPattern: { @@ -1563,59 +1895,11 @@ declare var CanvasPattern: { new(): CanvasPattern; }; -interface CanvasRenderingContext2D extends Object, CanvasPathMethods { +interface CanvasRenderingContext2D extends CanvasState, CanvasTransform, CanvasCompositing, CanvasImageSmoothing, CanvasFillStrokeStyles, CanvasShadowStyles, CanvasFilters, CanvasRect, CanvasDrawPath, CanvasUserInterface, CanvasText, CanvasDrawImage, CanvasImageData, CanvasPathDrawingStyles, CanvasTextDrawingStyles, CanvasPath { readonly canvas: HTMLCanvasElement; - fillStyle: string | CanvasGradient | CanvasPattern; - font: string; - globalAlpha: number; - globalCompositeOperation: string; - imageSmoothingEnabled: boolean; - lineCap: string; - lineDashOffset: number; - lineJoin: string; - lineWidth: number; - miterLimit: number; - msFillRule: CanvasFillRule; - shadowBlur: number; - shadowColor: string; - shadowOffsetX: number; - shadowOffsetY: number; - strokeStyle: string | CanvasGradient | CanvasPattern; - textAlign: string; - textBaseline: string; mozImageSmoothingEnabled: boolean; webkitImageSmoothingEnabled: boolean; oImageSmoothingEnabled: boolean; - beginPath(): void; - clearRect(x: number, y: number, w: number, h: number): void; - clip(fillRule?: CanvasFillRule): void; - createImageData(imageDataOrSw: number | ImageData, sh?: number): ImageData; - createLinearGradient(x0: number, y0: number, x1: number, y1: number): CanvasGradient; - createPattern(image: HTMLImageElement | HTMLCanvasElement | HTMLVideoElement, repetition: string): CanvasPattern; - createRadialGradient(x0: number, y0: number, r0: number, x1: number, y1: number, r1: number): CanvasGradient; - drawFocusIfNeeded(element: Element): void; - drawImage(image: HTMLImageElement | HTMLCanvasElement | HTMLVideoElement | ImageBitmap, dstX: number, dstY: number): void; - drawImage(image: HTMLImageElement | HTMLCanvasElement | HTMLVideoElement | ImageBitmap, dstX: number, dstY: number, dstW: number, dstH: number): void; - drawImage(image: HTMLImageElement | HTMLCanvasElement | HTMLVideoElement | ImageBitmap, srcX: number, srcY: number, srcW: number, srcH: number, dstX: number, dstY: number, dstW: number, dstH: number): void; - fill(fillRule?: CanvasFillRule): void; - fillRect(x: number, y: number, w: number, h: number): void; - fillText(text: string, x: number, y: number, maxWidth?: number): void; - getImageData(sx: number, sy: number, sw: number, sh: number): ImageData; - getLineDash(): number[]; - isPointInPath(x: number, y: number, fillRule?: CanvasFillRule): boolean; - measureText(text: string): TextMetrics; - putImageData(imagedata: ImageData, dx: number, dy: number, dirtyX?: number, dirtyY?: number, dirtyWidth?: number, dirtyHeight?: number): void; - restore(): void; - rotate(angle: number): void; - save(): void; - scale(x: number, y: number): void; - setLineDash(segments: number[]): void; - setTransform(m11: number, m12: number, m21: number, m22: number, dx: number, dy: number): void; - stroke(path?: Path2D): void; - strokeRect(x: number, y: number, w: number, h: number): void; - strokeText(text: string, x: number, y: number, maxWidth?: number): void; - transform(m11: number, m12: number, m21: number, m22: number, dx: number, dy: number): void; - translate(x: number, y: number): void; } declare var CanvasRenderingContext2D: { @@ -1623,6 +1907,17 @@ declare var CanvasRenderingContext2D: { new(): CanvasRenderingContext2D; }; +interface CaretPosition { + readonly offset: number; + readonly offsetNode: Node; + getClientRect(): DOMRect | null; +} + +declare var CaretPosition: { + prototype: CaretPosition; + new(): CaretPosition; +}; + interface CDATASection extends Text { } @@ -1636,7 +1931,7 @@ interface ChannelMergerNode extends AudioNode { declare var ChannelMergerNode: { prototype: ChannelMergerNode; - new(): ChannelMergerNode; + new(context: BaseAudioContext, options?: ChannelMergerOptions): ChannelMergerNode; }; interface ChannelSplitterNode extends AudioNode { @@ -1644,16 +1939,16 @@ interface ChannelSplitterNode extends AudioNode { declare var ChannelSplitterNode: { prototype: ChannelSplitterNode; - new(): ChannelSplitterNode; + new(context: BaseAudioContext, options?: ChannelSplitterNode): ChannelSplitterNode; }; -interface CharacterData extends Node, ChildNode { +interface CharacterData extends Node, NonDocumentTypeChildNode, ChildNode { data: string; readonly length: number; - appendData(arg: string): void; + appendData(data: string): void; deleteData(offset: number, count: number): void; - insertData(offset: number, arg: string): void; - replaceData(offset: number, count: number, arg: string): void; + insertData(offset: number, data: string): void; + replaceData(offset: number, count: number, data: string): void; substringData(offset: number, count: number): string; } @@ -1662,33 +1957,8 @@ declare var CharacterData: { new(): CharacterData; }; -interface ClientRect { - bottom: number; - readonly height: number; - left: number; - right: number; - top: number; - readonly width: number; -} - -declare var ClientRect: { - prototype: ClientRect; - new(): ClientRect; -}; - -interface ClientRectList { - readonly length: number; - item(index: number): ClientRect; - [index: number]: ClientRect; -} - -declare var ClientRectList: { - prototype: ClientRectList; - new(): ClientRectList; -}; - interface ClipboardEvent extends Event { - readonly clipboardData: DataTransfer; + readonly clipboardData: DataTransfer | null; } declare var ClipboardEvent: { @@ -1700,62 +1970,39 @@ interface CloseEvent extends Event { readonly code: number; readonly reason: string; readonly wasClean: boolean; - initCloseEvent(typeArg: string, canBubbleArg: boolean, cancelableArg: boolean, wasCleanArg: boolean, codeArg: number, reasonArg: string): void; } declare var CloseEvent: { prototype: CloseEvent; - new(typeArg: string, eventInitDict?: CloseEventInit): CloseEvent; + new(type: string, eventInitDict?: CloseEventInit): CloseEvent; }; interface Comment extends CharacterData { - text: string; } declare var Comment: { prototype: Comment; - new(): Comment; + new(data?: string): Comment; }; interface CompositionEvent extends UIEvent { readonly data: string; - readonly locale: string; - initCompositionEvent(typeArg: string, canBubbleArg: boolean, cancelableArg: boolean, viewArg: Window, dataArg: string, locale: string): void; } declare var CompositionEvent: { prototype: CompositionEvent; - new(typeArg: string, eventInitDict?: CompositionEventInit): CompositionEvent; + new(type: string, eventInitDict?: CompositionEventInit): CompositionEvent; }; -interface Console { - assert(test?: boolean, message?: string, ...optionalParams: any[]): void; - clear(): void; - count(countTitle?: string): void; - debug(message?: any, ...optionalParams: any[]): void; - dir(value?: any, ...optionalParams: any[]): void; - dirxml(value: any): void; - error(message?: any, ...optionalParams: any[]): void; - exception(message?: string, ...optionalParams: any[]): void; - group(groupTitle?: string, ...optionalParams: any[]): void; - groupCollapsed(groupTitle?: string, ...optionalParams: any[]): void; - groupEnd(): void; - info(message?: any, ...optionalParams: any[]): void; - log(message?: any, ...optionalParams: any[]): void; - msIsIndependentlyComposed(element: Element): boolean; - profile(reportName?: string): void; - profileEnd(): void; - select(element: Element): void; - table(...data: any[]): void; - time(timerName?: string): void; - timeEnd(timerName?: string): void; - trace(message?: any, ...optionalParams: any[]): void; - warn(message?: any, ...optionalParams: any[]): void; -} - -declare var Console: { - prototype: Console; - new(): Console; +interface ConstantSourceNode extends AudioScheduledSourceNode { + readonly offset: AudioParam; + addEventListener(type: K, listener: (this: ConstantSourceNode, ev: AudioScheduledSourceNodeEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; +} + +declare var ConstantSourceNode: { + prototype: ConstantSourceNode; + new(context: BaseAudioContext, options?: ConstantSourceOptions): ConstantSourceNode; }; interface ConvolverNode extends AudioNode { @@ -1765,26 +2012,12 @@ interface ConvolverNode extends AudioNode { declare var ConvolverNode: { prototype: ConvolverNode; - new(): ConvolverNode; -}; - -interface Coordinates { - readonly accuracy: number; - readonly altitude: number | null; - readonly altitudeAccuracy: number | null; - readonly heading: number | null; - readonly latitude: number; - readonly longitude: number; - readonly speed: number | null; -} - -declare var Coordinates: { - prototype: Coordinates; - new(): Coordinates; + new(context: BaseAudioContext, options?: ConvolverOptions): ConvolverNode; }; -interface Crypto extends Object, RandomSource { +interface Crypto { readonly subtle: SubtleCrypto; + getRandomValues(array: ArrayBufferView): ArrayBufferView; } declare var Crypto: { @@ -1793,10 +2026,10 @@ declare var Crypto: { }; interface CryptoKey { - readonly algorithm: KeyAlgorithm; + readonly algorithm: any; readonly extractable: boolean; - readonly type: string; - readonly usages: string[]; + readonly type: KeyType; + readonly usages: any; } declare var CryptoKey: { @@ -1804,23 +2037,19 @@ declare var CryptoKey: { new(): CryptoKey; }; -interface CryptoKeyPair { - privateKey: CryptoKey; - publicKey: CryptoKey; +interface CSS { } -declare var CryptoKeyPair: { - prototype: CryptoKeyPair; - new(): CryptoKeyPair; +declare var CSS: { + prototype: CSS; + new(): CSS; + escape(ident: CSSOMString): CSSOMString; + supports(property: CSSOMString, value: CSSOMString): boolean; + supports(conditionText: CSSOMString): boolean; }; -interface CSS { - supports(property: string, value?: string): boolean; -} -declare var CSS: CSS; - interface CSSConditionRule extends CSSGroupingRule { - conditionText: string; + conditionText: CSSOMString; } declare var CSSConditionRule: { @@ -1828,19 +2057,21 @@ declare var CSSConditionRule: { new(): CSSConditionRule; }; -interface CSSFontFaceRule extends CSSRule { - readonly style: CSSStyleDeclaration; +interface CSSGroupingRule extends CSSRule { + readonly cssRules: CSSRuleList; + deleteRule(index: number): void; + insertRule(rule: CSSOMString, index: number): number; } -declare var CSSFontFaceRule: { - prototype: CSSFontFaceRule; - new(): CSSFontFaceRule; +declare var CSSGroupingRule: { + prototype: CSSGroupingRule; + new(): CSSGroupingRule; }; interface CSSGroupingRule extends CSSRule { readonly cssRules: CSSRuleList; deleteRule(index: number): void; - insertRule(rule: string, index: number): number; + insertRule(rule: CSSOMString, index?: number): number; } declare var CSSGroupingRule: { @@ -1860,7 +2091,7 @@ declare var CSSImportRule: { }; interface CSSKeyframeRule extends CSSRule { - keyText: string; + keyText: CSSOMString; readonly style: CSSStyleDeclaration; } @@ -1871,10 +2102,10 @@ declare var CSSKeyframeRule: { interface CSSKeyframesRule extends CSSRule { readonly cssRules: CSSRuleList; - name: string; - appendRule(rule: string): void; - deleteRule(rule: string): void; - findRule(rule: string): CSSKeyframeRule; + name: CSSOMString; + appendRule(rule: CSSOMString): void; + deleteRule(select: CSSOMString): void; + findRule(select: CSSOMString): CSSKeyframeRule | null; } declare var CSSKeyframesRule: { @@ -1882,6 +2113,16 @@ declare var CSSKeyframesRule: { new(): CSSKeyframesRule; }; +interface CSSMarginRule extends CSSRule { + readonly name: CSSOMString; + readonly style: CSSStyleDeclaration; +} + +declare var CSSMarginRule: { + prototype: CSSMarginRule; + new(): CSSMarginRule; +}; + interface CSSMediaRule extends CSSConditionRule { readonly media: MediaList; } @@ -1892,8 +2133,8 @@ declare var CSSMediaRule: { }; interface CSSNamespaceRule extends CSSRule { - readonly namespaceURI: string; - readonly prefix: string; + readonly namespaceURI: CSSOMString; + readonly prefix: CSSOMString; } declare var CSSNamespaceRule: { @@ -1901,10 +2142,8 @@ declare var CSSNamespaceRule: { new(): CSSNamespaceRule; }; -interface CSSPageRule extends CSSRule { - readonly pseudoClass: string; - readonly selector: string; - selectorText: string; +interface CSSPageRule extends CSSGroupingRule { + selectorText: CSSOMString; readonly style: CSSStyleDeclaration; } @@ -1914,22 +2153,21 @@ declare var CSSPageRule: { }; interface CSSRule { - cssText: string; - readonly parentRule: CSSRule; - readonly parentStyleSheet: CSSStyleSheet; + cssText: CSSOMString; + readonly parentRule: CSSRule | null; + readonly parentStyleSheet: CSSStyleSheet | null; readonly type: number; readonly CHARSET_RULE: number; readonly FONT_FACE_RULE: number; readonly IMPORT_RULE: number; readonly KEYFRAME_RULE: number; readonly KEYFRAMES_RULE: number; + readonly MARGIN_RULE: number; readonly MEDIA_RULE: number; readonly NAMESPACE_RULE: number; readonly PAGE_RULE: number; readonly STYLE_RULE: number; readonly SUPPORTS_RULE: number; - readonly UNKNOWN_RULE: number; - readonly VIEWPORT_RULE: number; } declare var CSSRule: { @@ -1940,18 +2178,17 @@ declare var CSSRule: { readonly IMPORT_RULE: number; readonly KEYFRAME_RULE: number; readonly KEYFRAMES_RULE: number; + readonly MARGIN_RULE: number; readonly MEDIA_RULE: number; readonly NAMESPACE_RULE: number; readonly PAGE_RULE: number; readonly STYLE_RULE: number; readonly SUPPORTS_RULE: number; - readonly UNKNOWN_RULE: number; - readonly VIEWPORT_RULE: number; }; interface CSSRuleList { readonly length: number; - item(index: number): CSSRule; + item(index: number): CSSRule | null; [index: number]: CSSRule; } @@ -1961,359 +2198,386 @@ declare var CSSRuleList: { }; interface CSSStyleDeclaration { - alignContent: string | null; - alignItems: string | null; - alignmentBaseline: string | null; - alignSelf: string | null; - animation: string | null; - animationDelay: string | null; - animationDirection: string | null; - animationDuration: string | null; - animationFillMode: string | null; - animationIterationCount: string | null; - animationName: string | null; - animationPlayState: string | null; - animationTimingFunction: string | null; - backfaceVisibility: string | null; - background: string | null; - backgroundAttachment: string | null; - backgroundClip: string | null; - backgroundColor: string | null; - backgroundImage: string | null; - backgroundOrigin: string | null; - backgroundPosition: string | null; - backgroundPositionX: string | null; - backgroundPositionY: string | null; - backgroundRepeat: string | null; - backgroundSize: string | null; - baselineShift: string | null; - border: string | null; - borderBottom: string | null; - borderBottomColor: string | null; - borderBottomLeftRadius: string | null; - borderBottomRightRadius: string | null; - borderBottomStyle: string | null; - borderBottomWidth: string | null; - borderCollapse: string | null; - borderColor: string | null; - borderImage: string | null; - borderImageOutset: string | null; - borderImageRepeat: string | null; - borderImageSlice: string | null; - borderImageSource: string | null; - borderImageWidth: string | null; - borderLeft: string | null; - borderLeftColor: string | null; - borderLeftStyle: string | null; - borderLeftWidth: string | null; - borderRadius: string | null; - borderRight: string | null; - borderRightColor: string | null; - borderRightStyle: string | null; - borderRightWidth: string | null; - borderSpacing: string | null; - borderStyle: string | null; - borderTop: string | null; - borderTopColor: string | null; - borderTopLeftRadius: string | null; - borderTopRightRadius: string | null; - borderTopStyle: string | null; - borderTopWidth: string | null; - borderWidth: string | null; - bottom: string | null; - boxShadow: string | null; - boxSizing: string | null; - breakAfter: string | null; - breakBefore: string | null; - breakInside: string | null; - captionSide: string | null; - clear: string | null; - clip: string | null; - clipPath: string | null; - clipRule: string | null; - color: string | null; - colorInterpolationFilters: string | null; - columnCount: any; - columnFill: string | null; - columnGap: any; - columnRule: string | null; - columnRuleColor: any; - columnRuleStyle: string | null; - columnRuleWidth: any; - columns: string | null; - columnSpan: string | null; - columnWidth: any; - content: string | null; - counterIncrement: string | null; - counterReset: string | null; - cssFloat: string | null; - cssText: string; - cursor: string | null; - direction: string | null; - display: string | null; - dominantBaseline: string | null; - emptyCells: string | null; - enableBackground: string | null; - fill: string | null; - fillOpacity: string | null; - fillRule: string | null; - filter: string | null; - flex: string | null; - flexBasis: string | null; - flexDirection: string | null; - flexFlow: string | null; - flexGrow: string | null; - flexShrink: string | null; - flexWrap: string | null; - floodColor: string | null; - floodOpacity: string | null; - font: string | null; - fontFamily: string | null; - fontFeatureSettings: string | null; - fontSize: string | null; - fontSizeAdjust: string | null; - fontStretch: string | null; - fontStyle: string | null; - fontVariant: string | null; - fontWeight: string | null; - glyphOrientationHorizontal: string | null; - glyphOrientationVertical: string | null; - height: string | null; - imeMode: string | null; - justifyContent: string | null; - kerning: string | null; - layoutGrid: string | null; - layoutGridChar: string | null; - layoutGridLine: string | null; - layoutGridMode: string | null; - layoutGridType: string | null; - left: string | null; + alignContent: CSSOMString; + alignItems: CSSOMString; + alignmentBaseline: CSSOMString; + alignSelf: CSSOMString; + animation: CSSOMString; + animationDelay: CSSOMString; + animationDirection: CSSOMString; + animationDuration: CSSOMString; + animationFillMode: CSSOMString; + animationIterationCount: CSSOMString; + animationName: CSSOMString; + animationPlayState: CSSOMString; + animationTimingFunction: CSSOMString; + backfaceVisibility: CSSOMString; + background: CSSOMString; + backgroundAttachment: CSSOMString; + backgroundClip: CSSOMString; + backgroundColor: CSSOMString; + backgroundImage: CSSOMString; + backgroundOrigin: CSSOMString; + backgroundPosition: CSSOMString; + backgroundPositionX: CSSOMString; + backgroundPositionY: CSSOMString; + backgroundRepeat: CSSOMString; + backgroundSize: CSSOMString; + baselineShift: CSSOMString; + border: CSSOMString; + borderBottom: CSSOMString; + borderBottomColor: CSSOMString; + borderBottomLeftRadius: CSSOMString; + borderBottomRightRadius: CSSOMString; + borderBottomStyle: CSSOMString; + borderBottomWidth: CSSOMString; + borderCollapse: CSSOMString; + borderColor: CSSOMString; + borderImage: CSSOMString; + borderImageOutset: CSSOMString; + borderImageRepeat: CSSOMString; + borderImageSlice: CSSOMString; + borderImageSource: CSSOMString; + borderImageWidth: CSSOMString; + borderLeft: CSSOMString; + borderLeftColor: CSSOMString; + borderLeftStyle: CSSOMString; + borderLeftWidth: CSSOMString; + borderRadius: CSSOMString; + borderRight: CSSOMString; + borderRightColor: CSSOMString; + borderRightStyle: CSSOMString; + borderRightWidth: CSSOMString; + borderSpacing: CSSOMString; + borderStyle: CSSOMString; + borderTop: CSSOMString; + borderTopColor: CSSOMString; + borderTopLeftRadius: CSSOMString; + borderTopRightRadius: CSSOMString; + borderTopStyle: CSSOMString; + borderTopWidth: CSSOMString; + borderWidth: CSSOMString; + bottom: CSSOMString; + boxShadow: CSSOMString; + boxSizing: CSSOMString; + breakAfter: CSSOMString; + breakBefore: CSSOMString; + breakInside: CSSOMString; + captionSide: CSSOMString; + clear: CSSOMString; + clip: CSSOMString; + clipPath: CSSOMString; + clipRule: CSSOMString; + color: CSSOMString; + colorInterpolationFilters: CSSOMString; + columnCount: CSSOMString; + columnFill: CSSOMString; + columnGap: CSSOMString; + columnRule: CSSOMString; + columnRuleColor: CSSOMString; + columnRuleStyle: CSSOMString; + columnRuleWidth: CSSOMString; + columns: CSSOMString; + columnSpan: CSSOMString; + columnWidth: CSSOMString; + content: CSSOMString; + counterIncrement: CSSOMString; + counterReset: CSSOMString; + cssFloat: CSSOMString; + cssText: CSSOMString; + cursor: CSSOMString; + direction: CSSOMString; + display: CSSOMString; + dominantBaseline: CSSOMString; + emptyCells: CSSOMString; + enableBackground: CSSOMString; + fill: CSSOMString; + fillOpacity: CSSOMString; + fillRule: CSSOMString; + filter: CSSOMString; + flex: CSSOMString; + flexBasis: CSSOMString; + flexDirection: CSSOMString; + flexFlow: CSSOMString; + flexGrow: CSSOMString; + flexShrink: CSSOMString; + flexWrap: CSSOMString; + floodColor: CSSOMString; + floodOpacity: CSSOMString; + font: CSSOMString; + fontFamily: CSSOMString; + fontFeatureSettings: CSSOMString; + fontSize: CSSOMString; + fontSizeAdjust: CSSOMString; + fontStretch: CSSOMString; + fontStyle: CSSOMString; + fontVariant: CSSOMString; + fontWeight: CSSOMString; + glyphOrientationHorizontal: CSSOMString; + glyphOrientationVertical: CSSOMString; + height: CSSOMString; + imeMode: CSSOMString; + justifyContent: CSSOMString; + kerning: CSSOMString; + layoutGrid: CSSOMString; + layoutGridChar: CSSOMString; + layoutGridLine: CSSOMString; + layoutGridMode: CSSOMString; + layoutGridType: CSSOMString; + left: CSSOMString; readonly length: number; - letterSpacing: string | null; - lightingColor: string | null; - lineBreak: string | null; - lineHeight: string | null; - listStyle: string | null; - listStyleImage: string | null; - listStylePosition: string | null; - listStyleType: string | null; - margin: string | null; - marginBottom: string | null; - marginLeft: string | null; - marginRight: string | null; - marginTop: string | null; - marker: string | null; - markerEnd: string | null; - markerMid: string | null; - markerStart: string | null; - mask: string | null; - maxHeight: string | null; - maxWidth: string | null; - minHeight: string | null; - minWidth: string | null; - msContentZoomChaining: string | null; - msContentZooming: string | null; - msContentZoomLimit: string | null; - msContentZoomLimitMax: any; - msContentZoomLimitMin: any; - msContentZoomSnap: string | null; - msContentZoomSnapPoints: string | null; - msContentZoomSnapType: string | null; - msFlowFrom: string | null; - msFlowInto: string | null; - msFontFeatureSettings: string | null; - msGridColumn: any; - msGridColumnAlign: string | null; - msGridColumns: string | null; - msGridColumnSpan: any; - msGridRow: any; - msGridRowAlign: string | null; - msGridRows: string | null; - msGridRowSpan: any; - msHighContrastAdjust: string | null; - msHyphenateLimitChars: string | null; - msHyphenateLimitLines: any; - msHyphenateLimitZone: any; - msHyphens: string | null; - msImeAlign: string | null; - msOverflowStyle: string | null; - msScrollChaining: string | null; - msScrollLimit: string | null; - msScrollLimitXMax: any; - msScrollLimitXMin: any; - msScrollLimitYMax: any; - msScrollLimitYMin: any; - msScrollRails: string | null; - msScrollSnapPointsX: string | null; - msScrollSnapPointsY: string | null; - msScrollSnapType: string | null; - msScrollSnapX: string | null; - msScrollSnapY: string | null; - msScrollTranslation: string | null; - msTextCombineHorizontal: string | null; - msTextSizeAdjust: any; - msTouchAction: string | null; - msTouchSelect: string | null; - msUserSelect: string | null; - msWrapFlow: string; - msWrapMargin: any; - msWrapThrough: string; - opacity: string | null; - order: string | null; - orphans: string | null; - outline: string | null; - outlineColor: string | null; - outlineOffset: string | null; - outlineStyle: string | null; - outlineWidth: string | null; - overflow: string | null; - overflowX: string | null; - overflowY: string | null; - padding: string | null; - paddingBottom: string | null; - paddingLeft: string | null; - paddingRight: string | null; - paddingTop: string | null; - pageBreakAfter: string | null; - pageBreakBefore: string | null; - pageBreakInside: string | null; - readonly parentRule: CSSRule; - perspective: string | null; - perspectiveOrigin: string | null; - pointerEvents: string | null; - position: string | null; - quotes: string | null; - right: string | null; - rotate: string | null; - rubyAlign: string | null; - rubyOverhang: string | null; - rubyPosition: string | null; - scale: string | null; - stopColor: string | null; - stopOpacity: string | null; - stroke: string | null; - strokeDasharray: string | null; - strokeDashoffset: string | null; - strokeLinecap: string | null; - strokeLinejoin: string | null; - strokeMiterlimit: string | null; - strokeOpacity: string | null; - strokeWidth: string | null; - tableLayout: string | null; - textAlign: string | null; - textAlignLast: string | null; - textAnchor: string | null; - textDecoration: string | null; - textIndent: string | null; - textJustify: string | null; - textKashida: string | null; - textKashidaSpace: string | null; - textOverflow: string | null; - textShadow: string | null; - textTransform: string | null; - textUnderlinePosition: string | null; - top: string | null; - touchAction: string | null; - transform: string | null; - transformOrigin: string | null; - transformStyle: string | null; - transition: string | null; - transitionDelay: string | null; - transitionDuration: string | null; - transitionProperty: string | null; - transitionTimingFunction: string | null; - translate: string | null; - unicodeBidi: string | null; - verticalAlign: string | null; - visibility: string | null; - webkitAlignContent: string | null; - webkitAlignItems: string | null; - webkitAlignSelf: string | null; - webkitAnimation: string | null; - webkitAnimationDelay: string | null; - webkitAnimationDirection: string | null; - webkitAnimationDuration: string | null; - webkitAnimationFillMode: string | null; - webkitAnimationIterationCount: string | null; - webkitAnimationName: string | null; - webkitAnimationPlayState: string | null; - webkitAnimationTimingFunction: string | null; - webkitAppearance: string | null; - webkitBackfaceVisibility: string | null; - webkitBackgroundClip: string | null; - webkitBackgroundOrigin: string | null; - webkitBackgroundSize: string | null; - webkitBorderBottomLeftRadius: string | null; - webkitBorderBottomRightRadius: string | null; - webkitBorderImage: string | null; - webkitBorderRadius: string | null; - webkitBorderTopLeftRadius: string | null; - webkitBorderTopRightRadius: string | null; - webkitBoxAlign: string | null; - webkitBoxDirection: string | null; - webkitBoxFlex: string | null; - webkitBoxOrdinalGroup: string | null; - webkitBoxOrient: string | null; - webkitBoxPack: string | null; - webkitBoxSizing: string | null; - webkitColumnBreakAfter: string | null; - webkitColumnBreakBefore: string | null; - webkitColumnBreakInside: string | null; - webkitColumnCount: any; - webkitColumnGap: any; - webkitColumnRule: string | null; - webkitColumnRuleColor: any; - webkitColumnRuleStyle: string | null; - webkitColumnRuleWidth: any; - webkitColumns: string | null; - webkitColumnSpan: string | null; - webkitColumnWidth: any; - webkitFilter: string | null; - webkitFlex: string | null; - webkitFlexBasis: string | null; - webkitFlexDirection: string | null; - webkitFlexFlow: string | null; - webkitFlexGrow: string | null; - webkitFlexShrink: string | null; - webkitFlexWrap: string | null; - webkitJustifyContent: string | null; - webkitOrder: string | null; - webkitPerspective: string | null; - webkitPerspectiveOrigin: string | null; - webkitTapHighlightColor: string | null; - webkitTextFillColor: string | null; - webkitTextSizeAdjust: any; - webkitTextStroke: string | null; - webkitTextStrokeColor: string | null; - webkitTextStrokeWidth: string | null; - webkitTransform: string | null; - webkitTransformOrigin: string | null; - webkitTransformStyle: string | null; - webkitTransition: string | null; - webkitTransitionDelay: string | null; - webkitTransitionDuration: string | null; - webkitTransitionProperty: string | null; - webkitTransitionTimingFunction: string | null; - webkitUserModify: string | null; - webkitUserSelect: string | null; - webkitWritingMode: string | null; - whiteSpace: string | null; - widows: string | null; - width: string | null; - wordBreak: string | null; - wordSpacing: string | null; - wordWrap: string | null; - writingMode: string | null; - zIndex: string | null; - zoom: string | null; - resize: string | null; - userSelect: string | null; - getPropertyPriority(propertyName: string): string; - getPropertyValue(propertyName: string): string; - item(index: number): string; - removeProperty(propertyName: string): string; - setProperty(propertyName: string, value: string | null, priority?: string): void; - [index: number]: string; + letterSpacing: CSSOMString; + lightingColor: CSSOMString; + lineBreak: CSSOMString; + lineHeight: CSSOMString; + listStyle: CSSOMString; + listStyleImage: CSSOMString; + listStylePosition: CSSOMString; + listStyleType: CSSOMString; + margin: CSSOMString; + marginBottom: CSSOMString; + marginLeft: CSSOMString; + marginRight: CSSOMString; + marginTop: CSSOMString; + marker: CSSOMString; + markerEnd: CSSOMString; + markerMid: CSSOMString; + markerStart: CSSOMString; + mask: CSSOMString; + maxHeight: CSSOMString; + maxWidth: CSSOMString; + minHeight: CSSOMString; + minWidth: CSSOMString; + msContentZoomChaining: CSSOMString; + msContentZooming: CSSOMString; + msContentZoomLimit: CSSOMString; + msContentZoomLimitMax: CSSOMString; + msContentZoomLimitMin: CSSOMString; + msContentZoomSnap: CSSOMString; + msContentZoomSnapPoints: CSSOMString; + msContentZoomSnapType: CSSOMString; + msFlowFrom: CSSOMString; + msFlowInto: CSSOMString; + msFontFeatureSettings: CSSOMString; + msGridColumn: CSSOMString; + msGridColumnAlign: CSSOMString; + msGridColumns: CSSOMString; + msGridColumnSpan: CSSOMString; + msGridRow: CSSOMString; + msGridRowAlign: CSSOMString; + msGridRows: CSSOMString; + msGridRowSpan: CSSOMString; + msHighContrastAdjust: CSSOMString; + msHyphenateLimitChars: CSSOMString; + msHyphenateLimitLines: CSSOMString; + msHyphenateLimitZone: CSSOMString; + msHyphens: CSSOMString; + msImeAlign: CSSOMString; + msOverflowStyle: CSSOMString; + msScrollChaining: CSSOMString; + msScrollLimit: CSSOMString; + msScrollLimitXMax: CSSOMString; + msScrollLimitXMin: CSSOMString; + msScrollLimitYMax: CSSOMString; + msScrollLimitYMin: CSSOMString; + msScrollRails: CSSOMString; + msScrollSnapPointsX: CSSOMString; + msScrollSnapPointsY: CSSOMString; + msScrollSnapType: CSSOMString; + msScrollSnapX: CSSOMString; + msScrollSnapY: CSSOMString; + msScrollTranslation: CSSOMString; + msTextCombineHorizontal: CSSOMString; + msTextSizeAdjust: CSSOMString; + msTouchAction: CSSOMString; + msTouchSelect: CSSOMString; + msUserSelect: CSSOMString; + msWrapFlow: CSSOMString; + msWrapMargin: CSSOMString; + msWrapThrough: CSSOMString; + opacity: CSSOMString; + order: CSSOMString; + orphans: CSSOMString; + outline: CSSOMString; + outlineColor: CSSOMString; + outlineOffset: CSSOMString; + outlineStyle: CSSOMString; + outlineWidth: CSSOMString; + overflow: CSSOMString; + overflowX: CSSOMString; + overflowY: CSSOMString; + padding: CSSOMString; + paddingBottom: CSSOMString; + paddingLeft: CSSOMString; + paddingRight: CSSOMString; + paddingTop: CSSOMString; + pageBreakAfter: CSSOMString; + pageBreakBefore: CSSOMString; + pageBreakInside: CSSOMString; + readonly parentRule: CSSRule | null; + perspective: CSSOMString; + perspectiveOrigin: CSSOMString; + pointerEvents: CSSOMString; + position: CSSOMString; + quotes: CSSOMString; + resize: CSSOMString; + right: CSSOMString; + rotate: CSSOMString; + rubyAlign: CSSOMString; + rubyOverhang: CSSOMString; + rubyPosition: CSSOMString; + scale: CSSOMString; + scrollPadding: CSSOMString; + scrollPaddingBlock: CSSOMString; + scrollPaddingBlockEnd: CSSOMString; + scrollPaddingBlockStart: CSSOMString; + scrollPaddingBottom: CSSOMString; + scrollPaddingInline: CSSOMString; + scrollPaddingInlineEnd: CSSOMString; + scrollPaddingInlineStart: CSSOMString; + scrollPaddingLeft: CSSOMString; + scrollPaddingRight: CSSOMString; + scrollPaddingTop: CSSOMString; + scrollSnapAlign: CSSOMString; + scrollSnapMargin: CSSOMString; + scrollSnapMarginBlock: CSSOMString; + scrollSnapMarginBlockEnd: CSSOMString; + scrollSnapMarginBlockStart: CSSOMString; + scrollSnapMarginBottom: CSSOMString; + scrollSnapMarginInline: CSSOMString; + scrollSnapMarginInlineEnd: CSSOMString; + scrollSnapMarginInlineStart: CSSOMString; + scrollSnapMarginLeft: CSSOMString; + scrollSnapMarginRight: CSSOMString; + scrollSnapMarginTop: CSSOMString; + scrollSnapStop: CSSOMString; + scrollSnapType: CSSOMString; + stopColor: CSSOMString; + stopOpacity: CSSOMString; + stroke: CSSOMString; + strokeDasharray: CSSOMString; + strokeDashoffset: CSSOMString; + strokeLinecap: CSSOMString; + strokeLinejoin: CSSOMString; + strokeMiterlimit: CSSOMString; + strokeOpacity: CSSOMString; + strokeWidth: CSSOMString; + tableLayout: CSSOMString; + textAlign: CSSOMString; + textAlignLast: CSSOMString; + textAnchor: CSSOMString; + textDecoration: CSSOMString; + textIndent: CSSOMString; + textJustify: CSSOMString; + textKashida: CSSOMString; + textKashidaSpace: CSSOMString; + textOverflow: CSSOMString; + textShadow: CSSOMString; + textTransform: CSSOMString; + textUnderlinePosition: CSSOMString; + top: CSSOMString; + touchAction: CSSOMString; + transform: CSSOMString; + transformOrigin: CSSOMString; + transformStyle: CSSOMString; + transition: CSSOMString; + transitionDelay: CSSOMString; + transitionDuration: CSSOMString; + transitionProperty: CSSOMString; + transitionTimingFunction: CSSOMString; + translate: CSSOMString; + unicodeBidi: CSSOMString; + userSelect: CSSOMString; + verticalAlign: CSSOMString; + visibility: CSSOMString; + webkitAlignContent: CSSOMString; + webkitAlignItems: CSSOMString; + webkitAlignSelf: CSSOMString; + webkitAnimation: CSSOMString; + webkitAnimationDelay: CSSOMString; + webkitAnimationDirection: CSSOMString; + webkitAnimationDuration: CSSOMString; + webkitAnimationFillMode: CSSOMString; + webkitAnimationIterationCount: CSSOMString; + webkitAnimationName: CSSOMString; + webkitAnimationPlayState: CSSOMString; + webkitAnimationTimingFunction: CSSOMString; + webkitAppearance: CSSOMString; + webkitBackfaceVisibility: CSSOMString; + webkitBackgroundClip: CSSOMString; + webkitBackgroundOrigin: CSSOMString; + webkitBackgroundSize: CSSOMString; + webkitBorderBottomLeftRadius: CSSOMString; + webkitBorderBottomRightRadius: CSSOMString; + webkitBorderImage: CSSOMString; + webkitBorderRadius: CSSOMString; + webkitBorderTopLeftRadius: CSSOMString; + webkitBorderTopRightRadius: CSSOMString; + webkitBoxAlign: CSSOMString; + webkitBoxDirection: CSSOMString; + webkitBoxFlex: CSSOMString; + webkitBoxOrdinalGroup: CSSOMString; + webkitBoxOrient: CSSOMString; + webkitBoxPack: CSSOMString; + webkitBoxSizing: CSSOMString; + webkitColumnBreakAfter: CSSOMString; + webkitColumnBreakBefore: CSSOMString; + webkitColumnBreakInside: CSSOMString; + webkitColumnCount: CSSOMString; + webkitColumnGap: CSSOMString; + webkitColumnRule: CSSOMString; + webkitColumnRuleColor: CSSOMString; + webkitColumnRuleStyle: CSSOMString; + webkitColumnRuleWidth: CSSOMString; + webkitColumns: CSSOMString; + webkitColumnSpan: CSSOMString; + webkitColumnWidth: CSSOMString; + webkitFilter: CSSOMString; + webkitFlex: CSSOMString; + webkitFlexBasis: CSSOMString; + webkitFlexDirection: CSSOMString; + webkitFlexFlow: CSSOMString; + webkitFlexGrow: CSSOMString; + webkitFlexShrink: CSSOMString; + webkitFlexWrap: CSSOMString; + webkitJustifyContent: CSSOMString; + webkitOrder: CSSOMString; + webkitPerspective: CSSOMString; + webkitPerspectiveOrigin: CSSOMString; + webkitTapHighlightColor: CSSOMString; + webkitTextFillColor: CSSOMString; + webkitTextSizeAdjust: CSSOMString; + webkitTextStroke: CSSOMString; + webkitTextStrokeColor: CSSOMString; + webkitTextStrokeWidth: CSSOMString; + webkitTransform: CSSOMString; + webkitTransformOrigin: CSSOMString; + webkitTransformStyle: CSSOMString; + webkitTransition: CSSOMString; + webkitTransitionDelay: CSSOMString; + webkitTransitionDuration: CSSOMString; + webkitTransitionProperty: CSSOMString; + webkitTransitionTimingFunction: CSSOMString; + webkitUserModify: CSSOMString; + webkitUserSelect: CSSOMString; + webkitWritingMode: CSSOMString; + whiteSpace: CSSOMString; + widows: CSSOMString; + width: CSSOMString; + wordBreak: CSSOMString; + wordSpacing: CSSOMString; + wordWrap: CSSOMString; + writingMode: CSSOMString; + zIndex: CSSOMString; + zoom: CSSOMString; + getPropertyPriority(property: CSSOMString): CSSOMString; + getPropertyValue(property: CSSOMString): CSSOMString; + item(index: number): CSSOMString; + removeProperty(property: CSSOMString): CSSOMString; + setProperty(property: CSSOMString, value: CSSOMString, priority?: CSSOMString): void; + setPropertyPriority(property: CSSOMString, priority: CSSOMString): void; + setPropertyValue(property: CSSOMString, value: CSSOMString): void; + [index: number]: CSSOMString; } declare var CSSStyleDeclaration: { @@ -2322,8 +2586,7 @@ declare var CSSStyleDeclaration: { }; interface CSSStyleRule extends CSSRule { - readonly readOnly: boolean; - selectorText: string; + selectorText: CSSOMString; readonly style: CSSStyleDeclaration; } @@ -2334,23 +2597,9 @@ declare var CSSStyleRule: { interface CSSStyleSheet extends StyleSheet { readonly cssRules: CSSRuleList; - cssText: string; - readonly id: string; - readonly imports: StyleSheetList; - readonly isAlternate: boolean; - readonly isPrefAlternate: boolean; - readonly ownerRule: CSSRule; - readonly owningElement: Element; - readonly pages: StyleSheetPageList; - readonly readOnly: boolean; - readonly rules: CSSRuleList; - addImport(bstrURL: string, lIndex?: number): number; - addPageRule(bstrSelector: string, bstrStyle: string, lIndex?: number): number; - addRule(bstrSelector: string, bstrStyle?: string, lIndex?: number): number; - deleteRule(index?: number): void; - insertRule(rule: string, index?: number): number; - removeImport(lIndex: number): void; - removeRule(lIndex: number): void; + readonly ownerRule: CSSRule | null; + deleteRule(index: number): void; + insertRule(rule: CSSOMString, index?: number): number; } declare var CSSStyleSheet: { @@ -2366,25 +2615,25 @@ declare var CSSSupportsRule: { new(): CSSSupportsRule; }; -interface CustomEvent extends Event { - readonly detail: any; - initCustomEvent(typeArg: string, canBubbleArg: boolean, cancelableArg: boolean, detailArg: any): void; +interface CustomElementRegistry { + define(name: string, constructor: Function, options?: ElementDefinitionOptions): void; + get(name: string): any; + whenDefined(name: string): Promise; } -declare var CustomEvent: { - prototype: CustomEvent; - new(typeArg: string, eventInitDict?: CustomEventInit): CustomEvent; +declare var CustomElementRegistry: { + prototype: CustomElementRegistry; + new(): CustomElementRegistry; }; -interface DataCue extends TextTrackCue { - data: ArrayBuffer; - addEventListener(type: K, listener: (this: DataCue, ev: TextTrackCueEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; +interface CustomEvent extends Event { + readonly detail: any; + initCustomEvent(type: string, bubbles?: boolean, cancelable?: boolean, detail?: any): void; } -declare var DataCue: { - prototype: DataCue; - new(): DataCue; +declare var CustomEvent: { + prototype: CustomEvent; + new(type: string, eventInitDict?: CustomEventInit): CustomEvent; }; interface DataTransfer { @@ -2393,9 +2642,9 @@ interface DataTransfer { readonly files: FileList; readonly items: DataTransferItemList; readonly types: string[]; - clearData(format?: string): boolean; + clearData(format?: string): void; getData(format: string): string; - setData(format: string, data: string): boolean; + setData(format: string, data: string): void; setDragImage(image: Element, x: number, y: number): void; } @@ -2408,8 +2657,7 @@ interface DataTransferItem { readonly kind: string; readonly type: string; getAsFile(): File | null; - getAsString(_callback: FunctionStringCallback | null): void; - webkitGetAsEntry(): any; + getAsString(callback: FunctionStringCallback | null): void; } declare var DataTransferItem: { @@ -2419,9 +2667,9 @@ declare var DataTransferItem: { interface DataTransferItemList { readonly length: number; + add(data: string, type: string): DataTransferItem | null; add(data: File): DataTransferItem | null; clear(): void; - item(index: number): DataTransferItem; remove(index: number): void; [index: number]: DataTransferItem; } @@ -2431,46 +2679,13 @@ declare var DataTransferItemList: { new(): DataTransferItemList; }; -interface DeferredPermissionRequest { - readonly id: number; - readonly type: MSWebViewPermissionType; - readonly uri: string; - allow(): void; - deny(): void; -} - -declare var DeferredPermissionRequest: { - prototype: DeferredPermissionRequest; - new(): DeferredPermissionRequest; -}; - interface DelayNode extends AudioNode { readonly delayTime: AudioParam; } declare var DelayNode: { prototype: DelayNode; - new(): DelayNode; -}; - -interface DeviceAcceleration { - readonly x: number | null; - readonly y: number | null; - readonly z: number | null; -} - -declare var DeviceAcceleration: { - prototype: DeviceAcceleration; - new(): DeviceAcceleration; -}; - -interface DeviceLightEvent extends Event { - readonly value: number; -} - -declare var DeviceLightEvent: { - prototype: DeviceLightEvent; - new(typeArg: string, eventInitDict?: DeviceLightEventInit): DeviceLightEvent; + new(context: BaseAudioContext, options?: DelayOptions): DelayNode; }; interface DeviceMotionEvent extends Event { @@ -2478,12 +2693,11 @@ interface DeviceMotionEvent extends Event { readonly accelerationIncludingGravity: DeviceAcceleration | null; readonly interval: number | null; readonly rotationRate: DeviceRotationRate | null; - initDeviceMotionEvent(type: string, bubbles: boolean, cancelable: boolean, acceleration: DeviceAccelerationDict | null, accelerationIncludingGravity: DeviceAccelerationDict | null, rotationRate: DeviceRotationRateDict | null, interval: number | null): void; } declare var DeviceMotionEvent: { prototype: DeviceMotionEvent; - new(typeArg: string, eventInitDict?: DeviceMotionEventInit): DeviceMotionEvent; + new(type: string, eventInitDict?: DeviceMotionEventInit): DeviceMotionEvent; }; interface DeviceOrientationEvent extends Event { @@ -2491,121 +2705,24 @@ interface DeviceOrientationEvent extends Event { readonly alpha: number | null; readonly beta: number | null; readonly gamma: number | null; - initDeviceOrientationEvent(type: string, bubbles: boolean, cancelable: boolean, alpha: number | null, beta: number | null, gamma: number | null, absolute: boolean): void; } declare var DeviceOrientationEvent: { prototype: DeviceOrientationEvent; - new(typeArg: string, eventInitDict?: DeviceOrientationEventInit): DeviceOrientationEvent; -}; - -interface DeviceRotationRate { - readonly alpha: number | null; - readonly beta: number | null; - readonly gamma: number | null; -} - -declare var DeviceRotationRate: { - prototype: DeviceRotationRate; - new(): DeviceRotationRate; + new(type: string, eventInitDict?: DeviceOrientationEventInit): DeviceOrientationEvent; }; -interface DocumentEventMap extends GlobalEventHandlersEventMap { - "abort": UIEvent; - "activate": UIEvent; - "beforeactivate": UIEvent; - "beforedeactivate": UIEvent; - "blur": FocusEvent; - "canplay": Event; - "canplaythrough": Event; - "change": Event; - "click": MouseEvent; - "contextmenu": PointerEvent; - "dblclick": MouseEvent; - "deactivate": UIEvent; - "drag": DragEvent; - "dragend": DragEvent; - "dragenter": DragEvent; - "dragleave": DragEvent; - "dragover": DragEvent; - "dragstart": DragEvent; - "drop": DragEvent; - "durationchange": Event; - "emptied": Event; - "ended": MediaStreamErrorEvent; - "error": ErrorEvent; - "focus": FocusEvent; +interface DocumentEventMap extends GlobalEventHandlersEventMap, DocumentAndElementEventHandlersEventMap { "fullscreenchange": Event; "fullscreenerror": Event; - "input": Event; - "invalid": Event; - "keydown": KeyboardEvent; - "keypress": KeyboardEvent; - "keyup": KeyboardEvent; - "load": Event; - "loadeddata": Event; - "loadedmetadata": Event; - "loadstart": Event; - "mousedown": MouseEvent; - "mousemove": MouseEvent; - "mouseout": MouseEvent; - "mouseover": MouseEvent; - "mouseup": MouseEvent; - "mousewheel": WheelEvent; - "MSContentZoom": UIEvent; - "MSGestureChange": MSGestureEvent; - "MSGestureDoubleTap": MSGestureEvent; - "MSGestureEnd": MSGestureEvent; - "MSGestureHold": MSGestureEvent; - "MSGestureStart": MSGestureEvent; - "MSGestureTap": MSGestureEvent; - "MSInertiaStart": MSGestureEvent; - "MSManipulationStateChanged": MSManipulationEvent; - "MSPointerCancel": MSPointerEvent; - "MSPointerDown": MSPointerEvent; - "MSPointerEnter": MSPointerEvent; - "MSPointerLeave": MSPointerEvent; - "MSPointerMove": MSPointerEvent; - "MSPointerOut": MSPointerEvent; - "MSPointerOver": MSPointerEvent; - "MSPointerUp": MSPointerEvent; - "mssitemodejumplistitemremoved": MSSiteModeEvent; - "msthumbnailclick": MSSiteModeEvent; - "pause": Event; - "play": Event; - "playing": Event; - "pointerlockchange": Event; - "pointerlockerror": Event; - "progress": ProgressEvent; - "ratechange": Event; "readystatechange": Event; - "reset": Event; - "scroll": UIEvent; - "seeked": Event; - "seeking": Event; - "select": UIEvent; - "selectionchange": Event; - "selectstart": Event; - "stalled": Event; - "stop": Event; - "submit": Event; - "suspend": Event; - "timeupdate": Event; - "touchcancel": TouchEvent; - "touchend": TouchEvent; - "touchmove": TouchEvent; - "touchstart": TouchEvent; - "volumechange": Event; - "waiting": Event; - "webkitfullscreenchange": Event; - "webkitfullscreenerror": Event; } -interface Document extends Node, GlobalEventHandlers, NodeSelector, DocumentEvent, ParentNode, DocumentOrShadowRoot { +interface Document extends Node, NonElementParentNode, DocumentOrShadowRoot, ParentNode, GeometryUtils, GlobalEventHandlers, DocumentAndElementEventHandlers, ParentNode { /** * Gets the object that has the focus when the parent document has focus. */ - readonly activeElement: Element; + readonly activeElement: Element | null; /** * Sets or gets the color of all active links in the document. */ @@ -2629,19 +2746,20 @@ interface Document extends Node, GlobalEventHandlers, NodeSelector, DocumentEven /** * Specifies the beginning and end of the document body. */ - body: HTMLElement; + body: HTMLElement | null; readonly characterSet: string; /** * Gets or sets the character set used to encode the object. */ - charset: string; + readonly charset: string; /** * Gets a value that indicates whether standards-compliant mode is switched on for the object. */ readonly compatMode: string; + readonly contentType: string; cookie: string; readonly currentScript: HTMLScriptElement | SVGScriptElement | null; - readonly defaultView: Window; + readonly defaultView: Window | null; /** * Sets or gets a value that indicates whether the document can be edited. */ @@ -2653,11 +2771,12 @@ interface Document extends Node, GlobalEventHandlers, NodeSelector, DocumentEven /** * Gets an object representing the document type declaration associated with the current document. */ - readonly doctype: DocumentType; + readonly doctype: DocumentType | null; /** * Gets a reference to the root node of the document. */ documentElement: HTMLElement; + readonly documentURI: string; /** * Sets or gets the security domain of the document. */ @@ -2674,9 +2793,9 @@ interface Document extends Node, GlobalEventHandlers, NodeSelector, DocumentEven * Retrieves a collection, in source order, of all form objects in the document. */ forms: HTMLCollectionOf; - readonly fullscreenElement: Element | null; + readonly fullscreen: boolean; readonly fullscreenEnabled: boolean; - readonly head: HTMLHeadElement; + readonly head: HTMLHeadElement | null; readonly hidden: boolean; /** * Retrieves a collection, in source order, of img objects in the document. @@ -2689,7 +2808,7 @@ interface Document extends Node, GlobalEventHandlers, NodeSelector, DocumentEven /** * Returns the character encoding used to create the webpage that is loaded into the document object. */ - readonly inputEncoding: string | null; + readonly inputEncoding: string; /** * Gets the date that the page was last modified, if the page supplies one. */ @@ -2705,381 +2824,64 @@ interface Document extends Node, GlobalEventHandlers, NodeSelector, DocumentEven /** * Contains information about the current URL. */ - readonly location: Location; - msCapsLockWarningOff: boolean; - msCSSOMElementFloatMetrics: boolean; + readonly location: Location | null; + onfullscreenchange: (this: Document, ev: Event) => any; + onfullscreenerror: (this: Document, ev: Event) => any; /** - * Fires when the user aborts the download. - * @param ev The event. + * Fires when the state of the object has changed. + * @param ev The event */ - onabort: (this: Document, ev: UIEvent) => any; + onreadystatechange: (this: Document, ev: Event) => any; + readonly origin: string; + plugins: HTMLCollectionOf; /** - * Fires when the object is set as the active element. - * @param ev The event. + * Retrieves a value that indicates the current state of the object. */ - onactivate: (this: Document, ev: UIEvent) => any; + readonly readyState: DocumentReadyState; /** - * Fires immediately before the object is set as the active element. - * @param ev The event. + * Gets the URL of the location that referred the user to the current page. */ - onbeforeactivate: (this: Document, ev: UIEvent) => any; + readonly referrer: string; /** - * Fires immediately before the activeElement is changed from the current object to another object in the parent document. - * @param ev The event. + * Gets the root svg element in the document hierarchy. */ - onbeforedeactivate: (this: Document, ev: UIEvent) => any; + readonly rootElement: SVGSVGElement | null; /** - * Fires when the object loses the input focus. - * @param ev The focus event. + * Retrieves a collection of all script objects in the document. */ - onblur: (this: Document, ev: FocusEvent) => any; + scripts: HTMLCollectionOf; + readonly scrollingElement: Element | null; /** - * Occurs when playback is possible, but would require further buffering. - * @param ev The event. + * Retrieves a collection of styleSheet objects representing the style sheets that correspond to each instance of a link or style object in the document. */ - oncanplay: (this: Document, ev: Event) => any; - oncanplaythrough: (this: Document, ev: Event) => any; + readonly styleSheets: StyleSheetList; /** - * Fires when the contents of the object or selection have changed. - * @param ev The event. + * Contains the title of the document. */ - onchange: (this: Document, ev: Event) => any; + title: string; /** - * Fires when the user clicks the left mouse button on the object - * @param ev The mouse event. + * Sets or gets the URL for the current document. */ - onclick: (this: Document, ev: MouseEvent) => any; + readonly URL: string; + readonly visibilityState: VisibilityState; /** - * Fires when the user clicks the right mouse button in the client area, opening the context menu. - * @param ev The mouse event. + * Sets or gets the color of the links that the user has visited. */ - oncontextmenu: (this: Document, ev: PointerEvent) => any; + vlinkColor: string; + adoptNode(source: T): T; + captureEvents(): void; + caretPositionFromPoint(x: number, y: number): CaretPosition | null; + clear(): void; /** - * Fires when the user double-clicks the object. - * @param ev The mouse event. + * Closes an output stream and forces the sent data to display. */ - ondblclick: (this: Document, ev: MouseEvent) => any; + close(): void; /** - * Fires when the activeElement is changed from the current object to another object in the parent document. - * @param ev The UI Event + * Creates an attribute object with a specified name. + * @param name String that sets the attribute object's name. */ - ondeactivate: (this: Document, ev: UIEvent) => any; - /** - * Fires on the source object continuously during a drag operation. - * @param ev The event. - */ - ondrag: (this: Document, ev: DragEvent) => any; - /** - * Fires on the source object when the user releases the mouse at the close of a drag operation. - * @param ev The event. - */ - ondragend: (this: Document, ev: DragEvent) => any; - /** - * Fires on the target element when the user drags the object to a valid drop target. - * @param ev The drag event. - */ - ondragenter: (this: Document, ev: DragEvent) => any; - /** - * Fires on the target object when the user moves the mouse out of a valid drop target during a drag operation. - * @param ev The drag event. - */ - ondragleave: (this: Document, ev: DragEvent) => any; - /** - * Fires on the target element continuously while the user drags the object over a valid drop target. - * @param ev The event. - */ - ondragover: (this: Document, ev: DragEvent) => any; - /** - * Fires on the source object when the user starts to drag a text selection or selected object. - * @param ev The event. - */ - ondragstart: (this: Document, ev: DragEvent) => any; - ondrop: (this: Document, ev: DragEvent) => any; - /** - * Occurs when the duration attribute is updated. - * @param ev The event. - */ - ondurationchange: (this: Document, ev: Event) => any; - /** - * Occurs when the media element is reset to its initial state. - * @param ev The event. - */ - onemptied: (this: Document, ev: Event) => any; - /** - * Occurs when the end of playback is reached. - * @param ev The event - */ - onended: (this: Document, ev: MediaStreamErrorEvent) => any; - /** - * Fires when an error occurs during object loading. - * @param ev The event. - */ - onerror: (this: Document, ev: ErrorEvent) => any; - /** - * Fires when the object receives focus. - * @param ev The event. - */ - onfocus: (this: Document, ev: FocusEvent) => any; - onfullscreenchange: (this: Document, ev: Event) => any; - onfullscreenerror: (this: Document, ev: Event) => any; - oninput: (this: Document, ev: Event) => any; - oninvalid: (this: Document, ev: Event) => any; - /** - * Fires when the user presses a key. - * @param ev The keyboard event - */ - onkeydown: (this: Document, ev: KeyboardEvent) => any; - /** - * Fires when the user presses an alphanumeric key. - * @param ev The event. - */ - onkeypress: (this: Document, ev: KeyboardEvent) => any; - /** - * Fires when the user releases a key. - * @param ev The keyboard event - */ - onkeyup: (this: Document, ev: KeyboardEvent) => any; - /** - * Fires immediately after the browser loads the object. - * @param ev The event. - */ - onload: (this: Document, ev: Event) => any; - /** - * Occurs when media data is loaded at the current playback position. - * @param ev The event. - */ - onloadeddata: (this: Document, ev: Event) => any; - /** - * Occurs when the duration and dimensions of the media have been determined. - * @param ev The event. - */ - onloadedmetadata: (this: Document, ev: Event) => any; - /** - * Occurs when Internet Explorer begins looking for media data. - * @param ev The event. - */ - onloadstart: (this: Document, ev: Event) => any; - /** - * Fires when the user clicks the object with either mouse button. - * @param ev The mouse event. - */ - onmousedown: (this: Document, ev: MouseEvent) => any; - /** - * Fires when the user moves the mouse over the object. - * @param ev The mouse event. - */ - onmousemove: (this: Document, ev: MouseEvent) => any; - /** - * Fires when the user moves the mouse pointer outside the boundaries of the object. - * @param ev The mouse event. - */ - onmouseout: (this: Document, ev: MouseEvent) => any; - /** - * Fires when the user moves the mouse pointer into the object. - * @param ev The mouse event. - */ - onmouseover: (this: Document, ev: MouseEvent) => any; - /** - * Fires when the user releases a mouse button while the mouse is over the object. - * @param ev The mouse event. - */ - onmouseup: (this: Document, ev: MouseEvent) => any; - /** - * Fires when the wheel button is rotated. - * @param ev The mouse event - */ - onmousewheel: (this: Document, ev: WheelEvent) => any; - onmscontentzoom: (this: Document, ev: UIEvent) => any; - onmsgesturechange: (this: Document, ev: MSGestureEvent) => any; - onmsgesturedoubletap: (this: Document, ev: MSGestureEvent) => any; - onmsgestureend: (this: Document, ev: MSGestureEvent) => any; - onmsgesturehold: (this: Document, ev: MSGestureEvent) => any; - onmsgesturestart: (this: Document, ev: MSGestureEvent) => any; - onmsgesturetap: (this: Document, ev: MSGestureEvent) => any; - onmsinertiastart: (this: Document, ev: MSGestureEvent) => any; - onmsmanipulationstatechanged: (this: Document, ev: MSManipulationEvent) => any; - onmspointercancel: (this: Document, ev: MSPointerEvent) => any; - onmspointerdown: (this: Document, ev: MSPointerEvent) => any; - onmspointerenter: (this: Document, ev: MSPointerEvent) => any; - onmspointerleave: (this: Document, ev: MSPointerEvent) => any; - onmspointermove: (this: Document, ev: MSPointerEvent) => any; - onmspointerout: (this: Document, ev: MSPointerEvent) => any; - onmspointerover: (this: Document, ev: MSPointerEvent) => any; - onmspointerup: (this: Document, ev: MSPointerEvent) => any; - /** - * Occurs when an item is removed from a Jump List of a webpage running in Site Mode. - * @param ev The event. - */ - onmssitemodejumplistitemremoved: (this: Document, ev: MSSiteModeEvent) => any; - /** - * Occurs when a user clicks a button in a Thumbnail Toolbar of a webpage running in Site Mode. - * @param ev The event. - */ - onmsthumbnailclick: (this: Document, ev: MSSiteModeEvent) => any; - /** - * Occurs when playback is paused. - * @param ev The event. - */ - onpause: (this: Document, ev: Event) => any; - /** - * Occurs when the play method is requested. - * @param ev The event. - */ - onplay: (this: Document, ev: Event) => any; - /** - * Occurs when the audio or video has started playing. - * @param ev The event. - */ - onplaying: (this: Document, ev: Event) => any; - onpointerlockchange: (this: Document, ev: Event) => any; - onpointerlockerror: (this: Document, ev: Event) => any; - /** - * Occurs to indicate progress while downloading media data. - * @param ev The event. - */ - onprogress: (this: Document, ev: ProgressEvent) => any; - /** - * Occurs when the playback rate is increased or decreased. - * @param ev The event. - */ - onratechange: (this: Document, ev: Event) => any; - /** - * Fires when the state of the object has changed. - * @param ev The event - */ - onreadystatechange: (this: Document, ev: Event) => any; - /** - * Fires when the user resets a form. - * @param ev The event. - */ - onreset: (this: Document, ev: Event) => any; - /** - * Fires when the user repositions the scroll box in the scroll bar on the object. - * @param ev The event. - */ - onscroll: (this: Document, ev: UIEvent) => any; - /** - * Occurs when the seek operation ends. - * @param ev The event. - */ - onseeked: (this: Document, ev: Event) => any; - /** - * Occurs when the current playback position is moved. - * @param ev The event. - */ - onseeking: (this: Document, ev: Event) => any; - /** - * Fires when the current selection changes. - * @param ev The event. - */ - onselect: (this: Document, ev: UIEvent) => any; - /** - * Fires when the selection state of a document changes. - * @param ev The event. - */ - onselectionchange: (this: Document, ev: Event) => any; - onselectstart: (this: Document, ev: Event) => any; - /** - * Occurs when the download has stopped. - * @param ev The event. - */ - onstalled: (this: Document, ev: Event) => any; - /** - * Fires when the user clicks the Stop button or leaves the Web page. - * @param ev The event. - */ - onstop: (this: Document, ev: Event) => any; - onsubmit: (this: Document, ev: Event) => any; - /** - * Occurs if the load operation has been intentionally halted. - * @param ev The event. - */ - onsuspend: (this: Document, ev: Event) => any; - /** - * Occurs to indicate the current playback position. - * @param ev The event. - */ - ontimeupdate: (this: Document, ev: Event) => any; - ontouchcancel: (ev: TouchEvent) => any; - ontouchend: (ev: TouchEvent) => any; - ontouchmove: (ev: TouchEvent) => any; - ontouchstart: (ev: TouchEvent) => any; - /** - * Occurs when the volume is changed, or playback is muted or unmuted. - * @param ev The event. - */ - onvolumechange: (this: Document, ev: Event) => any; - /** - * Occurs when playback stops because the next frame of a video resource is not available. - * @param ev The event. - */ - onwaiting: (this: Document, ev: Event) => any; - onwebkitfullscreenchange: (this: Document, ev: Event) => any; - onwebkitfullscreenerror: (this: Document, ev: Event) => any; - plugins: HTMLCollectionOf; - readonly pointerLockElement: Element; - /** - * Retrieves a value that indicates the current state of the object. - */ - readonly readyState: string; - /** - * Gets the URL of the location that referred the user to the current page. - */ - readonly referrer: string; - /** - * Gets the root svg element in the document hierarchy. - */ - readonly rootElement: SVGSVGElement; - /** - * Retrieves a collection of all script objects in the document. - */ - scripts: HTMLCollectionOf; - readonly scrollingElement: Element | null; - /** - * Retrieves a collection of styleSheet objects representing the style sheets that correspond to each instance of a link or style object in the document. - */ - readonly styleSheets: StyleSheetList; - /** - * Contains the title of the document. - */ - title: string; - /** - * Sets or gets the URL for the current document. - */ - readonly URL: string; - /** - * Gets the URL for the document, stripped of any character encoding. - */ - readonly URLUnencoded: string; - readonly visibilityState: VisibilityState; - /** - * Sets or gets the color of the links that the user has visited. - */ - vlinkColor: string; - readonly webkitCurrentFullScreenElement: Element | null; - readonly webkitFullscreenElement: Element | null; - readonly webkitFullscreenEnabled: boolean; - readonly webkitIsFullScreen: boolean; - readonly xmlEncoding: string | null; - xmlStandalone: boolean; - /** - * Gets or sets the version attribute specified in the declaration of an XML document. - */ - xmlVersion: string | null; - adoptNode(source: T): T; - captureEvents(): void; - caretRangeFromPoint(x: number, y: number): Range; - clear(): void; - /** - * Closes an output stream and forces the sent data to display. - */ - close(): void; - /** - * Creates an attribute object with a specified name. - * @param name String that sets the attribute object's name. - */ - createAttribute(name: string): Attr; - createAttributeNS(namespaceURI: string | null, qualifiedName: string): Attr; + createAttribute(localName: string): Attr; + createAttributeNS(namespace: string | null, qualifiedName: string): Attr; createCDATASection(data: string): CDATASection; /** * Creates a comment object with the specified data. @@ -3094,8 +2896,6 @@ interface Document extends Node, GlobalEventHandlers, NodeSelector, DocumentEven * Creates an instance of the element for the specified tag. * @param tagName The name of an element. */ - createElement(tagName: K): HTMLElementTagNameMap[K]; - createElement(tagName: string): HTMLElement; createElementNS(namespaceURI: "http://www.w3.org/1999/xhtml", qualifiedName: string): HTMLElement; createElementNS(namespaceURI: "http://www.w3.org/2000/svg", qualifiedName: "a"): SVGAElement; createElementNS(namespaceURI: "http://www.w3.org/2000/svg", qualifiedName: "circle"): SVGCircleElement; @@ -3159,8 +2959,59 @@ interface Document extends Node, GlobalEventHandlers, NodeSelector, DocumentEven createElementNS(namespaceURI: "http://www.w3.org/2000/svg", qualifiedName: "use"): SVGUseElement; createElementNS(namespaceURI: "http://www.w3.org/2000/svg", qualifiedName: "view"): SVGViewElement; createElementNS(namespaceURI: "http://www.w3.org/2000/svg", qualifiedName: string): SVGElement; - createElementNS(namespaceURI: string | null, qualifiedName: string): Element; - createExpression(expression: string, resolver: XPathNSResolver): XPathExpression; + createElementNS(namespace: string | null, qualifiedName: string, options?: ElementCreationOptions): Element; + createEvent(eventInterface: "AnimationEvent"): AnimationEvent; + createEvent(eventInterface: "AudioProcessingEvent"): AudioProcessingEvent; + createEvent(eventInterface: "BeforeUnloadEvent"): BeforeUnloadEvent; + createEvent(eventInterface: "ClipboardEvent"): ClipboardEvent; + createEvent(eventInterface: "CloseEvent"): CloseEvent; + createEvent(eventInterface: "CompositionEvent"): CompositionEvent; + createEvent(eventInterface: "CustomEvent"): CustomEvent; + createEvent(eventInterface: "DeviceMotionEvent"): DeviceMotionEvent; + createEvent(eventInterface: "DeviceOrientationEvent"): DeviceOrientationEvent; + createEvent(eventInterface: "DragEvent"): DragEvent; + createEvent(eventInterface: "ErrorEvent"): ErrorEvent; + createEvent(eventInterface: "Event"): Event; + createEvent(eventInterface: "Events"): Event; + createEvent(eventInterface: "FocusEvent"): FocusEvent; + createEvent(eventInterface: "GamepadEvent"): GamepadEvent; + createEvent(eventInterface: "HashChangeEvent"): HashChangeEvent; + createEvent(eventInterface: "IDBVersionChangeEvent"): IDBVersionChangeEvent; + createEvent(eventInterface: "KeyboardEvent"): KeyboardEvent; + createEvent(eventInterface: "MediaEncryptedEvent"): MediaEncryptedEvent; + createEvent(eventInterface: "MediaKeyMessageEvent"): MediaKeyMessageEvent; + createEvent(eventInterface: "MediaQueryListEvent"): MediaQueryListEvent; + createEvent(eventInterface: "MediaStreamTrackEvent"): MediaStreamTrackEvent; + createEvent(eventInterface: "MessageEvent"): MessageEvent; + createEvent(eventInterface: "MouseEvent"): MouseEvent; + createEvent(eventInterface: "MouseEvents"): MouseEvent; + createEvent(eventInterface: "OfflineAudioCompletionEvent"): OfflineAudioCompletionEvent; + createEvent(eventInterface: "OverconstrainedErrorEvent"): OverconstrainedErrorEvent; + createEvent(eventInterface: "PageTransitionEvent"): PageTransitionEvent; + createEvent(eventInterface: "PaymentRequestUpdateEvent"): PaymentRequestUpdateEvent; + createEvent(eventInterface: "PointerEvent"): PointerEvent; + createEvent(eventInterface: "PopStateEvent"): PopStateEvent; + createEvent(eventInterface: "ProgressEvent"): ProgressEvent; + createEvent(eventInterface: "PromiseRejectionEvent"): PromiseRejectionEvent; + createEvent(eventInterface: "RTCDTMFToneChangeEvent"): RTCDTMFToneChangeEvent; + createEvent(eventInterface: "RTCDataChannelEvent"): RTCDataChannelEvent; + createEvent(eventInterface: "RTCErrorEvent"): RTCErrorEvent; + createEvent(eventInterface: "RTCPeerConnectionIceErrorEvent"): RTCPeerConnectionIceErrorEvent; + createEvent(eventInterface: "RTCPeerConnectionIceEvent"): RTCPeerConnectionIceEvent; + createEvent(eventInterface: "RTCTrackEvent"): RTCTrackEvent; + createEvent(eventInterface: "RelatedEvent"): RelatedEvent; + createEvent(eventInterface: "SpeechRecognitionError"): SpeechRecognitionError; + createEvent(eventInterface: "SpeechRecognitionEvent"): SpeechRecognitionEvent; + createEvent(eventInterface: "SpeechSynthesisEvent"): SpeechSynthesisEvent; + createEvent(eventInterface: "StorageEvent"): StorageEvent; + createEvent(eventInterface: "TouchEvent"): TouchEvent; + createEvent(eventInterface: "TrackEvent"): TrackEvent; + createEvent(eventInterface: "TransitionEvent"): TransitionEvent; + createEvent(eventInterface: "UIEvent"): UIEvent; + createEvent(eventInterface: "UIEvents"): UIEvent; + createEvent(eventInterface: "WebGLContextEvent"): WebGLContextEvent; + createEvent(eventInterface: "WheelEvent"): WheelEvent; + createEvent(eventInterface: string): Event; /** * Creates a NodeIterator object that you can use to traverse filtered lists of nodes or elements in a document. * @param root The root element or node to start traversing on. @@ -3168,8 +3019,7 @@ interface Document extends Node, GlobalEventHandlers, NodeSelector, DocumentEven * @param filter A custom NodeFilter function to use. For more information, see filter. Use null for no filter. * @param entityReferenceExpansion A flag that specifies whether entity reference nodes are expanded. */ - createNodeIterator(root: Node, whatToShow?: number, filter?: NodeFilter, entityReferenceExpansion?: boolean): NodeIterator; - createNSResolver(nodeResolver: Node): XPathNSResolver; + createNodeIterator(root: Node, whatToShow?: number, filter?: NodeFilter): NodeIterator; createProcessingInstruction(target: string, data: string): ProcessingInstruction; /** * Returns an empty range object that has both of its boundary points positioned at the beginning of the document. @@ -3189,37 +3039,22 @@ interface Document extends Node, GlobalEventHandlers, NodeSelector, DocumentEven * @param filter A custom NodeFilter function to use. * @param entityReferenceExpansion A flag that specifies whether entity reference nodes are expanded. */ - createTreeWalker(root: Node, whatToShow?: number, filter?: NodeFilter, entityReferenceExpansion?: boolean): TreeWalker; + createTreeWalker(root: Node, whatToShow?: number, filter?: NodeFilter): TreeWalker; /** * Returns the element for the specified x coordinate and the specified y coordinate. * @param x The x-offset * @param y The y-offset */ - elementFromPoint(x: number, y: number): Element; - evaluate(expression: string, contextNode: Node, resolver: XPathNSResolver | null, type: number, result: XPathResult | null): XPathResult; + elementFromPoint(x: number, y: number): Element | null; + elementsFromPoint(x: number, y: number): Element[]; /** * Executes a command on the current document, current selection, or the given range. * @param commandId String that specifies the command to execute. This command can be any of the command identifiers that can be executed in script. * @param showUI Display the user interface, defaults to false. * @param value Value to assign. */ - execCommand(commandId: string, showUI?: boolean, value?: any): boolean; - /** - * Displays help information for the given command identifier. - * @param commandId Displays help information for the given command identifier. - */ - execCommandShowHelp(commandId: string): boolean; - exitFullscreen(): void; - exitPointerLock(): void; - /** - * Causes the element to receive the focus and executes the code specified by the onfocus event. - */ - focus(): void; - /** - * Returns a reference to the first object with the specified value of the ID or NAME attribute. - * @param elementId String that specifies the ID value. Case-insensitive. - */ - getElementById(elementId: string): HTMLElement | null; + execCommand(commandId: string, showUI?: boolean, value?: string): boolean; + exitFullscreen(): Promise; getElementsByClassName(classNames: string): HTMLCollectionOf; /** * Gets a collection of objects based on the value of the NAME or ID attribute. @@ -3230,22 +3065,28 @@ interface Document extends Node, GlobalEventHandlers, NodeSelector, DocumentEven * Retrieves a collection of objects based on the specified element name. * @param name Specifies the name of an element. */ - getElementsByTagName(tagname: K): ElementListTagNameMap[K]; - getElementsByTagName(tagname: string): NodeListOf; + getElementsByTagName(qualifiedName: K): HTMLCollectionOf; + getElementsByTagName(qualifiedName: string): HTMLCollectionOf; getElementsByTagNameNS(namespaceURI: "http://www.w3.org/1999/xhtml", localName: string): HTMLCollectionOf; getElementsByTagNameNS(namespaceURI: "http://www.w3.org/2000/svg", localName: string): HTMLCollectionOf; getElementsByTagNameNS(namespaceURI: string, localName: string): HTMLCollectionOf; /** * Returns an object representing the current selection of the document that is loaded into the object displaying a webpage. */ - getSelection(): Selection; + getSelection(): Selection | null; /** * Gets a value indicating whether the object currently has focus. */ hasFocus(): boolean; importNode(importedNode: T, deep: boolean): T; - msElementsFromPoint(x: number, y: number): NodeListOf; - msElementsFromRect(left: number, top: number, width: number, height: number): NodeListOf; + /** + * Opens a new window and loads a document specified by a given URL. Also, opens a new window that uses the url parameter and the name parameter to collect the output of the write method and the writeln method. + * @param url Specifies a MIME type for the document. + * @param name Specifies the name of the window. This name is used as the value for the TARGET attribute on a form or an anchor element. + * @param features Contains a list of items separated by commas. Each item consists of an option and a value, separated by an equals sign (for example, "fullscreen=yes, toolbar=yes"). The following values are supported. + * @param replace Specifies whether the existing entry for the document is replaced in the history list. + */ + open(url?: string, name?: string, features?: string, replace?: boolean): Document; /** * Opens a new window and loads a document specified by a given URL. Also, opens a new window that uses the url parameter and the name parameter to collect the output of the write method and the writeln method. * @param url Specifies a MIME type for the document. @@ -3274,35 +3115,25 @@ interface Document extends Node, GlobalEventHandlers, NodeSelector, DocumentEven * @param commandId Specifies a command identifier. */ queryCommandSupported(commandId: string): boolean; - /** - * Retrieves the string associated with a command. - * @param commandId String that contains the identifier of a command. This can be any command identifier given in the list of Command Identifiers. - */ - queryCommandText(commandId: string): string; /** * Returns the current value of the document, range, or current selection for the given command. * @param commandId String that specifies a command identifier. */ queryCommandValue(commandId: string): string; releaseEvents(): void; - /** - * Allows updating the print settings for the page. - */ - updateSettings(): void; - webkitCancelFullScreen(): void; - webkitExitFullscreen(): void; /** * Writes one or more HTML expressions to a document in the specified window. * @param content Specifies the text and HTML tags to write. */ - write(...content: string[]): void; + write(...text: string[]): void; /** * Writes one or more HTML expressions, followed by a carriage return, to a document in the specified window. * @param content The text and HTML tags to write. */ - writeln(...content: string[]): void; + writeln(...text: string[]): void; addEventListener(type: K, listener: (this: Document, ev: DocumentEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; + [name: string]: any; } declare var Document: { @@ -3310,8 +3141,7 @@ declare var Document: { new(): Document; }; -interface DocumentFragment extends Node, NodeSelector, ParentNode { - getElementById(elementId: string): HTMLElement | null; +interface DocumentFragment extends Node, NonElementParentNode, ParentNode, ParentNode { } declare var DocumentFragment: { @@ -3320,10 +3150,7 @@ declare var DocumentFragment: { }; interface DocumentType extends Node, ChildNode { - readonly entities: NamedNodeMap; - readonly internalSubset: string | null; readonly name: string; - readonly notations: NamedNodeMap; readonly publicId: string; readonly systemId: string; } @@ -3333,96 +3160,115 @@ declare var DocumentType: { new(): DocumentType; }; -interface DOMError { - readonly name: string; - toString(): string; +interface DOMImplementation { + createDocument(namespaceURI: string | null, qualifiedName: string | null, doctype: DocumentType | null): Document; + createDocumentType(qualifiedName: string, publicId: string, systemId: string): DocumentType; + createHTMLDocument(title?: string): Document; + hasFeature(feature: string | null, version: string | null): boolean; } -declare var DOMError: { - prototype: DOMError; - new(): DOMError; +declare var DOMImplementation: { + prototype: DOMImplementation; + new(): DOMImplementation; }; -interface DOMException { - readonly code: number; - readonly message: string; - readonly name: string; - toString(): string; - readonly ABORT_ERR: number; - readonly DATA_CLONE_ERR: number; - readonly DOMSTRING_SIZE_ERR: number; - readonly HIERARCHY_REQUEST_ERR: number; - readonly INDEX_SIZE_ERR: number; - readonly INUSE_ATTRIBUTE_ERR: number; - readonly INVALID_ACCESS_ERR: number; - readonly INVALID_CHARACTER_ERR: number; - readonly INVALID_MODIFICATION_ERR: number; - readonly INVALID_NODE_TYPE_ERR: number; - readonly INVALID_STATE_ERR: number; - readonly NAMESPACE_ERR: number; - readonly NETWORK_ERR: number; - readonly NO_DATA_ALLOWED_ERR: number; - readonly NO_MODIFICATION_ALLOWED_ERR: number; - readonly NOT_FOUND_ERR: number; - readonly NOT_SUPPORTED_ERR: number; - readonly PARSE_ERR: number; - readonly QUOTA_EXCEEDED_ERR: number; - readonly SECURITY_ERR: number; - readonly SERIALIZE_ERR: number; - readonly SYNTAX_ERR: number; - readonly TIMEOUT_ERR: number; - readonly TYPE_MISMATCH_ERR: number; - readonly URL_MISMATCH_ERR: number; - readonly VALIDATION_ERR: number; - readonly WRONG_DOCUMENT_ERR: number; -} - -declare var DOMException: { - prototype: DOMException; - new(message?: string, name?: string): DOMException; - readonly ABORT_ERR: number; - readonly DATA_CLONE_ERR: number; - readonly DOMSTRING_SIZE_ERR: number; - readonly HIERARCHY_REQUEST_ERR: number; - readonly INDEX_SIZE_ERR: number; - readonly INUSE_ATTRIBUTE_ERR: number; - readonly INVALID_ACCESS_ERR: number; - readonly INVALID_CHARACTER_ERR: number; - readonly INVALID_MODIFICATION_ERR: number; - readonly INVALID_NODE_TYPE_ERR: number; - readonly INVALID_STATE_ERR: number; - readonly NAMESPACE_ERR: number; - readonly NETWORK_ERR: number; - readonly NO_DATA_ALLOWED_ERR: number; - readonly NO_MODIFICATION_ALLOWED_ERR: number; - readonly NOT_FOUND_ERR: number; - readonly NOT_SUPPORTED_ERR: number; - readonly PARSE_ERR: number; - readonly QUOTA_EXCEEDED_ERR: number; - readonly SECURITY_ERR: number; - readonly SERIALIZE_ERR: number; - readonly SYNTAX_ERR: number; - readonly TIMEOUT_ERR: number; - readonly TYPE_MISMATCH_ERR: number; - readonly URL_MISMATCH_ERR: number; - readonly VALIDATION_ERR: number; - readonly WRONG_DOCUMENT_ERR: number; -}; - -interface DOMImplementation { - createDocument(namespaceURI: string | null, qualifiedName: string | null, doctype: DocumentType | null): Document; - createDocumentType(qualifiedName: string, publicId: string, systemId: string): DocumentType; - createHTMLDocument(title: string): Document; - hasFeature(feature: string | null, version: string | null): boolean; -} - -declare var DOMImplementation: { - prototype: DOMImplementation; - new(): DOMImplementation; +interface DOMMatrix extends DOMMatrixReadOnly { + a: number; + b: number; + c: number; + d: number; + e: number; + f: number; + m11: number; + m12: number; + m13: number; + m14: number; + m21: number; + m22: number; + m23: number; + m24: number; + m31: number; + m32: number; + m33: number; + m34: number; + m41: number; + m42: number; + m43: number; + m44: number; + invertSelf(): DOMMatrix; + multiplySelf(other?: DOMMatrixInit): DOMMatrix; + preMultiplySelf(other?: DOMMatrixInit): DOMMatrix; + rotateAxisAngleSelf(x?: number, y?: number, z?: number, angle?: number): DOMMatrix; + rotateFromVectorSelf(x?: number, y?: number): DOMMatrix; + rotateSelf(rotX?: number, rotY?: number, rotZ?: number): DOMMatrix; + scale3dSelf(scale?: number, originX?: number, originY?: number, originZ?: number): DOMMatrix; + scaleSelf(scaleX?: number, scaleY?: number, scaleZ?: number, originX?: number, originY?: number, originZ?: number): DOMMatrix; + setMatrixValue(transformList: string): DOMMatrix; + skewXSelf(sx?: number): DOMMatrix; + skewYSelf(sy?: number): DOMMatrix; + translateSelf(tx?: number, ty?: number, tz?: number): DOMMatrix; +} + +declare var DOMMatrix: { + prototype: DOMMatrix; + new(init?: string | number[]): DOMMatrix; + fromFloat32Array(array32: Float32Array): DOMMatrix; + fromFloat64Array(array64: Float64Array): DOMMatrix; + fromMatrix(other?: DOMMatrixInit): DOMMatrix; +}; + +interface DOMMatrixReadOnly { + readonly a: number; + readonly b: number; + readonly c: number; + readonly d: number; + readonly e: number; + readonly f: number; + readonly is2D: boolean; + readonly isIdentity: boolean; + readonly m11: number; + readonly m12: number; + readonly m13: number; + readonly m14: number; + readonly m21: number; + readonly m22: number; + readonly m23: number; + readonly m24: number; + readonly m31: number; + readonly m32: number; + readonly m33: number; + readonly m34: number; + readonly m41: number; + readonly m42: number; + readonly m43: number; + readonly m44: number; + flipX(): DOMMatrix; + flipY(): DOMMatrix; + inverse(): DOMMatrix; + multiply(other?: DOMMatrixInit): DOMMatrix; + rotate(rotX?: number, rotY?: number, rotZ?: number): DOMMatrix; + rotateAxisAngle(x?: number, y?: number, z?: number, angle?: number): DOMMatrix; + rotateFromVector(x?: number, y?: number): DOMMatrix; + scale(scaleX?: number, scaleY?: number, scaleZ?: number, originX?: number, originY?: number, originZ?: number): DOMMatrix; + scale3d(scale?: number, originX?: number, originY?: number, originZ?: number): DOMMatrix; + skewX(sx?: number): DOMMatrix; + skewY(sy?: number): DOMMatrix; + toFloat32Array(): Float32Array; + toFloat64Array(): Float64Array; + transformPoint(point?: DOMPointInit): DOMPoint; + translate(tx?: number, ty?: number, tz?: number): DOMMatrix; +} + +declare var DOMMatrixReadOnly: { + prototype: DOMMatrixReadOnly; + new(init?: string | number[]): DOMMatrixReadOnly; + fromFloat32Array(array32: Float32Array): DOMMatrixReadOnly; + fromFloat64Array(array64: Float64Array): DOMMatrixReadOnly; + fromMatrix(other?: DOMMatrixInit): DOMMatrixReadOnly; }; interface DOMParser { - parseFromString(source: string, mimeType: string): Document; + parseFromString(str: string, type: any): Document; } declare var DOMParser: { @@ -3430,18 +3276,81 @@ declare var DOMParser: { new(): DOMParser; }; -interface DOMSettableTokenList extends DOMTokenList { - value: string; +interface DOMPoint extends DOMPointReadOnly { + w: number; + x: number; + y: number; + z: number; +} + +declare var DOMPoint: { + prototype: DOMPoint; + new(x?: number, y?: number, z?: number, w?: number): DOMPoint; + fromPoint(other?: DOMPointInit): DOMPoint; +}; + +interface DOMPointReadOnly { + readonly w: number; + readonly x: number; + readonly y: number; + readonly z: number; + matrixTransform(matrix?: DOMMatrixInit): DOMPoint; +} + +declare var DOMPointReadOnly: { + prototype: DOMPointReadOnly; + new(x?: number, y?: number, z?: number, w?: number): DOMPointReadOnly; + fromPoint(other?: DOMPointInit): DOMPointReadOnly; +}; + +interface DOMQuad { + readonly p1: DOMPoint; + readonly p2: DOMPoint; + readonly p3: DOMPoint; + readonly p4: DOMPoint; + getBounds(): DOMRect; } -declare var DOMSettableTokenList: { - prototype: DOMSettableTokenList; - new(): DOMSettableTokenList; +declare var DOMQuad: { + prototype: DOMQuad; + new(p1?: DOMPointInit, p2?: DOMPointInit, p3?: DOMPointInit, p4?: DOMPointInit): DOMQuad; + fromQuad(other?: DOMQuadInit): DOMQuad; + fromRect(other?: DOMRectInit): DOMQuad; +}; + +interface DOMRect extends DOMRectReadOnly { + height: number; + width: number; + x: number; + y: number; +} + +declare var DOMRect: { + prototype: DOMRect; + new(x?: number, y?: number, width?: number, height?: number): DOMRect; + fromRect(other?: DOMRectInit): DOMRect; +}; + +interface DOMRectReadOnly { + readonly bottom: number; + readonly height: number; + readonly left: number; + readonly right: number; + readonly top: number; + readonly width: number; + readonly x: number; + readonly y: number; +} + +declare var DOMRectReadOnly: { + prototype: DOMRectReadOnly; + new(x?: number, y?: number, width?: number, height?: number): DOMRectReadOnly; + fromRect(other?: DOMRectInit): DOMRectReadOnly; }; interface DOMStringList { readonly length: number; - contains(str: string): boolean; + contains(string: string): boolean; item(index: number): string | null; [index: number]: string; } @@ -3462,12 +3371,14 @@ declare var DOMStringMap: { interface DOMTokenList { readonly length: number; - add(...token: string[]): void; + value: string; + add(...tokens: string[]): void; contains(token: string): boolean; - item(index: number): string; - remove(...token: string[]): void; + item(index: number): string | null; + remove(...tokens: string[]): void; + replace(token: string, newToken: string): void; + supports(token: string): boolean; toggle(token: string, force?: boolean): boolean; - toString(): string; [index: number]: string; } @@ -3477,14 +3388,12 @@ declare var DOMTokenList: { }; interface DragEvent extends MouseEvent { - readonly dataTransfer: DataTransfer; - initDragEvent(typeArg: string, canBubbleArg: boolean, cancelableArg: boolean, viewArg: Window, detailArg: number, screenXArg: number, screenYArg: number, clientXArg: number, clientYArg: number, ctrlKeyArg: boolean, altKeyArg: boolean, shiftKeyArg: boolean, metaKeyArg: boolean, buttonArg: number, relatedTargetArg: EventTarget, dataTransferArg: DataTransfer): void; - msConvertURL(file: File, targetType: string, targetURL?: string): void; + readonly dataTransfer: DataTransfer | null; } declare var DragEvent: { prototype: DragEvent; - new(type: "drag" | "dragend" | "dragenter" | "dragexit" | "dragleave" | "dragover" | "dragstart" | "drop", dragEventInit?: { dataTransfer?: DataTransfer }): DragEvent; + new(type: string, eventInitDict?: DragEventInit): DragEvent; }; interface DynamicsCompressorNode extends AudioNode { @@ -3498,40 +3407,16 @@ interface DynamicsCompressorNode extends AudioNode { declare var DynamicsCompressorNode: { prototype: DynamicsCompressorNode; - new(): DynamicsCompressorNode; + new(context: BaseAudioContext, options?: DynamicsCompressorOptions): DynamicsCompressorNode; }; -interface ElementEventMap extends GlobalEventHandlersEventMap { - "ariarequest": Event; - "command": Event; +interface ElementEventMap { "gotpointercapture": PointerEvent; "lostpointercapture": PointerEvent; - "MSGestureChange": MSGestureEvent; - "MSGestureDoubleTap": MSGestureEvent; - "MSGestureEnd": MSGestureEvent; - "MSGestureHold": MSGestureEvent; - "MSGestureStart": MSGestureEvent; - "MSGestureTap": MSGestureEvent; - "MSGotPointerCapture": MSPointerEvent; - "MSInertiaStart": MSGestureEvent; - "MSLostPointerCapture": MSPointerEvent; - "MSPointerCancel": MSPointerEvent; - "MSPointerDown": MSPointerEvent; - "MSPointerEnter": MSPointerEvent; - "MSPointerLeave": MSPointerEvent; - "MSPointerMove": MSPointerEvent; - "MSPointerOut": MSPointerEvent; - "MSPointerOver": MSPointerEvent; - "MSPointerUp": MSPointerEvent; - "touchcancel": TouchEvent; - "touchend": TouchEvent; - "touchmove": TouchEvent; - "touchstart": TouchEvent; - "webkitfullscreenchange": Event; - "webkitfullscreenerror": Event; } -interface Element extends Node, GlobalEventHandlers, ElementTraversal, NodeSelector, ChildNode, ParentNode { +interface Element extends Node, ParentNode, NonDocumentTypeChildNode, ChildNode, Slotable, GeometryUtils, ParentNode { + readonly attributes: NamedNodeMap; readonly classList: DOMTokenList; className: string; readonly clientHeight: number; @@ -3540,94 +3425,70 @@ interface Element extends Node, GlobalEventHandlers, ElementTraversal, NodeSelec readonly clientWidth: number; id: string; innerHTML: string; - msContentZoomFactor: number; - readonly msRegionOverflow: string; - onariarequest: (this: Element, ev: Event) => any; - oncommand: (this: Element, ev: Event) => any; + readonly localName: string; + readonly namespaceURI: string | null; ongotpointercapture: (this: Element, ev: PointerEvent) => any; onlostpointercapture: (this: Element, ev: PointerEvent) => any; - onmsgesturechange: (this: Element, ev: MSGestureEvent) => any; - onmsgesturedoubletap: (this: Element, ev: MSGestureEvent) => any; - onmsgestureend: (this: Element, ev: MSGestureEvent) => any; - onmsgesturehold: (this: Element, ev: MSGestureEvent) => any; - onmsgesturestart: (this: Element, ev: MSGestureEvent) => any; - onmsgesturetap: (this: Element, ev: MSGestureEvent) => any; - onmsgotpointercapture: (this: Element, ev: MSPointerEvent) => any; - onmsinertiastart: (this: Element, ev: MSGestureEvent) => any; - onmslostpointercapture: (this: Element, ev: MSPointerEvent) => any; - onmspointercancel: (this: Element, ev: MSPointerEvent) => any; - onmspointerdown: (this: Element, ev: MSPointerEvent) => any; - onmspointerenter: (this: Element, ev: MSPointerEvent) => any; - onmspointerleave: (this: Element, ev: MSPointerEvent) => any; - onmspointermove: (this: Element, ev: MSPointerEvent) => any; - onmspointerout: (this: Element, ev: MSPointerEvent) => any; - onmspointerover: (this: Element, ev: MSPointerEvent) => any; - onmspointerup: (this: Element, ev: MSPointerEvent) => any; - ontouchcancel: (ev: TouchEvent) => any; - ontouchend: (ev: TouchEvent) => any; - ontouchmove: (ev: TouchEvent) => any; - ontouchstart: (ev: TouchEvent) => any; - onwebkitfullscreenchange: (this: Element, ev: Event) => any; - onwebkitfullscreenerror: (this: Element, ev: Event) => any; outerHTML: string; readonly prefix: string | null; readonly scrollHeight: number; scrollLeft: number; scrollTop: number; readonly scrollWidth: number; + readonly shadowRoot: ShadowRoot | null; + slot: string; readonly tagName: string; readonly assignedSlot: HTMLSlotElement | null; - slot: string; - readonly shadowRoot: ShadowRoot | null; + attachShadow(init: ShadowRootInit): ShadowRoot; + closest(selectors: string): Element | null; getAttribute(name: string): string | null; - getAttributeNode(name: string): Attr; - getAttributeNodeNS(namespaceURI: string, localName: string): Attr; - getAttributeNS(namespaceURI: string, localName: string): string; - getBoundingClientRect(): ClientRect; - getClientRects(): ClientRectList; - getElementsByTagName(name: K): ElementListTagNameMap[K]; - getElementsByTagName(name: string): NodeListOf; + getAttributeNames(): string[]; + getAttributeNode(qualifiedName: string): Attr | null; + getAttributeNodeNS(namespace: string | null, localName: string): Attr | null; + getAttributeNS(namespace: string | null, localName: string): string | null; + getBoundingClientRect(): DOMRect; + getClientRects(): DOMRect[]; + getElementsByClassName(classNames: string): HTMLCollectionOf; + getElementsByTagName(qualifiedName: K): HTMLCollectionOf; + getElementsByTagName(qualifiedName: string): HTMLCollectionOf; getElementsByTagNameNS(namespaceURI: "http://www.w3.org/1999/xhtml", localName: string): HTMLCollectionOf; getElementsByTagNameNS(namespaceURI: "http://www.w3.org/2000/svg", localName: string): HTMLCollectionOf; getElementsByTagNameNS(namespaceURI: string, localName: string): HTMLCollectionOf; - hasAttribute(name: string): boolean; - hasAttributeNS(namespaceURI: string, localName: string): boolean; - msGetRegionContent(): MSRangeCollection; - msGetUntransformedBounds(): ClientRect; - msMatchesSelector(selectors: string): boolean; - msReleasePointerCapture(pointerId: number): void; - msSetPointerCapture(pointerId: number): void; - msZoomTo(args: MsZoomToOptions): void; + hasAttribute(qualifiedName: string): boolean; + hasAttributeNS(namespace: string | null, localName: string): boolean; + hasAttributes(): boolean; + insertAdjacentElement(where: string, element: Element): Element | null; + insertAdjacentHTML(position: string, text: string): void; + insertAdjacentText(where: string, data: string): void; + matches(selectors: string): boolean; releasePointerCapture(pointerId: number): void; removeAttribute(qualifiedName: string): void; - removeAttributeNode(oldAttr: Attr): Attr; - removeAttributeNS(namespaceURI: string, localName: string): void; - requestFullscreen(): void; - requestPointerLock(): void; + removeAttributeNode(attr: Attr): Attr; + removeAttributeNS(namespace: string | null, localName: string): void; + requestFullscreen(): Promise; + scroll(options?: ScrollToOptions): void; + scroll(x: number, y: number): void; + scrollBy(options?: ScrollToOptions): void; + scrollBy(x: number, y: number): void; + scrollIntoView(): void; + scrollIntoView(arg: any): void; + scrollTo(x: number, y: number): void; + scrollTo(options?: ScrollToOptions): void; setAttribute(name: string, value: string): void; - setAttributeNode(newAttr: Attr): Attr; - setAttributeNodeNS(newAttr: Attr): Attr; - setAttributeNS(namespaceURI: string, qualifiedName: string, value: string): void; + setAttributeNode(attr: Attr): Attr | null; + setAttributeNodeNS(attr: Attr): Attr | null; + setAttributeNS(namespace: string | null, qualifiedName: string, value: string): void; setPointerCapture(pointerId: number): void; webkitMatchesSelector(selectors: string): boolean; - webkitRequestFullscreen(): void; - webkitRequestFullScreen(): void; getElementsByClassName(classNames: string): NodeListOf; matches(selector: string): boolean; closest(selector: string): Element | null; - scrollIntoView(arg?: boolean | ScrollIntoViewOptions): void; - scroll(options?: ScrollToOptions): void; - scroll(x: number, y: number): void; - scrollTo(options?: ScrollToOptions): void; - scrollTo(x: number, y: number): void; - scrollBy(options?: ScrollToOptions): void; - scrollBy(x: number, y: number): void; - insertAdjacentElement(position: InsertPosition, insertedElement: Element): Element | null; - insertAdjacentHTML(where: InsertPosition, html: string): void; - insertAdjacentText(where: InsertPosition, text: string): void; + insertAdjacentElement(position: string, insertedElement: Element): Element | null; + insertAdjacentHTML(where: string, html: string): void; + insertAdjacentText(where: string, text: string): void; attachShadow(shadowRootInitDict: ShadowRootInit): ShadowRoot; addEventListener(type: K, listener: (this: Element, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var Element: { @@ -3641,7 +3502,6 @@ interface ErrorEvent extends Event { readonly filename: string; readonly lineno: number; readonly message: string; - initErrorEvent(typeArg: string, canBubbleArg: boolean, cancelableArg: boolean, messageArg: string, filenameArg: string, linenoArg: number): void; } declare var ErrorEvent: { @@ -3653,17 +3513,17 @@ interface Event { readonly bubbles: boolean; readonly cancelable: boolean; cancelBubble: boolean; - readonly currentTarget: EventTarget; + readonly composed: boolean; + readonly currentTarget: EventTarget | null; readonly defaultPrevented: boolean; readonly eventPhase: number; readonly isTrusted: boolean; - returnValue: boolean; - readonly srcElement: Element | null; - readonly target: EventTarget; + readonly target: EventTarget | null; readonly timeStamp: number; readonly type: string; readonly scoped: boolean; - initEvent(eventTypeArg: string, canBubbleArg: boolean, cancelableArg: boolean): void; + composedPath(): EventTarget[]; + initEvent(type: string, bubbles?: boolean, cancelable?: boolean): void; preventDefault(): void; stopImmediatePropagation(): void; stopPropagation(): void; @@ -3671,74 +3531,61 @@ interface Event { readonly AT_TARGET: number; readonly BUBBLING_PHASE: number; readonly CAPTURING_PHASE: number; + readonly NONE: number; } declare var Event: { prototype: Event; - new(typeArg: string, eventInitDict?: EventInit): Event; + new(type: string, eventInitDict?: EventInit): Event; readonly AT_TARGET: number; readonly BUBBLING_PHASE: number; readonly CAPTURING_PHASE: number; + readonly NONE: number; }; -interface EventTarget { - addEventListener(type: string, listener?: EventListenerOrEventListenerObject, options?: boolean | AddEventListenerOptions): void; - dispatchEvent(evt: Event): boolean; - removeEventListener(type: string, listener?: EventListenerOrEventListenerObject, options?: boolean | EventListenerOptions): void; -} - -declare var EventTarget: { - prototype: EventTarget; - new(): EventTarget; -}; - -interface EXT_frag_depth { -} - -declare var EXT_frag_depth: { - prototype: EXT_frag_depth; - new(): EXT_frag_depth; -}; - -interface EXT_texture_filter_anisotropic { - readonly MAX_TEXTURE_MAX_ANISOTROPY_EXT: number; - readonly TEXTURE_MAX_ANISOTROPY_EXT: number; +interface EventSourceEventMap { + "error": Event; + "message": MessageEvent; + "open": Event; } -declare var EXT_texture_filter_anisotropic: { - prototype: EXT_texture_filter_anisotropic; - new(): EXT_texture_filter_anisotropic; - readonly MAX_TEXTURE_MAX_ANISOTROPY_EXT: number; - readonly TEXTURE_MAX_ANISOTROPY_EXT: number; -}; - -interface ExtensionScriptApis { - extensionIdToShortId(extensionId: string): number; - fireExtensionApiTelemetry(functionName: string, isSucceeded: boolean, isSupported: boolean): void; - genericFunction(routerAddress: any, parameters?: string, callbackId?: number): void; - genericSynchronousFunction(functionId: number, parameters?: string): string; - getExtensionId(): string; - registerGenericFunctionCallbackHandler(callbackHandler: any): void; - registerGenericPersistentCallbackHandler(callbackHandler: any): void; +interface EventSource extends EventTarget { + onerror: (this: EventSource, ev: Event) => any; + onmessage: (this: EventSource, ev: MessageEvent) => any; + onopen: (this: EventSource, ev: Event) => any; + readonly readyState: number; + readonly url: string; + readonly withCredentials: boolean; + close(): void; + readonly CLOSED: number; + readonly CONNECTING: number; + readonly OPEN: number; + addEventListener(type: K, listener: (this: EventSource, ev: EventSourceEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } -declare var ExtensionScriptApis: { - prototype: ExtensionScriptApis; - new(): ExtensionScriptApis; +declare var EventSource: { + prototype: EventSource; + new(url: string, eventSourceInitDict?: EventSourceInit): EventSource; + readonly CLOSED: number; + readonly CONNECTING: number; + readonly OPEN: number; }; -interface External { +interface EventTarget { + addEventListener(type: string, callback: EventListener | null, options?: AddEventListenerOptions | boolean): void; + dispatchEvent(event: Event): boolean; + removeEventListener(type: string, callback: EventListener | null, options?: EventListenerOptions | boolean): void; } -declare var External: { - prototype: External; - new(): External; +declare var EventTarget: { + prototype: EventTarget; + new(): EventTarget; }; interface File extends Blob { - readonly lastModifiedDate: any; + readonly lastModified: number; readonly name: string; - readonly webkitRelativePath: string; } declare var File: { @@ -3748,7 +3595,7 @@ declare var File: { interface FileList { readonly length: number; - item(index: number): File; + item(index: number): File | null; [index: number]: File; } @@ -3757,52 +3604,63 @@ declare var FileList: { new(): FileList; }; -interface FileReader extends EventTarget, MSBaseReader { - readonly error: DOMError; +interface FileReaderEventMap { + "abort": ProgressEvent; + "error": ProgressEvent; + "load": ProgressEvent; + "loadend": ProgressEvent; + "loadstart": ProgressEvent; + "progress": ProgressEvent; +} + +interface FileReader extends EventTarget { + readonly error: DOMException | null; + onabort: (this: FileReader, ev: ProgressEvent) => any; + onerror: (this: FileReader, ev: ProgressEvent) => any; + onload: (this: FileReader, ev: ProgressEvent) => any; + onloadend: (this: FileReader, ev: ProgressEvent) => any; + onloadstart: (this: FileReader, ev: ProgressEvent) => any; + onprogress: (this: FileReader, ev: ProgressEvent) => any; + readonly readyState: number; + readonly result: string | ArrayBuffer | null; + abort(): void; readAsArrayBuffer(blob: Blob): void; readAsBinaryString(blob: Blob): void; readAsDataURL(blob: Blob): void; - readAsText(blob: Blob, encoding?: string): void; - addEventListener(type: K, listener: (this: FileReader, ev: MSBaseReaderEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + readAsText(blob: Blob, label?: string): void; + readonly DONE: number; + readonly EMPTY: number; + readonly LOADING: number; + addEventListener(type: K, listener: (this: FileReader, ev: FileReaderEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var FileReader: { prototype: FileReader; new(): FileReader; + readonly DONE: number; + readonly EMPTY: number; + readonly LOADING: number; }; interface FocusEvent extends UIEvent { - readonly relatedTarget: EventTarget; - initFocusEvent(typeArg: string, canBubbleArg: boolean, cancelableArg: boolean, viewArg: Window, detailArg: number, relatedTargetArg: EventTarget): void; + readonly relatedTarget: EventTarget | null; } declare var FocusEvent: { prototype: FocusEvent; - new(typeArg: string, eventInitDict?: FocusEventInit): FocusEvent; -}; - -interface FocusNavigationEvent extends Event { - readonly navigationReason: NavigationReason; - readonly originHeight: number; - readonly originLeft: number; - readonly originTop: number; - readonly originWidth: number; - requestFocus(): void; -} - -declare var FocusNavigationEvent: { - prototype: FocusNavigationEvent; - new(type: string, eventInitDict?: FocusNavigationEventInit): FocusNavigationEvent; + new(type: string, eventInitDict?: FocusEventInit): FocusEvent; }; interface FormData { - append(name: string, value: string | Blob, fileName?: string): void; + append(name: string, value: string): void; + append(name: string, blobValue: Blob, filename?: string): void; delete(name: string): void; get(name: string): FormDataEntryValue | null; getAll(name: string): FormDataEntryValue[]; has(name: string): boolean; - set(name: string, value: string | Blob, fileName?: string): void; + set(name: string, value: string): void; + set(name: string, blobValue: Blob, filename?: string): void; } declare var FormData: { @@ -3816,16 +3674,16 @@ interface GainNode extends AudioNode { declare var GainNode: { prototype: GainNode; - new(): GainNode; + new(context: BaseAudioContext, options?: GainOptions): GainNode; }; interface Gamepad { - readonly axes: number[]; - readonly buttons: GamepadButton[]; + readonly axes: ReadonlyArray; + readonly buttons: ReadonlyArray; readonly connected: boolean; readonly id: string; readonly index: number; - readonly mapping: string; + readonly mapping: GamepadMappingType; readonly timestamp: number; } @@ -3836,6 +3694,7 @@ declare var Gamepad: { interface GamepadButton { readonly pressed: boolean; + readonly touched: boolean; readonly value: number; } @@ -3850,34 +3709,22 @@ interface GamepadEvent extends Event { declare var GamepadEvent: { prototype: GamepadEvent; - new(typeArg: string, eventInitDict?: GamepadEventInit): GamepadEvent; -}; - -interface Geolocation { - clearWatch(watchId: number): void; - getCurrentPosition(successCallback: PositionCallback, errorCallback?: PositionErrorCallback, options?: PositionOptions): void; - watchPosition(successCallback: PositionCallback, errorCallback?: PositionErrorCallback, options?: PositionOptions): number; -} - -declare var Geolocation: { - prototype: Geolocation; - new(): Geolocation; + new(type: string, eventInitDict: GamepadEventInit): GamepadEvent; }; interface HashChangeEvent extends Event { - readonly newURL: string | null; - readonly oldURL: string | null; + readonly newURL: string; + readonly oldURL: string; } declare var HashChangeEvent: { prototype: HashChangeEvent; - new(typeArg: string, eventInitDict?: HashChangeEventInit): HashChangeEvent; + new(type: string, eventInitDict?: HashChangeEventInit): HashChangeEvent; }; interface Headers { append(name: string, value: string): void; delete(name: string): void; - forEach(callback: ForEachCallback): void; get(name: string): string | null; has(name: string): boolean; set(name: string, value: string): void; @@ -3885,13 +3732,13 @@ interface Headers { declare var Headers: { prototype: Headers; - new(init?: Headers | string[][] | object): Headers; + new(init?: HeadersInit): Headers; }; interface History { readonly length: number; - readonly state: any; scrollRestoration: ScrollRestoration; + readonly state: any; back(): void; forward(): void; go(delta?: number): void; @@ -3916,7 +3763,7 @@ declare var HTMLAllCollection: { new(): HTMLAllCollection; }; -interface HTMLAnchorElement extends HTMLElement { +interface HTMLAnchorElement extends HTMLElement, HTMLHyperlinkElementUtils { /** * Sets or retrieves the character set used to encode the object. */ @@ -3926,58 +3773,25 @@ interface HTMLAnchorElement extends HTMLElement { */ coords: string; download: string; - /** - * Contains the anchor portion of the URL including the hash sign (#). - */ - hash: string; - /** - * Contains the hostname and port values of the URL. - */ - host: string; - /** - * Contains the hostname of a URL. - */ - hostname: string; - /** - * Sets or retrieves a destination URL or an anchor point. - */ - href: string; /** * Sets or retrieves the language code of the object. */ hreflang: string; - Methods: string; - readonly mimeType: string; /** * Sets or retrieves the shape of the object. */ name: string; - readonly nameProp: string; - /** - * Contains the pathname of the URL. - */ - pathname: string; - /** - * Sets or retrieves the port number associated with a URL. - */ - port: string; - /** - * Contains the protocol of the URL. - */ - protocol: string; - readonly protocolLong: string; + ping: string; + referrerPolicy: string; /** * Sets or retrieves the relationship between the object and the destination of the link. */ rel: string; + readonly relList: DOMTokenList; /** * Sets or retrieves the relationship between the object and the destination of the link. */ rev: string; - /** - * Sets or retrieves the substring of the href property that follows the question mark. - */ - search: string; /** * Sets or retrieves the shape of the object. */ @@ -3991,13 +3805,10 @@ interface HTMLAnchorElement extends HTMLElement { */ text: string; type: string; - urn: string; - /** - * Returns a string representation of an object. - */ - toString(): string; - addEventListener(type: K, listener: (this: HTMLAnchorElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLAnchorElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLAnchorElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLAnchorElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLAnchorElement: { @@ -4011,41 +3822,15 @@ interface HTMLAppletElement extends HTMLElement { * Sets or retrieves a text alternative to the graphic. */ alt: string; - /** - * Gets or sets the optional alternative HTML script to execute if the object fails to load. - */ - altHtml: string; /** * Sets or retrieves a character string that can be used to implement your own archive functionality for the object. */ archive: string; - /** - * Retrieves a string of the URL where the object tag can be found. This is often the href of the document that the object is in, or the value set by a base element. - */ - readonly BaseHref: string; - border: string; code: string; /** * Sets or retrieves the URL of the component. */ codeBase: string; - /** - * Sets or retrieves the Internet media type for the code associated with the object. - */ - codeType: string; - /** - * Address of a pointer to the document this page or frame contains. If there is no document, then null will be returned. - */ - readonly contentDocument: Document; - /** - * Sets or retrieves the URL that references the data of the object. - */ - data: string; - /** - * Sets or retrieves a character string that can be used to implement your own declare functionality for the object. - */ - declare: boolean; - readonly form: HTMLFormElement | null; /** * Sets or retrieves the height of the object. */ @@ -4055,23 +3840,13 @@ interface HTMLAppletElement extends HTMLElement { * Sets or retrieves the shape of the object. */ name: string; - object: string | null; - /** - * Sets or retrieves a message to be displayed while an object is loading. - */ - standby: string; - /** - * Returns the content type of the object. - */ - type: string; - /** - * Sets or retrieves the URL, often with a bookmark extension (#name), to use as a client-side image map. - */ - useMap: string; + object: string; vspace: number; - width: number; - addEventListener(type: K, listener: (this: HTMLAppletElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + width: string; + addEventListener(type: K, listener: (this: HTMLAppletElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLAppletElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLAppletElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLAppletElement: { @@ -4079,7 +3854,7 @@ declare var HTMLAppletElement: { new(): HTMLAppletElement; }; -interface HTMLAreaElement extends HTMLElement { +interface HTMLAreaElement extends HTMLElement, HTMLHyperlinkElementUtils { /** * Sets or retrieves a text alternative to the graphic. */ @@ -4089,57 +3864,26 @@ interface HTMLAreaElement extends HTMLElement { */ coords: string; download: string; - /** - * Sets or retrieves the subsection of the href property that follows the number sign (#). - */ - hash: string; - /** - * Sets or retrieves the hostname and port number of the location or URL. - */ - host: string; - /** - * Sets or retrieves the host name part of the location or URL. - */ - hostname: string; - /** - * Sets or retrieves a destination URL or an anchor point. - */ - href: string; /** * Sets or gets whether clicks in this region cause action. */ noHref: boolean; + ping: string; + referrerPolicy: string; + rel: string; + readonly relList: DOMTokenList; /** - * Sets or retrieves the file name or path specified by the object. - */ - pathname: string; - /** - * Sets or retrieves the port number associated with a URL. + * Sets or retrieves the shape of the object. */ - port: string; + shape: string; /** - * Sets or retrieves the protocol portion of a URL. - */ - protocol: string; - rel: string; - /** - * Sets or retrieves the substring of the href property that follows the question mark. - */ - search: string; - /** - * Sets or retrieves the shape of the object. - */ - shape: string; - /** - * Sets or retrieves the window or frame at which to target content. + * Sets or retrieves the window or frame at which to target content. */ target: string; - /** - * Returns a string representation of an object. - */ - toString(): string; - addEventListener(type: K, listener: (this: HTMLAreaElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLAreaElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLAreaElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLAreaElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLAreaElement: { @@ -4147,17 +3891,9 @@ declare var HTMLAreaElement: { new(): HTMLAreaElement; }; -interface HTMLAreasCollection extends HTMLCollectionBase { -} - -declare var HTMLAreasCollection: { - prototype: HTMLAreasCollection; - new(): HTMLAreasCollection; -}; - interface HTMLAudioElement extends HTMLMediaElement { addEventListener(type: K, listener: (this: HTMLAudioElement, ev: HTMLMediaElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLAudioElement: { @@ -4174,8 +3910,10 @@ interface HTMLBaseElement extends HTMLElement { * Sets or retrieves the window or frame at which to target content. */ target: string; - addEventListener(type: K, listener: (this: HTMLBaseElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLBaseElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLBaseElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLBaseElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLBaseElement: { @@ -4183,76 +3921,18 @@ declare var HTMLBaseElement: { new(): HTMLBaseElement; }; -interface HTMLBaseFontElement extends HTMLElement, DOML2DeprecatedColorProperty { - /** - * Sets or retrieves the current typeface family. - */ - face: string; - /** - * Sets or retrieves the font size of the object. - */ - size: number; - addEventListener(type: K, listener: (this: HTMLBaseFontElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; -} - -declare var HTMLBaseFontElement: { - prototype: HTMLBaseFontElement; - new(): HTMLBaseFontElement; -}; - -interface HTMLBodyElementEventMap extends HTMLElementEventMap { - "afterprint": Event; - "beforeprint": Event; - "beforeunload": BeforeUnloadEvent; - "blur": FocusEvent; - "error": ErrorEvent; - "focus": FocusEvent; - "hashchange": HashChangeEvent; - "load": Event; - "message": MessageEvent; - "offline": Event; - "online": Event; - "orientationchange": Event; - "pagehide": PageTransitionEvent; - "pageshow": PageTransitionEvent; - "popstate": PopStateEvent; - "resize": UIEvent; - "scroll": UIEvent; - "storage": StorageEvent; - "unload": Event; -} - -interface HTMLBodyElement extends HTMLElement { - aLink: any; +interface HTMLBodyElement extends HTMLElement, WindowEventHandlers { + aLink: string; background: string; - bgColor: any; - bgProperties: string; - link: any; - noWrap: boolean; - onafterprint: (this: HTMLBodyElement, ev: Event) => any; - onbeforeprint: (this: HTMLBodyElement, ev: Event) => any; - onbeforeunload: (this: HTMLBodyElement, ev: BeforeUnloadEvent) => any; - onblur: (this: HTMLBodyElement, ev: FocusEvent) => any; - onerror: (this: HTMLBodyElement, ev: ErrorEvent) => any; - onfocus: (this: HTMLBodyElement, ev: FocusEvent) => any; - onhashchange: (this: HTMLBodyElement, ev: HashChangeEvent) => any; - onload: (this: HTMLBodyElement, ev: Event) => any; - onmessage: (this: HTMLBodyElement, ev: MessageEvent) => any; - onoffline: (this: HTMLBodyElement, ev: Event) => any; - ononline: (this: HTMLBodyElement, ev: Event) => any; - onorientationchange: (this: HTMLBodyElement, ev: Event) => any; - onpagehide: (this: HTMLBodyElement, ev: PageTransitionEvent) => any; - onpageshow: (this: HTMLBodyElement, ev: PageTransitionEvent) => any; - onpopstate: (this: HTMLBodyElement, ev: PopStateEvent) => any; - onresize: (this: HTMLBodyElement, ev: UIEvent) => any; - onscroll: (this: HTMLBodyElement, ev: UIEvent) => any; - onstorage: (this: HTMLBodyElement, ev: StorageEvent) => any; - onunload: (this: HTMLBodyElement, ev: Event) => any; - text: any; - vLink: any; - addEventListener(type: K, listener: (this: HTMLBodyElement, ev: HTMLBodyElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + bgColor: string; + link: string; + text: string; + vLink: string; + addEventListener(type: K, listener: (this: HTMLBodyElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLBodyElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLBodyElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLBodyElement, ev: WindowEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLBodyElement: { @@ -4265,8 +3945,10 @@ interface HTMLBRElement extends HTMLElement { * Sets or retrieves the side on which floating objects are not to be positioned when any IHTMLBlockElement is inserted into the document. */ clear: string; - addEventListener(type: K, listener: (this: HTMLBRElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLBRElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLBRElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLBRElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLBRElement: { @@ -4299,16 +3981,16 @@ interface HTMLButtonElement extends HTMLElement { /** * Overrides any validation or required attributes on a form or form elements to allow it to be submitted without validation. This can be used to create a "save draft"-type submit option. */ - formNoValidate: string; + formNoValidate: boolean; /** * Overrides the target attribute on a form element. */ formTarget: string; + readonly labels: NodeList; /** * Sets or retrieves the name of the object. */ name: string; - status: any; /** * Gets the classification and default behavior of the button. */ @@ -4333,13 +4015,16 @@ interface HTMLButtonElement extends HTMLElement { * Returns whether a form will validate when it is submitted, without having to submit it. */ checkValidity(): boolean; + reportValidity(): boolean; /** * Sets a custom error message that is displayed when a form is submitted. * @param error Sets a custom error message that is displayed when a form is submitted. */ setCustomValidity(error: string): void; - addEventListener(type: K, listener: (this: HTMLButtonElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLButtonElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLButtonElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLButtonElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLButtonElement: { @@ -4363,18 +4048,18 @@ interface HTMLCanvasElement extends HTMLElement { getContext(contextId: "2d", contextAttributes?: Canvas2DContextAttributes): CanvasRenderingContext2D | null; getContext(contextId: "webgl" | "experimental-webgl", contextAttributes?: WebGLContextAttributes): WebGLRenderingContext | null; getContext(contextId: string, contextAttributes?: {}): CanvasRenderingContext2D | WebGLRenderingContext | null; - /** - * Returns a blob object encoded as a Portable Network Graphics (PNG) format from a canvas image or drawing. - */ - msToBlob(): Blob; + toBlob(callback: BlobCallback, type?: string, quality?: any): void; /** * Returns the content of the current canvas as an image that you can use as a source for another canvas or an HTML element. * @param type The standard MIME type for the image format to return. If you do not specify this parameter, the default value is a PNG format image. */ - toDataURL(type?: string, ...args: any[]): string; + toDataURL(type?: string, quality?: any): string; + transferControlToOffscreen(): OffscreenCanvas; toBlob(callback: (result: Blob | null) => void, type?: string, ...arguments: any[]): void; - addEventListener(type: K, listener: (this: HTMLCanvasElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLCanvasElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLCanvasElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLCanvasElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLCanvasElement: { @@ -4408,8 +4093,10 @@ declare var HTMLCollection: { interface HTMLDataElement extends HTMLElement { value: string; - addEventListener(type: K, listener: (this: HTMLDataElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLDataElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLDataElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLDataElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLDataElement: { @@ -4419,8 +4106,10 @@ declare var HTMLDataElement: { interface HTMLDataListElement extends HTMLElement { options: HTMLCollectionOf; - addEventListener(type: K, listener: (this: HTMLDataListElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLDataListElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLDataListElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLDataListElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLDataListElement: { @@ -4428,10 +4117,42 @@ declare var HTMLDataListElement: { new(): HTMLDataListElement; }; +interface HTMLDetailsElement extends HTMLElement { + open: boolean; + addEventListener(type: K, listener: (this: HTMLDetailsElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLDetailsElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLDetailsElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; +} + +declare var HTMLDetailsElement: { + prototype: HTMLDetailsElement; + new(): HTMLDetailsElement; +}; + +interface HTMLDialogElement extends HTMLElement { + open: boolean; + returnValue: string; + close(returnValue?: string): void; + show(): void; + showModal(): void; + addEventListener(type: K, listener: (this: HTMLDialogElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLDialogElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLDialogElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; +} + +declare var HTMLDialogElement: { + prototype: HTMLDialogElement; + new(): HTMLDialogElement; +}; + interface HTMLDirectoryElement extends HTMLElement { compact: boolean; - addEventListener(type: K, listener: (this: HTMLDirectoryElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLDirectoryElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLDirectoryElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLDirectoryElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLDirectoryElement: { @@ -4444,12 +4165,10 @@ interface HTMLDivElement extends HTMLElement { * Sets or retrieves how the object is aligned with adjacent text. */ align: string; - /** - * Sets or retrieves whether the browser automatically performs wordwrap. - */ - noWrap: boolean; - addEventListener(type: K, listener: (this: HTMLDivElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLDivElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLDivElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLDivElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLDivElement: { @@ -4459,8 +4178,10 @@ declare var HTMLDivElement: { interface HTMLDListElement extends HTMLElement { compact: boolean; - addEventListener(type: K, listener: (this: HTMLDListElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLDListElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLDListElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLDListElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLDListElement: { @@ -4468,182 +4189,33 @@ declare var HTMLDListElement: { new(): HTMLDListElement; }; -interface HTMLDocument extends Document { - addEventListener(type: K, listener: (this: HTMLDocument, ev: DocumentEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; -} - -declare var HTMLDocument: { - prototype: HTMLDocument; - new(): HTMLDocument; -}; - -interface HTMLElementEventMap extends ElementEventMap { - "abort": UIEvent; - "activate": UIEvent; - "beforeactivate": UIEvent; - "beforecopy": ClipboardEvent; - "beforecut": ClipboardEvent; - "beforedeactivate": UIEvent; - "beforepaste": ClipboardEvent; - "blur": FocusEvent; - "canplay": Event; - "canplaythrough": Event; - "change": Event; - "click": MouseEvent; - "contextmenu": PointerEvent; - "copy": ClipboardEvent; - "cuechange": Event; - "cut": ClipboardEvent; - "dblclick": MouseEvent; - "deactivate": UIEvent; - "drag": DragEvent; - "dragend": DragEvent; - "dragenter": DragEvent; - "dragleave": DragEvent; - "dragover": DragEvent; - "dragstart": DragEvent; - "drop": DragEvent; - "durationchange": Event; - "emptied": Event; - "ended": MediaStreamErrorEvent; - "error": ErrorEvent; - "focus": FocusEvent; - "input": Event; - "invalid": Event; - "keydown": KeyboardEvent; - "keypress": KeyboardEvent; - "keyup": KeyboardEvent; - "load": Event; - "loadeddata": Event; - "loadedmetadata": Event; - "loadstart": Event; - "mousedown": MouseEvent; - "mouseenter": MouseEvent; - "mouseleave": MouseEvent; - "mousemove": MouseEvent; - "mouseout": MouseEvent; - "mouseover": MouseEvent; - "mouseup": MouseEvent; - "mousewheel": WheelEvent; - "MSContentZoom": UIEvent; - "MSManipulationStateChanged": MSManipulationEvent; - "paste": ClipboardEvent; - "pause": Event; - "play": Event; - "playing": Event; - "progress": ProgressEvent; - "ratechange": Event; - "reset": Event; - "scroll": UIEvent; - "seeked": Event; - "seeking": Event; - "select": UIEvent; - "selectstart": Event; - "stalled": Event; - "submit": Event; - "suspend": Event; - "timeupdate": Event; - "volumechange": Event; - "waiting": Event; -} - -interface HTMLElement extends Element { +interface HTMLElement extends Element, GlobalEventHandlers, DocumentAndElementEventHandlers, ElementContentEditable, ElementCSSInlineStyle { accessKey: string; - readonly children: HTMLCollection; - contentEditable: string; + readonly accessKeyLabel: string; + contextMenu: HTMLMenuElement | null; readonly dataset: DOMStringMap; dir: string; draggable: boolean; hidden: boolean; - hideFocus: boolean; innerText: string; - readonly isContentEditable: boolean; lang: string; readonly offsetHeight: number; readonly offsetLeft: number; - readonly offsetParent: Element; + readonly offsetParent: Element | null; readonly offsetTop: number; readonly offsetWidth: number; - onabort: (this: HTMLElement, ev: UIEvent) => any; - onactivate: (this: HTMLElement, ev: UIEvent) => any; - onbeforeactivate: (this: HTMLElement, ev: UIEvent) => any; - onbeforecopy: (this: HTMLElement, ev: ClipboardEvent) => any; - onbeforecut: (this: HTMLElement, ev: ClipboardEvent) => any; - onbeforedeactivate: (this: HTMLElement, ev: UIEvent) => any; - onbeforepaste: (this: HTMLElement, ev: ClipboardEvent) => any; - onblur: (this: HTMLElement, ev: FocusEvent) => any; - oncanplay: (this: HTMLElement, ev: Event) => any; - oncanplaythrough: (this: HTMLElement, ev: Event) => any; - onchange: (this: HTMLElement, ev: Event) => any; - onclick: (this: HTMLElement, ev: MouseEvent) => any; - oncontextmenu: (this: HTMLElement, ev: PointerEvent) => any; - oncopy: (this: HTMLElement, ev: ClipboardEvent) => any; - oncuechange: (this: HTMLElement, ev: Event) => any; - oncut: (this: HTMLElement, ev: ClipboardEvent) => any; - ondblclick: (this: HTMLElement, ev: MouseEvent) => any; - ondeactivate: (this: HTMLElement, ev: UIEvent) => any; - ondrag: (this: HTMLElement, ev: DragEvent) => any; - ondragend: (this: HTMLElement, ev: DragEvent) => any; - ondragenter: (this: HTMLElement, ev: DragEvent) => any; - ondragleave: (this: HTMLElement, ev: DragEvent) => any; - ondragover: (this: HTMLElement, ev: DragEvent) => any; - ondragstart: (this: HTMLElement, ev: DragEvent) => any; - ondrop: (this: HTMLElement, ev: DragEvent) => any; - ondurationchange: (this: HTMLElement, ev: Event) => any; - onemptied: (this: HTMLElement, ev: Event) => any; - onended: (this: HTMLElement, ev: MediaStreamErrorEvent) => any; - onerror: (this: HTMLElement, ev: ErrorEvent) => any; - onfocus: (this: HTMLElement, ev: FocusEvent) => any; - oninput: (this: HTMLElement, ev: Event) => any; - oninvalid: (this: HTMLElement, ev: Event) => any; - onkeydown: (this: HTMLElement, ev: KeyboardEvent) => any; - onkeypress: (this: HTMLElement, ev: KeyboardEvent) => any; - onkeyup: (this: HTMLElement, ev: KeyboardEvent) => any; - onload: (this: HTMLElement, ev: Event) => any; - onloadeddata: (this: HTMLElement, ev: Event) => any; - onloadedmetadata: (this: HTMLElement, ev: Event) => any; - onloadstart: (this: HTMLElement, ev: Event) => any; - onmousedown: (this: HTMLElement, ev: MouseEvent) => any; - onmouseenter: (this: HTMLElement, ev: MouseEvent) => any; - onmouseleave: (this: HTMLElement, ev: MouseEvent) => any; - onmousemove: (this: HTMLElement, ev: MouseEvent) => any; - onmouseout: (this: HTMLElement, ev: MouseEvent) => any; - onmouseover: (this: HTMLElement, ev: MouseEvent) => any; - onmouseup: (this: HTMLElement, ev: MouseEvent) => any; - onmousewheel: (this: HTMLElement, ev: WheelEvent) => any; - onmscontentzoom: (this: HTMLElement, ev: UIEvent) => any; - onmsmanipulationstatechanged: (this: HTMLElement, ev: MSManipulationEvent) => any; - onpaste: (this: HTMLElement, ev: ClipboardEvent) => any; - onpause: (this: HTMLElement, ev: Event) => any; - onplay: (this: HTMLElement, ev: Event) => any; - onplaying: (this: HTMLElement, ev: Event) => any; - onprogress: (this: HTMLElement, ev: ProgressEvent) => any; - onratechange: (this: HTMLElement, ev: Event) => any; - onreset: (this: HTMLElement, ev: Event) => any; - onscroll: (this: HTMLElement, ev: UIEvent) => any; - onseeked: (this: HTMLElement, ev: Event) => any; - onseeking: (this: HTMLElement, ev: Event) => any; - onselect: (this: HTMLElement, ev: UIEvent) => any; - onselectstart: (this: HTMLElement, ev: Event) => any; - onstalled: (this: HTMLElement, ev: Event) => any; - onsubmit: (this: HTMLElement, ev: Event) => any; - onsuspend: (this: HTMLElement, ev: Event) => any; - ontimeupdate: (this: HTMLElement, ev: Event) => any; - onvolumechange: (this: HTMLElement, ev: Event) => any; - onwaiting: (this: HTMLElement, ev: Event) => any; - outerText: string; spellcheck: boolean; - readonly style: CSSStyleDeclaration; tabIndex: number; title: string; + translate: boolean; blur(): void; click(): void; - dragDrop(): boolean; focus(): void; - msGetInputContext(): MSInputMethodContext; - addEventListener(type: K, listener: (this: HTMLElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + forceSpellCheck(): void; + addEventListener(type: K, listener: (this: HTMLElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLElement: { @@ -4651,55 +4223,30 @@ declare var HTMLElement: { new(): HTMLElement; }; -interface HTMLEmbedElement extends HTMLElement, GetSVGDocument { +interface HTMLEmbedElement extends HTMLElement { + align: string; /** * Sets or retrieves the height of the object. */ height: string; - hidden: any; - /** - * Gets or sets whether the DLNA PlayTo device is available. - */ - msPlayToDisabled: boolean; - /** - * Gets or sets the path to the preferred media source. This enables the Play To target device to stream the media content, which can be DRM protected, from a different location, such as a cloud media server. - */ - msPlayToPreferredSourceUri: string; - /** - * Gets or sets the primary DLNA PlayTo device. - */ - msPlayToPrimary: boolean; - /** - * Gets the source associated with the media element for use by the PlayToManager. - */ - readonly msPlayToSource: any; /** * Sets or retrieves the name of the object. */ name: string; - /** - * Retrieves the palette used for the embedded document. - */ - readonly palette: string; - /** - * Retrieves the URL of the plug-in used to view an embedded document. - */ - readonly pluginspage: string; - readonly readyState: string; /** * Sets or retrieves a URL to be loaded by the object. */ src: string; - /** - * Sets or retrieves the height and width units of the embed object. - */ - units: string; + type: string; /** * Sets or retrieves the width of the object. */ width: string; - addEventListener(type: K, listener: (this: HTMLEmbedElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + getSVGDocument(): Document | null; + addEventListener(type: K, listener: (this: HTMLEmbedElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLEmbedElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLEmbedElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLEmbedElement: { @@ -4708,16 +4255,14 @@ declare var HTMLEmbedElement: { }; interface HTMLFieldSetElement extends HTMLElement { - /** - * Sets or retrieves how the object is aligned with adjacent text. - */ - align: string; disabled: boolean; + readonly elements: HTMLCollection; /** * Retrieves a reference to the form that the object is embedded in. */ readonly form: HTMLFormElement | null; name: string; + readonly type: string; /** * Returns the error message that would be displayed if the user submits the form, or an empty string if no error message. It also triggers the standard error message, such as "this is a required field". The result is that the user sees validation messages without actually submitting. */ @@ -4734,13 +4279,16 @@ interface HTMLFieldSetElement extends HTMLElement { * Returns whether a form will validate when it is submitted, without having to submit it. */ checkValidity(): boolean; + reportValidity(): boolean; /** * Sets a custom error message that is displayed when a form is submitted. * @param error Sets a custom error message that is displayed when a form is submitted. */ setCustomValidity(error: string): void; - addEventListener(type: K, listener: (this: HTMLFieldSetElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLFieldSetElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLFieldSetElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLFieldSetElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLFieldSetElement: { @@ -4748,13 +4296,17 @@ declare var HTMLFieldSetElement: { new(): HTMLFieldSetElement; }; -interface HTMLFontElement extends HTMLElement, DOML2DeprecatedColorProperty, DOML2DeprecatedSizeProperty { +interface HTMLFontElement extends HTMLElement { + color: string; /** * Sets or retrieves the current typeface family. */ face: string; - addEventListener(type: K, listener: (this: HTMLFontElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + size: string; + addEventListener(type: K, listener: (this: HTMLFontElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLFontElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLFontElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLFontElement: { @@ -4763,7 +4315,7 @@ declare var HTMLFontElement: { }; interface HTMLFormControlsCollection extends HTMLCollectionBase { - namedItem(name: string): HTMLCollection | Element | null; + namedItem(name: string): RadioNodeList | Element | null; } declare var HTMLFormControlsCollection: { @@ -4820,16 +4372,7 @@ interface HTMLFormElement extends HTMLElement { * Returns whether a form will validate when it is submitted, without having to submit it. */ checkValidity(): boolean; - /** - * Retrieves a form object or an object from an elements collection. - * @param name Variant of type Number or String that specifies the object or collection to retrieve. If this parameter is a Number, it is the zero-based index of the object. If this parameter is a string, all objects with matching name or id properties are retrieved, and a collection is returned if more than one match is made. - * @param index Variant of type Number that specifies the zero-based index of the object to retrieve when a collection is returned. - */ - item(name?: any, index?: any): any; - /** - * Retrieves a form object or an object from an elements collection. - */ - namedItem(name: string): any; + reportValidity(): boolean; /** * Fires when the user resets a form. */ @@ -4838,9 +4381,11 @@ interface HTMLFormElement extends HTMLElement { * Fires when a FORM is about to be submitted. */ submit(): void; - addEventListener(type: K, listener: (this: HTMLFormElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; - [name: string]: any; + addEventListener(type: K, listener: (this: HTMLFormElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLFormElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLFormElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; + [index: number]: Element; } declare var HTMLFormElement: { @@ -4848,39 +4393,19 @@ declare var HTMLFormElement: { new(): HTMLFormElement; }; -interface HTMLFrameElementEventMap extends HTMLElementEventMap { - "load": Event; -} - -interface HTMLFrameElement extends HTMLElement, GetSVGDocument { - /** - * Specifies the properties of a border drawn around an object. - */ - border: string; - /** - * Sets or retrieves the border color of the object. - */ - borderColor: any; +interface HTMLFrameElement extends HTMLElement { /** * Retrieves the document object of the page or frame. */ - readonly contentDocument: Document; + readonly contentDocument: Document | null; /** * Retrieves the object of the specified. */ - readonly contentWindow: Window; + readonly contentWindow: Window | null; /** * Sets or retrieves whether to display a border for the frame. */ frameBorder: string; - /** - * Sets or retrieves the amount of additional space between the frames. - */ - frameSpacing: any; - /** - * Sets or retrieves the height of the object. - */ - height: string | number; /** * Sets or retrieves a URI to a long description of the object. */ @@ -4901,10 +4426,6 @@ interface HTMLFrameElement extends HTMLElement, GetSVGDocument { * Sets or retrieves whether the user can resize the frame. */ noResize: boolean; - /** - * Raised when the object has been completely received from the server. - */ - onload: (this: HTMLFrameElement, ev: Event) => any; /** * Sets or retrieves whether the frame can be scrolled. */ @@ -4913,12 +4434,10 @@ interface HTMLFrameElement extends HTMLElement, GetSVGDocument { * Sets or retrieves a URL to be loaded by the object. */ src: string; - /** - * Sets or retrieves the width of the object. - */ - width: string | number; - addEventListener(type: K, listener: (this: HTMLFrameElement, ev: HTMLFrameElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLFrameElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLFrameElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLFrameElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLFrameElement: { @@ -4926,78 +4445,20 @@ declare var HTMLFrameElement: { new(): HTMLFrameElement; }; -interface HTMLFrameSetElementEventMap extends HTMLElementEventMap { - "afterprint": Event; - "beforeprint": Event; - "beforeunload": BeforeUnloadEvent; - "blur": FocusEvent; - "error": ErrorEvent; - "focus": FocusEvent; - "hashchange": HashChangeEvent; - "load": Event; - "message": MessageEvent; - "offline": Event; - "online": Event; - "orientationchange": Event; - "pagehide": PageTransitionEvent; - "pageshow": PageTransitionEvent; - "popstate": PopStateEvent; - "resize": UIEvent; - "scroll": UIEvent; - "storage": StorageEvent; - "unload": Event; -} - -interface HTMLFrameSetElement extends HTMLElement { - border: string; - /** - * Sets or retrieves the border color of the object. - */ - borderColor: any; +interface HTMLFrameSetElement extends HTMLElement, WindowEventHandlers { /** * Sets or retrieves the frame widths of the object. */ cols: string; - /** - * Sets or retrieves whether to display a border for the frame. - */ - frameBorder: string; - /** - * Sets or retrieves the amount of additional space between the frames. - */ - frameSpacing: any; - name: string; - onafterprint: (this: HTMLFrameSetElement, ev: Event) => any; - onbeforeprint: (this: HTMLFrameSetElement, ev: Event) => any; - onbeforeunload: (this: HTMLFrameSetElement, ev: BeforeUnloadEvent) => any; - /** - * Fires when the object loses the input focus. - */ - onblur: (this: HTMLFrameSetElement, ev: FocusEvent) => any; - onerror: (this: HTMLFrameSetElement, ev: ErrorEvent) => any; - /** - * Fires when the object receives focus. - */ - onfocus: (this: HTMLFrameSetElement, ev: FocusEvent) => any; - onhashchange: (this: HTMLFrameSetElement, ev: HashChangeEvent) => any; - onload: (this: HTMLFrameSetElement, ev: Event) => any; - onmessage: (this: HTMLFrameSetElement, ev: MessageEvent) => any; - onoffline: (this: HTMLFrameSetElement, ev: Event) => any; - ononline: (this: HTMLFrameSetElement, ev: Event) => any; - onorientationchange: (this: HTMLFrameSetElement, ev: Event) => any; - onpagehide: (this: HTMLFrameSetElement, ev: PageTransitionEvent) => any; - onpageshow: (this: HTMLFrameSetElement, ev: PageTransitionEvent) => any; - onpopstate: (this: HTMLFrameSetElement, ev: PopStateEvent) => any; - onresize: (this: HTMLFrameSetElement, ev: UIEvent) => any; - onscroll: (this: HTMLFrameSetElement, ev: UIEvent) => any; - onstorage: (this: HTMLFrameSetElement, ev: StorageEvent) => any; - onunload: (this: HTMLFrameSetElement, ev: Event) => any; /** * Sets or retrieves the frame heights of the object. */ rows: string; - addEventListener(type: K, listener: (this: HTMLFrameSetElement, ev: HTMLFrameSetElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLFrameSetElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLFrameSetElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLFrameSetElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLFrameSetElement, ev: WindowEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLFrameSetElement: { @@ -5006,9 +4467,10 @@ declare var HTMLFrameSetElement: { }; interface HTMLHeadElement extends HTMLElement { - profile: string; - addEventListener(type: K, listener: (this: HTMLHeadElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLHeadElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLHeadElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLHeadElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLHeadElement: { @@ -5021,8 +4483,10 @@ interface HTMLHeadingElement extends HTMLElement { * Sets or retrieves a value that indicates the table alignment. */ align: string; - addEventListener(type: K, listener: (this: HTMLHeadingElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLHeadingElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLHeadingElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLHeadingElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLHeadingElement: { @@ -5030,21 +4494,25 @@ declare var HTMLHeadingElement: { new(): HTMLHeadingElement; }; -interface HTMLHRElement extends HTMLElement, DOML2DeprecatedColorProperty, DOML2DeprecatedSizeProperty { +interface HTMLHRElement extends HTMLElement { /** * Sets or retrieves how the object is aligned with adjacent text. */ align: string; + color: string; /** * Sets or retrieves whether the horizontal rule is drawn with 3-D shading. */ noShade: boolean; + size: string; /** * Sets or retrieves the width of the object. */ - width: number; - addEventListener(type: K, listener: (this: HTMLHRElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + width: string; + addEventListener(type: K, listener: (this: HTMLHRElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLHRElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLHRElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLHRElement: { @@ -5057,8 +4525,10 @@ interface HTMLHtmlElement extends HTMLElement { * Sets or retrieves the DTD version that governs the current document. */ version: string; - addEventListener(type: K, listener: (this: HTMLHtmlElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLHtmlElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLHtmlElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLHtmlElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLHtmlElement: { @@ -5066,45 +4536,30 @@ declare var HTMLHtmlElement: { new(): HTMLHtmlElement; }; -interface HTMLIFrameElementEventMap extends HTMLElementEventMap { - "load": Event; -} - -interface HTMLIFrameElement extends HTMLElement, GetSVGDocument { +interface HTMLIFrameElement extends HTMLElement { /** * Sets or retrieves how the object is aligned with adjacent text. */ align: string; allowFullscreen: boolean; allowPaymentRequest: boolean; - /** - * Specifies the properties of a border drawn around an object. - */ - border: string; + allowUserMedia: boolean; /** * Retrieves the document object of the page or frame. */ - readonly contentDocument: Document; + readonly contentDocument: Document | null; /** * Retrieves the object of the specified. */ - readonly contentWindow: Window; + readonly contentWindow: Window | null; /** * Sets or retrieves whether to display a border for the frame. */ frameBorder: string; - /** - * Sets or retrieves the amount of additional space between the frames. - */ - frameSpacing: any; /** * Sets or retrieves the height of the object. */ height: string; - /** - * Sets or retrieves the horizontal margin for the object. - */ - hspace: number; /** * Sets or retrieves a URI to a long description of the object. */ @@ -5121,15 +4576,8 @@ interface HTMLIFrameElement extends HTMLElement, GetSVGDocument { * Sets or retrieves the frame name. */ name: string; - /** - * Sets or retrieves whether the user can resize the frame. - */ - noResize: boolean; - /** - * Raised when the object has been completely received from the server. - */ - onload: (this: HTMLIFrameElement, ev: Event) => any; - readonly sandbox: DOMSettableTokenList; + referrerPolicy: string; + readonly sandbox: DOMTokenList; /** * Sets or retrieves whether the frame can be scrolled. */ @@ -5138,16 +4586,16 @@ interface HTMLIFrameElement extends HTMLElement, GetSVGDocument { * Sets or retrieves a URL to be loaded by the object. */ src: string; - /** - * Sets or retrieves the vertical margin for the object. - */ - vspace: number; + srcdoc: string; /** * Sets or retrieves the width of the object. */ width: string; - addEventListener(type: K, listener: (this: HTMLIFrameElement, ev: HTMLIFrameElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + getSVGDocument(): Document | null; + addEventListener(type: K, listener: (this: HTMLIFrameElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLIFrameElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLIFrameElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLIFrameElement: { @@ -5191,19 +4639,6 @@ interface HTMLImageElement extends HTMLElement { */ longDesc: string; lowsrc: string; - /** - * Gets or sets whether the DLNA PlayTo device is available. - */ - msPlayToDisabled: boolean; - msPlayToPreferredSourceUri: string; - /** - * Gets or sets the primary DLNA PlayTo device. - */ - msPlayToPrimary: boolean; - /** - * Gets the source associated with the media element for use by the PlayToManager. - */ - readonly msPlayToSource: any; /** * Sets or retrieves the name of the object. */ @@ -5216,6 +4651,7 @@ interface HTMLImageElement extends HTMLElement { * The original width of the image resource before sizing. */ readonly naturalWidth: number; + referrerPolicy: string; sizes: string; /** * The address or URL of the a media resource that is to be considered. @@ -5236,9 +4672,10 @@ interface HTMLImageElement extends HTMLElement { width: number; readonly x: number; readonly y: number; - msGetAsCastingSource(): any; - addEventListener(type: K, listener: (this: HTMLImageElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLImageElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLImageElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLImageElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLImageElement: { @@ -5267,18 +4704,10 @@ interface HTMLInputElement extends HTMLElement { * Provides a way to direct a user to a specific field when a document loads. This can provide both direction and convenience for a user, reducing the need to click or tab to a field when a page opens. This attribute is true when present on an element, and false when missing. */ autofocus: boolean; - /** - * Sets or retrieves the width of the border to draw around the object. - */ - border: string; /** * Sets or retrieves the state of the check box or radio button. */ checked: boolean; - /** - * Retrieves whether the object is fully loaded. - */ - readonly complete: boolean; /** * Sets or retrieves the state of the check box or radio button. */ @@ -5287,6 +4716,7 @@ interface HTMLInputElement extends HTMLElement { * Sets or retrieves the initial contents of the object. */ defaultValue: string; + dirName: string; disabled: boolean; /** * Returns a FileList object on a file type input object. @@ -5311,7 +4741,7 @@ interface HTMLInputElement extends HTMLElement { /** * Overrides any validation or required attributes on a form or form elements to allow it to be submitted without validation. This can be used to create a "save draft"-type submit option. */ - formNoValidate: string; + formNoValidate: boolean; /** * Overrides the target attribute on a form element. */ @@ -5319,16 +4749,14 @@ interface HTMLInputElement extends HTMLElement { /** * Sets or retrieves the height of the object. */ - height: string; - /** - * Sets or retrieves the width of the border to draw around the object. - */ - hspace: number; + height: number; indeterminate: boolean; + inputMode: string; + readonly labels: NodeList | null; /** * Specifies the ID of a pre-defined datalist of options for an input element. */ - readonly list: HTMLElement; + readonly list: HTMLElement | null; /** * Defines the maximum acceptable value for an input element with type="number".When used with the min and step attributes, lets you control the range and increment (such as only even numbers) that the user can enter into an input field. */ @@ -5341,6 +4769,7 @@ interface HTMLInputElement extends HTMLElement { * Defines the minimum acceptable value for an input element with type="number". When used with the max and step attributes, lets you control the range and increment (such as even numbers only) that the user can enter into an input field. */ min: string; + minLength: number; /** * Sets or retrieves the Boolean value indicating whether multiple items can be selected from a list. */ @@ -5362,21 +4791,20 @@ interface HTMLInputElement extends HTMLElement { * When present, marks an element that can't be submitted without a value. */ required: boolean; - selectionDirection: string; + selectionDirection: string | null; /** * Gets or sets the end position or offset of a text selection. */ - selectionEnd: number; + selectionEnd: number | null; /** * Gets or sets the starting position or offset of a text selection. */ - selectionStart: number; + selectionStart: number | null; size: number; /** * The address or URL of the a media resource that is to be considered. */ src: string; - status: boolean; /** * Defines an increment or jump between values that you want to allow the user to enter. When used with the max and min attributes, lets you control the range and increment (for example, allow only even numbers) that the user can enter into an input field. */ @@ -5401,29 +4829,24 @@ interface HTMLInputElement extends HTMLElement { * Returns the value of the data at the cursor's current position. */ value: string; - valueAsDate: Date; + valueAsDate: any; /** * Returns the input field value as a number. */ valueAsNumber: number; - /** - * Sets or retrieves the vertical margin for the object. - */ - vspace: number; - webkitdirectory: boolean; /** * Sets or retrieves the width of the object. */ - width: string; + width: number; /** * Returns whether an element will successfully validate based on forms validation rules and constraints. */ readonly willValidate: boolean; - minLength: number; /** * Returns whether a form will validate when it is submitted, without having to submit it. */ checkValidity(): boolean; + reportValidity(): boolean; /** * Makes the selection equal to the current object. */ @@ -5433,12 +4856,14 @@ interface HTMLInputElement extends HTMLElement { * @param error Sets a custom error message that is displayed when a form is submitted. */ setCustomValidity(error: string): void; + setRangeText(replacement: string): void; + setRangeText(replacement: string, start: number, end: number, selectionMode?: SelectionMode): void; /** * Sets the start and end positions of a selection in a text field. * @param start The offset into the text field for the start of the selection. * @param end The offset into the text field for the end of the selection. */ - setSelectionRange(start?: number, end?: number, direction?: string): void; + setSelectionRange(start: number, end: number, direction?: string): void; /** * Decrements a range input control's value by the value given by the Step attribute. If the optional parameter is used, it will decrement the input control's step value multiplied by the parameter's value. * @param n Value to decrement the value by. @@ -5449,8 +4874,10 @@ interface HTMLInputElement extends HTMLElement { * @param n Value to increment the value by. */ stepUp(n?: number): void; - addEventListener(type: K, listener: (this: HTMLInputElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLInputElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLInputElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLInputElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLInputElement: { @@ -5459,6 +4886,7 @@ declare var HTMLInputElement: { }; interface HTMLLabelElement extends HTMLElement { + readonly control: HTMLElement | null; /** * Retrieves a reference to the form that the object is embedded in. */ @@ -5467,8 +4895,10 @@ interface HTMLLabelElement extends HTMLElement { * Sets or retrieves the object to which the given label object is assigned. */ htmlFor: string; - addEventListener(type: K, listener: (this: HTMLLabelElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLLabelElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLLabelElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLLabelElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLLabelElement: { @@ -5485,8 +4915,10 @@ interface HTMLLegendElement extends HTMLElement { * Retrieves a reference to the form that the object is embedded in. */ readonly form: HTMLFormElement | null; - addEventListener(type: K, listener: (this: HTMLLegendElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLLegendElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLLegendElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLLegendElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLLegendElement: { @@ -5500,8 +4932,10 @@ interface HTMLLIElement extends HTMLElement { * Sets or retrieves the value of a list item. */ value: number; - addEventListener(type: K, listener: (this: HTMLLIElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLLIElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLLIElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLLIElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLLIElement: { @@ -5510,11 +4944,12 @@ declare var HTMLLIElement: { }; interface HTMLLinkElement extends HTMLElement, LinkStyle { + as: string; /** * Sets or retrieves the character set used to encode the object. */ charset: string; - disabled: boolean; + crossOrigin: string | null; /** * Sets or retrieves a destination URL or an anchor point. */ @@ -5523,18 +4958,24 @@ interface HTMLLinkElement extends HTMLElement, LinkStyle { * Sets or retrieves the language code of the object. */ hreflang: string; + integrity: string; /** * Sets or retrieves the media type. */ media: string; + nonce: string; + referrerPolicy: string; /** * Sets or retrieves the relationship between the object and the destination of the link. */ rel: string; + readonly relList: DOMTokenList; /** * Sets or retrieves the relationship between the object and the destination of the link. */ rev: string; + scope: string; + readonly sizes: DOMTokenList; /** * Sets or retrieves the window or frame at which to target content. */ @@ -5543,10 +4984,13 @@ interface HTMLLinkElement extends HTMLElement, LinkStyle { * Sets or retrieves the MIME type of the object. */ type: string; + useCache: boolean; + workerType: WorkerType; import?: Document; - integrity: string; - addEventListener(type: K, listener: (this: HTMLLinkElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLLinkElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLLinkElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLLinkElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLLinkElement: { @@ -5558,13 +5002,15 @@ interface HTMLMapElement extends HTMLElement { /** * Retrieves a collection of the area objects defined for the given map object. */ - readonly areas: HTMLAreasCollection; + readonly areas: HTMLCollection; /** * Sets or retrieves the name of the object. */ name: string; - addEventListener(type: K, listener: (this: HTMLMapElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLMapElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLMapElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLMapElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLMapElement: { @@ -5572,7 +5018,7 @@ declare var HTMLMapElement: { new(): HTMLMapElement; }; -interface HTMLMarqueeElementEventMap extends HTMLElementEventMap { +interface HTMLMarqueeElementEventMap extends ElementEventMap, GlobalEventHandlersEventMap, DocumentAndElementEventHandlersEventMap { "bounce": Event; "finish": Event; "start": Event; @@ -5580,7 +5026,7 @@ interface HTMLMarqueeElementEventMap extends HTMLElementEventMap { interface HTMLMarqueeElement extends HTMLElement { behavior: string; - bgColor: any; + bgColor: string; direction: string; height: string; hspace: number; @@ -5596,7 +5042,7 @@ interface HTMLMarqueeElement extends HTMLElement { start(): void; stop(): void; addEventListener(type: K, listener: (this: HTMLMarqueeElement, ev: HTMLMarqueeElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLMarqueeElement: { @@ -5604,9 +5050,9 @@ declare var HTMLMarqueeElement: { new(): HTMLMarqueeElement; }; -interface HTMLMediaElementEventMap extends HTMLElementEventMap { +interface HTMLMediaElementEventMap extends ElementEventMap, GlobalEventHandlersEventMap, DocumentAndElementEventHandlersEventMap { "encrypted": MediaEncryptedEvent; - "msneedkey": MSMediaKeyNeededEvent; + "waitingforkey": Event; } interface HTMLMediaElement extends HTMLElement { @@ -5651,45 +5097,12 @@ interface HTMLMediaElement extends HTMLElement { /** * Returns an object representing the current error state of the audio or video element. */ - readonly error: MediaError; + readonly error: MediaError | null; /** * Gets or sets a flag to specify whether playback should restart after it completes. */ loop: boolean; readonly mediaKeys: MediaKeys | null; - /** - * Specifies the purpose of the audio or video media, such as background audio or alerts. - */ - msAudioCategory: string; - /** - * Specifies the output device id that the audio will be sent to. - */ - msAudioDeviceType: string; - readonly msGraphicsTrustStatus: MSGraphicsTrust; - /** - * Gets the MSMediaKeys object, which is used for decrypting media data, that is associated with this media element. - */ - readonly msKeys: MSMediaKeys; - /** - * Gets or sets whether the DLNA PlayTo device is available. - */ - msPlayToDisabled: boolean; - /** - * Gets or sets the path to the preferred media source. This enables the Play To target device to stream the media content, which can be DRM protected, from a different location, such as a cloud media server. - */ - msPlayToPreferredSourceUri: string; - /** - * Gets or sets the primary DLNA PlayTo device. - */ - msPlayToPrimary: boolean; - /** - * Gets the source associated with the media element for use by the PlayToManager. - */ - readonly msPlayToSource: any; - /** - * Specifies whether or not to enable low-latency playback on the media element. - */ - msRealTime: boolean; /** * Gets or sets a flag that indicates whether the audio (either audio or the audio track on video media) is muted. */ @@ -5699,7 +5112,7 @@ interface HTMLMediaElement extends HTMLElement { */ readonly networkState: number; onencrypted: (this: HTMLMediaElement, ev: MediaEncryptedEvent) => any; - onmsneedkey: (this: HTMLMediaElement, ev: MSMediaKeyNeededEvent) => any; + onwaitingforkey: (this: HTMLMediaElement, ev: Event) => any; /** * Gets a flag that specifies whether playback is paused. */ @@ -5729,36 +5142,24 @@ interface HTMLMediaElement extends HTMLElement { * The address or URL of the a media resource that is to be considered. */ src: string; - srcObject: MediaStream | null; + srcObject: MediaProvider | null; readonly textTracks: TextTrackList; readonly videoTracks: VideoTrackList; /** * Gets or sets the volume level for audio portions of the media element. */ volume: number; - addTextTrack(kind: string, label?: string, language?: string): TextTrack; + addTextTrack(kind: TextTrackKind, label?: string, language?: string): TextTrack; /** * Returns a string that specifies whether the client can play a given media resource type. */ - canPlayType(type: string): string; + canPlayType(type: string): CanPlayTypeResult; + fastSeek(time: number): void; + getStartDate(): any; /** * Resets the audio or video object and loads a new media resource. */ load(): void; - /** - * Clears all effects from the media pipeline. - */ - msClearEffects(): void; - msGetAsCastingSource(): any; - /** - * Inserts the specified audio effect into media pipeline. - */ - msInsertAudioEffect(activatableClassId: string, effectRequired: boolean, config?: any): void; - msSetMediaKeys(mediaKeys: MSMediaKeys): void; - /** - * Specifies the media protection manager for a given media pipeline. - */ - msSetMediaProtectionManager(mediaProtectionManager?: any): void; /** * Pauses the current playback and sets paused to TRUE. This can be used to test whether the media is playing or paused. You can also use the pause or play events to tell whether the media is playing or not. */ @@ -5778,7 +5179,7 @@ interface HTMLMediaElement extends HTMLElement { readonly NETWORK_LOADING: number; readonly NETWORK_NO_SOURCE: number; addEventListener(type: K, listener: (this: HTMLMediaElement, ev: HTMLMediaElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLMediaElement: { @@ -5797,9 +5198,12 @@ declare var HTMLMediaElement: { interface HTMLMenuElement extends HTMLElement { compact: boolean; + label: string; type: string; - addEventListener(type: K, listener: (this: HTMLMenuElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLMenuElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLMenuElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLMenuElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLMenuElement: { @@ -5807,11 +5211,26 @@ declare var HTMLMenuElement: { new(): HTMLMenuElement; }; +interface HTMLMenuItemElement extends HTMLElement { + checked: boolean; + default: boolean; + disabled: boolean; + icon: string; + label: string; + radiogroup: string; + type: string; + addEventListener(type: K, listener: (this: HTMLMenuItemElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLMenuItemElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLMenuItemElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; +} + +declare var HTMLMenuItemElement: { + prototype: HTMLMenuItemElement; + new(): HTMLMenuItemElement; +}; + interface HTMLMetaElement extends HTMLElement { - /** - * Sets or retrieves the character set used to encode the object. - */ - charset: string; /** * Gets or sets meta-information to associate with httpEquiv or name. */ @@ -5828,12 +5247,10 @@ interface HTMLMetaElement extends HTMLElement { * Sets or retrieves a scheme to be used in interpreting the value of a property specified for the object. */ scheme: string; - /** - * Sets or retrieves the URL property that will be loaded after the specified time has elapsed. - */ - url: string; - addEventListener(type: K, listener: (this: HTMLMetaElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLMetaElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLMetaElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLMetaElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLMetaElement: { @@ -5843,13 +5260,16 @@ declare var HTMLMetaElement: { interface HTMLMeterElement extends HTMLElement { high: number; + readonly labels: NodeList; low: number; max: number; min: number; optimum: number; value: number; - addEventListener(type: K, listener: (this: HTMLMeterElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLMeterElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLMeterElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLMeterElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLMeterElement: { @@ -5866,8 +5286,10 @@ interface HTMLModElement extends HTMLElement { * Sets or retrieves the date and time of a modification to the object. */ dateTime: string; - addEventListener(type: K, listener: (this: HTMLModElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLModElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLModElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLModElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLModElement: { @@ -5875,24 +5297,12 @@ declare var HTMLModElement: { new(): HTMLModElement; }; -interface HTMLObjectElement extends HTMLElement, GetSVGDocument { +interface HTMLObjectElement extends HTMLElement { align: string; - /** - * Sets or retrieves a text alternative to the graphic. - */ - alt: string; - /** - * Gets or sets the optional alternative HTML script to execute if the object fails to load. - */ - altHtml: string; /** * Sets or retrieves a character string that can be used to implement your own archive functionality for the object. */ archive: string; - /** - * Retrieves a string of the URL where the object tag can be found. This is often the href of the document that the object is in, or the value set by a base element. - */ - readonly BaseHref: string; border: string; /** * Sets or retrieves the URL of the file containing the compiled Java class. @@ -5909,7 +5319,8 @@ interface HTMLObjectElement extends HTMLElement, GetSVGDocument { /** * Retrieves the document object of the page or frame. */ - readonly contentDocument: Document; + readonly contentDocument: Document | null; + readonly contentWindow: Window | null; /** * Sets or retrieves the URL that references the data of the object. */ @@ -5924,27 +5335,10 @@ interface HTMLObjectElement extends HTMLElement, GetSVGDocument { */ height: string; hspace: number; - /** - * Gets or sets whether the DLNA PlayTo device is available. - */ - msPlayToDisabled: boolean; - /** - * Gets or sets the path to the preferred media source. This enables the Play To target device to stream the media content, which can be DRM protected, from a different location, such as a cloud media server. - */ - msPlayToPreferredSourceUri: string; - /** - * Gets or sets the primary DLNA PlayTo device. - */ - msPlayToPrimary: boolean; - /** - * Gets the source associated with the media element for use by the PlayToManager. - */ - readonly msPlayToSource: any; /** * Sets or retrieves the name of the object. */ name: string; - readonly readyState: number; /** * Sets or retrieves a message to be displayed while an object is loading. */ @@ -5953,6 +5347,7 @@ interface HTMLObjectElement extends HTMLElement, GetSVGDocument { * Sets or retrieves the MIME type of the object. */ type: string; + typeMustMatch: boolean; /** * Sets or retrieves the URL, often with a bookmark extension (#name), to use as a client-side image map. */ @@ -5978,13 +5373,17 @@ interface HTMLObjectElement extends HTMLElement, GetSVGDocument { * Returns whether a form will validate when it is submitted, without having to submit it. */ checkValidity(): boolean; + getSVGDocument(): Document | null; + reportValidity(): boolean; /** * Sets a custom error message that is displayed when a form is submitted. * @param error Sets a custom error message that is displayed when a form is submitted. */ setCustomValidity(error: string): void; - addEventListener(type: K, listener: (this: HTMLObjectElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLObjectElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLObjectElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLObjectElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLObjectElement: { @@ -5994,13 +5393,16 @@ declare var HTMLObjectElement: { interface HTMLOListElement extends HTMLElement { compact: boolean; + reversed: boolean; /** * The starting number. */ start: number; type: string; - addEventListener(type: K, listener: (this: HTMLOListElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLOListElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLOListElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLOListElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLOListElement: { @@ -6009,37 +5411,15 @@ declare var HTMLOListElement: { }; interface HTMLOptGroupElement extends HTMLElement { - /** - * Sets or retrieves the status of an option. - */ - defaultSelected: boolean; disabled: boolean; - /** - * Retrieves a reference to the form that the object is embedded in. - */ - readonly form: HTMLFormElement | null; - /** - * Sets or retrieves the ordinal position of an option in a list box. - */ - readonly index: number; /** * Sets or retrieves a value that you can use to implement your own label functionality for the object. */ label: string; - /** - * Sets or retrieves whether the option in the list box is the default item. - */ - selected: boolean; - /** - * Sets or retrieves the text string specified by the option tag. - */ - readonly text: string; - /** - * Sets or retrieves the value which is returned to the server when the form control is submitted. - */ - value: string; - addEventListener(type: K, listener: (this: HTMLOptGroupElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLOptGroupElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLOptGroupElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLOptGroupElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLOptGroupElement: { @@ -6077,8 +5457,10 @@ interface HTMLOptionElement extends HTMLElement { * Sets or retrieves the value which is returned to the server when the form control is submitted. */ value: string; - addEventListener(type: K, listener: (this: HTMLOptionElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLOptionElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLOptionElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLOptionElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLOptionElement: { @@ -6101,7 +5483,8 @@ declare var HTMLOptionsCollection: { interface HTMLOutputElement extends HTMLElement { defaultValue: string; readonly form: HTMLFormElement | null; - readonly htmlFor: DOMSettableTokenList; + readonly htmlFor: DOMTokenList; + readonly labels: NodeList; name: string; readonly type: string; readonly validationMessage: string; @@ -6111,8 +5494,10 @@ interface HTMLOutputElement extends HTMLElement { checkValidity(): boolean; reportValidity(): boolean; setCustomValidity(error: string): void; - addEventListener(type: K, listener: (this: HTMLOutputElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLOutputElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLOutputElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLOutputElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLOutputElement: { @@ -6125,9 +5510,10 @@ interface HTMLParagraphElement extends HTMLElement { * Sets or retrieves how the object is aligned with adjacent text. */ align: string; - clear: string; - addEventListener(type: K, listener: (this: HTMLParagraphElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLParagraphElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLParagraphElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLParagraphElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLParagraphElement: { @@ -6152,8 +5538,10 @@ interface HTMLParamElement extends HTMLElement { * Sets or retrieves the data type of the value attribute. */ valueType: string; - addEventListener(type: K, listener: (this: HTMLParamElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLParamElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLParamElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLParamElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLParamElement: { @@ -6162,8 +5550,10 @@ declare var HTMLParamElement: { }; interface HTMLPictureElement extends HTMLElement { - addEventListener(type: K, listener: (this: HTMLPictureElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLPictureElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLPictureElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLPictureElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLPictureElement: { @@ -6176,8 +5566,10 @@ interface HTMLPreElement extends HTMLElement { * Sets or gets a value that you can use to implement your own width functionality for the object. */ width: number; - addEventListener(type: K, listener: (this: HTMLPreElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLPreElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLPreElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLPreElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLPreElement: { @@ -6186,10 +5578,7 @@ declare var HTMLPreElement: { }; interface HTMLProgressElement extends HTMLElement { - /** - * Retrieves a reference to the form that the object is embedded in. - */ - readonly form: HTMLFormElement | null; + readonly labels: NodeList; /** * Defines the maximum, or "done" value for a progress element. */ @@ -6202,8 +5591,10 @@ interface HTMLProgressElement extends HTMLElement { * Sets or gets the current value of a progress element. The value must be a non-negative number between 0 and the max value. */ value: number; - addEventListener(type: K, listener: (this: HTMLProgressElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLProgressElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLProgressElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLProgressElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLProgressElement: { @@ -6216,8 +5607,10 @@ interface HTMLQuoteElement extends HTMLElement { * Sets or retrieves reference information about the object. */ cite: string; - addEventListener(type: K, listener: (this: HTMLQuoteElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLQuoteElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLQuoteElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLQuoteElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLQuoteElement: { @@ -6244,6 +5637,9 @@ interface HTMLScriptElement extends HTMLElement { * Sets or retrieves the object that is bound to the event script. */ htmlFor: string; + integrity: string; + noModule: boolean; + nonce: string; /** * Retrieves the URL to an external file that contains the source code or data. */ @@ -6256,9 +5652,10 @@ interface HTMLScriptElement extends HTMLElement { * Sets or retrieves the MIME type for the associated scripting engine. */ type: string; - integrity: string; - addEventListener(type: K, listener: (this: HTMLScriptElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLScriptElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLScriptElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLScriptElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLScriptElement: { @@ -6267,6 +5664,7 @@ declare var HTMLScriptElement: { }; interface HTMLSelectElement extends HTMLElement { + autocomplete: string; /** * Provides a way to direct a user to a specific field when a document loads. This can provide both direction and convenience for a user, reducing the need to click or tab to a field when a page opens. This attribute is true when present on an element, and false when missing. */ @@ -6276,6 +5674,7 @@ interface HTMLSelectElement extends HTMLElement { * Retrieves a reference to the form that the object is embedded in. */ readonly form: HTMLFormElement | null; + readonly labels: NodeList; /** * Sets or retrieves the number of objects in a collection. */ @@ -6327,7 +5726,7 @@ interface HTMLSelectElement extends HTMLElement { * @param element Variant of type Number that specifies the index position in the collection where the element is placed. If no value is given, the method places the element at the end of the collection. * @param before Variant of type Object that specifies an element to insert before, or null to append the object to the collection. */ - add(element: HTMLElement, before?: HTMLElement | number): void; + add(element: HTMLOptionElement | HTMLOptGroupElement, before?: HTMLElement | number): void; /** * Returns whether a form will validate when it is submitted, without having to submit it. */ @@ -6337,25 +5736,33 @@ interface HTMLSelectElement extends HTMLElement { * @param name Variant of type Number or String that specifies the object or collection to retrieve. If this parameter is an integer, it is the zero-based index of the object. If this parameter is a string, all objects with matching name or id properties are retrieved, and a collection is returned if more than one match is made. * @param index Variant of type Number that specifies the zero-based index of the object to retrieve when a collection is returned. */ - item(name?: any, index?: any): any; + item(index: number): Element | null; /** * Retrieves a select object or an object from an options collection. * @param namedItem A String that specifies the name or id property of the object to retrieve. A collection is returned if more than one match is made. */ - namedItem(name: string): any; + namedItem(name: string): HTMLOptionElement | null; + /** + * Removes an element from the collection. + * @param index Number that specifies the zero-based index of the element to remove from the collection. + */ + remove(): void; /** * Removes an element from the collection. * @param index Number that specifies the zero-based index of the element to remove from the collection. */ - remove(index?: number): void; + remove(index: number): void; + reportValidity(): boolean; /** * Sets a custom error message that is displayed when a form is submitted. * @param error Sets a custom error message that is displayed when a form is submitted. */ setCustomValidity(error: string): void; - addEventListener(type: K, listener: (this: HTMLSelectElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; - [name: string]: any; + addEventListener(type: K, listener: (this: HTMLSelectElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLSelectElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLSelectElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; + [index: number]: Element; } declare var HTMLSelectElement: { @@ -6363,12 +5770,25 @@ declare var HTMLSelectElement: { new(): HTMLSelectElement; }; +interface HTMLSlotElement extends HTMLElement { + name: string; + assignedNodes(options?: AssignedNodesOptions): Node[]; + addEventListener(type: K, listener: (this: HTMLSlotElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLSlotElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLSlotElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; +} + +declare var HTMLSlotElement: { + prototype: HTMLSlotElement; + new(): HTMLSlotElement; +}; + interface HTMLSourceElement extends HTMLElement { /** * Gets or sets the intended media type of the media source. */ media: string; - msKeySystem: string; sizes: string; /** * The address or URL of the a media resource that is to be considered. @@ -6379,8 +5799,10 @@ interface HTMLSourceElement extends HTMLElement { * Gets or sets the MIME type of a media resource. */ type: string; - addEventListener(type: K, listener: (this: HTMLSourceElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLSourceElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLSourceElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLSourceElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLSourceElement: { @@ -6389,8 +5811,10 @@ declare var HTMLSourceElement: { }; interface HTMLSpanElement extends HTMLElement { - addEventListener(type: K, listener: (this: HTMLSpanElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLSpanElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLSpanElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLSpanElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLSpanElement: { @@ -6399,17 +5823,19 @@ declare var HTMLSpanElement: { }; interface HTMLStyleElement extends HTMLElement, LinkStyle { - disabled: boolean; /** * Sets or retrieves the media type. */ media: string; + nonce: string; /** * Retrieves the CSS language in which the style sheet is written. */ type: string; - addEventListener(type: K, listener: (this: HTMLStyleElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLStyleElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLStyleElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLStyleElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLStyleElement: { @@ -6422,12 +5848,10 @@ interface HTMLTableCaptionElement extends HTMLElement { * Sets or retrieves the alignment of the caption or legend. */ align: string; - /** - * Sets or retrieves whether the caption appears at the top or bottom of the table. - */ - vAlign: string; - addEventListener(type: K, listener: (this: HTMLTableCaptionElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLTableCaptionElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLTableCaptionElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLTableCaptionElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLTableCaptionElement: { @@ -6435,7 +5859,7 @@ declare var HTMLTableCaptionElement: { new(): HTMLTableCaptionElement; }; -interface HTMLTableCellElement extends HTMLElement, HTMLTableAlignment { +interface HTMLTableCellElement extends HTMLElement { /** * Sets or retrieves abbreviated text for the object. */ @@ -6448,11 +5872,13 @@ interface HTMLTableCellElement extends HTMLElement, HTMLTableAlignment { * Sets or retrieves a comma-delimited list of conceptual categories associated with the object. */ axis: string; - bgColor: any; + bgColor: string; /** * Retrieves the position of the object in the cells collection of a row. */ readonly cellIndex: number; + ch: string; + chOff: string; /** * Sets or retrieves the number columns in the table that the object should span. */ @@ -6464,7 +5890,7 @@ interface HTMLTableCellElement extends HTMLElement, HTMLTableAlignment { /** * Sets or retrieves the height of the object. */ - height: any; + height: string; /** * Sets or retrieves whether the browser automatically performs wordwrap. */ @@ -6477,12 +5903,15 @@ interface HTMLTableCellElement extends HTMLElement, HTMLTableAlignment { * Sets or retrieves the group of cells in a table to which the object's information applies. */ scope: string; + vAlign: string; /** * Sets or retrieves the width of the object. */ width: string; - addEventListener(type: K, listener: (this: HTMLTableCellElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLTableCellElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLTableCellElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLTableCellElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLTableCellElement: { @@ -6490,21 +5919,26 @@ declare var HTMLTableCellElement: { new(): HTMLTableCellElement; }; -interface HTMLTableColElement extends HTMLElement, HTMLTableAlignment { +interface HTMLTableColElement extends HTMLElement { /** * Sets or retrieves the alignment of the object relative to the display or table. */ align: string; + ch: string; + chOff: string; /** * Sets or retrieves the number of columns in the group. */ span: number; + vAlign: string; /** * Sets or retrieves the width of the object. */ - width: any; - addEventListener(type: K, listener: (this: HTMLTableColElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + width: string; + addEventListener(type: K, listener: (this: HTMLTableColElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLTableColElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLTableColElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLTableColElement: { @@ -6512,34 +5946,20 @@ declare var HTMLTableColElement: { new(): HTMLTableColElement; }; -interface HTMLTableDataCellElement extends HTMLTableCellElement { - addEventListener(type: K, listener: (this: HTMLTableDataCellElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; -} - -declare var HTMLTableDataCellElement: { - prototype: HTMLTableDataCellElement; - new(): HTMLTableDataCellElement; -}; - interface HTMLTableElement extends HTMLElement { /** * Sets or retrieves a value that indicates the table alignment. */ align: string; - bgColor: any; + bgColor: string; /** * Sets or retrieves the width of the border to draw around the object. */ border: string; - /** - * Sets or retrieves the border color of the object. - */ - borderColor: any; /** * Retrieves the caption object of a table. */ - caption: HTMLTableCaptionElement; + caption: HTMLTableCaptionElement | null; /** * Sets or retrieves the amount of space between the border of the cell and the content of the cell. */ @@ -6548,18 +5968,10 @@ interface HTMLTableElement extends HTMLElement { * Sets or retrieves the amount of space between cells in a table. */ cellSpacing: string; - /** - * Sets or retrieves the number of columns in the table. - */ - cols: number; /** * Sets or retrieves the way the border frame around the table is displayed. */ frame: string; - /** - * Sets or retrieves the height of the object. - */ - height: any; /** * Sets or retrieves the number of horizontal rows contained in the object. */ @@ -6579,11 +5991,11 @@ interface HTMLTableElement extends HTMLElement { /** * Retrieves the tFoot object of the table. */ - tFoot: HTMLTableSectionElement; + tFoot: HTMLTableSectionElement | null; /** * Retrieves the tHead object of the table. */ - tHead: HTMLTableSectionElement; + tHead: HTMLTableSectionElement | null; /** * Sets or retrieves the width of the object. */ @@ -6612,7 +6024,7 @@ interface HTMLTableElement extends HTMLElement { * Removes the specified row (tr) from the element and from the rows collection. * @param index Number that specifies the zero-based position in the rows collection of the row to remove. */ - deleteRow(index?: number): void; + deleteRow(index: number): void; /** * Deletes the tFoot element and its contents from the table. */ @@ -6626,8 +6038,10 @@ interface HTMLTableElement extends HTMLElement { * @param index Number that specifies where to insert the row in the rows collection. The default value is -1, which appends the new row to the end of the rows collection. */ insertRow(index?: number): HTMLTableRowElement; - addEventListener(type: K, listener: (this: HTMLTableElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLTableElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLTableElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLTableElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLTableElement: { @@ -6635,34 +6049,18 @@ declare var HTMLTableElement: { new(): HTMLTableElement; }; -interface HTMLTableHeaderCellElement extends HTMLTableCellElement { - /** - * Sets or retrieves the group of cells in a table to which the object's information applies. - */ - scope: string; - addEventListener(type: K, listener: (this: HTMLTableHeaderCellElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; -} - -declare var HTMLTableHeaderCellElement: { - prototype: HTMLTableHeaderCellElement; - new(): HTMLTableHeaderCellElement; -}; - -interface HTMLTableRowElement extends HTMLElement, HTMLTableAlignment { +interface HTMLTableRowElement extends HTMLElement { /** * Sets or retrieves how the object is aligned with adjacent text. */ align: string; - bgColor: any; + bgColor: string; /** * Retrieves a collection of all cells in the table row. */ - cells: HTMLCollectionOf; - /** - * Sets or retrieves the height of the object. - */ - height: any; + cells: HTMLCollectionOf; + ch: string; + chOff: string; /** * Retrieves the position of the object in the rows collection for the table. */ @@ -6671,18 +6069,21 @@ interface HTMLTableRowElement extends HTMLElement, HTMLTableAlignment { * Retrieves the position of the object in the collection. */ readonly sectionRowIndex: number; + vAlign: string; /** * Removes the specified cell from the table row, as well as from the cells collection. * @param index Number that specifies the zero-based position of the cell to remove from the table row. If no value is provided, the last cell in the cells collection is deleted. */ - deleteCell(index?: number): void; + deleteCell(index: number): void; /** * Creates a new cell in the table row, and adds the cell to the cells collection. * @param index Number that specifies where to insert the cell in the tr. The default value is -1, which appends the new cell to the end of the cells collection. */ - insertCell(index?: number): HTMLTableDataCellElement; - addEventListener(type: K, listener: (this: HTMLTableRowElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + insertCell(index?: number): HTMLTableCellElement; + addEventListener(type: K, listener: (this: HTMLTableRowElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLTableRowElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLTableRowElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLTableRowElement: { @@ -6690,27 +6091,32 @@ declare var HTMLTableRowElement: { new(): HTMLTableRowElement; }; -interface HTMLTableSectionElement extends HTMLElement, HTMLTableAlignment { +interface HTMLTableSectionElement extends HTMLElement { /** * Sets or retrieves a value that indicates the table alignment. */ align: string; + ch: string; + chOff: string; /** * Sets or retrieves the number of horizontal rows contained in the object. */ rows: HTMLCollectionOf; + vAlign: string; /** * Removes the specified row (tr) from the element and from the rows collection. * @param index Number that specifies the zero-based position in the rows collection of the row to remove. */ - deleteRow(index?: number): void; + deleteRow(index: number): void; /** * Creates a new row (tr) in the table, and adds the row to the rows collection. * @param index Number that specifies where to insert the row in the rows collection. The default value is -1, which appends the new row to the end of the rows collection. */ insertRow(index?: number): HTMLTableRowElement; - addEventListener(type: K, listener: (this: HTMLTableSectionElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLTableSectionElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLTableSectionElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLTableSectionElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLTableSectionElement: { @@ -6720,8 +6126,10 @@ declare var HTMLTableSectionElement: { interface HTMLTemplateElement extends HTMLElement { readonly content: DocumentFragment; - addEventListener(type: K, listener: (this: HTMLTemplateElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLTemplateElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLTemplateElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLTemplateElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLTemplateElement: { @@ -6730,6 +6138,7 @@ declare var HTMLTemplateElement: { }; interface HTMLTextAreaElement extends HTMLElement { + autocomplete: string; /** * Provides a way to direct a user to a specific field when a document loads. This can provide both direction and convenience for a user, reducing the need to click or tab to a field when a page opens. This attribute is true when present on an element, and false when missing. */ @@ -6742,15 +6151,19 @@ interface HTMLTextAreaElement extends HTMLElement { * Sets or retrieves the initial contents of the object. */ defaultValue: string; + dirName: string; disabled: boolean; /** * Retrieves a reference to the form that the object is embedded in. */ readonly form: HTMLFormElement | null; + inputMode: string; + readonly labels: NodeList; /** * Sets or retrieves the maximum number of characters that the user can enter in a text control. */ maxLength: number; + minLength: number; /** * Sets or retrieves the name of the object. */ @@ -6771,6 +6184,7 @@ interface HTMLTextAreaElement extends HTMLElement { * Sets or retrieves the number of horizontal rows contained in the object. */ rows: number; + selectionDirection: string; /** * Gets or sets the end position or offset of a text selection. */ @@ -6779,10 +6193,7 @@ interface HTMLTextAreaElement extends HTMLElement { * Gets or sets the starting position or offset of a text selection. */ selectionStart: number; - /** - * Sets or retrieves the value indicating whether the control is selected. - */ - status: any; + readonly textLength: number; /** * Retrieves the type of control. */ @@ -6807,11 +6218,11 @@ interface HTMLTextAreaElement extends HTMLElement { * Sets or retrieves how to handle wordwrapping in the object. */ wrap: string; - minLength: number; /** * Returns whether a form will validate when it is submitted, without having to submit it. */ checkValidity(): boolean; + reportValidity(): boolean; /** * Highlights the input area of a form element. */ @@ -6821,14 +6232,18 @@ interface HTMLTextAreaElement extends HTMLElement { * @param error Sets a custom error message that is displayed when a form is submitted. */ setCustomValidity(error: string): void; + setRangeText(replacement: string): void; + setRangeText(replacement: string, start: number, end: number, selectionMode?: SelectionMode): void; /** * Sets the start and end positions of a selection in a text field. * @param start The offset into the text field for the start of the selection. * @param end The offset into the text field for the end of the selection. */ - setSelectionRange(start: number, end: number): void; - addEventListener(type: K, listener: (this: HTMLTextAreaElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + setSelectionRange(start: number, end: number, direction?: string): void; + addEventListener(type: K, listener: (this: HTMLTextAreaElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLTextAreaElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLTextAreaElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLTextAreaElement: { @@ -6838,8 +6253,10 @@ declare var HTMLTextAreaElement: { interface HTMLTimeElement extends HTMLElement { dateTime: string; - addEventListener(type: K, listener: (this: HTMLTimeElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLTimeElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLTimeElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLTimeElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLTimeElement: { @@ -6852,8 +6269,10 @@ interface HTMLTitleElement extends HTMLElement { * Retrieves or sets the text of the object as a string. */ text: string; - addEventListener(type: K, listener: (this: HTMLTitleElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLTitleElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLTitleElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLTitleElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLTitleElement: { @@ -6873,8 +6292,10 @@ interface HTMLTrackElement extends HTMLElement { readonly LOADED: number; readonly LOADING: number; readonly NONE: number; - addEventListener(type: K, listener: (this: HTMLTrackElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLTrackElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLTrackElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLTrackElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLTrackElement: { @@ -6889,8 +6310,10 @@ declare var HTMLTrackElement: { interface HTMLUListElement extends HTMLElement { compact: boolean; type: string; - addEventListener(type: K, listener: (this: HTMLUListElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLUListElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLUListElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLUListElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLUListElement: { @@ -6899,8 +6322,10 @@ declare var HTMLUListElement: { }; interface HTMLUnknownElement extends HTMLElement { - addEventListener(type: K, listener: (this: HTMLUnknownElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLUnknownElement, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLUnknownElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLUnknownElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLUnknownElement: { @@ -6908,26 +6333,12 @@ declare var HTMLUnknownElement: { new(): HTMLUnknownElement; }; -interface HTMLVideoElementEventMap extends HTMLMediaElementEventMap { - "MSVideoFormatChanged": Event; - "MSVideoFrameStepCompleted": Event; - "MSVideoOptimalLayoutChanged": Event; -} - interface HTMLVideoElement extends HTMLMediaElement { /** * Gets or sets the height of the video element. */ height: number; - msHorizontalMirror: boolean; - readonly msIsLayoutOptimalForPlayback: boolean; - readonly msIsStereo3D: boolean; - msStereo3DPackingMode: string; - msStereo3DRenderMode: string; - msZoom: boolean; - onMSVideoFormatChanged: (this: HTMLVideoElement, ev: Event) => any; - onMSVideoFrameStepCompleted: (this: HTMLVideoElement, ev: Event) => any; - onMSVideoOptimalLayoutChanged: (this: HTMLVideoElement, ev: Event) => any; + playsInline: boolean; /** * Gets or sets a URL of an image to display, for example, like a movie poster. This can be a still frame from the video, or another image if no video data is available. */ @@ -6940,22 +6351,13 @@ interface HTMLVideoElement extends HTMLMediaElement { * Gets the intrinsic width of a video in CSS pixels, or zero if the dimensions are not known. */ readonly videoWidth: number; - readonly webkitDisplayingFullscreen: boolean; - readonly webkitSupportsFullscreen: boolean; /** * Gets or sets the width of the video element. */ width: number; getVideoPlaybackQuality(): VideoPlaybackQuality; - msFrameStep(forward: boolean): void; - msInsertVideoEffect(activatableClassId: string, effectRequired: boolean, config?: any): void; - msSetVideoRectangle(left: number, top: number, right: number, bottom: number): void; - webkitEnterFullscreen(): void; - webkitEnterFullScreen(): void; - webkitExitFullscreen(): void; - webkitExitFullScreen(): void; - addEventListener(type: K, listener: (this: HTMLVideoElement, ev: HTMLVideoElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: HTMLVideoElement, ev: HTMLMediaElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var HTMLVideoElement: { @@ -6970,21 +6372,14 @@ interface IDBCursor { source: IDBObjectStore | IDBIndex; advance(count: number): void; continue(key?: IDBKeyRange | IDBValidKey): void; + continuePrimaryKey(key: any, primaryKey: any): void; delete(): IDBRequest; update(value: any): IDBRequest; - readonly NEXT: string; - readonly NEXT_NO_DUPLICATE: string; - readonly PREV: string; - readonly PREV_NO_DUPLICATE: string; } declare var IDBCursor: { prototype: IDBCursor; new(): IDBCursor; - readonly NEXT: string; - readonly NEXT_NO_DUPLICATE: string; - readonly PREV: string; - readonly PREV_NO_DUPLICATE: string; }; interface IDBCursorWithValue extends IDBCursor { @@ -6998,23 +6393,26 @@ declare var IDBCursorWithValue: { interface IDBDatabaseEventMap { "abort": Event; + "close": Event; "error": Event; + "versionchange": IDBVersionChangeEvent; } interface IDBDatabase extends EventTarget { readonly name: string; readonly objectStoreNames: DOMStringList; onabort: (this: IDBDatabase, ev: Event) => any; + onclose: (this: IDBDatabase, ev: Event) => any; onerror: (this: IDBDatabase, ev: Event) => any; + onversionchange: (this: IDBDatabase, ev: IDBVersionChangeEvent) => any; version: number; - onversionchange: (ev: IDBVersionChangeEvent) => any; close(): void; createObjectStore(name: string, optionalParameters?: IDBObjectStoreParameters): IDBObjectStore; deleteObjectStore(name: string): void; transaction(storeNames: string | string[], mode?: IDBTransactionMode): IDBTransaction; addEventListener(type: "versionchange", listener: (ev: IDBVersionChangeEvent) => any, useCapture?: boolean): void; addEventListener(type: K, listener: (this: IDBDatabase, ev: IDBDatabaseEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var IDBDatabase: { @@ -7035,12 +6433,14 @@ declare var IDBFactory: { interface IDBIndex { keyPath: string | string[]; - readonly name: string; + readonly multiEntry: boolean; + name: string; readonly objectStore: IDBObjectStore; readonly unique: boolean; - multiEntry: boolean; count(key?: IDBKeyRange | IDBValidKey): IDBRequest; get(key: IDBKeyRange | IDBValidKey): IDBRequest; + getAll(query?: any, count?: number): IDBRequest; + getAllKeys(query?: any, count?: number): IDBRequest; getKey(key: IDBKeyRange | IDBValidKey): IDBRequest; openCursor(range?: IDBKeyRange | IDBValidKey, direction?: IDBCursorDirection): IDBRequest; openKeyCursor(range?: IDBKeyRange | IDBValidKey, direction?: IDBCursorDirection): IDBRequest; @@ -7056,6 +6456,7 @@ interface IDBKeyRange { readonly lowerOpen: boolean; readonly upper: any; readonly upperOpen: boolean; + includes(key: any): boolean; } declare var IDBKeyRange: { @@ -7068,20 +6469,24 @@ declare var IDBKeyRange: { }; interface IDBObjectStore { + readonly autoIncrement: boolean; readonly indexNames: DOMStringList; keyPath: string | string[]; - readonly name: string; + name: string; readonly transaction: IDBTransaction; - autoIncrement: boolean; add(value: any, key?: IDBKeyRange | IDBValidKey): IDBRequest; clear(): IDBRequest; count(key?: IDBKeyRange | IDBValidKey): IDBRequest; createIndex(name: string, keyPath: string | string[], optionalParameters?: IDBIndexParameters): IDBIndex; delete(key: IDBKeyRange | IDBValidKey): IDBRequest; - deleteIndex(indexName: string): void; - get(key: any): IDBRequest; + deleteIndex(name: string): void; + get(query: any): IDBRequest; + getAll(query?: any, count?: number): IDBRequest; + getAllKeys(query?: any, count?: number): IDBRequest; + getKey(query: any): IDBRequest; index(name: string): IDBIndex; openCursor(range?: IDBKeyRange | IDBValidKey, direction?: IDBCursorDirection): IDBRequest; + openKeyCursor(query?: any, direction?: IDBCursorDirection): IDBRequest; put(value: any, key?: IDBKeyRange | IDBValidKey): IDBRequest; } @@ -7099,7 +6504,7 @@ interface IDBOpenDBRequest extends IDBRequest { onblocked: (this: IDBOpenDBRequest, ev: Event) => any; onupgradeneeded: (this: IDBOpenDBRequest, ev: IDBVersionChangeEvent) => any; addEventListener(type: K, listener: (this: IDBOpenDBRequest, ev: IDBOpenDBRequestEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var IDBOpenDBRequest: { @@ -7119,9 +6524,9 @@ interface IDBRequest extends EventTarget { readonly readyState: IDBRequestReadyState; readonly result: any; source: IDBObjectStore | IDBIndex | IDBCursor; - readonly transaction: IDBTransaction; + readonly transaction: IDBTransaction | null; addEventListener(type: K, listener: (this: IDBRequest, ev: IDBRequestEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var IDBRequest: { @@ -7139,24 +6544,19 @@ interface IDBTransaction extends EventTarget { readonly db: IDBDatabase; readonly error: DOMException; readonly mode: IDBTransactionMode; + readonly objectStoreNames: DOMStringList; onabort: (this: IDBTransaction, ev: Event) => any; oncomplete: (this: IDBTransaction, ev: Event) => any; onerror: (this: IDBTransaction, ev: Event) => any; abort(): void; objectStore(name: string): IDBObjectStore; - readonly READ_ONLY: string; - readonly READ_WRITE: string; - readonly VERSION_CHANGE: string; addEventListener(type: K, listener: (this: IDBTransaction, ev: IDBTransactionEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var IDBTransaction: { prototype: IDBTransaction; new(): IDBTransaction; - readonly READ_ONLY: string; - readonly READ_WRITE: string; - readonly VERSION_CHANGE: string; }; interface IDBVersionChangeEvent extends Event { @@ -7166,7 +6566,7 @@ interface IDBVersionChangeEvent extends Event { declare var IDBVersionChangeEvent: { prototype: IDBVersionChangeEvent; - new(): IDBVersionChangeEvent; + new(type: string, eventInitDict?: IDBVersionChangeEventInit): IDBVersionChangeEvent; }; interface IIRFilterNode extends AudioNode { @@ -7175,7 +6575,28 @@ interface IIRFilterNode extends AudioNode { declare var IIRFilterNode: { prototype: IIRFilterNode; - new(): IIRFilterNode; + new(context: BaseAudioContext, options: IIRFilterOptions): IIRFilterNode; +}; + +interface ImageBitmap { + readonly height: number; + readonly width: number; + close(): void; +} + +declare var ImageBitmap: { + prototype: ImageBitmap; + new(): ImageBitmap; +}; + +interface ImageBitmapRenderingContext { + readonly canvas: HTMLCanvasElement; + transferFromImageBitmap(bitmap: ImageBitmap | null): void; +} + +declare var ImageBitmapRenderingContext: { + prototype: ImageBitmapRenderingContext; + new(): ImageBitmapRenderingContext; }; interface ImageData { @@ -7190,10 +6611,29 @@ declare var ImageData: { new(array: Uint8ClampedArray, width: number, height: number): ImageData; }; +interface InputDeviceInfo extends MediaDeviceInfo { + getCapabilities(): MediaTrackCapabilities; +} + +declare var InputDeviceInfo: { + prototype: InputDeviceInfo; + new(): InputDeviceInfo; +}; + +interface InputEvent extends UIEvent { + readonly data: string | null; + readonly isComposing: boolean; +} + +declare var InputEvent: { + prototype: InputEvent; + new(type: string, eventInitDict?: InputEventInit): InputEvent; +}; + interface IntersectionObserver { readonly root: Element | null; readonly rootMargin: string; - readonly thresholds: number[]; + readonly thresholds: ReadonlyArray; disconnect(): void; observe(target: Element): void; takeRecords(): IntersectionObserverEntry[]; @@ -7206,13 +6646,13 @@ declare var IntersectionObserver: { }; interface IntersectionObserverEntry { - readonly boundingClientRect: ClientRect; + readonly boundingClientRect: DOMRectReadOnly; readonly intersectionRatio: number; - readonly intersectionRect: ClientRect; - readonly rootBounds: ClientRect; + readonly intersectionRect: DOMRectReadOnly; + readonly isIntersecting: boolean; + readonly rootBounds: DOMRectReadOnly; readonly target: Element; readonly time: number; - readonly isIntersecting: boolean; } declare var IntersectionObserverEntry: { @@ -7222,23 +6662,16 @@ declare var IntersectionObserverEntry: { interface KeyboardEvent extends UIEvent { readonly altKey: boolean; - readonly char: string | null; - readonly charCode: number; + readonly code: string; readonly ctrlKey: boolean; + readonly isComposing: boolean; readonly key: string; - readonly keyCode: number; - readonly locale: string; readonly location: number; readonly metaKey: boolean; readonly repeat: boolean; readonly shiftKey: boolean; - readonly which: number; - readonly code: string; getModifierState(keyArg: string): boolean; - initKeyboardEvent(typeArg: string, canBubbleArg: boolean, cancelableArg: boolean, viewArg: Window, keyArg: string, locationArg: number, modifiersListArg: string, repeat: boolean, locale: string): void; - readonly DOM_KEY_LOCATION_JOYSTICK: number; readonly DOM_KEY_LOCATION_LEFT: number; - readonly DOM_KEY_LOCATION_MOBILE: number; readonly DOM_KEY_LOCATION_NUMPAD: number; readonly DOM_KEY_LOCATION_RIGHT: number; readonly DOM_KEY_LOCATION_STANDARD: number; @@ -7246,26 +6679,15 @@ interface KeyboardEvent extends UIEvent { declare var KeyboardEvent: { prototype: KeyboardEvent; - new(typeArg: string, eventInitDict?: KeyboardEventInit): KeyboardEvent; - readonly DOM_KEY_LOCATION_JOYSTICK: number; + new(type: string, eventInitDict?: KeyboardEventInit): KeyboardEvent; readonly DOM_KEY_LOCATION_LEFT: number; - readonly DOM_KEY_LOCATION_MOBILE: number; readonly DOM_KEY_LOCATION_NUMPAD: number; readonly DOM_KEY_LOCATION_RIGHT: number; readonly DOM_KEY_LOCATION_STANDARD: number; }; -interface ListeningStateChangedEvent extends Event { - readonly label: string; - readonly state: ListeningState; -} - -declare var ListeningStateChangedEvent: { - prototype: ListeningStateChangedEvent; - new(): ListeningStateChangedEvent; -}; - interface Location { + readonly ancestorOrigins: DOMStringList; hash: string; host: string; hostname: string; @@ -7276,9 +6698,8 @@ interface Location { protocol: string; search: string; assign(url: string): void; - reload(forcedReload?: boolean): void; + reload(): void; replace(url: string): void; - toString(): string; } declare var Location: { @@ -7286,16 +6707,6 @@ declare var Location: { new(): Location; }; -interface LongRunningScriptDetectedEvent extends Event { - readonly executionTime: number; - stopPageScriptExecution: boolean; -} - -declare var LongRunningScriptDetectedEvent: { - prototype: LongRunningScriptDetectedEvent; - new(): LongRunningScriptDetectedEvent; -}; - interface MediaDeviceInfo { readonly deviceId: string; readonly groupId: string; @@ -7316,9 +6727,9 @@ interface MediaDevices extends EventTarget { ondevicechange: (this: MediaDevices, ev: Event) => any; enumerateDevices(): Promise; getSupportedConstraints(): MediaTrackSupportedConstraints; - getUserMedia(constraints: MediaStreamConstraints): Promise; + getUserMedia(constraints?: MediaStreamConstraints): Promise; addEventListener(type: K, listener: (this: MediaDevices, ev: MediaDevicesEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var MediaDevices: { @@ -7331,7 +6742,7 @@ interface MediaElementAudioSourceNode extends AudioNode { declare var MediaElementAudioSourceNode: { prototype: MediaElementAudioSourceNode; - new(): MediaElementAudioSourceNode; + new(context: BaseAudioContext, options: MediaElementAudioSourceOptions): MediaElementAudioSourceNode; }; interface MediaEncryptedEvent extends Event { @@ -7346,12 +6757,11 @@ declare var MediaEncryptedEvent: { interface MediaError { readonly code: number; - readonly msExtendedCode: number; + readonly message: string; readonly MEDIA_ERR_ABORTED: number; readonly MEDIA_ERR_DECODE: number; readonly MEDIA_ERR_NETWORK: number; readonly MEDIA_ERR_SRC_NOT_SUPPORTED: number; - readonly MS_MEDIA_ERR_ENCRYPTED: number; } declare var MediaError: { @@ -7361,7 +6771,6 @@ declare var MediaError: { readonly MEDIA_ERR_DECODE: number; readonly MEDIA_ERR_NETWORK: number; readonly MEDIA_ERR_SRC_NOT_SUPPORTED: number; - readonly MS_MEDIA_ERR_ENCRYPTED: number; }; interface MediaKeyMessageEvent extends Event { @@ -7371,12 +6780,12 @@ interface MediaKeyMessageEvent extends Event { declare var MediaKeyMessageEvent: { prototype: MediaKeyMessageEvent; - new(type: string, eventInitDict?: MediaKeyMessageEventInit): MediaKeyMessageEvent; + new(type: string, eventInitDict: MediaKeyMessageEventInit): MediaKeyMessageEvent; }; interface MediaKeys { createSession(sessionType?: MediaKeySessionType): MediaKeySession; - setServerCertificate(serverCertificate: any): Promise; + setServerCertificate(serverCertificate: BufferSource): Promise; } declare var MediaKeys: { @@ -7384,16 +6793,25 @@ declare var MediaKeys: { new(): MediaKeys; }; +interface MediaKeySessionEventMap { + "keystatuseschange": Event; + "message": MediaKeyMessageEvent; +} + interface MediaKeySession extends EventTarget { readonly closed: Promise; readonly expiration: number; readonly keyStatuses: MediaKeyStatusMap; + onkeystatuseschange: (this: MediaKeySession, ev: Event) => any; + onmessage: (this: MediaKeySession, ev: MediaKeyMessageEvent) => any; readonly sessionId: string; close(): Promise; - generateRequest(initDataType: string, initData: any): Promise; + generateRequest(initDataType: string, initData: BufferSource): Promise; load(sessionId: string): Promise; remove(): Promise; - update(response: any): Promise; + update(response: BufferSource): Promise; + addEventListener(type: K, listener: (this: MediaKeySession, ev: MediaKeySessionEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var MediaKeySession: { @@ -7403,9 +6821,8 @@ declare var MediaKeySession: { interface MediaKeyStatusMap { readonly size: number; - forEach(callback: ForEachCallback): void; - get(keyId: any): MediaKeyStatus; - has(keyId: any): boolean; + get(keyId: BufferSource): any; + has(keyId: BufferSource): boolean; } declare var MediaKeyStatusMap: { @@ -7426,12 +6843,11 @@ declare var MediaKeySystemAccess: { interface MediaList { readonly length: number; - mediaText: string; - appendMedium(newMedium: string): void; - deleteMedium(oldMedium: string): void; - item(index: number): string; - toString(): string; - [index: number]: string; + mediaText: CSSOMString; + appendMedium(medium: CSSOMString): void; + deleteMedium(medium: CSSOMString): void; + item(index: number): CSSOMString | null; + [index: number]: CSSOMString; } declare var MediaList: { @@ -7439,11 +6855,18 @@ declare var MediaList: { new(): MediaList; }; -interface MediaQueryList { +interface MediaQueryListEventMap { + "change": Event; +} + +interface MediaQueryList extends EventTarget { readonly matches: boolean; readonly media: string; - addListener(listener: MediaQueryListListener): void; - removeListener(listener: MediaQueryListListener): void; + onchange: (this: MediaQueryList, ev: Event) => any; + addListener(listener: EventListener | null): void; + removeListener(listener: EventListener | null): void; + addEventListener(type: K, listener: (this: MediaQueryList, ev: MediaQueryListEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var MediaQueryList: { @@ -7451,14 +6874,37 @@ declare var MediaQueryList: { new(): MediaQueryList; }; +interface MediaQueryListEvent extends Event { + readonly matches: boolean; + readonly media: string; +} + +declare var MediaQueryListEvent: { + prototype: MediaQueryListEvent; + new(type: string, eventInitDict?: MediaQueryListEventInit): MediaQueryListEvent; +}; + +interface MediaSourceEventMap { + "sourceclose": Event; + "sourceended": Event; + "sourceopen": Event; +} + interface MediaSource extends EventTarget { readonly activeSourceBuffers: SourceBufferList; duration: number; - readonly readyState: string; + onsourceclose: (this: MediaSource, ev: Event) => any; + onsourceended: (this: MediaSource, ev: Event) => any; + onsourceopen: (this: MediaSource, ev: Event) => any; + readonly readyState: ReadyState; readonly sourceBuffers: SourceBufferList; addSourceBuffer(type: string): SourceBuffer; - endOfStream(error?: number): void; + clearLiveSeekableRange(): void; + endOfStream(error?: EndOfStreamError): void; removeSourceBuffer(sourceBuffer: SourceBuffer): void; + setLiveSeekableRange(start: number, end: number): void; + addEventListener(type: K, listener: (this: MediaSource, ev: MediaSourceEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var MediaSource: { @@ -7468,18 +6914,14 @@ declare var MediaSource: { }; interface MediaStreamEventMap { - "active": Event; "addtrack": MediaStreamTrackEvent; - "inactive": Event; "removetrack": MediaStreamTrackEvent; } interface MediaStream extends EventTarget { readonly active: boolean; readonly id: string; - onactive: (this: MediaStream, ev: Event) => any; onaddtrack: (this: MediaStream, ev: MediaStreamTrackEvent) => any; - oninactive: (this: MediaStream, ev: Event) => any; onremovetrack: (this: MediaStream, ev: MediaStreamTrackEvent) => any; addTrack(track: MediaStreamTrack): void; clone(): MediaStream; @@ -7488,81 +6930,63 @@ interface MediaStream extends EventTarget { getTracks(): MediaStreamTrack[]; getVideoTracks(): MediaStreamTrack[]; removeTrack(track: MediaStreamTrack): void; - stop(): void; addEventListener(type: K, listener: (this: MediaStream, ev: MediaStreamEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var MediaStream: { prototype: MediaStream; - new(streamOrTracks?: MediaStream | MediaStreamTrack[]): MediaStream; -}; - -interface MediaStreamAudioSourceNode extends AudioNode { -} - -declare var MediaStreamAudioSourceNode: { - prototype: MediaStreamAudioSourceNode; - new(): MediaStreamAudioSourceNode; -}; - -interface MediaStreamError { - readonly constraintName: string | null; - readonly message: string | null; - readonly name: string; -} - -declare var MediaStreamError: { - prototype: MediaStreamError; - new(): MediaStreamError; + new(): MediaStream; + new(stream: MediaStream): MediaStream; + new(tracks: MediaStreamTrack[]): MediaStream; }; -interface MediaStreamErrorEvent extends Event { - readonly error: MediaStreamError | null; +interface MediaStreamAudioDestinationNode extends AudioNode { + readonly stream: MediaStream; } -declare var MediaStreamErrorEvent: { - prototype: MediaStreamErrorEvent; - new(typeArg: string, eventInitDict?: MediaStreamErrorEventInit): MediaStreamErrorEvent; +declare var MediaStreamAudioDestinationNode: { + prototype: MediaStreamAudioDestinationNode; + new(context: BaseAudioContext, options?: AudioNodeOptions): MediaStreamAudioDestinationNode; }; -interface MediaStreamEvent extends Event { - readonly stream: MediaStream | null; +interface MediaStreamAudioSourceNode extends AudioNode { } -declare var MediaStreamEvent: { - prototype: MediaStreamEvent; - new(type: string, eventInitDict: MediaStreamEventInit): MediaStreamEvent; +declare var MediaStreamAudioSourceNode: { + prototype: MediaStreamAudioSourceNode; + new(context: BaseAudioContext, options: MediaStreamAudioSourceOptions): MediaStreamAudioSourceNode; }; interface MediaStreamTrackEventMap { - "ended": MediaStreamErrorEvent; + "ended": Event; + "isolationchange": Event; "mute": Event; - "overconstrained": MediaStreamErrorEvent; + "overconstrained": OverconstrainedErrorEvent; "unmute": Event; } interface MediaStreamTrack extends EventTarget { enabled: boolean; readonly id: string; + readonly isolated: boolean; readonly kind: string; readonly label: string; readonly muted: boolean; - onended: (this: MediaStreamTrack, ev: MediaStreamErrorEvent) => any; + onended: (this: MediaStreamTrack, ev: Event) => any; + onisolationchange: (this: MediaStreamTrack, ev: Event) => any; onmute: (this: MediaStreamTrack, ev: Event) => any; - onoverconstrained: (this: MediaStreamTrack, ev: MediaStreamErrorEvent) => any; + onoverconstrained: (this: MediaStreamTrack, ev: OverconstrainedErrorEvent) => any; onunmute: (this: MediaStreamTrack, ev: Event) => any; - readonly readonly: boolean; readonly readyState: MediaStreamTrackState; - readonly remote: boolean; - applyConstraints(constraints: MediaTrackConstraints): Promise; + applyConstraints(constraints?: MediaTrackConstraints): Promise; clone(): MediaStreamTrack; getCapabilities(): MediaTrackCapabilities; getConstraints(): MediaTrackConstraints; getSettings(): MediaTrackSettings; stop(): void; addEventListener(type: K, listener: (this: MediaStreamTrack, ev: MediaStreamTrackEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var MediaStreamTrack: { @@ -7570,13 +6994,21 @@ declare var MediaStreamTrack: { new(): MediaStreamTrack; }; +interface MediaStreamTrackAudioSourceNode extends AudioNode { +} + +declare var MediaStreamTrackAudioSourceNode: { + prototype: MediaStreamTrackAudioSourceNode; + new(context: AudioContext, options: MediaStreamTrackAudioSourceOptions): MediaStreamTrackAudioSourceNode; +}; + interface MediaStreamTrackEvent extends Event { readonly track: MediaStreamTrack; } declare var MediaStreamTrackEvent: { prototype: MediaStreamTrackEvent; - new(typeArg: string, eventInitDict?: MediaStreamTrackEventInit): MediaStreamTrackEvent; + new(type: string, eventInitDict: MediaStreamTrackEventInit): MediaStreamTrackEvent; }; interface MessageChannel { @@ -7591,10 +7023,11 @@ declare var MessageChannel: { interface MessageEvent extends Event { readonly data: any; + readonly lastEventId: string; readonly origin: string; - readonly ports: any; - readonly source: Window; - initMessageEvent(typeArg: string, canBubbleArg: boolean, cancelableArg: boolean, dataArg: any, originArg: string, lastEventIdArg: string, sourceArg: Window): void; + readonly ports: ReadonlyArray; + readonly source: MessageEventSource | null; + initMessageEvent(type: string, bubbles?: boolean, cancelable?: boolean, data?: any, origin?: string, lastEventId?: string, source?: MessageEventSource, ports?: MessagePort[]): void; } declare var MessageEvent: { @@ -7604,15 +7037,17 @@ declare var MessageEvent: { interface MessagePortEventMap { "message": MessageEvent; + "messageerror": MessageEvent; } interface MessagePort extends EventTarget { onmessage: (this: MessagePort, ev: MessageEvent) => any; + onmessageerror: (this: MessagePort, ev: MessageEvent) => any; close(): void; - postMessage(message?: any, transfer?: any[]): void; + postMessage(message: any, transfer?: any[]): void; start(): void; addEventListener(type: K, listener: (this: MessagePort, ev: MessagePortEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var MessagePort: { @@ -7634,9 +7069,9 @@ declare var MimeType: { interface MimeTypeArray { readonly length: number; - item(index: number): Plugin; - namedItem(type: string): Plugin; - [index: number]: Plugin; + item(index: number): MimeType | null; + namedItem(name: string): MimeType | null; + [index: number]: MimeType; } declare var MimeTypeArray: { @@ -7651,496 +7086,28 @@ interface MouseEvent extends UIEvent { readonly clientX: number; readonly clientY: number; readonly ctrlKey: boolean; - readonly fromElement: Element; - readonly layerX: number; - readonly layerY: number; readonly metaKey: boolean; - readonly movementX: number; - readonly movementY: number; readonly offsetX: number; readonly offsetY: number; readonly pageX: number; readonly pageY: number; - readonly relatedTarget: EventTarget; + readonly relatedTarget: EventTarget | null; readonly screenX: number; readonly screenY: number; readonly shiftKey: boolean; - readonly toElement: Element; - readonly which: number; readonly x: number; readonly y: number; getModifierState(keyArg: string): boolean; - initMouseEvent(typeArg: string, canBubbleArg: boolean, cancelableArg: boolean, viewArg: Window, detailArg: number, screenXArg: number, screenYArg: number, clientXArg: number, clientYArg: number, ctrlKeyArg: boolean, altKeyArg: boolean, shiftKeyArg: boolean, metaKeyArg: boolean, buttonArg: number, relatedTargetArg: EventTarget | null): void; } declare var MouseEvent: { prototype: MouseEvent; - new(typeArg: string, eventInitDict?: MouseEventInit): MouseEvent; -}; - -interface MSApp { - clearTemporaryWebDataAsync(): MSAppAsyncOperation; - createBlobFromRandomAccessStream(type: string, seeker: any): Blob; - createDataPackage(object: any): any; - createDataPackageFromSelection(): any; - createFileFromStorageFile(storageFile: any): File; - createStreamFromInputStream(type: string, inputStream: any): MSStream; - execAsyncAtPriority(asynchronousCallback: MSExecAtPriorityFunctionCallback, priority: string, ...args: any[]): void; - execAtPriority(synchronousCallback: MSExecAtPriorityFunctionCallback, priority: string, ...args: any[]): any; - getCurrentPriority(): string; - getHtmlPrintDocumentSourceAsync(htmlDoc: any): Promise; - getViewId(view: any): any; - isTaskScheduledAtPriorityOrHigher(priority: string): boolean; - pageHandlesAllApplicationActivations(enabled: boolean): void; - suppressSubdownloadCredentialPrompts(suppress: boolean): void; - terminateApp(exceptionObject: any): void; - readonly CURRENT: string; - readonly HIGH: string; - readonly IDLE: string; - readonly NORMAL: string; -} -declare var MSApp: MSApp; - -interface MSAppAsyncOperationEventMap { - "complete": Event; - "error": Event; -} - -interface MSAppAsyncOperation extends EventTarget { - readonly error: DOMError; - oncomplete: (this: MSAppAsyncOperation, ev: Event) => any; - onerror: (this: MSAppAsyncOperation, ev: Event) => any; - readonly readyState: number; - readonly result: any; - start(): void; - readonly COMPLETED: number; - readonly ERROR: number; - readonly STARTED: number; - addEventListener(type: K, listener: (this: MSAppAsyncOperation, ev: MSAppAsyncOperationEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; -} - -declare var MSAppAsyncOperation: { - prototype: MSAppAsyncOperation; - new(): MSAppAsyncOperation; - readonly COMPLETED: number; - readonly ERROR: number; - readonly STARTED: number; -}; - -interface MSAssertion { - readonly id: string; - readonly type: MSCredentialType; -} - -declare var MSAssertion: { - prototype: MSAssertion; - new(): MSAssertion; -}; - -interface MSBlobBuilder { - append(data: any, endings?: string): void; - getBlob(contentType?: string): Blob; -} - -declare var MSBlobBuilder: { - prototype: MSBlobBuilder; - new(): MSBlobBuilder; -}; - -interface MSCredentials { - getAssertion(challenge: string, filter?: MSCredentialFilter, params?: MSSignatureParameters): Promise; - makeCredential(accountInfo: MSAccountInfo, params: MSCredentialParameters[], challenge?: string): Promise; -} - -declare var MSCredentials: { - prototype: MSCredentials; - new(): MSCredentials; -}; - -interface MSFIDOCredentialAssertion extends MSAssertion { - readonly algorithm: string | Algorithm; - readonly attestation: any; - readonly publicKey: string; - readonly transportHints: MSTransportType[]; -} - -declare var MSFIDOCredentialAssertion: { - prototype: MSFIDOCredentialAssertion; - new(): MSFIDOCredentialAssertion; -}; - -interface MSFIDOSignature { - readonly authnrData: string; - readonly clientData: string; - readonly signature: string; -} - -declare var MSFIDOSignature: { - prototype: MSFIDOSignature; - new(): MSFIDOSignature; -}; - -interface MSFIDOSignatureAssertion extends MSAssertion { - readonly signature: MSFIDOSignature; -} - -declare var MSFIDOSignatureAssertion: { - prototype: MSFIDOSignatureAssertion; - new(): MSFIDOSignatureAssertion; -}; - -interface MSGesture { - target: Element; - addPointer(pointerId: number): void; - stop(): void; -} - -declare var MSGesture: { - prototype: MSGesture; - new(): MSGesture; -}; - -interface MSGestureEvent extends UIEvent { - readonly clientX: number; - readonly clientY: number; - readonly expansion: number; - readonly gestureObject: any; - readonly hwTimestamp: number; - readonly offsetX: number; - readonly offsetY: number; - readonly rotation: number; - readonly scale: number; - readonly screenX: number; - readonly screenY: number; - readonly translationX: number; - readonly translationY: number; - readonly velocityAngular: number; - readonly velocityExpansion: number; - readonly velocityX: number; - readonly velocityY: number; - initGestureEvent(typeArg: string, canBubbleArg: boolean, cancelableArg: boolean, viewArg: Window, detailArg: number, screenXArg: number, screenYArg: number, clientXArg: number, clientYArg: number, offsetXArg: number, offsetYArg: number, translationXArg: number, translationYArg: number, scaleArg: number, expansionArg: number, rotationArg: number, velocityXArg: number, velocityYArg: number, velocityExpansionArg: number, velocityAngularArg: number, hwTimestampArg: number): void; - readonly MSGESTURE_FLAG_BEGIN: number; - readonly MSGESTURE_FLAG_CANCEL: number; - readonly MSGESTURE_FLAG_END: number; - readonly MSGESTURE_FLAG_INERTIA: number; - readonly MSGESTURE_FLAG_NONE: number; -} - -declare var MSGestureEvent: { - prototype: MSGestureEvent; - new(): MSGestureEvent; - readonly MSGESTURE_FLAG_BEGIN: number; - readonly MSGESTURE_FLAG_CANCEL: number; - readonly MSGESTURE_FLAG_END: number; - readonly MSGESTURE_FLAG_INERTIA: number; - readonly MSGESTURE_FLAG_NONE: number; -}; - -interface MSGraphicsTrust { - readonly constrictionActive: boolean; - readonly status: string; -} - -declare var MSGraphicsTrust: { - prototype: MSGraphicsTrust; - new(): MSGraphicsTrust; -}; - -interface MSHTMLWebViewElement extends HTMLElement { - readonly canGoBack: boolean; - readonly canGoForward: boolean; - readonly containsFullScreenElement: boolean; - readonly documentTitle: string; - height: number; - readonly settings: MSWebViewSettings; - src: string; - width: number; - addWebAllowedObject(name: string, applicationObject: any): void; - buildLocalStreamUri(contentIdentifier: string, relativePath: string): string; - capturePreviewToBlobAsync(): MSWebViewAsyncOperation; - captureSelectedContentToDataPackageAsync(): MSWebViewAsyncOperation; - getDeferredPermissionRequestById(id: number): DeferredPermissionRequest; - getDeferredPermissionRequests(): DeferredPermissionRequest[]; - goBack(): void; - goForward(): void; - invokeScriptAsync(scriptName: string, ...args: any[]): MSWebViewAsyncOperation; - navigate(uri: string): void; - navigateFocus(navigationReason: NavigationReason, origin: FocusNavigationOrigin): void; - navigateToLocalStreamUri(source: string, streamResolver: any): void; - navigateToString(contents: string): void; - navigateWithHttpRequestMessage(requestMessage: any): void; - refresh(): void; - stop(): void; - addEventListener(type: K, listener: (this: MSHTMLWebViewElement, ev: HTMLElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; -} - -declare var MSHTMLWebViewElement: { - prototype: MSHTMLWebViewElement; - new(): MSHTMLWebViewElement; -}; - -interface MSInputMethodContextEventMap { - "MSCandidateWindowHide": Event; - "MSCandidateWindowShow": Event; - "MSCandidateWindowUpdate": Event; -} - -interface MSInputMethodContext extends EventTarget { - readonly compositionEndOffset: number; - readonly compositionStartOffset: number; - oncandidatewindowhide: (this: MSInputMethodContext, ev: Event) => any; - oncandidatewindowshow: (this: MSInputMethodContext, ev: Event) => any; - oncandidatewindowupdate: (this: MSInputMethodContext, ev: Event) => any; - readonly target: HTMLElement; - getCandidateWindowClientRect(): ClientRect; - getCompositionAlternatives(): string[]; - hasComposition(): boolean; - isCandidateWindowVisible(): boolean; - addEventListener(type: K, listener: (this: MSInputMethodContext, ev: MSInputMethodContextEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; -} - -declare var MSInputMethodContext: { - prototype: MSInputMethodContext; - new(): MSInputMethodContext; -}; - -interface MSManipulationEvent extends UIEvent { - readonly currentState: number; - readonly inertiaDestinationX: number; - readonly inertiaDestinationY: number; - readonly lastState: number; - initMSManipulationEvent(typeArg: string, canBubbleArg: boolean, cancelableArg: boolean, viewArg: Window, detailArg: number, lastState: number, currentState: number): void; - readonly MS_MANIPULATION_STATE_ACTIVE: number; - readonly MS_MANIPULATION_STATE_CANCELLED: number; - readonly MS_MANIPULATION_STATE_COMMITTED: number; - readonly MS_MANIPULATION_STATE_DRAGGING: number; - readonly MS_MANIPULATION_STATE_INERTIA: number; - readonly MS_MANIPULATION_STATE_PRESELECT: number; - readonly MS_MANIPULATION_STATE_SELECTING: number; - readonly MS_MANIPULATION_STATE_STOPPED: number; -} - -declare var MSManipulationEvent: { - prototype: MSManipulationEvent; - new(): MSManipulationEvent; - readonly MS_MANIPULATION_STATE_ACTIVE: number; - readonly MS_MANIPULATION_STATE_CANCELLED: number; - readonly MS_MANIPULATION_STATE_COMMITTED: number; - readonly MS_MANIPULATION_STATE_DRAGGING: number; - readonly MS_MANIPULATION_STATE_INERTIA: number; - readonly MS_MANIPULATION_STATE_PRESELECT: number; - readonly MS_MANIPULATION_STATE_SELECTING: number; - readonly MS_MANIPULATION_STATE_STOPPED: number; -}; - -interface MSMediaKeyError { - readonly code: number; - readonly systemCode: number; - readonly MS_MEDIA_KEYERR_CLIENT: number; - readonly MS_MEDIA_KEYERR_DOMAIN: number; - readonly MS_MEDIA_KEYERR_HARDWARECHANGE: number; - readonly MS_MEDIA_KEYERR_OUTPUT: number; - readonly MS_MEDIA_KEYERR_SERVICE: number; - readonly MS_MEDIA_KEYERR_UNKNOWN: number; -} - -declare var MSMediaKeyError: { - prototype: MSMediaKeyError; - new(): MSMediaKeyError; - readonly MS_MEDIA_KEYERR_CLIENT: number; - readonly MS_MEDIA_KEYERR_DOMAIN: number; - readonly MS_MEDIA_KEYERR_HARDWARECHANGE: number; - readonly MS_MEDIA_KEYERR_OUTPUT: number; - readonly MS_MEDIA_KEYERR_SERVICE: number; - readonly MS_MEDIA_KEYERR_UNKNOWN: number; -}; - -interface MSMediaKeyMessageEvent extends Event { - readonly destinationURL: string | null; - readonly message: Uint8Array; -} - -declare var MSMediaKeyMessageEvent: { - prototype: MSMediaKeyMessageEvent; - new(): MSMediaKeyMessageEvent; -}; - -interface MSMediaKeyNeededEvent extends Event { - readonly initData: Uint8Array | null; -} - -declare var MSMediaKeyNeededEvent: { - prototype: MSMediaKeyNeededEvent; - new(): MSMediaKeyNeededEvent; -}; - -interface MSMediaKeys { - readonly keySystem: string; - createSession(type: string, initData: Uint8Array, cdmData?: Uint8Array): MSMediaKeySession; -} - -declare var MSMediaKeys: { - prototype: MSMediaKeys; - new(keySystem: string): MSMediaKeys; - isTypeSupported(keySystem: string, type?: string): boolean; - isTypeSupportedWithFeatures(keySystem: string, type?: string): string; -}; - -interface MSMediaKeySession extends EventTarget { - readonly error: MSMediaKeyError | null; - readonly keySystem: string; - readonly sessionId: string; - close(): void; - update(key: Uint8Array): void; -} - -declare var MSMediaKeySession: { - prototype: MSMediaKeySession; - new(): MSMediaKeySession; -}; - -interface MSPointerEvent extends MouseEvent { - readonly currentPoint: any; - readonly height: number; - readonly hwTimestamp: number; - readonly intermediatePoints: any; - readonly isPrimary: boolean; - readonly pointerId: number; - readonly pointerType: any; - readonly pressure: number; - readonly rotation: number; - readonly tiltX: number; - readonly tiltY: number; - readonly width: number; - getCurrentPoint(element: Element): void; - getIntermediatePoints(element: Element): void; - initPointerEvent(typeArg: string, canBubbleArg: boolean, cancelableArg: boolean, viewArg: Window, detailArg: number, screenXArg: number, screenYArg: number, clientXArg: number, clientYArg: number, ctrlKeyArg: boolean, altKeyArg: boolean, shiftKeyArg: boolean, metaKeyArg: boolean, buttonArg: number, relatedTargetArg: EventTarget, offsetXArg: number, offsetYArg: number, widthArg: number, heightArg: number, pressure: number, rotation: number, tiltX: number, tiltY: number, pointerIdArg: number, pointerType: any, hwTimestampArg: number, isPrimary: boolean): void; -} - -declare var MSPointerEvent: { - prototype: MSPointerEvent; - new(typeArg: string, eventInitDict?: PointerEventInit): MSPointerEvent; -}; - -interface MSRangeCollection { - readonly length: number; - item(index: number): Range; - [index: number]: Range; -} - -declare var MSRangeCollection: { - prototype: MSRangeCollection; - new(): MSRangeCollection; -}; - -interface MSSiteModeEvent extends Event { - readonly actionURL: string; - readonly buttonID: number; -} - -declare var MSSiteModeEvent: { - prototype: MSSiteModeEvent; - new(): MSSiteModeEvent; -}; - -interface MSStream { - readonly type: string; - msClose(): void; - msDetachStream(): any; -} - -declare var MSStream: { - prototype: MSStream; - new(): MSStream; -}; - -interface MSStreamReader extends EventTarget, MSBaseReader { - readonly error: DOMError; - readAsArrayBuffer(stream: MSStream, size?: number): void; - readAsBinaryString(stream: MSStream, size?: number): void; - readAsBlob(stream: MSStream, size?: number): void; - readAsDataURL(stream: MSStream, size?: number): void; - readAsText(stream: MSStream, encoding?: string, size?: number): void; - addEventListener(type: K, listener: (this: MSStreamReader, ev: MSBaseReaderEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; -} - -declare var MSStreamReader: { - prototype: MSStreamReader; - new(): MSStreamReader; -}; - -interface MSWebViewAsyncOperationEventMap { - "complete": Event; - "error": Event; -} - -interface MSWebViewAsyncOperation extends EventTarget { - readonly error: DOMError; - oncomplete: (this: MSWebViewAsyncOperation, ev: Event) => any; - onerror: (this: MSWebViewAsyncOperation, ev: Event) => any; - readonly readyState: number; - readonly result: any; - readonly target: MSHTMLWebViewElement; - readonly type: number; - start(): void; - readonly COMPLETED: number; - readonly ERROR: number; - readonly STARTED: number; - readonly TYPE_CAPTURE_PREVIEW_TO_RANDOM_ACCESS_STREAM: number; - readonly TYPE_CREATE_DATA_PACKAGE_FROM_SELECTION: number; - readonly TYPE_INVOKE_SCRIPT: number; - addEventListener(type: K, listener: (this: MSWebViewAsyncOperation, ev: MSWebViewAsyncOperationEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; -} - -declare var MSWebViewAsyncOperation: { - prototype: MSWebViewAsyncOperation; - new(): MSWebViewAsyncOperation; - readonly COMPLETED: number; - readonly ERROR: number; - readonly STARTED: number; - readonly TYPE_CAPTURE_PREVIEW_TO_RANDOM_ACCESS_STREAM: number; - readonly TYPE_CREATE_DATA_PACKAGE_FROM_SELECTION: number; - readonly TYPE_INVOKE_SCRIPT: number; -}; - -interface MSWebViewSettings { - isIndexedDBEnabled: boolean; - isJavaScriptEnabled: boolean; -} - -declare var MSWebViewSettings: { - prototype: MSWebViewSettings; - new(): MSWebViewSettings; -}; - -interface MutationEvent extends Event { - readonly attrChange: number; - readonly attrName: string; - readonly newValue: string; - readonly prevValue: string; - readonly relatedNode: Node; - initMutationEvent(typeArg: string, canBubbleArg: boolean, cancelableArg: boolean, relatedNodeArg: Node, prevValueArg: string, newValueArg: string, attrNameArg: string, attrChangeArg: number): void; - readonly ADDITION: number; - readonly MODIFICATION: number; - readonly REMOVAL: number; -} - -declare var MutationEvent: { - prototype: MutationEvent; - new(): MutationEvent; - readonly ADDITION: number; - readonly MODIFICATION: number; - readonly REMOVAL: number; + new(type: string, eventInitDict?: MouseEventInit): MouseEvent; }; interface MutationObserver { disconnect(): void; - observe(target: Node, options: MutationObserverInit): void; + observe(target: Node, options?: MutationObserverInit): void; takeRecords(): MutationRecord[]; } @@ -8168,13 +7135,13 @@ declare var MutationRecord: { interface NamedNodeMap { readonly length: number; - getNamedItem(name: string): Attr; - getNamedItemNS(namespaceURI: string | null, localName: string | null): Attr; - item(index: number): Attr; - removeNamedItem(name: string): Attr; - removeNamedItemNS(namespaceURI: string | null, localName: string | null): Attr; - setNamedItem(arg: Attr): Attr; - setNamedItemNS(arg: Attr): Attr; + getNamedItem(qualifiedName: string): Attr | null; + getNamedItemNS(namespace: string | null, localName: string): Attr | null; + item(index: number): Attr | null; + removeNamedItem(qualifiedName: string): Attr; + removeNamedItemNS(namespace: string | null, localName: string): Attr; + setNamedItem(attr: Attr): Attr | null; + setNamedItemNS(attr: Attr): Attr | null; [index: number]: Attr; } @@ -8183,54 +7150,27 @@ declare var NamedNodeMap: { new(): NamedNodeMap; }; -interface NavigationCompletedEvent extends NavigationEvent { - readonly isSuccess: boolean; - readonly webErrorStatus: number; -} - -declare var NavigationCompletedEvent: { - prototype: NavigationCompletedEvent; - new(): NavigationCompletedEvent; -}; - -interface NavigationEvent extends Event { - readonly uri: string; -} - -declare var NavigationEvent: { - prototype: NavigationEvent; - new(): NavigationEvent; -}; - -interface NavigationEventWithReferrer extends NavigationEvent { - readonly referer: string; +interface NavigationPreloadManager { + disable(): Promise; + enable(): Promise; + getState(): Promise; + setHeaderValue(value: string): Promise; } -declare var NavigationEventWithReferrer: { - prototype: NavigationEventWithReferrer; - new(): NavigationEventWithReferrer; +declare var NavigationPreloadManager: { + prototype: NavigationPreloadManager; + new(): NavigationPreloadManager; }; -interface Navigator extends Object, NavigatorID, NavigatorOnLine, NavigatorContentUtils, NavigatorStorageUtils, NavigatorGeolocation, MSNavigatorDoNotTrack, MSFileSaver, NavigatorBeacon, NavigatorConcurrentHardware, NavigatorUserMedia { - readonly authentication: WebAuthentication; - readonly cookieEnabled: boolean; - gamepadInputEmulation: GamepadInputEmulationType; - readonly language: string; +interface Navigator extends NavigatorID, NavigatorLanguage, NavigatorOnLine, NavigatorContentUtils, NavigatorCookies, NavigatorPlugins, NavigatorConcurrentHardware, NavigatorUserMedia { + readonly geolocation: Geolocation; readonly maxTouchPoints: number; - readonly mimeTypes: MimeTypeArray; - readonly msManipulationViewsEnabled: boolean; - readonly msMaxTouchPoints: number; - readonly msPointerEnabled: boolean; - readonly plugins: PluginArray; - readonly pointerEnabled: boolean; readonly serviceWorker: ServiceWorkerContainer; - readonly webdriver: boolean; readonly hardwareConcurrency: number; readonly languages: string[]; - getGamepads(): Gamepad[]; - javaEnabled(): boolean; - msLaunchUri(uri: string, successCallback?: MSLaunchUriCallback, noHandlerCallback?: MSLaunchUriCallback): void; + getGamepads(): (Gamepad | null)[]; requestMediaKeySystemAccess(keySystem: string, supportedConfigurations: MediaKeySystemConfiguration[]): Promise; + sendBeacon(url: string, data?: BodyInit): boolean; vibrate(pattern: number | number[]): boolean; } @@ -8240,18 +7180,16 @@ declare var Navigator: { }; interface Node extends EventTarget { - readonly attributes: NamedNodeMap; - readonly baseURI: string | null; + readonly baseURI: string; readonly childNodes: NodeList; readonly firstChild: Node | null; + readonly isConnected: boolean; readonly lastChild: Node | null; - readonly localName: string | null; - readonly namespaceURI: string | null; readonly nextSibling: Node | null; readonly nodeName: string; readonly nodeType: number; nodeValue: string | null; - readonly ownerDocument: Document; + readonly ownerDocument: Document | null; readonly parentElement: HTMLElement | null; readonly parentNode: Node | null; readonly previousSibling: Node | null; @@ -8259,15 +7197,15 @@ interface Node extends EventTarget { appendChild(newChild: T): T; cloneNode(deep?: boolean): Node; compareDocumentPosition(other: Node): number; - contains(child: Node): boolean; - hasAttributes(): boolean; + contains(other: Node | null): boolean; + getRootNode(options?: GetRootNodeOptions): Node; hasChildNodes(): boolean; insertBefore(newChild: T, refChild: Node | null): T; - isDefaultNamespace(namespaceURI: string | null): boolean; - isEqualNode(arg: Node): boolean; - isSameNode(other: Node): boolean; + isDefaultNamespace(namespace: string | null): boolean; + isEqualNode(otherNode: Node | null): boolean; + isSameNode(otherNode: Node | null): boolean; lookupNamespaceURI(prefix: string | null): string | null; - lookupPrefix(namespaceURI: string | null): string | null; + lookupPrefix(namespace: string | null): string | null; normalize(): void; removeChild(oldChild: T): T; replaceChild(newChild: Node, oldChild: T): T; @@ -8314,37 +7252,15 @@ declare var Node: { readonly TEXT_NODE: number; }; -interface NodeFilter { - acceptNode(n: Node): number; -} - -declare var NodeFilter: { - readonly FILTER_ACCEPT: number; - readonly FILTER_REJECT: number; - readonly FILTER_SKIP: number; - readonly SHOW_ALL: number; - readonly SHOW_ATTRIBUTE: number; - readonly SHOW_CDATA_SECTION: number; - readonly SHOW_COMMENT: number; - readonly SHOW_DOCUMENT: number; - readonly SHOW_DOCUMENT_FRAGMENT: number; - readonly SHOW_DOCUMENT_TYPE: number; - readonly SHOW_ELEMENT: number; - readonly SHOW_ENTITY: number; - readonly SHOW_ENTITY_REFERENCE: number; - readonly SHOW_NOTATION: number; - readonly SHOW_PROCESSING_INSTRUCTION: number; - readonly SHOW_TEXT: number; -}; - -interface NodeIterator { - readonly expandEntityReferences: boolean; - readonly filter: NodeFilter; - readonly root: Node; - readonly whatToShow: number; - detach(): void; - nextNode(): Node; - previousNode(): Node; +interface NodeIterator { + readonly filter: NodeFilter | null; + readonly pointerBeforeReferenceNode: boolean; + readonly referenceNode: Node; + readonly root: Node; + readonly whatToShow: number; + detach(): void; + nextNode(): Node | null; + previousNode(): Node | null; } declare var NodeIterator: { @@ -8354,7 +7270,7 @@ declare var NodeIterator: { interface NodeList { readonly length: number; - item(index: number): Node; + item(index: number): Node | null; [index: number]: Node; } @@ -8365,84 +7281,39 @@ declare var NodeList: { interface NotificationEventMap { "click": Event; - "close": Event; "error": Event; - "show": Event; } interface Notification extends EventTarget { + readonly actions: ReadonlyArray; + readonly badge: string; readonly body: string; + readonly data: any; readonly dir: NotificationDirection; readonly icon: string; + readonly image: string; readonly lang: string; + readonly maxActions: number; onclick: (this: Notification, ev: Event) => any; - onclose: (this: Notification, ev: Event) => any; onerror: (this: Notification, ev: Event) => any; - onshow: (this: Notification, ev: Event) => any; readonly permission: NotificationPermission; + readonly renotify: boolean; + readonly requireInteraction: boolean; + readonly silent: boolean; + readonly sound: string; readonly tag: string; + readonly timestamp: number; readonly title: string; + readonly vibrate: ReadonlyArray; close(): void; addEventListener(type: K, listener: (this: Notification, ev: NotificationEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var Notification: { prototype: Notification; new(title: string, options?: NotificationOptions): Notification; - requestPermission(callback?: NotificationPermissionCallback): Promise; -}; - -interface OES_element_index_uint { -} - -declare var OES_element_index_uint: { - prototype: OES_element_index_uint; - new(): OES_element_index_uint; -}; - -interface OES_standard_derivatives { - readonly FRAGMENT_SHADER_DERIVATIVE_HINT_OES: number; -} - -declare var OES_standard_derivatives: { - prototype: OES_standard_derivatives; - new(): OES_standard_derivatives; - readonly FRAGMENT_SHADER_DERIVATIVE_HINT_OES: number; -}; - -interface OES_texture_float { -} - -declare var OES_texture_float: { - prototype: OES_texture_float; - new(): OES_texture_float; -}; - -interface OES_texture_float_linear { -} - -declare var OES_texture_float_linear: { - prototype: OES_texture_float_linear; - new(): OES_texture_float_linear; -}; - -interface OES_texture_half_float { - readonly HALF_FLOAT_OES: number; -} - -declare var OES_texture_half_float: { - prototype: OES_texture_half_float; - new(): OES_texture_half_float; - readonly HALF_FLOAT_OES: number; -}; - -interface OES_texture_half_float_linear { -} - -declare var OES_texture_half_float_linear: { - prototype: OES_texture_half_float_linear; - new(): OES_texture_half_float_linear; + requestPermission(deprecatedCallback?: NotificationPermissionCallback): Promise; }; interface OfflineAudioCompletionEvent extends Event { @@ -8451,20 +7322,20 @@ interface OfflineAudioCompletionEvent extends Event { declare var OfflineAudioCompletionEvent: { prototype: OfflineAudioCompletionEvent; - new(): OfflineAudioCompletionEvent; + new(type: string, eventInitDict: OfflineAudioCompletionEventInit): OfflineAudioCompletionEvent; }; -interface OfflineAudioContextEventMap extends AudioContextEventMap { +interface OfflineAudioContextEventMap extends BaseAudioContextEventMap { "complete": OfflineAudioCompletionEvent; } -interface OfflineAudioContext extends AudioContextBase { +interface OfflineAudioContext extends BaseAudioContext { readonly length: number; oncomplete: (this: OfflineAudioContext, ev: OfflineAudioCompletionEvent) => any; startRendering(): Promise; suspend(suspendTime: number): Promise; addEventListener(type: K, listener: (this: OfflineAudioContext, ev: OfflineAudioContextEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var OfflineAudioContext: { @@ -8472,42 +7343,50 @@ declare var OfflineAudioContext: { new(numberOfChannels: number, length: number, sampleRate: number): OfflineAudioContext; }; -interface OscillatorNodeEventMap { - "ended": MediaStreamErrorEvent; +interface OffscreenCanvas extends EventTarget { + height: number; + width: number; + convertToBlob(options?: ImageEncodeOptions): Promise; + getContext(contextType: OffscreenRenderingContextType, ...arguments: any[]): OffscreenRenderingContext | null; + transferToImageBitmap(): ImageBitmap; +} + +declare var OffscreenCanvas: { + prototype: OffscreenCanvas; + new(width: number, height: number): OffscreenCanvas; +}; + +interface OffscreenCanvasRenderingContext2D extends CanvasState, CanvasTransform, CanvasCompositing, CanvasImageSmoothing, CanvasFillStrokeStyles, CanvasShadowStyles, CanvasFilters, CanvasRect, CanvasDrawPath, CanvasDrawImage, CanvasImageData, CanvasPathDrawingStyles, CanvasPath { + readonly canvas: OffscreenCanvas; + commit(): void; } -interface OscillatorNode extends AudioNode { +declare var OffscreenCanvasRenderingContext2D: { + prototype: OffscreenCanvasRenderingContext2D; + new(): OffscreenCanvasRenderingContext2D; +}; + +interface OscillatorNode extends AudioScheduledSourceNode { readonly detune: AudioParam; readonly frequency: AudioParam; - onended: (this: OscillatorNode, ev: MediaStreamErrorEvent) => any; type: OscillatorType; setPeriodicWave(periodicWave: PeriodicWave): void; - start(when?: number): void; - stop(when?: number): void; - addEventListener(type: K, listener: (this: OscillatorNode, ev: OscillatorNodeEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: OscillatorNode, ev: AudioScheduledSourceNodeEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var OscillatorNode: { prototype: OscillatorNode; - new(): OscillatorNode; + new(context: BaseAudioContext, options?: OscillatorOptions): OscillatorNode; }; -interface OverflowEvent extends UIEvent { - readonly horizontalOverflow: boolean; - readonly orient: number; - readonly verticalOverflow: boolean; - readonly BOTH: number; - readonly HORIZONTAL: number; - readonly VERTICAL: number; +interface OverconstrainedErrorEvent extends Event { + readonly error: any; } -declare var OverflowEvent: { - prototype: OverflowEvent; - new(): OverflowEvent; - readonly BOTH: number; - readonly HORIZONTAL: number; - readonly VERTICAL: number; +declare var OverconstrainedErrorEvent: { + prototype: OverconstrainedErrorEvent; + new(type: string, eventInitDict: OverconstrainedErrorEventInit): OverconstrainedErrorEvent; }; interface PageTransitionEvent extends Event { @@ -8516,7 +7395,7 @@ interface PageTransitionEvent extends Event { declare var PageTransitionEvent: { prototype: PageTransitionEvent; - new(): PageTransitionEvent; + new(type: string, eventInitDict?: PageTransitionEventInit): PageTransitionEvent; }; interface PannerNode extends AudioNode { @@ -8525,29 +7404,38 @@ interface PannerNode extends AudioNode { coneOuterGain: number; distanceModel: DistanceModelType; maxDistance: number; + readonly orientationX: AudioParam; + readonly orientationY: AudioParam; + readonly orientationZ: AudioParam; panningModel: PanningModelType; + readonly positionX: AudioParam; + readonly positionY: AudioParam; + readonly positionZ: AudioParam; refDistance: number; rolloffFactor: number; setOrientation(x: number, y: number, z: number): void; setPosition(x: number, y: number, z: number): void; - setVelocity(x: number, y: number, z: number): void; } declare var PannerNode: { prototype: PannerNode; - new(): PannerNode; + new(context: BaseAudioContext, options?: PannerOptions): PannerNode; }; -interface Path2D extends Object, CanvasPathMethods { +interface Path2D extends CanvasPath { + addPath(path: Path2D, transform?: DOMMatrixInit): void; } declare var Path2D: { prototype: Path2D; - new(path?: Path2D): Path2D; + new(): Path2D; + new(path: Path2D): Path2D; + new(paths: Path2D[], fillRule?: CanvasFillRule): Path2D; + new(d: string): Path2D; }; interface PaymentAddress { - readonly addressLine: string[]; + readonly addressLine: ReadonlyArray; readonly city: string; readonly country: string; readonly dependentLocality: string; @@ -8558,7 +7446,6 @@ interface PaymentAddress { readonly recipient: string; readonly region: string; readonly sortingCode: string; - toJSON(): any; } declare var PaymentAddress: { @@ -8572,24 +7459,26 @@ interface PaymentRequestEventMap { } interface PaymentRequest extends EventTarget { + readonly id: string; onshippingaddresschange: (this: PaymentRequest, ev: Event) => any; onshippingoptionchange: (this: PaymentRequest, ev: Event) => any; readonly shippingAddress: PaymentAddress | null; readonly shippingOption: string | null; readonly shippingType: PaymentShippingType | null; abort(): Promise; + canMakePayment(): Promise; show(): Promise; addEventListener(type: K, listener: (this: PaymentRequest, ev: PaymentRequestEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var PaymentRequest: { prototype: PaymentRequest; - new(methodData: PaymentMethodData[], details: PaymentDetails, options?: PaymentOptions): PaymentRequest; + new(methodData: PaymentMethodData[], details: PaymentDetailsInit, options?: PaymentOptions): PaymentRequest; }; interface PaymentRequestUpdateEvent extends Event { - updateWith(d: Promise): void; + updateWith(detailsPromise: Promise): void; } declare var PaymentRequestUpdateEvent: { @@ -8603,10 +7492,10 @@ interface PaymentResponse { readonly payerEmail: string | null; readonly payerName: string | null; readonly payerPhone: string | null; + readonly requestId: string; readonly shippingAddress: PaymentAddress | null; readonly shippingOption: string | null; complete(result?: PaymentComplete): Promise; - toJSON(): any; } declare var PaymentResponse: { @@ -8614,22 +7503,26 @@ declare var PaymentResponse: { new(): PaymentResponse; }; -interface Performance { +interface PerformanceEventMap { + "resourcetimingbufferfull": Event; +} + +interface Performance extends EventTarget { readonly navigation: PerformanceNavigation; + onresourcetimingbufferfull: (this: Performance, ev: Event) => any; readonly timing: PerformanceTiming; clearMarks(markName?: string): void; clearMeasures(measureName?: string): void; clearResourceTimings(): void; - getEntries(): any; - getEntriesByName(name: string, entryType?: string): any; - getEntriesByType(entryType: string): any; - getMarks(markName?: string): any; - getMeasures(measureName?: string): any; + getEntries(): PerformanceEntryList; + getEntriesByName(name: string, type?: string): PerformanceEntryList; + getEntriesByType(type: string): PerformanceEntryList; mark(markName: string): void; - measure(measureName: string, startMarkName?: string, endMarkName?: string): void; + measure(measureName: string, startMark?: string, endMark?: string): void; now(): number; setResourceTimingBufferSize(maxSize: number): void; - toJSON(): any; + addEventListener(type: K, listener: (this: Performance, ev: PerformanceEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var Performance: { @@ -8668,7 +7561,6 @@ declare var PerformanceMeasure: { interface PerformanceNavigation { readonly redirectCount: number; readonly type: number; - toJSON(): any; readonly TYPE_BACK_FORWARD: number; readonly TYPE_NAVIGATE: number; readonly TYPE_RELOAD: number; @@ -8684,26 +7576,14 @@ declare var PerformanceNavigation: { readonly TYPE_RESERVED: number; }; -interface PerformanceNavigationTiming extends PerformanceEntry { - readonly connectEnd: number; - readonly connectStart: number; - readonly domainLookupEnd: number; - readonly domainLookupStart: number; +interface PerformanceNavigationTiming extends PerformanceResourceTiming { readonly domComplete: number; readonly domContentLoadedEventEnd: number; readonly domContentLoadedEventStart: number; readonly domInteractive: number; - readonly domLoading: number; - readonly fetchStart: number; readonly loadEventEnd: number; readonly loadEventStart: number; - readonly navigationStart: number; readonly redirectCount: number; - readonly redirectEnd: number; - readonly redirectStart: number; - readonly requestStart: number; - readonly responseEnd: number; - readonly responseStart: number; readonly type: NavigationType; readonly unloadEventEnd: number; readonly unloadEventStart: number; @@ -8714,6 +7594,27 @@ declare var PerformanceNavigationTiming: { new(): PerformanceNavigationTiming; }; +interface PerformanceObserver { + disconnect(): void; + observe(options: PerformanceObserverInit): void; +} + +declare var PerformanceObserver: { + prototype: PerformanceObserver; + new(callback: PerformanceObserverCallback): PerformanceObserver; +}; + +interface PerformanceObserverEntryList { + getEntries(): PerformanceEntryList; + getEntriesByName(name: string, type?: string): PerformanceEntryList; + getEntriesByType(type: string): PerformanceEntryList; +} + +declare var PerformanceObserverEntryList: { + prototype: PerformanceObserverEntryList; + new(): PerformanceObserverEntryList; +}; + interface PerformanceResourceTiming extends PerformanceEntry { readonly connectEnd: number; readonly connectStart: number; @@ -8726,6 +7627,7 @@ interface PerformanceResourceTiming extends PerformanceEntry { readonly requestStart: number; readonly responseEnd: number; readonly responseStart: number; + readonly secureConnectionStart: number; } declare var PerformanceResourceTiming: { @@ -8746,17 +7648,15 @@ interface PerformanceTiming { readonly fetchStart: number; readonly loadEventEnd: number; readonly loadEventStart: number; - readonly msFirstPaint: number; readonly navigationStart: number; readonly redirectEnd: number; readonly redirectStart: number; readonly requestStart: number; readonly responseEnd: number; readonly responseStart: number; + readonly secureConnectionStart: number; readonly unloadEventEnd: number; readonly unloadEventStart: number; - readonly secureConnectionStart: number; - toJSON(): any; } declare var PerformanceTiming: { @@ -8764,60 +7664,12 @@ declare var PerformanceTiming: { new(): PerformanceTiming; }; -interface PerfWidgetExternal { - readonly activeNetworkRequestCount: number; - readonly averageFrameTime: number; - readonly averagePaintTime: number; - readonly extraInformationEnabled: boolean; - readonly independentRenderingEnabled: boolean; - readonly irDisablingContentString: string; - readonly irStatusAvailable: boolean; - readonly maxCpuSpeed: number; - readonly paintRequestsPerSecond: number; - readonly performanceCounter: number; - readonly performanceCounterFrequency: number; - addEventListener(eventType: string, callback: Function): void; - getMemoryUsage(): number; - getProcessCpuUsage(): number; - getRecentCpuUsage(last: number | null): any; - getRecentFrames(last: number | null): any; - getRecentMemoryUsage(last: number | null): any; - getRecentPaintRequests(last: number | null): any; - removeEventListener(eventType: string, callback: Function): void; - repositionWindow(x: number, y: number): void; - resizeWindow(width: number, height: number): void; -} - -declare var PerfWidgetExternal: { - prototype: PerfWidgetExternal; - new(): PerfWidgetExternal; -}; - interface PeriodicWave { } declare var PeriodicWave: { prototype: PeriodicWave; - new(): PeriodicWave; -}; - -interface PermissionRequest extends DeferredPermissionRequest { - readonly state: MSWebViewPermissionState; - defer(): void; -} - -declare var PermissionRequest: { - prototype: PermissionRequest; - new(): PermissionRequest; -}; - -interface PermissionRequestedEvent extends Event { - readonly permissionRequest: PermissionRequest; -} - -declare var PermissionRequestedEvent: { - prototype: PermissionRequestedEvent; - new(): PermissionRequestedEvent; + new(context: BaseAudioContext, options?: PeriodicWaveOptions): PeriodicWave; }; interface Plugin { @@ -8825,9 +7677,8 @@ interface Plugin { readonly filename: string; readonly length: number; readonly name: string; - readonly version: string; - item(index: number): MimeType; - namedItem(type: string): MimeType; + item(index: number): MimeType | null; + namedItem(name: string): MimeType | null; [index: number]: MimeType; } @@ -8838,8 +7689,8 @@ declare var Plugin: { interface PluginArray { readonly length: number; - item(index: number): Plugin; - namedItem(name: string): Plugin; + item(index: number): Plugin | null; + namedItem(name: string): Plugin | null; refresh(reload?: boolean): void; [index: number]: Plugin; } @@ -8850,66 +7701,31 @@ declare var PluginArray: { }; interface PointerEvent extends MouseEvent { - readonly currentPoint: any; readonly height: number; - readonly hwTimestamp: number; - readonly intermediatePoints: any; readonly isPrimary: boolean; readonly pointerId: number; - readonly pointerType: any; + readonly pointerType: string; readonly pressure: number; - readonly rotation: number; readonly tiltX: number; readonly tiltY: number; readonly width: number; - getCurrentPoint(element: Element): void; - getIntermediatePoints(element: Element): void; - initPointerEvent(typeArg: string, canBubbleArg: boolean, cancelableArg: boolean, viewArg: Window, detailArg: number, screenXArg: number, screenYArg: number, clientXArg: number, clientYArg: number, ctrlKeyArg: boolean, altKeyArg: boolean, shiftKeyArg: boolean, metaKeyArg: boolean, buttonArg: number, relatedTargetArg: EventTarget, offsetXArg: number, offsetYArg: number, widthArg: number, heightArg: number, pressure: number, rotation: number, tiltX: number, tiltY: number, pointerIdArg: number, pointerType: any, hwTimestampArg: number, isPrimary: boolean): void; } declare var PointerEvent: { prototype: PointerEvent; - new(typeArg: string, eventInitDict?: PointerEventInit): PointerEvent; + new(type: string, eventInitDict?: PointerEventInit): PointerEvent; }; interface PopStateEvent extends Event { readonly state: any; - initPopStateEvent(typeArg: string, canBubbleArg: boolean, cancelableArg: boolean, stateArg: any): void; } declare var PopStateEvent: { prototype: PopStateEvent; - new(typeArg: string, eventInitDict?: PopStateEventInit): PopStateEvent; -}; - -interface Position { - readonly coords: Coordinates; - readonly timestamp: number; -} - -declare var Position: { - prototype: Position; - new(): Position; -}; - -interface PositionError { - readonly code: number; - readonly message: string; - toString(): string; - readonly PERMISSION_DENIED: number; - readonly POSITION_UNAVAILABLE: number; - readonly TIMEOUT: number; -} - -declare var PositionError: { - prototype: PositionError; - new(): PositionError; - readonly PERMISSION_DENIED: number; - readonly POSITION_UNAVAILABLE: number; - readonly TIMEOUT: number; + new(type: string, eventInitDict?: PopStateEventInit): PopStateEvent; }; -interface ProcessingInstruction extends CharacterData { +interface ProcessingInstruction extends CharacterData, LinkStyle { readonly target: string; } @@ -8922,7 +7738,6 @@ interface ProgressEvent extends Event { readonly lengthComputable: boolean; readonly loaded: number; readonly total: number; - initProgressEvent(typeArg: string, canBubbleArg: boolean, cancelableArg: boolean, lengthComputableArg: boolean, loadedArg: number, totalArg: number): void; } declare var ProgressEvent: { @@ -8930,8 +7745,19 @@ declare var ProgressEvent: { new(type: string, eventInitDict?: ProgressEventInit): ProgressEvent; }; +interface PromiseRejectionEvent extends Event { + readonly promise: Promise; + readonly reason: any; +} + +declare var PromiseRejectionEvent: { + prototype: PromiseRejectionEvent; + new(type: string, eventInitDict: PromiseRejectionEventInit): PromiseRejectionEvent; +}; + interface PushManager { - getSubscription(): Promise; + readonly supportedContentEncodings: ReadonlyArray; + getSubscription(): Promise; permissionState(options?: PushSubscriptionOptionsInit): Promise; subscribe(options?: PushSubscriptionOptionsInit): Promise; } @@ -8942,10 +7768,10 @@ declare var PushManager: { }; interface PushSubscription { - readonly endpoint: USVString; + readonly endpoint: string; + readonly expirationTime: number | null; readonly options: PushSubscriptionOptions; getKey(name: PushEncryptionKeyName): ArrayBuffer | null; - toJSON(): any; unsubscribe(): Promise; } @@ -8964,6 +7790,15 @@ declare var PushSubscriptionOptions: { new(): PushSubscriptionOptions; }; +interface RadioNodeList extends NodeList { + value: string; +} + +declare var RadioNodeList: { + prototype: RadioNodeList; + new(): RadioNodeList; +}; + interface Range { readonly collapsed: boolean; readonly commonAncestorContainer: Node; @@ -8973,26 +7808,27 @@ interface Range { readonly startOffset: number; cloneContents(): DocumentFragment; cloneRange(): Range; - collapse(toStart: boolean): void; + collapse(toStart?: boolean): void; compareBoundaryPoints(how: number, sourceRange: Range): number; + comparePoint(node: Node, offset: number): number; createContextualFragment(fragment: string): DocumentFragment; deleteContents(): void; detach(): void; - expand(Unit: ExpandGranularity): boolean; extractContents(): DocumentFragment; - getBoundingClientRect(): ClientRect; - getClientRects(): ClientRectList; - insertNode(newNode: Node): void; - selectNode(refNode: Node): void; - selectNodeContents(refNode: Node): void; - setEnd(refNode: Node, offset: number): void; - setEndAfter(refNode: Node): void; - setEndBefore(refNode: Node): void; - setStart(refNode: Node, offset: number): void; - setStartAfter(refNode: Node): void; - setStartBefore(refNode: Node): void; + getBoundingClientRect(): DOMRect; + getClientRects(): DOMRect[]; + insertNode(node: Node): void; + intersectsNode(node: Node): boolean; + isPointInRange(node: Node, offset: number): boolean; + selectNode(node: Node): void; + selectNodeContents(node: Node): void; + setEnd(node: Node, offset: number): void; + setEndAfter(node: Node): void; + setEndBefore(node: Node): void; + setStart(node: Node, offset: number): void; + setStartAfter(node: Node): void; + setStartBefore(node: Node): void; surroundContents(newParent: Node): void; - toString(): string; readonly END_TO_END: number; readonly END_TO_START: number; readonly START_TO_END: number; @@ -9011,7 +7847,7 @@ declare var Range: { interface ReadableStream { readonly locked: boolean; cancel(): Promise; - getReader(): ReadableStreamReader; + getReader(): ReadableStreamDefaultReader; } declare var ReadableStream: { @@ -9019,18 +7855,28 @@ declare var ReadableStream: { new(): ReadableStream; }; -interface ReadableStreamReader { +interface ReadableStreamDefaultReader { + readonly closed: boolean; cancel(): Promise; read(): Promise; releaseLock(): void; } -declare var ReadableStreamReader: { - prototype: ReadableStreamReader; - new(): ReadableStreamReader; +declare var ReadableStreamDefaultReader: { + prototype: ReadableStreamDefaultReader; + new(stream: ReadableStream): ReadableStreamDefaultReader; +}; + +interface RelatedEvent extends Event { + readonly relatedTarget: EventTarget | null; +} + +declare var RelatedEvent: { + prototype: RelatedEvent; + new(type: string, eventInitDict?: RelatedEventInit): RelatedEvent; }; -interface Request extends Object, Body { +interface Request extends Body { readonly cache: RequestCache; readonly credentials: RequestCredentials; readonly destination: RequestDestination; @@ -9049,80 +7895,121 @@ interface Request extends Object, Body { declare var Request: { prototype: Request; - new(input: Request | string, init?: RequestInit): Request; + new(input: RequestInfo, init?: RequestInit): Request; }; -interface Response extends Object, Body { - readonly body: ReadableStream | null; +interface Response extends Body { readonly headers: Headers; readonly ok: boolean; + readonly redirected: boolean; readonly status: number; readonly statusText: string; + readonly trailer: Promise; readonly type: ResponseType; readonly url: string; - readonly redirected: boolean; clone(): Response; } declare var Response: { prototype: Response; - new(body?: any, init?: ResponseInit): Response; - error: () => Response; - redirect: (url: string, status?: number) => Response; + new(body?: BodyInit, init?: ResponseInit): Response; + error(): Response; + redirect(url: string, status?: number): Response; +}; + +interface RTCCertificate { + readonly expires: number; + getAlgorithm(): AlgorithmIdentifier; + getFingerprints(): RTCDtlsFingerprint[]; +} + +declare var RTCCertificate: { + prototype: RTCCertificate; + new(): RTCCertificate; +}; + +interface RTCDataChannelEventMap { + "bufferedamountlow": Event; + "close": Event; + "error": ErrorEvent; + "message": MessageEvent; + "open": Event; +} + +interface RTCDataChannel extends EventTarget { + binaryType: string; + readonly bufferedAmount: number; + bufferedAmountLowThreshold: number; + readonly id: number | null; + readonly label: string; + readonly maxPacketLifeTime: number | null; + readonly maxRetransmits: number | null; + readonly negotiated: boolean; + onbufferedamountlow: (this: RTCDataChannel, ev: Event) => any; + onclose: (this: RTCDataChannel, ev: Event) => any; + onerror: (this: RTCDataChannel, ev: ErrorEvent) => any; + onmessage: (this: RTCDataChannel, ev: MessageEvent) => any; + onopen: (this: RTCDataChannel, ev: Event) => any; + readonly ordered: boolean; + readonly priority: RTCPriorityType; + readonly protocol: string; + readonly readyState: RTCDataChannelState; + close(): void; + send(data: string): void; + send(data: Blob): void; + send(data: ArrayBuffer): void; + send(data: ArrayBufferView): void; + addEventListener(type: K, listener: (this: RTCDataChannel, ev: RTCDataChannelEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; +} + +declare var RTCDataChannel: { + prototype: RTCDataChannel; + new(): RTCDataChannel; +}; + +interface RTCDataChannelEvent extends Event { + readonly channel: RTCDataChannel; +} + +declare var RTCDataChannelEvent: { + prototype: RTCDataChannelEvent; + new(type: string, eventInitDict: RTCDataChannelEventInit): RTCDataChannelEvent; }; interface RTCDtlsTransportEventMap { - "dtlsstatechange": RTCDtlsTransportStateChangedEvent; - "error": Event; + "statechange": Event; } -interface RTCDtlsTransport extends RTCStatsProvider { - ondtlsstatechange: ((this: RTCDtlsTransport, ev: RTCDtlsTransportStateChangedEvent) => any) | null; - onerror: ((this: RTCDtlsTransport, ev: Event) => any) | null; +interface RTCDtlsTransport { + onstatechange: (this: RTCDtlsTransport, ev: Event) => any; readonly state: RTCDtlsTransportState; readonly transport: RTCIceTransport; - getLocalParameters(): RTCDtlsParameters; getRemoteCertificates(): ArrayBuffer[]; - getRemoteParameters(): RTCDtlsParameters | null; - start(remoteParameters: RTCDtlsParameters): void; - stop(): void; addEventListener(type: K, listener: (this: RTCDtlsTransport, ev: RTCDtlsTransportEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var RTCDtlsTransport: { prototype: RTCDtlsTransport; - new(transport: RTCIceTransport): RTCDtlsTransport; + new(): RTCDtlsTransport; }; -interface RTCDtlsTransportStateChangedEvent extends Event { - readonly state: RTCDtlsTransportState; -} - -declare var RTCDtlsTransportStateChangedEvent: { - prototype: RTCDtlsTransportStateChangedEvent; - new(): RTCDtlsTransportStateChangedEvent; -}; - -interface RTCDtmfSenderEventMap { +interface RTCDTMFSenderEventMap { "tonechange": RTCDTMFToneChangeEvent; } -interface RTCDtmfSender extends EventTarget { - readonly canInsertDTMF: boolean; - readonly duration: number; - readonly interToneGap: number; - ontonechange: (this: RTCDtmfSender, ev: RTCDTMFToneChangeEvent) => any; - readonly sender: RTCRtpSender; +interface RTCDTMFSender extends EventTarget { + ontonechange: (this: RTCDTMFSender, ev: RTCDTMFToneChangeEvent) => any; readonly toneBuffer: string; insertDTMF(tones: string, duration?: number, interToneGap?: number): void; - addEventListener(type: K, listener: (this: RTCDtmfSender, ev: RTCDtmfSenderEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: RTCDTMFSender, ev: RTCDTMFSenderEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } -declare var RTCDtmfSender: { - prototype: RTCDtmfSender; - new(sender: RTCRtpSender): RTCDtmfSender; +declare var RTCDTMFSender: { + prototype: RTCDTMFSender; + new(): RTCDTMFSender; }; interface RTCDTMFToneChangeEvent extends Event { @@ -9131,82 +8018,60 @@ interface RTCDTMFToneChangeEvent extends Event { declare var RTCDTMFToneChangeEvent: { prototype: RTCDTMFToneChangeEvent; - new(typeArg: string, eventInitDict: RTCDTMFToneChangeEventInit): RTCDTMFToneChangeEvent; -}; - -interface RTCIceCandidate { - candidate: string | null; - sdpMid: string | null; - sdpMLineIndex: number | null; - toJSON(): any; -} - -declare var RTCIceCandidate: { - prototype: RTCIceCandidate; - new(candidateInitDict?: RTCIceCandidateInit): RTCIceCandidate; -}; - -interface RTCIceCandidatePairChangedEvent extends Event { - readonly pair: RTCIceCandidatePair; -} - -declare var RTCIceCandidatePairChangedEvent: { - prototype: RTCIceCandidatePairChangedEvent; - new(): RTCIceCandidatePairChangedEvent; + new(type: string, eventInitDict: RTCDTMFToneChangeEventInit): RTCDTMFToneChangeEvent; }; -interface RTCIceGathererEventMap { - "error": Event; - "localcandidate": RTCIceGathererEvent; -} - -interface RTCIceGatherer extends RTCStatsProvider { - readonly component: RTCIceComponent; - onerror: ((this: RTCIceGatherer, ev: Event) => any) | null; - onlocalcandidate: ((this: RTCIceGatherer, ev: RTCIceGathererEvent) => any) | null; - createAssociatedGatherer(): RTCIceGatherer; - getLocalCandidates(): RTCIceCandidateDictionary[]; - getLocalParameters(): RTCIceParameters; - addEventListener(type: K, listener: (this: RTCIceGatherer, ev: RTCIceGathererEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; +interface RTCErrorEvent extends Event { + readonly error: any; } -declare var RTCIceGatherer: { - prototype: RTCIceGatherer; - new(options: RTCIceGatherOptions): RTCIceGatherer; +declare var RTCErrorEvent: { + prototype: RTCErrorEvent; + new(type: string, eventInitDict: RTCErrorEventInit): RTCErrorEvent; }; -interface RTCIceGathererEvent extends Event { - readonly candidate: RTCIceCandidateDictionary | RTCIceCandidateComplete; +interface RTCIceCandidate { + readonly candidate: string; + readonly foundation: string | null; + readonly ip: string | null; + readonly port: number | null; + readonly priority: number | null; + readonly protocol: RTCIceProtocol | null; + readonly relatedAddress: string | null; + readonly relatedPort: number | null; + readonly sdpMid: string | null; + readonly sdpMLineIndex: number | null; + readonly tcpType: RTCIceTcpCandidateType | null; + readonly type: RTCIceCandidateType | null; + readonly ufrag: string | null; } -declare var RTCIceGathererEvent: { - prototype: RTCIceGathererEvent; - new(): RTCIceGathererEvent; +declare var RTCIceCandidate: { + prototype: RTCIceCandidate; + new(candidateInitDict: RTCIceCandidateInit): RTCIceCandidate; }; interface RTCIceTransportEventMap { - "candidatepairchange": RTCIceCandidatePairChangedEvent; - "icestatechange": RTCIceTransportStateChangedEvent; + "gatheringstatechange": Event; + "selectedcandidatepairchange": Event; + "statechange": Event; } -interface RTCIceTransport extends RTCStatsProvider { +interface RTCIceTransport { readonly component: RTCIceComponent; - readonly iceGatherer: RTCIceGatherer | null; - oncandidatepairchange: ((this: RTCIceTransport, ev: RTCIceCandidatePairChangedEvent) => any) | null; - onicestatechange: ((this: RTCIceTransport, ev: RTCIceTransportStateChangedEvent) => any) | null; + readonly gatheringState: RTCIceGathererState; + ongatheringstatechange: (this: RTCIceTransport, ev: Event) => any; + onselectedcandidatepairchange: (this: RTCIceTransport, ev: Event) => any; + onstatechange: (this: RTCIceTransport, ev: Event) => any; readonly role: RTCIceRole; readonly state: RTCIceTransportState; - addRemoteCandidate(remoteCandidate: RTCIceCandidateDictionary | RTCIceCandidateComplete): void; - createAssociatedTransport(): RTCIceTransport; - getNominatedCandidatePair(): RTCIceCandidatePair | null; - getRemoteCandidates(): RTCIceCandidateDictionary[]; + getLocalCandidates(): RTCIceCandidate[]; + getLocalParameters(): RTCIceParameters | null; + getRemoteCandidates(): RTCIceCandidate[]; getRemoteParameters(): RTCIceParameters | null; - setRemoteCandidates(remoteCandidates: RTCIceCandidateDictionary[]): void; - start(gatherer: RTCIceGatherer, remoteParameters: RTCIceParameters, role?: RTCIceRole): void; - stop(): void; + getSelectedCandidatePair(): RTCIceCandidatePair | null; addEventListener(type: K, listener: (this: RTCIceTransport, ev: RTCIceTransportEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var RTCIceTransport: { @@ -9214,211 +8079,231 @@ declare var RTCIceTransport: { new(): RTCIceTransport; }; -interface RTCIceTransportStateChangedEvent extends Event { - readonly state: RTCIceTransportState; +interface RTCIdentityAssertion { + idp: string; + name: string; } -declare var RTCIceTransportStateChangedEvent: { - prototype: RTCIceTransportStateChangedEvent; - new(): RTCIceTransportStateChangedEvent; +declare var RTCIdentityAssertion: { + prototype: RTCIdentityAssertion; + new(idp: string, name: string): RTCIdentityAssertion; }; interface RTCPeerConnectionEventMap { - "addstream": MediaStreamEvent; + "connectionstatechange": Event; + "datachannel": RTCDataChannelEvent; + "fingerprintfailure": Event; "icecandidate": RTCPeerConnectionIceEvent; + "icecandidateerror": RTCPeerConnectionIceErrorEvent; "iceconnectionstatechange": Event; "icegatheringstatechange": Event; "negotiationneeded": Event; - "removestream": MediaStreamEvent; "signalingstatechange": Event; + "track": RTCTrackEvent; } interface RTCPeerConnection extends EventTarget { readonly canTrickleIceCandidates: boolean | null; + readonly connectionState: RTCPeerConnectionState; + readonly currentLocalDescription: RTCSessionDescription | null; + readonly currentRemoteDescription: RTCSessionDescription | null; readonly iceConnectionState: RTCIceConnectionState; readonly iceGatheringState: RTCIceGatheringState; + readonly idpErrorInfo: string | null; + readonly idpLoginUrl: string | null; readonly localDescription: RTCSessionDescription | null; - onaddstream: (this: RTCPeerConnection, ev: MediaStreamEvent) => any; + onconnectionstatechange: (this: RTCPeerConnection, ev: Event) => any; + ondatachannel: (this: RTCPeerConnection, ev: RTCDataChannelEvent) => any; + onfingerprintfailure: (this: RTCPeerConnection, ev: Event) => any; onicecandidate: (this: RTCPeerConnection, ev: RTCPeerConnectionIceEvent) => any; + onicecandidateerror: (this: RTCPeerConnection, ev: RTCPeerConnectionIceErrorEvent) => any; oniceconnectionstatechange: (this: RTCPeerConnection, ev: Event) => any; onicegatheringstatechange: (this: RTCPeerConnection, ev: Event) => any; onnegotiationneeded: (this: RTCPeerConnection, ev: Event) => any; - onremovestream: (this: RTCPeerConnection, ev: MediaStreamEvent) => any; onsignalingstatechange: (this: RTCPeerConnection, ev: Event) => any; + ontrack: (this: RTCPeerConnection, ev: RTCTrackEvent) => any; + readonly peerIdentity: Promise; + readonly pendingLocalDescription: RTCSessionDescription | null; + readonly pendingRemoteDescription: RTCSessionDescription | null; readonly remoteDescription: RTCSessionDescription | null; + readonly sctp: RTCSctpTransport | null; readonly signalingState: RTCSignalingState; - addIceCandidate(candidate: RTCIceCandidate, successCallback?: VoidFunction, failureCallback?: RTCPeerConnectionErrorCallback): Promise; - addStream(stream: MediaStream): void; + addIceCandidate(candidate: RTCIceCandidateInit | RTCIceCandidate, successCallback: VoidFunction, failureCallback: RTCPeerConnectionErrorCallback): Promise; + addIceCandidate(candidate: RTCIceCandidateInit | RTCIceCandidate): Promise; + addTrack(track: MediaStreamTrack, ...streams: MediaStream[]): RTCRtpSender; + addTransceiver(trackOrKind: MediaStreamTrack | string, init?: RTCRtpTransceiverInit): RTCRtpTransceiver; close(): void; - createAnswer(successCallback?: RTCSessionDescriptionCallback, failureCallback?: RTCPeerConnectionErrorCallback): Promise; - createOffer(successCallback?: RTCSessionDescriptionCallback, failureCallback?: RTCPeerConnectionErrorCallback, options?: RTCOfferOptions): Promise; + createAnswer(successCallback: RTCSessionDescriptionCallback, failureCallback: RTCPeerConnectionErrorCallback): Promise; + createAnswer(options?: RTCAnswerOptions): Promise; + createDataChannel(label: string, dataChannelDict?: RTCDataChannelInit): RTCDataChannel; + createOffer(successCallback: RTCSessionDescriptionCallback, failureCallback: RTCPeerConnectionErrorCallback, options?: RTCOfferOptions): Promise; + createOffer(options?: RTCOfferOptions): Promise; getConfiguration(): RTCConfiguration; - getLocalStreams(): MediaStream[]; - getRemoteStreams(): MediaStream[]; - getStats(selector: MediaStreamTrack | null, successCallback?: RTCStatsCallback, failureCallback?: RTCPeerConnectionErrorCallback): Promise; - getStreamById(streamId: string): MediaStream | null; - removeStream(stream: MediaStream): void; - setLocalDescription(description: RTCSessionDescription, successCallback?: VoidFunction, failureCallback?: RTCPeerConnectionErrorCallback): Promise; - setRemoteDescription(description: RTCSessionDescription, successCallback?: VoidFunction, failureCallback?: RTCPeerConnectionErrorCallback): Promise; + getIdentityAssertion(): Promise; + getReceivers(): RTCRtpReceiver[]; + getSenders(): RTCRtpSender[]; + getStats(selector?: MediaStreamTrack): Promise; + getTransceivers(): RTCRtpTransceiver[]; + removeTrack(sender: RTCRtpSender): void; + setConfiguration(configuration: RTCConfiguration): void; + setIdentityProvider(provider: string, options?: RTCIdentityProviderOptions): void; + setLocalDescription(description: RTCSessionDescriptionInit): Promise; + setLocalDescription(description: RTCSessionDescriptionInit, successCallback: VoidFunction, failureCallback: RTCPeerConnectionErrorCallback): Promise; + setRemoteDescription(description: RTCSessionDescriptionInit): Promise; + setRemoteDescription(description: RTCSessionDescriptionInit, successCallback: VoidFunction, failureCallback: RTCPeerConnectionErrorCallback): Promise; addEventListener(type: K, listener: (this: RTCPeerConnection, ev: RTCPeerConnectionEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var RTCPeerConnection: { prototype: RTCPeerConnection; - new(configuration: RTCConfiguration): RTCPeerConnection; + new(configuration?: RTCConfiguration): RTCPeerConnection; + generateCertificate(keygenAlgorithm: AlgorithmIdentifier): Promise; + getDefaultIceServers(): RTCIceServer[]; +}; + +interface RTCPeerConnectionIceErrorEvent extends Event { + readonly errorCode: number; + readonly errorText: string; + readonly hostCandidate: string; + readonly url: string; +} + +declare var RTCPeerConnectionIceErrorEvent: { + prototype: RTCPeerConnectionIceErrorEvent; + new(type: string, eventInitDict: RTCPeerConnectionIceErrorEventInit): RTCPeerConnectionIceErrorEvent; }; interface RTCPeerConnectionIceEvent extends Event { - readonly candidate: RTCIceCandidate; + readonly candidate: RTCIceCandidate | null; + readonly url: string | null; } declare var RTCPeerConnectionIceEvent: { prototype: RTCPeerConnectionIceEvent; - new(type: string, eventInitDict: RTCPeerConnectionIceEventInit): RTCPeerConnectionIceEvent; + new(type: string, eventInitDict?: RTCPeerConnectionIceEventInit): RTCPeerConnectionIceEvent; }; -interface RTCRtpReceiverEventMap { - "error": Event; +interface RTCRtpContributingSource { + readonly audioLevel: number | null; + readonly source: number; + readonly timestamp: number; } -interface RTCRtpReceiver extends RTCStatsProvider { - onerror: ((this: RTCRtpReceiver, ev: Event) => any) | null; - readonly rtcpTransport: RTCDtlsTransport; - readonly track: MediaStreamTrack | null; - readonly transport: RTCDtlsTransport | RTCSrtpSdesTransport; +declare var RTCRtpContributingSource: { + prototype: RTCRtpContributingSource; + new(): RTCRtpContributingSource; +}; + +interface RTCRtpReceiver { + readonly rtcpTransport: RTCDtlsTransport | null; + readonly track: MediaStreamTrack; + readonly transport: RTCDtlsTransport | null; getContributingSources(): RTCRtpContributingSource[]; - receive(parameters: RTCRtpParameters): void; - requestSendCSRC(csrc: number): void; - setTransport(transport: RTCDtlsTransport | RTCSrtpSdesTransport, rtcpTransport?: RTCDtlsTransport): void; - stop(): void; - addEventListener(type: K, listener: (this: RTCRtpReceiver, ev: RTCRtpReceiverEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + getParameters(): RTCRtpParameters; + getStats(): Promise; + getSynchronizationSources(): RTCRtpSynchronizationSource[]; } declare var RTCRtpReceiver: { prototype: RTCRtpReceiver; - new(transport: RTCDtlsTransport | RTCSrtpSdesTransport, kind: string, rtcpTransport?: RTCDtlsTransport): RTCRtpReceiver; - getCapabilities(kind?: string): RTCRtpCapabilities; + new(): RTCRtpReceiver; + getCapabilities(kind: string): RTCRtpCapabilities; }; -interface RTCRtpSenderEventMap { - "error": Event; - "ssrcconflict": RTCSsrcConflictEvent; -} - -interface RTCRtpSender extends RTCStatsProvider { - onerror: ((this: RTCRtpSender, ev: Event) => any) | null; - onssrcconflict: ((this: RTCRtpSender, ev: RTCSsrcConflictEvent) => any) | null; - readonly rtcpTransport: RTCDtlsTransport; - readonly track: MediaStreamTrack; - readonly transport: RTCDtlsTransport | RTCSrtpSdesTransport; - send(parameters: RTCRtpParameters): void; - setTrack(track: MediaStreamTrack): void; - setTransport(transport: RTCDtlsTransport | RTCSrtpSdesTransport, rtcpTransport?: RTCDtlsTransport): void; - stop(): void; - addEventListener(type: K, listener: (this: RTCRtpSender, ev: RTCRtpSenderEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; +interface RTCRtpSender { + readonly dtmf: RTCDTMFSender | null; + readonly rtcpTransport: RTCDtlsTransport | null; + readonly track: MediaStreamTrack | null; + readonly transport: RTCDtlsTransport | null; + getParameters(): RTCRtpParameters; + getStats(): Promise; + replaceTrack(withTrack: MediaStreamTrack): Promise; + setParameters(parameters?: RTCRtpParameters): Promise; } declare var RTCRtpSender: { prototype: RTCRtpSender; - new(track: MediaStreamTrack, transport: RTCDtlsTransport | RTCSrtpSdesTransport, rtcpTransport?: RTCDtlsTransport): RTCRtpSender; - getCapabilities(kind?: string): RTCRtpCapabilities; + new(): RTCRtpSender; + getCapabilities(kind: string): RTCRtpCapabilities; }; -interface RTCSessionDescription { - sdp: string | null; - type: RTCSdpType | null; - toJSON(): any; +interface RTCRtpSynchronizationSource { + readonly audioLevel: number; + readonly source: number; + readonly timestamp: number; + readonly voiceActivityFlag: boolean | null; } -declare var RTCSessionDescription: { - prototype: RTCSessionDescription; - new(descriptionInitDict?: RTCSessionDescriptionInit): RTCSessionDescription; +declare var RTCRtpSynchronizationSource: { + prototype: RTCRtpSynchronizationSource; + new(): RTCRtpSynchronizationSource; }; -interface RTCSrtpSdesTransportEventMap { - "error": Event; -} - -interface RTCSrtpSdesTransport extends EventTarget { - onerror: ((this: RTCSrtpSdesTransport, ev: Event) => any) | null; - readonly transport: RTCIceTransport; - addEventListener(type: K, listener: (this: RTCSrtpSdesTransport, ev: RTCSrtpSdesTransportEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; +interface RTCRtpTransceiver { + readonly currentDirection: RTCRtpTransceiverDirection | null; + readonly direction: RTCRtpTransceiverDirection; + readonly mid: string | null; + readonly receiver: RTCRtpReceiver; + readonly sender: RTCRtpSender; + readonly stopped: boolean; + setCodecPreferences(codecs: RTCRtpCodecCapability[]): void; + setDirection(direction: RTCRtpTransceiverDirection): void; + stop(): void; } -declare var RTCSrtpSdesTransport: { - prototype: RTCSrtpSdesTransport; - new(transport: RTCIceTransport, encryptParameters: RTCSrtpSdesParameters, decryptParameters: RTCSrtpSdesParameters): RTCSrtpSdesTransport; - getLocalParameters(): RTCSrtpSdesParameters[]; +declare var RTCRtpTransceiver: { + prototype: RTCRtpTransceiver; + new(): RTCRtpTransceiver; }; -interface RTCSsrcConflictEvent extends Event { - readonly ssrc: number; +interface RTCSctpTransport { + readonly maxMessageSize: number; + readonly transport: RTCDtlsTransport; } -declare var RTCSsrcConflictEvent: { - prototype: RTCSsrcConflictEvent; - new(): RTCSsrcConflictEvent; +declare var RTCSctpTransport: { + prototype: RTCSctpTransport; + new(): RTCSctpTransport; }; -interface RTCStatsProvider extends EventTarget { - getStats(): Promise; - msGetStats(): Promise; +interface RTCSessionDescription { + readonly sdp: string; + readonly type: RTCSdpType; } -declare var RTCStatsProvider: { - prototype: RTCStatsProvider; - new(): RTCStatsProvider; +declare var RTCSessionDescription: { + prototype: RTCSessionDescription; + new(descriptionInitDict: RTCSessionDescriptionInit): RTCSessionDescription; }; -interface ScopedCredential { - readonly id: ArrayBuffer; - readonly type: ScopedCredentialType; +interface RTCStatsReport { } -declare var ScopedCredential: { - prototype: ScopedCredential; - new(): ScopedCredential; +declare var RTCStatsReport: { + prototype: RTCStatsReport; + new(): RTCStatsReport; }; -interface ScopedCredentialInfo { - readonly credential: ScopedCredential; - readonly publicKey: CryptoKey; +interface RTCTrackEvent extends Event { + readonly receiver: RTCRtpReceiver; + readonly streams: ReadonlyArray; + readonly track: MediaStreamTrack; + readonly transceiver: RTCRtpTransceiver; } -declare var ScopedCredentialInfo: { - prototype: ScopedCredentialInfo; - new(): ScopedCredentialInfo; +declare var RTCTrackEvent: { + prototype: RTCTrackEvent; + new(type: string, eventInitDict: RTCTrackEventInit): RTCTrackEvent; }; -interface ScreenEventMap { - "MSOrientationChange": Event; -} - -interface Screen extends EventTarget { +interface Screen { readonly availHeight: number; readonly availWidth: number; - bufferDepth: number; readonly colorDepth: number; - readonly deviceXDPI: number; - readonly deviceYDPI: number; - readonly fontSmoothingEnabled: boolean; readonly height: number; - readonly logicalXDPI: number; - readonly logicalYDPI: number; - readonly msOrientation: string; - onmsorientationchange: (this: Screen, ev: Event) => any; readonly pixelDepth: number; - readonly systemXDPI: number; - readonly systemYDPI: number; readonly width: number; - msLockOrientation(orientations: string | string[]): boolean; - msUnlockOrientation(): void; - addEventListener(type: K, listener: (this: Screen, ev: ScreenEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; } declare var Screen: { @@ -9426,16 +8311,6 @@ declare var Screen: { new(): Screen; }; -interface ScriptNotifyEvent extends Event { - readonly callingUri: string; - readonly value: string; -} - -declare var ScriptNotifyEvent: { - prototype: ScriptNotifyEvent; - new(): ScriptNotifyEvent; -}; - interface ScriptProcessorNodeEventMap { "audioprocess": AudioProcessingEvent; } @@ -9444,7 +8319,7 @@ interface ScriptProcessorNode extends AudioNode { readonly bufferSize: number; onaudioprocess: (this: ScriptProcessorNode, ev: AudioProcessingEvent) => any; addEventListener(type: K, listener: (this: ScriptProcessorNode, ev: ScriptProcessorNodeEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var ScriptProcessorNode: { @@ -9453,32 +8328,27 @@ declare var ScriptProcessorNode: { }; interface Selection { - readonly anchorNode: Node; + readonly anchorNode: Node | null; readonly anchorOffset: number; - readonly baseNode: Node; - readonly baseOffset: number; - readonly extentNode: Node; - readonly extentOffset: number; - readonly focusNode: Node; + readonly focusNode: Node | null; readonly focusOffset: number; readonly isCollapsed: boolean; readonly rangeCount: number; readonly type: string; addRange(range: Range): void; - collapse(parentNode: Node, offset: number): void; + collapse(node: Node | null, offset?: number): void; collapseToEnd(): void; collapseToStart(): void; - containsNode(node: Node, partlyContained: boolean): boolean; + containsNode(node: Node, allowPartialContainment?: boolean): boolean; deleteFromDocument(): void; empty(): void; - extend(newNode: Node, offset: number): void; + extend(node: Node, offset?: number): void; getRangeAt(index: number): Range; removeAllRanges(): void; removeRange(range: Range): void; - selectAllChildren(parentNode: Node): void; - setBaseAndExtent(baseNode: Node, baseOffset: number, extentNode: Node, extentOffset: number): void; - setPosition(parentNode: Node, offset: number): void; - toString(): string; + selectAllChildren(node: Node): void; + setBaseAndExtent(anchorNode: Node, anchorOffset: number, focusNode: Node, focusOffset: number): void; + setPosition(node: Node | null, offset?: number): void; } declare var Selection: { @@ -9492,11 +8362,11 @@ interface ServiceWorkerEventMap extends AbstractWorkerEventMap { interface ServiceWorker extends EventTarget, AbstractWorker { onstatechange: (this: ServiceWorker, ev: Event) => any; - readonly scriptURL: USVString; + readonly scriptURL: string; readonly state: ServiceWorkerState; postMessage(message: any, transfer?: any[]): void; addEventListener(type: K, listener: (this: ServiceWorker, ev: ServiceWorkerEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var ServiceWorker: { @@ -9506,19 +8376,20 @@ declare var ServiceWorker: { interface ServiceWorkerContainerEventMap { "controllerchange": Event; - "message": ServiceWorkerMessageEvent; + "message": MessageEvent; } interface ServiceWorkerContainer extends EventTarget { readonly controller: ServiceWorker | null; oncontrollerchange: (this: ServiceWorkerContainer, ev: Event) => any; - onmessage: (this: ServiceWorkerContainer, ev: ServiceWorkerMessageEvent) => any; + onmessage: (this: ServiceWorkerContainer, ev: MessageEvent) => any; readonly ready: Promise; - getRegistration(): Promise; + getRegistration(clientURL?: string): Promise; getRegistrations(): Promise; - register(scriptURL: USVString, options?: RegistrationOptions): Promise; + register(scriptURL: string, options?: RegistrationOptions): Promise; + startMessages(): void; addEventListener(type: K, listener: (this: ServiceWorkerContainer, ev: ServiceWorkerContainerEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var ServiceWorkerContainer: { @@ -9526,19 +8397,6 @@ declare var ServiceWorkerContainer: { new(): ServiceWorkerContainer; }; -interface ServiceWorkerMessageEvent extends Event { - readonly data: any; - readonly lastEventId: string; - readonly origin: string; - readonly ports: MessagePort[] | null; - readonly source: ServiceWorker | MessagePort | null; -} - -declare var ServiceWorkerMessageEvent: { - prototype: ServiceWorkerMessageEvent; - new(type: string, eventInitDict?: ServiceWorkerMessageEventInit): ServiceWorkerMessageEvent; -}; - interface ServiceWorkerRegistrationEventMap { "updatefound": Event; } @@ -9546,17 +8404,19 @@ interface ServiceWorkerRegistrationEventMap { interface ServiceWorkerRegistration extends EventTarget { readonly active: ServiceWorker | null; readonly installing: ServiceWorker | null; + readonly navigationPreload: NavigationPreloadManager; onupdatefound: (this: ServiceWorkerRegistration, ev: Event) => any; readonly pushManager: PushManager; - readonly scope: USVString; + readonly scope: string; readonly sync: SyncManager; + readonly useCache: boolean; readonly waiting: ServiceWorker | null; getNotifications(filter?: GetNotificationOptions): Promise; showNotification(title: string, options?: NotificationOptions): Promise; unregister(): Promise; update(): Promise; addEventListener(type: K, listener: (this: ServiceWorkerRegistration, ev: ServiceWorkerRegistrationEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var ServiceWorkerRegistration: { @@ -9564,19 +8424,64 @@ declare var ServiceWorkerRegistration: { new(): ServiceWorkerRegistration; }; -interface SourceBuffer extends EventTarget { - appendWindowEnd: number; - appendWindowStart: number; +interface ShadowAnimation { + readonly sourceAnimation: any; +} + +declare var ShadowAnimation: { + prototype: ShadowAnimation; + new(source: any, newTarget: any): ShadowAnimation; +}; + +interface ShadowRoot extends DocumentFragment, DocumentOrShadowRoot { + readonly host: Element; + readonly mode: ShadowRootMode; +} + +declare var ShadowRoot: { + prototype: ShadowRoot; + new(): ShadowRoot; +}; + +interface SharedWorker extends EventTarget, AbstractWorker { + readonly port: MessagePort; + addEventListener(type: K, listener: (this: SharedWorker, ev: AbstractWorkerEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; +} + +declare var SharedWorker: { + prototype: SharedWorker; + new(scriptURL: string, options?: string | WorkerOptions): SharedWorker; +}; + +interface SourceBufferEventMap { + "abort": Event; + "error": Event; + "update": Event; + "updateend": Event; + "updatestart": Event; +} + +interface SourceBuffer extends EventTarget { + appendWindowEnd: number; + appendWindowStart: number; readonly audioTracks: AudioTrackList; readonly buffered: TimeRanges; mode: AppendMode; + onabort: (this: SourceBuffer, ev: Event) => any; + onerror: (this: SourceBuffer, ev: Event) => any; + onupdate: (this: SourceBuffer, ev: Event) => any; + onupdateend: (this: SourceBuffer, ev: Event) => any; + onupdatestart: (this: SourceBuffer, ev: Event) => any; + readonly textTracks: TextTrackList; timestampOffset: number; readonly updating: boolean; readonly videoTracks: VideoTrackList; abort(): void; - appendBuffer(data: ArrayBuffer | ArrayBufferView): void; - appendStream(stream: MSStream, maxSize?: number): void; + appendBuffer(data: BufferSource): void; remove(start: number, end: number): void; + addEventListener(type: K, listener: (this: SourceBuffer, ev: SourceBufferEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SourceBuffer: { @@ -9584,9 +8489,17 @@ declare var SourceBuffer: { new(): SourceBuffer; }; +interface SourceBufferListEventMap { + "addsourcebuffer": Event; + "removesourcebuffer": Event; +} + interface SourceBufferList extends EventTarget { readonly length: number; - item(index: number): SourceBuffer; + onaddsourcebuffer: (this: SourceBufferList, ev: Event) => any; + onremovesourcebuffer: (this: SourceBufferList, ev: Event) => any; + addEventListener(type: K, listener: (this: SourceBufferList, ev: SourceBufferListEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; [index: number]: SourceBuffer; } @@ -9595,6 +8508,128 @@ declare var SourceBufferList: { new(): SourceBufferList; }; +interface SpeechGrammar { + src: string; + weight: number; +} + +declare var SpeechGrammar: { + prototype: SpeechGrammar; + new(): SpeechGrammar; +}; + +interface SpeechGrammarList { + readonly length: number; + addFromString(string: string, weight?: number): void; + addFromURI(src: string, weight?: number): void; + item(index: number): SpeechGrammar; + [index: number]: SpeechGrammar; +} + +declare var SpeechGrammarList: { + prototype: SpeechGrammarList; + new(): SpeechGrammarList; +}; + +interface SpeechRecognitionEventMap { + "audioend": Event; + "audiostart": Event; + "end": Event; + "error": SpeechRecognitionError; + "nomatch": SpeechRecognitionEvent; + "result": SpeechRecognitionEvent; + "soundend": Event; + "soundstart": Event; + "speechend": Event; + "speechstart": Event; + "start": Event; +} + +interface SpeechRecognition extends EventTarget { + continuous: boolean; + grammars: SpeechGrammarList; + interimResults: boolean; + lang: string; + maxAlternatives: number; + onaudioend: (this: SpeechRecognition, ev: Event) => any; + onaudiostart: (this: SpeechRecognition, ev: Event) => any; + onend: (this: SpeechRecognition, ev: Event) => any; + onerror: (this: SpeechRecognition, ev: SpeechRecognitionError) => any; + onnomatch: (this: SpeechRecognition, ev: SpeechRecognitionEvent) => any; + onresult: (this: SpeechRecognition, ev: SpeechRecognitionEvent) => any; + onsoundend: (this: SpeechRecognition, ev: Event) => any; + onsoundstart: (this: SpeechRecognition, ev: Event) => any; + onspeechend: (this: SpeechRecognition, ev: Event) => any; + onspeechstart: (this: SpeechRecognition, ev: Event) => any; + onstart: (this: SpeechRecognition, ev: Event) => any; + serviceURI: string; + abort(): void; + start(): void; + stop(): void; + addEventListener(type: K, listener: (this: SpeechRecognition, ev: SpeechRecognitionEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; +} + +declare var SpeechRecognition: { + prototype: SpeechRecognition; + new(): SpeechRecognition; +}; + +interface SpeechRecognitionAlternative { + readonly confidence: number; + readonly transcript: string; +} + +declare var SpeechRecognitionAlternative: { + prototype: SpeechRecognitionAlternative; + new(): SpeechRecognitionAlternative; +}; + +interface SpeechRecognitionError extends Event { + readonly error: SpeechRecognitionErrorCode; + readonly message: string; +} + +declare var SpeechRecognitionError: { + prototype: SpeechRecognitionError; + new(): SpeechRecognitionError; +}; + +interface SpeechRecognitionEvent extends Event { + readonly emma: Document; + readonly interpretation: any; + readonly resultIndex: number; + readonly results: SpeechRecognitionResultList; +} + +declare var SpeechRecognitionEvent: { + prototype: SpeechRecognitionEvent; + new(): SpeechRecognitionEvent; +}; + +interface SpeechRecognitionResult { + readonly isFinal: boolean; + readonly length: number; + item(index: number): SpeechRecognitionAlternative; + [index: number]: SpeechRecognitionAlternative; +} + +declare var SpeechRecognitionResult: { + prototype: SpeechRecognitionResult; + new(): SpeechRecognitionResult; +}; + +interface SpeechRecognitionResultList { + readonly length: number; + item(index: number): SpeechRecognitionResult; + [index: number]: SpeechRecognitionResult; +} + +declare var SpeechRecognitionResultList: { + prototype: SpeechRecognitionResultList; + new(): SpeechRecognitionResultList; +}; + interface SpeechSynthesisEventMap { "voiceschanged": Event; } @@ -9610,7 +8645,7 @@ interface SpeechSynthesis extends EventTarget { resume(): void; speak(utterance: SpeechSynthesisUtterance): void; addEventListener(type: K, listener: (this: SpeechSynthesis, ev: SpeechSynthesisEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SpeechSynthesis: { @@ -9618,16 +8653,25 @@ declare var SpeechSynthesis: { new(): SpeechSynthesis; }; +interface SpeechSynthesisErrorEvent extends SpeechSynthesisEvent { + readonly error: SpeechSynthesisErrorCode; +} + +declare var SpeechSynthesisErrorEvent: { + prototype: SpeechSynthesisErrorEvent; + new(): SpeechSynthesisErrorEvent; +}; + interface SpeechSynthesisEvent extends Event { readonly charIndex: number; readonly elapsedTime: number; readonly name: string; - readonly utterance: SpeechSynthesisUtterance | null; + readonly utterance: SpeechSynthesisUtterance; } declare var SpeechSynthesisEvent: { prototype: SpeechSynthesisEvent; - new(type: string, eventInitDict?: SpeechSynthesisEventInit): SpeechSynthesisEvent; + new(): SpeechSynthesisEvent; }; interface SpeechSynthesisUtteranceEventMap { @@ -9655,12 +8699,13 @@ interface SpeechSynthesisUtterance extends EventTarget { voice: SpeechSynthesisVoice; volume: number; addEventListener(type: K, listener: (this: SpeechSynthesisUtterance, ev: SpeechSynthesisUtteranceEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SpeechSynthesisUtterance: { prototype: SpeechSynthesisUtterance; - new(text?: string): SpeechSynthesisUtterance; + new(): SpeechSynthesisUtterance; + new(text: string): SpeechSynthesisUtterance; }; interface SpeechSynthesisVoice { @@ -9682,7 +8727,7 @@ interface StereoPannerNode extends AudioNode { declare var StereoPannerNode: { prototype: StereoPannerNode; - new(): StereoPannerNode; + new(context: BaseAudioContext, options?: StereoPannerOptions): StereoPannerNode; }; interface Storage { @@ -9691,9 +8736,7 @@ interface Storage { getItem(key: string): string | null; key(index: number): string | null; removeItem(key: string): void; - setItem(key: string, data: string): void; - [key: string]: any; - [index: number]: string; + setItem(key: string, value: string): void; } declare var Storage: { @@ -9714,24 +8757,14 @@ declare var StorageEvent: { new (type: string, eventInitDict?: StorageEventInit): StorageEvent; }; -interface StyleMedia { - readonly type: string; - matchMedium(mediaquery: string): boolean; -} - -declare var StyleMedia: { - prototype: StyleMedia; - new(): StyleMedia; -}; - interface StyleSheet { disabled: boolean; - readonly href: string; + readonly href: string | null; readonly media: MediaList; - readonly ownerNode: Node; - readonly parentStyleSheet: StyleSheet; - readonly title: string; - readonly type: string; + readonly ownerNode: Element | ProcessingInstruction | null; + readonly parentStyleSheet: StyleSheet | null; + readonly title: string | null; + readonly type: CSSOMString; } declare var StyleSheet: { @@ -9741,7 +8774,7 @@ declare var StyleSheet: { interface StyleSheetList { readonly length: number; - item(index?: number): StyleSheet; + item(index: number): StyleSheet | null; [index: number]: StyleSheet; } @@ -9750,36 +8783,19 @@ declare var StyleSheetList: { new(): StyleSheetList; }; -interface StyleSheetPageList { - readonly length: number; - item(index: number): CSSPageRule; - [index: number]: CSSPageRule; -} - -declare var StyleSheetPageList: { - prototype: StyleSheetPageList; - new(): StyleSheetPageList; -}; - interface SubtleCrypto { - decrypt(algorithm: string | RsaOaepParams | AesCtrParams | AesCbcParams | AesCmacParams | AesGcmParams | AesCfbParams, key: CryptoKey, data: BufferSource): PromiseLike; - deriveBits(algorithm: string | EcdhKeyDeriveParams | DhKeyDeriveParams | ConcatParams | HkdfCtrParams | Pbkdf2Params, baseKey: CryptoKey, length: number): PromiseLike; - deriveKey(algorithm: string | EcdhKeyDeriveParams | DhKeyDeriveParams | ConcatParams | HkdfCtrParams | Pbkdf2Params, baseKey: CryptoKey, derivedKeyType: string | AesDerivedKeyParams | HmacImportParams | ConcatParams | HkdfCtrParams | Pbkdf2Params, extractable: boolean, keyUsages: string[]): PromiseLike; - digest(algorithm: AlgorithmIdentifier, data: BufferSource): PromiseLike; - encrypt(algorithm: string | RsaOaepParams | AesCtrParams | AesCbcParams | AesCmacParams | AesGcmParams | AesCfbParams, key: CryptoKey, data: BufferSource): PromiseLike; - exportKey(format: "jwk", key: CryptoKey): PromiseLike; - exportKey(format: "raw" | "pkcs8" | "spki", key: CryptoKey): PromiseLike; - exportKey(format: string, key: CryptoKey): PromiseLike; - generateKey(algorithm: string, extractable: boolean, keyUsages: string[]): PromiseLike; - generateKey(algorithm: RsaHashedKeyGenParams | EcKeyGenParams | DhKeyGenParams, extractable: boolean, keyUsages: string[]): PromiseLike; - generateKey(algorithm: AesKeyGenParams | HmacKeyGenParams | Pbkdf2Params, extractable: boolean, keyUsages: string[]): PromiseLike; - importKey(format: "jwk", keyData: JsonWebKey, algorithm: string | RsaHashedImportParams | EcKeyImportParams | HmacImportParams | DhImportKeyParams, extractable: boolean, keyUsages: string[]): PromiseLike; - importKey(format: "raw" | "pkcs8" | "spki", keyData: BufferSource, algorithm: string | RsaHashedImportParams | EcKeyImportParams | HmacImportParams | DhImportKeyParams, extractable: boolean, keyUsages: string[]): PromiseLike; - importKey(format: string, keyData: JsonWebKey | BufferSource, algorithm: string | RsaHashedImportParams | EcKeyImportParams | HmacImportParams | DhImportKeyParams, extractable: boolean, keyUsages: string[]): PromiseLike; - sign(algorithm: string | RsaPssParams | EcdsaParams | AesCmacParams, key: CryptoKey, data: BufferSource): PromiseLike; - unwrapKey(format: string, wrappedKey: BufferSource, unwrappingKey: CryptoKey, unwrapAlgorithm: AlgorithmIdentifier, unwrappedKeyAlgorithm: AlgorithmIdentifier, extractable: boolean, keyUsages: string[]): PromiseLike; - verify(algorithm: string | RsaPssParams | EcdsaParams | AesCmacParams, key: CryptoKey, signature: BufferSource, data: BufferSource): PromiseLike; - wrapKey(format: string, key: CryptoKey, wrappingKey: CryptoKey, wrapAlgorithm: AlgorithmIdentifier): PromiseLike; + decrypt(algorithm: AlgorithmIdentifier, key: CryptoKey, data: BufferSource): Promise; + deriveBits(algorithm: AlgorithmIdentifier, baseKey: CryptoKey, length: number): Promise; + deriveKey(algorithm: AlgorithmIdentifier, baseKey: CryptoKey, derivedKeyType: AlgorithmIdentifier, extractable: boolean, keyUsages: KeyUsage[]): Promise; + digest(algorithm: AlgorithmIdentifier, data: BufferSource): Promise; + encrypt(algorithm: AlgorithmIdentifier, key: CryptoKey, data: BufferSource): Promise; + exportKey(format: KeyFormat, key: CryptoKey): Promise; + generateKey(algorithm: AlgorithmIdentifier, extractable: boolean, keyUsages: KeyUsage[]): Promise; + importKey(format: KeyFormat, keyData: BufferSource | JsonWebKey, algorithm: AlgorithmIdentifier, extractable: boolean, keyUsages: KeyUsage[]): Promise; + sign(algorithm: AlgorithmIdentifier, key: CryptoKey, data: BufferSource): Promise; + unwrapKey(format: KeyFormat, wrappedKey: BufferSource, unwrappingKey: CryptoKey, unwrapAlgorithm: AlgorithmIdentifier, unwrappedKeyAlgorithm: AlgorithmIdentifier, extractable: boolean, keyUsages: KeyUsage[]): Promise; + verify(algorithm: AlgorithmIdentifier, key: CryptoKey, signature: BufferSource, data: BufferSource): Promise; + wrapKey(format: KeyFormat, key: CryptoKey, wrappingKey: CryptoKey, wrapAlgorithm: AlgorithmIdentifier): Promise; } declare var SubtleCrypto: { @@ -9787,10 +8803,16 @@ declare var SubtleCrypto: { new(): SubtleCrypto; }; -interface SVGAElement extends SVGGraphicsElement, SVGURIReference { +interface SVGAElement extends SVGGraphicsElement, SVGURIReference, HTMLHyperlinkElementUtilsBase { + readonly download: SVGAnimatedString; + readonly hreflang: SVGAnimatedString; + readonly rel: SVGAnimatedString; + readonly relList: SVGAnimatedString; readonly target: SVGAnimatedString; - addEventListener(type: K, listener: (this: SVGAElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + readonly type: SVGAnimatedString; + addEventListener(type: K, listener: (this: SVGAElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGAElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGAElement: { @@ -9913,8 +8935,8 @@ declare var SVGAnimatedPreserveAspectRatio: { }; interface SVGAnimatedRect { - readonly animVal: SVGRect; - readonly baseVal: SVGRect; + readonly animVal: DOMRectReadOnly; + readonly baseVal: DOMRect; } declare var SVGAnimatedRect: { @@ -9942,12 +8964,13 @@ declare var SVGAnimatedTransformList: { new(): SVGAnimatedTransformList; }; -interface SVGCircleElement extends SVGGraphicsElement { +interface SVGCircleElement extends SVGGeometryElement { readonly cx: SVGAnimatedLength; readonly cy: SVGAnimatedLength; readonly r: SVGAnimatedLength; - addEventListener(type: K, listener: (this: SVGCircleElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGCircleElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGCircleElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGCircleElement: { @@ -9955,10 +8978,12 @@ declare var SVGCircleElement: { new(): SVGCircleElement; }; -interface SVGClipPathElement extends SVGGraphicsElement, SVGUnitTypes { +interface SVGClipPathElement extends SVGElement, SVGUnitTypes { readonly clipPathUnits: SVGAnimatedEnumeration; - addEventListener(type: K, listener: (this: SVGClipPathElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + readonly transform: SVGAnimatedTransformList; + addEventListener(type: K, listener: (this: SVGClipPathElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGClipPathElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGClipPathElement: { @@ -9980,8 +9005,9 @@ interface SVGComponentTransferFunctionElement extends SVGElement { readonly SVG_FECOMPONENTTRANSFER_TYPE_LINEAR: number; readonly SVG_FECOMPONENTTRANSFER_TYPE_TABLE: number; readonly SVG_FECOMPONENTTRANSFER_TYPE_UNKNOWN: number; - addEventListener(type: K, listener: (this: SVGComponentTransferFunctionElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGComponentTransferFunctionElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGComponentTransferFunctionElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGComponentTransferFunctionElement: { @@ -9995,9 +9021,23 @@ declare var SVGComponentTransferFunctionElement: { readonly SVG_FECOMPONENTTRANSFER_TYPE_UNKNOWN: number; }; +interface SVGCursorElement extends SVGElement, SVGURIReference { + readonly x: SVGAnimatedLength; + readonly y: SVGAnimatedLength; + addEventListener(type: K, listener: (this: SVGCursorElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGCursorElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; +} + +declare var SVGCursorElement: { + prototype: SVGCursorElement; + new(): SVGCursorElement; +}; + interface SVGDefsElement extends SVGGraphicsElement { - addEventListener(type: K, listener: (this: SVGDefsElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGDefsElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGDefsElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGDefsElement: { @@ -10006,8 +9046,9 @@ declare var SVGDefsElement: { }; interface SVGDescElement extends SVGElement { - addEventListener(type: K, listener: (this: SVGDescElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGDescElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGDescElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGDescElement: { @@ -10015,37 +9056,17 @@ declare var SVGDescElement: { new(): SVGDescElement; }; -interface SVGElementEventMap extends ElementEventMap { - "click": MouseEvent; - "dblclick": MouseEvent; - "focusin": FocusEvent; - "focusout": FocusEvent; - "load": Event; - "mousedown": MouseEvent; - "mousemove": MouseEvent; - "mouseout": MouseEvent; - "mouseover": MouseEvent; - "mouseup": MouseEvent; -} - -interface SVGElement extends Element { +interface SVGElement extends Element, GlobalEventHandlers, SVGElementInstance, ElementCSSInlineStyle { className: any; - onclick: (this: SVGElement, ev: MouseEvent) => any; - ondblclick: (this: SVGElement, ev: MouseEvent) => any; - onfocusin: (this: SVGElement, ev: FocusEvent) => any; - onfocusout: (this: SVGElement, ev: FocusEvent) => any; - onload: (this: SVGElement, ev: Event) => any; - onmousedown: (this: SVGElement, ev: MouseEvent) => any; - onmousemove: (this: SVGElement, ev: MouseEvent) => any; - onmouseout: (this: SVGElement, ev: MouseEvent) => any; - onmouseover: (this: SVGElement, ev: MouseEvent) => any; - onmouseup: (this: SVGElement, ev: MouseEvent) => any; - readonly ownerSVGElement: SVGSVGElement; - readonly style: CSSStyleDeclaration; - readonly viewportElement: SVGElement; - xmlbase: string; - addEventListener(type: K, listener: (this: SVGElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + readonly dataset: DOMStringMap; + readonly ownerSVGElement: SVGSVGElement | null; + tabIndex: number; + readonly viewportElement: SVGElement | null; + blur(): void; + focus(): void; + addEventListener(type: K, listener: (this: SVGElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGElement: { @@ -10053,39 +9074,14 @@ declare var SVGElement: { new(): SVGElement; }; -interface SVGElementInstance extends EventTarget { - readonly childNodes: SVGElementInstanceList; - readonly correspondingElement: SVGElement; - readonly correspondingUseElement: SVGUseElement; - readonly firstChild: SVGElementInstance; - readonly lastChild: SVGElementInstance; - readonly nextSibling: SVGElementInstance; - readonly parentNode: SVGElementInstance; - readonly previousSibling: SVGElementInstance; -} - -declare var SVGElementInstance: { - prototype: SVGElementInstance; - new(): SVGElementInstance; -}; - -interface SVGElementInstanceList { - readonly length: number; - item(index: number): SVGElementInstance; -} - -declare var SVGElementInstanceList: { - prototype: SVGElementInstanceList; - new(): SVGElementInstanceList; -}; - -interface SVGEllipseElement extends SVGGraphicsElement { +interface SVGEllipseElement extends SVGGeometryElement { readonly cx: SVGAnimatedLength; readonly cy: SVGAnimatedLength; readonly rx: SVGAnimatedLength; readonly ry: SVGAnimatedLength; - addEventListener(type: K, listener: (this: SVGEllipseElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGEllipseElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGEllipseElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGEllipseElement: { @@ -10097,46 +9093,25 @@ interface SVGFEBlendElement extends SVGElement, SVGFilterPrimitiveStandardAttrib readonly in1: SVGAnimatedString; readonly in2: SVGAnimatedString; readonly mode: SVGAnimatedEnumeration; - readonly SVG_FEBLEND_MODE_COLOR: number; - readonly SVG_FEBLEND_MODE_COLOR_BURN: number; - readonly SVG_FEBLEND_MODE_COLOR_DODGE: number; readonly SVG_FEBLEND_MODE_DARKEN: number; - readonly SVG_FEBLEND_MODE_DIFFERENCE: number; - readonly SVG_FEBLEND_MODE_EXCLUSION: number; - readonly SVG_FEBLEND_MODE_HARD_LIGHT: number; - readonly SVG_FEBLEND_MODE_HUE: number; readonly SVG_FEBLEND_MODE_LIGHTEN: number; - readonly SVG_FEBLEND_MODE_LUMINOSITY: number; readonly SVG_FEBLEND_MODE_MULTIPLY: number; readonly SVG_FEBLEND_MODE_NORMAL: number; - readonly SVG_FEBLEND_MODE_OVERLAY: number; - readonly SVG_FEBLEND_MODE_SATURATION: number; readonly SVG_FEBLEND_MODE_SCREEN: number; - readonly SVG_FEBLEND_MODE_SOFT_LIGHT: number; readonly SVG_FEBLEND_MODE_UNKNOWN: number; - addEventListener(type: K, listener: (this: SVGFEBlendElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGFEBlendElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGFEBlendElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGFEBlendElement: { prototype: SVGFEBlendElement; new(): SVGFEBlendElement; - readonly SVG_FEBLEND_MODE_COLOR: number; - readonly SVG_FEBLEND_MODE_COLOR_BURN: number; - readonly SVG_FEBLEND_MODE_COLOR_DODGE: number; readonly SVG_FEBLEND_MODE_DARKEN: number; - readonly SVG_FEBLEND_MODE_DIFFERENCE: number; - readonly SVG_FEBLEND_MODE_EXCLUSION: number; - readonly SVG_FEBLEND_MODE_HARD_LIGHT: number; - readonly SVG_FEBLEND_MODE_HUE: number; readonly SVG_FEBLEND_MODE_LIGHTEN: number; - readonly SVG_FEBLEND_MODE_LUMINOSITY: number; readonly SVG_FEBLEND_MODE_MULTIPLY: number; readonly SVG_FEBLEND_MODE_NORMAL: number; - readonly SVG_FEBLEND_MODE_OVERLAY: number; - readonly SVG_FEBLEND_MODE_SATURATION: number; readonly SVG_FEBLEND_MODE_SCREEN: number; - readonly SVG_FEBLEND_MODE_SOFT_LIGHT: number; readonly SVG_FEBLEND_MODE_UNKNOWN: number; }; @@ -10149,8 +9124,9 @@ interface SVGFEColorMatrixElement extends SVGElement, SVGFilterPrimitiveStandard readonly SVG_FECOLORMATRIX_TYPE_MATRIX: number; readonly SVG_FECOLORMATRIX_TYPE_SATURATE: number; readonly SVG_FECOLORMATRIX_TYPE_UNKNOWN: number; - addEventListener(type: K, listener: (this: SVGFEColorMatrixElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGFEColorMatrixElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGFEColorMatrixElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGFEColorMatrixElement: { @@ -10165,8 +9141,9 @@ declare var SVGFEColorMatrixElement: { interface SVGFEComponentTransferElement extends SVGElement, SVGFilterPrimitiveStandardAttributes { readonly in1: SVGAnimatedString; - addEventListener(type: K, listener: (this: SVGFEComponentTransferElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGFEComponentTransferElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGFEComponentTransferElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGFEComponentTransferElement: { @@ -10189,8 +9166,9 @@ interface SVGFECompositeElement extends SVGElement, SVGFilterPrimitiveStandardAt readonly SVG_FECOMPOSITE_OPERATOR_OVER: number; readonly SVG_FECOMPOSITE_OPERATOR_UNKNOWN: number; readonly SVG_FECOMPOSITE_OPERATOR_XOR: number; - addEventListener(type: K, listener: (this: SVGFECompositeElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGFECompositeElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGFECompositeElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGFECompositeElement: { @@ -10215,15 +9193,15 @@ interface SVGFEConvolveMatrixElement extends SVGElement, SVGFilterPrimitiveStand readonly kernelUnitLengthY: SVGAnimatedNumber; readonly orderX: SVGAnimatedInteger; readonly orderY: SVGAnimatedInteger; - readonly preserveAlpha: SVGAnimatedBoolean; readonly targetX: SVGAnimatedInteger; readonly targetY: SVGAnimatedInteger; readonly SVG_EDGEMODE_DUPLICATE: number; readonly SVG_EDGEMODE_NONE: number; readonly SVG_EDGEMODE_UNKNOWN: number; readonly SVG_EDGEMODE_WRAP: number; - addEventListener(type: K, listener: (this: SVGFEConvolveMatrixElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGFEConvolveMatrixElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGFEConvolveMatrixElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGFEConvolveMatrixElement: { @@ -10241,8 +9219,9 @@ interface SVGFEDiffuseLightingElement extends SVGElement, SVGFilterPrimitiveStan readonly kernelUnitLengthX: SVGAnimatedNumber; readonly kernelUnitLengthY: SVGAnimatedNumber; readonly surfaceScale: SVGAnimatedNumber; - addEventListener(type: K, listener: (this: SVGFEDiffuseLightingElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGFEDiffuseLightingElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGFEDiffuseLightingElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGFEDiffuseLightingElement: { @@ -10261,8 +9240,9 @@ interface SVGFEDisplacementMapElement extends SVGElement, SVGFilterPrimitiveStan readonly SVG_CHANNEL_G: number; readonly SVG_CHANNEL_R: number; readonly SVG_CHANNEL_UNKNOWN: number; - addEventListener(type: K, listener: (this: SVGFEDisplacementMapElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGFEDisplacementMapElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGFEDisplacementMapElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGFEDisplacementMapElement: { @@ -10278,8 +9258,9 @@ declare var SVGFEDisplacementMapElement: { interface SVGFEDistantLightElement extends SVGElement { readonly azimuth: SVGAnimatedNumber; readonly elevation: SVGAnimatedNumber; - addEventListener(type: K, listener: (this: SVGFEDistantLightElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGFEDistantLightElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGFEDistantLightElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGFEDistantLightElement: { @@ -10287,9 +9268,27 @@ declare var SVGFEDistantLightElement: { new(): SVGFEDistantLightElement; }; +interface SVGFEDropShadowElement extends SVGElement, SVGFilterPrimitiveStandardAttributes { + readonly dx: SVGAnimatedNumber; + readonly dy: SVGAnimatedNumber; + readonly in1: SVGAnimatedString; + readonly stdDeviationX: SVGAnimatedNumber; + readonly stdDeviationY: SVGAnimatedNumber; + setStdDeviation(stdDeviationX: number, stdDeviationY: number): void; + addEventListener(type: K, listener: (this: SVGFEDropShadowElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGFEDropShadowElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; +} + +declare var SVGFEDropShadowElement: { + prototype: SVGFEDropShadowElement; + new(): SVGFEDropShadowElement; +}; + interface SVGFEFloodElement extends SVGElement, SVGFilterPrimitiveStandardAttributes { - addEventListener(type: K, listener: (this: SVGFEFloodElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGFEFloodElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGFEFloodElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGFEFloodElement: { @@ -10298,8 +9297,9 @@ declare var SVGFEFloodElement: { }; interface SVGFEFuncAElement extends SVGComponentTransferFunctionElement { - addEventListener(type: K, listener: (this: SVGFEFuncAElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGFEFuncAElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGFEFuncAElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGFEFuncAElement: { @@ -10308,8 +9308,9 @@ declare var SVGFEFuncAElement: { }; interface SVGFEFuncBElement extends SVGComponentTransferFunctionElement { - addEventListener(type: K, listener: (this: SVGFEFuncBElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGFEFuncBElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGFEFuncBElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGFEFuncBElement: { @@ -10318,8 +9319,9 @@ declare var SVGFEFuncBElement: { }; interface SVGFEFuncGElement extends SVGComponentTransferFunctionElement { - addEventListener(type: K, listener: (this: SVGFEFuncGElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGFEFuncGElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGFEFuncGElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGFEFuncGElement: { @@ -10328,8 +9330,9 @@ declare var SVGFEFuncGElement: { }; interface SVGFEFuncRElement extends SVGComponentTransferFunctionElement { - addEventListener(type: K, listener: (this: SVGFEFuncRElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGFEFuncRElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGFEFuncRElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGFEFuncRElement: { @@ -10338,23 +9341,35 @@ declare var SVGFEFuncRElement: { }; interface SVGFEGaussianBlurElement extends SVGElement, SVGFilterPrimitiveStandardAttributes { + readonly edgeMode: SVGAnimatedEnumeration; readonly in1: SVGAnimatedString; readonly stdDeviationX: SVGAnimatedNumber; readonly stdDeviationY: SVGAnimatedNumber; setStdDeviation(stdDeviationX: number, stdDeviationY: number): void; - addEventListener(type: K, listener: (this: SVGFEGaussianBlurElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + readonly SVG_EDGEMODE_DUPLICATE: number; + readonly SVG_EDGEMODE_NONE: number; + readonly SVG_EDGEMODE_UNKNOWN: number; + readonly SVG_EDGEMODE_WRAP: number; + addEventListener(type: K, listener: (this: SVGFEGaussianBlurElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGFEGaussianBlurElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGFEGaussianBlurElement: { prototype: SVGFEGaussianBlurElement; new(): SVGFEGaussianBlurElement; + readonly SVG_EDGEMODE_DUPLICATE: number; + readonly SVG_EDGEMODE_NONE: number; + readonly SVG_EDGEMODE_UNKNOWN: number; + readonly SVG_EDGEMODE_WRAP: number; }; interface SVGFEImageElement extends SVGElement, SVGFilterPrimitiveStandardAttributes, SVGURIReference { + readonly crossOrigin: SVGAnimatedString; readonly preserveAspectRatio: SVGAnimatedPreserveAspectRatio; - addEventListener(type: K, listener: (this: SVGFEImageElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGFEImageElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGFEImageElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGFEImageElement: { @@ -10363,8 +9378,9 @@ declare var SVGFEImageElement: { }; interface SVGFEMergeElement extends SVGElement, SVGFilterPrimitiveStandardAttributes { - addEventListener(type: K, listener: (this: SVGFEMergeElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGFEMergeElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGFEMergeElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGFEMergeElement: { @@ -10374,8 +9390,9 @@ declare var SVGFEMergeElement: { interface SVGFEMergeNodeElement extends SVGElement { readonly in1: SVGAnimatedString; - addEventListener(type: K, listener: (this: SVGFEMergeNodeElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGFEMergeNodeElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGFEMergeNodeElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGFEMergeNodeElement: { @@ -10391,8 +9408,9 @@ interface SVGFEMorphologyElement extends SVGElement, SVGFilterPrimitiveStandardA readonly SVG_MORPHOLOGY_OPERATOR_DILATE: number; readonly SVG_MORPHOLOGY_OPERATOR_ERODE: number; readonly SVG_MORPHOLOGY_OPERATOR_UNKNOWN: number; - addEventListener(type: K, listener: (this: SVGFEMorphologyElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGFEMorphologyElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGFEMorphologyElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGFEMorphologyElement: { @@ -10407,8 +9425,9 @@ interface SVGFEOffsetElement extends SVGElement, SVGFilterPrimitiveStandardAttri readonly dx: SVGAnimatedNumber; readonly dy: SVGAnimatedNumber; readonly in1: SVGAnimatedString; - addEventListener(type: K, listener: (this: SVGFEOffsetElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGFEOffsetElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGFEOffsetElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGFEOffsetElement: { @@ -10420,8 +9439,9 @@ interface SVGFEPointLightElement extends SVGElement { readonly x: SVGAnimatedNumber; readonly y: SVGAnimatedNumber; readonly z: SVGAnimatedNumber; - addEventListener(type: K, listener: (this: SVGFEPointLightElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGFEPointLightElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGFEPointLightElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGFEPointLightElement: { @@ -10436,8 +9456,9 @@ interface SVGFESpecularLightingElement extends SVGElement, SVGFilterPrimitiveSta readonly specularConstant: SVGAnimatedNumber; readonly specularExponent: SVGAnimatedNumber; readonly surfaceScale: SVGAnimatedNumber; - addEventListener(type: K, listener: (this: SVGFESpecularLightingElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGFESpecularLightingElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGFESpecularLightingElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGFESpecularLightingElement: { @@ -10454,8 +9475,9 @@ interface SVGFESpotLightElement extends SVGElement { readonly x: SVGAnimatedNumber; readonly y: SVGAnimatedNumber; readonly z: SVGAnimatedNumber; - addEventListener(type: K, listener: (this: SVGFESpotLightElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGFESpotLightElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGFESpotLightElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGFESpotLightElement: { @@ -10465,8 +9487,9 @@ declare var SVGFESpotLightElement: { interface SVGFETileElement extends SVGElement, SVGFilterPrimitiveStandardAttributes { readonly in1: SVGAnimatedString; - addEventListener(type: K, listener: (this: SVGFETileElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGFETileElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGFETileElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGFETileElement: { @@ -10487,8 +9510,9 @@ interface SVGFETurbulenceElement extends SVGElement, SVGFilterPrimitiveStandardA readonly SVG_TURBULENCE_TYPE_FRACTALNOISE: number; readonly SVG_TURBULENCE_TYPE_TURBULENCE: number; readonly SVG_TURBULENCE_TYPE_UNKNOWN: number; - addEventListener(type: K, listener: (this: SVGFETurbulenceElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGFETurbulenceElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGFETurbulenceElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGFETurbulenceElement: { @@ -10502,18 +9526,16 @@ declare var SVGFETurbulenceElement: { readonly SVG_TURBULENCE_TYPE_UNKNOWN: number; }; -interface SVGFilterElement extends SVGElement, SVGUnitTypes, SVGURIReference { - readonly filterResX: SVGAnimatedInteger; - readonly filterResY: SVGAnimatedInteger; +interface SVGFilterElement extends SVGElement, SVGURIReference, SVGUnitTypes { readonly filterUnits: SVGAnimatedEnumeration; readonly height: SVGAnimatedLength; readonly primitiveUnits: SVGAnimatedEnumeration; readonly width: SVGAnimatedLength; readonly x: SVGAnimatedLength; readonly y: SVGAnimatedLength; - setFilterRes(filterResX: number, filterResY: number): void; - addEventListener(type: K, listener: (this: SVGFilterElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGFilterElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGFilterElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGFilterElement: { @@ -10526,8 +9548,9 @@ interface SVGForeignObjectElement extends SVGGraphicsElement { readonly width: SVGAnimatedLength; readonly x: SVGAnimatedLength; readonly y: SVGAnimatedLength; - addEventListener(type: K, listener: (this: SVGForeignObjectElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGForeignObjectElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGForeignObjectElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGForeignObjectElement: { @@ -10536,8 +9559,9 @@ declare var SVGForeignObjectElement: { }; interface SVGGElement extends SVGGraphicsElement { - addEventListener(type: K, listener: (this: SVGGElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGGElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGGElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGGElement: { @@ -10545,7 +9569,23 @@ declare var SVGGElement: { new(): SVGGElement; }; -interface SVGGradientElement extends SVGElement, SVGUnitTypes, SVGURIReference { +interface SVGGeometryElement extends SVGGraphicsElement { + readonly pathLength: SVGAnimatedNumber; + getPointAtLength(distance: number): DOMPoint; + getTotalLength(): number; + isPointInFill(point: DOMPoint): boolean; + isPointInStroke(point: DOMPoint): boolean; + addEventListener(type: K, listener: (this: SVGGeometryElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGGeometryElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; +} + +declare var SVGGeometryElement: { + prototype: SVGGeometryElement; + new(): SVGGeometryElement; +}; + +interface SVGGradientElement extends SVGElement, SVGURIReference { readonly gradientTransform: SVGAnimatedTransformList; readonly gradientUnits: SVGAnimatedEnumeration; readonly spreadMethod: SVGAnimatedEnumeration; @@ -10553,8 +9593,9 @@ interface SVGGradientElement extends SVGElement, SVGUnitTypes, SVGURIReference { readonly SVG_SPREADMETHOD_REFLECT: number; readonly SVG_SPREADMETHOD_REPEAT: number; readonly SVG_SPREADMETHOD_UNKNOWN: number; - addEventListener(type: K, listener: (this: SVGGradientElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGGradientElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGGradientElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGGradientElement: { @@ -10567,15 +9608,13 @@ declare var SVGGradientElement: { }; interface SVGGraphicsElement extends SVGElement, SVGTests { - readonly farthestViewportElement: SVGElement; - readonly nearestViewportElement: SVGElement; readonly transform: SVGAnimatedTransformList; - getBBox(): SVGRect; - getCTM(): SVGMatrix; - getScreenCTM(): SVGMatrix; - getTransformToElement(element: SVGElement): SVGMatrix; - addEventListener(type: K, listener: (this: SVGGraphicsElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + getBBox(options?: SVGBoundingBoxOptions): DOMRect; + getCTM(): DOMMatrix | null; + getScreenCTM(): DOMMatrix | null; + addEventListener(type: K, listener: (this: SVGGraphicsElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGGraphicsElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGGraphicsElement: { @@ -10583,14 +9622,38 @@ declare var SVGGraphicsElement: { new(): SVGGraphicsElement; }; +interface SVGHatchElement extends SVGElement { + addEventListener(type: K, listener: (this: SVGHatchElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGHatchElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; +} + +declare var SVGHatchElement: { + prototype: SVGHatchElement; + new(): SVGHatchElement; +}; + +interface SVGHatchpathElement extends SVGElement { + addEventListener(type: K, listener: (this: SVGHatchpathElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGHatchpathElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; +} + +declare var SVGHatchpathElement: { + prototype: SVGHatchpathElement; + new(): SVGHatchpathElement; +}; + interface SVGImageElement extends SVGGraphicsElement, SVGURIReference { + crossOrigin: string | null; readonly height: SVGAnimatedLength; readonly preserveAspectRatio: SVGAnimatedPreserveAspectRatio; readonly width: SVGAnimatedLength; readonly x: SVGAnimatedLength; readonly y: SVGAnimatedLength; - addEventListener(type: K, listener: (this: SVGImageElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGImageElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGImageElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGImageElement: { @@ -10635,6 +9698,7 @@ declare var SVGLength: { }; interface SVGLengthList { + readonly length: number; readonly numberOfItems: number; appendItem(newItem: SVGLength): SVGLength; clear(): void; @@ -10643,6 +9707,7 @@ interface SVGLengthList { insertItemBefore(newItem: SVGLength, index: number): SVGLength; removeItem(index: number): SVGLength; replaceItem(newItem: SVGLength, index: number): SVGLength; + [index: number]: SVGLength; } declare var SVGLengthList: { @@ -10655,8 +9720,9 @@ interface SVGLinearGradientElement extends SVGGradientElement { readonly x2: SVGAnimatedLength; readonly y1: SVGAnimatedLength; readonly y2: SVGAnimatedLength; - addEventListener(type: K, listener: (this: SVGLinearGradientElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGLinearGradientElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGLinearGradientElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGLinearGradientElement: { @@ -10664,13 +9730,14 @@ declare var SVGLinearGradientElement: { new(): SVGLinearGradientElement; }; -interface SVGLineElement extends SVGGraphicsElement { +interface SVGLineElement extends SVGGeometryElement { readonly x1: SVGAnimatedLength; readonly x2: SVGAnimatedLength; readonly y1: SVGAnimatedLength; readonly y2: SVGAnimatedLength; - addEventListener(type: K, listener: (this: SVGLineElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGLineElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGLineElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGLineElement: { @@ -10682,6 +9749,7 @@ interface SVGMarkerElement extends SVGElement, SVGFitToViewBox { readonly markerHeight: SVGAnimatedLength; readonly markerUnits: SVGAnimatedEnumeration; readonly markerWidth: SVGAnimatedLength; + orient: string; readonly orientAngle: SVGAnimatedAngle; readonly orientType: SVGAnimatedEnumeration; readonly refX: SVGAnimatedLength; @@ -10694,8 +9762,9 @@ interface SVGMarkerElement extends SVGElement, SVGFitToViewBox { readonly SVG_MARKERUNITS_STROKEWIDTH: number; readonly SVG_MARKERUNITS_UNKNOWN: number; readonly SVG_MARKERUNITS_USERSPACEONUSE: number; - addEventListener(type: K, listener: (this: SVGMarkerElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGMarkerElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGMarkerElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGMarkerElement: { @@ -10709,15 +9778,16 @@ declare var SVGMarkerElement: { readonly SVG_MARKERUNITS_USERSPACEONUSE: number; }; -interface SVGMaskElement extends SVGElement, SVGTests, SVGUnitTypes { +interface SVGMaskElement extends SVGElement, SVGUnitTypes { readonly height: SVGAnimatedLength; readonly maskContentUnits: SVGAnimatedEnumeration; readonly maskUnits: SVGAnimatedEnumeration; readonly width: SVGAnimatedLength; readonly x: SVGAnimatedLength; readonly y: SVGAnimatedLength; - addEventListener(type: K, listener: (this: SVGMaskElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGMaskElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGMaskElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGMaskElement: { @@ -10725,34 +9795,54 @@ declare var SVGMaskElement: { new(): SVGMaskElement; }; -interface SVGMatrix { - a: number; - b: number; - c: number; - d: number; - e: number; - f: number; - flipX(): SVGMatrix; - flipY(): SVGMatrix; - inverse(): SVGMatrix; - multiply(secondMatrix: SVGMatrix): SVGMatrix; - rotate(angle: number): SVGMatrix; - rotateFromVector(x: number, y: number): SVGMatrix; - scale(scaleFactor: number): SVGMatrix; - scaleNonUniform(scaleFactorX: number, scaleFactorY: number): SVGMatrix; - skewX(angle: number): SVGMatrix; - skewY(angle: number): SVGMatrix; - translate(x: number, y: number): SVGMatrix; +interface SVGMeshElement extends SVGGeometryElement, SVGURIReference { + addEventListener(type: K, listener: (this: SVGMeshElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGMeshElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; +} + +declare var SVGMeshElement: { + prototype: SVGMeshElement; + new(): SVGMeshElement; +}; + +interface SVGMeshGradientElement extends SVGGradientElement { + addEventListener(type: K, listener: (this: SVGMeshGradientElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGMeshGradientElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; +} + +declare var SVGMeshGradientElement: { + prototype: SVGMeshGradientElement; + new(): SVGMeshGradientElement; +}; + +interface SVGMeshpatchElement extends SVGElement { + addEventListener(type: K, listener: (this: SVGMeshpatchElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGMeshpatchElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; +} + +declare var SVGMeshpatchElement: { + prototype: SVGMeshpatchElement; + new(): SVGMeshpatchElement; +}; + +interface SVGMeshrowElement extends SVGElement { + addEventListener(type: K, listener: (this: SVGMeshrowElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGMeshrowElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } -declare var SVGMatrix: { - prototype: SVGMatrix; - new(): SVGMatrix; +declare var SVGMeshrowElement: { + prototype: SVGMeshrowElement; + new(): SVGMeshrowElement; }; interface SVGMetadataElement extends SVGElement { - addEventListener(type: K, listener: (this: SVGMetadataElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGMetadataElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGMetadataElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGMetadataElement: { @@ -10770,6 +9860,7 @@ declare var SVGNumber: { }; interface SVGNumberList { + readonly length: number; readonly numberOfItems: number; appendItem(newItem: SVGNumber): SVGNumber; clear(): void; @@ -10778,6 +9869,7 @@ interface SVGNumberList { insertItemBefore(newItem: SVGNumber, index: number): SVGNumber; removeItem(index: number): SVGNumber; replaceItem(newItem: SVGNumber, index: number): SVGNumber; + [index: number]: SVGNumber; } declare var SVGNumberList: { @@ -10785,32 +9877,10 @@ declare var SVGNumberList: { new(): SVGNumberList; }; -interface SVGPathElement extends SVGGraphicsElement { - readonly pathSegList: SVGPathSegList; - createSVGPathSegArcAbs(x: number, y: number, r1: number, r2: number, angle: number, largeArcFlag: boolean, sweepFlag: boolean): SVGPathSegArcAbs; - createSVGPathSegArcRel(x: number, y: number, r1: number, r2: number, angle: number, largeArcFlag: boolean, sweepFlag: boolean): SVGPathSegArcRel; - createSVGPathSegClosePath(): SVGPathSegClosePath; - createSVGPathSegCurvetoCubicAbs(x: number, y: number, x1: number, y1: number, x2: number, y2: number): SVGPathSegCurvetoCubicAbs; - createSVGPathSegCurvetoCubicRel(x: number, y: number, x1: number, y1: number, x2: number, y2: number): SVGPathSegCurvetoCubicRel; - createSVGPathSegCurvetoCubicSmoothAbs(x: number, y: number, x2: number, y2: number): SVGPathSegCurvetoCubicSmoothAbs; - createSVGPathSegCurvetoCubicSmoothRel(x: number, y: number, x2: number, y2: number): SVGPathSegCurvetoCubicSmoothRel; - createSVGPathSegCurvetoQuadraticAbs(x: number, y: number, x1: number, y1: number): SVGPathSegCurvetoQuadraticAbs; - createSVGPathSegCurvetoQuadraticRel(x: number, y: number, x1: number, y1: number): SVGPathSegCurvetoQuadraticRel; - createSVGPathSegCurvetoQuadraticSmoothAbs(x: number, y: number): SVGPathSegCurvetoQuadraticSmoothAbs; - createSVGPathSegCurvetoQuadraticSmoothRel(x: number, y: number): SVGPathSegCurvetoQuadraticSmoothRel; - createSVGPathSegLinetoAbs(x: number, y: number): SVGPathSegLinetoAbs; - createSVGPathSegLinetoHorizontalAbs(x: number): SVGPathSegLinetoHorizontalAbs; - createSVGPathSegLinetoHorizontalRel(x: number): SVGPathSegLinetoHorizontalRel; - createSVGPathSegLinetoRel(x: number, y: number): SVGPathSegLinetoRel; - createSVGPathSegLinetoVerticalAbs(y: number): SVGPathSegLinetoVerticalAbs; - createSVGPathSegLinetoVerticalRel(y: number): SVGPathSegLinetoVerticalRel; - createSVGPathSegMovetoAbs(x: number, y: number): SVGPathSegMovetoAbs; - createSVGPathSegMovetoRel(x: number, y: number): SVGPathSegMovetoRel; - getPathSegAtLength(distance: number): number; - getPointAtLength(distance: number): SVGPoint; - getTotalLength(): number; - addEventListener(type: K, listener: (this: SVGPathElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; +interface SVGPathElement extends SVGGeometryElement { + addEventListener(type: K, listener: (this: SVGPathElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGPathElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGPathElement: { @@ -10818,344 +9888,62 @@ declare var SVGPathElement: { new(): SVGPathElement; }; -interface SVGPathSeg { - readonly pathSegType: number; - readonly pathSegTypeAsLetter: string; - readonly PATHSEG_ARC_ABS: number; - readonly PATHSEG_ARC_REL: number; - readonly PATHSEG_CLOSEPATH: number; - readonly PATHSEG_CURVETO_CUBIC_ABS: number; - readonly PATHSEG_CURVETO_CUBIC_REL: number; - readonly PATHSEG_CURVETO_CUBIC_SMOOTH_ABS: number; - readonly PATHSEG_CURVETO_CUBIC_SMOOTH_REL: number; - readonly PATHSEG_CURVETO_QUADRATIC_ABS: number; - readonly PATHSEG_CURVETO_QUADRATIC_REL: number; - readonly PATHSEG_CURVETO_QUADRATIC_SMOOTH_ABS: number; - readonly PATHSEG_CURVETO_QUADRATIC_SMOOTH_REL: number; - readonly PATHSEG_LINETO_ABS: number; - readonly PATHSEG_LINETO_HORIZONTAL_ABS: number; - readonly PATHSEG_LINETO_HORIZONTAL_REL: number; - readonly PATHSEG_LINETO_REL: number; - readonly PATHSEG_LINETO_VERTICAL_ABS: number; - readonly PATHSEG_LINETO_VERTICAL_REL: number; - readonly PATHSEG_MOVETO_ABS: number; - readonly PATHSEG_MOVETO_REL: number; - readonly PATHSEG_UNKNOWN: number; -} - -declare var SVGPathSeg: { - prototype: SVGPathSeg; - new(): SVGPathSeg; - readonly PATHSEG_ARC_ABS: number; - readonly PATHSEG_ARC_REL: number; - readonly PATHSEG_CLOSEPATH: number; - readonly PATHSEG_CURVETO_CUBIC_ABS: number; - readonly PATHSEG_CURVETO_CUBIC_REL: number; - readonly PATHSEG_CURVETO_CUBIC_SMOOTH_ABS: number; - readonly PATHSEG_CURVETO_CUBIC_SMOOTH_REL: number; - readonly PATHSEG_CURVETO_QUADRATIC_ABS: number; - readonly PATHSEG_CURVETO_QUADRATIC_REL: number; - readonly PATHSEG_CURVETO_QUADRATIC_SMOOTH_ABS: number; - readonly PATHSEG_CURVETO_QUADRATIC_SMOOTH_REL: number; - readonly PATHSEG_LINETO_ABS: number; - readonly PATHSEG_LINETO_HORIZONTAL_ABS: number; - readonly PATHSEG_LINETO_HORIZONTAL_REL: number; - readonly PATHSEG_LINETO_REL: number; - readonly PATHSEG_LINETO_VERTICAL_ABS: number; - readonly PATHSEG_LINETO_VERTICAL_REL: number; - readonly PATHSEG_MOVETO_ABS: number; - readonly PATHSEG_MOVETO_REL: number; - readonly PATHSEG_UNKNOWN: number; -}; - -interface SVGPathSegArcAbs extends SVGPathSeg { - angle: number; - largeArcFlag: boolean; - r1: number; - r2: number; - sweepFlag: boolean; - x: number; - y: number; -} - -declare var SVGPathSegArcAbs: { - prototype: SVGPathSegArcAbs; - new(): SVGPathSegArcAbs; -}; - -interface SVGPathSegArcRel extends SVGPathSeg { - angle: number; - largeArcFlag: boolean; - r1: number; - r2: number; - sweepFlag: boolean; - x: number; - y: number; +interface SVGPatternElement extends SVGElement, SVGFitToViewBox, SVGURIReference { + readonly height: SVGAnimatedLength; + readonly patternContentUnits: SVGAnimatedEnumeration; + readonly patternTransform: SVGAnimatedTransformList; + readonly patternUnits: SVGAnimatedEnumeration; + readonly width: SVGAnimatedLength; + readonly x: SVGAnimatedLength; + readonly y: SVGAnimatedLength; + addEventListener(type: K, listener: (this: SVGPatternElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGPatternElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } -declare var SVGPathSegArcRel: { - prototype: SVGPathSegArcRel; - new(): SVGPathSegArcRel; +declare var SVGPatternElement: { + prototype: SVGPatternElement; + new(): SVGPatternElement; }; -interface SVGPathSegClosePath extends SVGPathSeg { +interface SVGPointList { + readonly length: number; + readonly numberOfItems: number; + appendItem(newItem: DOMPoint): DOMPoint; + clear(): void; + getItem(index: number): DOMPoint; + initialize(newItem: DOMPoint): DOMPoint; + insertItemBefore(newItem: DOMPoint, index: number): DOMPoint; + removeItem(index: number): DOMPoint; + replaceItem(newItem: DOMPoint, index: number): DOMPoint; + [index: number]: DOMPoint; } -declare var SVGPathSegClosePath: { - prototype: SVGPathSegClosePath; - new(): SVGPathSegClosePath; +declare var SVGPointList: { + prototype: SVGPointList; + new(): SVGPointList; }; -interface SVGPathSegCurvetoCubicAbs extends SVGPathSeg { - x: number; - x1: number; - x2: number; - y: number; - y1: number; - y2: number; +interface SVGPolygonElement extends SVGGeometryElement, SVGAnimatedPoints { + addEventListener(type: K, listener: (this: SVGPolygonElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGPolygonElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } -declare var SVGPathSegCurvetoCubicAbs: { - prototype: SVGPathSegCurvetoCubicAbs; - new(): SVGPathSegCurvetoCubicAbs; +declare var SVGPolygonElement: { + prototype: SVGPolygonElement; + new(): SVGPolygonElement; }; -interface SVGPathSegCurvetoCubicRel extends SVGPathSeg { - x: number; - x1: number; - x2: number; - y: number; - y1: number; - y2: number; +interface SVGPolylineElement extends SVGGeometryElement, SVGAnimatedPoints { + addEventListener(type: K, listener: (this: SVGPolylineElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGPolylineElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } -declare var SVGPathSegCurvetoCubicRel: { - prototype: SVGPathSegCurvetoCubicRel; - new(): SVGPathSegCurvetoCubicRel; -}; - -interface SVGPathSegCurvetoCubicSmoothAbs extends SVGPathSeg { - x: number; - x2: number; - y: number; - y2: number; -} - -declare var SVGPathSegCurvetoCubicSmoothAbs: { - prototype: SVGPathSegCurvetoCubicSmoothAbs; - new(): SVGPathSegCurvetoCubicSmoothAbs; -}; - -interface SVGPathSegCurvetoCubicSmoothRel extends SVGPathSeg { - x: number; - x2: number; - y: number; - y2: number; -} - -declare var SVGPathSegCurvetoCubicSmoothRel: { - prototype: SVGPathSegCurvetoCubicSmoothRel; - new(): SVGPathSegCurvetoCubicSmoothRel; -}; - -interface SVGPathSegCurvetoQuadraticAbs extends SVGPathSeg { - x: number; - x1: number; - y: number; - y1: number; -} - -declare var SVGPathSegCurvetoQuadraticAbs: { - prototype: SVGPathSegCurvetoQuadraticAbs; - new(): SVGPathSegCurvetoQuadraticAbs; -}; - -interface SVGPathSegCurvetoQuadraticRel extends SVGPathSeg { - x: number; - x1: number; - y: number; - y1: number; -} - -declare var SVGPathSegCurvetoQuadraticRel: { - prototype: SVGPathSegCurvetoQuadraticRel; - new(): SVGPathSegCurvetoQuadraticRel; -}; - -interface SVGPathSegCurvetoQuadraticSmoothAbs extends SVGPathSeg { - x: number; - y: number; -} - -declare var SVGPathSegCurvetoQuadraticSmoothAbs: { - prototype: SVGPathSegCurvetoQuadraticSmoothAbs; - new(): SVGPathSegCurvetoQuadraticSmoothAbs; -}; - -interface SVGPathSegCurvetoQuadraticSmoothRel extends SVGPathSeg { - x: number; - y: number; -} - -declare var SVGPathSegCurvetoQuadraticSmoothRel: { - prototype: SVGPathSegCurvetoQuadraticSmoothRel; - new(): SVGPathSegCurvetoQuadraticSmoothRel; -}; - -interface SVGPathSegLinetoAbs extends SVGPathSeg { - x: number; - y: number; -} - -declare var SVGPathSegLinetoAbs: { - prototype: SVGPathSegLinetoAbs; - new(): SVGPathSegLinetoAbs; -}; - -interface SVGPathSegLinetoHorizontalAbs extends SVGPathSeg { - x: number; -} - -declare var SVGPathSegLinetoHorizontalAbs: { - prototype: SVGPathSegLinetoHorizontalAbs; - new(): SVGPathSegLinetoHorizontalAbs; -}; - -interface SVGPathSegLinetoHorizontalRel extends SVGPathSeg { - x: number; -} - -declare var SVGPathSegLinetoHorizontalRel: { - prototype: SVGPathSegLinetoHorizontalRel; - new(): SVGPathSegLinetoHorizontalRel; -}; - -interface SVGPathSegLinetoRel extends SVGPathSeg { - x: number; - y: number; -} - -declare var SVGPathSegLinetoRel: { - prototype: SVGPathSegLinetoRel; - new(): SVGPathSegLinetoRel; -}; - -interface SVGPathSegLinetoVerticalAbs extends SVGPathSeg { - y: number; -} - -declare var SVGPathSegLinetoVerticalAbs: { - prototype: SVGPathSegLinetoVerticalAbs; - new(): SVGPathSegLinetoVerticalAbs; -}; - -interface SVGPathSegLinetoVerticalRel extends SVGPathSeg { - y: number; -} - -declare var SVGPathSegLinetoVerticalRel: { - prototype: SVGPathSegLinetoVerticalRel; - new(): SVGPathSegLinetoVerticalRel; -}; - -interface SVGPathSegList { - readonly numberOfItems: number; - appendItem(newItem: SVGPathSeg): SVGPathSeg; - clear(): void; - getItem(index: number): SVGPathSeg; - initialize(newItem: SVGPathSeg): SVGPathSeg; - insertItemBefore(newItem: SVGPathSeg, index: number): SVGPathSeg; - removeItem(index: number): SVGPathSeg; - replaceItem(newItem: SVGPathSeg, index: number): SVGPathSeg; -} - -declare var SVGPathSegList: { - prototype: SVGPathSegList; - new(): SVGPathSegList; -}; - -interface SVGPathSegMovetoAbs extends SVGPathSeg { - x: number; - y: number; -} - -declare var SVGPathSegMovetoAbs: { - prototype: SVGPathSegMovetoAbs; - new(): SVGPathSegMovetoAbs; -}; - -interface SVGPathSegMovetoRel extends SVGPathSeg { - x: number; - y: number; -} - -declare var SVGPathSegMovetoRel: { - prototype: SVGPathSegMovetoRel; - new(): SVGPathSegMovetoRel; -}; - -interface SVGPatternElement extends SVGElement, SVGTests, SVGUnitTypes, SVGFitToViewBox, SVGURIReference { - readonly height: SVGAnimatedLength; - readonly patternContentUnits: SVGAnimatedEnumeration; - readonly patternTransform: SVGAnimatedTransformList; - readonly patternUnits: SVGAnimatedEnumeration; - readonly width: SVGAnimatedLength; - readonly x: SVGAnimatedLength; - readonly y: SVGAnimatedLength; - addEventListener(type: K, listener: (this: SVGPatternElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; -} - -declare var SVGPatternElement: { - prototype: SVGPatternElement; - new(): SVGPatternElement; -}; - -interface SVGPoint { - x: number; - y: number; - matrixTransform(matrix: SVGMatrix): SVGPoint; -} - -declare var SVGPoint: { - prototype: SVGPoint; - new(): SVGPoint; -}; - -interface SVGPointList { - readonly numberOfItems: number; - appendItem(newItem: SVGPoint): SVGPoint; - clear(): void; - getItem(index: number): SVGPoint; - initialize(newItem: SVGPoint): SVGPoint; - insertItemBefore(newItem: SVGPoint, index: number): SVGPoint; - removeItem(index: number): SVGPoint; - replaceItem(newItem: SVGPoint, index: number): SVGPoint; -} - -declare var SVGPointList: { - prototype: SVGPointList; - new(): SVGPointList; -}; - -interface SVGPolygonElement extends SVGGraphicsElement, SVGAnimatedPoints { - addEventListener(type: K, listener: (this: SVGPolygonElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; -} - -declare var SVGPolygonElement: { - prototype: SVGPolygonElement; - new(): SVGPolygonElement; -}; - -interface SVGPolylineElement extends SVGGraphicsElement, SVGAnimatedPoints { - addEventListener(type: K, listener: (this: SVGPolylineElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; -} - -declare var SVGPolylineElement: { - prototype: SVGPolylineElement; - new(): SVGPolylineElement; +declare var SVGPolylineElement: { + prototype: SVGPolylineElement; + new(): SVGPolylineElement; }; interface SVGPreserveAspectRatio { @@ -11199,11 +9987,13 @@ declare var SVGPreserveAspectRatio: { interface SVGRadialGradientElement extends SVGGradientElement { readonly cx: SVGAnimatedLength; readonly cy: SVGAnimatedLength; + readonly fr: SVGAnimatedLength; readonly fx: SVGAnimatedLength; readonly fy: SVGAnimatedLength; readonly r: SVGAnimatedLength; - addEventListener(type: K, listener: (this: SVGRadialGradientElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGRadialGradientElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGRadialGradientElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGRadialGradientElement: { @@ -11211,27 +10001,16 @@ declare var SVGRadialGradientElement: { new(): SVGRadialGradientElement; }; -interface SVGRect { - height: number; - width: number; - x: number; - y: number; -} - -declare var SVGRect: { - prototype: SVGRect; - new(): SVGRect; -}; - -interface SVGRectElement extends SVGGraphicsElement { +interface SVGRectElement extends SVGGeometryElement { readonly height: SVGAnimatedLength; readonly rx: SVGAnimatedLength; readonly ry: SVGAnimatedLength; readonly width: SVGAnimatedLength; readonly x: SVGAnimatedLength; readonly y: SVGAnimatedLength; - addEventListener(type: K, listener: (this: SVGRectElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGRectElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGRectElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGRectElement: { @@ -11240,9 +10019,11 @@ declare var SVGRectElement: { }; interface SVGScriptElement extends SVGElement, SVGURIReference { + crossOrigin: string | null; type: string; - addEventListener(type: K, listener: (this: SVGScriptElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGScriptElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGScriptElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGScriptElement: { @@ -11250,10 +10031,22 @@ declare var SVGScriptElement: { new(): SVGScriptElement; }; +interface SVGSolidcolorElement extends SVGElement { + addEventListener(type: K, listener: (this: SVGSolidcolorElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGSolidcolorElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; +} + +declare var SVGSolidcolorElement: { + prototype: SVGSolidcolorElement; + new(): SVGSolidcolorElement; +}; + interface SVGStopElement extends SVGElement { readonly offset: SVGAnimatedNumber; - addEventListener(type: K, listener: (this: SVGStopElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGStopElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGStopElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGStopElement: { @@ -11262,6 +10055,7 @@ declare var SVGStopElement: { }; interface SVGStringList { + readonly length: number; readonly numberOfItems: number; appendItem(newItem: string): string; clear(): void; @@ -11270,6 +10064,7 @@ interface SVGStringList { insertItemBefore(newItem: string, index: number): string; removeItem(index: number): string; replaceItem(newItem: string, index: number): string; + [index: number]: string; } declare var SVGStringList: { @@ -11277,13 +10072,13 @@ declare var SVGStringList: { new(): SVGStringList; }; -interface SVGStyleElement extends SVGElement { - disabled: boolean; +interface SVGStyleElement extends SVGElement, LinkStyle { media: string; title: string; type: string; - addEventListener(type: K, listener: (this: SVGStyleElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGStyleElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGStyleElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGStyleElement: { @@ -11291,60 +10086,35 @@ declare var SVGStyleElement: { new(): SVGStyleElement; }; -interface SVGSVGElementEventMap extends SVGElementEventMap { - "SVGAbort": Event; - "SVGError": Event; - "resize": UIEvent; - "scroll": UIEvent; - "SVGUnload": Event; - "SVGZoom": SVGZoomEvent; -} - -interface SVGSVGElement extends SVGGraphicsElement, DocumentEvent, SVGFitToViewBox, SVGZoomAndPan { - contentScriptType: string; - contentStyleType: string; +interface SVGSVGElement extends SVGGraphicsElement, SVGFitToViewBox, SVGZoomAndPan, WindowEventHandlers { currentScale: number; - readonly currentTranslate: SVGPoint; + readonly currentTranslate: DOMPointReadOnly; readonly height: SVGAnimatedLength; - onabort: (this: SVGSVGElement, ev: Event) => any; - onerror: (this: SVGSVGElement, ev: Event) => any; - onresize: (this: SVGSVGElement, ev: UIEvent) => any; - onscroll: (this: SVGSVGElement, ev: UIEvent) => any; - onunload: (this: SVGSVGElement, ev: Event) => any; - onzoom: (this: SVGSVGElement, ev: SVGZoomEvent) => any; - readonly pixelUnitToMillimeterX: number; - readonly pixelUnitToMillimeterY: number; - readonly screenPixelToMillimeterX: number; - readonly screenPixelToMillimeterY: number; - readonly viewport: SVGRect; readonly width: SVGAnimatedLength; readonly x: SVGAnimatedLength; readonly y: SVGAnimatedLength; - checkEnclosure(element: SVGElement, rect: SVGRect): boolean; - checkIntersection(element: SVGElement, rect: SVGRect): boolean; + checkEnclosure(element: SVGElement, rect: DOMRectReadOnly): boolean; + checkIntersection(element: SVGElement, rect: DOMRectReadOnly): boolean; createSVGAngle(): SVGAngle; createSVGLength(): SVGLength; - createSVGMatrix(): SVGMatrix; + createSVGMatrix(): DOMMatrix; createSVGNumber(): SVGNumber; - createSVGPoint(): SVGPoint; - createSVGRect(): SVGRect; + createSVGPoint(): DOMPoint; + createSVGRect(): DOMRect; createSVGTransform(): SVGTransform; - createSVGTransformFromMatrix(matrix: SVGMatrix): SVGTransform; + createSVGTransformFromMatrix(matrix: DOMMatrixReadOnly): SVGTransform; deselectAll(): void; forceRedraw(): void; - getComputedStyle(elt: Element, pseudoElt?: string): CSSStyleDeclaration; - getCurrentTime(): number; getElementById(elementId: string): Element; - getEnclosureList(rect: SVGRect, referenceElement: SVGElement): NodeListOf; - getIntersectionList(rect: SVGRect, referenceElement: SVGElement): NodeListOf; - pauseAnimations(): void; - setCurrentTime(seconds: number): void; + getEnclosureList(rect: DOMRectReadOnly, referenceElement: SVGElement): NodeListOf; + getIntersectionList(rect: DOMRectReadOnly, referenceElement: SVGElement): NodeListOf; suspendRedraw(maxWaitMilliseconds: number): number; - unpauseAnimations(): void; unsuspendRedraw(suspendHandleID: number): void; unsuspendRedrawAll(): void; - addEventListener(type: K, listener: (this: SVGSVGElement, ev: SVGSVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGSVGElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGSVGElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGSVGElement, ev: WindowEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGSVGElement: { @@ -11353,8 +10123,9 @@ declare var SVGSVGElement: { }; interface SVGSwitchElement extends SVGGraphicsElement { - addEventListener(type: K, listener: (this: SVGSwitchElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGSwitchElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGSwitchElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGSwitchElement: { @@ -11362,9 +10133,10 @@ declare var SVGSwitchElement: { new(): SVGSwitchElement; }; -interface SVGSymbolElement extends SVGElement, SVGFitToViewBox { - addEventListener(type: K, listener: (this: SVGSymbolElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; +interface SVGSymbolElement extends SVGGraphicsElement, SVGFitToViewBox { + addEventListener(type: K, listener: (this: SVGSymbolElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGSymbolElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGSymbolElement: { @@ -11375,20 +10147,21 @@ declare var SVGSymbolElement: { interface SVGTextContentElement extends SVGGraphicsElement { readonly lengthAdjust: SVGAnimatedEnumeration; readonly textLength: SVGAnimatedLength; - getCharNumAtPosition(point: SVGPoint): number; + getCharNumAtPosition(point: DOMPoint): number; getComputedTextLength(): number; - getEndPositionOfChar(charnum: number): SVGPoint; - getExtentOfChar(charnum: number): SVGRect; + getEndPositionOfChar(charnum: number): DOMPoint; + getExtentOfChar(charnum: number): DOMRect; getNumberOfChars(): number; getRotationOfChar(charnum: number): number; - getStartPositionOfChar(charnum: number): SVGPoint; + getStartPositionOfChar(charnum: number): DOMPoint; getSubStringLength(charnum: number, nchars: number): number; selectSubString(charnum: number, nchars: number): void; readonly LENGTHADJUST_SPACING: number; readonly LENGTHADJUST_SPACINGANDGLYPHS: number; readonly LENGTHADJUST_UNKNOWN: number; - addEventListener(type: K, listener: (this: SVGTextContentElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGTextContentElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGTextContentElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGTextContentElement: { @@ -11400,8 +10173,9 @@ declare var SVGTextContentElement: { }; interface SVGTextElement extends SVGTextPositioningElement { - addEventListener(type: K, listener: (this: SVGTextElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGTextElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGTextElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGTextElement: { @@ -11419,8 +10193,9 @@ interface SVGTextPathElement extends SVGTextContentElement, SVGURIReference { readonly TEXTPATH_SPACINGTYPE_AUTO: number; readonly TEXTPATH_SPACINGTYPE_EXACT: number; readonly TEXTPATH_SPACINGTYPE_UNKNOWN: number; - addEventListener(type: K, listener: (this: SVGTextPathElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGTextPathElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGTextPathElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGTextPathElement: { @@ -11440,8 +10215,9 @@ interface SVGTextPositioningElement extends SVGTextContentElement { readonly rotate: SVGAnimatedNumberList; readonly x: SVGAnimatedLengthList; readonly y: SVGAnimatedLengthList; - addEventListener(type: K, listener: (this: SVGTextPositioningElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGTextPositioningElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGTextPositioningElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGTextPositioningElement: { @@ -11450,8 +10226,9 @@ declare var SVGTextPositioningElement: { }; interface SVGTitleElement extends SVGElement { - addEventListener(type: K, listener: (this: SVGTitleElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGTitleElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGTitleElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGTitleElement: { @@ -11461,9 +10238,9 @@ declare var SVGTitleElement: { interface SVGTransform { readonly angle: number; - readonly matrix: SVGMatrix; + readonly matrix: DOMMatrix; readonly type: number; - setMatrix(matrix: SVGMatrix): void; + setMatrix(matrix: DOMMatrixReadOnly): void; setRotate(angle: number, cx: number, cy: number): void; setScale(sx: number, sy: number): void; setSkewX(angle: number): void; @@ -11491,16 +10268,18 @@ declare var SVGTransform: { }; interface SVGTransformList { + readonly length: number; readonly numberOfItems: number; appendItem(newItem: SVGTransform): SVGTransform; clear(): void; - consolidate(): SVGTransform; - createSVGTransformFromMatrix(matrix: SVGMatrix): SVGTransform; + consolidate(): SVGTransform | null; + createSVGTransformFromMatrix(matrix: DOMMatrixReadOnly): SVGTransform; getItem(index: number): SVGTransform; initialize(newItem: SVGTransform): SVGTransform; insertItemBefore(newItem: SVGTransform, index: number): SVGTransform; removeItem(index: number): SVGTransform; replaceItem(newItem: SVGTransform, index: number): SVGTransform; + [index: number]: SVGTransform; } declare var SVGTransformList: { @@ -11509,8 +10288,9 @@ declare var SVGTransformList: { }; interface SVGTSpanElement extends SVGTextPositioningElement { - addEventListener(type: K, listener: (this: SVGTSpanElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGTSpanElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGTSpanElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGTSpanElement: { @@ -11523,17 +10303,36 @@ interface SVGUnitTypes { readonly SVG_UNIT_TYPE_UNKNOWN: number; readonly SVG_UNIT_TYPE_USERSPACEONUSE: number; } -declare var SVGUnitTypes: SVGUnitTypes; + +declare var SVGUnitTypes: { + prototype: SVGUnitTypes; + new(): SVGUnitTypes; + readonly SVG_UNIT_TYPE_OBJECTBOUNDINGBOX: number; + readonly SVG_UNIT_TYPE_UNKNOWN: number; + readonly SVG_UNIT_TYPE_USERSPACEONUSE: number; +}; + +interface SVGUnknownElement extends SVGGraphicsElement { + addEventListener(type: K, listener: (this: SVGUnknownElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGUnknownElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; +} + +declare var SVGUnknownElement: { + prototype: SVGUnknownElement; + new(): SVGUnknownElement; +}; interface SVGUseElement extends SVGGraphicsElement, SVGURIReference { - readonly animatedInstanceRoot: SVGElementInstance; + readonly animatedInstanceRoot: SVGElement | null; readonly height: SVGAnimatedLength; - readonly instanceRoot: SVGElementInstance; + readonly instanceRoot: SVGElement | null; readonly width: SVGAnimatedLength; readonly x: SVGAnimatedLength; readonly y: SVGAnimatedLength; - addEventListener(type: K, listener: (this: SVGUseElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGUseElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGUseElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var SVGUseElement: { @@ -11541,38 +10340,23 @@ declare var SVGUseElement: { new(): SVGUseElement; }; -interface SVGViewElement extends SVGElement, SVGZoomAndPan, SVGFitToViewBox { - readonly viewTarget: SVGStringList; - addEventListener(type: K, listener: (this: SVGViewElement, ev: SVGElementEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; -} - -declare var SVGViewElement: { - prototype: SVGViewElement; - new(): SVGViewElement; -}; - -interface SVGZoomAndPan { - readonly zoomAndPan: number; +interface SVGUseElementShadowRoot extends ShadowRoot { } -declare var SVGZoomAndPan: { - readonly SVG_ZOOMANDPAN_DISABLE: number; - readonly SVG_ZOOMANDPAN_MAGNIFY: number; - readonly SVG_ZOOMANDPAN_UNKNOWN: number; +declare var SVGUseElementShadowRoot: { + prototype: SVGUseElementShadowRoot; + new(): SVGUseElementShadowRoot; }; -interface SVGZoomEvent extends UIEvent { - readonly newScale: number; - readonly newTranslate: SVGPoint; - readonly previousScale: number; - readonly previousTranslate: SVGPoint; - readonly zoomRectScreen: SVGRect; +interface SVGViewElement extends SVGElement, SVGFitToViewBox, SVGZoomAndPan { + addEventListener(type: K, listener: (this: SVGViewElement, ev: ElementEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: K, listener: (this: SVGViewElement, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } -declare var SVGZoomEvent: { - prototype: SVGZoomEvent; - new(): SVGZoomEvent; +declare var SVGViewElement: { + prototype: SVGViewElement; + new(): SVGViewElement; }; interface SyncManager { @@ -11585,7 +10369,7 @@ declare var SyncManager: { new(): SyncManager; }; -interface Text extends CharacterData { +interface Text extends CharacterData, Slotable, GeometryUtils { readonly wholeText: string; readonly assignedSlot: HTMLSlotElement | null; splitText(offset: number): Text; @@ -11596,39 +10380,18 @@ declare var Text: { new(data?: string): Text; }; -interface TextEvent extends UIEvent { - readonly data: string; - readonly inputMethod: number; - readonly locale: string; - initTextEvent(typeArg: string, canBubbleArg: boolean, cancelableArg: boolean, viewArg: Window, dataArg: string, inputMethod: number, locale: string): void; - readonly DOM_INPUT_METHOD_DROP: number; - readonly DOM_INPUT_METHOD_HANDWRITING: number; - readonly DOM_INPUT_METHOD_IME: number; - readonly DOM_INPUT_METHOD_KEYBOARD: number; - readonly DOM_INPUT_METHOD_MULTIMODAL: number; - readonly DOM_INPUT_METHOD_OPTION: number; - readonly DOM_INPUT_METHOD_PASTE: number; - readonly DOM_INPUT_METHOD_SCRIPT: number; - readonly DOM_INPUT_METHOD_UNKNOWN: number; - readonly DOM_INPUT_METHOD_VOICE: number; -} - -declare var TextEvent: { - prototype: TextEvent; - new(): TextEvent; - readonly DOM_INPUT_METHOD_DROP: number; - readonly DOM_INPUT_METHOD_HANDWRITING: number; - readonly DOM_INPUT_METHOD_IME: number; - readonly DOM_INPUT_METHOD_KEYBOARD: number; - readonly DOM_INPUT_METHOD_MULTIMODAL: number; - readonly DOM_INPUT_METHOD_OPTION: number; - readonly DOM_INPUT_METHOD_PASTE: number; - readonly DOM_INPUT_METHOD_SCRIPT: number; - readonly DOM_INPUT_METHOD_UNKNOWN: number; - readonly DOM_INPUT_METHOD_VOICE: number; -}; - interface TextMetrics { + readonly actualBoundingBoxAscent: number; + readonly actualBoundingBoxDescent: number; + readonly actualBoundingBoxLeft: number; + readonly actualBoundingBoxRight: number; + readonly alphabeticBaseline: number; + readonly emHeightAscent: number; + readonly emHeightDescent: number; + readonly fontBoundingBoxAscent: number; + readonly fontBoundingBoxDescent: number; + readonly hangingBaseline: number; + readonly ideographicBaseline: number; readonly width: number; } @@ -11639,45 +10402,28 @@ declare var TextMetrics: { interface TextTrackEventMap { "cuechange": Event; - "error": Event; - "load": Event; } interface TextTrack extends EventTarget { - readonly activeCues: TextTrackCueList; - readonly cues: TextTrackCueList; + readonly activeCues: TextTrackCueList | null; + readonly cues: TextTrackCueList | null; + readonly id: string; readonly inBandMetadataTrackDispatchType: string; - readonly kind: string; + readonly kind: TextTrackKind; readonly label: string; readonly language: string; - mode: any; + mode: TextTrackMode; oncuechange: (this: TextTrack, ev: Event) => any; - onerror: (this: TextTrack, ev: Event) => any; - onload: (this: TextTrack, ev: Event) => any; - readonly readyState: number; + readonly sourceBuffer: SourceBuffer | null; addCue(cue: TextTrackCue): void; removeCue(cue: TextTrackCue): void; - readonly DISABLED: number; - readonly ERROR: number; - readonly HIDDEN: number; - readonly LOADED: number; - readonly LOADING: number; - readonly NONE: number; - readonly SHOWING: number; addEventListener(type: K, listener: (this: TextTrack, ev: TextTrackEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var TextTrack: { prototype: TextTrack; new(): TextTrack; - readonly DISABLED: number; - readonly ERROR: number; - readonly HIDDEN: number; - readonly LOADED: number; - readonly LOADING: number; - readonly NONE: number; - readonly SHOWING: number; }; interface TextTrackCueEventMap { @@ -11692,22 +10438,19 @@ interface TextTrackCue extends EventTarget { onexit: (this: TextTrackCue, ev: Event) => any; pauseOnExit: boolean; startTime: number; - text: string; - readonly track: TextTrack; - getCueAsHTML(): DocumentFragment; + readonly track: TextTrack | null; addEventListener(type: K, listener: (this: TextTrackCue, ev: TextTrackCueEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var TextTrackCue: { prototype: TextTrackCue; - new(startTime: number, endTime: number, text: string): TextTrackCue; + new(): TextTrackCue; }; interface TextTrackCueList { readonly length: number; - getCueById(id: string): TextTrackCue; - item(index: number): TextTrackCue; + getCueById(id: string): TextTrackCue | null; [index: number]: TextTrackCue; } @@ -11718,14 +10461,18 @@ declare var TextTrackCueList: { interface TextTrackListEventMap { "addtrack": TrackEvent; + "change": Event; + "removetrack": TrackEvent; } interface TextTrackList extends EventTarget { readonly length: number; - onaddtrack: ((this: TextTrackList, ev: TrackEvent) => any) | null; - item(index: number): TextTrack; + onaddtrack: (this: TextTrackList, ev: TrackEvent) => any; + onchange: (this: TextTrackList, ev: Event) => any; + onremovetrack: (this: TextTrackList, ev: TrackEvent) => any; + getTrackById(id: string): TextTrack | null; addEventListener(type: K, listener: (this: TextTrackList, ev: TextTrackListEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; [index: number]: TextTrack; } @@ -11746,37 +10493,41 @@ declare var TimeRanges: { }; interface Touch { + readonly altitudeAngle: number; + readonly azimuthAngle: number; readonly clientX: number; readonly clientY: number; + readonly force: number; readonly identifier: number; readonly pageX: number; readonly pageY: number; + readonly radiusX: number; + readonly radiusY: number; + readonly rotationAngle: number; readonly screenX: number; readonly screenY: number; readonly target: EventTarget; + readonly touchType: TouchType; } declare var Touch: { prototype: Touch; - new(): Touch; + new(touchInitDict: TouchInit): Touch; }; interface TouchEvent extends UIEvent { readonly altKey: boolean; readonly changedTouches: TouchList; - readonly charCode: number; readonly ctrlKey: boolean; - readonly keyCode: number; readonly metaKey: boolean; readonly shiftKey: boolean; readonly targetTouches: TouchList; readonly touches: TouchList; - readonly which: number; } declare var TouchEvent: { prototype: TouchEvent; - new(type: string, touchEventInit?: TouchEventInit): TouchEvent; + new(type: string, eventInitDict?: TouchEventInit): TouchEvent; }; interface TouchList { @@ -11796,33 +10547,32 @@ interface TrackEvent extends Event { declare var TrackEvent: { prototype: TrackEvent; - new(typeArg: string, eventInitDict?: TrackEventInit): TrackEvent; + new(type: string, eventInitDict?: TrackEventInit): TrackEvent; }; interface TransitionEvent extends Event { readonly elapsedTime: number; - readonly propertyName: string; - initTransitionEvent(typeArg: string, canBubbleArg: boolean, cancelableArg: boolean, propertyNameArg: string, elapsedTimeArg: number): void; + readonly propertyName: CSSOMString; + readonly pseudoElement: CSSOMString; } declare var TransitionEvent: { prototype: TransitionEvent; - new(typeArg: string, eventInitDict?: TransitionEventInit): TransitionEvent; + new(type: CSSOMString, transitionEventInitDict?: TransitionEventInit): TransitionEvent; }; interface TreeWalker { currentNode: Node; - readonly expandEntityReferences: boolean; - readonly filter: NodeFilter; + readonly filter: NodeFilter | null; readonly root: Node; readonly whatToShow: number; - firstChild(): Node; - lastChild(): Node; - nextNode(): Node; - nextSibling(): Node; - parentNode(): Node; - previousNode(): Node; - previousSibling(): Node; + firstChild(): Node | null; + lastChild(): Node | null; + nextNode(): Node | null; + nextSibling(): Node | null; + parentNode(): Node | null; + previousNode(): Node | null; + previousSibling(): Node | null; } declare var TreeWalker: { @@ -11832,22 +10582,12 @@ declare var TreeWalker: { interface UIEvent extends Event { readonly detail: number; - readonly view: Window; - initUIEvent(typeArg: string, canBubbleArg: boolean, cancelableArg: boolean, viewArg: Window, detailArg: number): void; + readonly view: Window | null; } declare var UIEvent: { prototype: UIEvent; - new(typeArg: string, eventInitDict?: UIEventInit): UIEvent; -}; - -interface UnviewableContentIdentifiedEvent extends NavigationEventWithReferrer { - readonly mediaType: string; -} - -declare var UnviewableContentIdentifiedEvent: { - prototype: UnviewableContentIdentifiedEvent; - new(): UnviewableContentIdentifiedEvent; + new(type: string, eventInitDict?: UIEventInit): UIEvent; }; interface URL { @@ -11861,18 +10601,52 @@ interface URL { port: string; protocol: string; search: string; - username: string; readonly searchParams: URLSearchParams; - toString(): string; + username: string; + toJSON(): string; } declare var URL: { prototype: URL; new(url: string, base?: string): URL; - createObjectURL(object: any, options?: ObjectURLOptions): string; + createObjectURL(blob: Blob): string; + createObjectURL(mediaSource: MediaSource): string; revokeObjectURL(url: string): void; }; +interface URLSearchParams { + /** + * Appends a specified key/value pair as a new search parameter. + */ + append(name: string, value: string): void; + /** + * Deletes the given search parameter, and its associated value, from the list of all search parameters. + */ + delete(name: string): void; + /** + * Returns the first value associated to the given search parameter. + */ + get(name: string): string | null; + /** + * Returns all the values association with a given search parameter. + */ + getAll(name: string): string[]; + /** + * Returns a Boolean indicating if such a search parameter exists. + */ + has(name: string): boolean; + /** + * Sets the value associated to a given search parameter to the given value. If there were several values, delete the others. + */ + set(name: string, value: string): void; + sort(): void; +} + +declare var URLSearchParams: { + prototype: URLSearchParams; + new(init?: string[][] | { [key: string]: string } | string): URLSearchParams; +}; + interface ValidityState { readonly badInput: boolean; readonly customError: boolean; @@ -11881,10 +10655,10 @@ interface ValidityState { readonly rangeUnderflow: boolean; readonly stepMismatch: boolean; readonly tooLong: boolean; + readonly tooShort: boolean; readonly typeMismatch: boolean; readonly valid: boolean; readonly valueMissing: boolean; - readonly tooShort: boolean; } declare var ValidityState: { @@ -11896,7 +10670,6 @@ interface VideoPlaybackQuality { readonly corruptedVideoFrames: number; readonly creationTime: number; readonly droppedVideoFrames: number; - readonly totalFrameDelay: number; readonly totalVideoFrames: number; } @@ -11907,11 +10680,11 @@ declare var VideoPlaybackQuality: { interface VideoTrack { readonly id: string; - kind: string; + readonly kind: string; readonly label: string; - language: string; + readonly language: string; selected: boolean; - readonly sourceBuffer: SourceBuffer; + readonly sourceBuffer: SourceBuffer | null; } declare var VideoTrack: { @@ -11932,9 +10705,8 @@ interface VideoTrackList extends EventTarget { onremovetrack: (this: VideoTrackList, ev: TrackEvent) => any; readonly selectedIndex: number; getTrackById(id: string): VideoTrack | null; - item(index: number): VideoTrack; addEventListener(type: K, listener: (this: VideoTrackList, ev: VideoTrackListEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; [index: number]: VideoTrack; } @@ -11950,73 +10722,13 @@ interface WaveShaperNode extends AudioNode { declare var WaveShaperNode: { prototype: WaveShaperNode; - new(): WaveShaperNode; + new(context: BaseAudioContext, options?: WaveShaperOptions): WaveShaperNode; }; -interface WebAuthentication { - getAssertion(assertionChallenge: any, options?: AssertionOptions): Promise; - makeCredential(accountInformation: Account, cryptoParameters: ScopedCredentialParameters[], attestationChallenge: any, options?: ScopedCredentialOptions): Promise; -} - -declare var WebAuthentication: { - prototype: WebAuthentication; - new(): WebAuthentication; -}; - -interface WebAuthnAssertion { - readonly authenticatorData: ArrayBuffer; - readonly clientData: ArrayBuffer; - readonly credential: ScopedCredential; - readonly signature: ArrayBuffer; -} - -declare var WebAuthnAssertion: { - prototype: WebAuthnAssertion; - new(): WebAuthnAssertion; -}; - -interface WEBGL_compressed_texture_s3tc { - readonly COMPRESSED_RGB_S3TC_DXT1_EXT: number; - readonly COMPRESSED_RGBA_S3TC_DXT1_EXT: number; - readonly COMPRESSED_RGBA_S3TC_DXT3_EXT: number; - readonly COMPRESSED_RGBA_S3TC_DXT5_EXT: number; -} - -declare var WEBGL_compressed_texture_s3tc: { - prototype: WEBGL_compressed_texture_s3tc; - new(): WEBGL_compressed_texture_s3tc; - readonly COMPRESSED_RGB_S3TC_DXT1_EXT: number; - readonly COMPRESSED_RGBA_S3TC_DXT1_EXT: number; - readonly COMPRESSED_RGBA_S3TC_DXT3_EXT: number; - readonly COMPRESSED_RGBA_S3TC_DXT5_EXT: number; -}; - -interface WEBGL_debug_renderer_info { - readonly UNMASKED_RENDERER_WEBGL: number; - readonly UNMASKED_VENDOR_WEBGL: number; -} - -declare var WEBGL_debug_renderer_info: { - prototype: WEBGL_debug_renderer_info; - new(): WEBGL_debug_renderer_info; - readonly UNMASKED_RENDERER_WEBGL: number; - readonly UNMASKED_VENDOR_WEBGL: number; -}; - -interface WEBGL_depth_texture { - readonly UNSIGNED_INT_24_8_WEBGL: number; -} - -declare var WEBGL_depth_texture: { - prototype: WEBGL_depth_texture; - new(): WEBGL_depth_texture; - readonly UNSIGNED_INT_24_8_WEBGL: number; -}; - -interface WebGLActiveInfo { - readonly name: string; - readonly size: number; - readonly type: number; +interface WebGLActiveInfo { + readonly name: string; + readonly size: GLint; + readonly type: GLenum; } declare var WebGLActiveInfo: { @@ -12038,7 +10750,7 @@ interface WebGLContextEvent extends Event { declare var WebGLContextEvent: { prototype: WebGLContextEvent; - new(typeArg: string, eventInitDict?: WebGLContextEventInit): WebGLContextEvent; + new(type: string, eventInit?: WebGLContextEventInit): WebGLContextEvent; }; interface WebGLFramebuffer extends WebGLObject { @@ -12073,747 +10785,12 @@ declare var WebGLRenderbuffer: { new(): WebGLRenderbuffer; }; -interface WebGLRenderingContext { - readonly canvas: HTMLCanvasElement; - readonly drawingBufferHeight: number; - readonly drawingBufferWidth: number; - activeTexture(texture: number): void; - attachShader(program: WebGLProgram | null, shader: WebGLShader | null): void; - bindAttribLocation(program: WebGLProgram | null, index: number, name: string): void; - bindBuffer(target: number, buffer: WebGLBuffer | null): void; - bindFramebuffer(target: number, framebuffer: WebGLFramebuffer | null): void; - bindRenderbuffer(target: number, renderbuffer: WebGLRenderbuffer | null): void; - bindTexture(target: number, texture: WebGLTexture | null): void; - blendColor(red: number, green: number, blue: number, alpha: number): void; - blendEquation(mode: number): void; - blendEquationSeparate(modeRGB: number, modeAlpha: number): void; - blendFunc(sfactor: number, dfactor: number): void; - blendFuncSeparate(srcRGB: number, dstRGB: number, srcAlpha: number, dstAlpha: number): void; - bufferData(target: number, size: number | ArrayBufferView | ArrayBuffer, usage: number): void; - bufferSubData(target: number, offset: number, data: ArrayBufferView | ArrayBuffer): void; - checkFramebufferStatus(target: number): number; - clear(mask: number): void; - clearColor(red: number, green: number, blue: number, alpha: number): void; - clearDepth(depth: number): void; - clearStencil(s: number): void; - colorMask(red: boolean, green: boolean, blue: boolean, alpha: boolean): void; - compileShader(shader: WebGLShader | null): void; - compressedTexImage2D(target: number, level: number, internalformat: number, width: number, height: number, border: number, data: ArrayBufferView): void; - compressedTexSubImage2D(target: number, level: number, xoffset: number, yoffset: number, width: number, height: number, format: number, data: ArrayBufferView): void; - copyTexImage2D(target: number, level: number, internalformat: number, x: number, y: number, width: number, height: number, border: number): void; - copyTexSubImage2D(target: number, level: number, xoffset: number, yoffset: number, x: number, y: number, width: number, height: number): void; - createBuffer(): WebGLBuffer | null; - createFramebuffer(): WebGLFramebuffer | null; - createProgram(): WebGLProgram | null; - createRenderbuffer(): WebGLRenderbuffer | null; - createShader(type: number): WebGLShader | null; - createTexture(): WebGLTexture | null; - cullFace(mode: number): void; - deleteBuffer(buffer: WebGLBuffer | null): void; - deleteFramebuffer(framebuffer: WebGLFramebuffer | null): void; - deleteProgram(program: WebGLProgram | null): void; - deleteRenderbuffer(renderbuffer: WebGLRenderbuffer | null): void; - deleteShader(shader: WebGLShader | null): void; - deleteTexture(texture: WebGLTexture | null): void; - depthFunc(func: number): void; - depthMask(flag: boolean): void; - depthRange(zNear: number, zFar: number): void; - detachShader(program: WebGLProgram | null, shader: WebGLShader | null): void; - disable(cap: number): void; - disableVertexAttribArray(index: number): void; - drawArrays(mode: number, first: number, count: number): void; - drawElements(mode: number, count: number, type: number, offset: number): void; - enable(cap: number): void; - enableVertexAttribArray(index: number): void; - finish(): void; - flush(): void; - framebufferRenderbuffer(target: number, attachment: number, renderbuffertarget: number, renderbuffer: WebGLRenderbuffer | null): void; - framebufferTexture2D(target: number, attachment: number, textarget: number, texture: WebGLTexture | null, level: number): void; - frontFace(mode: number): void; - generateMipmap(target: number): void; - getActiveAttrib(program: WebGLProgram | null, index: number): WebGLActiveInfo | null; - getActiveUniform(program: WebGLProgram | null, index: number): WebGLActiveInfo | null; - getAttachedShaders(program: WebGLProgram | null): WebGLShader[] | null; - getAttribLocation(program: WebGLProgram | null, name: string): number; - getBufferParameter(target: number, pname: number): any; - getContextAttributes(): WebGLContextAttributes; - getError(): number; - getExtension(name: string): any; - getFramebufferAttachmentParameter(target: number, attachment: number, pname: number): any; - getParameter(pname: number): any; - getProgramInfoLog(program: WebGLProgram | null): string | null; - getProgramParameter(program: WebGLProgram | null, pname: number): any; - getRenderbufferParameter(target: number, pname: number): any; - getShaderInfoLog(shader: WebGLShader | null): string | null; - getShaderParameter(shader: WebGLShader | null, pname: number): any; - getShaderPrecisionFormat(shadertype: number, precisiontype: number): WebGLShaderPrecisionFormat | null; - getShaderSource(shader: WebGLShader | null): string | null; - getSupportedExtensions(): string[] | null; - getTexParameter(target: number, pname: number): any; - getUniform(program: WebGLProgram | null, location: WebGLUniformLocation | null): any; - getUniformLocation(program: WebGLProgram | null, name: string): WebGLUniformLocation | null; - getVertexAttrib(index: number, pname: number): any; - getVertexAttribOffset(index: number, pname: number): number; - hint(target: number, mode: number): void; - isBuffer(buffer: WebGLBuffer | null): boolean; - isContextLost(): boolean; - isEnabled(cap: number): boolean; - isFramebuffer(framebuffer: WebGLFramebuffer | null): boolean; - isProgram(program: WebGLProgram | null): boolean; - isRenderbuffer(renderbuffer: WebGLRenderbuffer | null): boolean; - isShader(shader: WebGLShader | null): boolean; - isTexture(texture: WebGLTexture | null): boolean; - lineWidth(width: number): void; - linkProgram(program: WebGLProgram | null): void; - pixelStorei(pname: number, param: number | boolean): void; - polygonOffset(factor: number, units: number): void; - readPixels(x: number, y: number, width: number, height: number, format: number, type: number, pixels: ArrayBufferView | null): void; - renderbufferStorage(target: number, internalformat: number, width: number, height: number): void; - sampleCoverage(value: number, invert: boolean): void; - scissor(x: number, y: number, width: number, height: number): void; - shaderSource(shader: WebGLShader | null, source: string): void; - stencilFunc(func: number, ref: number, mask: number): void; - stencilFuncSeparate(face: number, func: number, ref: number, mask: number): void; - stencilMask(mask: number): void; - stencilMaskSeparate(face: number, mask: number): void; - stencilOp(fail: number, zfail: number, zpass: number): void; - stencilOpSeparate(face: number, fail: number, zfail: number, zpass: number): void; - texImage2D(target: number, level: number, internalformat: number, width: number, height: number, border: number, format: number, type: number, pixels: ArrayBufferView | null): void; - texImage2D(target: number, level: number, internalformat: number, format: number, type: number, pixels: ImageBitmap | ImageData | HTMLVideoElement | HTMLImageElement | HTMLCanvasElement): void; - texParameterf(target: number, pname: number, param: number): void; - texParameteri(target: number, pname: number, param: number): void; - texSubImage2D(target: number, level: number, xoffset: number, yoffset: number, width: number, height: number, format: number, type: number, pixels: ArrayBufferView | null): void; - texSubImage2D(target: number, level: number, xoffset: number, yoffset: number, format: number, type: number, pixels: ImageBitmap | ImageData | HTMLVideoElement | HTMLImageElement | HTMLCanvasElement): void; - uniform1f(location: WebGLUniformLocation | null, x: number): void; - uniform1fv(location: WebGLUniformLocation, v: Float32Array | number[]): void; - uniform1i(location: WebGLUniformLocation | null, x: number): void; - uniform1iv(location: WebGLUniformLocation, v: Int32Array | number[]): void; - uniform2f(location: WebGLUniformLocation | null, x: number, y: number): void; - uniform2fv(location: WebGLUniformLocation, v: Float32Array | number[]): void; - uniform2i(location: WebGLUniformLocation | null, x: number, y: number): void; - uniform2iv(location: WebGLUniformLocation, v: Int32Array | number[]): void; - uniform3f(location: WebGLUniformLocation | null, x: number, y: number, z: number): void; - uniform3fv(location: WebGLUniformLocation, v: Float32Array | number[]): void; - uniform3i(location: WebGLUniformLocation | null, x: number, y: number, z: number): void; - uniform3iv(location: WebGLUniformLocation, v: Int32Array | number[]): void; - uniform4f(location: WebGLUniformLocation | null, x: number, y: number, z: number, w: number): void; - uniform4fv(location: WebGLUniformLocation, v: Float32Array | number[]): void; - uniform4i(location: WebGLUniformLocation | null, x: number, y: number, z: number, w: number): void; - uniform4iv(location: WebGLUniformLocation, v: Int32Array | number[]): void; - uniformMatrix2fv(location: WebGLUniformLocation, transpose: boolean, value: Float32Array | number[]): void; - uniformMatrix3fv(location: WebGLUniformLocation, transpose: boolean, value: Float32Array | number[]): void; - uniformMatrix4fv(location: WebGLUniformLocation, transpose: boolean, value: Float32Array | number[]): void; - useProgram(program: WebGLProgram | null): void; - validateProgram(program: WebGLProgram | null): void; - vertexAttrib1f(indx: number, x: number): void; - vertexAttrib1fv(indx: number, values: Float32Array | number[]): void; - vertexAttrib2f(indx: number, x: number, y: number): void; - vertexAttrib2fv(indx: number, values: Float32Array | number[]): void; - vertexAttrib3f(indx: number, x: number, y: number, z: number): void; - vertexAttrib3fv(indx: number, values: Float32Array | number[]): void; - vertexAttrib4f(indx: number, x: number, y: number, z: number, w: number): void; - vertexAttrib4fv(indx: number, values: Float32Array | number[]): void; - vertexAttribPointer(indx: number, size: number, type: number, normalized: boolean, stride: number, offset: number): void; - viewport(x: number, y: number, width: number, height: number): void; - readonly ACTIVE_ATTRIBUTES: number; - readonly ACTIVE_TEXTURE: number; - readonly ACTIVE_UNIFORMS: number; - readonly ALIASED_LINE_WIDTH_RANGE: number; - readonly ALIASED_POINT_SIZE_RANGE: number; - readonly ALPHA: number; - readonly ALPHA_BITS: number; - readonly ALWAYS: number; - readonly ARRAY_BUFFER: number; - readonly ARRAY_BUFFER_BINDING: number; - readonly ATTACHED_SHADERS: number; - readonly BACK: number; - readonly BLEND: number; - readonly BLEND_COLOR: number; - readonly BLEND_DST_ALPHA: number; - readonly BLEND_DST_RGB: number; - readonly BLEND_EQUATION: number; - readonly BLEND_EQUATION_ALPHA: number; - readonly BLEND_EQUATION_RGB: number; - readonly BLEND_SRC_ALPHA: number; - readonly BLEND_SRC_RGB: number; - readonly BLUE_BITS: number; - readonly BOOL: number; - readonly BOOL_VEC2: number; - readonly BOOL_VEC3: number; - readonly BOOL_VEC4: number; - readonly BROWSER_DEFAULT_WEBGL: number; - readonly BUFFER_SIZE: number; - readonly BUFFER_USAGE: number; - readonly BYTE: number; - readonly CCW: number; - readonly CLAMP_TO_EDGE: number; - readonly COLOR_ATTACHMENT0: number; - readonly COLOR_BUFFER_BIT: number; - readonly COLOR_CLEAR_VALUE: number; - readonly COLOR_WRITEMASK: number; - readonly COMPILE_STATUS: number; - readonly COMPRESSED_TEXTURE_FORMATS: number; - readonly CONSTANT_ALPHA: number; - readonly CONSTANT_COLOR: number; - readonly CONTEXT_LOST_WEBGL: number; - readonly CULL_FACE: number; - readonly CULL_FACE_MODE: number; - readonly CURRENT_PROGRAM: number; - readonly CURRENT_VERTEX_ATTRIB: number; - readonly CW: number; - readonly DECR: number; - readonly DECR_WRAP: number; - readonly DELETE_STATUS: number; - readonly DEPTH_ATTACHMENT: number; - readonly DEPTH_BITS: number; - readonly DEPTH_BUFFER_BIT: number; - readonly DEPTH_CLEAR_VALUE: number; - readonly DEPTH_COMPONENT: number; - readonly DEPTH_COMPONENT16: number; - readonly DEPTH_FUNC: number; - readonly DEPTH_RANGE: number; - readonly DEPTH_STENCIL: number; - readonly DEPTH_STENCIL_ATTACHMENT: number; - readonly DEPTH_TEST: number; - readonly DEPTH_WRITEMASK: number; - readonly DITHER: number; - readonly DONT_CARE: number; - readonly DST_ALPHA: number; - readonly DST_COLOR: number; - readonly DYNAMIC_DRAW: number; - readonly ELEMENT_ARRAY_BUFFER: number; - readonly ELEMENT_ARRAY_BUFFER_BINDING: number; - readonly EQUAL: number; - readonly FASTEST: number; - readonly FLOAT: number; - readonly FLOAT_MAT2: number; - readonly FLOAT_MAT3: number; - readonly FLOAT_MAT4: number; - readonly FLOAT_VEC2: number; - readonly FLOAT_VEC3: number; - readonly FLOAT_VEC4: number; - readonly FRAGMENT_SHADER: number; - readonly FRAMEBUFFER: number; - readonly FRAMEBUFFER_ATTACHMENT_OBJECT_NAME: number; - readonly FRAMEBUFFER_ATTACHMENT_OBJECT_TYPE: number; - readonly FRAMEBUFFER_ATTACHMENT_TEXTURE_CUBE_MAP_FACE: number; - readonly FRAMEBUFFER_ATTACHMENT_TEXTURE_LEVEL: number; - readonly FRAMEBUFFER_BINDING: number; - readonly FRAMEBUFFER_COMPLETE: number; - readonly FRAMEBUFFER_INCOMPLETE_ATTACHMENT: number; - readonly FRAMEBUFFER_INCOMPLETE_DIMENSIONS: number; - readonly FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT: number; - readonly FRAMEBUFFER_UNSUPPORTED: number; - readonly FRONT: number; - readonly FRONT_AND_BACK: number; - readonly FRONT_FACE: number; - readonly FUNC_ADD: number; - readonly FUNC_REVERSE_SUBTRACT: number; - readonly FUNC_SUBTRACT: number; - readonly GENERATE_MIPMAP_HINT: number; - readonly GEQUAL: number; - readonly GREATER: number; - readonly GREEN_BITS: number; - readonly HIGH_FLOAT: number; - readonly HIGH_INT: number; - readonly IMPLEMENTATION_COLOR_READ_FORMAT: number; - readonly IMPLEMENTATION_COLOR_READ_TYPE: number; - readonly INCR: number; - readonly INCR_WRAP: number; - readonly INT: number; - readonly INT_VEC2: number; - readonly INT_VEC3: number; - readonly INT_VEC4: number; - readonly INVALID_ENUM: number; - readonly INVALID_FRAMEBUFFER_OPERATION: number; - readonly INVALID_OPERATION: number; - readonly INVALID_VALUE: number; - readonly INVERT: number; - readonly KEEP: number; - readonly LEQUAL: number; - readonly LESS: number; - readonly LINE_LOOP: number; - readonly LINE_STRIP: number; - readonly LINE_WIDTH: number; - readonly LINEAR: number; - readonly LINEAR_MIPMAP_LINEAR: number; - readonly LINEAR_MIPMAP_NEAREST: number; - readonly LINES: number; - readonly LINK_STATUS: number; - readonly LOW_FLOAT: number; - readonly LOW_INT: number; - readonly LUMINANCE: number; - readonly LUMINANCE_ALPHA: number; - readonly MAX_COMBINED_TEXTURE_IMAGE_UNITS: number; - readonly MAX_CUBE_MAP_TEXTURE_SIZE: number; - readonly MAX_FRAGMENT_UNIFORM_VECTORS: number; - readonly MAX_RENDERBUFFER_SIZE: number; - readonly MAX_TEXTURE_IMAGE_UNITS: number; - readonly MAX_TEXTURE_SIZE: number; - readonly MAX_VARYING_VECTORS: number; - readonly MAX_VERTEX_ATTRIBS: number; - readonly MAX_VERTEX_TEXTURE_IMAGE_UNITS: number; - readonly MAX_VERTEX_UNIFORM_VECTORS: number; - readonly MAX_VIEWPORT_DIMS: number; - readonly MEDIUM_FLOAT: number; - readonly MEDIUM_INT: number; - readonly MIRRORED_REPEAT: number; - readonly NEAREST: number; - readonly NEAREST_MIPMAP_LINEAR: number; - readonly NEAREST_MIPMAP_NEAREST: number; - readonly NEVER: number; - readonly NICEST: number; - readonly NO_ERROR: number; - readonly NONE: number; - readonly NOTEQUAL: number; - readonly ONE: number; - readonly ONE_MINUS_CONSTANT_ALPHA: number; - readonly ONE_MINUS_CONSTANT_COLOR: number; - readonly ONE_MINUS_DST_ALPHA: number; - readonly ONE_MINUS_DST_COLOR: number; - readonly ONE_MINUS_SRC_ALPHA: number; - readonly ONE_MINUS_SRC_COLOR: number; - readonly OUT_OF_MEMORY: number; - readonly PACK_ALIGNMENT: number; - readonly POINTS: number; - readonly POLYGON_OFFSET_FACTOR: number; - readonly POLYGON_OFFSET_FILL: number; - readonly POLYGON_OFFSET_UNITS: number; - readonly RED_BITS: number; - readonly RENDERBUFFER: number; - readonly RENDERBUFFER_ALPHA_SIZE: number; - readonly RENDERBUFFER_BINDING: number; - readonly RENDERBUFFER_BLUE_SIZE: number; - readonly RENDERBUFFER_DEPTH_SIZE: number; - readonly RENDERBUFFER_GREEN_SIZE: number; - readonly RENDERBUFFER_HEIGHT: number; - readonly RENDERBUFFER_INTERNAL_FORMAT: number; - readonly RENDERBUFFER_RED_SIZE: number; - readonly RENDERBUFFER_STENCIL_SIZE: number; - readonly RENDERBUFFER_WIDTH: number; - readonly RENDERER: number; - readonly REPEAT: number; - readonly REPLACE: number; - readonly RGB: number; - readonly RGB5_A1: number; - readonly RGB565: number; - readonly RGBA: number; - readonly RGBA4: number; - readonly SAMPLE_ALPHA_TO_COVERAGE: number; - readonly SAMPLE_BUFFERS: number; - readonly SAMPLE_COVERAGE: number; - readonly SAMPLE_COVERAGE_INVERT: number; - readonly SAMPLE_COVERAGE_VALUE: number; - readonly SAMPLER_2D: number; - readonly SAMPLER_CUBE: number; - readonly SAMPLES: number; - readonly SCISSOR_BOX: number; - readonly SCISSOR_TEST: number; - readonly SHADER_TYPE: number; - readonly SHADING_LANGUAGE_VERSION: number; - readonly SHORT: number; - readonly SRC_ALPHA: number; - readonly SRC_ALPHA_SATURATE: number; - readonly SRC_COLOR: number; - readonly STATIC_DRAW: number; - readonly STENCIL_ATTACHMENT: number; - readonly STENCIL_BACK_FAIL: number; - readonly STENCIL_BACK_FUNC: number; - readonly STENCIL_BACK_PASS_DEPTH_FAIL: number; - readonly STENCIL_BACK_PASS_DEPTH_PASS: number; - readonly STENCIL_BACK_REF: number; - readonly STENCIL_BACK_VALUE_MASK: number; - readonly STENCIL_BACK_WRITEMASK: number; - readonly STENCIL_BITS: number; - readonly STENCIL_BUFFER_BIT: number; - readonly STENCIL_CLEAR_VALUE: number; - readonly STENCIL_FAIL: number; - readonly STENCIL_FUNC: number; - readonly STENCIL_INDEX: number; - readonly STENCIL_INDEX8: number; - readonly STENCIL_PASS_DEPTH_FAIL: number; - readonly STENCIL_PASS_DEPTH_PASS: number; - readonly STENCIL_REF: number; - readonly STENCIL_TEST: number; - readonly STENCIL_VALUE_MASK: number; - readonly STENCIL_WRITEMASK: number; - readonly STREAM_DRAW: number; - readonly SUBPIXEL_BITS: number; - readonly TEXTURE: number; - readonly TEXTURE_2D: number; - readonly TEXTURE_BINDING_2D: number; - readonly TEXTURE_BINDING_CUBE_MAP: number; - readonly TEXTURE_CUBE_MAP: number; - readonly TEXTURE_CUBE_MAP_NEGATIVE_X: number; - readonly TEXTURE_CUBE_MAP_NEGATIVE_Y: number; - readonly TEXTURE_CUBE_MAP_NEGATIVE_Z: number; - readonly TEXTURE_CUBE_MAP_POSITIVE_X: number; - readonly TEXTURE_CUBE_MAP_POSITIVE_Y: number; - readonly TEXTURE_CUBE_MAP_POSITIVE_Z: number; - readonly TEXTURE_MAG_FILTER: number; - readonly TEXTURE_MIN_FILTER: number; - readonly TEXTURE_WRAP_S: number; - readonly TEXTURE_WRAP_T: number; - readonly TEXTURE0: number; - readonly TEXTURE1: number; - readonly TEXTURE10: number; - readonly TEXTURE11: number; - readonly TEXTURE12: number; - readonly TEXTURE13: number; - readonly TEXTURE14: number; - readonly TEXTURE15: number; - readonly TEXTURE16: number; - readonly TEXTURE17: number; - readonly TEXTURE18: number; - readonly TEXTURE19: number; - readonly TEXTURE2: number; - readonly TEXTURE20: number; - readonly TEXTURE21: number; - readonly TEXTURE22: number; - readonly TEXTURE23: number; - readonly TEXTURE24: number; - readonly TEXTURE25: number; - readonly TEXTURE26: number; - readonly TEXTURE27: number; - readonly TEXTURE28: number; - readonly TEXTURE29: number; - readonly TEXTURE3: number; - readonly TEXTURE30: number; - readonly TEXTURE31: number; - readonly TEXTURE4: number; - readonly TEXTURE5: number; - readonly TEXTURE6: number; - readonly TEXTURE7: number; - readonly TEXTURE8: number; - readonly TEXTURE9: number; - readonly TRIANGLE_FAN: number; - readonly TRIANGLE_STRIP: number; - readonly TRIANGLES: number; - readonly UNPACK_ALIGNMENT: number; - readonly UNPACK_COLORSPACE_CONVERSION_WEBGL: number; - readonly UNPACK_FLIP_Y_WEBGL: number; - readonly UNPACK_PREMULTIPLY_ALPHA_WEBGL: number; - readonly UNSIGNED_BYTE: number; - readonly UNSIGNED_INT: number; - readonly UNSIGNED_SHORT: number; - readonly UNSIGNED_SHORT_4_4_4_4: number; - readonly UNSIGNED_SHORT_5_5_5_1: number; - readonly UNSIGNED_SHORT_5_6_5: number; - readonly VALIDATE_STATUS: number; - readonly VENDOR: number; - readonly VERSION: number; - readonly VERTEX_ATTRIB_ARRAY_BUFFER_BINDING: number; - readonly VERTEX_ATTRIB_ARRAY_ENABLED: number; - readonly VERTEX_ATTRIB_ARRAY_NORMALIZED: number; - readonly VERTEX_ATTRIB_ARRAY_POINTER: number; - readonly VERTEX_ATTRIB_ARRAY_SIZE: number; - readonly VERTEX_ATTRIB_ARRAY_STRIDE: number; - readonly VERTEX_ATTRIB_ARRAY_TYPE: number; - readonly VERTEX_SHADER: number; - readonly VIEWPORT: number; - readonly ZERO: number; +interface WebGLRenderingContext extends WebGLRenderingContextBase { } declare var WebGLRenderingContext: { prototype: WebGLRenderingContext; new(): WebGLRenderingContext; - readonly ACTIVE_ATTRIBUTES: number; - readonly ACTIVE_TEXTURE: number; - readonly ACTIVE_UNIFORMS: number; - readonly ALIASED_LINE_WIDTH_RANGE: number; - readonly ALIASED_POINT_SIZE_RANGE: number; - readonly ALPHA: number; - readonly ALPHA_BITS: number; - readonly ALWAYS: number; - readonly ARRAY_BUFFER: number; - readonly ARRAY_BUFFER_BINDING: number; - readonly ATTACHED_SHADERS: number; - readonly BACK: number; - readonly BLEND: number; - readonly BLEND_COLOR: number; - readonly BLEND_DST_ALPHA: number; - readonly BLEND_DST_RGB: number; - readonly BLEND_EQUATION: number; - readonly BLEND_EQUATION_ALPHA: number; - readonly BLEND_EQUATION_RGB: number; - readonly BLEND_SRC_ALPHA: number; - readonly BLEND_SRC_RGB: number; - readonly BLUE_BITS: number; - readonly BOOL: number; - readonly BOOL_VEC2: number; - readonly BOOL_VEC3: number; - readonly BOOL_VEC4: number; - readonly BROWSER_DEFAULT_WEBGL: number; - readonly BUFFER_SIZE: number; - readonly BUFFER_USAGE: number; - readonly BYTE: number; - readonly CCW: number; - readonly CLAMP_TO_EDGE: number; - readonly COLOR_ATTACHMENT0: number; - readonly COLOR_BUFFER_BIT: number; - readonly COLOR_CLEAR_VALUE: number; - readonly COLOR_WRITEMASK: number; - readonly COMPILE_STATUS: number; - readonly COMPRESSED_TEXTURE_FORMATS: number; - readonly CONSTANT_ALPHA: number; - readonly CONSTANT_COLOR: number; - readonly CONTEXT_LOST_WEBGL: number; - readonly CULL_FACE: number; - readonly CULL_FACE_MODE: number; - readonly CURRENT_PROGRAM: number; - readonly CURRENT_VERTEX_ATTRIB: number; - readonly CW: number; - readonly DECR: number; - readonly DECR_WRAP: number; - readonly DELETE_STATUS: number; - readonly DEPTH_ATTACHMENT: number; - readonly DEPTH_BITS: number; - readonly DEPTH_BUFFER_BIT: number; - readonly DEPTH_CLEAR_VALUE: number; - readonly DEPTH_COMPONENT: number; - readonly DEPTH_COMPONENT16: number; - readonly DEPTH_FUNC: number; - readonly DEPTH_RANGE: number; - readonly DEPTH_STENCIL: number; - readonly DEPTH_STENCIL_ATTACHMENT: number; - readonly DEPTH_TEST: number; - readonly DEPTH_WRITEMASK: number; - readonly DITHER: number; - readonly DONT_CARE: number; - readonly DST_ALPHA: number; - readonly DST_COLOR: number; - readonly DYNAMIC_DRAW: number; - readonly ELEMENT_ARRAY_BUFFER: number; - readonly ELEMENT_ARRAY_BUFFER_BINDING: number; - readonly EQUAL: number; - readonly FASTEST: number; - readonly FLOAT: number; - readonly FLOAT_MAT2: number; - readonly FLOAT_MAT3: number; - readonly FLOAT_MAT4: number; - readonly FLOAT_VEC2: number; - readonly FLOAT_VEC3: number; - readonly FLOAT_VEC4: number; - readonly FRAGMENT_SHADER: number; - readonly FRAMEBUFFER: number; - readonly FRAMEBUFFER_ATTACHMENT_OBJECT_NAME: number; - readonly FRAMEBUFFER_ATTACHMENT_OBJECT_TYPE: number; - readonly FRAMEBUFFER_ATTACHMENT_TEXTURE_CUBE_MAP_FACE: number; - readonly FRAMEBUFFER_ATTACHMENT_TEXTURE_LEVEL: number; - readonly FRAMEBUFFER_BINDING: number; - readonly FRAMEBUFFER_COMPLETE: number; - readonly FRAMEBUFFER_INCOMPLETE_ATTACHMENT: number; - readonly FRAMEBUFFER_INCOMPLETE_DIMENSIONS: number; - readonly FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT: number; - readonly FRAMEBUFFER_UNSUPPORTED: number; - readonly FRONT: number; - readonly FRONT_AND_BACK: number; - readonly FRONT_FACE: number; - readonly FUNC_ADD: number; - readonly FUNC_REVERSE_SUBTRACT: number; - readonly FUNC_SUBTRACT: number; - readonly GENERATE_MIPMAP_HINT: number; - readonly GEQUAL: number; - readonly GREATER: number; - readonly GREEN_BITS: number; - readonly HIGH_FLOAT: number; - readonly HIGH_INT: number; - readonly IMPLEMENTATION_COLOR_READ_FORMAT: number; - readonly IMPLEMENTATION_COLOR_READ_TYPE: number; - readonly INCR: number; - readonly INCR_WRAP: number; - readonly INT: number; - readonly INT_VEC2: number; - readonly INT_VEC3: number; - readonly INT_VEC4: number; - readonly INVALID_ENUM: number; - readonly INVALID_FRAMEBUFFER_OPERATION: number; - readonly INVALID_OPERATION: number; - readonly INVALID_VALUE: number; - readonly INVERT: number; - readonly KEEP: number; - readonly LEQUAL: number; - readonly LESS: number; - readonly LINE_LOOP: number; - readonly LINE_STRIP: number; - readonly LINE_WIDTH: number; - readonly LINEAR: number; - readonly LINEAR_MIPMAP_LINEAR: number; - readonly LINEAR_MIPMAP_NEAREST: number; - readonly LINES: number; - readonly LINK_STATUS: number; - readonly LOW_FLOAT: number; - readonly LOW_INT: number; - readonly LUMINANCE: number; - readonly LUMINANCE_ALPHA: number; - readonly MAX_COMBINED_TEXTURE_IMAGE_UNITS: number; - readonly MAX_CUBE_MAP_TEXTURE_SIZE: number; - readonly MAX_FRAGMENT_UNIFORM_VECTORS: number; - readonly MAX_RENDERBUFFER_SIZE: number; - readonly MAX_TEXTURE_IMAGE_UNITS: number; - readonly MAX_TEXTURE_SIZE: number; - readonly MAX_VARYING_VECTORS: number; - readonly MAX_VERTEX_ATTRIBS: number; - readonly MAX_VERTEX_TEXTURE_IMAGE_UNITS: number; - readonly MAX_VERTEX_UNIFORM_VECTORS: number; - readonly MAX_VIEWPORT_DIMS: number; - readonly MEDIUM_FLOAT: number; - readonly MEDIUM_INT: number; - readonly MIRRORED_REPEAT: number; - readonly NEAREST: number; - readonly NEAREST_MIPMAP_LINEAR: number; - readonly NEAREST_MIPMAP_NEAREST: number; - readonly NEVER: number; - readonly NICEST: number; - readonly NO_ERROR: number; - readonly NONE: number; - readonly NOTEQUAL: number; - readonly ONE: number; - readonly ONE_MINUS_CONSTANT_ALPHA: number; - readonly ONE_MINUS_CONSTANT_COLOR: number; - readonly ONE_MINUS_DST_ALPHA: number; - readonly ONE_MINUS_DST_COLOR: number; - readonly ONE_MINUS_SRC_ALPHA: number; - readonly ONE_MINUS_SRC_COLOR: number; - readonly OUT_OF_MEMORY: number; - readonly PACK_ALIGNMENT: number; - readonly POINTS: number; - readonly POLYGON_OFFSET_FACTOR: number; - readonly POLYGON_OFFSET_FILL: number; - readonly POLYGON_OFFSET_UNITS: number; - readonly RED_BITS: number; - readonly RENDERBUFFER: number; - readonly RENDERBUFFER_ALPHA_SIZE: number; - readonly RENDERBUFFER_BINDING: number; - readonly RENDERBUFFER_BLUE_SIZE: number; - readonly RENDERBUFFER_DEPTH_SIZE: number; - readonly RENDERBUFFER_GREEN_SIZE: number; - readonly RENDERBUFFER_HEIGHT: number; - readonly RENDERBUFFER_INTERNAL_FORMAT: number; - readonly RENDERBUFFER_RED_SIZE: number; - readonly RENDERBUFFER_STENCIL_SIZE: number; - readonly RENDERBUFFER_WIDTH: number; - readonly RENDERER: number; - readonly REPEAT: number; - readonly REPLACE: number; - readonly RGB: number; - readonly RGB5_A1: number; - readonly RGB565: number; - readonly RGBA: number; - readonly RGBA4: number; - readonly SAMPLE_ALPHA_TO_COVERAGE: number; - readonly SAMPLE_BUFFERS: number; - readonly SAMPLE_COVERAGE: number; - readonly SAMPLE_COVERAGE_INVERT: number; - readonly SAMPLE_COVERAGE_VALUE: number; - readonly SAMPLER_2D: number; - readonly SAMPLER_CUBE: number; - readonly SAMPLES: number; - readonly SCISSOR_BOX: number; - readonly SCISSOR_TEST: number; - readonly SHADER_TYPE: number; - readonly SHADING_LANGUAGE_VERSION: number; - readonly SHORT: number; - readonly SRC_ALPHA: number; - readonly SRC_ALPHA_SATURATE: number; - readonly SRC_COLOR: number; - readonly STATIC_DRAW: number; - readonly STENCIL_ATTACHMENT: number; - readonly STENCIL_BACK_FAIL: number; - readonly STENCIL_BACK_FUNC: number; - readonly STENCIL_BACK_PASS_DEPTH_FAIL: number; - readonly STENCIL_BACK_PASS_DEPTH_PASS: number; - readonly STENCIL_BACK_REF: number; - readonly STENCIL_BACK_VALUE_MASK: number; - readonly STENCIL_BACK_WRITEMASK: number; - readonly STENCIL_BITS: number; - readonly STENCIL_BUFFER_BIT: number; - readonly STENCIL_CLEAR_VALUE: number; - readonly STENCIL_FAIL: number; - readonly STENCIL_FUNC: number; - readonly STENCIL_INDEX: number; - readonly STENCIL_INDEX8: number; - readonly STENCIL_PASS_DEPTH_FAIL: number; - readonly STENCIL_PASS_DEPTH_PASS: number; - readonly STENCIL_REF: number; - readonly STENCIL_TEST: number; - readonly STENCIL_VALUE_MASK: number; - readonly STENCIL_WRITEMASK: number; - readonly STREAM_DRAW: number; - readonly SUBPIXEL_BITS: number; - readonly TEXTURE: number; - readonly TEXTURE_2D: number; - readonly TEXTURE_BINDING_2D: number; - readonly TEXTURE_BINDING_CUBE_MAP: number; - readonly TEXTURE_CUBE_MAP: number; - readonly TEXTURE_CUBE_MAP_NEGATIVE_X: number; - readonly TEXTURE_CUBE_MAP_NEGATIVE_Y: number; - readonly TEXTURE_CUBE_MAP_NEGATIVE_Z: number; - readonly TEXTURE_CUBE_MAP_POSITIVE_X: number; - readonly TEXTURE_CUBE_MAP_POSITIVE_Y: number; - readonly TEXTURE_CUBE_MAP_POSITIVE_Z: number; - readonly TEXTURE_MAG_FILTER: number; - readonly TEXTURE_MIN_FILTER: number; - readonly TEXTURE_WRAP_S: number; - readonly TEXTURE_WRAP_T: number; - readonly TEXTURE0: number; - readonly TEXTURE1: number; - readonly TEXTURE10: number; - readonly TEXTURE11: number; - readonly TEXTURE12: number; - readonly TEXTURE13: number; - readonly TEXTURE14: number; - readonly TEXTURE15: number; - readonly TEXTURE16: number; - readonly TEXTURE17: number; - readonly TEXTURE18: number; - readonly TEXTURE19: number; - readonly TEXTURE2: number; - readonly TEXTURE20: number; - readonly TEXTURE21: number; - readonly TEXTURE22: number; - readonly TEXTURE23: number; - readonly TEXTURE24: number; - readonly TEXTURE25: number; - readonly TEXTURE26: number; - readonly TEXTURE27: number; - readonly TEXTURE28: number; - readonly TEXTURE29: number; - readonly TEXTURE3: number; - readonly TEXTURE30: number; - readonly TEXTURE31: number; - readonly TEXTURE4: number; - readonly TEXTURE5: number; - readonly TEXTURE6: number; - readonly TEXTURE7: number; - readonly TEXTURE8: number; - readonly TEXTURE9: number; - readonly TRIANGLE_FAN: number; - readonly TRIANGLE_STRIP: number; - readonly TRIANGLES: number; - readonly UNPACK_ALIGNMENT: number; - readonly UNPACK_COLORSPACE_CONVERSION_WEBGL: number; - readonly UNPACK_FLIP_Y_WEBGL: number; - readonly UNPACK_PREMULTIPLY_ALPHA_WEBGL: number; - readonly UNSIGNED_BYTE: number; - readonly UNSIGNED_INT: number; - readonly UNSIGNED_SHORT: number; - readonly UNSIGNED_SHORT_4_4_4_4: number; - readonly UNSIGNED_SHORT_5_5_5_1: number; - readonly UNSIGNED_SHORT_5_6_5: number; - readonly VALIDATE_STATUS: number; - readonly VENDOR: number; - readonly VERSION: number; - readonly VERTEX_ATTRIB_ARRAY_BUFFER_BINDING: number; - readonly VERTEX_ATTRIB_ARRAY_ENABLED: number; - readonly VERTEX_ATTRIB_ARRAY_NORMALIZED: number; - readonly VERTEX_ATTRIB_ARRAY_POINTER: number; - readonly VERTEX_ATTRIB_ARRAY_SIZE: number; - readonly VERTEX_ATTRIB_ARRAY_STRIDE: number; - readonly VERTEX_ATTRIB_ARRAY_TYPE: number; - readonly VERTEX_SHADER: number; - readonly VIEWPORT: number; - readonly ZERO: number; }; interface WebGLShader extends WebGLObject { @@ -12825,9 +10802,9 @@ declare var WebGLShader: { }; interface WebGLShaderPrecisionFormat { - readonly precision: number; - readonly rangeMax: number; - readonly rangeMin: number; + readonly precision: GLint; + readonly rangeMax: GLint; + readonly rangeMin: GLint; } declare var WebGLShaderPrecisionFormat: { @@ -12851,116 +10828,6 @@ declare var WebGLUniformLocation: { new(): WebGLUniformLocation; }; -interface WebKitCSSMatrix { - a: number; - b: number; - c: number; - d: number; - e: number; - f: number; - m11: number; - m12: number; - m13: number; - m14: number; - m21: number; - m22: number; - m23: number; - m24: number; - m31: number; - m32: number; - m33: number; - m34: number; - m41: number; - m42: number; - m43: number; - m44: number; - inverse(): WebKitCSSMatrix; - multiply(secondMatrix: WebKitCSSMatrix): WebKitCSSMatrix; - rotate(angleX: number, angleY?: number, angleZ?: number): WebKitCSSMatrix; - rotateAxisAngle(x: number, y: number, z: number, angle: number): WebKitCSSMatrix; - scale(scaleX: number, scaleY?: number, scaleZ?: number): WebKitCSSMatrix; - setMatrixValue(value: string): void; - skewX(angle: number): WebKitCSSMatrix; - skewY(angle: number): WebKitCSSMatrix; - toString(): string; - translate(x: number, y: number, z?: number): WebKitCSSMatrix; -} - -declare var WebKitCSSMatrix: { - prototype: WebKitCSSMatrix; - new(text?: string): WebKitCSSMatrix; -}; - -interface WebKitDirectoryEntry extends WebKitEntry { - createReader(): WebKitDirectoryReader; -} - -declare var WebKitDirectoryEntry: { - prototype: WebKitDirectoryEntry; - new(): WebKitDirectoryEntry; -}; - -interface WebKitDirectoryReader { - readEntries(successCallback: WebKitEntriesCallback, errorCallback?: WebKitErrorCallback): void; -} - -declare var WebKitDirectoryReader: { - prototype: WebKitDirectoryReader; - new(): WebKitDirectoryReader; -}; - -interface WebKitEntry { - readonly filesystem: WebKitFileSystem; - readonly fullPath: string; - readonly isDirectory: boolean; - readonly isFile: boolean; - readonly name: string; -} - -declare var WebKitEntry: { - prototype: WebKitEntry; - new(): WebKitEntry; -}; - -interface WebKitFileEntry extends WebKitEntry { - file(successCallback: WebKitFileCallback, errorCallback?: WebKitErrorCallback): void; -} - -declare var WebKitFileEntry: { - prototype: WebKitFileEntry; - new(): WebKitFileEntry; -}; - -interface WebKitFileSystem { - readonly name: string; - readonly root: WebKitDirectoryEntry; -} - -declare var WebKitFileSystem: { - prototype: WebKitFileSystem; - new(): WebKitFileSystem; -}; - -interface WebKitPoint { - x: number; - y: number; -} - -declare var WebKitPoint: { - prototype: WebKitPoint; - new(x?: number, y?: number): WebKitPoint; -}; - -interface webkitRTCPeerConnection extends RTCPeerConnection { - addEventListener(type: K, listener: (this: webkitRTCPeerConnection, ev: RTCPeerConnectionEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; -} - -declare var webkitRTCPeerConnection: { - prototype: webkitRTCPeerConnection; - new(configuration: RTCConfiguration): webkitRTCPeerConnection; -}; - interface WebSocketEventMap { "close": CloseEvent; "error": Event; @@ -12969,7 +10836,7 @@ interface WebSocketEventMap { } interface WebSocket extends EventTarget { - binaryType: string; + binaryType: BinaryType; readonly bufferedAmount: number; readonly extensions: string; onclose: (this: WebSocket, ev: CloseEvent) => any; @@ -12980,13 +10847,16 @@ interface WebSocket extends EventTarget { readonly readyState: number; readonly url: string; close(code?: number, reason?: string): void; - send(data: any): void; + send(data: string): void; + send(data: Blob): void; + send(data: ArrayBuffer): void; + send(data: ArrayBufferView): void; readonly CLOSED: number; readonly CLOSING: number; readonly CONNECTING: number; readonly OPEN: number; addEventListener(type: K, listener: (this: WebSocket, ev: WebSocketEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var WebSocket: { @@ -13003,11 +10873,6 @@ interface WheelEvent extends MouseEvent { readonly deltaX: number; readonly deltaY: number; readonly deltaZ: number; - readonly wheelDelta: number; - readonly wheelDeltaX: number; - readonly wheelDeltaY: number; - getCurrentPoint(element: Element): void; - initWheelEvent(typeArg: string, canBubbleArg: boolean, cancelableArg: boolean, viewArg: Window, detailArg: number, screenXArg: number, screenYArg: number, clientXArg: number, clientYArg: number, buttonArg: number, relatedTargetArg: EventTarget, modifiersListArg: string, deltaXArg: number, deltaYArg: number, deltaZArg: number, deltaMode: number): void; readonly DOM_DELTA_LINE: number; readonly DOM_DELTA_PAGE: number; readonly DOM_DELTA_PIXEL: number; @@ -13015,291 +10880,91 @@ interface WheelEvent extends MouseEvent { declare var WheelEvent: { prototype: WheelEvent; - new(typeArg: string, eventInitDict?: WheelEventInit): WheelEvent; + new(type: string, eventInitDict?: WheelEventInit): WheelEvent; readonly DOM_DELTA_LINE: number; readonly DOM_DELTA_PAGE: number; readonly DOM_DELTA_PIXEL: number; }; -interface WindowEventMap extends GlobalEventHandlersEventMap { - "abort": UIEvent; - "afterprint": Event; - "beforeprint": Event; - "beforeunload": BeforeUnloadEvent; - "blur": FocusEvent; - "canplay": Event; - "canplaythrough": Event; - "change": Event; - "click": MouseEvent; - "compassneedscalibration": Event; - "contextmenu": PointerEvent; - "dblclick": MouseEvent; - "devicelight": DeviceLightEvent; +interface WindowEventMap extends GlobalEventHandlersEventMap, WindowEventHandlersEventMap { "devicemotion": DeviceMotionEvent; "deviceorientation": DeviceOrientationEvent; - "drag": DragEvent; - "dragend": DragEvent; - "dragenter": DragEvent; - "dragleave": DragEvent; - "dragover": DragEvent; - "dragstart": DragEvent; - "drop": DragEvent; - "durationchange": Event; - "emptied": Event; - "ended": MediaStreamErrorEvent; - "error": ErrorEvent; - "focus": FocusEvent; - "hashchange": HashChangeEvent; - "input": Event; - "invalid": Event; - "keydown": KeyboardEvent; - "keypress": KeyboardEvent; - "keyup": KeyboardEvent; - "load": Event; - "loadeddata": Event; - "loadedmetadata": Event; - "loadstart": Event; - "message": MessageEvent; - "mousedown": MouseEvent; - "mouseenter": MouseEvent; - "mouseleave": MouseEvent; - "mousemove": MouseEvent; - "mouseout": MouseEvent; - "mouseover": MouseEvent; - "mouseup": MouseEvent; - "mousewheel": WheelEvent; - "MSGestureChange": MSGestureEvent; - "MSGestureDoubleTap": MSGestureEvent; - "MSGestureEnd": MSGestureEvent; - "MSGestureHold": MSGestureEvent; - "MSGestureStart": MSGestureEvent; - "MSGestureTap": MSGestureEvent; - "MSInertiaStart": MSGestureEvent; - "MSPointerCancel": MSPointerEvent; - "MSPointerDown": MSPointerEvent; - "MSPointerEnter": MSPointerEvent; - "MSPointerLeave": MSPointerEvent; - "MSPointerMove": MSPointerEvent; - "MSPointerOut": MSPointerEvent; - "MSPointerOver": MSPointerEvent; - "MSPointerUp": MSPointerEvent; - "offline": Event; - "online": Event; - "orientationchange": Event; - "pagehide": PageTransitionEvent; - "pageshow": PageTransitionEvent; - "pause": Event; - "play": Event; - "playing": Event; - "popstate": PopStateEvent; - "progress": ProgressEvent; - "ratechange": Event; - "readystatechange": ProgressEvent; - "reset": Event; - "resize": UIEvent; - "scroll": UIEvent; - "seeked": Event; - "seeking": Event; - "select": UIEvent; - "stalled": Event; - "storage": StorageEvent; - "submit": Event; - "suspend": Event; - "timeupdate": Event; - "touchcancel": TouchEvent; - "touchend": TouchEvent; - "touchmove": TouchEvent; - "touchstart": TouchEvent; - "unload": Event; - "volumechange": Event; - "waiting": Event; } -interface Window extends EventTarget, WindowTimers, WindowSessionStorage, WindowLocalStorage, WindowConsole, GlobalEventHandlers, IDBEnvironment, WindowBase64, GlobalFetch { +interface Window extends EventTarget, GlobalEventHandlers, WindowEventHandlers, WindowOrWorkerGlobalScope, WindowSessionStorage, WindowLocalStorage, GlobalPerformance, GlobalCrypto, SpeechSynthesisGetter { readonly applicationCache: ApplicationCache; - readonly caches: CacheStorage; - readonly clientInformation: Navigator; + readonly audioWorklet: Worklet; readonly closed: boolean; - readonly crypto: Crypto; - defaultStatus: string; + readonly customElements: CustomElementRegistry; readonly devicePixelRatio: number; readonly document: Document; - readonly doNotTrack: string; - event: Event | undefined; readonly external: External; - readonly frameElement: Element; + readonly frameElement: Element | null; readonly frames: Window; readonly history: History; readonly innerHeight: number; readonly innerWidth: number; - readonly isSecureContext: boolean; readonly length: number; readonly location: Location; readonly locationbar: BarProp; readonly menubar: BarProp; - readonly msContentScript: ExtensionScriptApis; - readonly msCredentials: MSCredentials; name: string; readonly navigator: Navigator; - offscreenBuffering: string | boolean; - onabort: (this: Window, ev: UIEvent) => any; - onafterprint: (this: Window, ev: Event) => any; - onbeforeprint: (this: Window, ev: Event) => any; - onbeforeunload: (this: Window, ev: BeforeUnloadEvent) => any; - onblur: (this: Window, ev: FocusEvent) => any; - oncanplay: (this: Window, ev: Event) => any; - oncanplaythrough: (this: Window, ev: Event) => any; - onchange: (this: Window, ev: Event) => any; - onclick: (this: Window, ev: MouseEvent) => any; - oncompassneedscalibration: (this: Window, ev: Event) => any; - oncontextmenu: (this: Window, ev: PointerEvent) => any; - ondblclick: (this: Window, ev: MouseEvent) => any; - ondevicelight: (this: Window, ev: DeviceLightEvent) => any; ondevicemotion: (this: Window, ev: DeviceMotionEvent) => any; ondeviceorientation: (this: Window, ev: DeviceOrientationEvent) => any; - ondrag: (this: Window, ev: DragEvent) => any; - ondragend: (this: Window, ev: DragEvent) => any; - ondragenter: (this: Window, ev: DragEvent) => any; - ondragleave: (this: Window, ev: DragEvent) => any; - ondragover: (this: Window, ev: DragEvent) => any; - ondragstart: (this: Window, ev: DragEvent) => any; - ondrop: (this: Window, ev: DragEvent) => any; - ondurationchange: (this: Window, ev: Event) => any; - onemptied: (this: Window, ev: Event) => any; - onended: (this: Window, ev: MediaStreamErrorEvent) => any; - onerror: ErrorEventHandler; - onfocus: (this: Window, ev: FocusEvent) => any; - onhashchange: (this: Window, ev: HashChangeEvent) => any; - oninput: (this: Window, ev: Event) => any; - oninvalid: (this: Window, ev: Event) => any; - onkeydown: (this: Window, ev: KeyboardEvent) => any; - onkeypress: (this: Window, ev: KeyboardEvent) => any; - onkeyup: (this: Window, ev: KeyboardEvent) => any; - onload: (this: Window, ev: Event) => any; - onloadeddata: (this: Window, ev: Event) => any; - onloadedmetadata: (this: Window, ev: Event) => any; - onloadstart: (this: Window, ev: Event) => any; - onmessage: (this: Window, ev: MessageEvent) => any; - onmousedown: (this: Window, ev: MouseEvent) => any; - onmouseenter: (this: Window, ev: MouseEvent) => any; - onmouseleave: (this: Window, ev: MouseEvent) => any; - onmousemove: (this: Window, ev: MouseEvent) => any; - onmouseout: (this: Window, ev: MouseEvent) => any; - onmouseover: (this: Window, ev: MouseEvent) => any; - onmouseup: (this: Window, ev: MouseEvent) => any; - onmousewheel: (this: Window, ev: WheelEvent) => any; - onmsgesturechange: (this: Window, ev: MSGestureEvent) => any; - onmsgesturedoubletap: (this: Window, ev: MSGestureEvent) => any; - onmsgestureend: (this: Window, ev: MSGestureEvent) => any; - onmsgesturehold: (this: Window, ev: MSGestureEvent) => any; - onmsgesturestart: (this: Window, ev: MSGestureEvent) => any; - onmsgesturetap: (this: Window, ev: MSGestureEvent) => any; - onmsinertiastart: (this: Window, ev: MSGestureEvent) => any; - onmspointercancel: (this: Window, ev: MSPointerEvent) => any; - onmspointerdown: (this: Window, ev: MSPointerEvent) => any; - onmspointerenter: (this: Window, ev: MSPointerEvent) => any; - onmspointerleave: (this: Window, ev: MSPointerEvent) => any; - onmspointermove: (this: Window, ev: MSPointerEvent) => any; - onmspointerout: (this: Window, ev: MSPointerEvent) => any; - onmspointerover: (this: Window, ev: MSPointerEvent) => any; - onmspointerup: (this: Window, ev: MSPointerEvent) => any; - onoffline: (this: Window, ev: Event) => any; - ononline: (this: Window, ev: Event) => any; - onorientationchange: (this: Window, ev: Event) => any; - onpagehide: (this: Window, ev: PageTransitionEvent) => any; - onpageshow: (this: Window, ev: PageTransitionEvent) => any; - onpause: (this: Window, ev: Event) => any; - onplay: (this: Window, ev: Event) => any; - onplaying: (this: Window, ev: Event) => any; - onpopstate: (this: Window, ev: PopStateEvent) => any; - onprogress: (this: Window, ev: ProgressEvent) => any; - onratechange: (this: Window, ev: Event) => any; - onreadystatechange: (this: Window, ev: ProgressEvent) => any; - onreset: (this: Window, ev: Event) => any; - onresize: (this: Window, ev: UIEvent) => any; - onscroll: (this: Window, ev: UIEvent) => any; - onseeked: (this: Window, ev: Event) => any; - onseeking: (this: Window, ev: Event) => any; - onselect: (this: Window, ev: UIEvent) => any; - onstalled: (this: Window, ev: Event) => any; - onstorage: (this: Window, ev: StorageEvent) => any; - onsubmit: (this: Window, ev: Event) => any; - onsuspend: (this: Window, ev: Event) => any; - ontimeupdate: (this: Window, ev: Event) => any; - ontouchcancel: (ev: TouchEvent) => any; - ontouchend: (ev: TouchEvent) => any; - ontouchmove: (ev: TouchEvent) => any; - ontouchstart: (ev: TouchEvent) => any; - onunload: (this: Window, ev: Event) => any; - onvolumechange: (this: Window, ev: Event) => any; - onwaiting: (this: Window, ev: Event) => any; opener: any; - orientation: string | number; readonly outerHeight: number; readonly outerWidth: number; readonly pageXOffset: number; readonly pageYOffset: number; - readonly parent: Window; - readonly performance: Performance; + readonly parent: Window | null; readonly personalbar: BarProp; readonly screen: Screen; - readonly screenLeft: number; - readonly screenTop: number; readonly screenX: number; readonly screenY: number; readonly scrollbars: BarProp; readonly scrollX: number; readonly scrollY: number; readonly self: Window; - readonly speechSynthesis: SpeechSynthesis; status: string; readonly statusbar: BarProp; - readonly styleMedia: StyleMedia; readonly toolbar: BarProp; - readonly top: Window; + readonly top: Window | null; readonly window: Window; - URL: typeof URL; URLSearchParams: typeof URLSearchParams; Blob: typeof Blob; - customElements: CustomElementRegistry; + alert(message?: any): void; alert(message?: any): void; blur(): void; cancelAnimationFrame(handle: number): void; captureEvents(): void; close(): void; confirm(message?: string): boolean; - departFocus(navigationReason: NavigationReason, origin: FocusNavigationOrigin): void; focus(): void; - getComputedStyle(elt: Element, pseudoElt?: string): CSSStyleDeclaration; - getMatchedCSSRules(elt: Element, pseudoElt?: string): CSSRuleList; - getSelection(): Selection; - matchMedia(mediaQuery: string): MediaQueryList; - moveBy(x?: number, y?: number): void; - moveTo(x?: number, y?: number): void; - msWriteProfilerMark(profilerMarkName: string): void; + getComputedStyle(elt: Element, pseudoElt?: CSSOMString): CSSStyleDeclaration; + getSelection(): Selection | null; + matchMedia(query: string): MediaQueryList; + moveBy(x: number, y: number): void; + moveTo(x: number, y: number): void; open(url?: string, target?: string, features?: string, replace?: boolean): Window; postMessage(message: any, targetOrigin: string, transfer?: any[]): void; print(): void; prompt(message?: string, _default?: string): string | null; releaseEvents(): void; requestAnimationFrame(callback: FrameRequestCallback): number; - resizeBy(x?: number, y?: number): void; - resizeTo(x?: number, y?: number): void; - scroll(x?: number, y?: number): void; - scrollBy(x?: number, y?: number): void; - scrollTo(x?: number, y?: number): void; + resizeBy(x: number, y: number): void; + resizeTo(x: number, y: number): void; + scroll(options?: ScrollToOptions): void; + scroll(x: number, y: number): void; + scrollBy(options?: ScrollToOptions): void; + scrollBy(x: number, y: number): void; + scrollTo(options?: ScrollToOptions): void; + scrollTo(x: number, y: number): void; stop(): void; - webkitCancelAnimationFrame(handle: number): void; - webkitConvertPointFromNodeToPage(node: Node, pt: WebKitPoint): WebKitPoint; - webkitConvertPointFromPageToNode(node: Node, pt: WebKitPoint): WebKitPoint; - webkitRequestAnimationFrame(callback: FrameRequestCallback): number; createImageBitmap(image: HTMLImageElement | SVGImageElement | HTMLVideoElement | HTMLCanvasElement | ImageBitmap | ImageData | Blob, options?: ImageBitmapOptions): Promise; createImageBitmap(image: HTMLImageElement | SVGImageElement | HTMLVideoElement | HTMLCanvasElement | ImageBitmap | ImageData | Blob, sx: number, sy: number, sw: number, sh: number, options?: ImageBitmapOptions): Promise; - scroll(options?: ScrollToOptions): void; - scrollTo(options?: ScrollToOptions): void; - scrollBy(options?: ScrollToOptions): void; addEventListener(type: K, listener: (this: Window, ev: WindowEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var Window: { @@ -13309,24 +10974,35 @@ declare var Window: { interface WorkerEventMap extends AbstractWorkerEventMap { "message": MessageEvent; + "messageerror": MessageEvent; } interface Worker extends EventTarget, AbstractWorker { onmessage: (this: Worker, ev: MessageEvent) => any; + onmessageerror: (this: Worker, ev: MessageEvent) => any; postMessage(message: any, transfer?: any[]): void; terminate(): void; addEventListener(type: K, listener: (this: Worker, ev: WorkerEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var Worker: { prototype: Worker; - new(stringUrl: string): Worker; + new(scriptURL: string, options?: WorkerOptions): Worker; +}; + +interface Worklet { + addModule(moduleURL: string, options?: WorkletOptions): Promise; +} + +declare var Worklet: { + prototype: Worklet; + new(): Worklet; }; interface XMLDocument extends Document { addEventListener(type: K, listener: (this: XMLDocument, ev: DocumentEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var XMLDocument: { @@ -13338,7 +11014,7 @@ interface XMLHttpRequestEventMap extends XMLHttpRequestEventTargetEventMap { "readystatechange": Event; } -interface XMLHttpRequest extends EventTarget, XMLHttpRequestEventTarget { +interface XMLHttpRequest extends XMLHttpRequestEventTarget { onreadystatechange: (this: XMLHttpRequest, ev: Event) => any; readonly readyState: number; readonly response: any; @@ -13354,21 +11030,21 @@ interface XMLHttpRequest extends EventTarget, XMLHttpRequestEventTarget { msCaching?: string; abort(): void; getAllResponseHeaders(): string; - getResponseHeader(header: string): string | null; - msCachingEnabled(): boolean; - open(method: string, url: string, async?: boolean, user?: string, password?: string): void; + getResponseHeader(name: string): string | null; + open(method: string, url: string): void; + open(method: string, url: string, async: boolean, username?: string, password?: string): void; overrideMimeType(mime: string): void; send(data?: Document): void; send(data?: string): void; send(data?: any): void; - setRequestHeader(header: string, value: string): void; + setRequestHeader(name: string, value: string): void; readonly DONE: number; readonly HEADERS_RECEIVED: number; readonly LOADING: number; readonly OPENED: number; readonly UNSENT: number; addEventListener(type: K, listener: (this: XMLHttpRequest, ev: XMLHttpRequestEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var XMLHttpRequest: { @@ -13381,9 +11057,36 @@ declare var XMLHttpRequest: { readonly UNSENT: number; }; -interface XMLHttpRequestUpload extends EventTarget, XMLHttpRequestEventTarget { +interface XMLHttpRequestEventTargetEventMap { + "abort": Event; + "error": ErrorEvent; + "load": Event; + "loadend": Event; + "loadstart": Event; + "progress": ProgressEvent; + "timeout": ProgressEvent; +} + +interface XMLHttpRequestEventTarget extends EventTarget { + onabort: (this: XMLHttpRequest, ev: Event) => any; + onerror: (this: XMLHttpRequest, ev: ErrorEvent) => any; + onload: (this: XMLHttpRequest, ev: Event) => any; + onloadend: (this: XMLHttpRequest, ev: ProgressEvent) => any; + onloadstart: (this: XMLHttpRequest, ev: Event) => any; + onprogress: (this: XMLHttpRequest, ev: ProgressEvent) => any; + ontimeout: (this: XMLHttpRequest, ev: ProgressEvent) => any; + addEventListener(type: K, listener: (this: XMLHttpRequestEventTarget, ev: XMLHttpRequestEventTargetEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; +} + +declare var XMLHttpRequestEventTarget: { + prototype: XMLHttpRequestEventTarget; + new(): XMLHttpRequestEventTarget; +}; + +interface XMLHttpRequestUpload extends XMLHttpRequestEventTarget { addEventListener(type: K, listener: (this: XMLHttpRequestUpload, ev: XMLHttpRequestEventTargetEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var XMLHttpRequestUpload: { @@ -13392,7 +11095,7 @@ declare var XMLHttpRequestUpload: { }; interface XMLSerializer { - serializeToString(target: Node): string; + serializeToString(root: Node): string; } declare var XMLSerializer: { @@ -13400,88 +11103,6 @@ declare var XMLSerializer: { new(): XMLSerializer; }; -interface XPathEvaluator { - createExpression(expression: string, resolver: XPathNSResolver): XPathExpression; - createNSResolver(nodeResolver?: Node): XPathNSResolver; - evaluate(expression: string, contextNode: Node, resolver: XPathNSResolver | null, type: number, result: XPathResult | null): XPathResult; -} - -declare var XPathEvaluator: { - prototype: XPathEvaluator; - new(): XPathEvaluator; -}; - -interface XPathExpression { - evaluate(contextNode: Node, type: number, result: XPathResult | null): XPathResult; -} - -declare var XPathExpression: { - prototype: XPathExpression; - new(): XPathExpression; -}; - -interface XPathNSResolver { - lookupNamespaceURI(prefix: string): string; -} - -declare var XPathNSResolver: { - prototype: XPathNSResolver; - new(): XPathNSResolver; -}; - -interface XPathResult { - readonly booleanValue: boolean; - readonly invalidIteratorState: boolean; - readonly numberValue: number; - readonly resultType: number; - readonly singleNodeValue: Node; - readonly snapshotLength: number; - readonly stringValue: string; - iterateNext(): Node; - snapshotItem(index: number): Node; - readonly ANY_TYPE: number; - readonly ANY_UNORDERED_NODE_TYPE: number; - readonly BOOLEAN_TYPE: number; - readonly FIRST_ORDERED_NODE_TYPE: number; - readonly NUMBER_TYPE: number; - readonly ORDERED_NODE_ITERATOR_TYPE: number; - readonly ORDERED_NODE_SNAPSHOT_TYPE: number; - readonly STRING_TYPE: number; - readonly UNORDERED_NODE_ITERATOR_TYPE: number; - readonly UNORDERED_NODE_SNAPSHOT_TYPE: number; -} - -declare var XPathResult: { - prototype: XPathResult; - new(): XPathResult; - readonly ANY_TYPE: number; - readonly ANY_UNORDERED_NODE_TYPE: number; - readonly BOOLEAN_TYPE: number; - readonly FIRST_ORDERED_NODE_TYPE: number; - readonly NUMBER_TYPE: number; - readonly ORDERED_NODE_ITERATOR_TYPE: number; - readonly ORDERED_NODE_SNAPSHOT_TYPE: number; - readonly STRING_TYPE: number; - readonly UNORDERED_NODE_ITERATOR_TYPE: number; - readonly UNORDERED_NODE_SNAPSHOT_TYPE: number; -}; - -interface XSLTProcessor { - clearParameters(): void; - getParameter(namespaceURI: string, localName: string): any; - importStylesheet(style: Node): void; - removeParameter(namespaceURI: string, localName: string): void; - reset(): void; - setParameter(namespaceURI: string, localName: string, value: any): void; - transformToDocument(source: Node): Document; - transformToFragment(source: Node, document: Document): DocumentFragment; -} - -declare var XSLTProcessor: { - prototype: XSLTProcessor; - new(): XSLTProcessor; -}; - interface AbstractWorkerEventMap { "error": ErrorEvent; } @@ -13489,814 +11110,1358 @@ interface AbstractWorkerEventMap { interface AbstractWorker { onerror: (this: AbstractWorker, ev: ErrorEvent) => any; addEventListener(type: K, listener: (this: AbstractWorker, ev: AbstractWorkerEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; +} + +interface ANGLE_instanced_arrays { + drawArraysInstancedANGLE(mode: GLenum, first: GLint, count: GLsizei, primcount: GLsizei): void; + drawElementsInstancedANGLE(mode: GLenum, count: GLsizei, type: GLenum, offset: GLintptr, primcount: GLsizei): void; + vertexAttribDivisorANGLE(index: GLuint, divisor: GLuint): void; + readonly VERTEX_ATTRIB_ARRAY_DIVISOR_ANGLE: GLenum; } interface Body { + readonly body: ReadableStream | null; readonly bodyUsed: boolean; arrayBuffer(): Promise; blob(): Promise; + formData(): Promise; json(): Promise; text(): Promise; formData(): Promise; } -interface CanvasPathMethods { - arc(x: number, y: number, radius: number, startAngle: number, endAngle: number, anticlockwise?: boolean): void; - arcTo(x1: number, y1: number, x2: number, y2: number, radius: number): void; - bezierCurveTo(cp1x: number, cp1y: number, cp2x: number, cp2y: number, x: number, y: number): void; - closePath(): void; - ellipse(x: number, y: number, radiusX: number, radiusY: number, rotation: number, startAngle: number, endAngle: number, anticlockwise?: boolean): void; - lineTo(x: number, y: number): void; - moveTo(x: number, y: number): void; - quadraticCurveTo(cpx: number, cpy: number, x: number, y: number): void; - rect(x: number, y: number, w: number, h: number): void; +interface CanvasCompositing { + globalAlpha: number; + globalCompositeOperation: string; } -interface ChildNode { - remove(): void; +interface CanvasDrawImage { + drawImage(image: CanvasImageSource, dx: number, dy: number): void; + drawImage(image: CanvasImageSource, dx: number, dy: number, dw: number, dh: number): void; + drawImage(image: CanvasImageSource, sx: number, sy: number, sw: number, sh: number, dx: number, dy: number, dw: number, dh: number): void; } -interface DocumentEvent { - createEvent(eventInterface: "AnimationEvent"): AnimationEvent; - createEvent(eventInterface: "AudioProcessingEvent"): AudioProcessingEvent; - createEvent(eventInterface: "BeforeUnloadEvent"): BeforeUnloadEvent; - createEvent(eventInterface: "ClipboardEvent"): ClipboardEvent; - createEvent(eventInterface: "CloseEvent"): CloseEvent; - createEvent(eventInterface: "CompositionEvent"): CompositionEvent; - createEvent(eventInterface: "CustomEvent"): CustomEvent; - createEvent(eventInterface: "DeviceLightEvent"): DeviceLightEvent; - createEvent(eventInterface: "DeviceMotionEvent"): DeviceMotionEvent; - createEvent(eventInterface: "DeviceOrientationEvent"): DeviceOrientationEvent; - createEvent(eventInterface: "DragEvent"): DragEvent; - createEvent(eventInterface: "ErrorEvent"): ErrorEvent; - createEvent(eventInterface: "Event"): Event; - createEvent(eventInterface: "Events"): Event; - createEvent(eventInterface: "FocusEvent"): FocusEvent; - createEvent(eventInterface: "FocusNavigationEvent"): FocusNavigationEvent; - createEvent(eventInterface: "GamepadEvent"): GamepadEvent; - createEvent(eventInterface: "HashChangeEvent"): HashChangeEvent; - createEvent(eventInterface: "IDBVersionChangeEvent"): IDBVersionChangeEvent; - createEvent(eventInterface: "KeyboardEvent"): KeyboardEvent; - createEvent(eventInterface: "ListeningStateChangedEvent"): ListeningStateChangedEvent; - createEvent(eventInterface: "LongRunningScriptDetectedEvent"): LongRunningScriptDetectedEvent; - createEvent(eventInterface: "MSGestureEvent"): MSGestureEvent; - createEvent(eventInterface: "MSManipulationEvent"): MSManipulationEvent; - createEvent(eventInterface: "MSMediaKeyMessageEvent"): MSMediaKeyMessageEvent; - createEvent(eventInterface: "MSMediaKeyNeededEvent"): MSMediaKeyNeededEvent; - createEvent(eventInterface: "MSPointerEvent"): MSPointerEvent; - createEvent(eventInterface: "MSSiteModeEvent"): MSSiteModeEvent; - createEvent(eventInterface: "MediaEncryptedEvent"): MediaEncryptedEvent; - createEvent(eventInterface: "MediaKeyMessageEvent"): MediaKeyMessageEvent; - createEvent(eventInterface: "MediaStreamErrorEvent"): MediaStreamErrorEvent; - createEvent(eventInterface: "MediaStreamEvent"): MediaStreamEvent; - createEvent(eventInterface: "MediaStreamTrackEvent"): MediaStreamTrackEvent; - createEvent(eventInterface: "MessageEvent"): MessageEvent; - createEvent(eventInterface: "MouseEvent"): MouseEvent; - createEvent(eventInterface: "MouseEvents"): MouseEvent; - createEvent(eventInterface: "MutationEvent"): MutationEvent; - createEvent(eventInterface: "MutationEvents"): MutationEvent; - createEvent(eventInterface: "NavigationCompletedEvent"): NavigationCompletedEvent; - createEvent(eventInterface: "NavigationEvent"): NavigationEvent; - createEvent(eventInterface: "NavigationEventWithReferrer"): NavigationEventWithReferrer; - createEvent(eventInterface: "OfflineAudioCompletionEvent"): OfflineAudioCompletionEvent; - createEvent(eventInterface: "OverflowEvent"): OverflowEvent; - createEvent(eventInterface: "PageTransitionEvent"): PageTransitionEvent; - createEvent(eventInterface: "PaymentRequestUpdateEvent"): PaymentRequestUpdateEvent; - createEvent(eventInterface: "PermissionRequestedEvent"): PermissionRequestedEvent; - createEvent(eventInterface: "PointerEvent"): PointerEvent; - createEvent(eventInterface: "PopStateEvent"): PopStateEvent; - createEvent(eventInterface: "ProgressEvent"): ProgressEvent; - createEvent(eventInterface: "RTCDTMFToneChangeEvent"): RTCDTMFToneChangeEvent; - createEvent(eventInterface: "RTCDtlsTransportStateChangedEvent"): RTCDtlsTransportStateChangedEvent; - createEvent(eventInterface: "RTCIceCandidatePairChangedEvent"): RTCIceCandidatePairChangedEvent; - createEvent(eventInterface: "RTCIceGathererEvent"): RTCIceGathererEvent; - createEvent(eventInterface: "RTCIceTransportStateChangedEvent"): RTCIceTransportStateChangedEvent; - createEvent(eventInterface: "RTCPeerConnectionIceEvent"): RTCPeerConnectionIceEvent; - createEvent(eventInterface: "RTCSsrcConflictEvent"): RTCSsrcConflictEvent; - createEvent(eventInterface: "SVGZoomEvent"): SVGZoomEvent; - createEvent(eventInterface: "SVGZoomEvents"): SVGZoomEvent; - createEvent(eventInterface: "ScriptNotifyEvent"): ScriptNotifyEvent; - createEvent(eventInterface: "ServiceWorkerMessageEvent"): ServiceWorkerMessageEvent; - createEvent(eventInterface: "SpeechSynthesisEvent"): SpeechSynthesisEvent; - createEvent(eventInterface: "StorageEvent"): StorageEvent; - createEvent(eventInterface: "TextEvent"): TextEvent; - createEvent(eventInterface: "TouchEvent"): TouchEvent; - createEvent(eventInterface: "TrackEvent"): TrackEvent; - createEvent(eventInterface: "TransitionEvent"): TransitionEvent; - createEvent(eventInterface: "UIEvent"): UIEvent; - createEvent(eventInterface: "UIEvents"): UIEvent; - createEvent(eventInterface: "UnviewableContentIdentifiedEvent"): UnviewableContentIdentifiedEvent; - createEvent(eventInterface: "WebGLContextEvent"): WebGLContextEvent; - createEvent(eventInterface: "WheelEvent"): WheelEvent; - createEvent(eventInterface: string): Event; -} - -interface DOML2DeprecatedColorProperty { - color: string; -} - -interface DOML2DeprecatedSizeProperty { - size: number; -} - -interface ElementTraversal { - readonly childElementCount: number; - readonly firstElementChild: Element | null; - readonly lastElementChild: Element | null; - readonly nextElementSibling: Element | null; - readonly previousElementSibling: Element | null; +interface CanvasDrawPath { + beginPath(): void; + clip(fillRule?: CanvasFillRule): void; + clip(path: Path2D, fillRule?: CanvasFillRule): void; + fill(path: Path2D, fillRule?: CanvasFillRule): void; + fill(fillRule?: CanvasFillRule): void; + isPointInPath(x: number, y: number, fillRule?: CanvasFillRule): boolean; + isPointInPath(path: Path2D, x: number, y: number, fillRule?: CanvasFillRule): boolean; + isPointInStroke(x: number, y: number): boolean; + isPointInStroke(path: Path2D, x: number, y: number): boolean; + resetClip(): void; + stroke(): void; + stroke(path: Path2D): void; } -interface GetSVGDocument { - getSVGDocument(): Document; +interface CanvasFillStrokeStyles { + fillStyle: string | CanvasGradient | CanvasPattern; + strokeStyle: string | CanvasGradient | CanvasPattern; + createLinearGradient(x0: number, y0: number, x1: number, y1: number): CanvasGradient; + createPattern(image: CanvasImageSource, repetition: string): CanvasPattern | null; + createRadialGradient(x0: number, y0: number, r0: number, x1: number, y1: number, r1: number): CanvasGradient; } -interface GlobalEventHandlersEventMap { - "pointercancel": PointerEvent; - "pointerdown": PointerEvent; - "pointerenter": PointerEvent; - "pointerleave": PointerEvent; - "pointermove": PointerEvent; - "pointerout": PointerEvent; - "pointerover": PointerEvent; - "pointerup": PointerEvent; - "wheel": WheelEvent; +interface CanvasFilters { + filter: string; } -interface GlobalEventHandlers { - onpointercancel: (this: GlobalEventHandlers, ev: PointerEvent) => any; - onpointerdown: (this: GlobalEventHandlers, ev: PointerEvent) => any; - onpointerenter: (this: GlobalEventHandlers, ev: PointerEvent) => any; - onpointerleave: (this: GlobalEventHandlers, ev: PointerEvent) => any; - onpointermove: (this: GlobalEventHandlers, ev: PointerEvent) => any; - onpointerout: (this: GlobalEventHandlers, ev: PointerEvent) => any; - onpointerover: (this: GlobalEventHandlers, ev: PointerEvent) => any; - onpointerup: (this: GlobalEventHandlers, ev: PointerEvent) => any; - onwheel: (this: GlobalEventHandlers, ev: WheelEvent) => any; - addEventListener(type: K, listener: (this: GlobalEventHandlers, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; +interface CanvasImageData { + createImageData(sw: number, sh: number): ImageData; + createImageData(imagedata: ImageData): ImageData; + getImageData(sx: number, sy: number, sw: number, sh: number): ImageData; + putImageData(imagedata: ImageData, dx: number, dy: number): void; + putImageData(imagedata: ImageData, dx: number, dy: number, dirtyX: number, dirtyY: number, dirtyWidth: number, dirtyHeight: number): void; } -interface GlobalFetch { - fetch(input: RequestInfo, init?: RequestInit): Promise; +interface CanvasImageSmoothing { + imageSmoothingEnabled: boolean; + imageSmoothingQuality: ImageSmoothingQuality; } -interface HTMLTableAlignment { - /** - * Sets or retrieves a value that you can use to implement your own ch functionality for the object. - */ - ch: string; - /** - * Sets or retrieves a value that you can use to implement your own chOff functionality for the object. - */ - chOff: string; - /** - * Sets or retrieves how text and other content are vertically aligned within the object that contains them. - */ - vAlign: string; +interface CanvasPath { + arc(x: number, y: number, radius: number, startAngle: number, endAngle: number, anticlockwise?: boolean): void; + arcTo(x1: number, y1: number, x2: number, y2: number, radius: number): void; + arcTo(x1: number, y1: number, x2: number, y2: number, radiusX: number, radiusY: number, rotation: number): void; + bezierCurveTo(cp1x: number, cp1y: number, cp2x: number, cp2y: number, x: number, y: number): void; + closePath(): void; + ellipse(x: number, y: number, radiusX: number, radiusY: number, rotation: number, startAngle: number, endAngle: number, anticlockwise?: boolean): void; + lineTo(x: number, y: number): void; + moveTo(x: number, y: number): void; + quadraticCurveTo(cpx: number, cpy: number, x: number, y: number): void; + rect(x: number, y: number, w: number, h: number): void; } -interface IDBEnvironment { - readonly indexedDB: IDBFactory; +interface CanvasPathDrawingStyles { + lineCap: CanvasLineCap; + lineDashOffset: number; + lineJoin: CanvasLineJoin; + lineWidth: number; + miterLimit: number; + getLineDash(): number[]; + setLineDash(segments: number[]): void; } -interface LinkStyle { - readonly sheet: StyleSheet; +interface CanvasRect { + clearRect(x: number, y: number, w: number, h: number): void; + fillRect(x: number, y: number, w: number, h: number): void; + strokeRect(x: number, y: number, w: number, h: number): void; } -interface MSBaseReaderEventMap { - "abort": Event; - "error": ErrorEvent; - "load": Event; - "loadend": ProgressEvent; - "loadstart": Event; - "progress": ProgressEvent; +interface CanvasShadowStyles { + shadowBlur: number; + shadowColor: string; + shadowOffsetX: number; + shadowOffsetY: number; } -interface MSBaseReader { - onabort: (this: MSBaseReader, ev: Event) => any; - onerror: (this: MSBaseReader, ev: ErrorEvent) => any; - onload: (this: MSBaseReader, ev: Event) => any; - onloadend: (this: MSBaseReader, ev: ProgressEvent) => any; - onloadstart: (this: MSBaseReader, ev: Event) => any; - onprogress: (this: MSBaseReader, ev: ProgressEvent) => any; - readonly readyState: number; - readonly result: any; - abort(): void; - readonly DONE: number; - readonly EMPTY: number; - readonly LOADING: number; - addEventListener(type: K, listener: (this: MSBaseReader, ev: MSBaseReaderEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; +interface CanvasState { + restore(): void; + save(): void; } -interface MSFileSaver { - msSaveBlob(blob: any, defaultName?: string): boolean; - msSaveOrOpenBlob(blob: any, defaultName?: string): boolean; +interface CanvasText { + fillText(text: string, x: number, y: number, maxWidth?: number): void; + measureText(text: string): TextMetrics; + strokeText(text: string, x: number, y: number, maxWidth?: number): void; } -interface MSNavigatorDoNotTrack { - confirmSiteSpecificTrackingException(args: ConfirmSiteSpecificExceptionsInformation): boolean; - confirmWebWideTrackingException(args: ExceptionInformation): boolean; - removeSiteSpecificTrackingException(args: ExceptionInformation): void; - removeWebWideTrackingException(args: ExceptionInformation): void; - storeSiteSpecificTrackingException(args: StoreSiteSpecificExceptionsInformation): void; - storeWebWideTrackingException(args: StoreExceptionsInformation): void; +interface CanvasTextDrawingStyles { + direction: CanvasDirection; + font: string; + textAlign: CanvasTextAlign; + textBaseline: CanvasTextBaseline; } -interface NavigatorBeacon { - sendBeacon(url: USVString, data?: BodyInit): boolean; +interface CanvasTransform { + getTransform(): DOMMatrix; + resetTransform(): void; + rotate(angle: number): void; + scale(x: number, y: number): void; + setTransform(a: number, b: number, c: number, d: number, e: number, f: number): void; + setTransform(transform?: DOMMatrixInit): void; + transform(a: number, b: number, c: number, d: number, e: number, f: number): void; + translate(x: number, y: number): void; } -interface NavigatorConcurrentHardware { - readonly hardwareConcurrency: number; +interface CanvasUserInterface { + drawFocusIfNeeded(element: Element): void; + drawFocusIfNeeded(path: Path2D, element: Element): void; + scrollPathIntoView(): void; + scrollPathIntoView(path: Path2D): void; } -interface NavigatorContentUtils { +interface ChildNode { + after(...nodes: (Node | string)[]): void; + before(...nodes: (Node | string)[]): void; + remove(): void; + replaceWith(...nodes: (Node | string)[]): void; } -interface NavigatorGeolocation { - readonly geolocation: Geolocation; +interface ConstrainablePatternEventMap { + "overconstrained": OverconstrainedErrorEvent; } -interface NavigatorID { - readonly appCodeName: string; - readonly appName: string; - readonly appVersion: string; - readonly platform: string; - readonly product: string; - readonly productSub: string; - readonly userAgent: string; - readonly vendor: string; - readonly vendorSub: string; +interface ConstrainablePattern { + onoverconstrained: (this: ConstrainablePattern, ev: OverconstrainedErrorEvent) => any; + applyConstraints(constraints?: Constraints): Promise; + getCapabilities(): Capabilities; + getConstraints(): Constraints; + getSettings(): Settings; + addEventListener(type: K, listener: (this: ConstrainablePattern, ev: ConstrainablePatternEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } -interface NavigatorOnLine { - readonly onLine: boolean; +interface Coordinates { + readonly accuracy: number; + readonly altitude: number | null; + readonly altitudeAccuracy: number | null; + readonly heading: number | null; + readonly latitude: number; + readonly longitude: number; + readonly speed: number | null; } -interface NavigatorStorageUtils { +interface CSSPseudoElement extends GeometryUtils { } -interface NavigatorUserMedia { - readonly mediaDevices: MediaDevices; - getUserMedia(constraints: MediaStreamConstraints, successCallback: NavigatorUserMediaSuccessCallback, errorCallback: NavigatorUserMediaErrorCallback): void; +interface DeviceAcceleration { + readonly x: number | null; + readonly y: number | null; + readonly z: number | null; } -interface NodeSelector { - querySelector(selectors: K): ElementTagNameMap[K] | null; - querySelector(selectors: string): E | null; - querySelectorAll(selectors: K): ElementListTagNameMap[K]; - querySelectorAll(selectors: string): NodeListOf; +interface DeviceRotationRate { + readonly alpha: number | null; + readonly beta: number | null; + readonly gamma: number | null; } -interface RandomSource { - getRandomValues(array: T): T; +interface DocumentAndElementEventHandlersEventMap { + "copy": Event; + "cut": Event; + "paste": Event; } -interface SVGAnimatedPoints { - readonly animatedPoints: SVGPointList; - readonly points: SVGPointList; +interface DocumentAndElementEventHandlers { + oncopy: (this: DocumentAndElementEventHandlers, ev: Event) => any; + oncut: (this: DocumentAndElementEventHandlers, ev: Event) => any; + onpaste: (this: DocumentAndElementEventHandlers, ev: Event) => any; + addEventListener(type: K, listener: (this: DocumentAndElementEventHandlers, ev: DocumentAndElementEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } -interface SVGFilterPrimitiveStandardAttributes { - readonly height: SVGAnimatedLength; - readonly result: SVGAnimatedString; - readonly width: SVGAnimatedLength; - readonly x: SVGAnimatedLength; - readonly y: SVGAnimatedLength; +interface DocumentOrShadowRoot { + readonly fullscreenElement: Element | null; } -interface SVGFitToViewBox { - readonly preserveAspectRatio: SVGAnimatedPreserveAspectRatio; - readonly viewBox: SVGAnimatedRect; +interface ElementContentEditable { + contentEditable: string; + readonly isContentEditable: boolean; } -interface SVGTests { - readonly requiredExtensions: SVGStringList; - readonly requiredFeatures: SVGStringList; - readonly systemLanguage: SVGStringList; - hasExtension(extension: string): boolean; +interface ElementCSSInlineStyle { + readonly style: CSSStyleDeclaration; } -interface SVGURIReference { - readonly href: SVGAnimatedString; +interface EXT_frag_depth { } -interface WindowBase64 { - atob(encodedString: string): string; - btoa(rawString: string): string; +interface EXT_texture_filter_anisotropic { + readonly MAX_TEXTURE_MAX_ANISOTROPY_EXT: GLenum; + readonly TEXTURE_MAX_ANISOTROPY_EXT: GLenum; } -interface WindowConsole { - readonly console: Console; +interface External { + AddSearchProvider(): void; + IsSearchProviderInstalled(): void; } -interface WindowLocalStorage { - readonly localStorage: Storage; +interface Geolocation { + clearWatch(watchId: number): void; + getCurrentPosition(successCallback: PositionCallback, errorCallback?: PositionErrorCallback, options?: PositionOptions): void; + watchPosition(successCallback: PositionCallback, errorCallback?: PositionErrorCallback, options?: PositionOptions): number; } -interface WindowSessionStorage { - readonly sessionStorage: Storage; +interface GeometryUtils { + convertPointFromNode(point: DOMPointInit, from: GeometryNode, options?: ConvertCoordinateOptions): DOMPoint; + convertQuadFromNode(quad: DOMQuadInit, from: GeometryNode, options?: ConvertCoordinateOptions): DOMQuad; + convertRectFromNode(rect: DOMRectReadOnly, from: GeometryNode, options?: ConvertCoordinateOptions): DOMQuad; + getBoxQuads(options?: BoxQuadOptions): DOMQuad[]; } -interface WindowTimers extends Object, WindowTimersExtension { - clearInterval(handle: number): void; - clearTimeout(handle: number): void; - setInterval(handler: (...args: any[]) => void, timeout: number): number; - setInterval(handler: any, timeout?: any, ...args: any[]): number; - setTimeout(handler: (...args: any[]) => void, timeout: number): number; - setTimeout(handler: any, timeout?: any, ...args: any[]): number; +interface GetSVGDocument { + getSVGDocument(): Document; } -interface WindowTimersExtension { - clearImmediate(handle: number): void; - setImmediate(handler: (...args: any[]) => void): number; - setImmediate(handler: any, ...args: any[]): number; +interface GlobalCrypto { + readonly crypto: Crypto; } -interface XMLHttpRequestEventTargetEventMap { +interface GlobalEventHandlersEventMap { "abort": Event; - "error": ErrorEvent; + "animationcancel": AnimationEvent; + "animationend": AnimationEvent; + "animationiteration": AnimationEvent; + "animationstart": AnimationEvent; + "auxclick": MouseEvent; + "blur": Event; + "cancel": Event; + "canplay": Event; + "canplaythrough": Event; + "change": Event; + "click": MouseEvent; + "close": Event; + "contextmenu": MouseEvent; + "cuechange": Event; + "dblclick": MouseEvent; + "drag": DragEvent; + "dragend": DragEvent; + "dragenter": DragEvent; + "dragexit": DragEvent; + "dragleave": DragEvent; + "dragover": DragEvent; + "dragstart": DragEvent; + "drop": DragEvent; + "durationchange": Event; + "emptied": Event; + "ended": Event; + "error": Event; + "focus": Event; + "input": Event; + "invalid": Event; + "keydown": KeyboardEvent; + "keypress": KeyboardEvent; + "keyup": KeyboardEvent; "load": Event; - "loadend": ProgressEvent; + "loadeddata": Event; + "loadedmetadata": Event; + "loadend": Event; "loadstart": Event; - "progress": ProgressEvent; - "timeout": ProgressEvent; -} - -interface XMLHttpRequestEventTarget { - onabort: (this: XMLHttpRequest, ev: Event) => any; - onerror: (this: XMLHttpRequest, ev: ErrorEvent) => any; - onload: (this: XMLHttpRequest, ev: Event) => any; - onloadend: (this: XMLHttpRequest, ev: ProgressEvent) => any; - onloadstart: (this: XMLHttpRequest, ev: Event) => any; - onprogress: (this: XMLHttpRequest, ev: ProgressEvent) => any; - ontimeout: (this: XMLHttpRequest, ev: ProgressEvent) => any; - addEventListener(type: K, listener: (this: XMLHttpRequestEventTarget, ev: XMLHttpRequestEventTargetEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; -} - -interface BroadcastChannel extends EventTarget { - readonly name: string; - onmessage: (ev: MessageEvent) => any; - onmessageerror: (ev: MessageEvent) => any; - close(): void; - postMessage(message: any): void; - addEventListener(type: K, listener: (this: BroadcastChannel, ev: BroadcastChannelEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; -} - -declare var BroadcastChannel: { - prototype: BroadcastChannel; - new(name: string): BroadcastChannel; -}; - -interface BroadcastChannelEventMap { - message: MessageEvent; - messageerror: MessageEvent; -} - -interface ErrorEventInit { - message?: string; - filename?: string; - lineno?: number; - conlno?: number; - error?: any; -} - -interface StorageEventInit extends EventInit { - key?: string; - oldValue?: string; - newValue?: string; - url: string; - storageArea?: Storage; + "mousedown": MouseEvent; + "mouseenter": MouseEvent; + "mouseleave": MouseEvent; + "mousemove": MouseEvent; + "mouseout": MouseEvent; + "mouseover": MouseEvent; + "mouseup": MouseEvent; + "pause": Event; + "play": Event; + "playing": Event; + "pointercancel": PointerEvent; + "pointerdown": PointerEvent; + "pointerenter": PointerEvent; + "pointerleave": PointerEvent; + "pointermove": PointerEvent; + "pointerout": PointerEvent; + "pointerover": PointerEvent; + "pointerup": PointerEvent; + "progress": Event; + "ratechange": Event; + "reset": Event; + "resize": Event; + "scroll": Event; + "seeked": Event; + "seeking": Event; + "select": Event; + "selectionchange": Event; + "selectstart": Event; + "show": RelatedEvent; + "stalled": Event; + "submit": Event; + "suspend": Event; + "timeupdate": Event; + "toggle": Event; + "touchcancel": TouchEvent; + "touchend": TouchEvent; + "touchmove": TouchEvent; + "touchstart": TouchEvent; + "transitioncancel": TransitionEvent; + "transitionend": TransitionEvent; + "transitionrun": TransitionEvent; + "transitionstart": TransitionEvent; + "volumechange": Event; + "waiting": Event; + "wheel": WheelEvent; } -interface Canvas2DContextAttributes { - alpha?: boolean; - willReadFrequently?: boolean; - storage?: boolean; - [attribute: string]: boolean | string | undefined; +interface GlobalEventHandlers { + onabort: (this: GlobalEventHandlers, ev: Event) => any; + onanimationcancel: (this: GlobalEventHandlers, ev: AnimationEvent) => any; + onanimationend: (this: GlobalEventHandlers, ev: AnimationEvent) => any; + onanimationiteration: (this: GlobalEventHandlers, ev: AnimationEvent) => any; + onanimationstart: (this: GlobalEventHandlers, ev: AnimationEvent) => any; + onauxclick: (this: GlobalEventHandlers, ev: MouseEvent) => any; + onblur: (this: GlobalEventHandlers, ev: Event) => any; + oncancel: (this: GlobalEventHandlers, ev: Event) => any; + oncanplay: (this: GlobalEventHandlers, ev: Event) => any; + oncanplaythrough: (this: GlobalEventHandlers, ev: Event) => any; + onchange: (this: GlobalEventHandlers, ev: Event) => any; + onclick: (this: GlobalEventHandlers, ev: MouseEvent) => any; + onclose: (this: GlobalEventHandlers, ev: Event) => any; + oncontextmenu: (this: GlobalEventHandlers, ev: MouseEvent) => any; + oncuechange: (this: GlobalEventHandlers, ev: Event) => any; + ondblclick: (this: GlobalEventHandlers, ev: MouseEvent) => any; + ondrag: (this: GlobalEventHandlers, ev: DragEvent) => any; + ondragend: (this: GlobalEventHandlers, ev: DragEvent) => any; + ondragenter: (this: GlobalEventHandlers, ev: DragEvent) => any; + ondragexit: (this: GlobalEventHandlers, ev: DragEvent) => any; + ondragleave: (this: GlobalEventHandlers, ev: DragEvent) => any; + ondragover: (this: GlobalEventHandlers, ev: DragEvent) => any; + ondragstart: (this: GlobalEventHandlers, ev: DragEvent) => any; + ondrop: (this: GlobalEventHandlers, ev: DragEvent) => any; + ondurationchange: (this: GlobalEventHandlers, ev: Event) => any; + onemptied: (this: GlobalEventHandlers, ev: Event) => any; + onended: (this: GlobalEventHandlers, ev: Event) => any; + onerror: OnErrorEventHandler; + onfocus: (this: GlobalEventHandlers, ev: Event) => any; + oninput: (this: GlobalEventHandlers, ev: Event) => any; + oninvalid: (this: GlobalEventHandlers, ev: Event) => any; + onkeydown: (this: GlobalEventHandlers, ev: KeyboardEvent) => any; + onkeypress: (this: GlobalEventHandlers, ev: KeyboardEvent) => any; + onkeyup: (this: GlobalEventHandlers, ev: KeyboardEvent) => any; + onload: (this: GlobalEventHandlers, ev: Event) => any; + onloadeddata: (this: GlobalEventHandlers, ev: Event) => any; + onloadedmetadata: (this: GlobalEventHandlers, ev: Event) => any; + onloadend: (this: GlobalEventHandlers, ev: Event) => any; + onloadstart: (this: GlobalEventHandlers, ev: Event) => any; + onmousedown: (this: GlobalEventHandlers, ev: MouseEvent) => any; + onmouseenter: (this: GlobalEventHandlers, ev: MouseEvent) => any; + onmouseleave: (this: GlobalEventHandlers, ev: MouseEvent) => any; + onmousemove: (this: GlobalEventHandlers, ev: MouseEvent) => any; + onmouseout: (this: GlobalEventHandlers, ev: MouseEvent) => any; + onmouseover: (this: GlobalEventHandlers, ev: MouseEvent) => any; + onmouseup: (this: GlobalEventHandlers, ev: MouseEvent) => any; + onpause: (this: GlobalEventHandlers, ev: Event) => any; + onplay: (this: GlobalEventHandlers, ev: Event) => any; + onplaying: (this: GlobalEventHandlers, ev: Event) => any; + onpointercancel: (this: GlobalEventHandlers, ev: PointerEvent) => any; + onpointerdown: (this: GlobalEventHandlers, ev: PointerEvent) => any; + onpointerenter: (this: GlobalEventHandlers, ev: PointerEvent) => any; + onpointerleave: (this: GlobalEventHandlers, ev: PointerEvent) => any; + onpointermove: (this: GlobalEventHandlers, ev: PointerEvent) => any; + onpointerout: (this: GlobalEventHandlers, ev: PointerEvent) => any; + onpointerover: (this: GlobalEventHandlers, ev: PointerEvent) => any; + onpointerup: (this: GlobalEventHandlers, ev: PointerEvent) => any; + onprogress: (this: GlobalEventHandlers, ev: Event) => any; + onratechange: (this: GlobalEventHandlers, ev: Event) => any; + onreset: (this: GlobalEventHandlers, ev: Event) => any; + onresize: (this: GlobalEventHandlers, ev: Event) => any; + onscroll: (this: GlobalEventHandlers, ev: Event) => any; + onseeked: (this: GlobalEventHandlers, ev: Event) => any; + onseeking: (this: GlobalEventHandlers, ev: Event) => any; + onselect: (this: GlobalEventHandlers, ev: Event) => any; + onselectionchange: (this: GlobalEventHandlers, ev: Event) => any; + onselectstart: (this: GlobalEventHandlers, ev: Event) => any; + onshow: (this: GlobalEventHandlers, ev: RelatedEvent) => any; + onstalled: (this: GlobalEventHandlers, ev: Event) => any; + onsubmit: (this: GlobalEventHandlers, ev: Event) => any; + onsuspend: (this: GlobalEventHandlers, ev: Event) => any; + ontimeupdate: (this: GlobalEventHandlers, ev: Event) => any; + ontoggle: (this: GlobalEventHandlers, ev: Event) => any; + ontouchcancel: (this: GlobalEventHandlers, ev: TouchEvent) => any; + ontouchend: (this: GlobalEventHandlers, ev: TouchEvent) => any; + ontouchmove: (this: GlobalEventHandlers, ev: TouchEvent) => any; + ontouchstart: (this: GlobalEventHandlers, ev: TouchEvent) => any; + ontransitioncancel: (this: GlobalEventHandlers, ev: TransitionEvent) => any; + ontransitionend: (this: GlobalEventHandlers, ev: TransitionEvent) => any; + ontransitionrun: (this: GlobalEventHandlers, ev: TransitionEvent) => any; + ontransitionstart: (this: GlobalEventHandlers, ev: TransitionEvent) => any; + onvolumechange: (this: GlobalEventHandlers, ev: Event) => any; + onwaiting: (this: GlobalEventHandlers, ev: Event) => any; + onwheel: (this: GlobalEventHandlers, ev: WheelEvent) => any; + addEventListener(type: K, listener: (this: GlobalEventHandlers, ev: GlobalEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } -interface ImageBitmapOptions { - imageOrientation?: "none" | "flipY"; - premultiplyAlpha?: "none" | "premultiply" | "default"; - colorSpaceConversion?: "none" | "default"; - resizeWidth?: number; - resizeHeight?: number; - resizeQuality?: "pixelated" | "low" | "medium" | "high"; +interface GlobalPerformance { + readonly performance: Performance; } -interface ImageBitmap { - readonly width: number; - readonly height: number; - close(): void; +interface HTMLHyperlinkElementUtilsBase { + hash: string; + host: string; + hostname: string; + readonly origin: string; + password: string; + pathname: string; + port: string; + protocol: string; + search: string; + username: string; } -interface URLSearchParams { - /** - * Appends a specified key/value pair as a new search parameter. - */ - append(name: string, value: string): void; - /** - * Deletes the given search parameter, and its associated value, from the list of all search parameters. - */ - delete(name: string): void; - /** - * Returns the first value associated to the given search parameter. - */ - get(name: string): string | null; - /** - * Returns all the values association with a given search parameter. - */ - getAll(name: string): string[]; - /** - * Returns a Boolean indicating if such a search parameter exists. - */ - has(name: string): boolean; - /** - * Sets the value associated to a given search parameter to the given value. If there were several values, delete the others. - */ - set(name: string, value: string): void; +interface HTMLHyperlinkElementUtils extends HTMLHyperlinkElementUtilsBase { + href: string; } -declare var URLSearchParams: { - prototype: URLSearchParams; - /** - * Constructor returning a URLSearchParams object. - */ - new (init?: string | URLSearchParams): URLSearchParams; -}; - -interface NodeListOf extends NodeList { - length: number; - item(index: number): TNode; - [index: number]: TNode; +interface LinkStyle { + readonly sheet: StyleSheet | null; } -interface HTMLCollectionOf extends HTMLCollection { - item(index: number): T; - namedItem(name: string): T; - [index: number]: T; +interface NavigatorConcurrentHardware { + readonly hardwareConcurrency: number; } -interface BlobPropertyBag { - type?: string; - endings?: string; +interface NavigatorContentUtils { + isContentHandlerRegistered(mimeType: string, url: string): string; + isProtocolHandlerRegistered(scheme: string, url: string): string; + registerContentHandler(mimeType: string, url: string, title: string): void; + registerProtocolHandler(scheme: string, url: string, title: string): void; + unregisterContentHandler(mimeType: string, url: string): void; + unregisterProtocolHandler(scheme: string, url: string): void; } -interface FilePropertyBag extends BlobPropertyBag { - lastModified?: number; +interface NavigatorCookies { + readonly cookieEnabled: boolean; } -interface EventListenerObject { - handleEvent(evt: Event): void; +interface NavigatorID { + readonly appCodeName: string; + readonly appName: string; + readonly appVersion: string; + readonly oscpu: string; + readonly platform: string; + readonly product: string; + readonly productSub: string; + readonly userAgent: string; + readonly vendor: string; + readonly vendorSub: string; + taintEnabled(): boolean; } -interface ProgressEventInit extends EventInit { - lengthComputable?: boolean; - loaded?: number; - total?: number; +interface NavigatorLanguage { + readonly language: string; + readonly languages: ReadonlyArray; } -interface ScrollOptions { - behavior?: ScrollBehavior; +interface NavigatorOnLine { + readonly onLine: boolean; } -interface ScrollToOptions extends ScrollOptions { - left?: number; - top?: number; +interface NavigatorPlugins { + readonly mimeTypes: MimeTypeArray; + readonly plugins: PluginArray; + javaEnabled(): boolean; } -interface ScrollIntoViewOptions extends ScrollOptions { - block?: ScrollLogicalPosition; - inline?: ScrollLogicalPosition; +interface NavigatorUserMedia { + readonly mediaDevices: MediaDevices; + getUserMedia(constraints: MediaStreamConstraints, successCallback: NavigatorUserMediaSuccessCallback, errorCallback: NavigatorUserMediaErrorCallback): void; } -interface ClipboardEventInit extends EventInit { - data?: string; - dataType?: string; +interface NonDocumentTypeChildNode { + readonly nextElementSibling: Element | null; + readonly previousElementSibling: Element | null; } -interface IDBArrayKey extends Array { +interface NonElementParentNode { + getElementById(elementId: string): Element | null; } -interface RsaKeyGenParams extends Algorithm { - modulusLength: number; - publicExponent: Uint8Array; +interface OES_element_index_uint { } -interface RsaHashedKeyGenParams extends RsaKeyGenParams { - hash: AlgorithmIdentifier; +interface OES_standard_derivatives { + readonly FRAGMENT_SHADER_DERIVATIVE_HINT_OES: GLenum; } -interface RsaKeyAlgorithm extends KeyAlgorithm { - modulusLength: number; - publicExponent: Uint8Array; +interface OES_texture_float { } -interface RsaHashedKeyAlgorithm extends RsaKeyAlgorithm { - hash: AlgorithmIdentifier; +interface OES_texture_float_linear { } -interface RsaHashedImportParams { - hash: AlgorithmIdentifier; +interface OES_texture_half_float { + readonly HALF_FLOAT_OES: GLenum; } -interface RsaPssParams { - saltLength: number; +interface OES_texture_half_float_linear { } -interface RsaOaepParams extends Algorithm { - label?: BufferSource; +interface ParentNode { + readonly childElementCount: number; + readonly children: HTMLCollection; + readonly firstElementChild: Element | null; + readonly lastElementChild: Element | null; + append(...nodes: (Node | string)[]): void; + prepend(...nodes: (Node | string)[]): void; + querySelectorAll(selectors: K): NodeListOf; + querySelectorAll(selectors: string): NodeListOf; } -interface EcdsaParams extends Algorithm { - hash: AlgorithmIdentifier; +interface Position { + readonly coords: Coordinates; + readonly timestamp: number; } -interface EcKeyGenParams extends Algorithm { - namedCurve: string; +interface PositionError { + readonly code: number; + readonly message: string; + readonly PERMISSION_DENIED: number; + readonly POSITION_UNAVAILABLE: number; + readonly TIMEOUT: number; } -interface EcKeyAlgorithm extends KeyAlgorithm { - typedCurve: string; +interface RTCDtmfSender { } -interface EcKeyImportParams { - namedCurve: string; +interface RTCIceGatherer { } -interface EcdhKeyDeriveParams extends Algorithm { - public: CryptoKey; +interface RTCSrtpSdesTransport { } -interface AesCtrParams extends Algorithm { - counter: BufferSource; - length: number; +interface Slotable { + readonly assignedSlot: HTMLSlotElement | null; } -interface AesKeyAlgorithm extends KeyAlgorithm { - length: number; +interface SpeechSynthesisGetter { + readonly speechSynthesis: SpeechSynthesis; } -interface AesKeyGenParams extends Algorithm { - length: number; +interface SVGAnimatedPoints { + readonly animatedPoints: SVGPointList; + readonly points: SVGPointList; } -interface AesDerivedKeyParams extends Algorithm { - length: number; +interface SVGElementInstance { + readonly correspondingElement: SVGElement | null; + readonly correspondingUseElement: SVGUseElement | null; } -interface AesCbcParams extends Algorithm { - iv: BufferSource; +interface SVGFilterPrimitiveStandardAttributes { + readonly height: SVGAnimatedLength; + readonly result: SVGAnimatedString; + readonly width: SVGAnimatedLength; + readonly x: SVGAnimatedLength; + readonly y: SVGAnimatedLength; } -interface AesCmacParams extends Algorithm { - length: number; +interface SVGFitToViewBox { + readonly preserveAspectRatio: SVGAnimatedPreserveAspectRatio; + readonly viewBox: SVGAnimatedRect; } -interface AesGcmParams extends Algorithm { - iv: BufferSource; - additionalData?: BufferSource; - tagLength?: number; +interface SVGTests { + readonly requiredExtensions: SVGStringList; + readonly systemLanguage: SVGStringList; } -interface AesCfbParams extends Algorithm { - iv: BufferSource; +interface SVGURIReference { + readonly href: SVGAnimatedString; } -interface HmacImportParams extends Algorithm { - hash?: AlgorithmIdentifier; - length?: number; +interface SVGZoomAndPan { + zoomAndPan: number; + readonly SVG_ZOOMANDPAN_DISABLE: number; + readonly SVG_ZOOMANDPAN_MAGNIFY: number; + readonly SVG_ZOOMANDPAN_UNKNOWN: number; } -interface HmacKeyAlgorithm extends KeyAlgorithm { - hash: AlgorithmIdentifier; - length: number; +interface WEBGL_compressed_texture_s3tc { + readonly COMPRESSED_RGB_S3TC_DXT1_EXT: GLenum; + readonly COMPRESSED_RGBA_S3TC_DXT1_EXT: GLenum; + readonly COMPRESSED_RGBA_S3TC_DXT3_EXT: GLenum; + readonly COMPRESSED_RGBA_S3TC_DXT5_EXT: GLenum; } -interface HmacKeyGenParams extends Algorithm { - hash: AlgorithmIdentifier; - length?: number; +interface WEBGL_debug_renderer_info { + readonly UNMASKED_RENDERER_WEBGL: GLenum; + readonly UNMASKED_VENDOR_WEBGL: GLenum; } -interface DhKeyGenParams extends Algorithm { - prime: Uint8Array; - generator: Uint8Array; +interface WEBGL_depth_texture { + readonly UNSIGNED_INT_24_8_WEBGL: GLenum; } -interface DhKeyAlgorithm extends KeyAlgorithm { - prime: Uint8Array; - generator: Uint8Array; +interface WebGLRenderingContextBase { + readonly canvas: HTMLCanvasElement; + readonly drawingBufferHeight: GLsizei; + readonly drawingBufferWidth: GLsizei; + activeTexture(texture: GLenum): void; + attachShader(program: WebGLProgram, shader: WebGLShader): void; + bindAttribLocation(program: WebGLProgram, index: GLuint, name: string): void; + bindBuffer(target: GLenum, buffer: WebGLBuffer | null): void; + bindFramebuffer(target: GLenum, framebuffer: WebGLFramebuffer | null): void; + bindRenderbuffer(target: GLenum, renderbuffer: WebGLRenderbuffer | null): void; + bindTexture(target: GLenum, texture: WebGLTexture | null): void; + blendColor(red: GLclampf, green: GLclampf, blue: GLclampf, alpha: GLclampf): void; + blendEquation(mode: GLenum): void; + blendEquationSeparate(modeRGB: GLenum, modeAlpha: GLenum): void; + blendFunc(sfactor: GLenum, dfactor: GLenum): void; + blendFuncSeparate(srcRGB: GLenum, dstRGB: GLenum, srcAlpha: GLenum, dstAlpha: GLenum): void; + bufferData(target: GLenum, size: GLsizeiptr, usage: GLenum): void; + bufferData(target: GLenum, data: BufferSource | null, usage: GLenum): void; + bufferSubData(target: GLenum, offset: GLintptr, data: BufferSource): void; + checkFramebufferStatus(target: GLenum): GLenum; + clear(mask: GLbitfield): void; + clearColor(red: GLclampf, green: GLclampf, blue: GLclampf, alpha: GLclampf): void; + clearDepth(depth: GLclampf): void; + clearStencil(s: GLint): void; + colorMask(red: GLboolean, green: GLboolean, blue: GLboolean, alpha: GLboolean): void; + compileShader(shader: WebGLShader): void; + compressedTexImage2D(target: GLenum, level: GLint, internalformat: GLenum, width: GLsizei, height: GLsizei, border: GLint, data: ArrayBufferView): void; + compressedTexSubImage2D(target: GLenum, level: GLint, xoffset: GLint, yoffset: GLint, width: GLsizei, height: GLsizei, format: GLenum, data: ArrayBufferView): void; + copyTexImage2D(target: GLenum, level: GLint, internalformat: GLenum, x: GLint, y: GLint, width: GLsizei, height: GLsizei, border: GLint): void; + copyTexSubImage2D(target: GLenum, level: GLint, xoffset: GLint, yoffset: GLint, x: GLint, y: GLint, width: GLsizei, height: GLsizei): void; + createBuffer(): WebGLBuffer | null; + createFramebuffer(): WebGLFramebuffer | null; + createProgram(): WebGLProgram | null; + createRenderbuffer(): WebGLRenderbuffer | null; + createShader(type: GLenum): WebGLShader | null; + createTexture(): WebGLTexture | null; + cullFace(mode: GLenum): void; + deleteBuffer(buffer: WebGLBuffer | null): void; + deleteFramebuffer(framebuffer: WebGLFramebuffer | null): void; + deleteProgram(program: WebGLProgram | null): void; + deleteRenderbuffer(renderbuffer: WebGLRenderbuffer | null): void; + deleteShader(shader: WebGLShader | null): void; + deleteTexture(texture: WebGLTexture | null): void; + depthFunc(func: GLenum): void; + depthMask(flag: GLboolean): void; + depthRange(zNear: GLclampf, zFar: GLclampf): void; + detachShader(program: WebGLProgram, shader: WebGLShader): void; + disable(cap: GLenum): void; + disableVertexAttribArray(index: GLuint): void; + drawArrays(mode: GLenum, first: GLint, count: GLsizei): void; + drawElements(mode: GLenum, count: GLsizei, type: GLenum, offset: GLintptr): void; + enable(cap: GLenum): void; + enableVertexAttribArray(index: GLuint): void; + finish(): void; + flush(): void; + framebufferRenderbuffer(target: GLenum, attachment: GLenum, renderbuffertarget: GLenum, renderbuffer: WebGLRenderbuffer | null): void; + framebufferTexture2D(target: GLenum, attachment: GLenum, textarget: GLenum, texture: WebGLTexture | null, level: GLint): void; + frontFace(mode: GLenum): void; + generateMipmap(target: GLenum): void; + getActiveAttrib(program: WebGLProgram, index: GLuint): WebGLActiveInfo | null; + getActiveUniform(program: WebGLProgram, index: GLuint): WebGLActiveInfo | null; + getAttachedShaders(program: WebGLProgram): WebGLShader[] | null; + getAttribLocation(program: WebGLProgram, name: string): GLint; + getBufferParameter(target: GLenum, pname: GLenum): any; + getContextAttributes(): WebGLContextAttributes | null; + getError(): GLenum; + getExtension(name: string): any; + getFramebufferAttachmentParameter(target: GLenum, attachment: GLenum, pname: GLenum): any; + getParameter(pname: GLenum): any; + getProgramInfoLog(program: WebGLProgram): string | null; + getProgramParameter(program: WebGLProgram, pname: GLenum): any; + getRenderbufferParameter(target: GLenum, pname: GLenum): any; + getShaderInfoLog(shader: WebGLShader): string | null; + getShaderParameter(shader: WebGLShader, pname: GLenum): any; + getShaderPrecisionFormat(shadertype: GLenum, precisiontype: GLenum): WebGLShaderPrecisionFormat | null; + getShaderSource(shader: WebGLShader): string | null; + getSupportedExtensions(): string[] | null; + getTexParameter(target: GLenum, pname: GLenum): any; + getUniform(program: WebGLProgram, location: WebGLUniformLocation): any; + getUniformLocation(program: WebGLProgram, name: string): WebGLUniformLocation | null; + getVertexAttrib(index: GLuint, pname: GLenum): any; + getVertexAttribOffset(index: GLuint, pname: GLenum): GLintptr; + hint(target: GLenum, mode: GLenum): void; + isBuffer(buffer: WebGLBuffer | null): GLboolean; + isContextLost(): boolean; + isEnabled(cap: GLenum): GLboolean; + isFramebuffer(framebuffer: WebGLFramebuffer | null): GLboolean; + isProgram(program: WebGLProgram | null): GLboolean; + isRenderbuffer(renderbuffer: WebGLRenderbuffer | null): GLboolean; + isShader(shader: WebGLShader | null): GLboolean; + isTexture(texture: WebGLTexture | null): GLboolean; + lineWidth(width: GLfloat): void; + linkProgram(program: WebGLProgram): void; + pixelStorei(pname: GLenum, param: GLint): void; + polygonOffset(factor: GLfloat, units: GLfloat): void; + readPixels(x: GLint, y: GLint, width: GLsizei, height: GLsizei, format: GLenum, type: GLenum, pixels: ArrayBufferView | null): void; + renderbufferStorage(target: GLenum, internalformat: GLenum, width: GLsizei, height: GLsizei): void; + sampleCoverage(value: GLclampf, invert: GLboolean): void; + scissor(x: GLint, y: GLint, width: GLsizei, height: GLsizei): void; + shaderSource(shader: WebGLShader, source: string): void; + stencilFunc(func: GLenum, ref: GLint, mask: GLuint): void; + stencilFuncSeparate(face: GLenum, func: GLenum, ref: GLint, mask: GLuint): void; + stencilMask(mask: GLuint): void; + stencilMaskSeparate(face: GLenum, mask: GLuint): void; + stencilOp(fail: GLenum, zfail: GLenum, zpass: GLenum): void; + stencilOpSeparate(face: GLenum, fail: GLenum, zfail: GLenum, zpass: GLenum): void; + texImage2D(target: GLenum, level: GLint, internalformat: GLint, width: GLsizei, height: GLsizei, border: GLint, format: GLenum, type: GLenum, pixels: ArrayBufferView | null): void; + texImage2D(target: GLenum, level: GLint, internalformat: GLint, format: GLenum, type: GLenum, source: TexImageSource): void; + texParameterf(target: GLenum, pname: GLenum, param: GLfloat): void; + texParameteri(target: GLenum, pname: GLenum, param: GLint): void; + texSubImage2D(target: GLenum, level: GLint, xoffset: GLint, yoffset: GLint, format: GLenum, type: GLenum, source: TexImageSource): void; + texSubImage2D(target: GLenum, level: GLint, xoffset: GLint, yoffset: GLint, width: GLsizei, height: GLsizei, format: GLenum, type: GLenum, pixels: ArrayBufferView | null): void; + uniform1f(location: WebGLUniformLocation | null, x: GLfloat): void; + uniform1fv(location: WebGLUniformLocation | null, v: Float32List): void; + uniform1i(location: WebGLUniformLocation | null, x: GLint): void; + uniform1iv(location: WebGLUniformLocation | null, v: Int32List): void; + uniform2f(location: WebGLUniformLocation | null, x: GLfloat, y: GLfloat): void; + uniform2fv(location: WebGLUniformLocation | null, v: Float32List): void; + uniform2i(location: WebGLUniformLocation | null, x: GLint, y: GLint): void; + uniform2iv(location: WebGLUniformLocation | null, v: Int32List): void; + uniform3f(location: WebGLUniformLocation | null, x: GLfloat, y: GLfloat, z: GLfloat): void; + uniform3fv(location: WebGLUniformLocation | null, v: Float32List): void; + uniform3i(location: WebGLUniformLocation | null, x: GLint, y: GLint, z: GLint): void; + uniform3iv(location: WebGLUniformLocation | null, v: Int32List): void; + uniform4f(location: WebGLUniformLocation | null, x: GLfloat, y: GLfloat, z: GLfloat, w: GLfloat): void; + uniform4fv(location: WebGLUniformLocation | null, v: Float32List): void; + uniform4i(location: WebGLUniformLocation | null, x: GLint, y: GLint, z: GLint, w: GLint): void; + uniform4iv(location: WebGLUniformLocation | null, v: Int32List): void; + uniformMatrix2fv(location: WebGLUniformLocation | null, transpose: GLboolean, value: Float32List): void; + uniformMatrix3fv(location: WebGLUniformLocation | null, transpose: GLboolean, value: Float32List): void; + uniformMatrix4fv(location: WebGLUniformLocation | null, transpose: GLboolean, value: Float32List): void; + useProgram(program: WebGLProgram | null): void; + validateProgram(program: WebGLProgram): void; + vertexAttrib1f(index: GLuint, x: GLfloat): void; + vertexAttrib1fv(index: GLuint, values: Float32List): void; + vertexAttrib2f(index: GLuint, x: GLfloat, y: GLfloat): void; + vertexAttrib2fv(index: GLuint, values: Float32List): void; + vertexAttrib3f(index: GLuint, x: GLfloat, y: GLfloat, z: GLfloat): void; + vertexAttrib3fv(index: GLuint, values: Float32List): void; + vertexAttrib4f(index: GLuint, x: GLfloat, y: GLfloat, z: GLfloat, w: GLfloat): void; + vertexAttrib4fv(index: GLuint, values: Float32List): void; + vertexAttribPointer(index: GLuint, size: GLint, type: GLenum, normalized: GLboolean, stride: GLsizei, offset: GLintptr): void; + viewport(x: GLint, y: GLint, width: GLsizei, height: GLsizei): void; + readonly ACTIVE_ATTRIBUTES: GLenum; + readonly ACTIVE_TEXTURE: GLenum; + readonly ACTIVE_UNIFORMS: GLenum; + readonly ALIASED_LINE_WIDTH_RANGE: GLenum; + readonly ALIASED_POINT_SIZE_RANGE: GLenum; + readonly ALPHA: GLenum; + readonly ALPHA_BITS: GLenum; + readonly ALWAYS: GLenum; + readonly ARRAY_BUFFER: GLenum; + readonly ARRAY_BUFFER_BINDING: GLenum; + readonly ATTACHED_SHADERS: GLenum; + readonly BACK: GLenum; + readonly BLEND: GLenum; + readonly BLEND_COLOR: GLenum; + readonly BLEND_DST_ALPHA: GLenum; + readonly BLEND_DST_RGB: GLenum; + readonly BLEND_EQUATION: GLenum; + readonly BLEND_EQUATION_ALPHA: GLenum; + readonly BLEND_EQUATION_RGB: GLenum; + readonly BLEND_SRC_ALPHA: GLenum; + readonly BLEND_SRC_RGB: GLenum; + readonly BLUE_BITS: GLenum; + readonly BOOL: GLenum; + readonly BOOL_VEC2: GLenum; + readonly BOOL_VEC3: GLenum; + readonly BOOL_VEC4: GLenum; + readonly BROWSER_DEFAULT_WEBGL: GLenum; + readonly BUFFER_SIZE: GLenum; + readonly BUFFER_USAGE: GLenum; + readonly BYTE: GLenum; + readonly CCW: GLenum; + readonly CLAMP_TO_EDGE: GLenum; + readonly COLOR_ATTACHMENT0: GLenum; + readonly COLOR_BUFFER_BIT: GLenum; + readonly COLOR_CLEAR_VALUE: GLenum; + readonly COLOR_WRITEMASK: GLenum; + readonly COMPILE_STATUS: GLenum; + readonly COMPRESSED_TEXTURE_FORMATS: GLenum; + readonly CONSTANT_ALPHA: GLenum; + readonly CONSTANT_COLOR: GLenum; + readonly CONTEXT_LOST_WEBGL: GLenum; + readonly CULL_FACE: GLenum; + readonly CULL_FACE_MODE: GLenum; + readonly CURRENT_PROGRAM: GLenum; + readonly CURRENT_VERTEX_ATTRIB: GLenum; + readonly CW: GLenum; + readonly DECR: GLenum; + readonly DECR_WRAP: GLenum; + readonly DELETE_STATUS: GLenum; + readonly DEPTH_ATTACHMENT: GLenum; + readonly DEPTH_BITS: GLenum; + readonly DEPTH_BUFFER_BIT: GLenum; + readonly DEPTH_CLEAR_VALUE: GLenum; + readonly DEPTH_COMPONENT: GLenum; + readonly DEPTH_COMPONENT16: GLenum; + readonly DEPTH_FUNC: GLenum; + readonly DEPTH_RANGE: GLenum; + readonly DEPTH_STENCIL: GLenum; + readonly DEPTH_STENCIL_ATTACHMENT: GLenum; + readonly DEPTH_TEST: GLenum; + readonly DEPTH_WRITEMASK: GLenum; + readonly DITHER: GLenum; + readonly DONT_CARE: GLenum; + readonly DST_ALPHA: GLenum; + readonly DST_COLOR: GLenum; + readonly DYNAMIC_DRAW: GLenum; + readonly ELEMENT_ARRAY_BUFFER: GLenum; + readonly ELEMENT_ARRAY_BUFFER_BINDING: GLenum; + readonly EQUAL: GLenum; + readonly FASTEST: GLenum; + readonly FLOAT: GLenum; + readonly FLOAT_MAT2: GLenum; + readonly FLOAT_MAT3: GLenum; + readonly FLOAT_MAT4: GLenum; + readonly FLOAT_VEC2: GLenum; + readonly FLOAT_VEC3: GLenum; + readonly FLOAT_VEC4: GLenum; + readonly FRAGMENT_SHADER: GLenum; + readonly FRAMEBUFFER: GLenum; + readonly FRAMEBUFFER_ATTACHMENT_OBJECT_NAME: GLenum; + readonly FRAMEBUFFER_ATTACHMENT_OBJECT_TYPE: GLenum; + readonly FRAMEBUFFER_ATTACHMENT_TEXTURE_CUBE_MAP_FACE: GLenum; + readonly FRAMEBUFFER_ATTACHMENT_TEXTURE_LEVEL: GLenum; + readonly FRAMEBUFFER_BINDING: GLenum; + readonly FRAMEBUFFER_COMPLETE: GLenum; + readonly FRAMEBUFFER_INCOMPLETE_ATTACHMENT: GLenum; + readonly FRAMEBUFFER_INCOMPLETE_DIMENSIONS: GLenum; + readonly FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT: GLenum; + readonly FRAMEBUFFER_UNSUPPORTED: GLenum; + readonly FRONT: GLenum; + readonly FRONT_AND_BACK: GLenum; + readonly FRONT_FACE: GLenum; + readonly FUNC_ADD: GLenum; + readonly FUNC_REVERSE_SUBTRACT: GLenum; + readonly FUNC_SUBTRACT: GLenum; + readonly GENERATE_MIPMAP_HINT: GLenum; + readonly GEQUAL: GLenum; + readonly GREATER: GLenum; + readonly GREEN_BITS: GLenum; + readonly HIGH_FLOAT: GLenum; + readonly HIGH_INT: GLenum; + readonly IMPLEMENTATION_COLOR_READ_FORMAT: GLenum; + readonly IMPLEMENTATION_COLOR_READ_TYPE: GLenum; + readonly INCR: GLenum; + readonly INCR_WRAP: GLenum; + readonly INT: GLenum; + readonly INT_VEC2: GLenum; + readonly INT_VEC3: GLenum; + readonly INT_VEC4: GLenum; + readonly INVALID_ENUM: GLenum; + readonly INVALID_FRAMEBUFFER_OPERATION: GLenum; + readonly INVALID_OPERATION: GLenum; + readonly INVALID_VALUE: GLenum; + readonly INVERT: GLenum; + readonly KEEP: GLenum; + readonly LEQUAL: GLenum; + readonly LESS: GLenum; + readonly LINE_LOOP: GLenum; + readonly LINE_STRIP: GLenum; + readonly LINE_WIDTH: GLenum; + readonly LINEAR: GLenum; + readonly LINEAR_MIPMAP_LINEAR: GLenum; + readonly LINEAR_MIPMAP_NEAREST: GLenum; + readonly LINES: GLenum; + readonly LINK_STATUS: GLenum; + readonly LOW_FLOAT: GLenum; + readonly LOW_INT: GLenum; + readonly LUMINANCE: GLenum; + readonly LUMINANCE_ALPHA: GLenum; + readonly MAX_COMBINED_TEXTURE_IMAGE_UNITS: GLenum; + readonly MAX_CUBE_MAP_TEXTURE_SIZE: GLenum; + readonly MAX_FRAGMENT_UNIFORM_VECTORS: GLenum; + readonly MAX_RENDERBUFFER_SIZE: GLenum; + readonly MAX_TEXTURE_IMAGE_UNITS: GLenum; + readonly MAX_TEXTURE_SIZE: GLenum; + readonly MAX_VARYING_VECTORS: GLenum; + readonly MAX_VERTEX_ATTRIBS: GLenum; + readonly MAX_VERTEX_TEXTURE_IMAGE_UNITS: GLenum; + readonly MAX_VERTEX_UNIFORM_VECTORS: GLenum; + readonly MAX_VIEWPORT_DIMS: GLenum; + readonly MEDIUM_FLOAT: GLenum; + readonly MEDIUM_INT: GLenum; + readonly MIRRORED_REPEAT: GLenum; + readonly NEAREST: GLenum; + readonly NEAREST_MIPMAP_LINEAR: GLenum; + readonly NEAREST_MIPMAP_NEAREST: GLenum; + readonly NEVER: GLenum; + readonly NICEST: GLenum; + readonly NO_ERROR: GLenum; + readonly NONE: GLenum; + readonly NOTEQUAL: GLenum; + readonly ONE: GLenum; + readonly ONE_MINUS_CONSTANT_ALPHA: GLenum; + readonly ONE_MINUS_CONSTANT_COLOR: GLenum; + readonly ONE_MINUS_DST_ALPHA: GLenum; + readonly ONE_MINUS_DST_COLOR: GLenum; + readonly ONE_MINUS_SRC_ALPHA: GLenum; + readonly ONE_MINUS_SRC_COLOR: GLenum; + readonly OUT_OF_MEMORY: GLenum; + readonly PACK_ALIGNMENT: GLenum; + readonly POINTS: GLenum; + readonly POLYGON_OFFSET_FACTOR: GLenum; + readonly POLYGON_OFFSET_FILL: GLenum; + readonly POLYGON_OFFSET_UNITS: GLenum; + readonly RED_BITS: GLenum; + readonly RENDERBUFFER: GLenum; + readonly RENDERBUFFER_ALPHA_SIZE: GLenum; + readonly RENDERBUFFER_BINDING: GLenum; + readonly RENDERBUFFER_BLUE_SIZE: GLenum; + readonly RENDERBUFFER_DEPTH_SIZE: GLenum; + readonly RENDERBUFFER_GREEN_SIZE: GLenum; + readonly RENDERBUFFER_HEIGHT: GLenum; + readonly RENDERBUFFER_INTERNAL_FORMAT: GLenum; + readonly RENDERBUFFER_RED_SIZE: GLenum; + readonly RENDERBUFFER_STENCIL_SIZE: GLenum; + readonly RENDERBUFFER_WIDTH: GLenum; + readonly RENDERER: GLenum; + readonly REPEAT: GLenum; + readonly REPLACE: GLenum; + readonly RGB: GLenum; + readonly RGB5_A1: GLenum; + readonly RGB565: GLenum; + readonly RGBA: GLenum; + readonly RGBA4: GLenum; + readonly SAMPLE_ALPHA_TO_COVERAGE: GLenum; + readonly SAMPLE_BUFFERS: GLenum; + readonly SAMPLE_COVERAGE: GLenum; + readonly SAMPLE_COVERAGE_INVERT: GLenum; + readonly SAMPLE_COVERAGE_VALUE: GLenum; + readonly SAMPLER_2D: GLenum; + readonly SAMPLER_CUBE: GLenum; + readonly SAMPLES: GLenum; + readonly SCISSOR_BOX: GLenum; + readonly SCISSOR_TEST: GLenum; + readonly SHADER_TYPE: GLenum; + readonly SHADING_LANGUAGE_VERSION: GLenum; + readonly SHORT: GLenum; + readonly SRC_ALPHA: GLenum; + readonly SRC_ALPHA_SATURATE: GLenum; + readonly SRC_COLOR: GLenum; + readonly STATIC_DRAW: GLenum; + readonly STENCIL_ATTACHMENT: GLenum; + readonly STENCIL_BACK_FAIL: GLenum; + readonly STENCIL_BACK_FUNC: GLenum; + readonly STENCIL_BACK_PASS_DEPTH_FAIL: GLenum; + readonly STENCIL_BACK_PASS_DEPTH_PASS: GLenum; + readonly STENCIL_BACK_REF: GLenum; + readonly STENCIL_BACK_VALUE_MASK: GLenum; + readonly STENCIL_BACK_WRITEMASK: GLenum; + readonly STENCIL_BITS: GLenum; + readonly STENCIL_BUFFER_BIT: GLenum; + readonly STENCIL_CLEAR_VALUE: GLenum; + readonly STENCIL_FAIL: GLenum; + readonly STENCIL_FUNC: GLenum; + readonly STENCIL_INDEX8: GLenum; + readonly STENCIL_PASS_DEPTH_FAIL: GLenum; + readonly STENCIL_PASS_DEPTH_PASS: GLenum; + readonly STENCIL_REF: GLenum; + readonly STENCIL_TEST: GLenum; + readonly STENCIL_VALUE_MASK: GLenum; + readonly STENCIL_WRITEMASK: GLenum; + readonly STREAM_DRAW: GLenum; + readonly SUBPIXEL_BITS: GLenum; + readonly TEXTURE: GLenum; + readonly TEXTURE_2D: GLenum; + readonly TEXTURE_BINDING_2D: GLenum; + readonly TEXTURE_BINDING_CUBE_MAP: GLenum; + readonly TEXTURE_CUBE_MAP: GLenum; + readonly TEXTURE_CUBE_MAP_NEGATIVE_X: GLenum; + readonly TEXTURE_CUBE_MAP_NEGATIVE_Y: GLenum; + readonly TEXTURE_CUBE_MAP_NEGATIVE_Z: GLenum; + readonly TEXTURE_CUBE_MAP_POSITIVE_X: GLenum; + readonly TEXTURE_CUBE_MAP_POSITIVE_Y: GLenum; + readonly TEXTURE_CUBE_MAP_POSITIVE_Z: GLenum; + readonly TEXTURE_MAG_FILTER: GLenum; + readonly TEXTURE_MIN_FILTER: GLenum; + readonly TEXTURE_WRAP_S: GLenum; + readonly TEXTURE_WRAP_T: GLenum; + readonly TEXTURE0: GLenum; + readonly TEXTURE1: GLenum; + readonly TEXTURE10: GLenum; + readonly TEXTURE11: GLenum; + readonly TEXTURE12: GLenum; + readonly TEXTURE13: GLenum; + readonly TEXTURE14: GLenum; + readonly TEXTURE15: GLenum; + readonly TEXTURE16: GLenum; + readonly TEXTURE17: GLenum; + readonly TEXTURE18: GLenum; + readonly TEXTURE19: GLenum; + readonly TEXTURE2: GLenum; + readonly TEXTURE20: GLenum; + readonly TEXTURE21: GLenum; + readonly TEXTURE22: GLenum; + readonly TEXTURE23: GLenum; + readonly TEXTURE24: GLenum; + readonly TEXTURE25: GLenum; + readonly TEXTURE26: GLenum; + readonly TEXTURE27: GLenum; + readonly TEXTURE28: GLenum; + readonly TEXTURE29: GLenum; + readonly TEXTURE3: GLenum; + readonly TEXTURE30: GLenum; + readonly TEXTURE31: GLenum; + readonly TEXTURE4: GLenum; + readonly TEXTURE5: GLenum; + readonly TEXTURE6: GLenum; + readonly TEXTURE7: GLenum; + readonly TEXTURE8: GLenum; + readonly TEXTURE9: GLenum; + readonly TRIANGLE_FAN: GLenum; + readonly TRIANGLE_STRIP: GLenum; + readonly TRIANGLES: GLenum; + readonly UNPACK_ALIGNMENT: GLenum; + readonly UNPACK_COLORSPACE_CONVERSION_WEBGL: GLenum; + readonly UNPACK_FLIP_Y_WEBGL: GLenum; + readonly UNPACK_PREMULTIPLY_ALPHA_WEBGL: GLenum; + readonly UNSIGNED_BYTE: GLenum; + readonly UNSIGNED_INT: GLenum; + readonly UNSIGNED_SHORT: GLenum; + readonly UNSIGNED_SHORT_4_4_4_4: GLenum; + readonly UNSIGNED_SHORT_5_5_5_1: GLenum; + readonly UNSIGNED_SHORT_5_6_5: GLenum; + readonly VALIDATE_STATUS: GLenum; + readonly VENDOR: GLenum; + readonly VERSION: GLenum; + readonly VERTEX_ATTRIB_ARRAY_BUFFER_BINDING: GLenum; + readonly VERTEX_ATTRIB_ARRAY_ENABLED: GLenum; + readonly VERTEX_ATTRIB_ARRAY_NORMALIZED: GLenum; + readonly VERTEX_ATTRIB_ARRAY_POINTER: GLenum; + readonly VERTEX_ATTRIB_ARRAY_SIZE: GLenum; + readonly VERTEX_ATTRIB_ARRAY_STRIDE: GLenum; + readonly VERTEX_ATTRIB_ARRAY_TYPE: GLenum; + readonly VERTEX_SHADER: GLenum; + readonly VIEWPORT: GLenum; + readonly ZERO: GLenum; +} + +interface WindowEventHandlersEventMap { + "afterprint": Event; + "beforeprint": Event; + "beforeunload": BeforeUnloadEvent; + "hashchange": HashChangeEvent; + "languagechange": Event; + "message": MessageEvent; + "messageerror": MessageEvent; + "offline": Event; + "online": Event; + "pagehide": PageTransitionEvent; + "pageshow": PageTransitionEvent; + "popstate": PopStateEvent; + "rejectionhandled": PromiseRejectionEvent; + "storage": StorageEvent; + "unhandledrejection": PromiseRejectionEvent; + "unload": Event; } -interface DhKeyDeriveParams extends Algorithm { - public: CryptoKey; +interface WindowEventHandlers { + onafterprint: (this: WindowEventHandlers, ev: Event) => any; + onbeforeprint: (this: WindowEventHandlers, ev: Event) => any; + onbeforeunload: OnBeforeUnloadEventHandler; + onhashchange: (this: WindowEventHandlers, ev: HashChangeEvent) => any; + onlanguagechange: (this: WindowEventHandlers, ev: Event) => any; + onmessage: (this: WindowEventHandlers, ev: MessageEvent) => any; + onmessageerror: (this: WindowEventHandlers, ev: MessageEvent) => any; + onoffline: (this: WindowEventHandlers, ev: Event) => any; + ononline: (this: WindowEventHandlers, ev: Event) => any; + onpagehide: (this: WindowEventHandlers, ev: PageTransitionEvent) => any; + onpageshow: (this: WindowEventHandlers, ev: PageTransitionEvent) => any; + onpopstate: (this: WindowEventHandlers, ev: PopStateEvent) => any; + onrejectionhandled: (this: WindowEventHandlers, ev: PromiseRejectionEvent) => any; + onstorage: (this: WindowEventHandlers, ev: StorageEvent) => any; + onunhandledrejection: (this: WindowEventHandlers, ev: PromiseRejectionEvent) => any; + onunload: (this: WindowEventHandlers, ev: Event) => any; + addEventListener(type: K, listener: (this: WindowEventHandlers, ev: WindowEventHandlersEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } -interface DhImportKeyParams extends Algorithm { - prime: Uint8Array; - generator: Uint8Array; +interface WindowLocalStorage { + readonly localStorage: Storage; } -interface ConcatParams extends Algorithm { - hash?: AlgorithmIdentifier; - algorithmId: Uint8Array; - partyUInfo: Uint8Array; - partyVInfo: Uint8Array; - publicInfo?: Uint8Array; - privateInfo?: Uint8Array; +interface WindowOrWorkerGlobalScope { + readonly caches: CacheStorage; + readonly indexedDB: IDBFactory; + readonly origin: string; + atob(data: string): string; + btoa(data: string): string; + clearInterval(handle?: number): void; + clearTimeout(handle?: number): void; + createImageBitmap(image: ImageBitmapSource, options?: ImageBitmapOptions): Promise; + createImageBitmap(image: ImageBitmapSource, sx: number, sy: number, sw: number, sh: number, options?: ImageBitmapOptions): Promise; + fetch(input: RequestInfo, init?: RequestInit): Promise; + setInterval(handler: (...args: any[]) => void, timeout: number): number; + setInterval(handler: any, timeout?: any, ...args: any[]): number; + setTimeout(handler: (...args: any[]) => void, timeout: number): number; + setTimeout(handler: any, timeout?: any, ...args: any[]): number; } -interface HkdfCtrParams extends Algorithm { - hash: AlgorithmIdentifier; - label: BufferSource; - context: BufferSource; +interface WindowSessionStorage { + readonly sessionStorage: Storage; } -interface Pbkdf2Params extends Algorithm { - salt: BufferSource; - iterations: number; - hash: AlgorithmIdentifier; +declare namespace console { + function assert(condition?: boolean, ...data: any[]): void; + function clear(): void; + function count(label?: string): void; + function debug(...data: any[]): void; + function dir(item: any, options?: any): void; + function dirxml(...data: any[]): void; + function error(...data: any[]): void; + function group(...data: any[]): void; + function groupCollapsed(...data: any[]): void; + function groupEnd(): void; + function info(...data: any[]): void; + function log(...data: any[]): void; + function table(tabularData: any, properties?: string[]): void; + function time(label?: string): void; + function timeEnd(label?: string): void; + function trace(...data: any[]): void; + function warn(...data: any[]): void; } -interface RsaOtherPrimesInfo { - r: string; - d: string; - t: string; +interface BroadcastChannel extends EventTarget { + readonly name: string; + onmessage: (ev: MessageEvent) => any; + onmessageerror: (ev: MessageEvent) => any; + close(): void; + postMessage(message: any): void; + addEventListener(type: K, listener: (this: BroadcastChannel, ev: BroadcastChannelEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; } -interface JsonWebKey { - kty: string; - use?: string; - key_ops?: string[]; - alg?: string; - kid?: string; - x5u?: string; - x5c?: string; - x5t?: string; - ext?: boolean; - crv?: string; - x?: string; - y?: string; - d?: string; - n?: string; - e?: string; - p?: string; - q?: string; - dp?: string; - dq?: string; - qi?: string; - oth?: RsaOtherPrimesInfo[]; - k?: string; +declare var BroadcastChannel: { + prototype: BroadcastChannel; + new(name: string): BroadcastChannel; +}; + +interface BroadcastChannelEventMap { + message: MessageEvent; + messageerror: MessageEvent; } -interface ParentNode { - readonly children: HTMLCollection; - readonly firstElementChild: Element | null; - readonly lastElementChild: Element | null; - readonly childElementCount: number; +interface ErrorEventInit { + message?: string; + filename?: string; + lineno?: number; + conlno?: number; + error?: any; } -interface DocumentOrShadowRoot { - readonly activeElement: Element | null; - readonly stylesheets: StyleSheetList; - getSelection(): Selection | null; - elementFromPoint(x: number, y: number): Element | null; - elementsFromPoint(x: number, y: number): Element[]; +interface Canvas2DContextAttributes { + alpha?: boolean; + willReadFrequently?: boolean; + storage?: boolean; + [attribute: string]: boolean | string | undefined; } -interface ShadowRoot extends DocumentOrShadowRoot, DocumentFragment { - readonly host: Element; - innerHTML: string; +interface ImageBitmapOptions { + imageOrientation?: "none" | "flipY"; + premultiplyAlpha?: "none" | "premultiply" | "default"; + colorSpaceConversion?: "none" | "default"; + resizeWidth?: number; + resizeHeight?: number; + resizeQuality?: "pixelated" | "low" | "medium" | "high"; } -interface ShadowRootInit { - mode: "open" | "closed"; - delegatesFocus?: boolean; +interface ImageBitmap { + readonly width: number; + readonly height: number; + close(): void; } -interface HTMLSlotElement extends HTMLElement { - name: string; - assignedNodes(options?: AssignedNodesOptions): Node[]; +interface NodeListOf extends NodeList { + length: number; + item(index: number): TNode; + [index: number]: TNode; } -interface AssignedNodesOptions { - flatten?: boolean; +interface HTMLCollectionOf extends HTMLCollection { + item(index: number): T; + namedItem(name: string): T; + [index: number]: T; } -interface ElementDefinitionOptions { - extends: string; +interface BlobPropertyBag { + type?: string; + endings?: string; } -interface CustomElementRegistry { - define(name: string, constructor: Function, options?: ElementDefinitionOptions): void; - get(name: string): any; - whenDefined(name: string): PromiseLike; +interface FilePropertyBag extends BlobPropertyBag { + lastModified?: number; } -interface PromiseRejectionEvent extends Event { - readonly promise: PromiseLike; - readonly reason: any; +interface EventListenerObject { + handleEvent(evt: Event): void; } -interface PromiseRejectionEventInit extends EventInit { - promise: PromiseLike; - reason?: any; +interface ProgressEventInit extends EventInit { + lengthComputable?: boolean; + loaded?: number; + total?: number; } -interface EventListenerOptions { - capture?: boolean; +interface ClipboardEventInit extends EventInit { + data?: string; + dataType?: string; } -interface AddEventListenerOptions extends EventListenerOptions { - passive?: boolean; - once?: boolean; +interface IDBArrayKey extends Array { } -interface TouchEventInit extends EventModifierInit { - touches?: Touch[]; - targetTouches?: Touch[]; - changedTouches?: Touch[]; +interface DocumentOrShadowRoot { + readonly activeElement: Element | null; + readonly stylesheets: StyleSheetList; + getSelection(): Selection | null; + elementFromPoint(x: number, y: number): Element | null; + elementsFromPoint(x: number, y: number): Element[]; } -interface HTMLDialogElement extends HTMLElement { - open: boolean; - returnValue: string; - close(returnValue?: string): void; - show(): void; - showModal(): void; +interface ShadowRoot extends DocumentOrShadowRoot, DocumentFragment { + readonly host: Element; + innerHTML: string; } -declare var HTMLDialogElement: { - prototype: HTMLDialogElement; - new(): HTMLDialogElement; -}; - -interface HTMLMainElement extends HTMLElement { +interface HTMLSlotElement extends HTMLElement { + name: string; + assignedNodes(options?: AssignedNodesOptions): Node[]; } -declare var HTMLMainElement: { - prototype: HTMLMainElement; - new(): HTMLMainElement; -}; - -interface HTMLDetailsElement extends HTMLElement { - open: boolean; +interface AssignedNodesOptions { + flatten?: boolean; } -declare var HTMLDetailsElement: { - prototype: HTMLDetailsElement; - new(): HTMLDetailsElement; -}; - -interface HTMLSummaryElement extends HTMLElement { +interface DOMException extends Error { + readonly name: string; + readonly code: number; + readonly INDEX_SIZE_ERR: number; + readonly DOMSTRING_SIZE_ERR: number; + readonly HIERARCHY_REQUEST_ERR: number; + readonly WRONG_DOCUMENT_ERR: number; + readonly INVALID_CHARACTER_ERR: number; + readonly NO_DATA_ALLOWED_ERR: number; + readonly NO_MODIFICATION_ALLOWED_ERR: number; + readonly NOT_FOUND_ERR: number; + readonly NOT_SUPPORTED_ERR: number; + readonly INUSE_ATTRIBUTE_ERR: number; + readonly INVALID_STATE_ERR: number; + readonly SYNTAX_ERR: number; + readonly INVALID_MODIFICATION_ERR: number; + readonly NAMESPACE_ERR: number; + readonly INVALID_ACCESS_ERR: number; + readonly VALIDATION_ERR: number; + readonly TYPE_MISMATCH_ERR: number; + readonly SECURITY_ERR: number; + readonly NETWORK_ERR: number; + readonly ABORT_ERR: number; + readonly URL_MISMATCH_ERR: number; + readonly QUOTA_EXCEEDED_ERR: number; + readonly TIMEOUT_ERR: number; + readonly INVALID_NODE_TYPE_ERR: number; + readonly DATA_CLONE_ERR: number; } -declare var HTMLSummaryElement: { - prototype: HTMLSummaryElement; - new(): HTMLSummaryElement; +declare var DOMException: { + prototype: DOMException; + new (message?: string, name?: string): DOMException; + readonly INDEX_SIZE_ERR: number; + readonly DOMSTRING_SIZE_ERR: number; + readonly HIERARCHY_REQUEST_ERR: number; + readonly WRONG_DOCUMENT_ERR: number; + readonly INVALID_CHARACTER_ERR: number; + readonly NO_DATA_ALLOWED_ERR: number; + readonly NO_MODIFICATION_ALLOWED_ERR: number; + readonly NOT_FOUND_ERR: number; + readonly NOT_SUPPORTED_ERR: number; + readonly INUSE_ATTRIBUTE_ERR: number; + readonly INVALID_STATE_ERR: number; + readonly SYNTAX_ERR: number; + readonly INVALID_MODIFICATION_ERR: number; + readonly NAMESPACE_ERR: number; + readonly INVALID_ACCESS_ERR: number; + readonly VALIDATION_ERR: number; + readonly TYPE_MISMATCH_ERR: number; + readonly SECURITY_ERR: number; + readonly NETWORK_ERR: number; + readonly ABORT_ERR: number; + readonly URL_MISMATCH_ERR: number; + readonly QUOTA_EXCEEDED_ERR: number; + readonly TIMEOUT_ERR: number; + readonly INVALID_NODE_TYPE_ERR: number; + readonly DATA_CLONE_ERR: number; }; -declare type EventListenerOrEventListenerObject = EventListener | EventListenerObject; - +interface BlobCallback { + (blob: Blob | null): void; +} interface DecodeErrorCallback { (error: DOMException): void; } interface DecodeSuccessCallback { (decodedData: AudioBuffer): void; } -interface ErrorEventHandler { - (message: string, filename?: string, lineno?: number, colno?: number, error?: Error): void; -} -interface ForEachCallback { - (keyId: any, status: MediaKeyStatus): void; +interface EventHandlerNonNull { + (event: Event): any; } interface FrameRequestCallback { (time: number): void; } +interface Function { + (...arguments: any[]): any; +} interface FunctionStringCallback { (data: string): void; } +interface GenerateAssertionCallback { + (contents: string, origin: string, options: RTCIdentityProviderOptions): Promise; +} interface IntersectionObserverCallback { (entries: IntersectionObserverEntry[], observer: IntersectionObserver): void; } -interface MediaQueryListListener { - (mql: MediaQueryList): void; -} -interface MSExecAtPriorityFunctionCallback { - (...args: any[]): any; -} -interface MSLaunchUriCallback { - (): void; -} -interface MSUnsafeFunctionCallback { - (): any; -} interface MutationCallback { (mutations: MutationRecord[], observer: MutationObserver): void; } @@ -14309,20 +12474,29 @@ interface NavigatorUserMediaSuccessCallback { interface NotificationPermissionCallback { (permission: NotificationPermission): void; } +interface OnBeforeUnloadEventHandlerNonNull { + (event: Event): string; +} +interface OnErrorEventHandlerNonNull { + (event: Event | string, source?: string, lineno?: number, colno?: number, error?: any): any; +} +interface PerformanceObserverCallback { + (entries: PerformanceObserverEntryList, observer: PerformanceObserver): void; +} interface PositionCallback { (position: Position): void; } interface PositionErrorCallback { - (error: PositionError): void; + (positionError: PositionError): void; } interface RTCPeerConnectionErrorCallback { - (error: DOMError): void; + (error: DOMException): void; } interface RTCSessionDescriptionCallback { - (sdp: RTCSessionDescription): void; + (description: RTCSessionDescriptionInit): void; } -interface RTCStatsCallback { - (report: RTCStatsReport): void; +interface ValidateAssertionCallback { + (assertion: string, origin: string): Promise; } interface VoidFunction { (): void; @@ -14333,7 +12507,6 @@ interface HTMLElementTagNameMap { "area": HTMLAreaElement; "audio": HTMLAudioElement; "base": HTMLBaseElement; - "basefont": HTMLBaseFontElement; "blockquote": HTMLQuoteElement; "body": HTMLBodyElement; "br": HTMLBRElement; @@ -14345,6 +12518,7 @@ interface HTMLElementTagNameMap { "data": HTMLDataElement; "datalist": HTMLDataListElement; "del": HTMLModElement; + "dialog": HTMLDialogElement; "dir": HTMLDirectoryElement; "div": HTMLDivElement; "dl": HTMLDListElement; @@ -14397,11 +12571,11 @@ interface HTMLElementTagNameMap { "style": HTMLStyleElement; "table": HTMLTableElement; "tbody": HTMLTableSectionElement; - "td": HTMLTableDataCellElement; + "td": HTMLTableCellElement; "template": HTMLTemplateElement; "textarea": HTMLTextAreaElement; "tfoot": HTMLTableSectionElement; - "th": HTMLTableHeaderCellElement; + "th": HTMLTableCellElement; "thead": HTMLTableSectionElement; "time": HTMLTimeElement; "title": HTMLTitleElement; @@ -14409,7 +12583,6 @@ interface HTMLElementTagNameMap { "track": HTMLTrackElement; "ul": HTMLUListElement; "video": HTMLVideoElement; - "x-ms-webview": MSHTMLWebViewElement; "xmp": HTMLPreElement; } @@ -14512,67 +12685,110 @@ interface ElementTagNameMap extends HTMLElementTagNameMap { "wbr": HTMLElement; } -type ElementListTagNameMap = { - [key in keyof ElementTagNameMap]: NodeListOf -}; - declare var Audio: { new(src?: string): HTMLAudioElement; }; declare var Image: { new(width?: number, height?: number): HTMLImageElement; }; declare var Option: { new(text?: string, value?: string, defaultSelected?: boolean, selected?: boolean): HTMLOptionElement; }; declare var applicationCache: ApplicationCache; -declare var caches: CacheStorage; -declare var clientInformation: Navigator; +declare var audioWorklet: Worklet; declare var closed: boolean; -declare var crypto: Crypto; -declare var defaultStatus: string; +declare var customElements: CustomElementRegistry; declare var devicePixelRatio: number; declare var document: Document; -declare var doNotTrack: string; -declare var event: Event | undefined; declare var external: External; -declare var frameElement: Element; +declare var frameElement: Element | null; declare var frames: Window; declare var history: History; declare var innerHeight: number; declare var innerWidth: number; -declare var isSecureContext: boolean; declare var length: number; declare var location: Location; declare var locationbar: BarProp; declare var menubar: BarProp; -declare var msContentScript: ExtensionScriptApis; -declare var msCredentials: MSCredentials; declare const name: never; declare var navigator: Navigator; -declare var offscreenBuffering: string | boolean; -declare var onabort: (this: Window, ev: UIEvent) => any; -declare var onafterprint: (this: Window, ev: Event) => any; -declare var onbeforeprint: (this: Window, ev: Event) => any; -declare var onbeforeunload: (this: Window, ev: BeforeUnloadEvent) => any; -declare var onblur: (this: Window, ev: FocusEvent) => any; +declare var ondevicemotion: (this: Window, ev: DeviceMotionEvent) => any; +declare var ondeviceorientation: (this: Window, ev: DeviceOrientationEvent) => any; +declare var opener: any; +declare var outerHeight: number; +declare var outerWidth: number; +declare var pageXOffset: number; +declare var pageYOffset: number; +declare var parent: Window | null; +declare var personalbar: BarProp; +declare var screen: Screen; +declare var screenX: number; +declare var screenY: number; +declare var scrollbars: BarProp; +declare var scrollX: number; +declare var scrollY: number; +declare var self: Window; +declare var status: string; +declare var statusbar: BarProp; +declare var toolbar: BarProp; +declare var top: Window | null; +declare var window: Window; +declare function alert(message?: any): void; +declare function alert(message?: any): void; +declare function blur(): void; +declare function cancelAnimationFrame(handle: number): void; +declare function captureEvents(): void; +declare function close(): void; +declare function confirm(message?: string): boolean; +declare function focus(): void; +declare function getComputedStyle(elt: Element, pseudoElt?: CSSOMString): CSSStyleDeclaration; +declare function getSelection(): Selection | null; +declare function matchMedia(query: string): MediaQueryList; +declare function moveBy(x: number, y: number): void; +declare function moveTo(x: number, y: number): void; +declare function open(url?: string, target?: string, features?: string, replace?: boolean): Window; +declare function postMessage(message: any, targetOrigin: string, transfer?: any[]): void; +declare function print(): void; +declare function prompt(message?: string, _default?: string): string | null; +declare function releaseEvents(): void; +declare function requestAnimationFrame(callback: FrameRequestCallback): number; +declare function resizeBy(x: number, y: number): void; +declare function resizeTo(x: number, y: number): void; +declare function scroll(options?: ScrollToOptions): void; +declare function scroll(x: number, y: number): void; +declare function scrollBy(options?: ScrollToOptions): void; +declare function scrollBy(x: number, y: number): void; +declare function scrollTo(options?: ScrollToOptions): void; +declare function scrollTo(x: number, y: number): void; +declare function stop(): void; +declare function createImageBitmap(image: HTMLImageElement | SVGImageElement | HTMLVideoElement | HTMLCanvasElement | ImageBitmap | ImageData | Blob, options?: ImageBitmapOptions): Promise; +declare function createImageBitmap(image: HTMLImageElement | SVGImageElement | HTMLVideoElement | HTMLCanvasElement | ImageBitmap | ImageData | Blob, sx: number, sy: number, sw: number, sh: number, options?: ImageBitmapOptions): Promise; +declare function toString(): string; +declare function dispatchEvent(event: Event): boolean; +declare function removeEventListener(type: string, callback: EventListener | null, options?: EventListenerOptions | boolean): void; +declare var onabort: (this: Window, ev: Event) => any; +declare var onanimationcancel: (this: Window, ev: AnimationEvent) => any; +declare var onanimationend: (this: Window, ev: AnimationEvent) => any; +declare var onanimationiteration: (this: Window, ev: AnimationEvent) => any; +declare var onanimationstart: (this: Window, ev: AnimationEvent) => any; +declare var onauxclick: (this: Window, ev: MouseEvent) => any; +declare var onblur: (this: Window, ev: Event) => any; +declare var oncancel: (this: Window, ev: Event) => any; declare var oncanplay: (this: Window, ev: Event) => any; declare var oncanplaythrough: (this: Window, ev: Event) => any; declare var onchange: (this: Window, ev: Event) => any; declare var onclick: (this: Window, ev: MouseEvent) => any; -declare var oncompassneedscalibration: (this: Window, ev: Event) => any; -declare var oncontextmenu: (this: Window, ev: PointerEvent) => any; +declare var onclose: (this: Window, ev: Event) => any; +declare var oncontextmenu: (this: Window, ev: MouseEvent) => any; +declare var oncuechange: (this: Window, ev: Event) => any; declare var ondblclick: (this: Window, ev: MouseEvent) => any; -declare var ondevicelight: (this: Window, ev: DeviceLightEvent) => any; -declare var ondevicemotion: (this: Window, ev: DeviceMotionEvent) => any; -declare var ondeviceorientation: (this: Window, ev: DeviceOrientationEvent) => any; declare var ondrag: (this: Window, ev: DragEvent) => any; declare var ondragend: (this: Window, ev: DragEvent) => any; declare var ondragenter: (this: Window, ev: DragEvent) => any; +declare var ondragexit: (this: Window, ev: DragEvent) => any; declare var ondragleave: (this: Window, ev: DragEvent) => any; declare var ondragover: (this: Window, ev: DragEvent) => any; declare var ondragstart: (this: Window, ev: DragEvent) => any; declare var ondrop: (this: Window, ev: DragEvent) => any; declare var ondurationchange: (this: Window, ev: Event) => any; declare var onemptied: (this: Window, ev: Event) => any; -declare var onended: (this: Window, ev: MediaStreamErrorEvent) => any; -declare var onerror: ErrorEventHandler; -declare var onfocus: (this: Window, ev: FocusEvent) => any; -declare var onhashchange: (this: Window, ev: HashChangeEvent) => any; +declare var onended: (this: Window, ev: Event) => any; +declare var onerror: OnErrorEventHandler; +declare var onfocus: (this: Window, ev: Event) => any; declare var oninput: (this: Window, ev: Event) => any; declare var oninvalid: (this: Window, ev: Event) => any; declare var onkeydown: (this: Window, ev: KeyboardEvent) => any; @@ -14581,8 +12797,8 @@ declare var onkeyup: (this: Window, ev: KeyboardEvent) => any; declare var onload: (this: Window, ev: Event) => any; declare var onloadeddata: (this: Window, ev: Event) => any; declare var onloadedmetadata: (this: Window, ev: Event) => any; +declare var onloadend: (this: Window, ev: Event) => any; declare var onloadstart: (this: Window, ev: Event) => any; -declare var onmessage: (this: Window, ev: MessageEvent) => any; declare var onmousedown: (this: Window, ev: MouseEvent) => any; declare var onmouseenter: (this: Window, ev: MouseEvent) => any; declare var onmouseleave: (this: Window, ev: MouseEvent) => any; @@ -14590,153 +12806,98 @@ declare var onmousemove: (this: Window, ev: MouseEvent) => any; declare var onmouseout: (this: Window, ev: MouseEvent) => any; declare var onmouseover: (this: Window, ev: MouseEvent) => any; declare var onmouseup: (this: Window, ev: MouseEvent) => any; -declare var onmousewheel: (this: Window, ev: WheelEvent) => any; -declare var onmsgesturechange: (this: Window, ev: MSGestureEvent) => any; -declare var onmsgesturedoubletap: (this: Window, ev: MSGestureEvent) => any; -declare var onmsgestureend: (this: Window, ev: MSGestureEvent) => any; -declare var onmsgesturehold: (this: Window, ev: MSGestureEvent) => any; -declare var onmsgesturestart: (this: Window, ev: MSGestureEvent) => any; -declare var onmsgesturetap: (this: Window, ev: MSGestureEvent) => any; -declare var onmsinertiastart: (this: Window, ev: MSGestureEvent) => any; -declare var onmspointercancel: (this: Window, ev: MSPointerEvent) => any; -declare var onmspointerdown: (this: Window, ev: MSPointerEvent) => any; -declare var onmspointerenter: (this: Window, ev: MSPointerEvent) => any; -declare var onmspointerleave: (this: Window, ev: MSPointerEvent) => any; -declare var onmspointermove: (this: Window, ev: MSPointerEvent) => any; -declare var onmspointerout: (this: Window, ev: MSPointerEvent) => any; -declare var onmspointerover: (this: Window, ev: MSPointerEvent) => any; -declare var onmspointerup: (this: Window, ev: MSPointerEvent) => any; -declare var onoffline: (this: Window, ev: Event) => any; -declare var ononline: (this: Window, ev: Event) => any; -declare var onorientationchange: (this: Window, ev: Event) => any; -declare var onpagehide: (this: Window, ev: PageTransitionEvent) => any; -declare var onpageshow: (this: Window, ev: PageTransitionEvent) => any; declare var onpause: (this: Window, ev: Event) => any; declare var onplay: (this: Window, ev: Event) => any; declare var onplaying: (this: Window, ev: Event) => any; -declare var onpopstate: (this: Window, ev: PopStateEvent) => any; -declare var onprogress: (this: Window, ev: ProgressEvent) => any; +declare var onpointercancel: (this: Window, ev: PointerEvent) => any; +declare var onpointerdown: (this: Window, ev: PointerEvent) => any; +declare var onpointerenter: (this: Window, ev: PointerEvent) => any; +declare var onpointerleave: (this: Window, ev: PointerEvent) => any; +declare var onpointermove: (this: Window, ev: PointerEvent) => any; +declare var onpointerout: (this: Window, ev: PointerEvent) => any; +declare var onpointerover: (this: Window, ev: PointerEvent) => any; +declare var onpointerup: (this: Window, ev: PointerEvent) => any; +declare var onprogress: (this: Window, ev: Event) => any; declare var onratechange: (this: Window, ev: Event) => any; -declare var onreadystatechange: (this: Window, ev: ProgressEvent) => any; declare var onreset: (this: Window, ev: Event) => any; -declare var onresize: (this: Window, ev: UIEvent) => any; -declare var onscroll: (this: Window, ev: UIEvent) => any; +declare var onresize: (this: Window, ev: Event) => any; +declare var onscroll: (this: Window, ev: Event) => any; declare var onseeked: (this: Window, ev: Event) => any; declare var onseeking: (this: Window, ev: Event) => any; -declare var onselect: (this: Window, ev: UIEvent) => any; +declare var onselect: (this: Window, ev: Event) => any; +declare var onselectionchange: (this: Window, ev: Event) => any; +declare var onselectstart: (this: Window, ev: Event) => any; +declare var onshow: (this: Window, ev: RelatedEvent) => any; declare var onstalled: (this: Window, ev: Event) => any; -declare var onstorage: (this: Window, ev: StorageEvent) => any; declare var onsubmit: (this: Window, ev: Event) => any; declare var onsuspend: (this: Window, ev: Event) => any; declare var ontimeupdate: (this: Window, ev: Event) => any; -declare var ontouchcancel: (ev: TouchEvent) => any; -declare var ontouchend: (ev: TouchEvent) => any; -declare var ontouchmove: (ev: TouchEvent) => any; -declare var ontouchstart: (ev: TouchEvent) => any; -declare var onunload: (this: Window, ev: Event) => any; +declare var ontoggle: (this: Window, ev: Event) => any; +declare var ontouchcancel: (this: Window, ev: TouchEvent) => any; +declare var ontouchend: (this: Window, ev: TouchEvent) => any; +declare var ontouchmove: (this: Window, ev: TouchEvent) => any; +declare var ontouchstart: (this: Window, ev: TouchEvent) => any; +declare var ontransitioncancel: (this: Window, ev: TransitionEvent) => any; +declare var ontransitionend: (this: Window, ev: TransitionEvent) => any; +declare var ontransitionrun: (this: Window, ev: TransitionEvent) => any; +declare var ontransitionstart: (this: Window, ev: TransitionEvent) => any; declare var onvolumechange: (this: Window, ev: Event) => any; declare var onwaiting: (this: Window, ev: Event) => any; -declare var opener: any; -declare var orientation: string | number; -declare var outerHeight: number; -declare var outerWidth: number; -declare var pageXOffset: number; -declare var pageYOffset: number; -declare var parent: Window; -declare var performance: Performance; -declare var personalbar: BarProp; -declare var screen: Screen; -declare var screenLeft: number; -declare var screenTop: number; -declare var screenX: number; -declare var screenY: number; -declare var scrollbars: BarProp; -declare var scrollX: number; -declare var scrollY: number; -declare var self: Window; -declare var speechSynthesis: SpeechSynthesis; -declare var status: string; -declare var statusbar: BarProp; -declare var styleMedia: StyleMedia; -declare var toolbar: BarProp; -declare var top: Window; -declare var window: Window; -declare var customElements: CustomElementRegistry; -declare function alert(message?: any): void; -declare function blur(): void; -declare function cancelAnimationFrame(handle: number): void; -declare function captureEvents(): void; -declare function close(): void; -declare function confirm(message?: string): boolean; -declare function departFocus(navigationReason: NavigationReason, origin: FocusNavigationOrigin): void; -declare function focus(): void; -declare function getComputedStyle(elt: Element, pseudoElt?: string): CSSStyleDeclaration; -declare function getMatchedCSSRules(elt: Element, pseudoElt?: string): CSSRuleList; -declare function getSelection(): Selection; -declare function matchMedia(mediaQuery: string): MediaQueryList; -declare function moveBy(x?: number, y?: number): void; -declare function moveTo(x?: number, y?: number): void; -declare function msWriteProfilerMark(profilerMarkName: string): void; -declare function open(url?: string, target?: string, features?: string, replace?: boolean): Window; -declare function postMessage(message: any, targetOrigin: string, transfer?: any[]): void; -declare function print(): void; -declare function prompt(message?: string, _default?: string): string | null; -declare function releaseEvents(): void; -declare function requestAnimationFrame(callback: FrameRequestCallback): number; -declare function resizeBy(x?: number, y?: number): void; -declare function resizeTo(x?: number, y?: number): void; -declare function scroll(x?: number, y?: number): void; -declare function scrollBy(x?: number, y?: number): void; -declare function scrollTo(x?: number, y?: number): void; -declare function stop(): void; -declare function webkitCancelAnimationFrame(handle: number): void; -declare function webkitConvertPointFromNodeToPage(node: Node, pt: WebKitPoint): WebKitPoint; -declare function webkitConvertPointFromPageToNode(node: Node, pt: WebKitPoint): WebKitPoint; -declare function webkitRequestAnimationFrame(callback: FrameRequestCallback): number; -declare function createImageBitmap(image: HTMLImageElement | SVGImageElement | HTMLVideoElement | HTMLCanvasElement | ImageBitmap | ImageData | Blob, options?: ImageBitmapOptions): Promise; -declare function createImageBitmap(image: HTMLImageElement | SVGImageElement | HTMLVideoElement | HTMLCanvasElement | ImageBitmap | ImageData | Blob, sx: number, sy: number, sw: number, sh: number, options?: ImageBitmapOptions): Promise; -declare function scroll(options?: ScrollToOptions): void; -declare function scrollTo(options?: ScrollToOptions): void; -declare function scrollBy(options?: ScrollToOptions): void; -declare function toString(): string; -declare function dispatchEvent(evt: Event): boolean; -declare function removeEventListener(type: string, listener?: EventListenerOrEventListenerObject, options?: boolean | EventListenerOptions): void; -declare function clearInterval(handle: number): void; -declare function clearTimeout(handle: number): void; +declare var onwheel: (this: Window, ev: WheelEvent) => any; +declare var onafterprint: (this: Window, ev: Event) => any; +declare var onbeforeprint: (this: Window, ev: Event) => any; +declare var onbeforeunload: OnBeforeUnloadEventHandler; +declare var onhashchange: (this: Window, ev: HashChangeEvent) => any; +declare var onlanguagechange: (this: Window, ev: Event) => any; +declare var onmessage: (this: Window, ev: MessageEvent) => any; +declare var onmessageerror: (this: Window, ev: MessageEvent) => any; +declare var onoffline: (this: Window, ev: Event) => any; +declare var ononline: (this: Window, ev: Event) => any; +declare var onpagehide: (this: Window, ev: PageTransitionEvent) => any; +declare var onpageshow: (this: Window, ev: PageTransitionEvent) => any; +declare var onpopstate: (this: Window, ev: PopStateEvent) => any; +declare var onrejectionhandled: (this: Window, ev: PromiseRejectionEvent) => any; +declare var onstorage: (this: Window, ev: StorageEvent) => any; +declare var onunhandledrejection: (this: Window, ev: PromiseRejectionEvent) => any; +declare var onunload: (this: Window, ev: Event) => any; +declare var caches: CacheStorage; +declare var indexedDB: IDBFactory; +declare var origin: string; +declare function atob(data: string): string; +declare function btoa(data: string): string; +declare function clearInterval(handle?: number): void; +declare function clearTimeout(handle?: number): void; +declare function createImageBitmap(image: ImageBitmapSource, options?: ImageBitmapOptions): Promise; +declare function createImageBitmap(image: ImageBitmapSource, sx: number, sy: number, sw: number, sh: number, options?: ImageBitmapOptions): Promise; +declare function fetch(input: RequestInfo, init?: RequestInit): Promise; declare function setInterval(handler: (...args: any[]) => void, timeout: number): number; declare function setInterval(handler: any, timeout?: any, ...args: any[]): number; declare function setTimeout(handler: (...args: any[]) => void, timeout: number): number; declare function setTimeout(handler: any, timeout?: any, ...args: any[]): number; -declare function clearImmediate(handle: number): void; -declare function setImmediate(handler: (...args: any[]) => void): number; -declare function setImmediate(handler: any, ...args: any[]): number; declare var sessionStorage: Storage; declare var localStorage: Storage; -declare var console: Console; -declare var onpointercancel: (this: Window, ev: PointerEvent) => any; -declare var onpointerdown: (this: Window, ev: PointerEvent) => any; -declare var onpointerenter: (this: Window, ev: PointerEvent) => any; -declare var onpointerleave: (this: Window, ev: PointerEvent) => any; -declare var onpointermove: (this: Window, ev: PointerEvent) => any; -declare var onpointerout: (this: Window, ev: PointerEvent) => any; -declare var onpointerover: (this: Window, ev: PointerEvent) => any; -declare var onpointerup: (this: Window, ev: PointerEvent) => any; -declare var onwheel: (this: Window, ev: WheelEvent) => any; -declare var indexedDB: IDBFactory; -declare function atob(encodedString: string): string; -declare function btoa(rawString: string): string; -declare function fetch(input: RequestInfo, init?: RequestInit): Promise; +declare var performance: Performance; +declare var crypto: Crypto; +declare var speechSynthesis: SpeechSynthesis; declare function addEventListener(type: K, listener: (this: Window, ev: WindowEventMap[K]) => any, useCapture?: boolean): void; -declare function addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; -type AAGUID = string; -type AlgorithmIdentifier = string | Algorithm; -type BodyInit = any; -type ByteString = string; +declare function addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; +type AlgorithmIdentifier = any; +type BigInteger = Uint8Array; +type BlobPart = BufferSource | Blob | string; +type BodyInit = Blob | BufferSource | FormData | URLSearchParams | ReadableStream | string; +type BufferSource = ArrayBufferView | ArrayBuffer; +type CanvasImageSource = HTMLOrSVGImageElement | HTMLVideoElement | HTMLCanvasElement | ImageBitmap | OffscreenCanvas; type ConstrainBoolean = boolean | ConstrainBooleanParameters; type ConstrainDOMString = string | string[] | ConstrainDOMStringParameters; type ConstrainDouble = number | ConstrainDoubleRange; type ConstrainLong = number | ConstrainLongRange; -type CryptoOperationData = ArrayBufferView; +type CSSOMString = string; +type DOMHighResTimeStamp = number; +type DOMTimeStamp = number; +type EventHandler = EventHandlerNonNull; +type Float32List = Float32Array | GLfloat[]; +type FormDataEntryValue = File | string; +type GeometryNode = Text | Element | CSSPseudoElement | Document; type GLbitfield = number; type GLboolean = boolean; type GLbyte = number; @@ -14751,95 +12912,120 @@ type GLsizeiptr = number; type GLubyte = number; type GLuint = number; type GLushort = number; -type HeadersInit = Headers | string[][]; -type IDBKeyPath = string; -type KeyFormat = string; -type KeyType = string; -type KeyUsage = string; -type MSInboundPayload = MSVideoRecvPayload | MSAudioRecvPayload; -type MSLocalClientEvent = MSLocalClientEventBase | MSAudioLocalClientEvent; -type MSOutboundPayload = MSVideoSendPayload | MSAudioSendPayload; -type RTCIceGatherCandidate = RTCIceCandidateDictionary | RTCIceCandidateComplete; -type RTCTransport = RTCDtlsTransport | RTCSrtpSdesTransport; +type HashAlgorithmIdentifier = AlgorithmIdentifier; +type HeadersInit = string[][] | { [key: string]: string }; +type HTMLOrSVGImageElement = HTMLImageElement | SVGImageElement; +type HTMLOrSVGScriptElement = HTMLScriptElement | SVGScriptElement; +type ImageBitmapSource = CanvasImageSource | Blob | ImageData; +type Int32List = Int32Array | GLint[]; +type MediaProvider = MediaStream | MediaSource | Blob; +type MediaStreamError = any; +type MessageEventSource = Window | MessagePort | ServiceWorker; +type NamedCurve = string; +type OffscreenRenderingContext = OffscreenCanvasRenderingContext2D | WebGLRenderingContext; +type OnBeforeUnloadEventHandler = OnBeforeUnloadEventHandlerNonNull; +type OnErrorEventHandler = OnErrorEventHandlerNonNull; +type PerformanceEntryList = PerformanceEntry[]; +type RenderingContext = CanvasRenderingContext2D | WebGLRenderingContext; type RequestInfo = Request | string; -type USVString = string; -type payloadtype = number; -type ScrollBehavior = "auto" | "instant" | "smooth"; -type ScrollLogicalPosition = "start" | "center" | "end" | "nearest"; +type TexImageSource = ImageBitmap | ImageData | HTMLImageElement | HTMLCanvasElement | HTMLVideoElement; +type TimerHandler = string | Function; type IDBValidKey = number | string | Date | IDBArrayKey; -type BufferSource = ArrayBuffer | ArrayBufferView; type MouseWheelEvent = WheelEvent; -type ScrollRestoration = "auto" | "manual"; -type FormDataEntryValue = string | File; -type InsertPosition = "beforebegin" | "afterbegin" | "beforeend" | "afterend"; type AppendMode = "segments" | "sequence"; +type AudioContextLatencyCategory = "balanced" | "interactive" | "playback"; type AudioContextState = "suspended" | "running" | "closed"; +type BinaryType = "blob" | "arraybuffer"; type BiquadFilterType = "lowpass" | "highpass" | "bandpass" | "lowshelf" | "highshelf" | "peaking" | "notch" | "allpass"; +type CanPlayTypeResult = "" | "maybe" | "probably"; +type CanvasDirection = "ltr" | "rtl" | "inherit"; type CanvasFillRule = "nonzero" | "evenodd"; +type CanvasLineCap = "butt" | "round" | "square"; +type CanvasLineJoin = "round" | "bevel" | "miter"; +type CanvasTextAlign = "start" | "end" | "left" | "right" | "center"; +type CanvasTextBaseline = "top" | "hanging" | "middle" | "alphabetic" | "ideographic" | "bottom"; type ChannelCountMode = "max" | "clamped-max" | "explicit"; type ChannelInterpretation = "speakers" | "discrete"; +type ColorSpaceConversion = "none" | "default"; +type CSSBoxType = "margin" | "border" | "padding" | "content"; type DistanceModelType = "linear" | "inverse" | "exponential"; -type ExpandGranularity = "character" | "word" | "sentence" | "textedit"; -type GamepadInputEmulationType = "mouse" | "keyboard" | "gamepad"; +type DocumentReadyState = "loading" | "interactive" | "complete"; +type EndOfStreamError = "network" | "decode"; +type GamepadMappingType = "" | "standard"; type IDBCursorDirection = "next" | "nextunique" | "prev" | "prevunique"; type IDBRequestReadyState = "pending" | "done"; type IDBTransactionMode = "readonly" | "readwrite" | "versionchange"; -type ListeningState = "inactive" | "active" | "disambiguation"; +type ImageOrientation = "none" | "flipY"; +type ImageSmoothingQuality = "low" | "medium" | "high"; +type KeyFormat = "raw" | "spki" | "pkcs8" | "jwk"; +type KeyType = "public" | "private" | "secret"; +type KeyUsage = "encrypt" | "decrypt" | "sign" | "verify" | "deriveKey" | "deriveBits" | "wrapKey" | "unwrapKey"; type MediaDeviceKind = "audioinput" | "audiooutput" | "videoinput"; type MediaKeyMessageType = "license-request" | "license-renewal" | "license-release" | "individualization-request"; -type MediaKeySessionType = "temporary" | "persistent-license" | "persistent-release-message"; +type MediaKeySessionType = "temporary" | "persistent-license"; type MediaKeysRequirement = "required" | "optional" | "not-allowed"; -type MediaKeyStatus = "usable" | "expired" | "output-downscaled" | "output-not-allowed" | "status-pending" | "internal-error"; +type MediaKeyStatus = "usable" | "expired" | "released" | "output-restricted" | "output-downscaled" | "status-pending" | "internal-error"; type MediaStreamTrackState = "live" | "ended"; -type MSCredentialType = "FIDO_2_0"; -type MSIceAddrType = "os" | "stun" | "turn" | "peer-derived"; -type MSIceType = "failed" | "direct" | "relay"; -type MSStatsType = "description" | "localclientevent" | "inbound-network" | "outbound-network" | "inbound-payload" | "outbound-payload" | "transportdiagnostics"; -type MSTransportType = "Embedded" | "USB" | "NFC" | "BT"; -type MSWebViewPermissionState = "unknown" | "defer" | "allow" | "deny"; -type MSWebViewPermissionType = "geolocation" | "unlimitedIndexedDBQuota" | "media" | "pointerlock" | "webnotifications"; -type NavigationReason = "up" | "down" | "left" | "right"; type NavigationType = "navigate" | "reload" | "back_forward" | "prerender"; type NotificationDirection = "auto" | "ltr" | "rtl"; type NotificationPermission = "default" | "denied" | "granted"; +type OffscreenRenderingContextType = "2d" | "webgl"; type OscillatorType = "sine" | "square" | "sawtooth" | "triangle" | "custom"; type OverSampleType = "none" | "2x" | "4x"; -type PanningModelType = "equalpower"; -type PaymentComplete = "success" | "fail" | ""; +type PanningModelType = "equalpower" | "HRTF"; +type PaymentComplete = "fail" | "success" | "unknown"; type PaymentShippingType = "shipping" | "delivery" | "pickup"; +type PremultiplyAlpha = "none" | "premultiply" | "default"; type PushEncryptionKeyName = "p256dh" | "auth"; -type PushPermissionState = "granted" | "denied" | "prompt"; -type ReferrerPolicy = "" | "no-referrer" | "no-referrer-when-downgrade" | "origin-only" | "origin-when-cross-origin" | "unsafe-url"; -type RequestCache = "default" | "no-store" | "reload" | "no-cache" | "force-cache"; +type PushPermissionState = "denied" | "granted" | "prompt"; +type ReadyState = "closed" | "open" | "ended"; +type ReferrerPolicy = "" | "no-referrer" | "no-referrer-when-downgrade" | "same-origin" | "origin" | "strict-origin" | "origin-when-cross-origin" | "strict-origin-when-cross-origin" | "unsafe-url"; +type RequestCache = "default" | "no-store" | "reload" | "no-cache" | "force-cache" | "only-if-cached"; type RequestCredentials = "omit" | "same-origin" | "include"; -type RequestDestination = "" | "document" | "sharedworker" | "subresource" | "unknown" | "worker"; +type RequestDestination = "" | "audio" | "document" | "embed" | "font" | "image" | "manifest" | "object" | "report" | "script" | "serviceworker" | "sharedworker" | "style" | "track" | "video" | "worker" | "xslt"; type RequestMode = "navigate" | "same-origin" | "no-cors" | "cors"; type RequestRedirect = "follow" | "error" | "manual"; type RequestType = "" | "audio" | "font" | "image" | "script" | "style" | "track" | "video"; +type ResizeQuality = "pixelated" | "low" | "medium" | "high"; type ResponseType = "basic" | "cors" | "default" | "error" | "opaque" | "opaqueredirect"; type RTCBundlePolicy = "balanced" | "max-compat" | "max-bundle"; +type RTCDataChannelState = "connecting" | "open" | "closing" | "closed"; type RTCDegradationPreference = "maintain-framerate" | "maintain-resolution" | "balanced"; -type RTCDtlsRole = "auto" | "client" | "server"; -type RTCDtlsTransportState = "new" | "connecting" | "connected" | "closed"; +type RTCDtlsTransportState = "new" | "connecting" | "connected" | "closed" | "failed"; +type RTCDtxStatus = "disabled" | "enabled"; +type RTCErrorDetailType = "data-channel-failure" | "idp-bad-script-failure" | "idp-execution-failure" | "idp-load-failure" | "idp-need-login" | "idp-timeout" | "idp-tls-failure" | "idp-token-expired" | "idp-token-invalid" | "sctp-failure" | "sdp-syntax-error"; type RTCIceCandidateType = "host" | "srflx" | "prflx" | "relay"; -type RTCIceComponent = "RTP" | "RTCP"; +type RTCIceComponent = "rtp" | "rtcp"; type RTCIceConnectionState = "new" | "checking" | "connected" | "completed" | "failed" | "disconnected" | "closed"; +type RTCIceCredentialType = "password" | "oauth"; type RTCIceGathererState = "new" | "gathering" | "complete"; type RTCIceGatheringState = "new" | "gathering" | "complete"; -type RTCIceGatherPolicy = "all" | "nohost" | "relay"; type RTCIceProtocol = "udp" | "tcp"; type RTCIceRole = "controlling" | "controlled"; type RTCIceTcpCandidateType = "active" | "passive" | "so"; -type RTCIceTransportPolicy = "none" | "relay" | "all"; -type RTCIceTransportState = "new" | "checking" | "connected" | "completed" | "disconnected" | "closed"; -type RTCSdpType = "offer" | "pranswer" | "answer"; +type RTCIceTransportPolicy = "relay" | "all"; +type RTCIceTransportState = "new" | "checking" | "connected" | "completed" | "failed" | "disconnected" | "closed"; +type RTCPeerConnectionState = "new" | "connecting" | "connected" | "disconnected" | "failed" | "closed"; +type RTCPriorityType = "very-low" | "low" | "medium" | "high"; +type RTCRtcpMuxPolicy = "negotiate" | "require"; +type RTCRtpTransceiverDirection = "sendrecv" | "sendonly" | "recvonly" | "inactive"; +type RTCSdpType = "offer" | "pranswer" | "answer" | "rollback"; type RTCSignalingState = "stable" | "have-local-offer" | "have-remote-offer" | "have-local-pranswer" | "have-remote-pranswer" | "closed"; type RTCStatsIceCandidatePairState = "frozen" | "waiting" | "inprogress" | "failed" | "succeeded" | "cancelled"; -type RTCStatsIceCandidateType = "host" | "serverreflexive" | "peerreflexive" | "relayed"; -type RTCStatsType = "inboundrtp" | "outboundrtp" | "session" | "datachannel" | "track" | "transport" | "candidatepair" | "localcandidate" | "remotecandidate"; -type ScopedCredentialType = "ScopedCred"; +type RTCStatsType = "codec" | "inbound-rtp" | "outbound-rtp" | "peer-connection" | "data-channel" | "track" | "transport" | "candidate-pair" | "local-candidate" | "remote-candidate" | "certificate"; +type ScrollBehavior = "auto" | "instant" | "smooth"; +type ScrollLogicalPosition = "start" | "center" | "end" | "nearest"; +type ScrollRestoration = "auto" | "manual"; +type SelectionMode = "select" | "start" | "end" | "preserve"; type ServiceWorkerState = "installing" | "installed" | "activating" | "activated" | "redundant"; -type Transport = "usb" | "nfc" | "ble"; +type ShadowRootMode = "open" | "closed"; +type SpeechRecognitionErrorCode = "no-speech" | "aborted" | "audio-capture" | "network" | "not-allowed" | "service-not-allowed" | "bad-grammar" | "language-not-supported"; +type SpeechSynthesisErrorCode = "canceled" | "interrupted" | "audio-busy" | "audio-hardware" | "network" | "synthesis-unavailable" | "synthesis-failed" | "language-unavailable" | "voice-unavailable" | "text-too-long" | "invalid-argument"; +type TextTrackKind = "subtitles" | "captions" | "descriptions" | "chapters" | "metadata"; +type TextTrackMode = "disabled" | "hidden" | "showing"; +type TouchType = "direct" | "stylus"; type VideoFacingModeEnum = "user" | "environment" | "left" | "right"; type VisibilityState = "hidden" | "visible" | "prerender" | "unloaded"; +type WebGLPowerPreference = "default" | "low-power" | "high-performance"; +type WorkerType = "classic" | "module"; type XMLHttpRequestResponseType = "" | "arraybuffer" | "blob" | "document" | "json" | "text"; \ No newline at end of file diff --git a/baselines/webworker.generated.d.ts b/baselines/webworker.generated.d.ts index 55f69349a..f9f9599ed 100644 --- a/baselines/webworker.generated.d.ts +++ b/baselines/webworker.generated.d.ts @@ -3,8 +3,9 @@ /// Worker APIs ///////////////////////////// -interface Algorithm { - name: string; +interface AddEventListenerOptions extends EventListenerOptions { + once?: boolean; + passive?: boolean; } interface CacheQueryOptions { @@ -14,16 +15,117 @@ interface CacheQueryOptions { ignoreVary?: boolean; } +interface ClientQueryOptions { + includeReserved?: boolean; + includeUncontrolled?: boolean; + type?: ClientType; +} + interface CloseEventInit extends EventInit { code?: number; reason?: string; wasClean?: boolean; } +interface CustomEventInit extends EventInit { + detail?: any; +} + +interface DOMMatrixInit { + a?: number; + b?: number; + c?: number; + d?: number; + e?: number; + f?: number; + is2D?: boolean; + m11?: number; + m12?: number; + m13?: number; + m14?: number; + m21?: number; + m22?: number; + m23?: number; + m24?: number; + m31?: number; + m32?: number; + m33?: number; + m34?: number; + m41?: number; + m42?: number; + m43?: number; + m44?: number; +} + +interface DOMPointInit { + w?: number; + x?: number; + y?: number; + z?: number; +} + +interface DOMQuadInit { + p1?: DOMPointInit; + p2?: DOMPointInit; + p3?: DOMPointInit; + p4?: DOMPointInit; +} + +interface DOMRectInit { + height?: number; + width?: number; + x?: number; + y?: number; +} + interface EventInit { scoped?: boolean; bubbles?: boolean; cancelable?: boolean; + composed?: boolean; +} + +interface EventListenerOptions { + capture?: boolean; +} + +interface EventSourceInit { + withCredentials?: boolean; +} + +interface ExtendableEventInit extends EventInit { +} + +interface ExtendableMessageEventInit extends ExtendableEventInit { + data?: any; + lastEventId?: string; + origin?: string; + ports?: MessagePort[]; + source?: Client | ServiceWorker | MessagePort | null; +} + +interface FetchEventInit extends ExtendableEventInit { + clientId?: string; + preloadResponse: Promise; + request: Request; + reservedClientId?: string; + targetClientId?: string; +} + +interface ForeignFetchEventInit extends ExtendableEventInit { + origin?: string; + request: Request; +} + +interface ForeignFetchOptions { + origins: string[]; + scopes: string[]; +} + +interface ForeignFetchResponse { + headers?: string[]; + origin?: string; + response: Response; } interface GetNotificationOptions { @@ -37,44 +139,117 @@ interface IDBIndexParameters { interface IDBObjectStoreParameters { autoIncrement?: boolean; - keyPath?: IDBKeyPath | null; + keyPath?: string | string[] | null; } -interface KeyAlgorithm { - name?: string; +interface IDBVersionChangeEventInit extends EventInit { + newVersion?: number | null; + oldVersion?: number; +} + +interface ImageEncodeOptions { + quality?: number; + type?: string; +} + +interface JsonWebKey { + alg?: string; + crv?: string; + d?: string; + dp?: string; + dq?: string; + e?: string; + ext?: boolean; + k?: string; + key_ops?: string[]; + kty?: string; + n?: string; + oth?: RsaOtherPrimesInfo[]; + p?: string; + q?: string; + qi?: string; + use?: string; + x?: string; + y?: string; } interface MessageEventInit extends EventInit { - lastEventId?: string; channel?: string; data?: any; + lastEventId?: string; origin?: string; ports?: MessagePort[]; - source?: any; + source?: MessageEventSource | null; +} + +interface NavigationPreloadState { + enabled?: boolean; + headerValue?: string; +} + +interface NotificationAction { + action: string; + icon?: string; + title: string; +} + +interface NotificationEventInit extends ExtendableEventInit { + action?: string; + notification: Notification; } interface NotificationOptions { + actions?: NotificationAction[]; + badge?: string; body?: string; + data?: any; dir?: NotificationDirection; icon?: string; + image?: string; lang?: string; + renotify?: boolean; + requireInteraction?: boolean; + silent?: boolean; + sound?: string; tag?: string; + timestamp?: number; + vibrate?: any; +} + +interface PerformanceObserverInit { + entryTypes: string[]; } -interface ObjectURLOptions { - oneTimeOnly?: boolean; +interface PromiseRejectionEventInit extends EventInit { + promise: Promise; + reason?: any; +} + +interface PushEventInit extends ExtendableEventInit { + data?: PushMessageDataInit; +} + +interface PushSubscriptionChangeInit extends ExtendableEventInit { + newSubscription?: PushSubscription; + oldSubscription?: PushSubscription; } interface PushSubscriptionOptionsInit { - applicationServerKey?: any; + applicationServerKey?: BufferSource | string | null; userVisibleOnly?: boolean; } +interface RegistrationOptions { + scope?: string; + type?: WorkerType; + useCache?: boolean; +} + interface RequestInit { - body?: any; + body?: BodyInit | null; cache?: RequestCache; credentials?: RequestCredentials; - headers?: Headers | string[][]; + headers?: HeadersInit; integrity?: string; keepalive?: boolean; method?: string; @@ -86,83 +261,33 @@ interface RequestInit { } interface ResponseInit { - headers?: Headers | string[][]; + headers?: HeadersInit; status?: number; statusText?: string; } -interface ClientQueryOptions { - includeUncontrolled?: boolean; - type?: ClientType; -} - -interface ExtendableEventInit extends EventInit { -} - -interface ExtendableMessageEventInit extends ExtendableEventInit { - data?: any; - origin?: string; - lastEventId?: string; - source?: Client | ServiceWorker | MessagePort | null; - ports?: MessagePort[] | null; -} - -interface FetchEventInit extends ExtendableEventInit { - request: Request; - clientId?: string | null; - isReload?: boolean; -} - -interface NotificationEventInit extends ExtendableEventInit { - notification: Notification; - action?: string; -} - -interface PushEventInit extends ExtendableEventInit { - data?: any; +interface RsaOtherPrimesInfo { + d?: string; + r?: string; + t?: string; } interface SyncEventInit extends ExtendableEventInit { - tag: string; lastChance?: boolean; + tag: string; } -interface EventListener { - (evt: Event): void; -} - -interface WebKitEntriesCallback { - (evt: Event): void; -} - -interface WebKitErrorCallback { - (evt: Event): void; -} - -interface WebKitFileCallback { - (evt: Event): void; -} - -interface AudioBuffer { - readonly duration: number; - readonly length: number; - readonly numberOfChannels: number; - readonly sampleRate: number; - copyFromChannel(destination: Float32Array, channelNumber: number, startInChannel?: number): void; - copyToChannel(source: Float32Array, channelNumber: number, startInChannel?: number): void; - getChannelData(channel: number): Float32Array; +interface WorkerOptions { + credentials?: RequestCredentials; + name?: string; + type?: WorkerType; } -declare var AudioBuffer: { - prototype: AudioBuffer; - new(): AudioBuffer; -}; +type EventListener = (event: Event) => void | { handleEvent(event: Event): void; }; interface Blob { readonly size: number; readonly type: string; - msClose(): void; - msDetachStream(): any; slice(start?: number, end?: number, contentType?: string): Blob; } @@ -171,12 +296,32 @@ declare var Blob: { new (blobParts?: any[], options?: BlobPropertyBag): Blob; }; +interface BroadcastChannelEventMap { + "message": MessageEvent; + "messageerror": MessageEvent; +} + +interface BroadcastChannel extends EventTarget { + readonly name: string; + onmessage: (this: BroadcastChannel, ev: MessageEvent) => any; + onmessageerror: (this: BroadcastChannel, ev: MessageEvent) => any; + close(): void; + postMessage(message: any): void; + addEventListener(type: K, listener: (this: BroadcastChannel, ev: BroadcastChannelEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; +} + +declare var BroadcastChannel: { + prototype: BroadcastChannel; + new(name: string): BroadcastChannel; +}; + interface Cache { add(request: RequestInfo): Promise; addAll(requests: RequestInfo[]): Promise; delete(request: RequestInfo, options?: CacheQueryOptions): Promise; keys(request?: RequestInfo, options?: CacheQueryOptions): Promise; - match(request: RequestInfo, options?: CacheQueryOptions): Promise; + match(request: RequestInfo, options?: CacheQueryOptions): Promise; matchAll(request?: RequestInfo, options?: CacheQueryOptions): Promise; put(request: RequestInfo, response: Response): Promise; } @@ -199,68 +344,75 @@ declare var CacheStorage: { new(): CacheStorage; }; +interface CanvasGradient { + addColorStop(offset: number, color: string): void; +} + +declare var CanvasGradient: { + prototype: CanvasGradient; + new(): CanvasGradient; +}; + +interface CanvasPattern { + setTransform(transform?: DOMMatrixInit): void; +} + +declare var CanvasPattern: { + prototype: CanvasPattern; + new(): CanvasPattern; +}; + +interface Client { + readonly id: string; + readonly reserved: boolean; + readonly type: ClientType; + readonly url: string; + postMessage(message: any, transfer?: any[]): void; +} + +declare var Client: { + prototype: Client; + new(): Client; +}; + +interface Clients { + claim(): Promise; + get(id: string): Promise; + matchAll(options?: ClientQueryOptions): Promise; + openWindow(url: string): Promise; +} + +declare var Clients: { + prototype: Clients; + new(): Clients; +}; + interface CloseEvent extends Event { readonly code: number; readonly reason: string; readonly wasClean: boolean; - initCloseEvent(typeArg: string, canBubbleArg: boolean, cancelableArg: boolean, wasCleanArg: boolean, codeArg: number, reasonArg: string): void; } declare var CloseEvent: { prototype: CloseEvent; - new(typeArg: string, eventInitDict?: CloseEventInit): CloseEvent; -}; - -interface Console { - assert(test?: boolean, message?: string, ...optionalParams: any[]): void; - clear(): void; - count(countTitle?: string): void; - debug(message?: any, ...optionalParams: any[]): void; - dir(value?: any, ...optionalParams: any[]): void; - dirxml(value: any): void; - error(message?: any, ...optionalParams: any[]): void; - exception(message?: string, ...optionalParams: any[]): void; - group(groupTitle?: string, ...optionalParams: any[]): void; - groupCollapsed(groupTitle?: string, ...optionalParams: any[]): void; - groupEnd(): void; - info(message?: any, ...optionalParams: any[]): void; - log(message?: any, ...optionalParams: any[]): void; - msIsIndependentlyComposed(element: any): boolean; - profile(reportName?: string): void; - profileEnd(): void; - select(element: any): void; - table(...data: any[]): void; - time(timerName?: string): void; - timeEnd(timerName?: string): void; - trace(message?: any, ...optionalParams: any[]): void; - warn(message?: any, ...optionalParams: any[]): void; -} - -declare var Console: { - prototype: Console; - new(): Console; -}; - -interface Coordinates { - readonly accuracy: number; - readonly altitude: number | null; - readonly altitudeAccuracy: number | null; - readonly heading: number | null; - readonly latitude: number; - readonly longitude: number; - readonly speed: number | null; -} - -declare var Coordinates: { - prototype: Coordinates; - new(): Coordinates; + new(type: string, eventInitDict?: CloseEventInit): CloseEvent; +}; + +interface Crypto { + readonly subtle: SubtleCrypto; + getRandomValues(array: ArrayBufferView): ArrayBufferView; +} + +declare var Crypto: { + prototype: Crypto; + new(): Crypto; }; interface CryptoKey { - readonly algorithm: KeyAlgorithm; + readonly algorithm: any; readonly extractable: boolean; - readonly type: string; - readonly usages: string[]; + readonly type: KeyType; + readonly usages: any; } declare var CryptoKey: { @@ -268,85 +420,205 @@ declare var CryptoKey: { new(): CryptoKey; }; -interface DOMError { - readonly name: string; - toString(): string; +interface CustomEvent extends Event { + readonly detail: any; + initCustomEvent(type: string, bubbles?: boolean, cancelable?: boolean, detail?: any): void; } -declare var DOMError: { - prototype: DOMError; - new(): DOMError; +declare var CustomEvent: { + prototype: CustomEvent; + new(type: string, eventInitDict?: CustomEventInit): CustomEvent; }; -interface DOMException { - readonly code: number; - readonly message: string; +interface DedicatedWorkerGlobalScopeEventMap extends WorkerGlobalScopeEventMap { + "message": MessageEvent; + "messageerror": MessageEvent; +} + +interface DedicatedWorkerGlobalScope extends WorkerGlobalScope { readonly name: string; - toString(): string; - readonly ABORT_ERR: number; - readonly DATA_CLONE_ERR: number; - readonly DOMSTRING_SIZE_ERR: number; - readonly HIERARCHY_REQUEST_ERR: number; - readonly INDEX_SIZE_ERR: number; - readonly INUSE_ATTRIBUTE_ERR: number; - readonly INVALID_ACCESS_ERR: number; - readonly INVALID_CHARACTER_ERR: number; - readonly INVALID_MODIFICATION_ERR: number; - readonly INVALID_NODE_TYPE_ERR: number; - readonly INVALID_STATE_ERR: number; - readonly NAMESPACE_ERR: number; - readonly NETWORK_ERR: number; - readonly NO_DATA_ALLOWED_ERR: number; - readonly NO_MODIFICATION_ALLOWED_ERR: number; - readonly NOT_FOUND_ERR: number; - readonly NOT_SUPPORTED_ERR: number; - readonly PARSE_ERR: number; - readonly QUOTA_EXCEEDED_ERR: number; - readonly SECURITY_ERR: number; - readonly SERIALIZE_ERR: number; - readonly SYNTAX_ERR: number; - readonly TIMEOUT_ERR: number; - readonly TYPE_MISMATCH_ERR: number; - readonly URL_MISMATCH_ERR: number; - readonly VALIDATION_ERR: number; - readonly WRONG_DOCUMENT_ERR: number; + onmessage: (this: DedicatedWorkerGlobalScope, ev: MessageEvent) => any; + onmessageerror: (this: DedicatedWorkerGlobalScope, ev: MessageEvent) => any; + close(): void; + postMessage(message: any, transfer?: any[]): void; + addEventListener(type: K, listener: (this: DedicatedWorkerGlobalScope, ev: DedicatedWorkerGlobalScopeEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } -declare var DOMException: { - prototype: DOMException; - new(message?: string, name?: string): DOMException; - readonly ABORT_ERR: number; - readonly DATA_CLONE_ERR: number; - readonly DOMSTRING_SIZE_ERR: number; - readonly HIERARCHY_REQUEST_ERR: number; - readonly INDEX_SIZE_ERR: number; - readonly INUSE_ATTRIBUTE_ERR: number; - readonly INVALID_ACCESS_ERR: number; - readonly INVALID_CHARACTER_ERR: number; - readonly INVALID_MODIFICATION_ERR: number; - readonly INVALID_NODE_TYPE_ERR: number; - readonly INVALID_STATE_ERR: number; - readonly NAMESPACE_ERR: number; - readonly NETWORK_ERR: number; - readonly NO_DATA_ALLOWED_ERR: number; - readonly NO_MODIFICATION_ALLOWED_ERR: number; - readonly NOT_FOUND_ERR: number; - readonly NOT_SUPPORTED_ERR: number; - readonly PARSE_ERR: number; - readonly QUOTA_EXCEEDED_ERR: number; - readonly SECURITY_ERR: number; - readonly SERIALIZE_ERR: number; - readonly SYNTAX_ERR: number; - readonly TIMEOUT_ERR: number; - readonly TYPE_MISMATCH_ERR: number; - readonly URL_MISMATCH_ERR: number; - readonly VALIDATION_ERR: number; - readonly WRONG_DOCUMENT_ERR: number; +declare var DedicatedWorkerGlobalScope: { + prototype: DedicatedWorkerGlobalScope; + new(): DedicatedWorkerGlobalScope; +}; + +interface DOMMatrix extends DOMMatrixReadOnly { + a: number; + b: number; + c: number; + d: number; + e: number; + f: number; + m11: number; + m12: number; + m13: number; + m14: number; + m21: number; + m22: number; + m23: number; + m24: number; + m31: number; + m32: number; + m33: number; + m34: number; + m41: number; + m42: number; + m43: number; + m44: number; + invertSelf(): DOMMatrix; + multiplySelf(other?: DOMMatrixInit): DOMMatrix; + preMultiplySelf(other?: DOMMatrixInit): DOMMatrix; + rotateAxisAngleSelf(x?: number, y?: number, z?: number, angle?: number): DOMMatrix; + rotateFromVectorSelf(x?: number, y?: number): DOMMatrix; + rotateSelf(rotX?: number, rotY?: number, rotZ?: number): DOMMatrix; + scale3dSelf(scale?: number, originX?: number, originY?: number, originZ?: number): DOMMatrix; + scaleSelf(scaleX?: number, scaleY?: number, scaleZ?: number, originX?: number, originY?: number, originZ?: number): DOMMatrix; + skewXSelf(sx?: number): DOMMatrix; + skewYSelf(sy?: number): DOMMatrix; + translateSelf(tx?: number, ty?: number, tz?: number): DOMMatrix; +} + +declare var DOMMatrix: { + prototype: DOMMatrix; + new(init?: string | number[]): DOMMatrix; + fromFloat32Array(array32: Float32Array): DOMMatrix; + fromFloat64Array(array64: Float64Array): DOMMatrix; + fromMatrix(other?: DOMMatrixInit): DOMMatrix; +}; + +interface DOMMatrixReadOnly { + readonly a: number; + readonly b: number; + readonly c: number; + readonly d: number; + readonly e: number; + readonly f: number; + readonly is2D: boolean; + readonly isIdentity: boolean; + readonly m11: number; + readonly m12: number; + readonly m13: number; + readonly m14: number; + readonly m21: number; + readonly m22: number; + readonly m23: number; + readonly m24: number; + readonly m31: number; + readonly m32: number; + readonly m33: number; + readonly m34: number; + readonly m41: number; + readonly m42: number; + readonly m43: number; + readonly m44: number; + flipX(): DOMMatrix; + flipY(): DOMMatrix; + inverse(): DOMMatrix; + multiply(other?: DOMMatrixInit): DOMMatrix; + rotate(rotX?: number, rotY?: number, rotZ?: number): DOMMatrix; + rotateAxisAngle(x?: number, y?: number, z?: number, angle?: number): DOMMatrix; + rotateFromVector(x?: number, y?: number): DOMMatrix; + scale(scaleX?: number, scaleY?: number, scaleZ?: number, originX?: number, originY?: number, originZ?: number): DOMMatrix; + scale3d(scale?: number, originX?: number, originY?: number, originZ?: number): DOMMatrix; + skewX(sx?: number): DOMMatrix; + skewY(sy?: number): DOMMatrix; + toFloat32Array(): Float32Array; + toFloat64Array(): Float64Array; + transformPoint(point?: DOMPointInit): DOMPoint; + translate(tx?: number, ty?: number, tz?: number): DOMMatrix; +} + +declare var DOMMatrixReadOnly: { + prototype: DOMMatrixReadOnly; + new(init?: string | number[]): DOMMatrixReadOnly; + fromFloat32Array(array32: Float32Array): DOMMatrixReadOnly; + fromFloat64Array(array64: Float64Array): DOMMatrixReadOnly; + fromMatrix(other?: DOMMatrixInit): DOMMatrixReadOnly; +}; + +interface DOMPoint extends DOMPointReadOnly { + w: number; + x: number; + y: number; + z: number; +} + +declare var DOMPoint: { + prototype: DOMPoint; + new(x?: number, y?: number, z?: number, w?: number): DOMPoint; + fromPoint(other?: DOMPointInit): DOMPoint; +}; + +interface DOMPointReadOnly { + readonly w: number; + readonly x: number; + readonly y: number; + readonly z: number; + matrixTransform(matrix?: DOMMatrixInit): DOMPoint; +} + +declare var DOMPointReadOnly: { + prototype: DOMPointReadOnly; + new(x?: number, y?: number, z?: number, w?: number): DOMPointReadOnly; + fromPoint(other?: DOMPointInit): DOMPointReadOnly; +}; + +interface DOMQuad { + readonly p1: DOMPoint; + readonly p2: DOMPoint; + readonly p3: DOMPoint; + readonly p4: DOMPoint; + getBounds(): DOMRect; +} + +declare var DOMQuad: { + prototype: DOMQuad; + new(p1?: DOMPointInit, p2?: DOMPointInit, p3?: DOMPointInit, p4?: DOMPointInit): DOMQuad; + fromQuad(other?: DOMQuadInit): DOMQuad; + fromRect(other?: DOMRectInit): DOMQuad; +}; + +interface DOMRect extends DOMRectReadOnly { + height: number; + width: number; + x: number; + y: number; +} + +declare var DOMRect: { + prototype: DOMRect; + new(x?: number, y?: number, width?: number, height?: number): DOMRect; + fromRect(other?: DOMRectInit): DOMRect; +}; + +interface DOMRectReadOnly { + readonly bottom: number; + readonly height: number; + readonly left: number; + readonly right: number; + readonly top: number; + readonly width: number; + readonly x: number; + readonly y: number; +} + +declare var DOMRectReadOnly: { + prototype: DOMRectReadOnly; + new(x?: number, y?: number, width?: number, height?: number): DOMRectReadOnly; + fromRect(other?: DOMRectInit): DOMRectReadOnly; }; interface DOMStringList { readonly length: number; - contains(str: string): boolean; + contains(string: string): boolean; item(index: number): string | null; [index: number]: string; } @@ -362,7 +634,6 @@ interface ErrorEvent extends Event { readonly filename: string; readonly lineno: number; readonly message: string; - initErrorEvent(typeArg: string, canBubbleArg: boolean, cancelableArg: boolean, messageArg: string, filenameArg: string, linenoArg: number): void; } declare var ErrorEvent: { @@ -374,17 +645,17 @@ interface Event { readonly bubbles: boolean; readonly cancelable: boolean; cancelBubble: boolean; - readonly currentTarget: EventTarget; + readonly composed: boolean; + readonly currentTarget: EventTarget | null; readonly defaultPrevented: boolean; readonly eventPhase: number; readonly isTrusted: boolean; - returnValue: boolean; - readonly srcElement: any; - readonly target: EventTarget; + readonly target: EventTarget | null; readonly timeStamp: number; readonly type: string; readonly scoped: boolean; - initEvent(eventTypeArg: string, canBubbleArg: boolean, cancelableArg: boolean): void; + composedPath(): EventTarget[]; + initEvent(type: string, bubbles?: boolean, cancelable?: boolean): void; preventDefault(): void; stopImmediatePropagation(): void; stopPropagation(): void; @@ -392,20 +663,51 @@ interface Event { readonly AT_TARGET: number; readonly BUBBLING_PHASE: number; readonly CAPTURING_PHASE: number; + readonly NONE: number; } declare var Event: { prototype: Event; - new(typeArg: string, eventInitDict?: EventInit): Event; + new(type: string, eventInitDict?: EventInit): Event; readonly AT_TARGET: number; readonly BUBBLING_PHASE: number; readonly CAPTURING_PHASE: number; + readonly NONE: number; }; -interface EventTarget { - addEventListener(type: string, listener?: EventListenerOrEventListenerObject, options?: boolean | AddEventListenerOptions): void; - dispatchEvent(evt: Event): boolean; - removeEventListener(type: string, listener?: EventListenerOrEventListenerObject, options?: boolean | EventListenerOptions): void; +interface EventSourceEventMap { + "error": Event; + "message": MessageEvent; + "open": Event; +} + +interface EventSource extends EventTarget { + onerror: (this: EventSource, ev: Event) => any; + onmessage: (this: EventSource, ev: MessageEvent) => any; + onopen: (this: EventSource, ev: Event) => any; + readonly readyState: number; + readonly url: string; + readonly withCredentials: boolean; + close(): void; + readonly CLOSED: number; + readonly CONNECTING: number; + readonly OPEN: number; + addEventListener(type: K, listener: (this: EventSource, ev: EventSourceEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; +} + +declare var EventSource: { + prototype: EventSource; + new(url: string, eventSourceInitDict?: EventSourceInit): EventSource; + readonly CLOSED: number; + readonly CONNECTING: number; + readonly OPEN: number; +}; + +interface EventTarget { + addEventListener(type: string, callback: EventListener | null, options?: AddEventListenerOptions | boolean): void; + dispatchEvent(event: Event): boolean; + removeEventListener(type: string, callback: EventListener | null, options?: EventListenerOptions | boolean): void; } declare var EventTarget: { @@ -413,10 +715,45 @@ declare var EventTarget: { new(): EventTarget; }; +interface ExtendableEvent extends Event { + waitUntil(f: Promise): void; +} + +declare var ExtendableEvent: { + prototype: ExtendableEvent; + new(type: string, eventInitDict?: ExtendableEventInit): ExtendableEvent; +}; + +interface ExtendableMessageEvent extends ExtendableEvent { + readonly data: any; + readonly lastEventId: string; + readonly origin: string; + readonly ports: ReadonlyArray; + readonly source: Client | ServiceWorker | MessagePort | null; +} + +declare var ExtendableMessageEvent: { + prototype: ExtendableMessageEvent; + new(type: string, eventInitDict?: ExtendableMessageEventInit): ExtendableMessageEvent; +}; + +interface FetchEvent extends ExtendableEvent { + readonly clientId: string; + readonly preloadResponse: Promise; + readonly request: Request; + readonly reservedClientId: string; + readonly targetClientId: string; + respondWith(r: Promise): void; +} + +declare var FetchEvent: { + prototype: FetchEvent; + new(type: string, eventInitDict: FetchEventInit): FetchEvent; +}; + interface File extends Blob { - readonly lastModifiedDate: any; + readonly lastModified: number; readonly name: string; - readonly webkitRelativePath: string; } declare var File: { @@ -426,7 +763,7 @@ declare var File: { interface FileList { readonly length: number; - item(index: number): File; + item(index: number): File | null; [index: number]: File; } @@ -435,34 +772,87 @@ declare var FileList: { new(): FileList; }; -interface FileReader extends EventTarget, MSBaseReader { - readonly error: DOMError; +interface FileReaderEventMap { + "abort": ProgressEvent; + "error": ProgressEvent; + "load": ProgressEvent; + "loadend": ProgressEvent; + "loadstart": ProgressEvent; + "progress": ProgressEvent; +} + +interface FileReader extends EventTarget { + readonly error: DOMException | null; + onabort: (this: FileReader, ev: ProgressEvent) => any; + onerror: (this: FileReader, ev: ProgressEvent) => any; + onload: (this: FileReader, ev: ProgressEvent) => any; + onloadend: (this: FileReader, ev: ProgressEvent) => any; + onloadstart: (this: FileReader, ev: ProgressEvent) => any; + onprogress: (this: FileReader, ev: ProgressEvent) => any; + readonly readyState: number; + readonly result: string | ArrayBuffer | null; + abort(): void; readAsArrayBuffer(blob: Blob): void; readAsBinaryString(blob: Blob): void; readAsDataURL(blob: Blob): void; - readAsText(blob: Blob, encoding?: string): void; - addEventListener(type: K, listener: (this: FileReader, ev: MSBaseReaderEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + readAsText(blob: Blob, label?: string): void; + readonly DONE: number; + readonly EMPTY: number; + readonly LOADING: number; + addEventListener(type: K, listener: (this: FileReader, ev: FileReaderEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var FileReader: { prototype: FileReader; new(): FileReader; + readonly DONE: number; + readonly EMPTY: number; + readonly LOADING: number; +}; + +interface FileReaderSync { + readAsArrayBuffer(blob: Blob): ArrayBuffer; + readAsBinaryString(blob: Blob): string; + readAsDataURL(blob: Blob): string; + readAsText(blob: Blob, label?: string): string; +} + +declare var FileReaderSync: { + prototype: FileReaderSync; + new(): FileReaderSync; +}; + +interface ForeignFetchEvent extends ExtendableEvent { + readonly origin: string; + readonly request: Request; + respondWith(r: Promise): void; +} + +declare var ForeignFetchEvent: { + prototype: ForeignFetchEvent; + new(type: string, eventInitDict: ForeignFetchEventInit): ForeignFetchEvent; }; interface FormData { - append(name: string, value: string | Blob, fileName?: string): void; + append(name: string, value: string): void; + append(name: string, blobValue: Blob, filename?: string): void; + delete(name: string): void; + get(name: string): FormDataEntryValue | null; + getAll(name: string): FormDataEntryValue[]; + has(name: string): boolean; + set(name: string, value: string): void; + set(name: string, blobValue: Blob, filename?: string): void; } declare var FormData: { prototype: FormData; - new(): FormData; + new(form?: never): FormData; }; interface Headers { append(name: string, value: string): void; delete(name: string): void; - forEach(callback: ForEachCallback): void; get(name: string): string | null; has(name: string): boolean; set(name: string, value: string): void; @@ -470,7 +860,7 @@ interface Headers { declare var Headers: { prototype: Headers; - new(init?: Headers | string[][] | object): Headers; + new(init?: HeadersInit): Headers; }; interface IDBCursor { @@ -480,21 +870,14 @@ interface IDBCursor { source: IDBObjectStore | IDBIndex; advance(count: number): void; continue(key?: IDBKeyRange | IDBValidKey): void; + continuePrimaryKey(key: any, primaryKey: any): void; delete(): IDBRequest; update(value: any): IDBRequest; - readonly NEXT: string; - readonly NEXT_NO_DUPLICATE: string; - readonly PREV: string; - readonly PREV_NO_DUPLICATE: string; } declare var IDBCursor: { prototype: IDBCursor; new(): IDBCursor; - readonly NEXT: string; - readonly NEXT_NO_DUPLICATE: string; - readonly PREV: string; - readonly PREV_NO_DUPLICATE: string; }; interface IDBCursorWithValue extends IDBCursor { @@ -508,23 +891,26 @@ declare var IDBCursorWithValue: { interface IDBDatabaseEventMap { "abort": Event; + "close": Event; "error": Event; + "versionchange": IDBVersionChangeEvent; } interface IDBDatabase extends EventTarget { readonly name: string; readonly objectStoreNames: DOMStringList; onabort: (this: IDBDatabase, ev: Event) => any; + onclose: (this: IDBDatabase, ev: Event) => any; onerror: (this: IDBDatabase, ev: Event) => any; + onversionchange: (this: IDBDatabase, ev: IDBVersionChangeEvent) => any; version: number; - onversionchange: (ev: IDBVersionChangeEvent) => any; close(): void; createObjectStore(name: string, optionalParameters?: IDBObjectStoreParameters): IDBObjectStore; deleteObjectStore(name: string): void; transaction(storeNames: string | string[], mode?: IDBTransactionMode): IDBTransaction; addEventListener(type: "versionchange", listener: (ev: IDBVersionChangeEvent) => any, useCapture?: boolean): void; addEventListener(type: K, listener: (this: IDBDatabase, ev: IDBDatabaseEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var IDBDatabase: { @@ -545,12 +931,14 @@ declare var IDBFactory: { interface IDBIndex { keyPath: string | string[]; - readonly name: string; + readonly multiEntry: boolean; + name: string; readonly objectStore: IDBObjectStore; readonly unique: boolean; - multiEntry: boolean; count(key?: IDBKeyRange | IDBValidKey): IDBRequest; get(key: IDBKeyRange | IDBValidKey): IDBRequest; + getAll(query?: any, count?: number): IDBRequest; + getAllKeys(query?: any, count?: number): IDBRequest; getKey(key: IDBKeyRange | IDBValidKey): IDBRequest; openCursor(range?: IDBKeyRange | IDBValidKey, direction?: IDBCursorDirection): IDBRequest; openKeyCursor(range?: IDBKeyRange | IDBValidKey, direction?: IDBCursorDirection): IDBRequest; @@ -566,6 +954,7 @@ interface IDBKeyRange { readonly lowerOpen: boolean; readonly upper: any; readonly upperOpen: boolean; + includes(key: any): boolean; } declare var IDBKeyRange: { @@ -578,20 +967,24 @@ declare var IDBKeyRange: { }; interface IDBObjectStore { + readonly autoIncrement: boolean; readonly indexNames: DOMStringList; keyPath: string | string[]; - readonly name: string; + name: string; readonly transaction: IDBTransaction; - autoIncrement: boolean; add(value: any, key?: IDBKeyRange | IDBValidKey): IDBRequest; clear(): IDBRequest; count(key?: IDBKeyRange | IDBValidKey): IDBRequest; createIndex(name: string, keyPath: string | string[], optionalParameters?: IDBIndexParameters): IDBIndex; delete(key: IDBKeyRange | IDBValidKey): IDBRequest; - deleteIndex(indexName: string): void; - get(key: any): IDBRequest; + deleteIndex(name: string): void; + get(query: any): IDBRequest; + getAll(query?: any, count?: number): IDBRequest; + getAllKeys(query?: any, count?: number): IDBRequest; + getKey(query: any): IDBRequest; index(name: string): IDBIndex; openCursor(range?: IDBKeyRange | IDBValidKey, direction?: IDBCursorDirection): IDBRequest; + openKeyCursor(query?: any, direction?: IDBCursorDirection): IDBRequest; put(value: any, key?: IDBKeyRange | IDBValidKey): IDBRequest; } @@ -609,7 +1002,7 @@ interface IDBOpenDBRequest extends IDBRequest { onblocked: (this: IDBOpenDBRequest, ev: Event) => any; onupgradeneeded: (this: IDBOpenDBRequest, ev: IDBVersionChangeEvent) => any; addEventListener(type: K, listener: (this: IDBOpenDBRequest, ev: IDBOpenDBRequestEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var IDBOpenDBRequest: { @@ -629,9 +1022,9 @@ interface IDBRequest extends EventTarget { readonly readyState: IDBRequestReadyState; readonly result: any; source: IDBObjectStore | IDBIndex | IDBCursor; - readonly transaction: IDBTransaction; + readonly transaction: IDBTransaction | null; addEventListener(type: K, listener: (this: IDBRequest, ev: IDBRequestEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var IDBRequest: { @@ -649,24 +1042,19 @@ interface IDBTransaction extends EventTarget { readonly db: IDBDatabase; readonly error: DOMException; readonly mode: IDBTransactionMode; + readonly objectStoreNames: DOMStringList; onabort: (this: IDBTransaction, ev: Event) => any; oncomplete: (this: IDBTransaction, ev: Event) => any; onerror: (this: IDBTransaction, ev: Event) => any; abort(): void; objectStore(name: string): IDBObjectStore; - readonly READ_ONLY: string; - readonly READ_WRITE: string; - readonly VERSION_CHANGE: string; addEventListener(type: K, listener: (this: IDBTransaction, ev: IDBTransactionEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var IDBTransaction: { prototype: IDBTransaction; new(): IDBTransaction; - readonly READ_ONLY: string; - readonly READ_WRITE: string; - readonly VERSION_CHANGE: string; }; interface IDBVersionChangeEvent extends Event { @@ -676,7 +1064,18 @@ interface IDBVersionChangeEvent extends Event { declare var IDBVersionChangeEvent: { prototype: IDBVersionChangeEvent; - new(): IDBVersionChangeEvent; + new(type: string, eventInitDict?: IDBVersionChangeEventInit): IDBVersionChangeEvent; +}; + +interface ImageBitmap { + readonly height: number; + readonly width: number; + close(): void; +} + +declare var ImageBitmap: { + prototype: ImageBitmap; + new(): ImageBitmap; }; interface ImageData { @@ -691,6 +1090,15 @@ declare var ImageData: { new(array: Uint8ClampedArray, width: number, height: number): ImageData; }; +interface InstallEvent extends ExtendableEvent { + registerForeignFetch(options: ForeignFetchOptions): void; +} + +declare var InstallEvent: { + prototype: InstallEvent; + new(type: string, eventInitDict?: ExtendableEventInit): InstallEvent; +}; + interface MessageChannel { readonly port1: MessagePort; readonly port2: MessagePort; @@ -703,10 +1111,11 @@ declare var MessageChannel: { interface MessageEvent extends Event { readonly data: any; + readonly lastEventId: string; readonly origin: string; - readonly ports: any; - readonly source: any; - initMessageEvent(typeArg: string, canBubbleArg: boolean, cancelableArg: boolean, dataArg: any, originArg: string, lastEventIdArg: string, sourceArg: any): void; + readonly ports: ReadonlyArray; + readonly source: MessageEventSource | null; + initMessageEvent(type: string, bubbles?: boolean, cancelable?: boolean, data?: any, origin?: string, lastEventId?: string, source?: MessageEventSource, ports?: MessagePort[]): void; } declare var MessageEvent: { @@ -716,15 +1125,17 @@ declare var MessageEvent: { interface MessagePortEventMap { "message": MessageEvent; + "messageerror": MessageEvent; } interface MessagePort extends EventTarget { onmessage: (this: MessagePort, ev: MessageEvent) => any; + onmessageerror: (this: MessagePort, ev: MessageEvent) => any; close(): void; - postMessage(message?: any, transfer?: any[]): void; + postMessage(message: any, transfer?: any[]): void; start(): void; addEventListener(type: K, listener: (this: MessagePort, ev: MessagePortEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var MessagePort: { @@ -732,52 +1143,117 @@ declare var MessagePort: { new(): MessagePort; }; +interface NavigationPreloadManager { + disable(): Promise; + enable(): Promise; + getState(): Promise; + setHeaderValue(value: string): Promise; +} + +declare var NavigationPreloadManager: { + prototype: NavigationPreloadManager; + new(): NavigationPreloadManager; +}; + interface NotificationEventMap { "click": Event; - "close": Event; "error": Event; - "show": Event; } interface Notification extends EventTarget { + readonly actions: ReadonlyArray; + readonly badge: string; readonly body: string; + readonly data: any; readonly dir: NotificationDirection; readonly icon: string; + readonly image: string; readonly lang: string; + readonly maxActions: number; onclick: (this: Notification, ev: Event) => any; - onclose: (this: Notification, ev: Event) => any; onerror: (this: Notification, ev: Event) => any; - onshow: (this: Notification, ev: Event) => any; readonly permission: NotificationPermission; + readonly renotify: boolean; + readonly requireInteraction: boolean; + readonly silent: boolean; + readonly sound: string; readonly tag: string; + readonly timestamp: number; readonly title: string; + readonly vibrate: ReadonlyArray; close(): void; addEventListener(type: K, listener: (this: Notification, ev: NotificationEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var Notification: { prototype: Notification; new(title: string, options?: NotificationOptions): Notification; - requestPermission(callback?: NotificationPermissionCallback): Promise; }; -interface Performance { - readonly navigation: PerformanceNavigation; - readonly timing: PerformanceTiming; +interface NotificationEvent extends ExtendableEvent { + readonly action: string; + readonly notification: Notification; +} + +declare var NotificationEvent: { + prototype: NotificationEvent; + new(type: string, eventInitDict: NotificationEventInit): NotificationEvent; +}; + +interface OffscreenCanvas extends EventTarget { + height: number; + width: number; + convertToBlob(options?: ImageEncodeOptions): Promise; + getContext(contextType: OffscreenRenderingContextType, ...arguments: any[]): OffscreenRenderingContext | null; + transferToImageBitmap(): ImageBitmap; +} + +declare var OffscreenCanvas: { + prototype: OffscreenCanvas; + new(width: number, height: number): OffscreenCanvas; +}; + +interface OffscreenCanvasRenderingContext2D extends CanvasState, CanvasTransform, CanvasCompositing, CanvasImageSmoothing, CanvasFillStrokeStyles, CanvasShadowStyles, CanvasFilters, CanvasRect, CanvasDrawPath, CanvasDrawImage, CanvasImageData, CanvasPathDrawingStyles, CanvasPath { + readonly canvas: OffscreenCanvas; + commit(): void; +} + +declare var OffscreenCanvasRenderingContext2D: { + prototype: OffscreenCanvasRenderingContext2D; + new(): OffscreenCanvasRenderingContext2D; +}; + +interface Path2D extends CanvasPath { + addPath(path: Path2D, transform?: DOMMatrixInit): void; +} + +declare var Path2D: { + prototype: Path2D; + new(): Path2D; + new(path: Path2D): Path2D; + new(paths: Path2D[], fillRule?: CanvasFillRule): Path2D; + new(d: string): Path2D; +}; + +interface PerformanceEventMap { + "resourcetimingbufferfull": Event; +} + +interface Performance extends EventTarget { + onresourcetimingbufferfull: (this: Performance, ev: Event) => any; clearMarks(markName?: string): void; clearMeasures(measureName?: string): void; clearResourceTimings(): void; - getEntries(): any; - getEntriesByName(name: string, entryType?: string): any; - getEntriesByType(entryType: string): any; - getMarks(markName?: string): any; - getMeasures(measureName?: string): any; + getEntries(): PerformanceEntryList; + getEntriesByName(name: string, type?: string): PerformanceEntryList; + getEntriesByType(type: string): PerformanceEntryList; mark(markName: string): void; - measure(measureName: string, startMarkName?: string, endMarkName?: string): void; + measure(measureName: string, startMark?: string, endMark?: string): void; now(): number; setResourceTimingBufferSize(maxSize: number): void; - toJSON(): any; + addEventListener(type: K, listener: (this: Performance, ev: PerformanceEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var Performance: { @@ -785,88 +1261,43 @@ declare var Performance: { new(): Performance; }; -interface PerformanceNavigation { - readonly redirectCount: number; - readonly type: number; - toJSON(): any; - readonly TYPE_BACK_FORWARD: number; - readonly TYPE_NAVIGATE: number; - readonly TYPE_RELOAD: number; - readonly TYPE_RESERVED: number; -} - -declare var PerformanceNavigation: { - prototype: PerformanceNavigation; - new(): PerformanceNavigation; - readonly TYPE_BACK_FORWARD: number; - readonly TYPE_NAVIGATE: number; - readonly TYPE_RELOAD: number; - readonly TYPE_RESERVED: number; -}; - -interface PerformanceTiming { - readonly connectEnd: number; - readonly connectStart: number; - readonly domainLookupEnd: number; - readonly domainLookupStart: number; - readonly domComplete: number; - readonly domContentLoadedEventEnd: number; - readonly domContentLoadedEventStart: number; - readonly domInteractive: number; - readonly domLoading: number; - readonly fetchStart: number; - readonly loadEventEnd: number; - readonly loadEventStart: number; - readonly msFirstPaint: number; - readonly navigationStart: number; - readonly redirectEnd: number; - readonly redirectStart: number; - readonly requestStart: number; - readonly responseEnd: number; - readonly responseStart: number; - readonly unloadEventEnd: number; - readonly unloadEventStart: number; - readonly secureConnectionStart: number; - toJSON(): any; -} - -declare var PerformanceTiming: { - prototype: PerformanceTiming; - new(): PerformanceTiming; -}; - -interface Position { - readonly coords: Coordinates; - readonly timestamp: number; +interface PerformanceEntry { + readonly duration: number; + readonly entryType: string; + readonly name: string; + readonly startTime: number; } -declare var Position: { - prototype: Position; - new(): Position; +declare var PerformanceEntry: { + prototype: PerformanceEntry; + new(): PerformanceEntry; }; -interface PositionError { - readonly code: number; - readonly message: string; - toString(): string; - readonly PERMISSION_DENIED: number; - readonly POSITION_UNAVAILABLE: number; - readonly TIMEOUT: number; +interface PerformanceObserver { + disconnect(): void; + observe(options: PerformanceObserverInit): void; +} + +declare var PerformanceObserver: { + prototype: PerformanceObserver; + new(callback: PerformanceObserverCallback): PerformanceObserver; +}; + +interface PerformanceObserverEntryList { + getEntries(): PerformanceEntryList; + getEntriesByName(name: string, type?: string): PerformanceEntryList; + getEntriesByType(type: string): PerformanceEntryList; } -declare var PositionError: { - prototype: PositionError; - new(): PositionError; - readonly PERMISSION_DENIED: number; - readonly POSITION_UNAVAILABLE: number; - readonly TIMEOUT: number; +declare var PerformanceObserverEntryList: { + prototype: PerformanceObserverEntryList; + new(): PerformanceObserverEntryList; }; interface ProgressEvent extends Event { readonly lengthComputable: boolean; readonly loaded: number; readonly total: number; - initProgressEvent(typeArg: string, canBubbleArg: boolean, cancelableArg: boolean, lengthComputableArg: boolean, loadedArg: number, totalArg: number): void; } declare var ProgressEvent: { @@ -874,8 +1305,28 @@ declare var ProgressEvent: { new(type: string, eventInitDict?: ProgressEventInit): ProgressEvent; }; +interface PromiseRejectionEvent extends Event { + readonly promise: Promise; + readonly reason: any; +} + +declare var PromiseRejectionEvent: { + prototype: PromiseRejectionEvent; + new(type: string, eventInitDict: PromiseRejectionEventInit): PromiseRejectionEvent; +}; + +interface PushEvent extends ExtendableEvent { + readonly data: PushMessageData | null; +} + +declare var PushEvent: { + prototype: PushEvent; + new(type: string, eventInitDict?: PushEventInit): PushEvent; +}; + interface PushManager { - getSubscription(): Promise; + readonly supportedContentEncodings: ReadonlyArray; + getSubscription(): Promise; permissionState(options?: PushSubscriptionOptionsInit): Promise; subscribe(options?: PushSubscriptionOptionsInit): Promise; } @@ -885,11 +1336,23 @@ declare var PushManager: { new(): PushManager; }; +interface PushMessageData { + arrayBuffer(): ArrayBuffer; + blob(): Blob; + json(): any; + text(): string; +} + +declare var PushMessageData: { + prototype: PushMessageData; + new(): PushMessageData; +}; + interface PushSubscription { - readonly endpoint: USVString; + readonly endpoint: string; + readonly expirationTime: number | null; readonly options: PushSubscriptionOptions; getKey(name: PushEncryptionKeyName): ArrayBuffer | null; - toJSON(): any; unsubscribe(): Promise; } @@ -898,6 +1361,16 @@ declare var PushSubscription: { new(): PushSubscription; }; +interface PushSubscriptionChangeEvent extends ExtendableEvent { + readonly newSubscription: PushSubscription | null; + readonly oldSubscription: PushSubscription | null; +} + +declare var PushSubscriptionChangeEvent: { + prototype: PushSubscriptionChangeEvent; + new(type: string, eventInitDict?: PushSubscriptionChangeInit): PushSubscriptionChangeEvent; +}; + interface PushSubscriptionOptions { readonly applicationServerKey: ArrayBuffer | null; readonly userVisibleOnly: boolean; @@ -911,7 +1384,7 @@ declare var PushSubscriptionOptions: { interface ReadableStream { readonly locked: boolean; cancel(): Promise; - getReader(): ReadableStreamReader; + getReader(): ReadableStreamDefaultReader; } declare var ReadableStream: { @@ -919,18 +1392,19 @@ declare var ReadableStream: { new(): ReadableStream; }; -interface ReadableStreamReader { +interface ReadableStreamDefaultReader { + readonly closed: boolean; cancel(): Promise; read(): Promise; releaseLock(): void; } -declare var ReadableStreamReader: { - prototype: ReadableStreamReader; - new(): ReadableStreamReader; +declare var ReadableStreamDefaultReader: { + prototype: ReadableStreamDefaultReader; + new(stream: ReadableStream): ReadableStreamDefaultReader; }; -interface Request extends Object, Body { +interface Request extends Body { readonly cache: RequestCache; readonly credentials: RequestCredentials; readonly destination: RequestDestination; @@ -949,26 +1423,26 @@ interface Request extends Object, Body { declare var Request: { prototype: Request; - new(input: Request | string, init?: RequestInit): Request; + new(input: RequestInfo, init?: RequestInit): Request; }; -interface Response extends Object, Body { - readonly body: ReadableStream | null; +interface Response extends Body { readonly headers: Headers; readonly ok: boolean; + readonly redirected: boolean; readonly status: number; readonly statusText: string; + readonly trailer: Promise; readonly type: ResponseType; readonly url: string; - readonly redirected: boolean; clone(): Response; } declare var Response: { prototype: Response; - new(body?: any, init?: ResponseInit): Response; - error: () => Response; - redirect: (url: string, status?: number) => Response; + new(body?: BodyInit, init?: ResponseInit): Response; + error(): Response; + redirect(url: string, status?: number): Response; }; interface ServiceWorkerEventMap extends AbstractWorkerEventMap { @@ -977,11 +1451,11 @@ interface ServiceWorkerEventMap extends AbstractWorkerEventMap { interface ServiceWorker extends EventTarget, AbstractWorker { onstatechange: (this: ServiceWorker, ev: Event) => any; - readonly scriptURL: USVString; + readonly scriptURL: string; readonly state: ServiceWorkerState; postMessage(message: any, transfer?: any[]): void; addEventListener(type: K, listener: (this: ServiceWorker, ev: ServiceWorkerEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var ServiceWorker: { @@ -989,6 +1463,65 @@ declare var ServiceWorker: { new(): ServiceWorker; }; +interface ServiceWorkerContainerEventMap { + "controllerchange": Event; + "message": MessageEvent; +} + +interface ServiceWorkerContainer extends EventTarget { + readonly controller: ServiceWorker | null; + oncontrollerchange: (this: ServiceWorkerContainer, ev: Event) => any; + onmessage: (this: ServiceWorkerContainer, ev: MessageEvent) => any; + readonly ready: Promise; + getRegistration(clientURL?: string): Promise; + getRegistrations(): Promise; + register(scriptURL: string, options?: RegistrationOptions): Promise; + startMessages(): void; + addEventListener(type: K, listener: (this: ServiceWorkerContainer, ev: ServiceWorkerContainerEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; +} + +declare var ServiceWorkerContainer: { + prototype: ServiceWorkerContainer; + new(): ServiceWorkerContainer; +}; + +interface ServiceWorkerGlobalScopeEventMap extends WorkerGlobalScopeEventMap { + "activate": ExtendableEvent; + "fetch": FetchEvent; + "foreignfetch": FetchEvent; + "install": InstallEvent; + "message": ExtendableMessageEvent; + "notificationclick": NotificationEvent; + "notificationclose": NotificationEvent; + "push": PushEvent; + "pushsubscriptionchange": PushSubscriptionChangeEvent; + "sync": SyncEvent; +} + +interface ServiceWorkerGlobalScope extends WorkerGlobalScope { + readonly clients: Clients; + onactivate: (this: ServiceWorkerGlobalScope, ev: ExtendableEvent) => any; + onfetch: (this: ServiceWorkerGlobalScope, ev: FetchEvent) => any; + onforeignfetch: (this: ServiceWorkerGlobalScope, ev: FetchEvent) => any; + oninstall: (this: ServiceWorkerGlobalScope, ev: InstallEvent) => any; + onmessage: (this: ServiceWorkerGlobalScope, ev: ExtendableMessageEvent) => any; + onnotificationclick: (this: ServiceWorkerGlobalScope, ev: NotificationEvent) => any; + onnotificationclose: (this: ServiceWorkerGlobalScope, ev: NotificationEvent) => any; + onpush: (this: ServiceWorkerGlobalScope, ev: PushEvent) => any; + onpushsubscriptionchange: (this: ServiceWorkerGlobalScope, ev: PushSubscriptionChangeEvent) => any; + onsync: (this: ServiceWorkerGlobalScope, ev: SyncEvent) => any; + readonly registration: ServiceWorkerRegistration; + skipWaiting(): Promise; + addEventListener(type: K, listener: (this: ServiceWorkerGlobalScope, ev: ServiceWorkerGlobalScopeEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; +} + +declare var ServiceWorkerGlobalScope: { + prototype: ServiceWorkerGlobalScope; + new(): ServiceWorkerGlobalScope; +}; + interface ServiceWorkerRegistrationEventMap { "updatefound": Event; } @@ -996,17 +1529,19 @@ interface ServiceWorkerRegistrationEventMap { interface ServiceWorkerRegistration extends EventTarget { readonly active: ServiceWorker | null; readonly installing: ServiceWorker | null; + readonly navigationPreload: NavigationPreloadManager; onupdatefound: (this: ServiceWorkerRegistration, ev: Event) => any; readonly pushManager: PushManager; - readonly scope: USVString; + readonly scope: string; readonly sync: SyncManager; + readonly useCache: boolean; readonly waiting: ServiceWorker | null; getNotifications(filter?: GetNotificationOptions): Promise; showNotification(title: string, options?: NotificationOptions): Promise; unregister(): Promise; update(): Promise; addEventListener(type: K, listener: (this: ServiceWorkerRegistration, ev: ServiceWorkerRegistrationEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var ServiceWorkerRegistration: { @@ -1014,6 +1549,64 @@ declare var ServiceWorkerRegistration: { new(): ServiceWorkerRegistration; }; +interface SharedWorker extends EventTarget, AbstractWorker { + readonly port: MessagePort; + addEventListener(type: K, listener: (this: SharedWorker, ev: AbstractWorkerEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; +} + +declare var SharedWorker: { + prototype: SharedWorker; + new(scriptURL: string, options?: string | WorkerOptions): SharedWorker; +}; + +interface SharedWorkerGlobalScopeEventMap extends WorkerGlobalScopeEventMap { + "connect": MessageEvent; +} + +interface SharedWorkerGlobalScope extends WorkerGlobalScope { + readonly name: string; + onconnect: (this: SharedWorkerGlobalScope, ev: MessageEvent) => any; + close(): void; + addEventListener(type: K, listener: (this: SharedWorkerGlobalScope, ev: SharedWorkerGlobalScopeEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; +} + +declare var SharedWorkerGlobalScope: { + prototype: SharedWorkerGlobalScope; + new(): SharedWorkerGlobalScope; +}; + +interface SubtleCrypto { + decrypt(algorithm: AlgorithmIdentifier, key: CryptoKey, data: BufferSource): Promise; + deriveBits(algorithm: AlgorithmIdentifier, baseKey: CryptoKey, length: number): Promise; + deriveKey(algorithm: AlgorithmIdentifier, baseKey: CryptoKey, derivedKeyType: AlgorithmIdentifier, extractable: boolean, keyUsages: KeyUsage[]): Promise; + digest(algorithm: AlgorithmIdentifier, data: BufferSource): Promise; + encrypt(algorithm: AlgorithmIdentifier, key: CryptoKey, data: BufferSource): Promise; + exportKey(format: KeyFormat, key: CryptoKey): Promise; + generateKey(algorithm: AlgorithmIdentifier, extractable: boolean, keyUsages: KeyUsage[]): Promise; + importKey(format: KeyFormat, keyData: BufferSource | JsonWebKey, algorithm: AlgorithmIdentifier, extractable: boolean, keyUsages: KeyUsage[]): Promise; + sign(algorithm: AlgorithmIdentifier, key: CryptoKey, data: BufferSource): Promise; + unwrapKey(format: KeyFormat, wrappedKey: BufferSource, unwrappingKey: CryptoKey, unwrapAlgorithm: AlgorithmIdentifier, unwrappedKeyAlgorithm: AlgorithmIdentifier, extractable: boolean, keyUsages: KeyUsage[]): Promise; + verify(algorithm: AlgorithmIdentifier, key: CryptoKey, signature: BufferSource, data: BufferSource): Promise; + wrapKey(format: KeyFormat, key: CryptoKey, wrappingKey: CryptoKey, wrapAlgorithm: AlgorithmIdentifier): Promise; +} + +declare var SubtleCrypto: { + prototype: SubtleCrypto; + new(): SubtleCrypto; +}; + +interface SyncEvent extends ExtendableEvent { + readonly lastChance: boolean; + readonly tag: string; +} + +declare var SyncEvent: { + prototype: SyncEvent; + new(type: string, init: SyncEventInit): SyncEvent; +}; + interface SyncManager { getTags(): Promise; register(tag: string): Promise; @@ -1035,30 +1628,63 @@ interface URL { port: string; protocol: string; search: string; - username: string; readonly searchParams: URLSearchParams; - toString(): string; + username: string; + toJSON(): string; } declare var URL: { prototype: URL; new(url: string, base?: string): URL; - createObjectURL(object: any, options?: ObjectURLOptions): string; + createObjectURL(blob: Blob): string; revokeObjectURL(url: string): void; }; -interface WebSocketEventMap { - "close": CloseEvent; - "error": Event; - "message": MessageEvent; - "open": Event; -} - -interface WebSocket extends EventTarget { - binaryType: string; - readonly bufferedAmount: number; - readonly extensions: string; - onclose: (this: WebSocket, ev: CloseEvent) => any; +interface URLSearchParams { + /** + * Appends a specified key/value pair as a new search parameter. + */ + append(name: string, value: string): void; + /** + * Deletes the given search parameter, and its associated value, from the list of all search parameters. + */ + delete(name: string): void; + /** + * Returns the first value associated to the given search parameter. + */ + get(name: string): string | null; + /** + * Returns all the values association with a given search parameter. + */ + getAll(name: string): string[]; + /** + * Returns a Boolean indicating if such a search parameter exists. + */ + has(name: string): boolean; + /** + * Sets the value associated to a given search parameter to the given value. If there were several values, delete the others. + */ + set(name: string, value: string): void; + sort(): void; +} + +declare var URLSearchParams: { + prototype: URLSearchParams; + new(init?: string[][] | { [key: string]: string } | string): URLSearchParams; +}; + +interface WebSocketEventMap { + "close": CloseEvent; + "error": Event; + "message": MessageEvent; + "open": Event; +} + +interface WebSocket extends EventTarget { + binaryType: BinaryType; + readonly bufferedAmount: number; + readonly extensions: string; + onclose: (this: WebSocket, ev: CloseEvent) => any; onerror: (this: WebSocket, ev: Event) => any; onmessage: (this: WebSocket, ev: MessageEvent) => any; onopen: (this: WebSocket, ev: Event) => any; @@ -1066,13 +1692,16 @@ interface WebSocket extends EventTarget { readonly readyState: number; readonly url: string; close(code?: number, reason?: string): void; - send(data: any): void; + send(data: string): void; + send(data: Blob): void; + send(data: ArrayBuffer): void; + send(data: ArrayBufferView): void; readonly CLOSED: number; readonly CLOSING: number; readonly CONNECTING: number; readonly OPEN: number; addEventListener(type: K, listener: (this: WebSocket, ev: WebSocketEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var WebSocket: { @@ -1084,35 +1713,107 @@ declare var WebSocket: { readonly OPEN: number; }; +interface WindowClient extends Client { + readonly ancestorOrigins: ReadonlyArray; + readonly focused: boolean; + readonly visibilityState: VisibilityState; + focus(): Promise; + navigate(url: string): Promise; +} + +declare var WindowClient: { + prototype: WindowClient; + new(): WindowClient; +}; + interface WorkerEventMap extends AbstractWorkerEventMap { "message": MessageEvent; + "messageerror": MessageEvent; } interface Worker extends EventTarget, AbstractWorker { onmessage: (this: Worker, ev: MessageEvent) => any; + onmessageerror: (this: Worker, ev: MessageEvent) => any; postMessage(message: any, transfer?: any[]): void; terminate(): void; addEventListener(type: K, listener: (this: Worker, ev: WorkerEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var Worker: { prototype: Worker; - new(stringUrl: string): Worker; + new(scriptURL: string, options?: WorkerOptions): Worker; +}; + +interface WorkerGlobalScopeEventMap { + "error": ErrorEvent; + "languagechange": Event; + "offline": Event; + "online": Event; + "rejectionhandled": PromiseRejectionEvent; + "unhandledrejection": PromiseRejectionEvent; +} + +interface WorkerGlobalScope extends EventTarget, WindowOrWorkerGlobalScope, GlobalPerformance, GlobalCrypto { + readonly location: WorkerLocation; + readonly navigator: WorkerNavigator; + onerror: OnErrorEventHandler; + onlanguagechange: (this: WorkerGlobalScope, ev: Event) => any; + onoffline: (this: WorkerGlobalScope, ev: Event) => any; + ononline: (this: WorkerGlobalScope, ev: Event) => any; + onrejectionhandled: (this: WorkerGlobalScope, ev: PromiseRejectionEvent) => any; + onunhandledrejection: (this: WorkerGlobalScope, ev: PromiseRejectionEvent) => any; + readonly self: WorkerGlobalScope; + importScripts(...urls: string[]): void; + createImageBitmap(image: ImageBitmap | ImageData | Blob, options?: ImageBitmapOptions): Promise; + createImageBitmap(image: ImageBitmap | ImageData | Blob, sx: number, sy: number, sw: number, sh: number, options?: ImageBitmapOptions): Promise; + addEventListener(type: K, listener: (this: WorkerGlobalScope, ev: WorkerGlobalScopeEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; +} + +declare var WorkerGlobalScope: { + prototype: WorkerGlobalScope; + new(): WorkerGlobalScope; +}; + +interface WorkerLocation { + readonly hash: string; + readonly host: string; + readonly hostname: string; + readonly href: string; + readonly origin: string; + readonly pathname: string; + readonly port: string; + readonly protocol: string; + readonly search: string; +} + +declare var WorkerLocation: { + prototype: WorkerLocation; + new(): WorkerLocation; +}; + +interface WorkerNavigator extends NavigatorID, NavigatorLanguage, NavigatorOnLine, NavigatorConcurrentHardware { + readonly serviceWorker: ServiceWorkerContainer; + readonly hardwareConcurrency: number; +} + +declare var WorkerNavigator: { + prototype: WorkerNavigator; + new(): WorkerNavigator; }; interface XMLHttpRequestEventMap extends XMLHttpRequestEventTargetEventMap { "readystatechange": Event; } -interface XMLHttpRequest extends EventTarget, XMLHttpRequestEventTarget { +interface XMLHttpRequest extends XMLHttpRequestEventTarget { onreadystatechange: (this: XMLHttpRequest, ev: Event) => any; readonly readyState: number; readonly response: any; readonly responseText: string; responseType: XMLHttpRequestResponseType; readonly responseURL: string; - readonly responseXML: any; readonly status: number; readonly statusText: string; timeout: number; @@ -1121,20 +1822,20 @@ interface XMLHttpRequest extends EventTarget, XMLHttpRequestEventTarget { msCaching?: string; abort(): void; getAllResponseHeaders(): string; - getResponseHeader(header: string): string | null; - msCachingEnabled(): boolean; - open(method: string, url: string, async?: boolean, user?: string, password?: string): void; + getResponseHeader(name: string): string | null; + open(method: string, url: string): void; + open(method: string, url: string, async: boolean, username?: string, password?: string): void; overrideMimeType(mime: string): void; send(data?: string): void; send(data?: any): void; - setRequestHeader(header: string, value: string): void; + setRequestHeader(name: string, value: string): void; readonly DONE: number; readonly HEADERS_RECEIVED: number; readonly LOADING: number; readonly OPENED: number; readonly UNSENT: number; addEventListener(type: K, listener: (this: XMLHttpRequest, ev: XMLHttpRequestEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var XMLHttpRequest: { @@ -1147,9 +1848,36 @@ declare var XMLHttpRequest: { readonly UNSENT: number; }; -interface XMLHttpRequestUpload extends EventTarget, XMLHttpRequestEventTarget { +interface XMLHttpRequestEventTargetEventMap { + "abort": Event; + "error": ErrorEvent; + "load": Event; + "loadend": Event; + "loadstart": Event; + "progress": ProgressEvent; + "timeout": ProgressEvent; +} + +interface XMLHttpRequestEventTarget extends EventTarget { + onabort: (this: XMLHttpRequest, ev: Event) => any; + onerror: (this: XMLHttpRequest, ev: ErrorEvent) => any; + onload: (this: XMLHttpRequest, ev: Event) => any; + onloadend: (this: XMLHttpRequest, ev: ProgressEvent) => any; + onloadstart: (this: XMLHttpRequest, ev: Event) => any; + onprogress: (this: XMLHttpRequest, ev: ProgressEvent) => any; + ontimeout: (this: XMLHttpRequest, ev: ProgressEvent) => any; + addEventListener(type: K, listener: (this: XMLHttpRequestEventTarget, ev: XMLHttpRequestEventTargetEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; +} + +declare var XMLHttpRequestEventTarget: { + prototype: XMLHttpRequestEventTarget; + new(): XMLHttpRequestEventTarget; +}; + +interface XMLHttpRequestUpload extends XMLHttpRequestEventTarget { addEventListener(type: K, listener: (this: XMLHttpRequestUpload, ev: XMLHttpRequestEventTargetEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } declare var XMLHttpRequestUpload: { @@ -1164,360 +1892,207 @@ interface AbstractWorkerEventMap { interface AbstractWorker { onerror: (this: AbstractWorker, ev: ErrorEvent) => any; addEventListener(type: K, listener: (this: AbstractWorker, ev: AbstractWorkerEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; } interface Body { + readonly body: ReadableStream | null; readonly bodyUsed: boolean; arrayBuffer(): Promise; blob(): Promise; + formData(): Promise; json(): Promise; text(): Promise; } -interface GlobalFetch { - fetch(input: RequestInfo, init?: RequestInit): Promise; +interface CanvasCompositing { + globalAlpha: number; + globalCompositeOperation: string; } -interface MSBaseReaderEventMap { - "abort": Event; - "error": ErrorEvent; - "load": Event; - "loadend": ProgressEvent; - "loadstart": Event; - "progress": ProgressEvent; +interface CanvasDrawImage { + drawImage(image: CanvasImageSource, dx: number, dy: number): void; + drawImage(image: CanvasImageSource, dx: number, dy: number, dw: number, dh: number): void; + drawImage(image: CanvasImageSource, sx: number, sy: number, sw: number, sh: number, dx: number, dy: number, dw: number, dh: number): void; } -interface MSBaseReader { - onabort: (this: MSBaseReader, ev: Event) => any; - onerror: (this: MSBaseReader, ev: ErrorEvent) => any; - onload: (this: MSBaseReader, ev: Event) => any; - onloadend: (this: MSBaseReader, ev: ProgressEvent) => any; - onloadstart: (this: MSBaseReader, ev: Event) => any; - onprogress: (this: MSBaseReader, ev: ProgressEvent) => any; - readonly readyState: number; - readonly result: any; - abort(): void; - readonly DONE: number; - readonly EMPTY: number; - readonly LOADING: number; - addEventListener(type: K, listener: (this: MSBaseReader, ev: MSBaseReaderEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; +interface CanvasDrawPath { + beginPath(): void; + clip(fillRule?: CanvasFillRule): void; + clip(path: Path2D, fillRule?: CanvasFillRule): void; + fill(path: Path2D, fillRule?: CanvasFillRule): void; + fill(fillRule?: CanvasFillRule): void; + isPointInPath(x: number, y: number, fillRule?: CanvasFillRule): boolean; + isPointInPath(path: Path2D, x: number, y: number, fillRule?: CanvasFillRule): boolean; + isPointInStroke(x: number, y: number): boolean; + isPointInStroke(path: Path2D, x: number, y: number): boolean; + resetClip(): void; + stroke(): void; + stroke(path: Path2D): void; } -interface NavigatorBeacon { - sendBeacon(url: USVString, data?: BodyInit): boolean; +interface CanvasFillStrokeStyles { + fillStyle: string | CanvasGradient | CanvasPattern; + strokeStyle: string | CanvasGradient | CanvasPattern; + createLinearGradient(x0: number, y0: number, x1: number, y1: number): CanvasGradient; + createPattern(image: CanvasImageSource, repetition: string): CanvasPattern | null; + createRadialGradient(x0: number, y0: number, r0: number, x1: number, y1: number, r1: number): CanvasGradient; } -interface NavigatorConcurrentHardware { - readonly hardwareConcurrency: number; +interface CanvasFilters { + filter: string; } -interface NavigatorID { - readonly appCodeName: string; - readonly appName: string; - readonly appVersion: string; - readonly platform: string; - readonly product: string; - readonly productSub: string; - readonly userAgent: string; - readonly vendor: string; - readonly vendorSub: string; +interface CanvasImageData { + createImageData(sw: number, sh: number): ImageData; + createImageData(imagedata: ImageData): ImageData; + getImageData(sx: number, sy: number, sw: number, sh: number): ImageData; + putImageData(imagedata: ImageData, dx: number, dy: number): void; + putImageData(imagedata: ImageData, dx: number, dy: number, dirtyX: number, dirtyY: number, dirtyWidth: number, dirtyHeight: number): void; } -interface NavigatorOnLine { - readonly onLine: boolean; +interface CanvasImageSmoothing { + imageSmoothingEnabled: boolean; + imageSmoothingQuality: ImageSmoothingQuality; } -interface WindowBase64 { - atob(encodedString: string): string; - btoa(rawString: string): string; +interface CanvasPath { + arc(x: number, y: number, radius: number, startAngle: number, endAngle: number, anticlockwise?: boolean): void; + arcTo(x1: number, y1: number, x2: number, y2: number, radius: number): void; + arcTo(x1: number, y1: number, x2: number, y2: number, radiusX: number, radiusY: number, rotation: number): void; + bezierCurveTo(cp1x: number, cp1y: number, cp2x: number, cp2y: number, x: number, y: number): void; + closePath(): void; + ellipse(x: number, y: number, radiusX: number, radiusY: number, rotation: number, startAngle: number, endAngle: number, anticlockwise?: boolean): void; + lineTo(x: number, y: number): void; + moveTo(x: number, y: number): void; + quadraticCurveTo(cpx: number, cpy: number, x: number, y: number): void; + rect(x: number, y: number, w: number, h: number): void; } -interface WindowConsole { - readonly console: Console; +interface CanvasPathDrawingStyles { + lineCap: CanvasLineCap; + lineDashOffset: number; + lineJoin: CanvasLineJoin; + lineWidth: number; + miterLimit: number; + getLineDash(): number[]; + setLineDash(segments: number[]): void; } -interface XMLHttpRequestEventTargetEventMap { - "abort": Event; - "error": ErrorEvent; - "load": Event; - "loadend": ProgressEvent; - "loadstart": Event; - "progress": ProgressEvent; - "timeout": ProgressEvent; +interface CanvasRect { + clearRect(x: number, y: number, w: number, h: number): void; + fillRect(x: number, y: number, w: number, h: number): void; + strokeRect(x: number, y: number, w: number, h: number): void; } -interface XMLHttpRequestEventTarget { - onabort: (this: XMLHttpRequest, ev: Event) => any; - onerror: (this: XMLHttpRequest, ev: ErrorEvent) => any; - onload: (this: XMLHttpRequest, ev: Event) => any; - onloadend: (this: XMLHttpRequest, ev: ProgressEvent) => any; - onloadstart: (this: XMLHttpRequest, ev: Event) => any; - onprogress: (this: XMLHttpRequest, ev: ProgressEvent) => any; - ontimeout: (this: XMLHttpRequest, ev: ProgressEvent) => any; - addEventListener(type: K, listener: (this: XMLHttpRequestEventTarget, ev: XMLHttpRequestEventTargetEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; +interface CanvasShadowStyles { + shadowBlur: number; + shadowColor: string; + shadowOffsetX: number; + shadowOffsetY: number; } -interface Client { - readonly frameType: FrameType; - readonly id: string; - readonly url: USVString; - postMessage(message: any, transfer?: any[]): void; +interface CanvasState { + restore(): void; + save(): void; } -declare var Client: { - prototype: Client; - new(): Client; -}; - -interface Clients { - claim(): Promise; - get(id: string): Promise; - matchAll(options?: ClientQueryOptions): Promise; - openWindow(url: USVString): Promise; +interface CanvasTransform { + getTransform(): DOMMatrix; + resetTransform(): void; + rotate(angle: number): void; + scale(x: number, y: number): void; + setTransform(a: number, b: number, c: number, d: number, e: number, f: number): void; + setTransform(transform?: DOMMatrixInit): void; + transform(a: number, b: number, c: number, d: number, e: number, f: number): void; + translate(x: number, y: number): void; } -declare var Clients: { - prototype: Clients; - new(): Clients; -}; +interface GlobalCrypto { + readonly crypto: Crypto; +} -interface DedicatedWorkerGlobalScopeEventMap extends WorkerGlobalScopeEventMap { - "message": MessageEvent; +interface GlobalPerformance { + readonly performance: Performance; } -interface DedicatedWorkerGlobalScope extends WorkerGlobalScope { - onmessage: (this: DedicatedWorkerGlobalScope, ev: MessageEvent) => any; - close(): void; - postMessage(message: any, transfer?: any[]): void; - addEventListener(type: K, listener: (this: DedicatedWorkerGlobalScope, ev: DedicatedWorkerGlobalScopeEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; +interface NavigatorConcurrentHardware { + readonly hardwareConcurrency: number; } -declare var DedicatedWorkerGlobalScope: { - prototype: DedicatedWorkerGlobalScope; - new(): DedicatedWorkerGlobalScope; -}; +interface NavigatorID { + readonly appCodeName: string; + readonly appName: string; + readonly appVersion: string; + readonly platform: string; + readonly product: string; + readonly userAgent: string; +} -interface ExtendableEvent extends Event { - waitUntil(f: Promise): void; +interface NavigatorLanguage { + readonly language: string; + readonly languages: ReadonlyArray; } -declare var ExtendableEvent: { - prototype: ExtendableEvent; - new(type: string, eventInitDict?: ExtendableEventInit): ExtendableEvent; -}; +interface NavigatorOnLine { + readonly onLine: boolean; +} -interface ExtendableMessageEvent extends ExtendableEvent { - readonly data: any; - readonly lastEventId: string; +interface WindowOrWorkerGlobalScope { + readonly caches: CacheStorage; + readonly indexedDB: IDBFactory; readonly origin: string; - readonly ports: MessagePort[] | null; - readonly source: Client | ServiceWorker | MessagePort | null; + atob(data: string): string; + btoa(data: string): string; + clearInterval(handle?: number): void; + clearTimeout(handle?: number): void; + createImageBitmap(image: ImageBitmapSource, options?: ImageBitmapOptions): Promise; + createImageBitmap(image: ImageBitmapSource, sx: number, sy: number, sw: number, sh: number, options?: ImageBitmapOptions): Promise; + fetch(input: RequestInfo, init?: RequestInit): Promise; + setInterval(handler: (...args: any[]) => void, timeout: number): number; + setInterval(handler: any, timeout?: any, ...args: any[]): number; + setTimeout(handler: (...args: any[]) => void, timeout: number): number; + setTimeout(handler: any, timeout?: any, ...args: any[]): number; } -declare var ExtendableMessageEvent: { - prototype: ExtendableMessageEvent; - new(type: string, eventInitDict?: ExtendableMessageEventInit): ExtendableMessageEvent; -}; +declare namespace console { + function assert(condition?: boolean, ...data: any[]): void; + function clear(): void; + function count(label?: string): void; + function debug(...data: any[]): void; + function dir(item: any, options?: any): void; + function dirxml(...data: any[]): void; + function error(...data: any[]): void; + function group(...data: any[]): void; + function groupCollapsed(...data: any[]): void; + function groupEnd(): void; + function info(...data: any[]): void; + function log(...data: any[]): void; + function table(tabularData: any, properties?: string[]): void; + function time(label?: string): void; + function timeEnd(label?: string): void; + function trace(...data: any[]): void; + function warn(...data: any[]): void; +} -interface FetchEvent extends ExtendableEvent { - readonly clientId: string | null; - readonly isReload: boolean; - readonly request: Request; - respondWith(r: Promise): void; +interface BroadcastChannel extends EventTarget { + readonly name: string; + onmessage: (ev: MessageEvent) => any; + onmessageerror: (ev: MessageEvent) => any; + close(): void; + postMessage(message: any): void; + addEventListener(type: K, listener: (this: BroadcastChannel, ev: BroadcastChannelEventMap[K]) => any, useCapture?: boolean): void; + addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; } -declare var FetchEvent: { - prototype: FetchEvent; - new(type: string, eventInitDict: FetchEventInit): FetchEvent; +declare var BroadcastChannel: { + prototype: BroadcastChannel; + new(name: string): BroadcastChannel; }; -interface FileReaderSync { - readAsArrayBuffer(blob: Blob): any; - readAsBinaryString(blob: Blob): void; - readAsDataURL(blob: Blob): string; - readAsText(blob: Blob, encoding?: string): string; -} - -declare var FileReaderSync: { - prototype: FileReaderSync; - new(): FileReaderSync; -}; - -interface NotificationEvent extends ExtendableEvent { - readonly action: string; - readonly notification: Notification; -} - -declare var NotificationEvent: { - prototype: NotificationEvent; - new(type: string, eventInitDict: NotificationEventInit): NotificationEvent; -}; - -interface PushEvent extends ExtendableEvent { - readonly data: PushMessageData | null; -} - -declare var PushEvent: { - prototype: PushEvent; - new(type: string, eventInitDict?: PushEventInit): PushEvent; -}; - -interface PushMessageData { - arrayBuffer(): ArrayBuffer; - blob(): Blob; - json(): JSON; - text(): USVString; -} - -declare var PushMessageData: { - prototype: PushMessageData; - new(): PushMessageData; -}; - -interface ServiceWorkerGlobalScopeEventMap extends WorkerGlobalScopeEventMap { - "activate": ExtendableEvent; - "fetch": FetchEvent; - "install": ExtendableEvent; - "message": ExtendableMessageEvent; - "notificationclick": NotificationEvent; - "notificationclose": NotificationEvent; - "push": PushEvent; - "pushsubscriptionchange": ExtendableEvent; - "sync": SyncEvent; -} - -interface ServiceWorkerGlobalScope extends WorkerGlobalScope { - readonly clients: Clients; - onactivate: (this: ServiceWorkerGlobalScope, ev: ExtendableEvent) => any; - onfetch: (this: ServiceWorkerGlobalScope, ev: FetchEvent) => any; - oninstall: (this: ServiceWorkerGlobalScope, ev: ExtendableEvent) => any; - onmessage: (this: ServiceWorkerGlobalScope, ev: ExtendableMessageEvent) => any; - onnotificationclick: (this: ServiceWorkerGlobalScope, ev: NotificationEvent) => any; - onnotificationclose: (this: ServiceWorkerGlobalScope, ev: NotificationEvent) => any; - onpush: (this: ServiceWorkerGlobalScope, ev: PushEvent) => any; - onpushsubscriptionchange: (this: ServiceWorkerGlobalScope, ev: ExtendableEvent) => any; - onsync: (this: ServiceWorkerGlobalScope, ev: SyncEvent) => any; - readonly registration: ServiceWorkerRegistration; - skipWaiting(): Promise; - addEventListener(type: K, listener: (this: ServiceWorkerGlobalScope, ev: ServiceWorkerGlobalScopeEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; -} - -declare var ServiceWorkerGlobalScope: { - prototype: ServiceWorkerGlobalScope; - new(): ServiceWorkerGlobalScope; -}; - -interface SyncEvent extends ExtendableEvent { - readonly lastChance: boolean; - readonly tag: string; -} - -declare var SyncEvent: { - prototype: SyncEvent; - new(type: string, init: SyncEventInit): SyncEvent; -}; - -interface WindowClient extends Client { - readonly focused: boolean; - readonly visibilityState: VisibilityState; - focus(): Promise; - navigate(url: USVString): Promise; -} - -declare var WindowClient: { - prototype: WindowClient; - new(): WindowClient; -}; - -interface WorkerGlobalScopeEventMap { - "error": ErrorEvent; -} - -interface WorkerGlobalScope extends EventTarget, WorkerUtils, WindowConsole, GlobalFetch { - readonly caches: CacheStorage; - readonly isSecureContext: boolean; - readonly location: WorkerLocation; - onerror: (this: WorkerGlobalScope, ev: ErrorEvent) => any; - readonly performance: Performance; - readonly self: WorkerGlobalScope; - msWriteProfilerMark(profilerMarkName: string): void; - createImageBitmap(image: ImageBitmap | ImageData | Blob, options?: ImageBitmapOptions): Promise; - createImageBitmap(image: ImageBitmap | ImageData | Blob, sx: number, sy: number, sw: number, sh: number, options?: ImageBitmapOptions): Promise; - addEventListener(type: K, listener: (this: WorkerGlobalScope, ev: WorkerGlobalScopeEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; -} - -declare var WorkerGlobalScope: { - prototype: WorkerGlobalScope; - new(): WorkerGlobalScope; -}; - -interface WorkerLocation { - readonly hash: string; - readonly host: string; - readonly hostname: string; - readonly href: string; - readonly origin: string; - readonly pathname: string; - readonly port: string; - readonly protocol: string; - readonly search: string; - toString(): string; -} - -declare var WorkerLocation: { - prototype: WorkerLocation; - new(): WorkerLocation; -}; - -interface WorkerNavigator extends Object, NavigatorID, NavigatorOnLine, NavigatorBeacon, NavigatorConcurrentHardware { - readonly hardwareConcurrency: number; -} - -declare var WorkerNavigator: { - prototype: WorkerNavigator; - new(): WorkerNavigator; -}; - -interface WorkerUtils extends Object, WindowBase64 { - readonly indexedDB: IDBFactory; - readonly msIndexedDB: IDBFactory; - readonly navigator: WorkerNavigator; - clearImmediate(handle: number): void; - clearInterval(handle: number): void; - clearTimeout(handle: number): void; - importScripts(...urls: string[]): void; - setImmediate(handler: (...args: any[]) => void): number; - setImmediate(handler: any, ...args: any[]): number; - setInterval(handler: (...args: any[]) => void, timeout: number): number; - setInterval(handler: any, timeout?: any, ...args: any[]): number; - setTimeout(handler: (...args: any[]) => void, timeout: number): number; - setTimeout(handler: any, timeout?: any, ...args: any[]): number; -} - -interface BroadcastChannel extends EventTarget { - readonly name: string; - onmessage: (ev: MessageEvent) => any; - onmessageerror: (ev: MessageEvent) => any; - close(): void; - postMessage(message: any): void; - addEventListener(type: K, listener: (this: BroadcastChannel, ev: BroadcastChannelEventMap[K]) => any, useCapture?: boolean): void; - addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; -} - -declare var BroadcastChannel: { - prototype: BroadcastChannel; - new(name: string): BroadcastChannel; -}; - -interface BroadcastChannelEventMap { - message: MessageEvent; - messageerror: MessageEvent; +interface BroadcastChannelEventMap { + message: MessageEvent; + messageerror: MessageEvent; } interface ErrorEventInit { @@ -1543,41 +2118,6 @@ interface ImageBitmap { close(): void; } -interface URLSearchParams { - /** - * Appends a specified key/value pair as a new search parameter. - */ - append(name: string, value: string): void; - /** - * Deletes the given search parameter, and its associated value, from the list of all search parameters. - */ - delete(name: string): void; - /** - * Returns the first value associated to the given search parameter. - */ - get(name: string): string | null; - /** - * Returns all the values association with a given search parameter. - */ - getAll(name: string): string[]; - /** - * Returns a Boolean indicating if such a search parameter exists. - */ - has(name: string): boolean; - /** - * Sets the value associated to a given search parameter to the given value. If there were several values, delete the others. - */ - set(name: string, value: string): void; -} - -declare var URLSearchParams: { - prototype: URLSearchParams; - /** - * Constructor returning a URLSearchParams object. - */ - new (init?: string | URLSearchParams): URLSearchParams; -}; - interface BlobPropertyBag { type?: string; endings?: string; @@ -1600,273 +2140,154 @@ interface ProgressEventInit extends EventInit { interface IDBArrayKey extends Array { } -interface RsaKeyGenParams extends Algorithm { - modulusLength: number; - publicExponent: Uint8Array; -} - -interface RsaHashedKeyGenParams extends RsaKeyGenParams { - hash: AlgorithmIdentifier; -} - -interface RsaKeyAlgorithm extends KeyAlgorithm { - modulusLength: number; - publicExponent: Uint8Array; -} - -interface RsaHashedKeyAlgorithm extends RsaKeyAlgorithm { - hash: AlgorithmIdentifier; -} - -interface RsaHashedImportParams { - hash: AlgorithmIdentifier; -} - -interface RsaPssParams { - saltLength: number; -} - -interface RsaOaepParams extends Algorithm { - label?: BufferSource; -} - -interface EcdsaParams extends Algorithm { - hash: AlgorithmIdentifier; -} - -interface EcKeyGenParams extends Algorithm { - namedCurve: string; -} - -interface EcKeyAlgorithm extends KeyAlgorithm { - typedCurve: string; -} - -interface EcKeyImportParams { - namedCurve: string; -} - -interface EcdhKeyDeriveParams extends Algorithm { - public: CryptoKey; -} - -interface AesCtrParams extends Algorithm { - counter: BufferSource; - length: number; -} - -interface AesKeyAlgorithm extends KeyAlgorithm { - length: number; -} - -interface AesKeyGenParams extends Algorithm { - length: number; -} - -interface AesDerivedKeyParams extends Algorithm { - length: number; -} - -interface AesCbcParams extends Algorithm { - iv: BufferSource; -} - -interface AesCmacParams extends Algorithm { - length: number; -} - -interface AesGcmParams extends Algorithm { - iv: BufferSource; - additionalData?: BufferSource; - tagLength?: number; -} - -interface AesCfbParams extends Algorithm { - iv: BufferSource; -} - -interface HmacImportParams extends Algorithm { - hash?: AlgorithmIdentifier; - length?: number; -} - -interface HmacKeyAlgorithm extends KeyAlgorithm { - hash: AlgorithmIdentifier; - length: number; -} - -interface HmacKeyGenParams extends Algorithm { - hash: AlgorithmIdentifier; - length?: number; -} - -interface DhKeyGenParams extends Algorithm { - prime: Uint8Array; - generator: Uint8Array; -} - -interface DhKeyAlgorithm extends KeyAlgorithm { - prime: Uint8Array; - generator: Uint8Array; -} - -interface DhKeyDeriveParams extends Algorithm { - public: CryptoKey; -} - -interface DhImportKeyParams extends Algorithm { - prime: Uint8Array; - generator: Uint8Array; -} - -interface ConcatParams extends Algorithm { - hash?: AlgorithmIdentifier; - algorithmId: Uint8Array; - partyUInfo: Uint8Array; - partyVInfo: Uint8Array; - publicInfo?: Uint8Array; - privateInfo?: Uint8Array; -} - -interface HkdfCtrParams extends Algorithm { - hash: AlgorithmIdentifier; - label: BufferSource; - context: BufferSource; -} - -interface Pbkdf2Params extends Algorithm { - salt: BufferSource; - iterations: number; - hash: AlgorithmIdentifier; -} - -interface RsaOtherPrimesInfo { - r: string; - d: string; - t: string; -} - -interface JsonWebKey { - kty: string; - use?: string; - key_ops?: string[]; - alg?: string; - kid?: string; - x5u?: string; - x5c?: string; - x5t?: string; - ext?: boolean; - crv?: string; - x?: string; - y?: string; - d?: string; - n?: string; - e?: string; - p?: string; - q?: string; - dp?: string; - dq?: string; - qi?: string; - oth?: RsaOtherPrimesInfo[]; - k?: string; -} - -interface EventListenerOptions { - capture?: boolean; -} - -interface AddEventListenerOptions extends EventListenerOptions { - passive?: boolean; - once?: boolean; +interface DOMException extends Error { + readonly name: string; + readonly code: number; + readonly INDEX_SIZE_ERR: number; + readonly DOMSTRING_SIZE_ERR: number; + readonly HIERARCHY_REQUEST_ERR: number; + readonly WRONG_DOCUMENT_ERR: number; + readonly INVALID_CHARACTER_ERR: number; + readonly NO_DATA_ALLOWED_ERR: number; + readonly NO_MODIFICATION_ALLOWED_ERR: number; + readonly NOT_FOUND_ERR: number; + readonly NOT_SUPPORTED_ERR: number; + readonly INUSE_ATTRIBUTE_ERR: number; + readonly INVALID_STATE_ERR: number; + readonly SYNTAX_ERR: number; + readonly INVALID_MODIFICATION_ERR: number; + readonly NAMESPACE_ERR: number; + readonly INVALID_ACCESS_ERR: number; + readonly VALIDATION_ERR: number; + readonly TYPE_MISMATCH_ERR: number; + readonly SECURITY_ERR: number; + readonly NETWORK_ERR: number; + readonly ABORT_ERR: number; + readonly URL_MISMATCH_ERR: number; + readonly QUOTA_EXCEEDED_ERR: number; + readonly TIMEOUT_ERR: number; + readonly INVALID_NODE_TYPE_ERR: number; + readonly DATA_CLONE_ERR: number; } -declare type EventListenerOrEventListenerObject = EventListener | EventListenerObject; +declare var DOMException: { + prototype: DOMException; + new (message?: string, name?: string): DOMException; + readonly INDEX_SIZE_ERR: number; + readonly DOMSTRING_SIZE_ERR: number; + readonly HIERARCHY_REQUEST_ERR: number; + readonly WRONG_DOCUMENT_ERR: number; + readonly INVALID_CHARACTER_ERR: number; + readonly NO_DATA_ALLOWED_ERR: number; + readonly NO_MODIFICATION_ALLOWED_ERR: number; + readonly NOT_FOUND_ERR: number; + readonly NOT_SUPPORTED_ERR: number; + readonly INUSE_ATTRIBUTE_ERR: number; + readonly INVALID_STATE_ERR: number; + readonly SYNTAX_ERR: number; + readonly INVALID_MODIFICATION_ERR: number; + readonly NAMESPACE_ERR: number; + readonly INVALID_ACCESS_ERR: number; + readonly VALIDATION_ERR: number; + readonly TYPE_MISMATCH_ERR: number; + readonly SECURITY_ERR: number; + readonly NETWORK_ERR: number; + readonly ABORT_ERR: number; + readonly URL_MISMATCH_ERR: number; + readonly QUOTA_EXCEEDED_ERR: number; + readonly TIMEOUT_ERR: number; + readonly INVALID_NODE_TYPE_ERR: number; + readonly DATA_CLONE_ERR: number; +}; -interface DecodeErrorCallback { - (error: DOMException): void; -} -interface DecodeSuccessCallback { - (decodedData: AudioBuffer): void; -} -interface ErrorEventHandler { - (message: string, filename?: string, lineno?: number, colno?: number, error?: Error): void; -} -interface ForEachCallback { - (keyId: any, status: MediaKeyStatus): void; -} -interface FunctionStringCallback { - (data: string): void; -} interface NotificationPermissionCallback { (permission: NotificationPermission): void; } -interface PositionCallback { - (position: Position): void; +interface OnErrorEventHandlerNonNull { + (event: Event | string, source?: string, lineno?: number, colno?: number, error?: any): any; } -interface PositionErrorCallback { - (error: PositionError): void; +interface PerformanceObserverCallback { + (entries: PerformanceObserverEntryList, observer: PerformanceObserver): void; } +declare var name: string; declare var onmessage: (this: DedicatedWorkerGlobalScope, ev: MessageEvent) => any; +declare var onmessageerror: (this: DedicatedWorkerGlobalScope, ev: MessageEvent) => any; declare function close(): void; declare function postMessage(message: any, transfer?: any[]): void; -declare var caches: CacheStorage; -declare var isSecureContext: boolean; declare var location: WorkerLocation; -declare var onerror: (this: DedicatedWorkerGlobalScope, ev: ErrorEvent) => any; -declare var performance: Performance; +declare var navigator: WorkerNavigator; +declare var onerror: OnErrorEventHandler; +declare var onlanguagechange: (this: DedicatedWorkerGlobalScope, ev: Event) => any; +declare var onoffline: (this: DedicatedWorkerGlobalScope, ev: Event) => any; +declare var ononline: (this: DedicatedWorkerGlobalScope, ev: Event) => any; +declare var onrejectionhandled: (this: DedicatedWorkerGlobalScope, ev: PromiseRejectionEvent) => any; +declare var onunhandledrejection: (this: DedicatedWorkerGlobalScope, ev: PromiseRejectionEvent) => any; declare var self: WorkerGlobalScope; -declare function msWriteProfilerMark(profilerMarkName: string): void; +declare function importScripts(...urls: string[]): void; declare function createImageBitmap(image: ImageBitmap | ImageData | Blob, options?: ImageBitmapOptions): Promise; declare function createImageBitmap(image: ImageBitmap | ImageData | Blob, sx: number, sy: number, sw: number, sh: number, options?: ImageBitmapOptions): Promise; -declare function dispatchEvent(evt: Event): boolean; -declare function removeEventListener(type: string, listener?: EventListenerOrEventListenerObject, options?: boolean | EventListenerOptions): void; +declare function dispatchEvent(event: Event): boolean; +declare function removeEventListener(type: string, callback: EventListener | null, options?: EventListenerOptions | boolean): void; +declare var caches: CacheStorage; declare var indexedDB: IDBFactory; -declare var msIndexedDB: IDBFactory; -declare var navigator: WorkerNavigator; -declare function clearImmediate(handle: number): void; -declare function clearInterval(handle: number): void; -declare function clearTimeout(handle: number): void; -declare function importScripts(...urls: string[]): void; -declare function setImmediate(handler: (...args: any[]) => void): number; -declare function setImmediate(handler: any, ...args: any[]): number; +declare var origin: string; +declare function atob(data: string): string; +declare function btoa(data: string): string; +declare function clearInterval(handle?: number): void; +declare function clearTimeout(handle?: number): void; +declare function createImageBitmap(image: ImageBitmapSource, options?: ImageBitmapOptions): Promise; +declare function createImageBitmap(image: ImageBitmapSource, sx: number, sy: number, sw: number, sh: number, options?: ImageBitmapOptions): Promise; +declare function fetch(input: RequestInfo, init?: RequestInit): Promise; declare function setInterval(handler: (...args: any[]) => void, timeout: number): number; declare function setInterval(handler: any, timeout?: any, ...args: any[]): number; declare function setTimeout(handler: (...args: any[]) => void, timeout: number): number; declare function setTimeout(handler: any, timeout?: any, ...args: any[]): number; -declare function atob(encodedString: string): string; -declare function btoa(rawString: string): string; -declare var console: Console; -declare function fetch(input: RequestInfo, init?: RequestInit): Promise; -declare function dispatchEvent(evt: Event): boolean; -declare function removeEventListener(type: string, listener?: EventListenerOrEventListenerObject, options?: boolean | EventListenerOptions): void; +declare var performance: Performance; +declare var crypto: Crypto; +declare function dispatchEvent(event: Event): boolean; +declare function removeEventListener(type: string, callback: EventListener | null, options?: EventListenerOptions | boolean): void; declare function addEventListener(type: K, listener: (this: DedicatedWorkerGlobalScope, ev: DedicatedWorkerGlobalScopeEventMap[K]) => any, useCapture?: boolean): void; -declare function addEventListener(type: string, listener: EventListenerOrEventListenerObject, useCapture?: boolean): void; -type AlgorithmIdentifier = string | Algorithm; -type BodyInit = any; -type IDBKeyPath = string; +declare function addEventListener(type: string, listener: EventListener, useCapture?: boolean): void; +type AlgorithmIdentifier = any; +type BodyInit = Blob | BufferSource | FormData | URLSearchParams | ReadableStream | string; +type BufferSource = ArrayBufferView | ArrayBuffer; +type CanvasImageSource = never | never | never | ImageBitmap | OffscreenCanvas; +type FormDataEntryValue = File | string; +type HeadersInit = string[][] | { [key: string]: string }; +type ImageBitmapSource = CanvasImageSource | Blob | ImageData; +type MessageEventSource = never | MessagePort | ServiceWorker; +type OffscreenRenderingContext = OffscreenCanvasRenderingContext2D | never; +type OnErrorEventHandler = OnErrorEventHandlerNonNull; +type PerformanceEntryList = PerformanceEntry[]; +type PushMessageDataInit = BufferSource | string; type RequestInfo = Request | string; -type USVString = string; type IDBValidKey = number | string | Date | IDBArrayKey; -type BufferSource = ArrayBuffer | ArrayBufferView; -type FormDataEntryValue = string | File; +type BinaryType = "blob" | "arraybuffer"; +type CanvasFillRule = "nonzero" | "evenodd"; +type CanvasLineCap = "butt" | "round" | "square"; +type CanvasLineJoin = "round" | "bevel" | "miter"; +type ClientType = "window" | "worker" | "sharedworker" | "all"; type IDBCursorDirection = "next" | "nextunique" | "prev" | "prevunique"; type IDBRequestReadyState = "pending" | "done"; type IDBTransactionMode = "readonly" | "readwrite" | "versionchange"; -type MediaKeyStatus = "usable" | "expired" | "output-downscaled" | "output-not-allowed" | "status-pending" | "internal-error"; +type ImageSmoothingQuality = "low" | "medium" | "high"; +type KeyFormat = "raw" | "spki" | "pkcs8" | "jwk"; +type KeyType = "public" | "private" | "secret"; +type KeyUsage = "encrypt" | "decrypt" | "sign" | "verify" | "deriveKey" | "deriveBits" | "wrapKey" | "unwrapKey"; type NotificationDirection = "auto" | "ltr" | "rtl"; type NotificationPermission = "default" | "denied" | "granted"; +type OffscreenRenderingContextType = "2d" | "webgl"; type PushEncryptionKeyName = "p256dh" | "auth"; -type PushPermissionState = "granted" | "denied" | "prompt"; -type ReferrerPolicy = "" | "no-referrer" | "no-referrer-when-downgrade" | "origin-only" | "origin-when-cross-origin" | "unsafe-url"; -type RequestCache = "default" | "no-store" | "reload" | "no-cache" | "force-cache"; +type PushPermissionState = "denied" | "granted" | "prompt"; +type ReferrerPolicy = "" | "no-referrer" | "no-referrer-when-downgrade" | "same-origin" | "origin" | "strict-origin" | "origin-when-cross-origin" | "strict-origin-when-cross-origin" | "unsafe-url"; +type RequestCache = "default" | "no-store" | "reload" | "no-cache" | "force-cache" | "only-if-cached"; type RequestCredentials = "omit" | "same-origin" | "include"; -type RequestDestination = "" | "document" | "sharedworker" | "subresource" | "unknown" | "worker"; +type RequestDestination = "" | "audio" | "document" | "embed" | "font" | "image" | "manifest" | "object" | "report" | "script" | "serviceworker" | "sharedworker" | "style" | "track" | "video" | "worker" | "xslt"; type RequestMode = "navigate" | "same-origin" | "no-cors" | "cors"; type RequestRedirect = "follow" | "error" | "manual"; type RequestType = "" | "audio" | "font" | "image" | "script" | "style" | "track" | "video"; type ResponseType = "basic" | "cors" | "default" | "error" | "opaque" | "opaqueredirect"; type ServiceWorkerState = "installing" | "installed" | "activating" | "activated" | "redundant"; type VisibilityState = "hidden" | "visible" | "prerender" | "unloaded"; -type XMLHttpRequestResponseType = "" | "arraybuffer" | "blob" | "document" | "json" | "text"; -type ClientType = "window" | "worker" | "sharedworker" | "all"; -type FrameType = "auxiliary" | "top-level" | "nested" | "none"; \ No newline at end of file +type WorkerType = "classic" | "module"; +type XMLHttpRequestResponseType = "" | "arraybuffer" | "blob" | "document" | "json" | "text"; \ No newline at end of file diff --git a/inputfiles/addedTypes.json b/inputfiles/addedTypes.json index 7138f0871..00f157f87 100644 --- a/inputfiles/addedTypes.json +++ b/inputfiles/addedTypes.json @@ -77,46 +77,6 @@ } ] }, - { - "kind": "property", - "interface": "CSSStyleDeclaration", - "name": "resize", - "type": "string | null" - }, - { - "kind": "property", - "interface": "CSSStyleDeclaration", - "name": "userSelect", - "type": "string | null" - }, - { - "kind": "interface", - "name": "StorageEventInit", - "flavor": "Web", - "extends": "EventInit", - "properties": [ - { - "name": "key?", - "type": "string" - }, - { - "name": "oldValue?", - "type": "string" - }, - { - "name": "newValue?", - "type": "string" - }, - { - "name": "url", - "type": "string" - }, - { - "name": "storageArea?", - "type": "Storage" - } - ] - }, { "kind": "interface", "name": "Canvas2DContextAttributes", @@ -142,7 +102,6 @@ }, { "kind": "interface", - "flavor": "Worker", "name": "ImageBitmapOptions", "properties": [ { @@ -174,7 +133,6 @@ { "kind": "interface", "name": "ImageBitmap", - "flavor": "Worker", "properties": [ { "name": "width", @@ -212,71 +170,6 @@ "createImageBitmap(image: ImageBitmap | ImageData | Blob, sx: number, sy: number, sw: number, sh: number, options?: ImageBitmapOptions): Promise" ] }, - { - "kind": "property", - "interface": "IDBObjectStoreParameters", - "name": "autoIncrement?", - "type": "boolean" - }, - { - "kind": "property", - "interface": "IDBIndexParameters", - "name": "multiEntry?", - "type": "boolean" - }, - { - "kind": "property", - "interface": "IDBIndex", - "name": "multiEntry", - "type": "boolean" - }, - { - "kind": "interface", - "name": "URLSearchParams", - "constructorSignatures": [ - "new (init?: string | URLSearchParams): URLSearchParams" - ], - "methods": [ - { - "name": "append", - "signatures": ["append(name: string, value: string): void"] - }, - { - "name": "delete", - "signatures": ["delete(name: string): void"] - }, - { - "name": "get", - "signatures": ["get(name: string): string | null"] - }, - { - "name": "getAll", - "signatures": ["getAll(name: string): string[]"] - }, - { - "name": "has", - "signatures": ["has(name: string): boolean"] - }, - { - "name": "set", - "signatures": ["set(name: string, value: string): void"] - } - ] - }, - { - "kind": "property", - "interface": "URL", - "name": "searchParams", - "readonly": true, - "type": "URLSearchParams" - }, - { - "kind": "property", - "interface": "Window", - "exposeGlobally": false, - "name": "URL", - "type": "typeof URL" - }, { "kind": "property", "interface": "Window", @@ -370,12 +263,6 @@ } ] }, - { - "kind": "property", - "interface": "MessageEventInit", - "name": "lastEventId?", - "type": "string" - }, { "kind": "property", "interface": "MessageEventInit", @@ -416,105 +303,6 @@ "interface": "Element", "signatures": [ "closest(selector: string): Element | null" ] }, - { - "kind": "typedef", - "flavor": "Web", - "name": "ScrollBehavior", - "type": "\"auto\" | \"instant\" | \"smooth\"" - }, - { - "kind": "interface", - "flavor": "Web", - "name": "ScrollOptions", - "properties": [ - { - "name": "behavior?", - "type": "ScrollBehavior" - } - ] - }, - { - "kind": "interface", - "flavor": "Web", - "name": "ScrollToOptions", - "extends": "ScrollOptions", - "properties": [ - { - "name": "left?", - "type": "number" - }, - { - "name": "top?", - "type": "number" - } - ] - }, - { - "kind": "method", - "interface": "Window", - "signatures": [ "scroll(options?: ScrollToOptions): void" ] - }, - { - "kind": "method", - "interface": "Window", - "signatures": [ "scrollTo(options?: ScrollToOptions): void" ] - }, - { - "kind": "method", - "interface": "Window", - "signatures": [ "scrollBy(options?: ScrollToOptions): void" ] - }, - { - "kind": "typedef", - "flavor": "Web", - "name": "ScrollLogicalPosition", - "type": "\"start\" | \"center\" | \"end\" | \"nearest\"" - }, - { - "kind": "interface", - "flavor": "Web", - "name": "ScrollIntoViewOptions", - "extends": "ScrollOptions", - "properties": [ - { - "name": "block?", - "type": "ScrollLogicalPosition" - }, - { - "name": "inline?", - "type": "ScrollLogicalPosition" - } - ] - }, - { - "kind": "method", - "interface": "Element", - "signatures": [ "scrollIntoView(arg?: boolean | ScrollIntoViewOptions): void" ] - }, - { - "kind": "method", - "interface": "Element", - "signatures": [ - "scroll(options?: ScrollToOptions): void", - "scroll(x: number, y: number): void" - ] - }, - { - "kind": "method", - "interface": "Element", - "signatures": [ - "scrollTo(options?: ScrollToOptions): void", - "scrollTo(x: number, y: number): void" - ] - }, - { - "kind": "method", - "interface": "Element", - "signatures": [ - "scrollBy(options?: ScrollToOptions): void", - "scrollBy(x: number, y: number): void" - ] - }, { "kind": "signatureoverload", "name": "createElementNS", @@ -649,12 +437,6 @@ "name": "storageArea?", "type": "Storage" }, - { - "kind": "property", - "interface": "IDBObjectStore", - "name": "autoIncrement", - "type": "boolean" - }, { "kind": "interface", "flavor": "Web", @@ -681,24 +463,6 @@ "name": "IDBArrayKey", "extends": "Array" }, - { - "kind": "property", - "interface": "HTMLInputElement", - "name": "minLength", - "type": "number" - }, - { - "kind": "property", - "interface": "HTMLTextAreaElement", - "name": "minLength", - "type": "number" - }, - { - "kind": "property", - "interface": "IDBDatabase", - "name": "onversionchange", - "type": "(ev: IDBVersionChangeEvent) => any" - }, { "kind": "method", "interface": "IDBDatabase", @@ -725,1044 +489,320 @@ }, { "kind": "property", - "interface": "WebGLContextAttributes", - "name": "failIfMajorPerformanceCaveat?", - "type": "boolean" + "name": "msCaching?", + "interface": "XMLHttpRequest", + "type": "string" }, { "kind": "typedef", - "name": "BufferSource", - "type": "ArrayBuffer | ArrayBufferView" + "name": "MouseWheelEvent", + "flavor": "Web", + "type": "WheelEvent" + }, + { + "kind": "method", + "interface": "Element", + "name": "insertAdjacentElement", + "signatures": ["insertAdjacentElement(position: string, insertedElement: Element): Element | null"] + }, + { + "kind": "method", + "interface": "Element", + "name": "insertAdjacentHTML", + "signatures": ["insertAdjacentHTML(where: string, html: string): void"] + }, + { + "kind": "method", + "interface": "Element", + "name": "insertAdjacentText", + "signatures": ["insertAdjacentText(where: string, text: string): void"] }, { "kind": "interface", - "name": "RsaKeyGenParams", - "extends": "Algorithm", + "name": "ParentNode", + "flavor": "DOM", "properties": [ { - "name": "modulusLength", - "type": "number" + "name": "children", + "readonly": true, + "type": "HTMLCollection" + }, + { + "name": "firstElementChild", + "readonly": true, + "type": "Element | null" + }, + { + "name": "lastElementChild", + "readonly": true, + "type": "Element | null" }, { - "name": "publicExponent", - "type": "Uint8Array" + "name": "childElementCount", + "readonly": true, + "type": "number" } ] }, { - "kind": "interface", - "name": "RsaHashedKeyGenParams", - "extends": "RsaKeyGenParams", - "properties": [ - { - "name": "hash", - "type": "AlgorithmIdentifier" - } - ] + "kind": "extends", + "baseInterface": "ParentNode", + "interface": "Element" + }, + { + "kind": "extends", + "baseInterface": "ParentNode", + "interface": "Document" + }, + { + "kind": "extends", + "baseInterface": "ParentNode", + "interface": "DocumentFragment" }, { "kind": "interface", - "name": "RsaKeyAlgorithm", - "extends": "KeyAlgorithm", - "properties": [ + "name": "DocumentOrShadowRoot", + "flavor": "Web", + "methods": [ { - "name": "modulusLength", - "type": "number" + "name": "getSelection", + "signatures": ["getSelection(): Selection | null"] + }, + { + "name": "elementFromPoint", + "signatures": ["elementFromPoint(x: number, y: number): Element | null"] }, { - "name": "publicExponent", - "type": "Uint8Array" + "name": "elementsFromPoint", + "signatures": ["elementsFromPoint(x: number, y: number): Element[]"] } - ] - }, - { - "kind": "interface", - "name": "RsaHashedKeyAlgorithm", - "extends": "RsaKeyAlgorithm", + ], "properties": [ { - "name": "hash", - "type": "AlgorithmIdentifier" + "name": "activeElement", + "type": "Element | null", + "readonly": true + }, + { + "name": "stylesheets", + "type": "StyleSheetList", + "readonly": true } ] }, { "kind": "interface", - "name": "RsaHashedImportParams", + "name": "ShadowRoot", + "extends": "DocumentOrShadowRoot, DocumentFragment", + "flavor": "Web", "properties": [ { - "name": "hash", - "type": "AlgorithmIdentifier" + "name": "host", + "type": "Element", + "readonly": true + }, + { + "name": "innerHTML", + "type": "string" } ] }, { - "kind": "interface", - "name": "RsaPssParams", - "properties": [ - { - "name": "saltLength", - "type": "number" - } - ] + "kind": "method", + "interface": "Element", + "name": "attachShadow", + "signatures": ["attachShadow(shadowRootInitDict: ShadowRootInit): ShadowRoot"] }, { - "kind": "interface", - "name": "RsaOaepParams", - "extends": "Algorithm", - "properties": [ - { - "name": "label?", - "type": "BufferSource" - } - ] + "kind": "property", + "interface": "Element", + "name": "assignedSlot", + "type": "HTMLSlotElement | null", + "readonly": true }, { - "kind": "interface", - "name": "EcdsaParams", - "extends": "Algorithm", - "properties": [ - { - "name": "hash", - "type": "AlgorithmIdentifier" - } - ] + "kind": "property", + "interface": "Text", + "name": "assignedSlot", + "type": "HTMLSlotElement | null", + "readonly": true }, { "kind": "interface", - "name": "EcKeyGenParams", - "extends": "Algorithm", + "name": "HTMLSlotElement", + "extends": "HTMLElement", + "flavor": "Web", "properties": [ { - "name": "namedCurve", + "name": "name", "type": "string" } - ] - }, - { - "kind": "interface", - "name": "EcKeyAlgorithm", - "extends": "KeyAlgorithm", - "properties": [ + ], + "methods": [ { - "name": "typedCurve", - "type": "string" + "name": "assignedNodes", + "signatures": ["assignedNodes(options?: AssignedNodesOptions): Node[]"] } ] }, { "kind": "interface", - "name": "EcKeyImportParams", + "name": "AssignedNodesOptions", + "flavor": "Web", "properties": [ { - "name": "namedCurve", - "type": "string" + "name": "flatten?", + "type": "boolean" } ] }, { - "kind": "interface", - "name": "EcdhKeyDeriveParams", - "extends": "Algorithm", - "properties": [ - { - "name": "public", - "type": "CryptoKey" - } - ] + "kind": "property", + "interface": "EventInit", + "name": "scoped?", + "type": "boolean" }, { - "kind": "interface", - "name": "AesCtrParams", - "extends": "Algorithm", - "properties": [ - { - "name": "counter", - "type": "BufferSource" - }, - { - "name": "length", - "type": "number" - } - ] + "kind": "property", + "interface": "Event", + "name": "scoped", + "type": "boolean", + "readonly": true }, { - "kind": "interface", - "name": "AesKeyAlgorithm", - "extends": "KeyAlgorithm", - "properties": [ - { - "name": "length", - "type": "number" - } - ] + "kind": "method", + "interface": "Event", + "name": "deepPath", + "signatures": ["deepPath(): EventTarget[]"] }, { - "kind": "interface", - "name": "AesKeyGenParams", - "extends": "Algorithm", - "properties": [ - { - "name": "length", - "type": "number" - } - ] + "kind": "method", + "interface": "Body", + "name": "formData", + "flavor": "Web", + "signatures": ["formData(): Promise"] }, + { "kind": "interface", - "name": "AesDerivedKeyParams", - "extends": "Algorithm", + "name": "DOMException", + "extends": "Error", "properties": [ { - "name": "length", - "type": "number" - } - ] - }, - { - "kind": "interface", - "name": "AesCbcParams", - "extends": "Algorithm", - "properties": [ + "name": "name", + "type": "string", + "readonly": true + }, { - "name": "iv", - "type": "BufferSource" + "name": "code", + "type": "number", + "readonly": true } - ] - }, - { - "kind": "interface", - "name": "AesCmacParams", - "extends": "Algorithm", - "properties": [ + ], + "constructorSignatures": [ + "new (message?: string, name?: string): DOMException" + ], + "constants": [ { - "name": "length", + "name": "INDEX_SIZE_ERR", "type": "number" - } - ] - }, - { - "kind": "interface", - "name": "AesGcmParams", - "extends": "Algorithm", - "properties": [ - { - "name": "iv", - "type": "BufferSource" - }, - { - "name": "additionalData?", - "type": "BufferSource" }, { - "name": "tagLength?", + "name": "DOMSTRING_SIZE_ERR", "type": "number" - } - ] - }, - { - "kind": "interface", - "name": "AesCfbParams", - "extends": "Algorithm", - "properties": [ - { - "name": "iv", - "type": "BufferSource" - } - ] - }, - { - "kind": "interface", - "name": "HmacImportParams", - "extends": "Algorithm", - "properties": [ - { - "name": "hash?", - "type": "AlgorithmIdentifier" }, { - "name": "length?", + "name": "HIERARCHY_REQUEST_ERR", "type": "number" - } - ] - }, - { - "kind": "interface", - "name": "HmacKeyAlgorithm", - "extends": "KeyAlgorithm", - "properties": [ - { - "name": "hash", - "type": "AlgorithmIdentifier" }, { - "name": "length", + "name": "WRONG_DOCUMENT_ERR", "type": "number" - } - ] - }, - { - "kind": "interface", - "name": "HmacKeyGenParams", - "extends": "Algorithm", - "properties": [ - { - "name": "hash", - "type": "AlgorithmIdentifier" }, { - "name": "length?", + "name": "INVALID_CHARACTER_ERR", "type": "number" - } - ] - }, - { - "kind": "interface", - "name": "DhKeyGenParams", - "extends": "Algorithm", - "properties": [ - { - "name": "prime", - "type": "Uint8Array" - }, - { - "name": "generator", - "type": "Uint8Array" - } - ] - }, - { - "kind": "interface", - "name": "DhKeyAlgorithm", - "extends": "KeyAlgorithm", - "properties": [ - { - "name": "prime", - "type": "Uint8Array" - }, - { - "name": "generator", - "type": "Uint8Array" - } - ] - }, - { - "kind": "interface", - "name": "DhKeyDeriveParams", - "extends": "Algorithm", - "properties": [ - { - "name": "public", - "type": "CryptoKey" - } - ] - }, - { - "kind": "interface", - "name": "DhImportKeyParams", - "extends": "Algorithm", - "properties": [ - { - "name": "prime", - "type": "Uint8Array" - }, - { - "name": "generator", - "type": "Uint8Array" - } - ] - }, - { - "kind": "interface", - "name": "ConcatParams", - "extends": "Algorithm", - "properties": [ - { - "name": "hash?", - "type": "AlgorithmIdentifier" - }, - { - "name": "algorithmId", - "type": "Uint8Array" }, { - "name": "partyUInfo", - "type": "Uint8Array" + "name": "NO_DATA_ALLOWED_ERR", + "type": "number" }, { - "name": "partyVInfo", - "type": "Uint8Array" + "name": "NO_MODIFICATION_ALLOWED_ERR", + "type": "number" }, { - "name": "publicInfo?", - "type": "Uint8Array" + "name": "NOT_FOUND_ERR", + "type": "number" }, { - "name": "privateInfo?", - "type": "Uint8Array" - } - ] - }, - { - "kind": "interface", - "name": "HkdfCtrParams", - "extends": "Algorithm", - "properties": [ - { - "name": "hash", - "type": "AlgorithmIdentifier" + "name": "NOT_SUPPORTED_ERR", + "type": "number" }, { - "name": "label", - "type": "BufferSource" + "name": "INUSE_ATTRIBUTE_ERR", + "type": "number" }, { - "name": "context", - "type": "BufferSource" - } - ] - }, - { - "kind": "interface", - "name": "Pbkdf2Params", - "extends": "Algorithm", - "properties": [ - { - "name": "salt", - "type": "BufferSource" + "name": "INVALID_STATE_ERR", + "type": "number" }, { - "name": "iterations", + "name": "SYNTAX_ERR", "type": "number" }, { - "name": "hash", - "type": "AlgorithmIdentifier" - } - ] - }, - { - "kind": "interface", - "name": "RsaOtherPrimesInfo", - "properties": [ - { - "name": "r", - "type": "string" + "name": "INVALID_MODIFICATION_ERR", + "type": "number" }, { - "name": "d", - "type": "string" + "name": "NAMESPACE_ERR", + "type": "number" }, { - "name": "t", - "type": "string" - } - ] - }, - { - "kind": "interface", - "name": "JsonWebKey", - "properties": [ - { - "name": "kty", - "type": "string" + "name": "INVALID_ACCESS_ERR", + "type": "number" }, { - "name": "use?", - "type": "string" + "name": "VALIDATION_ERR", + "type": "number" }, { - "name": "key_ops?", - "type": "string[]" + "name": "TYPE_MISMATCH_ERR", + "type": "number" }, { - "name": "alg?", - "type": "string" + "name": "SECURITY_ERR", + "type": "number" }, { - "name": "kid?", - "type": "string" + "name": "NETWORK_ERR", + "type": "number" }, { - "name": "x5u?", - "type": "string" + "name": "ABORT_ERR", + "type": "number" }, { - "name": "x5c?", - "type": "string" + "name": "URL_MISMATCH_ERR", + "type": "number" }, { - "name": "x5t?", - "type": "string" + "name": "QUOTA_EXCEEDED_ERR", + "type": "number" }, { - "name": "ext?", - "type": "boolean" + "name": "TIMEOUT_ERR", + "type": "number" }, { - "name": "crv?", - "type": "string" + "name": "INVALID_NODE_TYPE_ERR", + "type": "number" }, { - "name": "x?", - "type": "string" - }, - { - "name": "y?", - "type": "string" - }, - { - "name": "d?", - "type": "string" - }, - { - "name": "n?", - "type": "string" - }, - { - "name": "e?", - "type": "string" - }, - { - "name": "p?", - "type": "string" - }, - { - "name": "q?", - "type": "string" - }, - { - "name": "dp?", - "type": "string" - }, - { - "name": "dq?", - "type": "string" - }, - { - "name": "qi?", - "type": "string" - }, - { - "name": "oth?", - "type": "RsaOtherPrimesInfo[]" - }, - { - "name": "k?", - "type": "string" - } - ] - }, - { - "kind": "property", - "name": "msCaching?", - "interface": "XMLHttpRequest", - "type": "string" - }, - { - "kind": "typedef", - "name": "MouseWheelEvent", - "flavor": "Web", - "type": "WheelEvent" - }, - { - "kind": "method", - "interface": "DataTransfer", - "name": "setDragImage", - "signatures": ["setDragImage(image: Element, x: number, y: number): void"] - }, - { - "kind": "method", - "interface": "Element", - "name": "insertAdjacentElement", - "signatures": ["insertAdjacentElement(position: InsertPosition, insertedElement: Element): Element | null"] - }, - { - "kind": "method", - "interface": "Element", - "name": "insertAdjacentHTML", - "signatures": ["insertAdjacentHTML(where: InsertPosition, html: string): void"] - }, - { - "kind": "method", - "interface": "Element", - "name": "insertAdjacentText", - "signatures": ["insertAdjacentText(where: InsertPosition, text: string): void"] - }, - { - "kind": "property", - "name": "secureConnectionStart", - "interface": "PerformanceTiming", - "readonly": true, - "type": "number" - }, - { - "kind": "property", - "interface": "HTMLLinkElement", - "name": "integrity", - "type": "string" - }, - { - "kind": "property", - "interface": "HTMLScriptElement", - "name": "integrity", - "type": "string" - }, - { - "kind": "property", - "interface": "KeyboardEvent", - "readonly": true, - "name": "code", - "type": "string" - }, - { - "kind": "property", - "interface": "KeyboardEventInit", - "name": "code?", - "type": "string" - }, - { - "kind": "interface", - "name": "ParentNode", - "flavor": "DOM", - "properties": [ - { - "name": "children", - "readonly": true, - "type": "HTMLCollection" - }, - { - "name": "firstElementChild", - "readonly": true, - "type": "Element | null" - }, - { - "name": "lastElementChild", - "readonly": true, - "type": "Element | null" - }, - { - "name": "childElementCount", - "readonly": true, + "name": "DATA_CLONE_ERR", "type": "number" } ] - }, - { - "kind": "extends", - "baseInterface": "ParentNode", - "interface": "Element" - }, - { - "kind": "extends", - "baseInterface": "ParentNode", - "interface": "Document" - }, - { - "kind": "extends", - "baseInterface": "ParentNode", - "interface": "DocumentFragment" - }, - { - "kind": "typedef", - "name": "ScrollRestoration", - "flavor": "DOM", - "type": "\"auto\" | \"manual\"" - }, - { - "kind": "property", - "interface": "History", - "name": "scrollRestoration", - "type": "ScrollRestoration" - }, - { - "kind": "method", - "interface": "CanvasPattern", - "name": "setTransform", - "signatures": ["setTransform(matrix: SVGMatrix): void"] - }, - { - "kind": "interface", - "name": "DocumentOrShadowRoot", - "flavor": "DOM", - "methods": [ - { - "name": "getSelection", - "signatures": ["getSelection(): Selection | null"] - }, - { - "name": "elementFromPoint", - "signatures": ["elementFromPoint(x: number, y: number): Element | null"] - }, - { - "name": "elementsFromPoint", - "signatures": ["elementsFromPoint(x: number, y: number): Element[]"] - } - ], - "properties": [ - { - "name": "activeElement", - "type": "Element | null", - "readonly": true - }, - { - "name": "stylesheets", - "type": "StyleSheetList", - "readonly": true - } - ] - }, - { - "kind": "interface", - "name": "ShadowRoot", - "extends": "DocumentOrShadowRoot, DocumentFragment", - "flavor": "DOM", - "properties": [ - { - "name": "host", - "type": "Element", - "readonly": true - }, - { - "name": "innerHTML", - "type": "string" - } - ] - }, - { - "kind": "method", - "interface": "Element", - "name": "attachShadow", - "signatures": ["attachShadow(shadowRootInitDict: ShadowRootInit): ShadowRoot"] - }, - { - "kind": "property", - "interface": "Element", - "name": "assignedSlot", - "type": "HTMLSlotElement | null", - "readonly": true - }, - { - "kind": "property", - "interface": "Element", - "name": "slot", - "type": "string" - }, - { - "kind": "property", - "interface": "Element", - "name": "shadowRoot", - "type": "ShadowRoot | null", - "readonly": true - }, - { - "kind": "interface", - "name": "ShadowRootInit", - "flavor": "DOM", - "properties": [ - { - "name": "mode", - "type": "\"open\" | \"closed\"" - }, - { - "name": "delegatesFocus?", - "type": "boolean" - } - ] - }, - { - "kind": "property", - "interface": "Text", - "name": "assignedSlot", - "type": "HTMLSlotElement | null", - "readonly": true - }, - { - "kind": "interface", - "name": "HTMLSlotElement", - "extends": "HTMLElement", - "flavor": "DOM", - "properties": [ - { - "name": "name", - "type": "string" - } - ], - "methods": [ - { - "name": "assignedNodes", - "signatures": ["assignedNodes(options?: AssignedNodesOptions): Node[]"] - } - ] - }, - { - "kind": "interface", - "name": "AssignedNodesOptions", - "flavor": "DOM", - "properties": [ - { - "name": "flatten?", - "type": "boolean" - } - ] - }, - { - "kind": "property", - "interface": "EventInit", - "name": "scoped?", - "type": "boolean" - }, - { - "kind": "property", - "interface": "Event", - "name": "scoped", - "type": "boolean", - "readonly": true - }, - { - "kind": "method", - "interface": "Event", - "name": "deepPath", - "signatures": ["deepPath(): EventTarget[]"] - }, - { - "kind": "interface", - "name": "ElementDefinitionOptions", - "flavor": "DOM", - "properties": [{ - "name": "extends", - "type": "string" - }] - }, - { - "kind": "interface", - "name": "CustomElementRegistry", - "flavor": "DOM", - "methods": [{ - "name": "define", - "signatures": ["define(name: string, constructor: Function, options?: ElementDefinitionOptions): void"] - }, { - "name": "get", - "signatures": ["get(name: string): any"] - }, { - "name": "whenDefined", - "signatures": ["whenDefined(name: string): PromiseLike"] - }] - }, - { - "kind": "property", - "interface": "Window", - "name": "customElements", - "type": "CustomElementRegistry" - }, - { - "kind": "interface", - "name": "PromiseRejectionEvent", - "extends": "Event", - "flavor": "Web", - "properties": [{ - "name": "promise", - "type": "PromiseLike", - "readonly": true - }, { - "name": "reason", - "type": "any", - "readonly": true - }] - }, - { - "kind": "interface", - "name": "PromiseRejectionEventInit", - "extends": "EventInit", - "flavor": "Web", - "properties": [{ - "name": "promise", - "type": "PromiseLike" - }, { - "name": "reason?", - "type": "any" - }] - }, - { - "kind": "method", - "interface": "Body", - "name": "formData", - "flavor": "Web", - "signatures": ["formData(): Promise"] - }, - { - "kind": "method", - "interface": "DocumentFragment", - "name": "getElementById", - "flavor": "DOM", - "signatures": ["getElementById(elementId: string): HTMLElement | null"] - }, - { - "kind": "typedef", - "name": "FormDataEntryValue", - "type": "string | File" - }, - { - "kind": "method", - "interface": "FormData", - "name": "delete", - "flavor": "Web", - "signatures": ["delete(name: string): void"] - }, - { - "kind": "method", - "interface": "FormData", - "name": "get", - "flavor": "Web", - "signatures": ["get(name: string): FormDataEntryValue | null"] - }, - { - "kind": "method", - "interface": "FormData", - "name": "getAll", - "flavor": "Web", - "signatures": ["getAll(name: string): FormDataEntryValue[]"] - }, - { - "kind": "method", - "interface": "FormData", - "name": "has", - "flavor": "Web", - "signatures": ["has(name: string): boolean"] - }, - { - "kind": "method", - "interface": "FormData", - "name": "set", - "flavor": "Web", - "signatures": ["set(name: string, value: string | Blob, fileName?: string): void"] - }, - { - "kind": "interface", - "name": "EventListenerOptions", - "properties": [{ - "name": "capture?", - "type": "boolean" - }] - }, - { - "kind": "interface", - "name": "AddEventListenerOptions", - "extends": "EventListenerOptions", - "properties": [{ - "name": "passive?", - "type": "boolean" - }, { - "name": "once?", - "type": "boolean" - }] - }, - { - "kind": "interface", - "name": "TouchEventInit", - "flavor": "Web", - "extends": "EventModifierInit", - "properties": [{ - "name": "touches?", - "type": "Touch[]" - }, { - "name": "targetTouches?", - "type": "Touch[]" - }, { - "name": "changedTouches?", - "type": "Touch[]" - }] - }, - { - "kind": "typedef", - "name": "InsertPosition", - "flavor": "Web", - "type": "\"beforebegin\" | \"afterbegin\" | \"beforeend\" | \"afterend\"" - }, - { - "kind": "property", - "interface": "IntersectionObserverEntryInit", - "name": "isIntersecting", - "type": "boolean" - }, - { - "kind": "property", - "interface": "IntersectionObserverEntry", - "name": "isIntersecting", - "type": "boolean", - "readonly": true - }, - { - "kind": "property", - "interface": "ValidityState", - "name": "tooShort", - "flavor": "Web", - "readonly": true, - "type": "boolean" - }, - { - "kind": "interface", - "name": "HTMLDialogElement", - "constructorSignatures": ["new(): HTMLDialogElement"], - "extends": "HTMLElement", - "flavor": "DOM", - "properties": [ - { - "name": "open", - "type": "boolean" - }, - { - "name": "returnValue", - "type": "string" - } - ], - "methods": [ - { - "name": "close", - "signatures": ["close(returnValue?: string): void"] - }, - { - "name": "show", - "signatures": ["show(): void"] - }, - { - "name": "showModal", - "signatures": ["showModal(): void"] - } - ] - }, - { - "kind": "property", - "interface": "Response", - "name": "redirected", - "readonly": true, - "type": "boolean" - }, - { - "kind": "interface", - "name": "HTMLMainElement", - "constructorSignatures": ["new(): HTMLMainElement"], - "extends": "HTMLElement", - "flavor": "DOM" - }, - { - "kind": "interface", - "name": "HTMLDetailsElement", - "constructorSignatures": ["new(): HTMLDetailsElement"], - "extends": "HTMLElement", - "flavor": "DOM", - "properties": [ - { - "name": "open", - "type": "boolean" - } - ] - }, - { - "kind": "interface", - "name": "HTMLSummaryElement", - "constructorSignatures": ["new(): HTMLSummaryElement"], - "extends": "HTMLElement", - "flavor": "DOM" } ] diff --git a/inputfiles/browser.webidl.xml b/inputfiles/browser.webidl.xml index 4ae841ac2..10128a46c 100644 --- a/inputfiles/browser.webidl.xml +++ b/inputfiles/browser.webidl.xml @@ -1,37 +1,35 @@ - + - + + + + + + - - - - - - - - - + + + + + + + + + + - - - - - - - - @@ -45,20 +43,35 @@ + + + + + + + + + + + + + + - + - + - + - - + + + @@ -66,59 +79,190 @@ - - - - - - - - - - - - - - - + - + + + + + + + + + + + + + + + + + + + - - + + - + - - - - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + - + + + + + + + + + - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + - + - - - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + @@ -129,20 +273,40 @@ - + + + + + + + + + + + + + + + + + + + - - - - - - + + + + + + + + - + @@ -151,9 +315,9 @@ - + - + @@ -180,10 +344,30 @@ - + + + + + + + + + + + + + + + + + + + + + - - + + @@ -191,24 +375,25 @@ - + - - - + + - + - + + + - - + + - + @@ -219,13 +404,56 @@ - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + @@ -240,11 +468,60 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + - + @@ -253,6 +530,12 @@ + + + + + + @@ -266,7 +549,6 @@ - @@ -274,9 +556,35 @@ - + + + + + + + + + + + + + + + + + + + + + + + + + + + - + @@ -284,26 +592,33 @@ - + + + + + + + + + + + + + - - - - - + + + - + - - - - + - + @@ -311,29 +626,102 @@ + + + + + - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + - - - - - + + + + + + + @@ -343,13 +731,37 @@ + + + + + + + + + + + + + + + + + + + + + + - + + + @@ -361,6 +773,11 @@ + + + + + @@ -369,17 +786,19 @@ - - + + - + - + + - + + @@ -388,40 +807,49 @@ - + - - + + + + + + + - + - + + + - + - + - + - + + - - + + - - - - - + + + + + + @@ -431,28 +859,32 @@ - - - - - - - - - - - + + + + + + + + + + + + + + + @@ -461,25 +893,28 @@ - - - - - - - - - - - + + + + + + + + + + + + + - - - + + + + @@ -493,496 +928,382 @@ - + - - - - - + + + + + + + - + - - - - - - - - - - - - - - - - + + - + - - - - - - - - - - - - - - - - - - - + + + - + - - - - - - + + - + - - - - + + + + + + + + + + + + + + + - + - - - + - + - - - + + + + - + - + - + - + - + - - + + + + + + + + + + + + + + - + - - + + + - + - - - - - - - + + + - + - - + + - + - - - - - - - - - - - - - - - - - - - - - - + + + + - + - - - + + - + - - - + + + - + - - + + - + - - - - + + + + + - - - - - - + + - + - - - - - + + + + - + - + + + - + - - + - + - + - + - - + + - + - - + + + + + + + + - + - + - + - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + - + - - - - - - + + + - + - - - - - - + + - + - - - - - - - - - - - - - - - - - - - - - - + - + - - - - - - - - - - - - - - - - - - - - - - - - - - + + - + - - - - - - - + + - + - - - - - + + + - + - + - + - - - + + + + + + + + + + + + - + - - - - - + + + - + - - - - + - + - - - + - + - - + - + - - - - - + + - - + - - - - + + - + - + - + - - - - - - - - + + + - + - + - + + + + - - - + - + - - - + + + + - + - - + + + + + + - + - + + + + + + + - + - - - - - - - - - - - - + - + - - - + + + + + + + - + - - - - + + + + + + + + @@ -991,53 +1312,28 @@ - - - - - - - - - - - - - - - - - + - - + - - - - - - - - - - + - - - + + + + - - + + @@ -1046,52 +1342,119 @@ + + + + + - + + + + + + + - + - - - + + + + + + + + + - - - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + @@ -1100,124 +1463,117 @@ + + - + + + + + + + - - - + + + + + + + + + + + + + + + + - + + - + - - + + - - - + - - + + - - - - - - - - - - - - + + + - - - - - - - - - - - - - - + + + - - - - + + - - - - - - + + + + + + - - - + - - - - + @@ -1228,8 +1584,8 @@ - + @@ -1244,58 +1600,50 @@ + + - + - - - + + + - - - - - - - - - - - - - - - - - - - + + - + - - + + + - - + + + + + + + + @@ -1307,54 +1655,83 @@ - + - - - + + - + - - - - + - + - - + + - + + + + - - - - - + - + - - - - + + + + + + + + + + + + + + + + + + - + - - - + + - + - + + + + + + + + + + + + + + + + + + + + + + @@ -1364,8 +1741,9 @@ - - + + + @@ -1374,15 +1752,22 @@ - + + + + + + - - - - - - + + + + + + + + @@ -1393,9 +1778,21 @@ - - - + + + + + + + + + + + + + + + @@ -1404,11 +1801,20 @@ segments sequence + + balanced + interactive + playback + suspended running closed + + blob + arraybuffer + lowpass highpass @@ -1419,10 +1825,45 @@ notch allpass + + + maybe + probably + + + ltr + rtl + inherit + nonzero evenodd + + butt + round + square + + + round + bevel + miter + + + start + end + left + right + center + + + top + hanging + middle + alphabetic + ideographic + bottom + max clamped-max @@ -1432,21 +1873,39 @@ speakers discrete + + window + worker + sharedworker + all + + + none + default + + + margin + border + padding + content + linear inverse exponential - - character - word - sentence - textedit + + loading + interactive + complete + + + network + decode - - mouse - keyboard - gamepad + + + standard next @@ -1463,10 +1922,35 @@ readwrite versionchange - - inactive - active - disambiguation + + none + flipY + + + low + medium + high + + + raw + spki + pkcs8 + jwk + + + public + private + secret + + + encrypt + decrypt + sign + verify + deriveKey + deriveBits + wrapKey + unwrapKey audioinput @@ -1482,7 +1966,6 @@ temporary persistent-license - persistent-release-message required @@ -1492,8 +1975,9 @@ usable expired + released + output-restricted output-downscaled - output-not-allowed status-pending internal-error @@ -1501,70 +1985,26 @@ live ended - - FIDO_2_0 + + navigate + reload + back_forward + prerender - - os - stun - turn - peer-derived - - - failed - direct - relay - - - description - localclientevent - inbound-network - outbound-network - inbound-payload - outbound-payload - transportdiagnostics - - - Embedded - USB - NFC - BT - - - unknown - defer - allow - deny - - - geolocation - unlimitedIndexedDBQuota - media - pointerlock - webnotifications - - - up - down - left - right - - - navigate - reload - back_forward - prerender - - - auto - ltr - rtl + + auto + ltr + rtl default denied granted + + 2d + webgl + sine square @@ -1579,32 +2019,46 @@ equalpower + HRTF - success fail - + success + unknown shipping delivery pickup + + none + premultiply + default + p256dh auth - granted denied + granted prompt + + closed + open + ended + no-referrer no-referrer-when-downgrade - origin-only + same-origin + origin + strict-origin origin-when-cross-origin + strict-origin-when-cross-origin unsafe-url @@ -1613,6 +2067,7 @@ reload no-cache force-cache + only-if-cached omit @@ -1621,11 +2076,22 @@ + audio document + embed + font + image + manifest + object + report + script + serviceworker sharedworker - subresource - unknown + style + track + video worker + xslt navigate @@ -1648,6 +2114,12 @@ track video + + pixelated + low + medium + high + basic cors @@ -1661,21 +2133,40 @@ max-compat max-bundle + + connecting + open + closing + closed + maintain-framerate maintain-resolution balanced - - auto - client - server - new connecting connected closed + failed + + + disabled + enabled + + + data-channel-failure + idp-bad-script-failure + idp-execution-failure + idp-load-failure + idp-need-login + idp-timeout + idp-tls-failure + idp-token-expired + idp-token-invalid + sctp-failure + sdp-syntax-error host @@ -1684,8 +2175,8 @@ relay - RTP - RTCP + rtp + rtcp new @@ -1696,6 +2187,10 @@ disconnected closed + + password + oauth + new gathering @@ -1706,11 +2201,6 @@ gathering complete - - all - nohost - relay - udp tcp @@ -1725,7 +2215,6 @@ so - none relay all @@ -1734,13 +2223,39 @@ checking connected completed + failed + disconnected + closed + + + new + connecting + connected disconnected + failed closed + + very-low + low + medium + high + + + negotiate + require + + + sendrecv + sendonly + recvonly + inactive + offer pranswer answer + rollback stable @@ -1758,25 +2273,40 @@ succeeded cancelled - - host - serverreflexive - peerreflexive - relayed - + - inboundrtp - outboundrtp - session - datachannel + codec + inbound-rtp + outbound-rtp + peer-connection + data-channel track transport - candidatepair - localcandidate - remotecandidate + candidate-pair + local-candidate + remote-candidate + certificate - - ScopedCred + + auto + instant + smooth + + + start + center + end + nearest + + + auto + manual + + + select + start + end + preserve installing @@ -1785,10 +2315,48 @@ activated redundant - - usb - nfc - ble + + open + closed + + + no-speech + aborted + audio-capture + network + not-allowed + service-not-allowed + bad-grammar + language-not-supported + + + canceled + interrupted + audio-busy + audio-hardware + network + synthesis-unavailable + synthesis-failed + language-unavailable + voice-unavailable + text-too-long + invalid-argument + + + subtitles + captions + descriptions + chapters + metadata + + + disabled + hidden + showing + + + direct + stylus user @@ -1802,6 +2370,15 @@ prerender unloaded + + default + low-power + high-performance + + + classic + module + arraybuffer @@ -1813,6 +2390,10 @@ + + + + @@ -1835,47 +2416,15 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - + + - - - - - - - - - - + + @@ -1887,6 +2436,22 @@ + + + + + + + + + + + + + + + + @@ -1897,42 +2462,31 @@ - - - - - - - - - - - - - - - - - + + - - + + + + + + - + - + @@ -1941,24 +2495,22 @@ - - + + - - - - + + + + + - + - - - @@ -1966,73 +2518,35 @@ - + + + - + + + + - - - - - - - - - - - - - - - - - - - - - - - - + - - - - - - - - - - - - - - - - - - + + - + - - - - - - + + @@ -2043,27 +2557,29 @@ - - - - - - + + + + + + - - - - - - - - + + + - - + + + + + + + + + @@ -2073,21 +2589,50 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + - + + + + - + @@ -2100,7 +2645,7 @@ - + @@ -2114,58 +2659,187 @@ + + + + + + + + + + + + + + + + + + + + + + + - + - - + + + + + + + + + + + + + + + + + + + + - - + + + - - + + + + + + + + + + - - - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + - + + + + + @@ -2181,14 +2855,15 @@ - - + + + + + - - - - + + @@ -2197,233 +2872,136 @@ - + + + + + + + + + + + + + + + + + + + + + - + - + - + - + - + - + - + - + - + - + - - + + - + - + - + - - - CanvasPathMethods + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + - - - - - - - - - - - - - - - - - - + CanvasState + CanvasTransform + CanvasCompositing + CanvasImageSmoothing + CanvasFillStrokeStyles + CanvasShadowStyles + CanvasFilters + CanvasRect + CanvasDrawPath + CanvasUserInterface + CanvasText + CanvasDrawImage + CanvasImageData + CanvasPathDrawingStyles + CanvasTextDrawingStyles + CanvasPath - - - - - - - - - ChildNode + + + + + + + + + + + + + + + + + + + + + + + - + @@ -2431,12 +3009,12 @@ - + - + @@ -2447,202 +3025,139 @@ + NonDocumentTypeChildNode + ChildNode - + + + + + + + - - - - - - + + + + - + - - + + + + + + + + + - - - + + + + - + - + - + - - - - - - - - - - - + - - - - + + + + - + + + + + + + + + + + + + + + + + + + + + + + + + - - - - - - - + + - - + + + + + + + + + - + - - - - + + - - - + + + - - - + + - - - + + + + + + + + + + + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - RandomSource - - - - - - - - - - - - - - - - - - - - - - - + + + - - - - - - - - + @@ -2651,8 +3166,8 @@ - - + + @@ -2661,50 +3176,54 @@ - - + + - + - + - + - - + + - + + + + + + + - + - - + + - + - - - + @@ -2715,501 +3234,520 @@ + - - - - - + + + - + - + - - + + - - + + - + - - + + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + - - + - - - - - - - - - - - - - - - + - + - - - - - - - - - - - - - - - - + - + + + + + + + + + + + + + + + + - + - - - - + + + + - - - - - - + - + + - - + + - + + + + + + - + - + - + - @@ -3217,14 +3755,20 @@ + + + + + + + + + - - - @@ -3233,130 +3777,75 @@ - + - - + + + + + - - - + + + + + + + - - - - - - - - - - - - - - + + - + - + - - - - - - - - - - - - - - - + + + + - + - - - - - - - - - - - - - - - - - - - - - + + + - - - - - - - - - - - - - - - - - - - - - GlobalEventHandlers - NodeSelector - DocumentEvent + + - + - - - + + + - + - + @@ -3367,24 +3856,21 @@ - + + - + + - - - + + - - - - - - + + @@ -3395,82 +3881,63 @@ - + - - - - + + + + - - - + + - - - + + + - - - - - - + + + - - - - - - - - - - + - + + - - + + - - + + - + - - - - - - + + - - - - - + + + - - - - - + + + + @@ -3484,235 +3951,108 @@ - - - - - - - + - + - + - + - + - - - + + + + - - - + + + + - + - + - + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + + + - - - - + + + - + - - + - - - - - - - + NonElementParentNode + DocumentOrShadowRoot + ParentNode + GeometryUtils + + + + + + GlobalEventHandlers + DocumentAndElementEventHandlers + + + + + + + + + - - NodeSelector + + + NonElementParentNode + ParentNode - - ChildNode + - - - + ChildNode - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + - - - - + + + + @@ -3720,107 +4060,387 @@ - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + - - + + - + + + + + + + + + + + + - + + + + - + + + + + + + - - + + - - + + - + + + + - - - - - - - - + + + + + + + + + + - - + + - - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + - + - + - + + + + + + + + - + + + + - - - - - - - - - - - - - - - - - - - - - - - - - + + + + - + + + + + @@ -3830,49 +4450,154 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + ParentNode + NonDocumentTypeChildNode + ChildNode + Slotable + GeometryUtils @@ -3883,27 +4608,8 @@ - - - - - - - - - - - - - - - - - - - @@ -3921,14 +4627,9 @@ - - - - - @@ -3953,195 +4654,44 @@ - - - - - - - - - - GlobalEventHandlers - ElementTraversal - NodeSelector - ChildNode - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + - + - - - - - - - - - - - - + + - + + + + + + - - - - + - - - + + + @@ -4151,80 +4701,116 @@ - + + - - - - + + - + + + + + + + + + + + + + + + + + + + + + + + + + + + + - - + + - + - - + + - - - - - - - - + + + + + - - - - - - - - - - - - - - - - - - - - + + - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + - - + + + + + + - + - - + - + @@ -4232,9 +4818,47 @@ - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + @@ -4242,180 +4866,183 @@ - MSBaseReader + + + - + - + - + - + - + - - - - + - - - - - - - - - - - + - + - + - + + + - - - - - + + - - + + + + - - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + - - + + - + + - - + + - - - - - - - - - - - - - - - - - - + - - + + - + - + - - + + - + - - - - - + + - + - - + + + + + - - - - - - + + - + - - - + + + - - - + + + - + + @@ -4438,216 +5065,148 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + + + + + + + + + + + + + + HTMLHyperlinkElementUtils + - - - - - - - - - - - - - - - - - - - - - - - - - - + + + + + + + + + + + + - - - - - - - - - - - - - - - - - - - - - - - + + + + + + + + + + + + HTMLHyperlinkElementUtils + - - + - - - + + + - - - DOML2DeprecatedColorProperty + + WindowEventHandlers - - + + + + + + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + - - + + - - - - + - - - - - - - - - - - + + + + + + + + + + + - + + - - - - - - - + - + - - - - + + + + + + + + + - - + + + + + + + + - + @@ -4661,51 +5220,85 @@ - - + + - + + + + + + + + + + + + + + + + + + + + - - - - - + + - - - - - - + + - - - - - + + - - - - - + + + + + + + + + + + + + + + + + + + + + + + + + + + GlobalEventHandlers + DocumentAndElementEventHandlers + ElementContentEditable + ElementCSSInlineStyle @@ -4749,419 +5342,230 @@ + + - - - - - - - - - - - - - - - - - - - - - - - + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + + + + - - - - - - GetSVGDocument - - - - - - - - - - - - - - - - - - - + - - - - + + + + + + - - - - - DOML2DeprecatedColorProperty - DOML2DeprecatedSizeProperty - + + + + - + - - - - - - - - - - - - - + + + - + + + + + - - - + + + - - - - - - - + + + + + + + - - - - - - - + + - GetSVGDocument - - - - - - - - - - - - - - - - - - + + + + + + + + + + + + + + + + + + + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + WindowEventHandlers + - - - - - - + + + - - - - - - - - DOML2DeprecatedColorProperty - DOML2DeprecatedSizeProperty - - - + + + + + + - - - - - + + - - - - + + + + + + + + + + + + + + + + + + + + + + + - GetSVGDocument - - - - - - - - - - - - - - - - - - - - - - - + - - - - - - - - - - - - - + + + - - - - - - - - - - - - + + + + + + + + - - - - - - + + + + + + + - - - - - - - - - + + + + + + + + + + + + + - - + + @@ -5172,144 +5576,147 @@ - - - - - - + + + + + - - - - - - - - - - - - - + + + + + + + + + + + + - - - - - - - - - - - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + - - - - - + + + + + + + + + + - - - - - - + + + + - - - - - - + + + - - - - - - + + + - + + + + + + + + + + + + + + + + + + + + + LinkStyle - LinkStyle - - - - - - - - - - - + - - - + + + - - - - - - - - - - - - - - - - - - - - - - - + + + + + + + + + + + + + + + + + + + + @@ -5323,241 +5730,213 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + - + - - - - - - - - - - - - - + + + + - + - + - - - + + + - + - + - - - - - - - - - - - - + + + - - + + - - + + - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + - - - + + + + + + + - - + + + + + + + - - - - - - - + + + + + - - - - - - - + + + + + + + + - - - - - - - + + + + - - - - - - - - - GetSVGDocument + + - - - - - - - - - - - - - - - - - - - - - - - - + + + + + + + + + + + + + + + + + + - - + + + + + + + - - - - - - - + + + + + - - - - - - - - - + + + - - + - - + + - - - + + + - + - + + - + @@ -5565,7 +5944,7 @@ - + @@ -5577,7 +5956,6 @@ - @@ -5587,356 +5965,361 @@ - - - + + + + + - - - - - - + + - - - - - + + + + + - - - + + + - - - - - - - - + + + + + - - - - - - + + + - + + + + + + + + + + + + + + - - - - - - - - - - - + - - - - - - - - + + + + + + - - + + - - - + + - + + - + + - - - + + + + + - - + + - + - + + + + + + + + + + + + + + + + - - - - - - - + + + + + + - - - - + + + + + + LinkStyle - LinkStyle - - - - - + - - - - - - + + - HTMLTableAlignment - - - - + + + + - - - - - - - - + + + + + + + + + + + + + - - - HTMLTableAlignment - - - + + + + + + - - - - - - + + - - - - - - - - + + + + - + - + - - - - - - - - - - + + + + + + + - - + + - - - - - - - - - + + + + - - HTMLTableAlignment - + - + - - + + - + + + + - - - - - - - HTMLTableAlignment - + - + + + + + + + - + - - - - - - - - - + + + + + + + + + + + - - - - - - - - - - - + + + + + + + + + + + + + + + + + - + - + + + + + + + - - + + - + @@ -5945,98 +6328,59 @@ - - - - - - - + + + - - + + + + + + - - - - - - + + + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + + - - - + + + + + + + + - - - - - - - + - + - + + + + + @@ -6050,21 +6394,17 @@ - + - - - - - + - + @@ -6077,12 +6417,22 @@ - - + + + + + + + + + + + + - + @@ -6093,38 +6443,47 @@ - + - + - + - + + + + + + + + + - + - + - + - - + + + - + @@ -6132,6 +6491,9 @@ + + + @@ -6151,85 +6513,91 @@ - + - + - + - - + + - + - + - + + + + + + + + + + + + - + + + + + - + + - - + + - + + + + + - - - - - - - - - + - - - + + + - - + + - - - - - - - - - - + + + + @@ -6238,20 +6606,34 @@ - + - - - + + + + + + + + + - + + + + + - + + + + + @@ -6260,10 +6642,34 @@ - + + + + + + + + + + + + + + + + + + + + + + + + - - + + + @@ -6271,7 +6677,33 @@ - + + + + + + + + + + + + + + + + + + + + + + + + + + + @@ -6287,9 +6719,9 @@ - + - + @@ -6297,96 +6729,67 @@ - + - - + + + - - - - - - - - - + + + + + + + - - - - - - - - - - - - - + + - - - - - - - - - - - - - - + + - - + + + - - - - - - - - - - - - - - - - + + + + + + + + + + - + @@ -6394,29 +6797,34 @@ - - - - + - + - + + + + + + + + + + - - + @@ -6426,17 +6834,16 @@ - - - + + - + @@ -6448,16 +6855,12 @@ - + - - - - @@ -6474,17 +6877,22 @@ - + + + + + + + + + - - - - + @@ -6494,6 +6902,9 @@ + + + @@ -6507,46 +6918,55 @@ - + - + - + - - + - + - + - + + - - - - - - + + + + + + + + + + + + + + + @@ -6556,24 +6976,37 @@ + + + + - + + + + + + + + + + + + - + + - + + + + - - - - - - @@ -6588,53 +7021,39 @@ - - - - - - - - - - - - - + + + + + + + + - + - - + + - + - + - - + + - - - - - - - - - - + - + @@ -6645,72 +7064,87 @@ + - - - - - + + + + + - + + + + + + + + + + + - + - - + + - + - + - + - - - - - - - + + + + + + + + - - - + + + + - - - - + - - + + - + + + + + + @@ -6722,11 +7156,11 @@ - + - - + + @@ -6735,1471 +7169,813 @@ - + - - - - - - - - - - - - - - - - - - + - - - - - - - - - - + + + + + - - - - + + - - - - - - - + + + + - - - - - - - - - - - - - - - - - - - - + + + + - - - - + + + + + + + + + + + + + + + + + + + + - - - + + + - - + + - - + + - - + + + - - + + - - + + - - - - - - - - - - - - - - - - - - - - - - - - - + - - + - - - - - - + + + + + - + + NavigatorID + NavigatorLanguage + NavigatorOnLine + NavigatorContentUtils + NavigatorCookies + NavigatorPlugins + NavigatorConcurrentHardware + NavigatorUserMedia - - - - - - - - - + + + + - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + - - + + + - + - - - - - + + + + + + + + + + + + + + + + + + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + + + + + + + + + - - - + + - - - - + + + + - - - - - - + + - - + + - - - + + - - - + + + + + - - + + + - - + + + - - - - - - - - - - + + + + + + + + + + + + + + - - - - - - + - - - - + + + - - - - - - + + + + + - - - - - - - - - - - + - - - - - - - - + + - - - - + + + + - - - - - - - - - + + + + + + + + + + + - - + + + + + + + + + + + + + + + + + + + + + + + + + + - + + + + + - - + + - + + + + + - + - + - + + + - - - - - - - - - - - - + + + - + + - - - - - + + + + + + + - - - + + + + + + + - - - + + - - - - - + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + + + CanvasState + CanvasTransform + CanvasCompositing + CanvasImageSmoothing + CanvasFillStrokeStyles + CanvasShadowStyles + CanvasFilters + CanvasRect + CanvasDrawPath + CanvasDrawImage + CanvasImageData + CanvasPathDrawingStyles + CanvasPath - + + + + + - - + + - + + + + + + - + + + + + - - + - - - - - + + + + + - + - - - - - - - - - - - MSBaseReader + + + + + - - - - - - - - - - - - - - - + + + + - - - - + + + + - + + + + + + + + + + + + + + - - - - - - - - - - - - - + + + + + + + + + + + + - + + + + - - - - - - - - - + CanvasPath - + - - + + + + + + + + + + + - - - - - - + + + + + + - - - - - - - - - - + + + - - - - - + + + + + + + + + + - + - + + - - - - + + - - + + + + + + - - - - - - - - - + + + + + + + + - + - - - - - - + + - - + + - + + + + - - - + + + + + - - + + + + - - + + + - + + + + + + - + - - + + + + - + + + + + + + + + - + + - + - + + + + + + + + + + - - NavigatorID - NavigatorOnLine - NavigatorContentUtils - NavigatorStorageUtils - NavigatorGeolocation - MSNavigatorDoNotTrack - MSFileSaver - NavigatorBeacon - NavigatorConcurrentHardware - NavigatorUserMedia + + + + - - - - - - - - - - + + + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + + - - - + + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + - - - - + + + + + + + + + + + + - - - - - - + - + + + + + + + + + + + + + + + + + + + + + - + - - + + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + - - - + + + + + + + - + - - - - + - - + + - - + + - - + + - - - - + - - - - - - - - - - - - - - + + + + + - - - + + + + + + + + - + + + + + - + - - - - - - - - - - - - - - - - - - + - - - - - - - - + + LinkStyle - + - + + - CanvasPathMethods - - - - - - - - - - - - - - - - + + + - + - - - + + - - - - - - - - - - - - - + + - + - + - - - - - + + + - + - - + + + + + + - - - - - - - - + - + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + + + + + + + + - + - - + + + - + + + + + - - - - + + - - - - - - - - - - - - + - - + + - + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + - + + + + + @@ -8210,88 +7986,109 @@ - + + + + + - - - - - + + - + + + + + + + + - + - + - - + + - + - + - - + + - + - + - - + - + - + - + - + + + + + + + + + + + + + + + + - + - + - Body @@ -8302,535 +8099,614 @@ - + - + - + + Body - + - + - Body + + + + + - + - + + - + + Body - - - - - - - - + - - - - - - - + + - - - - + - + + + + + + + + + + + + + + + + - + + + + + + + + + + + + + + + + + + + + + + + + - + - + + - - + + + + + + + + + + + + + + + + + + - - + + - - - - - + + + + - + - + - + + - - - - - - + - + + + + + + + + + + + + + + + + + + + + + + + + + + + + - + + + + + + + + + + + + - + - + + - - - - - - - - - - - - + + - + - + - - - - - - + - - - - - - - - - - - - - - + + - - - - - - - - - - - - - - - + - - - - - - - - - - - - + + + - - + + + + + + + + + + - - - + + + + + + + + + + + + + + + - - - + + + + - - + + + + - - - + + + + + + + + - - + + + - - + + - - - + + + + + + - - - + + + - + + + + - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + - + - + - + + + + - + - - - + + - - - + + + + + + + + + + + + + - + - - - - - - - - - - - + + + - - - - + + + - - - - - - - - + + - - - - + - - + + + + - - - + + - - - - - - + + + + + + + - - - - - - - + - - + + + + - - - - - - - - - + - + + + + + + + - - + + + + + + - + - + + - - - - - - - + + + + - - + + - + + + + + + - - + + + + - - - - - - - - - - + - - - + + - - - - - - - - + - - - + - + - - + + - - - - - - + + + - - + + - + - - + + - + - + - - - - + + + + - - + + - - - - - - - - - + + + + - + - - - - - - AbstractWorker + - + - + - - + AbstractWorker - - + + + - + - - + + + - - - - + + + + + + + + - - - - - + + + + - - - - - + + + + + + + + + + + + - - - + + + + + + + + + + + + @@ -8839,59 +8715,139 @@ - - + + - - - + + + + - + + + + + - + + + + + + + + + + + + + + + DocumentOrShadowRoot + + + + + + + + + + AbstractWorker + + + + + + + + + - - - - - + + + - - - - - + - + - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + - + + + + + + + + + @@ -8899,12 +8855,90 @@ - - - - + + - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + @@ -8913,28 +8947,48 @@ - + + + + + + + + + - - - - - + + - + + + + + + + + + + + + + + + + @@ -8944,21 +8998,6 @@ - - - - - - - - - - - - - - - @@ -8970,181 +9009,153 @@ + + + + - + - - + + - + - + - + - + - + - - - - - - - - - - - - - - - - - - - - - - - - - - + + + + - + + + + + - - - - - - + + + + + + - - - - - - - - - - - + - + - + - + - + - - + + - + - + - + - - + + - + - + - + - + - + - - - - + + + + - + - + - + - - - + + + - - + + - + - + - - + + - + - + - - - - - - - - - - - - SVGURIReference - + + + + + + + SVGURIReference + HTMLHyperlinkElementUtils + @@ -9226,8 +9237,8 @@ - - + + @@ -9242,43 +9253,21 @@ - - - - - - - - - - - - - - - - - - - - - - - - - + - - - + + + + - - - SVGUnitTypes + - + + + SVGUnitTypes + @@ -9290,143 +9279,74 @@ - - - - - - - + + + + + + + + + + + + + + SVGURIReference - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + - + + + + + + GlobalEventHandlers + SVGElementInstance + ElementCSSInlineStyle + + + - - - - - - - - - - - - - - - - - - - - - - - - - + - - - - + + + + + - - - - - - - - - - - - - - - - SVGFilterPrimitiveStandardAttributes - - - + + + + SVGFilterPrimitiveStandardAttributes + - - - @@ -9434,28 +9354,22 @@ - - SVGFilterPrimitiveStandardAttributes - - - + + + + SVGFilterPrimitiveStandardAttributes + - - - - - SVGFilterPrimitiveStandardAttributes - + + SVGFilterPrimitiveStandardAttributes + - - - @@ -9465,65 +9379,53 @@ - - SVGFilterPrimitiveStandardAttributes - - - - - - - + + + + + + + + SVGFilterPrimitiveStandardAttributes + - - - - - SVGFilterPrimitiveStandardAttributes - - - - - - - - - - - - + + + + + + + + + + + + SVGFilterPrimitiveStandardAttributes + - - - - - - - SVGFilterPrimitiveStandardAttributes - - - - - + + + + + + SVGFilterPrimitiveStandardAttributes + - - - @@ -9531,32 +9433,42 @@ - - SVGFilterPrimitiveStandardAttributes - - - - - + + + + + + SVGFilterPrimitiveStandardAttributes + + + + + + + + + + + + + - - + + + + + + SVGFilterPrimitiveStandardAttributes - - - - - - - SVGFilterPrimitiveStandardAttributes + @@ -9571,11 +9483,12 @@ - - - - - SVGFilterPrimitiveStandardAttributes + + + + + + @@ -9583,119 +9496,98 @@ - - - + + + + + SVGFilterPrimitiveStandardAttributes + - - - - - - - SVGFilterPrimitiveStandardAttributes - SVGURIReference + + SVGFilterPrimitiveStandardAttributes + SVGURIReference + - - - - SVGFilterPrimitiveStandardAttributes + - - + + - - - - - SVGFilterPrimitiveStandardAttributes - - - - + + + + + SVGFilterPrimitiveStandardAttributes + - - - - - SVGFilterPrimitiveStandardAttributes - - - + + + + SVGFilterPrimitiveStandardAttributes + - - - - + + + + - - - - - - - SVGFilterPrimitiveStandardAttributes - - - - - - + + + + + + + SVGFilterPrimitiveStandardAttributes + - - - - - - - - - + + + + + + + + + - - - - - SVGFilterPrimitiveStandardAttributes - + + SVGFilterPrimitiveStandardAttributes + - - - @@ -9704,125 +9596,104 @@ - - SVGFilterPrimitiveStandardAttributes - - - - - - + + + + + + + SVGFilterPrimitiveStandardAttributes + - - - - - - SVGUnitTypes - SVGURIReference - - - - - - - - - - - - - - + + + + + + + SVGURIReference + SVGUnitTypes + - - - - - - + - - - - - - - + + + + + + + + + + + + + + + + + - - - - SVGUnitTypes - SVGURIReference - - - + + + + SVGURIReference - - - - - SVGTests - - - - - + + + + - - - + + SVGTests + + - - - - - - - + + + + + + + + + SVGURIReference - SVGURIReference - - - - - - - + @@ -9855,12 +9726,18 @@ + + + + + + - + @@ -9879,67 +9756,29 @@ + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + + + + + + - - - - + + + + + - - - - - - - - - - - - @@ -9948,8 +9787,6 @@ - - SVGFitToViewBox @@ -9957,80 +9794,36 @@ - - - - - - - + + + + + + + + + SVGFitToViewBox + - - - - - - - - - - - - SVGTests - SVGUnitTypes - - - - - - + + + + + + + SVGUnitTypes + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + SVGURIReference + + + @@ -10040,12 +9833,18 @@ + + + + + + - + @@ -10064,462 +9863,69 @@ + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + - - + + + + + + + - - - - - - - - - - - - - - - - SVGTests - SVGUnitTypes SVGFitToViewBox SVGURIReference - - - - - - - - - - - - - - - - - - - - + + + + + + + - - + + - + - - + + - - + + - + - - + + + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + SVGAnimatedPoints + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + SVGAnimatedPoints + @@ -10544,85 +9950,55 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + + + + + + + + - - - - - - + + + + + + + - - - - - SVGURIReference - + + + SVGURIReference + + - - - - - - - + + + + + + + + - + @@ -10641,144 +10017,79 @@ + - - - - - - - - + + + + LinkStyle + - - - - - - - - - - - - - - - - - - - - - DocumentEvent - SVGFitToViewBox - SVGZoomAndPan - + - + - + - - + + - + - - - - - - - + + - - - - - - + + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + + + + + SVGFitToViewBox + SVGZoomAndPan + WindowEventHandlers + + + - - - - - - - - - - - - - - + SVGFitToViewBox + @@ -10788,20 +10099,20 @@ - + - + - + - + @@ -10814,92 +10125,14 @@ - - + + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - @@ -10908,27 +10141,24 @@ - - SVGURIReference - - - + + + + SVGURIReference + - - - - - + + + + + - - - @@ -10943,7 +10173,7 @@ - + @@ -10967,21 +10197,27 @@ - + + + + + + + - + - + - + @@ -11000,109 +10236,50 @@ + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + - - - - - - - - - - - - - SVGURIReference - - - - - - + + + + + + + SVGURIReference + + - - - - - SVGZoomAndPan SVGFitToViewBox - - - - - - - - - - - - - + SVGZoomAndPan + - + + + + + - - - - - + + - + @@ -11110,11 +10287,10 @@ - - - - - + + + + @@ -11123,57 +10299,26 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + Slotable + GeometryUtils - + + + + + + + + + + + + - - - - - - - - - - - - - - @@ -11183,70 +10328,77 @@ - - + + + - + - - - - - + + + - - - - - - - - - + + + - - - + + - - + + - - + + + + + + + + + + - + - - - - - - - - - + + + + + + + - + + + + + + + + + + @@ -11262,29 +10414,40 @@ + + + - - + + + + + - - - - + + + + + + + + + + + + - - - @@ -11299,103 +10462,117 @@ - + - + - - + + - - - - - - - - - - + + - + - - - - - - - + + + + + + + - - + - + - - - - - - - - - - + - - - - - - + - - + + - - - + + - + + + + - + - - - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + @@ -11405,6 +10582,7 @@ + @@ -11415,101 +10593,65 @@ - - + - + - + - - - - - + + + + + - - - - - - + + + + + + + + + + + + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + - - + + @@ -11520,1965 +10662,2427 @@ + WebGLRenderingContextBase + + + + + + + + + + + + + + + + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + + - - - - - - + + + - - - - + + - - - + + - - - + + - - - + + - - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + - - - - - - - - - - - - - - - - - - - - - - + + + + + - - - - + + + - - - - + + + + - - + + + + - - + + + - - - - - + + + - - + + + - - + + + + - - - - - + + + + - - + + + + - - - - - - - - + + + - - - - - - - - - + + + - - - - - - - - - + + + - - - - - - - - - + + - - - - - - + + + - - - + + - - + + + - - + + - - + + + - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + GlobalEventHandlers + WindowEventHandlers + WindowOrWorkerGlobalScope + WindowSessionStorage + WindowLocalStorage + GlobalPerformance + GlobalCrypto + SpeechSynthesisGetter + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + - - + + + + + + + + + + + + + + + + - - + + + + + + + AbstractWorker + + + + + + + + + + - - + + + + + + + + + + + + + WindowOrWorkerGlobalScope + + + + + + + + + GlobalPerformance + GlobalCrypto + + + + + + + + + + + + + + + + NavigatorID + NavigatorLanguage + NavigatorOnLine + NavigatorConcurrentHardware + + + + + + + + + - - + + + + + + + + + + + + + + + + + + - - - + + + - - - + + + + + + - - + + - - + + - - - - + + + - - - - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + - - + + + + + + + + + + + + + + + + + + + - - + + + + + + - - - - - - - + + + - - - - - - + + + + + + + + + + + + + + + + + + + + + + + + + + + - - + + + + + + - - + + + + + + + + + + - - - + + + + + + + - - - + + + - - + + + - - - + + - - - + + + + - - - - + + + + + - - - - + + + - - + + + + - - + + + + - - - + + + + + + + + + - - - + + + - - + + + + + + + - - - + + + + + + + + + + + + + + + + - - - + + - - + + + + + - - - - + + + + - - - + + + + + + + + - - - + + + + + + + + + + + + + + + + + - - - + + + + + + - - - + + + + + + + + - - - + + + + + + + - - + + + + + + + + + + - - - + + + - - + + + - - + + + + + - - + + + + + - - + + + + + + + - - + + + + + + + + + + + + + + + + - - + + + + + - - + + + + + - - - + + + + + + + + + + + + + + + + + + + + + + + - - - + + - - - - - - - - + + + + + - - - - - + + + + + + + + + + + + + + + + - - - + + + - - - - - + + + + + + + - - - + + - - - - + + + + + + + - - - - - + + + - - + + + + + + - - - + + + - - - - + + + - - - - - + + + + + + - - - - - - - + + - - - - + + + - - - - + + + + + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + + + GeometryUtils + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + - - - + + + + - - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + - - - + + + - - - + + + + - - - - + + + - - - + + + - - - - + + + - - - + + + - - - - - + + + + + - - - + + - - - - - + + + - - - + + + - - - - - - + + + + + - - - + + + + - - - - - - + + + + - - - + + + + - - - - + + - - - - + + - - - - + + + + + - - + + - - + + - - - + + + + + - - - + + - - - - + + + + + + + + - - - + + + + + + + + + - - - - - + + + + + + + + + - - - + + + + + + + + + - - - - - - + + + + + + - - - + + + - - - - - - - + + - - - - - + + - - - - - - - - - - - - - - - - - - - - - - - - - + + - - - - + + - - - - - + + - - - - + + - - + + - - + + - - + + + - - - - - + + + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + - - - - - - - - - - - - - - - - + + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + + - - + + + + + - - - - - - - - - - - - - - - - - - - - - - - - - - - + + - - - - - - - - - - - - - - - - - + + - - - - - - - - - - - - - - - + + + + + + + - - + + + + + + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - WindowTimers - WindowSessionStorage - WindowLocalStorage - WindowConsole - GlobalEventHandlers - IDBEnvironment - WindowBase64 - GlobalFetch - - - + + - - - + + - - - - + + + - - - + + + - - - - + + - - - + + + - - - + + + - - - + + + + - - - + + + + - - + + - - - - - + + - - - - + + + - - - - + + + - - - + + - - - + + + - - - + + + - - - + + - - - + + + + - - - + + + - - - + + + - - - + + + - - - + + + - - + + + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - AbstractWorker - - - - + + - - - - - - - - - - - - - - - - - - - - - - - - - - - XMLHttpRequestEventTarget - - - - - + + + - - - - - - - + + - - + + - - + + - - - + + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - XMLHttpRequestEventTarget - - - - - - + + - - - - - - - - + + - - + + - - - - - - + + + - - - - - - - - + + + - - - - - - + + + + + + + + - - - - - - - - - - - - - - - - - - - + + + + + - - - - - - - - - - - - - - - - - - + + + - - + + + + + - - - + + + - - - - - + + + + - - + + + + + - - - + + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + - - - - - - + + + + - - - - - - - + + + + + - - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + - - - + + + - - - + + + + + - - - - - + + + - - - - - + + + + + + - - - - - - - - - - - + + + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + + + + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + - - - + + + + - - - - - - + + + + - - + + + + - - + + - - + + - - + + + - - + + + - - - - - - - + + + + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + - - - - - - - - - + + + + + - - + + + - - - - - - + + + + + + - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + - - - - - - - - - - - - - - - - + + + + + + + - - + + + + + - - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + - - - - - - - WindowTimersExtension + + + + + + + - + - + - - - - + + + - - - - + + + + + + + - - - - - - + + + + + + + + - - - + + + + + + + + + - + - - - - - - - + - - - - + + + + + + + - + + + + + + + - + - + @@ -13487,19 +13091,80 @@ - - - - - - - - - - - - - - + + + + + + + + + + + + + + + + + + + - \ No newline at end of file + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/inputfiles/knownExposures.json b/inputfiles/knownExposures.json new file mode 100644 index 000000000..ed0e74d9c --- /dev/null +++ b/inputfiles/knownExposures.json @@ -0,0 +1,87 @@ +{ + "AddEventListenerOptions": "Window Worker", + "AlgorithmIdentifier": "Window Worker", + "BinaryType": "Window Worker", + "BodyInit": "Window Worker", + "BufferSource": "Window Worker", + "CacheQueryOptions": "Window Worker", + "CanvasFillRule": "Window Worker", + "CanvasImageSource": "Window Worker", + "CanvasLineCap": "Window Worker", + "CanvasLineJoin": "Window Worker", + "ClientQueryOptions": "ServiceWorker", + "ClientType": "ServiceWorker", + "CloseEventInit": "Window Worker", + "CustomEventInit": "Window Worker", + "DOMMatrixInit": "Window Worker", + "DOMPointInit": "Window Worker", + "DOMQuadInit": "Window Worker", + "DOMRectInit": "Window Worker", + "EventInit": "Window Worker", + "EventListenerOptions": "Window Worker", + "EventSourceInit": "Window Worker", + "ExtendableEventInit": "ServiceWorker", + "ExtendableMessageEventInit": "ServiceWorker", + "FetchEventInit": "ServiceWorker", + "ForeignFetchEventInit": "ServiceWorker", + "ForeignFetchOptions": "ServiceWorker", + "ForeignFetchResponse": "ServiceWorker", + "FormDataEntryValue": "Window Worker", + "GetNotificationOptions": "Window Worker", + "HeadersInit": "Window Worker", + "IDBCursorDirection": "Window Worker", + "IDBIndexParameters": "Window Worker", + "IDBObjectStoreParameters": "Window Worker", + "IDBRequestReadyState": "Window Worker", + "IDBTransactionMode": "Window Worker", + "IDBVersionChangeEventInit": "Window Worker", + "ImageBitmapSource": "Window Worker", + "ImageEncodeOptions": "Window Worker", + "ImageSmoothingQuality": "Window Worker", + "JsonWebKey": "Window Worker", + "KeyFormat": "Window Worker", + "KeyType": "Window Worker", + "KeyUsage": "Window Worker", + "MessageEventInit": "Window Worker", + "MessageEventSource": "Window Worker", + "NavigationPreloadState": "Window Worker", + "NotificationAction": "Window Worker", + "NotificationDirection": "Window Worker", + "NotificationEventInit": "ServiceWorker", + "NotificationOptions": "Window Worker", + "NotificationPermission": "Window Worker", + "NotificationPermissionCallback": "Window Worker", + "OffscreenRenderingContext": "Window Worker", + "OffscreenRenderingContextType": "Window Worker", + "OnErrorEventHandler": "Window Worker", + "OnErrorEventHandlerNonNull": "Window Worker", + "PerformanceEntryList": "Window Worker", + "PerformanceObserverCallback": "Window Worker", + "PerformanceObserverInit": "Window Worker", + "PromiseRejectionEventInit": "Window Worker", + "PushEncryptionKeyName": "Window Worker", + "PushEventInit": "ServiceWorker", + "PushMessageDataInit": "ServiceWorker", + "PushPermissionState": "Window Worker", + "PushSubscriptionChangeInit": "ServiceWorker", + "PushSubscriptionOptionsInit": "Window Worker", + "ReferrerPolicy": "Window Worker", + "RegistrationOptions": "Window Worker", + "RequestCache": "Window Worker", + "RequestCredentials": "Window Worker", + "RequestDestination": "Window Worker", + "RequestInfo": "Window Worker", + "RequestInit": "Window Worker", + "RequestMode": "Window Worker", + "RequestRedirect": "Window Worker", + "RequestType": "Window Worker", + "ResponseInit": "Window Worker", + "ResponseType": "Window Worker", + "RsaOtherPrimesInfo": "Window Worker", + "ServiceWorkerState": "Window Worker", + "SyncEventInit": "ServiceWorker", + "VisibilityState": "Window ServiceWorker", + "WorkerOptions": "Window Worker", + "WorkerType": "Window Worker", + "XMLHttpRequestResponseType": "Window Worker" +} \ No newline at end of file diff --git a/inputfiles/knownWorkerEnums.json b/inputfiles/knownWorkerEnums.json deleted file mode 100644 index cd779c566..000000000 --- a/inputfiles/knownWorkerEnums.json +++ /dev/null @@ -1,21 +0,0 @@ -[ - "IDBCursorDirection", - "IDBRequestReadyState", - "IDBTransactionMode", - "MediaKeyStatus", - "NotificationDirection", - "NotificationPermission", - "PushPermissionState", - "PushEncryptionKeyName", - "ReferrerPolicy", - "RequestCache", - "RequestCredentials", - "RequestDestination", - "RequestMode", - "RequestRedirect", - "RequestType", - "ResponseType", - "ServiceWorkerState", - "VisibilityState", - "XMLHttpRequestResponseType" -] \ No newline at end of file diff --git a/inputfiles/knownWorkerInterfaces.json b/inputfiles/knownWorkerInterfaces.json deleted file mode 100644 index 853c0e862..000000000 --- a/inputfiles/knownWorkerInterfaces.json +++ /dev/null @@ -1,105 +0,0 @@ -[ - "AbstractWorker", - "Algorithm", - "AlgorithmIdentifier", - "AudioBuffer", - "Blob", - "Body", - "BodyInit", - "Cache", - "CacheQueryOptions", - "CacheStorage", - "ClientQueryOptions", - "CloseEvent", - "CloseEventInit", - "Console", - "Coordinates", - "CryptoKey", - "DOMError", - "DOMException", - "DOMStringList", - "DecodeErrorCallback", - "DecodeSuccessCallback", - "ErrorEvent", - "ErrorEventHandler", - "Event", - "EventInit", - "EventListener", - "EventTarget", - "ExtendableEventInit", - "ExtendableMessageEventInit", - "FetchEventInit", - "File", - "FileList", - "FileReader", - "ForEachCallback", - "FormData", - "FunctionStringCallback", - "GetNotificationOptions", - "GlobalFetch", - "Headers", - "IDBCursor", - "IDBCursorWithValue", - "IDBDatabase", - "IDBFactory", - "IDBIndex", - "IDBIndexParameters", - "IDBKeyPath", - "IDBKeyRange", - "IDBObjectStore", - "IDBObjectStoreParameters", - "IDBOpenDBRequest", - "IDBRequest", - "IDBTransaction", - "IDBVersionChangeEvent", - "ImageData", - "KeyAlgorithm", - "MessageChannel", - "MessageEvent", - "MessageEventInit", - "MessagePort", - "MSBaseReader", - "NavigatorBeacon", - "NavigatorConcurrentHardware", - "NavigatorID", - "NavigatorOnLine", - "Notification", - "NotificationEventInit", - "NotificationOptions", - "NotificationPermissionCallback", - "ObjectURLOptions", - "Performance", - "PerformanceNavigation", - "PerformanceTiming", - "Position", - "PositionCallback", - "PositionError", - "PositionErrorCallback", - "ProgressEvent", - "PushEventInit", - "PushManager", - "PushSubscription", - "PushSubscriptionOptions", - "PushSubscriptionOptionsInit", - "ReadableStream", - "ReadableStreamReader", - "Request", - "RequestInfo", - "RequestInit", - "Response", - "ResponseInit", - "ServiceWorker", - "ServiceWorkerRegistration", - "SyncEventInit", - "SyncManager", - "USVString", - "URL", - "URLSearchParams", - "WebSocket", - "WindowBase64", - "WindowConsole", - "Worker", - "XMLHttpRequest", - "XMLHttpRequestEventTarget", - "XMLHttpRequestUpload" -] diff --git a/inputfiles/overridingTypes.json b/inputfiles/overridingTypes.json index 3e8a35df7..957112f4d 100644 --- a/inputfiles/overridingTypes.json +++ b/inputfiles/overridingTypes.json @@ -1,13 +1,4 @@ [ - { - "kind": "constructor", - "interface": "Response", - "signatures": [ - "new(body?: any, init?: ResponseInit): Response", - "error: () => Response", - "redirect: (url: string, status?: number) => Response" - ] - }, { "kind": "constructor", "interface": "ErrorEvent", @@ -333,13 +324,13 @@ "kind": "method", "interface": "SVGSVGElement", "name": "getEnclosureList", - "signatures": ["getEnclosureList(rect: SVGRect, referenceElement: SVGElement): NodeListOf"] + "signatures": ["getEnclosureList(rect: DOMRectReadOnly, referenceElement: SVGElement): NodeListOf"] }, { "kind": "method", "interface": "SVGSVGElement", "name": "getIntersectionList", - "signatures": ["getIntersectionList(rect: SVGRect, referenceElement: SVGElement): NodeListOf"] + "signatures": ["getIntersectionList(rect: DOMRectReadOnly, referenceElement: SVGElement): NodeListOf"] }, { "kind": "property", @@ -519,17 +510,11 @@ "name": "rows", "type": "HTMLCollectionOf" }, - { - "kind": "method", - "interface": "HTMLTableRowElement", - "name": "insertCell", - "signatures": ["insertCell(index?: number): HTMLTableDataCellElement"] - }, { "kind": "property", "interface": "HTMLTableRowElement", "name": "cells", - "type": "HTMLCollectionOf" + "type": "HTMLCollectionOf" }, { "kind": "method", @@ -617,50 +602,6 @@ "name": "open", "signatures": ["open(url?: string, target?: string, features?: string, replace?: boolean): Window"] }, - { - "kind": "method", - "interface": "AudioNode", - "name": "connect", - "signatures": [ - "connect(destination: AudioNode, output?: number, input?: number): AudioNode", - "connect(destination: AudioParam, output?: number): void" - ] - }, - { - "kind": "method", - "interface": "AudioNode", - "name": "disconnect", - "signatures": [ - "disconnect(output?: number): void", - "disconnect(destination: AudioNode, output?: number, input?: number): void", - "disconnect(destination: AudioParam, output?: number): void" - ] - }, - { - "kind": "callback", - "name": "DecodeErrorCallback", - "signatures": ["(error: DOMException): void"] - }, - { - "kind": "property", - "name": "ontouchcancel", - "type": "(ev: TouchEvent) => any" - }, - { - "kind": "property", - "name": "ontouchend", - "type": "(ev: TouchEvent) => any" - }, - { - "kind": "property", - "name": "ontouchmove", - "type": "(ev: TouchEvent) => any" - }, - { - "kind": "property", - "name": "ontouchstart", - "type": "(ev: TouchEvent) => any" - }, { "kind": "property", "name": "keyPath?", @@ -859,96 +800,6 @@ "baseInterface": "HTMLCollectionOf", "interface": "HTMLOptionsCollection" }, - { - "kind": "property", - "interface": "Algorithm", - "name": "name", - "type": "string" - }, - { - "kind": "method", - "interface": "SubtleCrypto", - "name": "decrypt", - "signatures": ["decrypt(algorithm: string | RsaOaepParams | AesCtrParams | AesCbcParams | AesCmacParams | AesGcmParams | AesCfbParams, key: CryptoKey, data: BufferSource): PromiseLike"] - }, - { - "kind": "method", - "interface": "SubtleCrypto", - "name": "deriveBits", - "signatures": ["deriveBits(algorithm: string | EcdhKeyDeriveParams | DhKeyDeriveParams | ConcatParams | HkdfCtrParams | Pbkdf2Params, baseKey: CryptoKey, length: number): PromiseLike"] - }, - { - "kind": "method", - "interface": "SubtleCrypto", - "name": "deriveKey", - "signatures": ["deriveKey(algorithm: string | EcdhKeyDeriveParams | DhKeyDeriveParams | ConcatParams | HkdfCtrParams | Pbkdf2Params, baseKey: CryptoKey, derivedKeyType: string | AesDerivedKeyParams | HmacImportParams | ConcatParams | HkdfCtrParams | Pbkdf2Params, extractable: boolean, keyUsages: string[]): PromiseLike"] - }, - { - "kind": "method", - "interface": "SubtleCrypto", - "name": "digest", - "signatures": ["digest(algorithm: AlgorithmIdentifier, data: BufferSource): PromiseLike"] - }, - { - "kind": "method", - "interface": "SubtleCrypto", - "name": "encrypt", - "signatures": ["encrypt(algorithm: string | RsaOaepParams | AesCtrParams | AesCbcParams | AesCmacParams | AesGcmParams | AesCfbParams, key: CryptoKey, data: BufferSource): PromiseLike"] - }, - { - "kind": "method", - "interface": "SubtleCrypto", - "name": "exportKey", - "signatures": [ - "exportKey(format: \"jwk\", key: CryptoKey): PromiseLike", - "exportKey(format: \"raw\" | \"pkcs8\" | \"spki\", key: CryptoKey): PromiseLike", - "exportKey(format: string, key: CryptoKey): PromiseLike" - ] - }, - { - "kind": "method", - "interface": "SubtleCrypto", - "name": "generateKey", - "signatures": [ - "generateKey(algorithm: string, extractable: boolean, keyUsages: string[]): PromiseLike", - "generateKey(algorithm: RsaHashedKeyGenParams | EcKeyGenParams | DhKeyGenParams, extractable: boolean, keyUsages: string[]): PromiseLike", - "generateKey(algorithm: AesKeyGenParams | HmacKeyGenParams | Pbkdf2Params, extractable: boolean, keyUsages: string[]): PromiseLike" - ] - }, - { - "kind": "method", - "interface": "SubtleCrypto", - "name": "importKey", - "signatures": [ - "importKey(format: \"jwk\", keyData: JsonWebKey, algorithm: string | RsaHashedImportParams | EcKeyImportParams | HmacImportParams | DhImportKeyParams, extractable: boolean, keyUsages: string[]): PromiseLike", - "importKey(format: \"raw\" | \"pkcs8\" | \"spki\", keyData: BufferSource, algorithm: string | RsaHashedImportParams | EcKeyImportParams | HmacImportParams | DhImportKeyParams, extractable: boolean, keyUsages: string[]): PromiseLike", - "importKey(format: string, keyData: JsonWebKey | BufferSource, algorithm: string | RsaHashedImportParams | EcKeyImportParams | HmacImportParams | DhImportKeyParams, extractable: boolean, keyUsages: string[]): PromiseLike" - ] - }, - { - "kind": "method", - "interface": "SubtleCrypto", - "name": "sign", - "signatures": ["sign(algorithm: string | RsaPssParams | EcdsaParams | AesCmacParams, key: CryptoKey, data: BufferSource): PromiseLike"] - }, - { - "kind": "method", - "interface": "SubtleCrypto", - "name": "unwrapKey", - "signatures": ["unwrapKey(format: string, wrappedKey: BufferSource, unwrappingKey: CryptoKey, unwrapAlgorithm: AlgorithmIdentifier, unwrappedKeyAlgorithm: AlgorithmIdentifier, extractable: boolean, keyUsages: string[]): PromiseLike"] - }, - { - "kind": "method", - "interface": "SubtleCrypto", - "name": "verify", - "signatures": ["verify(algorithm: string | RsaPssParams | EcdsaParams | AesCmacParams, key: CryptoKey, signature: BufferSource, data: BufferSource): PromiseLike"] - }, - { - "kind": "method", - "interface": "SubtleCrypto", - "name": "wrapKey", - "signatures": ["wrapKey(format: string, key: CryptoKey, wrappingKey: CryptoKey, wrapAlgorithm: AlgorithmIdentifier): PromiseLike"] - }, { "kind": "method", "name": "setTimeout", @@ -1089,11 +940,6 @@ "name": "evaluate", "signatures": ["evaluate(contextNode: Node, type: number, result: XPathResult | null): XPathResult"] }, - { - "kind": "extends", - "baseInterface": "Node, GlobalEventHandlers, NodeSelector, DocumentEvent, ParentNode, DocumentOrShadowRoot", - "interface": "Document" - }, { "kind": "property", "interface": "ElementTraversal", @@ -1138,256 +984,5 @@ "interface": "DOMImplementation", "name": "createDocument", "signatures": ["createDocument(namespaceURI: string | null, qualifiedName: string | null, doctype: DocumentType | null): Document"] - }, - { - "kind": "method", - "interface": "FormData", - "name": "append", - "flavor": "Web", - "signatures": ["append(name: string, value: string | Blob, fileName?: string): void"] - }, - { - "kind": "method", - "interface": "EventTarget", - "name": "addEventListener", - "signatures": ["addEventListener(type: string, listener?: EventListenerOrEventListenerObject, options?: boolean | AddEventListenerOptions): void"] - }, - { - "kind": "method", - "interface": "EventTarget", - "name": "removeEventListener", - "signatures": ["removeEventListener(type: string, listener?: EventListenerOrEventListenerObject, options?: boolean | EventListenerOptions): void"] - }, - { - "kind": "constructor", - "interface": "TouchEvent", - "signatures": [ - "new(type: string, touchEventInit?: TouchEventInit): TouchEvent" - ] - }, - { - "kind": "constructor", - "interface": "Text", - "signatures": [ - "new(data?: string): Text" - ] - }, - { - "kind": "method", - "interface": "HTMLMediaElement", - "name": "play", - "signatures": [ - "play(): Promise" - ] - }, - { - "kind": "constructor", - "interface": "DragEvent", - "signatures": [ - "new(type: \"drag\" | \"dragend\" | \"dragenter\" | \"dragexit\" | \"dragleave\" | \"dragover\" | \"dragstart\" | \"drop\", dragEventInit?: { dataTransfer?: DataTransfer }): DragEvent" - ] - }, - { - "kind": "property", - "interface": "HTMLAppletElement", - "readonly": true, - "name": "form", - "type": "HTMLFormElement | null" - }, - { - "kind": "property", - "interface": "HTMLButtonElement", - "readonly": true, - "name": "form", - "type": "HTMLFormElement | null" - }, - { - "kind": "property", - "interface": "HTMLFieldSetElement", - "readonly": true, - "name": "form", - "type": "HTMLFormElement | null" - }, - { - "kind": "property", - "interface": "HTMLInputElement", - "readonly": true, - "name": "form", - "type": "HTMLFormElement | null" - }, - { - "kind": "property", - "interface": "HTMLLabelElement", - "readonly": true, - "name": "form", - "type": "HTMLFormElement | null" - }, - { - "kind": "property", - "interface": "HTMLLegendElement", - "readonly": true, - "name": "form", - "type": "HTMLFormElement | null" - }, - { - "kind": "property", - "interface": "HTMLObjectElement", - "readonly": true, - "name": "form", - "type": "HTMLFormElement | null" - }, - { - "kind": "property", - "interface": "HTMLOptGroupElement", - "readonly": true, - "name": "form", - "type": "HTMLFormElement | null" - }, - { - "kind": "property", - "interface": "HTMLOptionElement", - "readonly": true, - "name": "form", - "type": "HTMLFormElement | null" - }, - { - "kind": "property", - "interface": "HTMLOutputElement", - "readonly": true, - "name": "form", - "type": "HTMLFormElement | null" - }, - { - "kind": "property", - "interface": "HTMLProgressElement", - "readonly": true, - "name": "form", - "type": "HTMLFormElement | null" - }, - { - "kind": "property", - "interface": "HTMLSelectElement", - "readonly": true, - "name": "form", - "type": "HTMLFormElement | null" - }, - { - "kind": "property", - "interface": "HTMLTextAreaElement", - "readonly": true, - "name": "form", - "type": "HTMLFormElement | null" - }, - { - "kind": "method", - "interface": "RandomSource", - "name": "getRandomValues", - "signatures": [ - "getRandomValues(array: T): T" - ] - }, - { - "kind": "property", - "interface": "HTMLAppletElement", - "readonly": true, - "name": "form", - "type": "HTMLFormElement | null" - }, - { - "kind": "property", - "interface": "HTMLButtonElement", - "readonly": true, - "name": "form", - "type": "HTMLFormElement | null" - }, - { - "kind": "property", - "interface": "HTMLFieldSetElement", - "readonly": true, - "name": "form", - "type": "HTMLFormElement | null" - }, - { - "kind": "property", - "interface": "HTMLInputElement", - "readonly": true, - "name": "form", - "type": "HTMLFormElement | null" - }, - { - "kind": "property", - "interface": "HTMLLabelElement", - "readonly": true, - "name": "form", - "type": "HTMLFormElement | null" - }, - { - "kind": "property", - "interface": "HTMLegendElement", - "readonly": true, - "name": "form", - "type": "HTMLFormElement | null" - }, - { - "kind": "property", - "interface": "HTMLObjectElement", - "readonly": true, - "name": "form", - "type": "HTMLFormElement | null" - }, - { - "kind": "property", - "interface": "HTMLOptGroupElement", - "readonly": true, - "name": "form", - "type": "HTMLFormElement | null" - }, - { - "kind": "property", - "interface": "HTMLOptionElement", - "readonly": true, - "name": "form", - "type": "HTMLFormElement | null" - }, - { - "kind": "property", - "interface": "HTMLOutputElement", - "readonly": true, - "name": "form", - "type": "HTMLFormElement | null" - }, - { - "kind": "property", - "interface": "HTMLProgressElement", - "readonly": true, - "name": "form", - "type": "HTMLFormElement | null" - }, - { - "kind": "property", - "interface": "HTMLSelectElement", - "readonly": true, - "name": "form", - "type": "HTMLFormElement | null" - }, - { - "kind": "property", - "interface": "HTMLTextAreaElement", - "readonly": true, - "name": "form", - "type": "HTMLFormElement | null" - }, - { - "kind": "constructor", - "interface": "Headers", - "signatures": [ - "new(init?: Headers | string[][] | object): Headers" - ] - }, - { - "kind": "method", - "interface": "ServiceWorkerContainer", - "name": "getRegistration", - "signatures": ["getRegistration(): Promise"] } ] diff --git a/inputfiles/removedTypes.json b/inputfiles/removedTypes.json index 9168ace44..9da674cee 100644 --- a/inputfiles/removedTypes.json +++ b/inputfiles/removedTypes.json @@ -77,5 +77,9 @@ { "kind": "typedef", "name": "JSON" + }, + { + "kind": "typedef", + "name": "ArrayBufferView" } ] diff --git a/inputfiles/sample.json b/inputfiles/sample.json index d516ad12f..beebf60ad 100644 --- a/inputfiles/sample.json +++ b/inputfiles/sample.json @@ -348,5 +348,31 @@ "type": "HTMLCollection" } ] + }, + { + "kind": "interface", + "name": "DOMException", + "extends": "Error", + "properties": [ + { + "name": "name", + "type": "string", + "readonly": true + }, + { + "name": "code", + "type": "number", + "readonly": true + } + ], + "constructorSignatures": [ + "new (message?: string, name?: string): DOMException" + ], + "constants": [ + { + "name": "INDEX_SIZE_ERR", + "type": "number" + } + ] } ] diff --git a/sample.xml b/sample.xml index 3cea2a352..e1bc211fd 100644 --- a/sample.xml +++ b/sample.xml @@ -2195,7 +2195,7 @@ - + @@ -3066,77 +3066,6 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - @@ -6276,13 +6205,18 @@ - - + + + + + + + - - - + + + @@ -11386,6 +11320,9 @@ + + + @@ -12971,7 +12908,7 @@ - + @@ -13516,4 +13453,64 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file