UNPKG

5.46 kBTypeScriptView Raw
1declare var _: string;
2export = _;
3
4import * as angular from "angular";
5
6declare module "angular" {
7 ///////////////////////////////////////////////////////////////////////////////
8 // ngSanitize module (angular-sanitize.js)
9 // see https://code.angularjs.org/1.7.0/docs/api/ngSanitize
10 ///////////////////////////////////////////////////////////////////////////////
11 namespace sanitize {
12 /**
13 * Sanitizes an html string by stripping all potentially dangerous tokens.
14 *
15 * The input is sanitized by parsing the HTML into tokens.
16 * All safe tokens (from a trusted list) are then serialized back to a properly
17 * escaped HTML string.
18 * This means that no unsafe input can make it into the returned string.
19 *
20 * URLs allowed in attribute values are configured using the methods aHrefSanitizationTrustedUrlList
21 * and imgSrcSanitizationTrustedUrlList of $compileProvider.
22 * The input may also contain SVG markup if this is enabled via $sanitizeProvider.
23 *
24 * @param html HTML input.
25 */
26 interface ISanitizeService {
27 (html: string): string;
28 }
29
30 /**
31 * Creates and configures $sanitize instance.
32 */
33 interface ISanitizeProvider {
34 /**
35 * Enables a subset of svg to be supported by the sanitizer.
36 *
37 * @see https://code.angularjs.org/1.7.0/docs/api/ngSanitize/provider/$sanitizeProvider#enableSvg
38 * @param flag Enable or disable SVG support in the sanitizer.
39 */
40 enableSvg(): boolean;
41 enableSvg(flag: boolean): ISanitizeProvider;
42 enableSvg(flag?: boolean): boolean | ISanitizeProvider;
43
44 /**
45 * Extends the built-in lists of valid HTML/SVG elements, i.e. elements that are considered safe and are not stripped off during sanitization.
46 *
47 * You can extend the following lists of elements:
48 * htmlElements: A list of elements (tag names) to extend the current list of safe HTML elements. HTML elements considered safe will not be removed during sanitization. All other elements will be stripped off.
49 * htmlVoidElements: This is similar to htmlElements, but marks the elements as "void elements" (similar to HTML void elements). These elements have no end tag and cannot have content.
50 * svgElements: This is similar to htmlElements, but for SVG elements. This list is only taken into account if SVG is enabled for $sanitize.
51 *
52 * @see https://code.angularjs.org/1.7.0/docs/api/ngSanitize/provider/$sanitizeProvider#addValidElements
53 * @param elements A list of valid HTML elements or an object with one or more of the following properties: htmlElements, htmlVoidElements, svgElements
54 */
55 addValidElements(
56 elements: string[] | {
57 htmlElements?: string[] | undefined;
58 htmlVoidElements?: string[] | undefined;
59 svgElements?: string[] | undefined;
60 },
61 ): ISanitizeProvider;
62
63 /**
64 * Extends the built-in list of valid attributes, i.e. attributes that are considered safe and are not stripped off during sanitization.
65 *
66 * Note: The new attributes will not be treated as URI attributes, which means their
67 * values will not be sanitized as URIs using $compileProvider's
68 * aHrefSanitizationTrustedUrlList and imgSrcSanitizationTrustedUrlList.
69 * @see https://code.angularjs.org/1.7.0/docs/api/ngSanitize/provider/$sanitizeProvider#addValidAttrs
70 * @param attrs A list of valid attributes.
71 */
72 addValidAttrs(attrs: string[]): ISanitizeProvider;
73 }
74
75 ///////////////////////////////////////////////////////////////////////////
76 // Filters included with the ngSanitize
77 // see https://github.com/angular/angular.js/tree/v1.2.0/src/ngSanitize/filter
78 ///////////////////////////////////////////////////////////////////////////
79 export namespace filter {
80 /**
81 * Finds links in text input and turns them into html links. Supports http/https/ftp/mailto and plain email address links.
82 * @see https://code.angularjs.org/1.7.0/docs/api/ngSanitize/filter/linky
83 * @param text Input text.
84 * @param target ILinkyTargetType Window (_blank|_self|_parent|_top) or named frame to open links in.
85 * @param attributes Add custom attributes to the link element.
86 * @return Html-linkified and sanitized text.
87 */
88 interface ILinky {
89 (
90 text: string,
91 target?: string,
92 attributes?: { [attribute: string]: string } | ((url: string) => { [attribute: string]: string }),
93 ): string;
94 }
95 }
96
97 ///////////////////////////////////////////////////////////////////////////////
98 // Extend angular $filter declarations to include filters from angular.sanitize module
99 ///////////////////////////////////////////////////////////////////////////////
100 interface IFilterService {
101 (name: "linky"): angular.sanitize.filter.ILinky;
102 }
103 }
104}
105
\No newline at end of file