gzjs-utils 1.0.2-7.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,477 @@
1
+ declare type any_str = string | undefined | null;
2
+ /**
3
+ * 年份
4
+ */
5
+ declare type year = number;
6
+ /**
7
+ * 月数
8
+ */
9
+ declare type moth = number;
10
+ /**
11
+ * 天数
12
+ */
13
+ declare type day = number;
14
+ /**
15
+ * 0=trim左右空白
16
+ * 1=trim左边空白
17
+ * 2=trim右边空白
18
+ */
19
+ declare type TrimMode = 0 | 1 | 2;
20
+ export type URLParam = string | number | boolean | any;
21
+ export type QueryParams = {
22
+ [key: string]: string | boolean | any | "";
23
+ } & Record<any, any>;
24
+ export type URI = {
25
+ "source": string | "";
26
+ "protocol": string | "";
27
+ "authority": string | "";
28
+ "userInfo": string | "";
29
+ "user": string | "";
30
+ "password": string | "";
31
+ "host": string | "";
32
+ "port": string | "";
33
+ "relative": string | "";
34
+ "path": string | "";
35
+ "directory": string | "";
36
+ "file": string | "";
37
+ "query": string | "";
38
+ "anchor": string | "";
39
+ "origin": string | "";
40
+ "hash": string | "";
41
+ "params": QueryParams;
42
+ toURLString: () => string;
43
+ hashInfo: {
44
+ params: QueryParams;
45
+ toString: () => string;
46
+ };
47
+ };
48
+ export type RandomTypeOrSource = 1 | 2 | 3 | (number | string)[] | string;
49
+ export declare const TRUE_FLAG: readonly (string | number | boolean)[];
50
+ export declare const FALSE_FLAG: readonly (string | number | boolean)[];
51
+ export declare const type: (obj: any) => any;
52
+ export declare const isFunction: (obj: any) => boolean;
53
+ export declare const isBase64: (str: any) => boolean;
54
+ export declare const trim: (s: any) => any;
55
+ export declare const parseUri: (str: any, strictMode?: boolean) => URI;
56
+ export declare const parseQuery: (query: string) => QueryParams;
57
+ export declare const getQueryParams: (search?: string, allowFromLocation?: boolean) => QueryParams;
58
+ /**
59
+ * 随机生成UUID
60
+ * @param len 长度
61
+ */
62
+ export declare function uuid(len: number): string;
63
+ export declare function isArrayLike(obj: any): boolean;
64
+ export declare function isArray(obj: any): boolean;
65
+ export declare function shuffle<T>(arr: any): any;
66
+ /**
67
+ * 获取随机数, 默认 字母+数组
68
+ * @param len 随机数长度
69
+ * @param typeOrSource 随机数类型:1=字母+数字, 2=数字 , 3=字母,或者自定义数据源
70
+ */
71
+ export declare function random(len?: number, typeOrSource?: RandomTypeOrSource): string;
72
+ declare const _Utils_: {
73
+ /**
74
+ * 获取字符串中包含的中文个数
75
+ * @param obj 字符串
76
+ * @returns 中文字符的数量
77
+ */
78
+ chineseLen(obj: any_str): number;
79
+ /**
80
+ * 从身份证获取年龄(年、月、日)
81
+ * @param str 身份证号码
82
+ * @returns 返回 [年份, 月数, 天数] 数组,如果身份证无效则返回空数组
83
+ */
84
+ getAgeFromIDcard(str: string): [year, moth, day] | [];
85
+ /**
86
+ * 获取查询参数
87
+ * @param search 查询参数字符串,如果为空则从 URL 读取
88
+ * @param allowFromLocation 是否允许从 location 上获取,默认为 true
89
+ * @returns 查询参数对象
90
+ */
91
+ getQueryParams: (search?: string, allowFromLocation?: boolean) => QueryParams;
92
+ /**
93
+ * 获取 URL 路径中的指定参数
94
+ * @param url URL 字符串
95
+ * @param key 参数名
96
+ * @returns 参数值
97
+ */
98
+ getUrlParam(url: string, key: string): URLParam;
99
+ /**
100
+ * 获取 URL 路径中的所有参数
101
+ * @param url URL 字符串
102
+ * @returns 查询参数对象
103
+ */
104
+ getUrlParams(url: string): QueryParams;
105
+ /**
106
+ * 从 HTTP 响应中获取文件名
107
+ * @param source 数据源,支持以下格式:
108
+ * - string: Content-Disposition 响应头内容
109
+ * - Headers: Fetch API 的 Headers 对象
110
+ * - Response: Fetch API 的 Response 对象
111
+ * - XMLHttpRequest: XHR 对象
112
+ * @param headerName 可选,指定响应头名称,默认为 'Content-Disposition'
113
+ * @returns 文件名,如果解析失败则返回 null
114
+ */
115
+ getFileNameFromResponse(source: string | Headers | Response | XMLHttpRequest | any, headerName?: string): string;
116
+ /**
117
+ * 判断是否是安卓设备
118
+ * @returns 如果是安卓设备返回 true,否则返回 false
119
+ */
120
+ isAndroid(): boolean;
121
+ /**
122
+ * 是否为数组类型
123
+ * @param obj 待检测的对象
124
+ * @returns 如果是数组类型返回 true,否则返回 false
125
+ */
126
+ isArray: typeof isArray;
127
+ /**
128
+ * 判断是否为空,支持对象、字符串、Map、Set、Array 等
129
+ * @param obj 待检测的对象
130
+ * @returns 如果为空返回 true,否则返回 false
131
+ */
132
+ isEmpty(obj: any): boolean;
133
+ /**
134
+ * 判断是否为空白字符串
135
+ * @param str 待检测的字符串
136
+ * @returns 如果为空白字符串(null、undefined、空字符串或纯空白字符)返回 true
137
+ */
138
+ isBlank(str: any): boolean;
139
+ /**
140
+ * 是否为 Base64 编码字符串
141
+ * @param str 待检测的字符串
142
+ * @returns 如果是 Base64 编码返回 true,否则返回 false
143
+ */
144
+ isBase64: (str: any) => boolean;
145
+ /**
146
+ * 是否为 Base64 图片格式
147
+ * @param str 待检测的字符串,格式如:data:image/png;base64,iVBORw0KGgo******
148
+ * @returns 如果是 Base64 图片格式返回 true,否则返回 false
149
+ */
150
+ isBase64Img(str: any): boolean;
151
+ /**
152
+ * 判断字符串是否全部是中文
153
+ * @param chs 待检测的字符串
154
+ * @returns 如果全部是中文字符返回 true,否则返回 false
155
+ */
156
+ isChinese(chs: any_str): boolean;
157
+ /**
158
+ * 判断对象是否为函数类型
159
+ * @param obj 待检测的对象
160
+ * @returns 如果是函数类型返回 true,否则返回 false
161
+ */
162
+ isFunction: (obj: any) => boolean;
163
+ /**
164
+ * 判断是否为 URL(必须包含协议部分)
165
+ * @param str 待检测的字符串
166
+ * @returns 如果是有效 URL(如 http://baidu.com)返回 true,否则返回 false
167
+ */
168
+ isUrl(str: any_str): boolean;
169
+ /**
170
+ * 判断是否为 HTTP 协议
171
+ * @param str URL 字符串
172
+ * @returns 如果是 HTTP 协议返回 true,否则返回 false
173
+ */
174
+ isHttp(str: any): boolean;
175
+ /**
176
+ * 判断是否为 HTTPS 协议
177
+ * @param str URL 字符串
178
+ * @returns 如果是 HTTPS 协议返回 true,否则返回 false
179
+ */
180
+ isHttps(str: any): boolean;
181
+ /**
182
+ * 判断是否为有效的身份证号码
183
+ * @param str 身份证号码
184
+ * @returns 如果是有效的身份证号码返回 true,否则返回 false
185
+ */
186
+ isIDCard(str: string): boolean;
187
+ /**
188
+ * 是否为 IPv6 地址
189
+ * @param s 待检测的字符串
190
+ * @returns 如果是 IPv6 地址返回 true,否则返回 false
191
+ */
192
+ isIPv6(s: any): boolean;
193
+ /**
194
+ * 是否为 IPv4 地址
195
+ * @param s 待检测的字符串
196
+ * @returns 如果是 IPv4 地址返回 true,否则返回 false
197
+ */
198
+ isIPv4(s: any): boolean;
199
+ /**
200
+ * 是否为 IP 地址(IPv4 或 IPv6)
201
+ * @param str 待检测的字符串
202
+ * @returns 如果是 IP 地址返回 true,否则返回 false
203
+ */
204
+ isIP(str: any): any;
205
+ /**
206
+ * 是否为闰年
207
+ * @param str 年份,yyyy 格式
208
+ * @returns 如果是闰年返回 true,否则返回 false
209
+ */
210
+ isLeapYear(str: number | string): boolean;
211
+ /**
212
+ * 是否为手机号码
213
+ * @param str 待检测的字符串
214
+ * @param country 国家编号,默认为 'cn'(中国),可选 'us'(美国)等
215
+ * @returns 如果是手机号码返回 true,否则返回 false
216
+ */
217
+ isMobile(str: any_str, country?: string | "cn"): boolean;
218
+ /**
219
+ * 是否为邮箱地址
220
+ * @param email 待检测的邮箱字符串
221
+ * @returns 如果是邮箱地址返回 true,否则返回 false
222
+ */
223
+ isEmail(email: string): boolean;
224
+ /**
225
+ * 校验是否包含非法字符(脚本内容)
226
+ * @param text 待检测的文本
227
+ * @returns 如果包含非法字符返回 true,否则返回 false
228
+ */
229
+ isScript(text: string): boolean;
230
+ /**
231
+ * 是否为 String 类型
232
+ * @param obj 待检测的对象
233
+ * @returns 如果是 String 类型返回 true,否则返回 false
234
+ */
235
+ isString(obj: any): boolean;
236
+ /**
237
+ * 判断对象是否为 true
238
+ * <pre>
239
+ * 内置 true 枚举值:[true, 1, "1", "true", "TRUE", "Y", 'y', "YES", "yes", "ON", "on", '是', '开']
240
+ * </pre>
241
+ * @param obj 待检测的对象
242
+ * @returns 如果满足 true 枚举值返回 true,否则返回 false
243
+ */
244
+ isTrue(obj: any): boolean;
245
+ /**
246
+ * 判断对象是否为 boolean 类型或布尔值字符串
247
+ * <pre>
248
+ * 内置 true 枚举值:[true, 1, "1", "true", "TRUE", "Y", 'y', "YES", "yes", "ON", "on", '是', '开']
249
+ * 内置 false 枚举值:[false, 0, "0", "false", "FALSE", "N", 'n', "NO", "no", "OFF", "off", '否', '关']
250
+ * </pre>
251
+ * 与 isTrue 的区别:
252
+ * <pre>
253
+ * 1、isTrue:满足内置 true 枚举值返回 true,否则返回 false
254
+ * 2、isBoolean:满足内置 true 或 false 枚举值中任意值返回 true,否则返回 false
255
+ * </pre>
256
+ * @param obj 待检测的对象
257
+ * @returns 如果是布尔类型或布尔值字符串返回 true,否则返回 false
258
+ */
259
+ isBoolean(obj: any): boolean;
260
+ /**
261
+ * 判断字符串是否为整数
262
+ * @param value 待检测的字符串
263
+ * @returns 如果是整数返回 true,否则返回 false
264
+ */
265
+ isInteger(value: any_str): boolean;
266
+ /**
267
+ * 判断字符串是否为数字格式
268
+ * @param str 待检测的字符串
269
+ * @returns 如果是数字格式返回 true,否则返回 false
270
+ */
271
+ isNumber(str: any): boolean;
272
+ /**
273
+ * 解析 URL 查询参数并封装为参数对象
274
+ * @param search URL 查询参数字符串
275
+ * @returns 查询参数对象
276
+ */
277
+ parseQuery(search: string | ""): QueryParams;
278
+ /**
279
+ * 解析 URI
280
+ * @param source URI 字符串
281
+ * @param strictMode 是否使用严格模式解析
282
+ * @returns 解析后的 URI 对象
283
+ */
284
+ parseUri(source: string | "", strictMode?: boolean): URI;
285
+ /**
286
+ * 新增参数到 URL 上
287
+ * @param url URL 字符串
288
+ * @param key 参数名
289
+ * @param value 参数值
290
+ * @param override 是否覆盖原有参数,默认为 false
291
+ * @returns 新的 URL 字符串
292
+ */
293
+ addParamToURL(url: string, key: string, value: any, override?: boolean): string;
294
+ /**
295
+ * 新增参数对象到 URL 上
296
+ * @param url URL 字符串
297
+ * @param params 参数对象
298
+ * @param override 是否覆盖原有参数,默认为 false
299
+ * @returns 新的 URL 字符串
300
+ */
301
+ addParamObjToURL(url: string, params: Record<any, any> | object, override?: boolean): string;
302
+ /**
303
+ * 从 URL 上删除参数
304
+ * @param url URL 字符串
305
+ * @param keys 要删除的参数名(字符串或数组)
306
+ * @returns 新的 URL 字符串
307
+ */
308
+ removeParamFromURL(url: string, keys?: string[] | string): string;
309
+ /**
310
+ * 随机打乱数组顺序
311
+ * @param arr 待打乱的数组
312
+ * @returns 打乱后的数组
313
+ */
314
+ shuffle: typeof shuffle;
315
+ /**
316
+ * 左填充内容
317
+ * @param str 基础字符串
318
+ * @param len 填充后的总长度
319
+ * @param ch 填充字符,默认为空格
320
+ * @returns 填充后的字符串
321
+ */
322
+ lpad(str: any_str, len: number, ch?: string): any_str;
323
+ /**
324
+ * 右填充内容
325
+ * @param str 基础字符串
326
+ * @param len 填充后的总长度
327
+ * @param ch 填充字符,默认为空格
328
+ * @returns 填充后的字符串
329
+ */
330
+ rpad(str: any_str, len: number, ch?: string): any_str;
331
+ /**
332
+ * 下划线转驼峰
333
+ * @param str 下划线格式的字符串
334
+ * @returns 驼峰格式的字符串
335
+ */
336
+ toCamelCase(str: any): any;
337
+ /**
338
+ * 驼峰转下划线
339
+ * @param str 驼峰格式的字符串
340
+ * @param lowerCase 是否转为小写,默认为 true
341
+ * @returns 下划线格式的字符串
342
+ */
343
+ toUnderlineCase(str: any, lowerCase?: boolean): any;
344
+ /**
345
+ * 去除字符串空白
346
+ * @param str 基础字符串
347
+ * @param flag 去除模式:0=去除左右空白,1=去除左边空白,2=去除右边空白,默认为 0
348
+ * @returns 去除空白后的字符串
349
+ */
350
+ trim<T = string>(str: T, flag?: TrimMode): any;
351
+ /**
352
+ * 去除字符串左边的内容
353
+ * @param str 基础字符串
354
+ * @param prefix 要去除的左边内容,如果不指定则去除左边空白
355
+ * @returns 去除后的字符串
356
+ */
357
+ trimLeft<T = string>(str: T, prefix?: string): T;
358
+ /**
359
+ * 去除字符串右边的内容
360
+ * @param str 基础字符串
361
+ * @param suffix 要去除的右边内容,如果不指定则去除右边空白
362
+ * @returns 去除后的字符串
363
+ */
364
+ trimRight<T = string>(str: T, suffix?: string): T;
365
+ /**
366
+ * 获取对象类型
367
+ * <pre>
368
+ * 例如:
369
+ * type('123') 返回 'String'
370
+ * type(133) 返回 'Number'
371
+ * type([]) 返回 'Array'
372
+ * type() 返回 'Undefined'
373
+ * type(null) 返回 'Null'
374
+ * </pre>
375
+ * @param obj 待检测的对象
376
+ * @returns 对象类型字符串
377
+ */
378
+ type(obj: any): string;
379
+ /**
380
+ * 生成 32 位 UUID
381
+ * @returns UUID 字符串
382
+ */
383
+ uuid(): string;
384
+ /**
385
+ * 生成随机字符串
386
+ */
387
+ random: typeof random;
388
+ /**
389
+ * 数据分页
390
+ * <pre>
391
+ * 例如:
392
+ * page([1,2,3,4,5,6,7,8,9,10], 3) 返回 [[1,2,3],[4,5,6],[7,8,9],[10]]
393
+ * page([1,2,3,4,5,6,7,8,9,10], 3, 3) 返回 [[7,8,9]]
394
+ * </pre>
395
+ * @param arr 数据列表
396
+ * @param pageSize 分页大小
397
+ * @param pageNo 页码(从 1 开始),不指定则返回全部分页数据
398
+ * @returns 分页后的数组
399
+ */
400
+ page(arr: any, pageSize: any, pageNo: any): any[];
401
+ /**
402
+ * 获取当前浏览器 DPI
403
+ * @returns DPI 值
404
+ */
405
+ getDPI(): number;
406
+ /**
407
+ * 毫米转像素
408
+ * @param mm 毫米值
409
+ * @param dpi DPI 值,默认使用当前屏幕 DPI
410
+ * @returns 像素值
411
+ */
412
+ mm2px(mm: number, dpi?: number): number;
413
+ /**
414
+ * 像素转毫米
415
+ * @param px 像素值
416
+ * @param dpi DPI 值,默认使用当前屏幕 DPI
417
+ * @returns 毫米值
418
+ */
419
+ px2mm(px: number, dpi?: number): number;
420
+ /**
421
+ * 英寸转像素
422
+ * @param inc 英寸值
423
+ * @param dpi DPI 值,默认使用当前屏幕 DPI
424
+ * @returns 像素值
425
+ */
426
+ in2px(inc: number, dpi: number): number;
427
+ /**
428
+ * 像素转英寸
429
+ * @param px 像素值
430
+ * @param dpi DPI 值,默认使用当前屏幕 DPI
431
+ * @returns 英寸值
432
+ */
433
+ px2in(px: number, dpi: number): number;
434
+ /**
435
+ * 英寸转毫米
436
+ * @param inc 英寸值
437
+ * @returns 毫米值
438
+ */
439
+ in2mm(inc: number): number;
440
+ /**
441
+ * 毫米转英寸
442
+ * @param mm 毫米值
443
+ * @returns 英寸值
444
+ */
445
+ mm2in(mm: number): number;
446
+ /**
447
+ * 获取 innerText(去除 HTML 标签)
448
+ * @param str HTML 字符串
449
+ * @returns 去除 HTML 标签后的纯文本
450
+ */
451
+ getInnerText(str: string): string;
452
+ /**
453
+ * 克隆对象(深拷贝)
454
+ * @param obj 待克隆的对象
455
+ * @param deep 是否深拷贝,默认 true
456
+ * @returns 克隆后的对象
457
+ * @example
458
+ * // 深拷贝对象
459
+ * const cloned = Utils.clone({ a: 1, b: { c: 2 } });
460
+ *
461
+ * // 浅拷贝
462
+ * const shallow = Utils.clone({ a: 1, b: { c: 2 } }, false);
463
+ *
464
+ * // 克隆数组
465
+ * const arr = Utils.clone([1, 2, { x: 3 }]);
466
+ *
467
+ * // 克隆 Date
468
+ * const date = Utils.clone(new Date());
469
+ *
470
+ * // 克隆 Map/Set
471
+ * const map = Utils.clone(new Map([['a', 1]]));
472
+ * const set = Utils.clone(new Set([1, 2, 3]));
473
+ */
474
+ clone<T>(obj: T, deep?: boolean): T;
475
+ };
476
+ export default _Utils_;
477
+ export declare type Utils = typeof _Utils_;
@@ -0,0 +1,18 @@
1
+ declare type IpRet = {
2
+ public: IpItem[];
3
+ private: IpItem[];
4
+ };
5
+ declare type IpItem = {
6
+ ip: string;
7
+ IPv4: boolean;
8
+ type: "public" | "private" | "IPv6";
9
+ };
10
+ export declare type WebRTCIP = {
11
+ /**
12
+ * 获取IP信息W
13
+ * @param timeout 超时时间
14
+ */
15
+ getIPs(timeout?: number): Promise<IpRet>;
16
+ };
17
+ declare const _WebRTCIP_: WebRTCIP;
18
+ export default _WebRTCIP_;
@@ -0,0 +1,147 @@
1
+ import { Utils } from './Utils';
2
+ import { WebRTCIP } from './WebRTCIP';
3
+ import { Bytes } from './Bytes';
4
+ import { Base64 } from './Base64';
5
+ import { MD5 } from './MD5';
6
+ import { AES } from './AES';
7
+ import { default as _Hmac_ } from './Hmac';
8
+ import { default as SHA } from './SHA';
9
+ import { default as EnumBuilder } from './EnumBuilder';
10
+ import { Env } from './Env';
11
+ import { TreeUtils } from './TreeUtils';
12
+ import { DateUtils } from './DateUtils';
13
+ import { default as ExpUtils } from './ExpUtils';
14
+ import { default as Requests } from './Requests';
15
+ import { ConsoleInstance } from './Console';
16
+ export type KeyInfo = {
17
+ /**
18
+ * 请求过期时长,单位/秒
19
+ */
20
+ req: number;
21
+ /**
22
+ * 申请日期, yyyy-MM-dd HH:mm:ss
23
+ */
24
+ begin: string;
25
+ /**
26
+ * 到期时间,yyyy-MM-dd HH:mm:ss
27
+ */
28
+ end: string;
29
+ /**
30
+ * 是否可用
31
+ */
32
+ enabled: boolean;
33
+ /**
34
+ * 相对有效 日期 的可用时长,如果 enabled=false,则表示 已过期的时长
35
+ */
36
+ diff: number;
37
+ /**
38
+ * 扩展数据
39
+ */
40
+ data?: string;
41
+ };
42
+ /**
43
+ * 枚举项
44
+ */
45
+ export interface EnumItem {
46
+ /**
47
+ * 枚举项名称
48
+ */
49
+ label: string;
50
+ /**
51
+ * 枚举项描述
52
+ */
53
+ desc?: string;
54
+ /**
55
+ * 枚举项编码,默认枚举值
56
+ */
57
+ value: string | number;
58
+ /**
59
+ * 扩展值
60
+ */
61
+ values?: (string | number)[];
62
+ /**
63
+ * 比较是否相等,
64
+ * @param val
65
+ */
66
+ eq?: (val: any | string) => boolean;
67
+ /**
68
+ * 文字颜色值
69
+ */
70
+ color?: string;
71
+ /**
72
+ * 背景颜色
73
+ */
74
+ bgColor?: string;
75
+ }
76
+ export type KeyArg = [
77
+ /**
78
+ * 过期时间, 单位/秒
79
+ */
80
+ expire?: number,
81
+ /**
82
+ * 参数数据
83
+ */
84
+ ...data: any[]
85
+ ] | [
86
+ /**
87
+ * 参数数据
88
+ */
89
+ data?: any,
90
+ expire?: number
91
+ ];
92
+ export type KeyTool = {
93
+ version: string;
94
+ /**
95
+ * 读取授权码信息
96
+ * @param key
97
+ */
98
+ readKey(key: string): KeyInfo;
99
+ /**
100
+ * 创建授权码
101
+ * @param args
102
+ */
103
+ createKey(...args: KeyArg): string;
104
+ };
105
+ /**
106
+ * 分页参数
107
+ */
108
+ export type PageParam = {
109
+ pageNo?: number | 1;
110
+ pageSize?: number | 10;
111
+ };
112
+ /**
113
+ * 分页结果对象
114
+ */
115
+ export type PageResult<T = any> = {
116
+ list: T[];
117
+ total: number;
118
+ };
119
+ export type RequestUtil = typeof Requests;
120
+ export type JsUtils = Utils & Pick<TreeUtils, 'buildTree' | 'eachTree' | 'findTreeItem' | 'treeToArray'> & WebRTCIP & {
121
+ Bytes: Bytes;
122
+ Base64: Base64;
123
+ Utils: Utils;
124
+ DateUtils: DateUtils;
125
+ DT: DateUtils;
126
+ TreeUtils: TreeUtils;
127
+ Requests: RequestUtil;
128
+ ThrottleRequest: typeof Requests.ThrottleRequest;
129
+ MD5: MD5;
130
+ AES: AES;
131
+ Hmac: typeof _Hmac_;
132
+ SHA: typeof SHA;
133
+ EnumBuilder: typeof EnumBuilder;
134
+ ExpUtils: typeof ExpUtils;
135
+ readonly KeyTool: KeyTool;
136
+ getEnvironments(): Env;
137
+ readonly version: string;
138
+ /**
139
+ * 关闭工具日志警告
140
+ * @param flag
141
+ */
142
+ disable_warning?: (flag?: boolean) => void;
143
+ getNativeConsole: () => ConsoleInstance;
144
+ Console: Console;
145
+ };
146
+ declare const _JsUtils_: JsUtils;
147
+ export default _JsUtils_;