forked from zurb/tribute
-
Notifications
You must be signed in to change notification settings - Fork 0
/
tributejs.d.ts
75 lines (53 loc) · 2.05 KB
/
tributejs.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
// Type definitions for TributeJS v3.3.5
// Project: https://github.com/zurb/tribute
// Definitions by: Jordan Humphreys <https://github.com/mrsweaters/>
export type TributeItem<T extends {}> = {
index: number
original: T
score: number
string: string
}
export type TributeCollection<T extends {}> = {
// symbol that starts the lookup
trigger?: string
// element to target for @mentions
iframe?: any
// class added in the flyout menu for active item
selectClass?: string
// function called on select that returns the content to insert
selectTemplate?: (item: TributeItem<T>) => string
// template for displaying item in menu
menuItemTemplate?: (item: TributeItem<T>) => string
// template for when no match is found (optional),
// If no template is provided, menu is hidden.
noMatchTemplate?: () => string
// specify an alternative parent container for the menu
menuContainer?: Element
// column to search against in the object (accepts function or string)
lookup?: string | ((item: T) => string)
// column that contains the content to insert by default
fillAttr?: string
// array of objects to match
values?: Array<T> | ((text: string, cb: (result: Array<T>) => void) => void)
// specify whether a space is required before the trigger character
requireLeadingSpace?: boolean
// specify whether a space is allowed in the middle of mentions
allowSpaces?: boolean
// optionally specify a custom suffix for the replace text
// (defaults to empty space if undefined)
replaceTextSuffix?: string
//specify whether the menu should be positioned
positionMenu?: boolean
}
export type TributeOptions<T> = TributeCollection<T> | {
// pass an array of config objects
collection: Array<TributeCollection<{ [key: string]: any }>>
}
export default class Tribute<T extends {}> {
constructor(options: TributeOptions<T>)
isActive: boolean
append(index: number, values: Array<T>, replace?: boolean): void
appendCurrent(values: Array<T>, replace?: boolean): void
attach(to: Element): void
detach(to: Element): void
}