mirror of
https://github.com/twitter/twemoji.git
synced 2024-06-15 03:35:16 +00:00
feat: add TypeScript definitions
This commit is contained in:
parent
0bff51c31b
commit
6fc406b63b
@ -32,6 +32,7 @@
|
||||
"main": "./dist/twemoji.npm.js",
|
||||
"module": "./dist/twemoji.esm.js",
|
||||
"unpkg": "./dist/twemoji.min.js",
|
||||
"typings": "./src/twemoji.d.ts",
|
||||
"scripts": {
|
||||
"build": "./scripts/generate",
|
||||
"deploy": "./scripts/deploy.sh gh-pages",
|
||||
@ -45,6 +46,7 @@
|
||||
"universalify": "^0.1.2"
|
||||
},
|
||||
"files": [
|
||||
"dist/twemoji*.js"
|
||||
"dist/twemoji*.js",
|
||||
"src/twemoji.d.ts"
|
||||
]
|
||||
}
|
||||
|
203
src/twemoji.d.ts
vendored
Normal file
203
src/twemoji.d.ts
vendored
Normal file
@ -0,0 +1,203 @@
|
||||
const twemoji: {
|
||||
/**
|
||||
* default assets url, by default will be Twitter Inc. CDN
|
||||
*/
|
||||
base: string
|
||||
|
||||
/**
|
||||
* default assets file extensions, by default '.png'
|
||||
*/
|
||||
ext: string
|
||||
|
||||
/**
|
||||
* default assets/folder size, by default "72x72"
|
||||
* available via Twitter CDN: 72
|
||||
*/
|
||||
size: string
|
||||
|
||||
/**
|
||||
* default class name, by default 'emoji'
|
||||
*/
|
||||
className: string
|
||||
|
||||
/**
|
||||
* basic utilities / helpers to convert code points
|
||||
* to JavaScript surrogates and vice versa
|
||||
*/
|
||||
convert: {
|
||||
/**
|
||||
* Given an HEX codepoint, returns UTF16 surrogate pairs.
|
||||
*
|
||||
* @param codepoint string generic codepoint, i.e. '1F4A9'
|
||||
* @return string codepoint transformed into utf16 surrogates pair,
|
||||
* i.e. \uD83D\uDCA9
|
||||
*
|
||||
* @example
|
||||
* twemoji.convert.fromCodePoint('1f1e8');
|
||||
* // "\ud83c\udde8"
|
||||
*
|
||||
* '1f1e8-1f1f3'.split('-').map(twemoji.convert.fromCodePoint).join('')
|
||||
* // "\ud83c\udde8\ud83c\uddf3"
|
||||
*/
|
||||
fromCodePoint: (codepoint: string) => string
|
||||
|
||||
/**
|
||||
* Given UTF16 surrogate pairs, returns the equivalent HEX codepoint.
|
||||
*
|
||||
* @param unicodeSurrogates string generic utf16 surrogates pair, i.e. \uD83D\uDCA9
|
||||
* @param sep string optional separator for double code points, default='-'
|
||||
* @return string utf16 transformed into codepoint, i.e. '1F4A9'
|
||||
*
|
||||
* @example
|
||||
* twemoji.convert.toCodePoint('\ud83c\udde8\ud83c\uddf3');
|
||||
* // "1f1e8-1f1f3"
|
||||
*
|
||||
* twemoji.convert.toCodePoint('\ud83c\udde8\ud83c\uddf3', '~');
|
||||
* // "1f1e8~1f1f3"
|
||||
*/
|
||||
toCodePoint: (unicodeSurrogates: string, sep: string) => string
|
||||
}
|
||||
|
||||
/**
|
||||
* User first: used to remove missing images
|
||||
* preserving the original text intent when
|
||||
* a fallback for network problems is desired.
|
||||
* Automatically added to Image nodes via DOM
|
||||
* It could be recycled for string operations via:
|
||||
* $('img.emoji').on('error', twemoji.onerror)
|
||||
*/
|
||||
onerror: () => void
|
||||
|
||||
/**
|
||||
* Given a string, invokes the callback argument
|
||||
* per each emoji found in such string.
|
||||
* This is the most raw version used by
|
||||
* the .parse(string) method itself.
|
||||
*
|
||||
* @param text string generic string to parse
|
||||
* @param callback Function a generic callback that will be
|
||||
* invoked to replace the content.
|
||||
* This calback wil receive standard
|
||||
* String.prototype.replace(str, callback)
|
||||
* arguments such:
|
||||
* callback(
|
||||
* rawText, // the emoji match
|
||||
* );
|
||||
*
|
||||
* and others commonly received via replace.
|
||||
*/
|
||||
replace: (text: string, callback: Function) => string
|
||||
|
||||
/**
|
||||
* Simplify string tests against emoji.
|
||||
*
|
||||
* @param text string some text that might contain emoji
|
||||
* @return boolean true if any emoji was found, false otherwise.
|
||||
*
|
||||
* @example
|
||||
*
|
||||
* if (twemoji.test(someContent)) {
|
||||
* console.log("emoji All The Things!");
|
||||
* }
|
||||
*/
|
||||
test: (text: string) => boolean
|
||||
|
||||
/**
|
||||
* Main method/logic to generate either <img> tags or HTMLImage nodes.
|
||||
* "emojify" a generic text or DOM Element.
|
||||
*
|
||||
* @overloads
|
||||
*
|
||||
* String replacement for `innerHTML` or server side operations
|
||||
* twemoji.parse(string);
|
||||
* twemoji.parse(string, Function);
|
||||
* twemoji.parse(string, Object);
|
||||
*
|
||||
* HTMLElement tree parsing for safer operations over existing DOM
|
||||
* twemoji.parse(HTMLElement);
|
||||
* twemoji.parse(HTMLElement, Function);
|
||||
* twemoji.parse(HTMLElement, Object);
|
||||
*
|
||||
* @param what string|HTMLElement the source to parse and enrich with emoji.
|
||||
*
|
||||
* string replace emoji matches with <img> tags.
|
||||
* Mainly used to inject emoji via `innerHTML`
|
||||
* It does **not** parse the string or validate it,
|
||||
* it simply replaces found emoji with a tag.
|
||||
* NOTE: be sure this won't affect security.
|
||||
*
|
||||
* HTMLElement walk through the DOM tree and find emoji
|
||||
* that are inside **text node only** (nodeType === 3)
|
||||
* Mainly used to put emoji in already generated DOM
|
||||
* without compromising surrounding nodes and
|
||||
* **avoiding** the usage of `innerHTML`.
|
||||
* NOTE: Using DOM elements instead of strings should
|
||||
* improve security without compromising too much
|
||||
* performance compared with a less safe `innerHTML`.
|
||||
*
|
||||
* @param how Function|Object [optional]
|
||||
* either the callback that will be invoked or an object
|
||||
* with all properties to use per each found emoji.
|
||||
*
|
||||
* Function if specified, this will be invoked per each emoji
|
||||
* that has been found through the RegExp except
|
||||
* those follwed by the invariant \uFE0E ("as text").
|
||||
* Once invoked, parameters will be:
|
||||
*
|
||||
* iconId:string the lower case HEX code point
|
||||
* i.e. "1f4a9"
|
||||
*
|
||||
* options:Object all info for this parsing operation
|
||||
*
|
||||
* variant:char the optional \uFE0F ("as image")
|
||||
* variant, in case this info
|
||||
* is anyhow meaningful.
|
||||
* By default this is ignored.
|
||||
*
|
||||
* If such callback will return a falsy value instead
|
||||
* of a valid `src` to use for the image, nothing will
|
||||
* actually change for that specific emoji.
|
||||
*
|
||||
*
|
||||
* Object if specified, an object containing the following properties
|
||||
*
|
||||
* callback Function the callback to invoke per each found emoji.
|
||||
* base string the base url, by default twemoji.base
|
||||
* ext string the image extension, by default twemoji.ext
|
||||
* size string the assets size, by default twemoji.size
|
||||
*
|
||||
* @example
|
||||
*
|
||||
* twemoji.parse("I \u2764\uFE0F emoji!");
|
||||
* // I <img class="emoji" draggable="false" alt="❤️" src="/assets/2764.gif"/> emoji!
|
||||
*
|
||||
*
|
||||
* twemoji.parse("I \u2764\uFE0F emoji!", function(iconId, options) {
|
||||
* return '/assets/' + iconId + '.gif';
|
||||
* });
|
||||
* // I <img class="emoji" draggable="false" alt="❤️" src="/assets/2764.gif"/> emoji!
|
||||
*
|
||||
*
|
||||
* twemoji.parse("I \u2764\uFE0F emoji!", {
|
||||
* size: 72,
|
||||
* callback: function(iconId, options) {
|
||||
* return '/assets/' + options.size + '/' + iconId + options.ext;
|
||||
* }
|
||||
* });
|
||||
* // I <img class="emoji" draggable="false" alt="❤️" src="/assets/72x72/2764.png"/> emoji!
|
||||
*/
|
||||
parse: (
|
||||
what: string | HTMLElement,
|
||||
how?: Partial<{
|
||||
callback: Function
|
||||
attributes: Function
|
||||
base: string
|
||||
ext: string
|
||||
className: string
|
||||
size: string | number
|
||||
folder: string
|
||||
}>,
|
||||
) => string
|
||||
}
|
||||
|
||||
export default twemoji
|
Loading…
Reference in New Issue
Block a user