js-cool
Version:
Collection of common JavaScript / TypeScript utilities
1,800 lines (1,657 loc) • 60.4 kB
TypeScript
import { default as awaitTo } from 'await-to-done';
import { download } from 'use-downloads';
import { default as loadSource } from 'load-source';
import { default as mountCss } from 'mount-css';
import { default as mountImg } from 'mount-image';
import { default as mountJs } from 'mount-script';
import { default as mountStyle } from 'mount-style';
/**
* addEvent() event delegate, supports multiple delegates
*
* @since 1.0.2
* @param element - js dom object
* @param type - The event type. No need to add on
* @param handler - callback method
*/
export declare function addEvent(element: AnyObject, type: string, handler: AnyFunction): void;
export declare namespace addEvent {
var guid: number;
}
/**
* Returns true if the provided predicate function returns true for all elements in a set, otherwise it returns false.
*
* @example
* ```js
* all([4, 2, 3], x => x > 1)
* // true
* ```
* @since 1.0.9
* @param arr - the target array
* @param fn - the judgment method
* @returns - the result of the judgment
*/
export declare const all: <T = unknown>(arr: T[], fn: AnyFunction) => boolean;
/**
* Returns true if the provided predicate function returns true for at least one element of a set, otherwise it returns false.
*
* @example
* ```js
* any([0, 1, 2, 0], x => x >= 2)
* // true
* ```
* @since 1.0.9
* @param arr - the target array
* @param fn - the judgment method
* @returns - the result of the judgment
*/
export declare const any: <T = unknown>(arr: T[], fn: AnyFunction) => boolean;
export declare interface AnyFunction extends AnyObject {
(...args: any[]): any;
}
export declare type AnyObject = Record<string, any>;
/**
* Get the APP version from navigator.userAgent, support 'x.x.x' & 'x.x.x-tagname.x'
*
* @example
* ```js
* // navigator.userAgent => '5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/114.0.0.0 Safari/537.36 AppName/1.0.0-beta.8'
* appVersion('Chrome') // 114.0.0.0
* appVersion('Safari') // 537.36
* appVersion('appname', false) // null
* appVersion('appname') // 1.0.0-beta.8
* ```
* @since 5.1.0
* @param appName - app name
* @param ua - ua or any ua like string, allowed to be undefined, default is navigator.userAgent
* @param ignoreCase - whether to ignore case
* @return string|null
*/
export declare function appVersion(appName: string): string | null;
export declare function appVersion(appName: string, ua: string): string | null;
export declare function appVersion(appName: string, ua: boolean): string | null;
export declare function appVersion(appName: string, ua: string, ignoreCase: boolean): string | null;
/**
* arrayBuffer to base64
*
* @example
* ```js
* arrayBufferToBase64(arrayBuffer, 'image/png')
* // 
*
* arrayBufferToBase64(arrayBuffer)
* // xxxxxxxxxxxx
* ```
* @since 5.13.0
* @param input - arrayBuffer
* @param mime - image mime, eq: image/png
* @returns - base64
*/
export declare function arrayBufferToBase64(input: ArrayBuffer, mime?: string): string;
/**
* arrayBuffer to blob
*
* @since 5.13.0
* @param input - arrayBuffer
* @param mime - image mime, default: image/png
* @returns - blob
*/
export declare function arrayBufferToBlob(input: ArrayBuffer, mime?: string): Blob;
export declare interface ArrayOne<T> {
0: T;
}
export declare type ArrayOneMore<T> = ArrayOne<T> & Array<T>;
/**
* Converts a two-dimensional array to a comma-separated string of values (CSV).
*
* @example
* ```js
* arrayToCSV([['a', 'b'], ['c', 'd']])
* // '"a", "b" \n "c", "d"'
*
* arrayToCSV([['a', 'b'], ['c', 'd']], ';')
* // '"a"; "b"\n "c"; "d"'
*
* arrayToCSV([['a', '"b" great'], ['c', 3.1415]])
* // '"a", """b"" great"\n "c",3.1415'
* ```
* @since 1.0.9
* @param data - json data
* @param delimiter - delimiter, default ','
* @returns CSV data
*/
export declare const arrayToCSV: <T extends unknown[][]>(arr: T, delimiter?: string) => string;
export declare type ArrayTwoMore<T> = {
0: T;
1: T;
} & Array<T>;
export { awaitTo }
/**
* base64 to arrayBuffer
*
* @since 5.13.0
* @param input - base64 string
* @returns - arrayBuffer
*/
export declare function base64ToArrayBuffer(input: string): Uint8Array<ArrayBuffer> | Buffer<ArrayBuffer>;
/**
* base64 to blob
*
* @since 5.13.0
* @param input - base64 string
* @returns - blob
*/
export declare function base64ToBlob(input: string): Blob;
/**
* base64 to file
*
* @since 5.13.0
* @param input - base64 string
* @param fileName - file name
* @returns - the BASE64 encoding
*/
export declare function base64ToFile(input: string, fileName: string): File;
/**
* blob to arrayBuffer
*
* @since 5.13.0
* @param input - blob data
* @returns - arrayBuffer
*/
export declare function blobToArrayBuffer(input: Blob): Promise<ArrayBuffer | null>;
/**
* blob to base64
*
* @since 5.13.0
* @param input - blob data
* @returns - base64 string
*/
export declare function blobToBase64(input: Blob): Promise<string | null>;
/**
* blob to blobUrl
*
* @since 5.13.0
* @param input - blob data
* @returns - blobUrl
*/
export declare function blobToUrl(input: Blob): string;
export declare interface BrowserVersion {
name: 'Safari' | 'Chrome' | 'IE' | 'Edge' | 'Firefox' | 'Firefox Focus' | 'Chromium' | 'Opera' | 'Vivaldi' | 'Yandex' | 'Arora' | 'Lunascape' | 'QupZilla' | 'Coc Coc' | 'Kindle' | 'Iceweasel' | 'Konqueror' | 'Iceape' | 'SeaMonkey' | 'Epiphany' | '360' | '360SE' | '360EE' | 'Maxthon' | 'QQBrowser' | 'QQ' | 'Baidu' | 'UC' | 'Sogou' | 'Liebao' | 'LBBROWSER' | '2345Explorer' | '115Browser' | 'TheWorld' | 'XiaoMi' | 'Vivo' | 'Quark' | 'Qiyu' | 'Wechat' | 'WechatWork' | 'Taobao' | 'Alipay' | 'Weibo' | 'Douban' | 'Suning' | 'iQiYi' | 'DingTalk' | 'Huawei';
version: string;
}
/**
* Get the browser name and version
*
* @example
* ```
* // Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) Ap…KHTML, like Gecko) Chrome/114.0.0.0 Safari/537.36
* browserVersion() // \{ name: 'Chrome', version: '114.0.0.0' \}
* ```
* @since 5.2.0
* @param ua - ua or any ua like string, allowed to be undefined, default is navigator.userAgent
* @return BrowserVersion|null
*/
export declare function browserVersion(ua?: string): BrowserVersion | null;
/**
* Converts humped strings to -spaced and all lowercase Dash pattern
*
* @since 1.0.1
* @param string - the string to be converted
* @returns - the converted string
*/
export declare function camel2Dash(string: string): string;
/**
* Data cleaning methods
*
* @since 1.0.2
* @param data - the object to be cleaned, must be passed
* @param map - the data queue to be cleaned, can be passed as array or object
* @param map -
* @param nullFix -
* @param map -
* @param nullFix -
* @param nullFix - optional, the value returned if there is no corresponding property, the default does not return the property
* @returns - the cleaned object
*/
export declare function cleanData(data: any, map: any[] | AnyObject, nullFix?: any): any;
/**
* Remove all attributes of HTML tags
*
* @since 1.0.1
* @param string - pass in the string
* @returns newString
*/
export declare function clearAttr(string: string): string;
/**
* Removing HTML tags
*
* @since 1.0.1
* @param string - string with html tags
* @returns newString
*/
export declare function clearHtml(string: string): string;
/**
* The client method returns a browser judgment result: `{ ANDROID: true, GECKO: true, GLSH_APP: false, IE: false, IOS: false, IPAD: false, IPHONE: false, MOBILE: true, MOBILEDEVICE. true, OPERA: false, QQ: false, QQBROWSER: false, TRIDENT: false, WEBKIT: true, WEIXIN: false }`
*
* @deprecated Will be refactored for the next major release
* @since 1.0.1
* @param name - optional, e.g. pass in MicroMessenger to return whether it is the built-in browser of Weixin
* @param userAgent - optional, pass in a custom ua, default takes the browser's navigator.userAgent
* @returns - the common ua match table, if name is passed, then returns whether the terminal matches true/false
*/
export declare const client: (name?: string, userAgent?: string) => boolean | {
IE: boolean;
GECKO: boolean;
WEBKIT: boolean;
OPERA: boolean;
TRIDENT: boolean;
MOBILE: boolean;
IOS: boolean;
ANDROID: boolean;
IPHONE: boolean;
IPAD: boolean;
QQBROWSER: boolean;
WEIXIN: boolean;
QQ: RegExpMatchArray | null;
};
/**
* deep clone (Buffer, Promise, Set, Map are not supported)
*
* @example
* ```js
* const source = { a: 100, reg: /\d+/g, arr: [1, 2] }
* const res = clone(source)
* // { a: 100, reg: /\d+/g, arr: [1, 2] }
* ```
* @since 5.15.0
* @param parent - source object
* @returns - new object
*/
export declare function clone<T = any>(parent: T): T;
/**
* Version number size comparison, tag version: rc \> beta \> alpha \> other
*
* @example
* ```js
* compareVersion('1.11.0', '1.9.9')
* // => 1: 1=Version 1.11.0 is newer than 1.9.9
*
* compareVersion('1.11.0', '1.11.0')
* // => 0: 0=Versions 1.11.0 and 1.11.0 are the same
*
* compareVersion('1.11.0', '1.99.0')
* // => -1: -1=Version 1.11.0 is older than 1.99.0
*
* compareVersion('1.0.0.0.0.10', '1.0')
* // => -1
*
* // compare tag version: rc > beta > alpha > other
* compareVersion('1.11.0', '1.11.0-beta.1')
* // => -1
*
* compareVersion('1.11.0-beta.1', '1.11.0')
* // => -1
*
* compareVersion('1.11.0-beta.10', '1.11.0-beta.10')
* // => 0
*
* compareVersion('1.11.0-alpha.10', '1.11.0-beta.1')
* // => -1
*
* compareVersion('1.11.0-alpha.10', '1.11.0-rc.1')
* // => -1
*
* compareVersion('1.11.0-tag.10', '1.11.0-alpha.1')
* // => -1
*
* compareVersion('1.11.0-tag.10', '1.11.0-tag.1')
* // => 1
*
* compareVersion('1.11.0-release.10', '1.11.0-tag.1')
* // => 1
* ```
* @since 4.7.0
* @param input - input version
* @param compare - compare version
* @return 1/0/-1
*/
export declare function compareVersion(input: string, compare: string): 0 | 1 | -1;
/**
* Find the complement of multiple arrays
*
* @example
* ```js
* complement([1, 2], [2, '33'], [2]) // [1, '33']
* ```
* @since 2.2.1
* @param args - arguments
* @returns array
*/
export declare function complement<T = unknown>(...args: T[][]): T[];
/**
* Whether the array contains the specified element
*
* @example
* ```js
* contains([1, 2], 2) // true
* contains([1, 2], 3) // false
* ```
* @since 2.2.1
* @param arr - the target array
* @param item - the target to find
* @returns boolean
*/
export declare function contains(arr: any[], item: any): boolean;
/**
* copy to clipboard
*
* @since 5.0.0
* @param value - any target
* @returns - target is Object
*/
export declare function copy(value: any): boolean | undefined;
/**
* Converts a comma-separated string of values (CSV) to a 2D array.
*
* @example
* ```js
* CSVToArray('a,b\\nc,d')
* // `[['a','b'],['c','d']]`.
*
* CSVToArray('a;b\\\nc;d', ';')
* // `[['a','b'],['c','d']]`.
*
* CSVToArray('col1,col2\\\na,b\\\nc,d', ',', true)
* // `[['a','b'],['c','d']]`.
* ```
* @since 1.0.9
* @param data - csv data
* @param delimiter - separator, default ','
* @param omitFirstRow - the first row is the table header data, default false
* @returns array
*/
export declare const CSVToArray: (data: string, delimiter?: string, omitFirstRow?: boolean) => string[][];
/**
* Converts a comma-separated string of values (CSV) to an array of 2D objects. The first line of the string is used as the header line.
*
* @example
* ```js
* CSVToJSON('col1,col2\\na,b\\\nc,d')
* // `[{'col1': 'a', 'col2': 'b'}, {'col1': 'c', 'col2': 'd'}]`.
*
* CSVToJSON('col1;col2\\\na;b\\\nc;d', ';')
* // `[{'col1': 'a', 'col2': 'b'}, {'col1': 'c', 'col2': 'd'}]`.
* ```
* @since 1.0.9
* @param data - csv data
* @param delimiter - delimiter, default ','
* @returns - json
*/
export declare function CSVToJSON(data: string, delimiter?: string): any[];
/**
* Intercept string, Chinese counts as 2 bytes
*
* @since 1.0.1
* @param str - the string to be intercepted
* @param len -
* @param hasDot -
* @returns - the intercepted string
*/
export declare function cutCHSString(str: string, len?: number, hasDot?: boolean): string;
/**
* Converts -spaced and all lowercase Dash patterns to humped strings
*
* @since 1.0.1
* @param string - the string to be converted
* @returns - the converted string
*/
export declare function dash2Camel(string: string): string;
/**
* base64 decoding
*
* @since 1.0.1
* @param input - the string to be decoded
* @returns decoded string
*/
export declare function decodeBase64(input: string): string;
/**
* Decoding Utf8
*
* @since 1.0.1
* @param input - the string to be decoded
* @returns decoded string
*/
export declare function decodeUtf8(utftext: string): string;
declare const _default: {
version: string;
download: typeof download;
RGBToHex: (r: number, g: number, b: number) => string;
addEvent: typeof addEvent;
all: <T = unknown>(arr: T[], fn: AnyFunction) => boolean;
any: <T = unknown>(arr: T[], fn: AnyFunction) => boolean;
getCache: typeof getCache;
setCache: typeof setCache;
delCache: typeof delCache;
getSession: typeof getSession;
setSession: typeof setSession;
delSession: typeof delSession;
getCookie: typeof getCookie;
getCookies: typeof getCookies;
setCookie: typeof setCookie;
delCookie: typeof delCookie;
camel2Dash: typeof camel2Dash;
cleanData: typeof cleanData;
clearAttr: typeof clearAttr;
clearHtml: typeof clearHtml;
escape: typeof escape_2;
unescape: typeof unescape_2;
client: (name?: string, userAgent?: string) => boolean | {
IE: boolean;
GECKO: boolean;
WEBKIT: boolean;
OPERA: boolean;
TRIDENT: boolean;
MOBILE: boolean;
IOS: boolean;
ANDROID: boolean;
IPHONE: boolean;
IPAD: boolean;
QQBROWSER: boolean;
WEIXIN: boolean;
QQ: RegExpMatchArray | null;
};
complement: typeof complement;
contains: typeof contains;
CSVToArray: (data: string, delimiter?: string, omitFirstRow?: boolean) => string[][];
arrayToCSV: <T extends unknown[][]>(arr: T, delimiter?: string) => string;
CSVToJSON: typeof CSVToJSON;
JSONToCSV: (arr: any[], columns: any[], delimiter?: string) => string;
cutCHSString: typeof cutCHSString;
dash2Camel: typeof dash2Camel;
decodeBase64: typeof decodeBase64;
decodeUtf8: typeof decodeUtf8;
delay: typeof delay;
encodeBase64: typeof encodeBase64;
encodeUtf8: typeof encodeUtf8;
extend: typeof extend;
clone: typeof clone;
fillIPv6: typeof fillIPv6;
fixNumber: typeof fixNumber;
mapTemplate: typeof mapTemplate;
getAppVersion: typeof getAppVersion;
appVersion: typeof appVersion;
getCHSLength: typeof getCHSLength;
getDirParam: typeof getDirParam;
compareVersion: typeof compareVersion;
getNumber: typeof getNumber;
getOsVersion: typeof getOsVersion;
osVersion: typeof osVersion;
browserVersion: typeof browserVersion;
getQueryParam: typeof getQueryParam;
getQueryParams: typeof getQueryParams;
getProperty: typeof getProperty;
randomColor: typeof randomColor;
randomNumber: typeof randomNumber;
randomNumbers: typeof randomNumbers;
randomString: typeof randomString;
shuffle: typeof shuffle;
fingerprint: typeof fingerprint;
getScrollPosition: typeof getScrollPosition;
getType: typeof getType;
getFileType: typeof getFileType;
sorter: typeof sorter;
sortPinyin: typeof sortPinyin;
parseUrlParam: typeof parseUrlParam;
spliceUrlParam: typeof spliceUrlParam;
safeParse: typeof safeParse;
safeStringify: typeof safeStringify;
getUrlParam: typeof getUrlParam;
getUrlParams: typeof getUrlParams;
intersect: typeof intersect;
isDigitals: typeof isDigitals;
isExitsFunction: typeof isExitsFunction;
isExitsVariable: typeof isExitsVariable;
isEqual: typeof isEqual;
isWindow: typeof isWindow;
isObject: typeof isObject;
isDate: typeof isDate;
isRegExp: typeof isRegExp;
isArray: typeof isArray;
isIterable: typeof isIterable;
isPlainObject: typeof isPlainObject;
isDarkMode: typeof isDarkMode;
inBrowser: boolean;
inNodeJs: boolean;
isNumberBrowser: typeof isNumberBrowser;
minus: typeof minus;
nextIndex: typeof nextIndex;
nextVersion: typeof nextVersion;
punctualTimer: typeof punctualTimer;
promiseFactory: typeof promiseFactory;
waiting: (milliseconds: number, throwOnTimeout?: boolean) => Promise<void>;
awaitTo: typeof awaitTo;
arrayBufferToBase64: typeof arrayBufferToBase64;
arrayBufferToBlob: typeof arrayBufferToBlob;
base64ToArrayBuffer: typeof base64ToArrayBuffer;
base64ToBlob: typeof base64ToBlob;
base64ToFile: typeof base64ToFile;
blobToArrayBuffer: typeof blobToArrayBuffer;
blobToBase64: typeof blobToBase64;
blobToUrl: typeof blobToUrl;
fileToBase64: typeof fileToBase64;
svgToBlob: typeof svgToBlob;
urlToBlob: typeof urlToBlob;
openUrl: typeof openUrl;
copy: typeof copy;
pattern: {
any: RegExp;
number: RegExp;
string: RegExp;
postcode: RegExp;
url: RegExp;
username: RegExp;
float: RegExp;
email: RegExp;
mobile: RegExp;
chinese: RegExp;
tel: RegExp;
qq: RegExp;
pass: RegExp;
json: RegExp;
arrjson: RegExp;
array: RegExp;
isjson: RegExp;
textarea: RegExp;
mac: RegExp;
ip4: RegExp;
ip4_pri: RegExp;
};
removeEvent: typeof removeEvent;
searchObject: typeof searchObject;
setProperty: typeof setProperty;
stopBubble: typeof stopBubble;
stopDefault: typeof stopDefault;
toThousands: typeof toThousands;
trim: typeof trim;
union: typeof union;
unique: typeof unique;
upperFirst: typeof upperFirst;
uuid: () => string;
windowSize: typeof windowSize;
loadSource: typeof loadSource;
mountCss: typeof mountCss;
mountImg: typeof mountImg;
mountJs: typeof mountJs;
mountStyle: typeof mountStyle;
preloader: typeof preloader;
};
export default _default;
/**
* debounce & throttle
*
* @since 1.0.2
* @returns class
*/
export declare function delay(): {
map: any;
register(id: string, fn: AnyFunction, time: number, boo: boolean): void;
destroy(id: string): void;
};
/**
* Delete localStorage
*
* @since 1.0.2
* @param name - name
*/
export declare function delCache(name: string): void;
/**
* Delete cookie
*
* @since 1.0.2
* @param name - cookie name
*/
export declare function delCookie(name: string): void;
/**
* Delete sessionStorage
*
* @since 1.0.2
* @param name - name
*/
export declare function delSession(name: string): void;
export declare interface DirParamType {
path?: string[];
host?: string;
}
export { download }
/**
* String, number to base64
*
* @since 1.0.1
* @param input - the string to be encoded
* @returns - the BASE64 encoding
*/
export declare function encodeBase64(input: string): string;
/**
* Encoding Utf8
*
* @since 1.0.1
* @param input - the string to be encoded
* @returns - the UTF-8 encoding
*/
export declare function encodeUtf8(string: string): string;
/**
* Escaping HTML Special Characters
*
* @example
* ```js
* escape('<div>test<br />string</div>')
* // '<div>test<br />string</div>'
* ```
* @since 5.5.0
* @param string - string with html tags
* @returns - newString
*/
declare function escape_2(string: string): string;
export { escape_2 as escape }
/**
* deep copy & merge objects
*
* @since 1.0.2
* @param target - boolean | ExtendData
* @param args - ArrayOneMore<ExtendData>
*/
export declare function extend(target: ExtendObjectData, ...args: ArrayOneMore<ExtendObjectData>): ExtendObjectData;
export declare function extend(target: boolean, ...args: ArrayOneMore<ExtendObjectData>): ExtendObjectData;
export declare function extend(target: ExtendArrayData, ...args: ArrayOneMore<ExtendArrayData>): ExtendArrayData;
export declare function extend(target: boolean, ...args: ArrayOneMore<ExtendArrayData>): ExtendArrayData;
export declare type ExtendArrayData = any[];
export declare type ExtendData = ExtendArrayData | ExtendObjectData;
export declare type ExtendObjectData = Record<string, any>;
/**
* file to base64
*
* @since 5.13.0
* @param input - file data
* @returns - base64 string
*/
export declare function fileToBase64(input: File): Promise<string | null>;
/**
* Read full IPv6
*
* @example
* ```js
* fillIPv6('2409:8005:800::2')
* // '2409:8005:0800:0000:0000:0000:0000:0002'
*
* fillIPv6('2409:8005:800::1c')
* // '2409:8005:0800:0000:0000:0000:0000:001c'
* ```
* @since 2.2.2
* @returns - string
*/
export declare function fillIPv6(ip: string): string;
/**
* Generating Browser Fingerprints
*
* @since 5.2.0
* @param domain - key string, default: location.host
* @returns - fingerprint
*/
export declare function fingerprint(domain?: string): string | null;
/**
* Intercept the decimal places, do not fill in the missing 0
*
* @example
* ```js
* fixNumber('100.888')
* // 100.88
*
* fixNumber('100.8', 2)
* // 100.8
*
* fixNumber('100.8888', 3)
* // 100.888
* ```
* @since 1.0.2
* @param number - the number of digits to be processed, required
* @param n - the number of decimal places to keep, default is 2
* @returns - the new number
*/
export declare function fixNumber(number: string | number, n?: number): number;
/**
* Get the APP version number
*
* @deprecated please use 'appVersion' instead
* @since 1.0.1
* @param appName - app name
* @param withApp - whether to bring the name
* @param userAgent - ua, allowed to be undefined, default is navigator.userAgent
* @return null/true/false
*/
export declare function getAppVersion(appName: string, withApp?: boolean, userAgent?: string): string | boolean | null;
/**
* Get the cache, if the deposited is Object, the retrieved is also Object, no need to convert again
*
* @example
* ```js
* const data1 = 100
* const data2 = { a: 10 }
* const data3 = null
*
* setCache('data1', data1)
* setCache('data2', data2)
* setCache('data3', data3)
*
* getCache('data1') // 100
* getCache('data2') // {a:10}
* getCache('data3') // null
*
* getCache('data4') // null
* ```
* @since 1.0.2
* @param name - cache name
* @returns - data, if it's an object, it's also an object
*/
export declare function getCache(name: string): any;
/**
* Get the length of the text, Chinese counts as 2 bytes
*
* @example
* ```js
* getCHSLength('测试')
* // 2
* ```
* @since 1.0.1
* @param str - string
* @returns - length
*/
export declare function getCHSLength(str: string): number;
/**
* Read cookie by name
*
* @example
* ```js
* getCookie('data1')
* // 100
* ```
* @since 1.0.2
* @param name - cookie name
* @returns - the cookie string
*/
export declare function getCookie(name: string): any;
/**
* Read all cookies
*
* @example
* ```js
* getCookies()
* // \{ token: 'xxx', name: 'saqqdy' \}
* ```
* @since 5.6.0
* @returns - the cookie values
*/
export declare function getCookies(): Record<string, string>;
/**
* Get directory form URL parameters
*
* @deprecated It will be refactored and renamed getDirParams in the next major release.
* @since 1.0.1
* @param url - pass in the url address
* @returns - parameter object
*/
export declare function getDirParam(url: string): DirParamType;
/**
* Determine file type based on link suffix
*
* @example
* ```js
* getFileType('/name.png')
* // { "suffix": "png", "type": "image" }
*
* getFileType('/name.PDF')
* // { "suffix": "pdf", "type": "pdf" }
*
* getFileType('/name.xyz')
* // { "suffix": "xyz", "type": "other" }
* ```
* @since 5.11.0
* @param url - file url
* @returns result
*/
export declare function getFileType(url: string): {
suffix: string;
type: "audio" | "video" | "image" | "other" | "word" | "txt" | "excel" | "pdf" | "ppt" | "zip";
};
/**
* Get the number in the string
*
* @example
* ```js
* getNumber('Chrome123.33')
* // '123.33'.
*
* getNumber('234test.88')
* // '234.88'.
* ```
* @since 1.0.1
* @param string - pass in a string with a number
* @returns - a pure numeric string
*/
export declare function getNumber(string: string): string;
/**
* Get the phone system version
*
* @example
* ```
* getOsVersion('iPhone')
* // '13.2.3'
*
* getOsVersion('iPhone', true)
* // 'iPhone/13.2.3'
* ```
* @deprecated please use 'osVersion' instead
* @since 1.0.1
* @param osName - system type string Android, iPod, iWatch or iPhone
* @param withOS - whether to bring the name
* @param userAgent - ua, allowed to be undefined, default takes navigator.userAgent
* @return - null/true/false
*/
export declare function getOsVersion(osName: string, withOS?: boolean, userAgent?: string): string | boolean | null;
/**
* Get array, object property values based on path string
*
* @example
* ```js
* const target = {
* a: 1,
* b: [{
* c: 2
* d: NaN
* }]
* }
* getProperty(target, 'a') // 1
* getProperty(target, 'd', 100) // 100
* getProperty(target, 'b[0].c') // 2
* getProperty(target, 'b[0].d', 100) // 100
* getProperty(target, () => 'a') // 1
* ```
* @since 2.2.4
* @param target - target array, object
* @param prop - query target, can pass function
* @param defaultValue - default value
* @returns result
*/
export declare function getProperty<T extends Record<string, any>>(target: T, prop: string | {
(): string;
}, defaultValue?: any): any;
export declare function getProperty<T extends Array<any>>(target: T, prop: string | {
(): string;
}, defaultValue?: any): any;
/**
* Get a single query parameter (behind "#")
*
* @example
* ```js
* getQueryParam('key1')
* // key1 => xxx
*
* getQueryParam('key1', 'https://test.com?key1=100#/home?key1=200')
* // key1 => 200
* ```
* @since 5.0.0
* @param key - key name
* @param url - pass in the url string
* @returns - result
*/
export declare function getQueryParam(key: string): string | undefined;
export declare function getQueryParam(key: string, url: string): string | undefined;
/**
* Get all URL parameters (behind "#")
*
* @example
* ```js
* getQueryParams('https://test.com?key1=100#/home?key1=200')
* // \{"key1":"200"\}
*
* getQueryParams('https://test.com?key1=100#/home?key1=200', true)
* // \{"key1":200\}
*
* getQueryParams(true)
* // \{"key1":200\}
* ```
* @since 5.0.0
* @param url - pass in the url string
* @param covert - Converts a specific string to a corresponding value (Scientific notation, binary, octal and hexadecimal types of data are not converted, like: 0b111, 0o13, 0xFF, 1e3, -1e-2)
* @returns - result
*/
export declare function getQueryParams(url: string): Record<string, string>;
export declare function getQueryParams(url: boolean): Record<string, unknown>;
export declare function getQueryParams(url: string, covert: boolean): Record<string, unknown>;
/**
* Get slide to top and bottom return 'top' 'bottom', recommend using limit flow
*
* @deprecated will be removed in the next major release.
* @since 1.0.2
* @returns - position
*/
export declare function getScrollPosition(): "bottom" | "top" | undefined;
/**
* Read sessionStorage
*
* @example
* ```js
* const data1 = 100
* const data2 = { a: 10 }
* const data3 = null
*
* setSession('data1', data1)
* setSession('data2', data2)
* setSession('data3', data3)
*
* getSession('data1') // 100
* getSession('data2') // {a:10}
* getSession('data3') // null
*
* getSession('data4') // null
* ```
* @since 1.0.2
* @param name - name
* @returns - sessionStorage
*/
export declare function getSession(name: string): any;
/**
* Get the target type
*
* @since 1.0.2
* @param target - target
* @returns type
*/
export declare function getType<T = any>(target: T): "string" | "number" | "bigint" | "boolean" | "symbol" | "undefined" | "object" | "function" | "window" | "error" | "promise" | "math" | "document" | "navigator" | "global" | "array" | "date" | "regexp" | "null";
/**
* Get a single URL parameter (from the "location.search", before "#")
*
* @example
* ```js
* getUrlParam('key1')
* // key1 => xxx
*
* getUrlParam('key1', 'https://test.com?key1=100#/home?key1=200')
* // key1 => 100
* ```
* @since 5.0.0
* @param key - key name
* @param url - pass in the url string
* @returns - result
*/
export declare function getUrlParam(key: string): string | undefined;
export declare function getUrlParam(key: string, url: string): string | undefined;
/**
* Get all URL parameters (from the "location.search", before "#")
*
* @example
* ```js
* getUrlParams('https://test.com?key1=100#/home?key1=200')
* // \{"key1":"100"\}
*
* getUrlParams('https://test.com?key1=100#/home?key1=200', true)
* // \{"key1":100\}
*
* getUrlParams(true)
* // \{"key1":100\}
* ```
* @since 5.0.0
* @param url - pass in the url string
* @param covert - Converts a specific string to a corresponding value (Scientific notation, binary, octal and hexadecimal types of data are not converted, like: 0b111, 0o13, 0xFF, 1e3, -1e-2)
* @returns - result
*/
export declare function getUrlParams(url: string): Record<string, string>;
export declare function getUrlParams(url: boolean): Record<string, unknown>;
export declare function getUrlParams(url: string, covert: boolean): Record<string, unknown>;
/**
* Determine if it is running on the browser side
*
* @since 4.5.0
* @returns boolean
*/
export declare const inBrowser: boolean;
/**
* Determine if it is running on node.js
*
* @since 5.13.0
* @returns boolean
*/
export declare const inNodeJs: boolean;
/**
* Find the intersection of multiple arrays
*
* @example
* ```js
* intersect([1, 2], [2, 3, 4], [2, 8], [2, '33']) // [2]
* ```
* @since 2.2.1
* @param args - arguments
* @returns - new array
*/
export declare function intersect<T = unknown>(...args: T[][]): T[];
/**
* Determine if it is an array
*
* @example
* ```js
* isArray([]) // true
* ```
* @since 1.0.2
* @param target - any target
* @returns - target is Array
*/
export declare function isArray(target: any): target is any[];
/**
* Determine if dark color mode
*
* @example
* ```js
* isDarkMode() // true
* ```
* @since 5.5.0
* @returns - result
*/
export declare function isDarkMode(): boolean;
/**
* Determine if target is Date
*
* @example
* ```js
* const now = new Date()
*
* isDate(now)
* // true
* ```
* @since 5.15.0
* @param target - any target
* @returns - target is Date
*/
export declare function isDate(target: any): target is Date;
/**
* Whether or not it is a string consisting of numbers
*
* @deprecated will be removed in the next major release.
* @since 1.0.1
* @param str - the string to be tested
* @returns - true/false
*/
export declare function isDigitals(str: string): boolean;
/**
* Determine if 2 objects are equal
*
* @example
* ```js
* isEqual({ a: 22, b: {} }, { b: {}, a: 22 })
* // true
*
* isEqual([1, 2], [2, 1])
* // false
*
* isEqual(NaN, NaN)
* // true
* ```
* @since 5.12.0
* @param a - source
* @param b - compare
* @returns - a equals to b
*/
export declare function isEqual<T, P>(a: T, b: P): boolean;
/**
* The presence or absence of the specified function
*
* @example
* ```js
* isExitsFunction('test') // false
* isExitsFunction('console.log') // true
* ```
* @since 1.0.1
* @param name - incoming function name
* @returns - true/false
*/
export declare function isExitsFunction(name: string): boolean;
/**
* The presence or absence of the specified variable
*
* @example
* ```js
* isExitsVariable('test') // false
* isExitsVariable('window') // true
* ```
* @since 1.0.1
* @param name - variable name
* @returns - true/false
*/
export declare function isExitsVariable(name: string): boolean;
/**
* Determine if it is iterable
*
* @example
* ```js
* isIterable([]) // true
* ```
* @since 5.7.0
* @param target - any target
* @returns - target is Array
*/
export declare function isIterable<T = any>(target: T | Iterable<T>): target is Iterable<T>;
/**
* Detect if the client is a 360 browser
*
* @example
* ```js
* // 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/122.0.6261.95 Safari/537.36 QIHU 360EE'
* // true
*
* // 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/122.0.6261.95 Safari/537.36'
* // true
* ```
* @since 5.22.0
* @param userAgent - ua, allowed to be undefined, default takes navigator.userAgent
* @returns - result
*/
export declare function isNumberBrowser(userAgent?: string): boolean;
/**
* Determine if target is an object
*
* @example
* ```js
* isObject({}) // true
* ```
* @since 5.0.0
* @param target - any target
* @returns - target is Object
*/
export declare function isObject(target: any): target is Object;
/**
* Determine if target is an plain object
*
* @example
* ```js
* isPlainObject({}) // true
* isPlainObject(window) // false
* ```
* @since 5.0.0
* @param target - any target
* @returns - target is plain Object
*/
export declare function isPlainObject(target: unknown): target is PlainObject;
/**
* Determine if target is RegExp
*
* @example
* ```js
* isRegExp(/\d/) // true
* ```
* @since 5.15.0
* @param target - any target
* @returns - target is RegExp
*/
export declare function isRegExp(target: any): target is RegExp;
/**
* Determine if target is an window object
*
* @example
* ```js
* isWindow({}) // false
* isWindow(window) // true
* ```
* @since 5.0.0
* @param target - any
* @returns - target is Window
*/
export declare function isWindow(target: any): target is Window;
export declare interface JSONArray extends Array<JSONValue> {
}
/**
* Converts an array of objects to a comma-separated value (CSV) string containing only the specified columns.
*
* @example
* ```js
* JSONToCSV([{ a: 1, b: 2 }, { a: 3, b: 4, c: 5 }, { a: 6 }, { b: 7 }], ['a', 'b'])
* // 'a,b\n "1", "2"\n "3", "4"\n "6",""\n"", "7"'
*
* JSONToCSV([{ a: 1, b: 2 }, { a: 3, b: 4, c: 5 }, { a: 6 }, { b: 7 }], ['a', 'b'], ';')
* // 'a;b\n "1"; "2"\n "3"; "4"\n "6";""\n""; "7"'
* ```
* @since 1.0.9
* @param data - json data
* @param columns - the specified columns
* @param delimiter - delimiter, default ','
* @returns - CSV data
*/
export declare const JSONToCSV: (arr: any[], columns: any[], delimiter?: string) => string;
export declare type JSONValue = Primitive | PlainObject | JSONArray;
export { loadSource }
/**
* Replacing specific data in a template string, support `${xxxx}` `{{xxxx}}` and `{xxxx}`
*
* @example
* ```ts
* const tmp = "My name is ${name}, I'm ${age} years old."
* mapTemplate(tmp, {
* name: 'saqqdy',
* age: 18
* })
* // My name is saqqdy, I'm 18 years old.
*
* mapTemplate(tmp, key => ({ name: 'saqqdy', age: 28 }[key]))
* // My name is saqqdy, I'm 28 years old.
*
* const tmp = "My name is {{name}}, I'm {{age}} years old."
* mapTemplate(tmp, {
* name: 'saqqdy',
* age: 18
* })
* // My name is saqqdy, I'm 18 years old.
* ```
* @since 5.9.0
* @param tmp - Template string
* @param data - Template data of map function
* @returns - result
*/
export declare function mapTemplate(tmp: string, data: ((value: string) => unknown) | Record<string, unknown>): string;
export declare type MaybePromiseOrGetter<T> = Promise<T> | (<T>() => Promise<T>);
/**
* Find the set of differences of multiple arrays that belong to A but not to B/C/D... of the elements of
*
* @example
* ```js
* minus([1, 2], [2, '33'], [2, 4]) // [1]
* ```
* @since 2.2.1
* @param args - arguments
* @returns - new array
*/
export declare function minus<T = unknown>(...args: T[][]): T[];
export { mountCss }
export { mountImg }
export { mountJs }
export { mountStyle }
/**
* Return the next zIndex value
*
* @example
* ```js
* nextIndex()
* // 1
*
* nextIndex(1000)
* // 1001
*
* nextIndex(10, 100)
* // 100
* ```
* @since 1.0.2
* @param min - optional, minimum value
* @param max - optional, maximum value
* @returns - number
*/
export declare function nextIndex(min?: number, max?: number): number;
/**
* return the next version, Only version types with no more than 3 digits are supported. (Follow the npm version rules)
*
* @example
* ```js
* nextVersion('1.2.33') // 1.2.34
*
* nextVersion('1.2.33', 'major') // 2.0.0
*
* nextVersion('1.2.33', 'premajor', 'alpha') // 2.0.0-alpha.1
* ```
* @since 5.10.0
* @param version - version(like: 1.0.0)
* @param type - optional, version type
* @param preid - optional, prerelease id
* @returns - new version
*/
export declare function nextVersion(version: string, type?: 'major' | 'minor' | 'patch' | 'premajor' | 'preminor' | 'prepatch' | 'prerelease', preid?: string): string;
export declare type OmitPartial<T, K extends keyof T> = {
[P in K]: T[P];
} & Omit<Partial<T>, K>;
export declare type OmitRequired<T, K extends keyof T> = {
[P in K]: T[P];
} & Omit<Required<T>, K>;
/**
* Open link in new tab (file jump download if browser can't parse)
*
* @since 1.0.6
* @param url - link
*/
export declare function openUrl(url: string): void;
export declare interface OsVersion {
name: 'Windows' | 'MacOS' | 'Android' | 'iOS' | 'WindowsPhone' | 'Debian' | 'WebOS' | 'Harmony';
version: string;
}
/**
* Get the system name and version
*
* @example
* ```
* // ipad => 'Mozilla/5.0 (iPad; CPU OS 13_3 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) CriOS/87.0.4280.77 Mobile/15E148 Safari/604.1'
* osVersion() // \{ name: 'iOS', version: '13.3' \}
*
* // iphone => 'Mozilla/5.0 (iPhone; CPU iPhone OS 13_2_3 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/13.0.3 Mobile/15E148 Safari/604.1'
* osVersion() // \{ name: 'iOS', version: '13.2.3' \}
*
* // mac os => 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/114.0.0.0 Safari/537.36'
* osVersion() // \{ name: 'MacOS', version: '10.15.7' \}
*
* // windows => 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/114.0.0.0 Safari/537.36'
* osVersion() // \{ name: 'Windows', version: '10.0' \}
*
* // windows xp => 'Mozilla/5.0 (Windows NT 5.2; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/114.0.0.0 Safari/537.36'
* osVersion() // \{ name: 'Windows', version: 'XP' \}
*
* // windows phone => 'Mozilla/5.0 (Windows Phone OS 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/98.0.4758.82 Safari/537.36'
* osVersion() // \{ name: 'WindowsPhone', version: '10.0' \}
*
* ```
* @since 5.1.0
* @param ua - ua or any ua like string, allowed to be undefined, default is navigator.userAgent
* @return OsVersion|null
*/
export declare function osVersion(ua?: string): OsVersion | null;
/**
* parse url params
*
* @example
* ```js
* parseUrlParam('?key1=100&key2=true&key3=null&key4=undefined&key5=NaN&key6=10.888&key7=Infinity&key8=test')
* // \{"key1":"100","key2":"true","key3":"null","key4":"undefined","key5":"NaN","key6":"10.888","key7":"Infinity","key8":"test"\}
*
* parseUrlParam('?key1=100&key2=true&key3=null&key4=undefined&key5=NaN&key6=10.888&key7=Infinity&key8=test', true)
* // \{"key1":100,"key2":true,"key3":null,"key5":NaN,"key6":10.888,"key7":Infinity,"key8":"test"\}
* ```
* @since 5.0.0
* @param url - url string (like: ?key1=value1&key2=value2)
* @param covert - Converts a specific string to a corresponding value (Scientific notation, binary, octal and hexadecimal types of data are not converted, like: 0b111, 0o13, 0xFF, 1e3, -1e-2)
* @returns object
*/
export declare function parseUrlParam(url: string, covert?: boolean): Record<string, unknown>;
/**
* Collection of common regular expressions
*
* @deprecated It will be refactored and renamed patterns in the next major release.
* @since 1.0.1
* @returns - object
*/
export declare const pattern: {
any: RegExp;
number: RegExp;
string: RegExp;
postcode: RegExp;
url: RegExp;
username: RegExp;
float: RegExp;
email: RegExp;
mobile: RegExp;
chinese: RegExp;
tel: RegExp;
qq: RegExp;
pass: RegExp;
json: RegExp;
arrjson: RegExp;
array: RegExp;
isjson: RegExp;
textarea: RegExp;
mac: RegExp;
ip4: RegExp;
ip4_pri: RegExp;
};
export declare type PickPartial<T, K extends keyof T> = {
[P in K]?: T[P];
} & Omit<T, K>;
export declare type PickRequired<T, K extends keyof T> = {
[P in K]-?: T[P];
} & Omit<T, K>;
export declare interface PlainObject {
[key: string]: JSONValue;
}
/**
* Image preloading
*
* @since 5.5.0
* @param images - images url
*/
export declare function preloader(images: string): HTMLImageElement;
export declare function preloader(images: string[]): Record<string, HTMLImageElement>;
export declare type Primitive = bigint | boolean | null | number | string | symbol | undefined;
/**
* Convert an object to a promise like api
*
* @example
* ```js
* import { promiseFactory, waiting } from 'js-cool'
*
* function promise() {
* const stats = {
* value: 100
* }
*
* const resolver = () =>
* new Promise(resolve =>
* waiting(2000).then(() => {
* stats.value = 200
* resolve(stats)
* })
* )
*
* return promiseFactory(stats, resolver)
* }
*
* const res = promise() // res => 100
* const res = await promise() // res => 200
* ```
* @since 5.10.0
* @param original - original object
* @param resolver - resolver function
* @returns - result
*/
export declare function promiseFactory<T extends object>(original: T, resolver: () => Promise<any>): T & PromiseLike<T>;
/**
* punctual setInterval
*
* @example
* ```js
* const printDate = () => console.log(new Date())
* const timer = punctualTimer(printDate, 1000)
* console.log(timer.count) // 10
* timer.clear() // clear punctualTimer or use clearTimeout(timer.timer)
* ```
* @since 5.18.0
* @param handler - A function to be executed after the timer expires.
* @param delay - The time, in milliseconds that the timer should wait before the specified function or code is executed. If this parameter is omitted, a value of 0 is used, meaning execute "immediately", or more accurately, the next event cycle.
* @param args - Additional arguments which are passed through to the function specified by handler.
*/
export declare function punctualTimer<TArgs extends any[]>(handler: (args: void) => void, delay: number, [...args]?: TArgs): PunctualTimerReturns;
export declare function punctualTimer<TArgs extends any[]>(handler: (...args: TArgs) => void, delay: number, [...args]?: TArgs): PunctualTimerReturns;
export declare interface PunctualTimerReturns {
count: number;
timer: number | null;
clear: () => void;
}
/**
* Generate random hexadecimal colors
*
* @example
* ```js
* randomColor()
* // #bf444b
*
* randomColor(200)
* // #d6e9d7
*
* randomColor(200, 255)
* // #d3f9e4
*
* randomColor([0, 0, 0], [255, 255, 255])
* // #d6e9d7
* ```
* @since 5.5.0
* @param min - the minimum value of the random numbers, eg: [10, 10, 10]
* @param max - the maximum value of the random number, eg: [255, 255, 255]
* @returns - result
*/
export declare function randomColor(min?: number | [number, number, number], max?: number | [number, number, number]): string;
/**
* Get a random integer
*
* @example
* ```js
* randomNumber()
* // 8
*
* randomNumber(0.1, 0.9)
* // 0.8
* ```
* @since 5.0.0
* @param min - the minimum value of the random number
* @param max - the maximum value of the random number
* @returns - random number
*/
export declare function randomNumber(min?: number, max?: number): number;
/**
* Generate n random integers that sum to a fixed sum
*
* @example
* ```js
* randomNumbers()
* // [8]
*
* randomNumbers(4, 5)
* // [1, 1, 2, 1]
*
* randomNumbers(4, 5, false)
* // [0, 1, 2, 2]
* ```
* @since 5.4.0
* @param n - Number of generated integers, default: 1
* @param sum - Sum of generated integers, default: 100
* @param max - Generate integers that are not zero, default: true
* @returns - numbers
*/
export declare function randomNumbers(n?: number, sum?: number, noZero?: boolean): number[];
/**
* Get a random string
*
* @example
* ```ts
* // 1. No parameters are passed, a 32-bit (possibly) string containing upper and lower case letters and numbers is generated by default
* randomString()
* // PVSjz902EqYbmxaLtvDnggtnlvt5uFTZ
*
* // 2. Generate a 16-bit random string
* randomString(16)
* // coTgZy0mqqMJ1sMM
*
* // 3. Same effect as #2 above
* randomString({
* length: 16
* })
* // ngCI5aPqJm84t90d
*
* // 4. Generate containing special characters (old way of passing values, not recommended)
* randomString(true)
* // 0Uby@op3B-sK5]dHl4S|15As.OlHiNXd
*
* // 5. Same effect as #4 above (recommended)
* randomString({
* charTypes: ['uppercase', 'lowercase', 'number', 'special']
* })
* // m,2^vpkrE,F,DbcSFk0=vr&@DJ27j9XK
*
* // 6. Same effect as #4 above, Limit string length to 16 bits
* randomString(16, true)
* // dXz[J_sYM^3d8fnA
*
* // 7. Generate a 16-bit random number
* randomString({
* length: 16,
* charTypes: 'number'
* })
* // 7450026301030286
*
* // 8. Elimination of confusing characters: oOLl,9gq,Vv,Uu,I1
* randomString({
* length: 16,
* noConfuse: true
* })
* // 8DEGna8ppC4mqyew
*
* // 9. The generated random string must contain at least 1 character of each type of character specified, e.g. to generate a 16-bit password that must contain upper and lower case letters, numbers, and special characters.
* randomString({
* length: 16,
* strict: true
* })
* // PFYAPD5KFqOHIADL
* ```
* @since 5.0.0
* @param len - the length of the random string that needs to be obtained
* @param options - optional, randomString options
* @returns - random string
*/
export declare function randomString(len?: number, options?: RandomStringOptions | boolean): string;
export declare function randomString(len?: RandomStringOptions | boolean, options?: RandomStringOptions | boolean): string;
export declare type RandomStringCharType = 'uppercase' | 'lowercase' | 'number' | 'special';
export declare interface RandomStringOptions {
length?: number;
charTypes?: RandomStringCharType | ArrayOneMore<RandomStringCharType>;
/**
* Elimination of confusing characters: oOLl,9gq,Vv,Uu,I1
*/
noConfuse?: boolean;
/**
* The generated random string must contain each of the listed character types
*/
strict?: boolean;
}
/**
* removeEvent removes the event delegate created by addEvent
*
* @since 1.0.2
* @param element - js dom object
* @param type - The type of the event. No need to add on
* @param handler - Callback method.
*/
export declare function removeEvent(element: AnyObject, type: string, handler: AnyFunction): void;
/**
* Converts RGB component values to color codes.
*
* @example
* ```js
* RGBToHex(255, 165, 1)
* // 'ffa501'
* ```
* @since 1.0.9
* @param r - the 1st value of RGB
* @param g - RGB's 2nd value
* @param b - RGB's 3rd value
* @returns - hex value
*/
export declare const RGBToHex: (r: number, g: number, b: number) => string;
/**
* Secure parsing of JSON strings
*
* @example
* ```js
* safeParse('100')
* // 100
*
* safeParse('{"a":"undefined","b":"NaN","c":"Infinity","d":"9007199254740993"}')
* // { b: NaN, c: Infinity, d: 9007199254740993n }
* ```
* @param data - JSON string
* @param covert - Whether to convert data, default: true
* @returns - JSON Object
*/
export declare function safeParse(data: string, covert?: boolean): any;
/**
* Secure stringify of JSON Object
*
* @example
* ```js
* safeStringify(100)
* // "10