forked from DefinitelyTyped/DefinitelyTyped
-
Notifications
You must be signed in to change notification settings - Fork 0
/
flickity.d.ts
410 lines (346 loc) · 11.8 KB
/
flickity.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
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
// Type definitions for Flickity v1.1.1
// Project: http://flickity.metafizzy.co/
// Definitions by: Chris McGrath <https://www.github.com/clmcgrath>
// Definitions: https://github.com/clmcgrath/
interface JQuery {
/**
* initialize fickity plugin
*/
flickity: FlickityJquery;
}
interface FlickityJquery {
(options?: FlickityOptions): JQuery;
(command: string, ...params: any[]): JQuery;
}
declare class Flickity {
/**
* Initializes an new instance of Flickity .
*
* @param element Element selector string
* @param options (IFlickityOptions) Flickity options
*/
constructor(selector: string, options?: FlickityOptions);
/**
* Initializes an new instance of Flickity .
*
* @param element Container Element to initialize Flickity on
* @param options (IFlickityOptions) Flickity options
*/
constructor(element: Element, options?: FlickityOptions);
//properties
/**
* @type integer
* The selected cell index.
*/
selectedIndex: number;
/**
* @type Element
* The selected cell element.
*/
selectedElement: Element;
/**
* @type Element[]
* The array of cells. Use cells.length for the total number of cells.
*/
cells: Element[];
// static methods
/**
* (static) Get the Flickity instance via selector.
*
* @param element Element selector string
*/
static data(element: string): Flickity;
/**
* (static) Get the Flickity instance via its element.
*
* @param element The element
*/
static data(element: Element): Flickity;
// instance methods
/**
* Select a cell.
*
* @param index Integer Zero-based index of the cell to select.
* @param isWrapped (Optional) If true, the last cell will be selected if at the first cell.
* @param isInstant (Optional) If true, immediately view the selected cell without animation.
*/
select(index: number, isWrapped?: boolean, isInstant?: boolean): void;
/**
* Select the previous cell.
*
* @param isWrapped (Optional) If true, the first cell will be selected if at the last cell.
*/
previous(isWrapped?: boolean): void;
/**
* Select the next cell.
* @param isWrapped (Optional) If true, the first cell will be selected if at the first cell.
*/
next(isWrapped?: boolean): void;
/**
* Resize the gallery and re-position cells.
*/
resize(): void;
/**
* Position cells at selected position.
* Trigger reposition after the size of a cell has been changed.
*/
reposition(): void;
/**
* Prepend elements and create cells to the beginning of the gallery.
*
* @param elements JQuery, Element[], Element, or NodeList
*/
prepend(elements: Element | NodeList): void;
/**
* Append elements and create cells to the end of the gallery.
*
* @param elements JQuery, Element[], Element, or NodeList
*/
append(elements: Element | NodeList): void;
/**
* Insert elements into the gallery and create cells.
*
* @param elements Element[], Element, or NodeList
* @param index Integer: Zero-based index to insert elements.
*/
insert(elements: Element[] | Element | NodeList, index: number): void;
/**
* Remove cells from gallery and remove elements from DOM.
*
* @param elements Element[], Element, or NodeList
*/
remove(elements: Element[] | Element | NodeList): void;
/**
* Remove Flickity functionality completely. destroy will return the element back to its pre-initialized state.
*/
destroy(): void;
/**
* Re-collect all cell elements in flickity-slider.
*/
reloadCells(): void;
/**
* Get the elements of the cells.
* @returns Element[]
*/
getCellElements() : Element[];
//event listeners
/**
* Add new classic event listener
*/
listener(...params: any[]): void;
/**
* bind event listener
* @param eventName name of event (@see FlickityEvents class for filckity supported events)
* @param callback callback funtion to execute when event fires
*/
on(eventname: string, callback: (eventt?: Event, cellElement?: Element) => any) : void;
/**
* bind event listener
* @param eventName name of event (@see FlickityEvents class for filckity supported events)
* @param callback callback funtion to execute when event fires
*/
on(eventname: string, callback: (event?: Event, pointer?: Element | Touch) => any): void;
/**
* bind event listener
* @param eventName name of event (@see FlickityEvents class for filckity supported events)
* @param callback callback funtion to execute when event fires
*/
on(eventname: string, callback: (event?: Event, pointer?: Element | Touch, moveVector?: Object) => any): void;
/**
* bind event listener
* @param eventName name of event (@see FlickityEvents class for filckity supported events)
* @param callback callback funtion to execute when event fires
*/
on(eventname: string, callback: (event?: Event, pointer?: Element | Touch, cellElement?: Element, cellIndex?: number) => any): void;
/**
* Remove event listener
* @param eventName name of event (@see FlickityEvents class for filckity supported events)
* @param callback callback funtion to execute when event fires
*/
off(eventname: string, callback: (event?: Event, cellElement?: Element) => any): void;
/**
* Remove event listener
* @param eventName name of event (@see FlickityEvents class for filckity supported events)
* @param callback callback funtion to execute when event fires
*/
off(eventname: string, callback: (event?: Event, pointer?: Element | Touch) => any): void;
/**
* Remove event listener
* @param eventName name of event (@see FlickityEvents class for filckity supported events)
* @param callback callback funtion to execute when event fires
*/
off(eventname: string, callback: (event?: Event, pointer?: Element | Touch, moveVector?: Object) => any): void;
/**
* Remove event listener
* @param eventName name of event (@see FlickityEvents class for filckity supported events)
* @param callback callback funtion to execute when event fires
*/
off(eventname: string, callback: (event?: Event, pointer?: Element | Touch, cellElement?: Element, cellIndex?: number) => any): void;
/**
* one time event handler
* @param eventName name of event (@see FlickityEvents class for filckity supported events)
* @param callback callback funtion to execute when event fires
*/
once(eventname: string, callback: (event?: Event, cellElement?: Element) => any): void;
/**
* one time event handler
* @param eventName name of event (@see FlickityEvents class for filckity supported events)
* @param callback callback funtion to execute when event fires
*/
once(eventname: string, callback: (event?: Event, pointer?: Element | Touch) => any): void;
/**
* one time event handler
* @param eventName name of event (@see FlickityEvents class for filckity supported events)
* @param callback callback funtion to execute when event fires
*/
once(eventname: string, callback: (event?: Event, pointer?: Element | Touch, moveVector?: Object) => any): void;
/**
* one time event handler
* @param eventName name of event (@see FlickityEvents class for filckity supported events)
* @param callback callback funtion to execute when event fires
*/
once(eventname: string, callback: (event?: Event, pointer?: Element | Touch, cellElement?: Element, cellIndex?: number) => any): void;
}
interface FlickityOptions {
/**
* Specify selector for cell elements. cellSelector is useful if you have other elements in your gallery elements that are not cells.
*
* default: '.gallery-cell'
*/
cellSelector?: string;
/**
* Zero-based index of the initial selected cell.
*
* default: 2
*/
initialIndex?: number;
/**
* Enable keyboard navigation. Users can tab to a Flickity gallery, and pressing left & right keys to change cells.
*
* default: true
*/
accessibility?: boolean;
/**
* Sets the height of the gallery to the height of the tallest cell. Set to false if you prefer to size the gallery with CSS, rather than using the size of cells.
*
* default: true
*/
setGallerySize?: boolean;
/**
* Adjusts sizes and positions when window is resized.
*
* default: true
*/
resize?: boolean;
/**
* Align cells within the gallery element.
* opttions: 'left', 'center', 'right'
*
* default: 'center'
*/
cellAlign?: string;
/**
* Contains cells to gallery element to prevent excess scroll at beginning or end. Has no effect if wrapAround is enabled
*
* default: true
*/
contain?: boolean;
/**
* Unloaded images have no size, which can throw off cell positions. To fix this, the imagesLoaded option re-positions cells once their images have loaded.
*
* default: true
*/
imagesLoaded?: boolean;
/**
* Sets positioning in percent values, rather than pixel values. If your cells do not have percent widths, we recommended percentPosition: false.
*
* default: false
*/
percentPosition?: boolean;
/**
* Enables right-to-left layout.
*
* default: false
*/
rightToLeft?: boolean;
/**
* Enables dragging and flicking
*
* default: true
*/
draggable?: boolean;
/**
* Enables content to be freely scrolled and flicked without aligning cells to an end position.
* Enable freeScroll and wrapAround and you can flick forever, man.
*
* default: false
*/
freeScroll?: boolean;
/**
* At the end of cells, wrap-around to the other end for infinite scrolling.
*
* default: false
*/
wrapAround?: boolean;
/**
* Loads cell images when a cell is selected.
* Set the image's URL to load with data-flickity-lazyload.
*
* default: false
*/
lazyLoad?: boolean | number;
/**
* Automatically advances to the next cell.
*
* default: false
*/
autoPlay?: boolean | number;
/**
* You can enable and disable Flickity with CSS. watchCSS option watches the content of :after of the gallery element. Flickity is enabled if :after content is 'flickity'.
* note: IE8 and Android 2.3 do not support watching :after. Flickity will be disabled when watchCSS: true. Set watchCSS: 'fallbackOn' to enable Flickity for these browsers.
*
* default: false
*/
watchCSS?: boolean | string;
/**
* Use one Flickity gallery as navigation for another.
*
* default: disabled
*/
asNavFor?: string;
/**
* selectedAttraction attracts the position of the slider to the selected cell. Higher attraction makes the slider move faster. Lower makes it move slower.
*
* default: 0.025
*/
selectedAttraction?: number;
/**
* riction slows the movement of slider. Higher friction makes the slider feel stickier and less bouncy. Lower friction makes the slider feel looser and more wobbly.
*
* default: 0.28
*/
friction?: number;
/**
* Slows movement of slider when freeScroll: true. Higher friction makes the slider feel stickier. Lower friction makes the slider feel looser.
*
* default: 0.75
*/
freeScrollFriction?: number;
/**
* Creates and enables previous & next buttons.
*
* default: true
*/
prevNextButtons?: boolean;
/**
* Creates and enables paging dots.
*
* default: true
*/
pageDots?: boolean;
/**
* Draws the shape of the arrows in the previous & next buttons.
* javascript dictionary of points or path to SVG file
*/
arrowShape?: any;
}