forked from securingsincity/react-ace
-
Notifications
You must be signed in to change notification settings - Fork 0
/
types.d.ts
176 lines (166 loc) · 5.22 KB
/
types.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
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
// Type definitions for react-ace 4.1.3
// Project: https://github.com/securingsincity/react-ace
// Definitions by: Alberto Nicoletti <https://github.com/illbexyz>
import { Component, CSSProperties } from 'react'
export interface Annotation {
row: number
column: number
type: string
text: string
}
export interface Marker {
startRow: number
startCol: number
endRow: number
endCol: number
className: string
type: string
}
export interface CommandBindKey {
win: string
mac: string
}
export interface Command {
name: string
bindKey: CommandBindKey
exec(editor: any): void
}
export interface Selection {
getCursor(): Annotation;
}
/**
* See https://github.com/ajaxorg/ace/wiki/Configuring-Ace
*/
export interface AceOptions {
selectionStyle?: "line" | "text"
highlightActiveLine?: boolean
highlightSelectedWord?: boolean
readOnly?: boolean
cursorStyle?: "ace"|"slim"|"smooth"|"wide"
mergeUndoDeltas?: false | true | "always"
behavioursEnabled?: boolean
wrapBehavioursEnabled?: boolean
/** this is needed if editor is inside scrollable page */
autoScrollEditorIntoView?: boolean
hScrollBarAlwaysVisible?: boolean
vScrollBarAlwaysVisible?: boolean
highlightGutterLine?: boolean
animatedScroll?: boolean
showInvisibles?: boolean
showPrintMargin?: boolean
printMarginColumn?: number;
printMargin?: boolean | number;
fadeFoldWidgets?: boolean
showFoldWidgets?: boolean
showLineNumbers?: boolean
showGutter?: boolean
displayIndentGuides?: boolean
/** number or css font-size string */
fontSize?: number | string
/** css */
fontFamily?: string
maxLines?: number
minLines?: number
scrollPastEnd?: boolean
fixedWidthGutter?: boolean
/** path to a theme e.g "ace/theme/textmate" */
theme?: string
scrollSpeed?: number
dragDelay?: number
dragEnabled?: boolean
focusTimout?: number
tooltipFollowsMouse?: boolean
firstLineNumber?: number
overwrite?: boolean
newLineMode?: boolean
useWorker?: boolean
useSoftTabs?: boolean
tabSize?: number
wrap?: boolean
foldStyle?: boolean
/** path to a mode e.g "ace/mode/text" */
mode?: string
/** on by default */
enableMultiselect?: boolean
enableEmmet?: boolean
enableBasicAutocompletion?: boolean
enableLiveAutocompletion?: boolean
enableSnippets?: boolean
spellcheck?: boolean
useElasticTabstops?: boolean
}
export interface EditorProps {
$blockScrolling?: number | boolean
$blockSelectEnabled?: boolean
$enableBlockSelect?: boolean
$enableMultiselect?: boolean
$highlightPending?: boolean
$highlightTagPending?: boolean
$multiselectOnSessionChange?: (...args: any[]) => any
$onAddRange?: (...args: any[]) => any
$onChangeAnnotation?: (...args: any[]) => any
$onChangeBackMarker?: (...args: any[]) => any
$onChangeBreakpoint?: (...args: any[]) => any
$onChangeFold?: (...args: any[]) => any
$onChangeFrontMarker?: (...args: any[]) => any
$onChangeMode?: (...args: any[]) => any
$onChangeTabSize?: (...args: any[]) => any
$onChangeWrapLimit?: (...args: any[]) => any
$onChangeWrapMode?: (...args: any[]) => any
$onCursorChange?: (...args: any[]) => any
$onDocumentChange?: (...args: any[]) => any
$onMultiSelect?: (...args: any[]) => any
$onRemoveRange?: (...args: any[]) => any
$onScrollLeftChange?: (...args: any[]) => any
$onScrollTopChange?: (...args: any[]) => any
$onSelectionChange?: (...args: any[]) => any
$onSingleSelect?: (...args: any[]) => any
$onTokenizerUpdate?: (...args: any[]) => any
}
export interface AceEditorProps {
name?: string
/** For available modes see https://github.com/thlorenz/brace/tree/master/mode */
mode?: string
/** For available themes see https://github.com/thlorenz/brace/tree/master/theme */
theme?: string
height?: string
width?: string
className?: string
fontSize?: number
showGutter?: boolean
showPrintMargin?: boolean
highlightActiveLine?: boolean
focus?: boolean
cursorStart?: number
wrapEnabled?: boolean
readOnly?: boolean
minLines?: number
maxLines?: number
enableBasicAutocompletion?: boolean
enableLiveAutocompletion?: boolean
tabSize?: number
value?: string
defaultValue?: string
scrollMargin?: number[]
onLoad?: (editor: EditorProps) => void
onBeforeLoad?: (ace: any) => void
onChange?: (value: string, event?: any) => void
onInput?: (value: string, event?: any) => void
onSelectionChange?: (selectedText: string, event?: any) => void
onCopy?: (value: string) => void
onPaste?: (value: string) => void
onFocus?: (event: any) => void
onBlur?: (event: any) => void
onValidate?: (annotations: Array<Annotation>) => void
onScroll?: (editor: EditorProps) => void
onCursorChange?: (selection: Selection) => void;
editorProps?: EditorProps
setOptions?: AceOptions
keyboardHandler?: string
commands?: Array<Command>
annotations?: Array<Annotation>
markers?: Array<Marker>
style?: CSSProperties
debounceChangePeriod?: number
}
export default class AceEditor extends Component<AceEditorProps, {}> {}