mirror of
https://github.com/gosticks/DefinitelyTyped.git
synced 2025-10-16 12:05:41 +00:00
160 lines
6.2 KiB
TypeScript
160 lines
6.2 KiB
TypeScript
// Type definitions for bootstrap-maxlength v1.7.0
|
||
// Project: https://github.com/mimo84/bootstrap-maxlength
|
||
// Definitions by: Dan Manastireanu <https://github.com/danmana>
|
||
// Definitions: https://github.com/DefinitelyTyped/DefinitelyTyped
|
||
// TypeScript Version: 2.3
|
||
|
||
/// <reference types="jquery" />
|
||
|
||
declare namespace BootstrapMaxlength {
|
||
|
||
/**
|
||
* Possible options for the position of the counter. (passed to $.fn.css)
|
||
*/
|
||
interface PlacementOptions {
|
||
/**
|
||
* The top position of the counter (Number of pixels, or a px or percent string)
|
||
*/
|
||
top?: Number | string,
|
||
/**
|
||
* The right position of the counter (Number of pixels, or a px or percent string)
|
||
*/
|
||
right?: Number | string,
|
||
/**
|
||
* The bottom position of the counter (Number of pixels, or a px or percent string)
|
||
*/
|
||
bottom?: Number | string,
|
||
/**
|
||
* The left position of the counter (Number of pixels, or a px or percent string)
|
||
*/
|
||
left?: Number | string,
|
||
/**
|
||
* The positioning to use. For example 'relative', 'absolute'
|
||
*/
|
||
position?: string
|
||
}
|
||
|
||
/**
|
||
* Representation of the current input position
|
||
*/
|
||
interface PositionParam {
|
||
top: Number,
|
||
right: Number,
|
||
bottom: Number,
|
||
left: Number,
|
||
width: Number,
|
||
height: Number
|
||
}
|
||
|
||
export interface Options {
|
||
/**
|
||
* If true the threshold will be ignored and the remaining length indication will be always showing up while typing or on focus on the input
|
||
* @default false
|
||
*/
|
||
alwaysShow?: Boolean,
|
||
/**
|
||
* This is a number indicating how many chars are left to start displaying the indications
|
||
* @default 10
|
||
*/
|
||
threshold?: Number,
|
||
/**
|
||
* It's the class of the element with the indicator. By default is the bootstrap "label label-success" but can be changed to anything you'd like.
|
||
* @default 'label label-success'
|
||
*/
|
||
warningClass?: string,
|
||
/**
|
||
* It's the class the element gets when the limit is reached. Default is "label label-important label-danger" (to support Bootstrap 2 and 3).
|
||
* @default 'label label-important label-danger'
|
||
*/
|
||
limitReachedClass?: string,
|
||
/**
|
||
* Represents the separator between the number of typed chars and total number of available chars.
|
||
* @default ' / '
|
||
*/
|
||
separator?: string,
|
||
/**
|
||
* Is a string of text that can be outputted in front of the indicator.
|
||
* @default ''
|
||
*/
|
||
preText?: string,
|
||
/**
|
||
* Is a string outputted after the indicator.
|
||
* @default ''
|
||
*/
|
||
postText?: string,
|
||
/**
|
||
* If false, will display just the number of typed characters, e.g. will not display the max length.
|
||
* @default true
|
||
*/
|
||
showMaxLength?: Boolean,
|
||
/**
|
||
* If false, will display just the remaining length, e.g. will display remaining lenght instead of number of typed characters.
|
||
* @default true
|
||
*/
|
||
showCharsTyped?: Boolean,
|
||
/**
|
||
* Is a string, define where to output the counter.
|
||
* Options: bottom, left, top, right, bottom-right, top-right, top-left, bottom-left and centered-right
|
||
* @default 'bottom'
|
||
*/
|
||
placement?: string | PlacementOptions | ((currentInput: JQuery, maxLengthIndicator: JQuery, currentInputPosition: PositionParam) => void),
|
||
/**
|
||
* Appends the maxlength indicator badge to the parent of the input rather than to the body.
|
||
* @default false
|
||
*/
|
||
appendToParent?: boolean,
|
||
/**
|
||
* An alternative way to provide the message text.
|
||
* String example: 'You have typed %charsTyped% chars, %charsRemaining% of %charsTotal% remaining'.
|
||
* %charsTyped%, %charsRemaining% and %charsTotal% will be replaced by the actual values. This overrides the options separator, preText, postText and showMaxLength.
|
||
* Alternatively you may supply a function that the current text and max length and returns the string to be displayed.
|
||
* Function example: function(currentText, maxLength) { return '' + Math.ceil(currentText.length / 160) + ' SMS Message(s)'; }
|
||
* @default null
|
||
*/
|
||
message?: string | ((currentText : string, maxLength: Number) => string),
|
||
/**
|
||
* If true the input will count using utf8 bytesize/encoding. For example: the '<27>' character is counted as two characters.
|
||
* @default false
|
||
*/
|
||
utf8?: boolean,
|
||
/**
|
||
* Shows the badge as soon as it is added to the page, similar to alwaysShow
|
||
* @default false
|
||
*/
|
||
showOnReady?: boolean,
|
||
/**
|
||
* Count linebreak as 2 characters to match IE/Chrome textarea validation. As well as DB storage.
|
||
* @default true
|
||
*/
|
||
twoCharLinebreak?: boolean,
|
||
/**
|
||
* Allows a custom attribute to display indicator without triggering native maxlength behaviour.
|
||
* Ignored if value greater than a native maxlength attribute.
|
||
* 'overmax' class gets added when exceeded to allow user to implement form validation.
|
||
* @default null (use the maxlength attribute and browser functionality)
|
||
*/
|
||
customMaxAttribute?: string,
|
||
/**
|
||
* Will allow the input to be over the customMaxLength. Useful in soft max situations.
|
||
* @default false
|
||
*/
|
||
allowOverMax?: boolean,
|
||
/**
|
||
* If the browser doesn't support the maxlength attribute, attempt to type more than
|
||
* the indicated chars, will be prevented.
|
||
* @default false
|
||
*/
|
||
validate?: boolean
|
||
}
|
||
}
|
||
|
||
|
||
interface JQuery {
|
||
/** Apply the maxlength plugin on the selected elemens */
|
||
maxlength(options?: BootstrapMaxlength.Options): JQuery;
|
||
on(events: 'maxlength.shown', handler: (eventObject: JQueryEventObject, ...args: any[]) => any): JQuery;
|
||
on(events: 'maxlength.hidden', handler: (eventObject: JQueryEventObject, ...args: any[]) => any): JQuery;
|
||
trigger(eventType: 'maxlength.reposition', extraParameters?: any[]|Object): JQuery;
|
||
|
||
}
|