forked from goofychris/art-template
-
Notifications
You must be signed in to change notification settings - Fork 0
/
index.d.ts
109 lines (99 loc) · 2.7 KB
/
index.d.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
declare type artTemplateDefaults = {
/**
* template name
*/
filename?: string;
/**
* an array of rules of template syntax
*/
rules: any[];
/**
* whether to automatically encode output statements of template. Setting false will close that functionality
* escape can prevent XSS attacks
*/
excape: boolean;
/**
* enable debug mode. If true: {cache:false, minimize:false, compileDebug:true}
*/
debug: boolean;
/**
* if bail is set true, compilation errors and runtime errors will throw exception
*/
bail: boolean;
/**
* whether to enable caching
*/
cache: boolean;
/**
* whether to enable minimization. It will execute htmlMinifier and minimize HTML, CSS, JS
* if template contains unclosing tags, please don't open minimize. Otherwise unclosing tags will be restored or filtered
*/
minimize: boolean;
/**
* whether to compile in debug mode
*/
compileDebug: boolean;
/**
* resolve template path
*/
resolveFilename: any;
/**
* sub template compilation adapter
*/
include: any,
/**
* HTML minifier. Work only in NodeJS environment
*/
htmlMinifier: any;
/**
* HTML minifier configuration. Refer to: https://github.com/kangax/html-minifier
*/
htmlMinifierOptions: {
collapseWhitespace: boolean,
minifyCSS: boolean,
minifyJS: boolean,
// automatically merged at runtime: rules.map(rule => rule.test)
ignoreCustomFragments: any[]
};
/**
* error events. Work only if bail is false
*/
onerror: any,
/**
* template file loader
*/
loader: any,
/**
* cache center adapter (depend on filename field)
*/
caches: any,
/**
* root directory of template. If filename field is not a local path, template will be found in root directory
* @default '/'
*/
root: string;
/**
* @default '.art'
* default extension. If no extensions, extname will be automatically added
*/
extname: string,
/**
* ignored variables. An array of template variables ignored by template compiler
*/
ignore: any[],
// imported template variables
imports: { [key: string]: Function }
}
/**
*
* @param filenameOrTemplateId [ for bowser ] id of template [ for Node ] fileName of template
* @param content [ if is Object ] return compile result , [ if is string ] return compile Funtion
*/
declare function artTemplate(filenameOrTemplateId: string, content?: string | Object): any;
declare namespace artTemplate {
export const defaults: artTemplateDefaults;
export const extension: { [key: string]: Function };
function render(source: string, data: any, options?: any): string;
function compile(source: string, options?: any): (data: any) => string;
}
export = artTemplate;