memobirdsdk 1.0.0
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.
- package/README.md +483 -0
- package/dist/api/bind.d.ts +24 -0
- package/dist/api/bind.d.ts.map +1 -0
- package/dist/api/bind.js +49 -0
- package/dist/api/bind.js.map +1 -0
- package/dist/api/image.d.ts +25 -0
- package/dist/api/image.d.ts.map +1 -0
- package/dist/api/image.js +46 -0
- package/dist/api/image.js.map +1 -0
- package/dist/api/index.d.ts +9 -0
- package/dist/api/index.d.ts.map +1 -0
- package/dist/api/index.js +9 -0
- package/dist/api/index.js.map +1 -0
- package/dist/api/print.d.ts +71 -0
- package/dist/api/print.d.ts.map +1 -0
- package/dist/api/print.js +147 -0
- package/dist/api/print.js.map +1 -0
- package/dist/api/status.d.ts +24 -0
- package/dist/api/status.d.ts.map +1 -0
- package/dist/api/status.js +47 -0
- package/dist/api/status.js.map +1 -0
- package/dist/client.d.ts +204 -0
- package/dist/client.d.ts.map +1 -0
- package/dist/client.js +250 -0
- package/dist/client.js.map +1 -0
- package/dist/constants.d.ts +18 -0
- package/dist/constants.d.ts.map +1 -0
- package/dist/constants.js +23 -0
- package/dist/constants.js.map +1 -0
- package/dist/errors/APIError.d.ts +16 -0
- package/dist/errors/APIError.d.ts.map +1 -0
- package/dist/errors/APIError.js +21 -0
- package/dist/errors/APIError.js.map +1 -0
- package/dist/errors/MemobirdError.d.ts +13 -0
- package/dist/errors/MemobirdError.d.ts.map +1 -0
- package/dist/errors/MemobirdError.js +18 -0
- package/dist/errors/MemobirdError.js.map +1 -0
- package/dist/errors/NetworkError.d.ts +14 -0
- package/dist/errors/NetworkError.d.ts.map +1 -0
- package/dist/errors/NetworkError.js +18 -0
- package/dist/errors/NetworkError.js.map +1 -0
- package/dist/errors/ValidationError.d.ts +14 -0
- package/dist/errors/ValidationError.d.ts.map +1 -0
- package/dist/errors/ValidationError.js +18 -0
- package/dist/errors/ValidationError.js.map +1 -0
- package/dist/errors/index.d.ts +9 -0
- package/dist/errors/index.d.ts.map +1 -0
- package/dist/errors/index.js +9 -0
- package/dist/errors/index.js.map +1 -0
- package/dist/index.d.ts +21 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +25 -0
- package/dist/index.js.map +1 -0
- package/dist/types/api.d.ts +122 -0
- package/dist/types/api.d.ts.map +1 -0
- package/dist/types/api.js +2 -0
- package/dist/types/api.js.map +1 -0
- package/dist/types/common.d.ts +27 -0
- package/dist/types/common.d.ts.map +1 -0
- package/dist/types/common.js +15 -0
- package/dist/types/common.js.map +1 -0
- package/dist/types/config.d.ts +32 -0
- package/dist/types/config.d.ts.map +1 -0
- package/dist/types/config.js +2 -0
- package/dist/types/config.js.map +1 -0
- package/dist/types/index.d.ts +8 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +8 -0
- package/dist/types/index.js.map +1 -0
- package/dist/utils/content-formatter.d.ts +49 -0
- package/dist/utils/content-formatter.d.ts.map +1 -0
- package/dist/utils/content-formatter.js +65 -0
- package/dist/utils/content-formatter.js.map +1 -0
- package/dist/utils/encoding.d.ts +32 -0
- package/dist/utils/encoding.d.ts.map +1 -0
- package/dist/utils/encoding.js +50 -0
- package/dist/utils/encoding.js.map +1 -0
- package/dist/utils/image.d.ts +42 -0
- package/dist/utils/image.d.ts.map +1 -0
- package/dist/utils/image.js +58 -0
- package/dist/utils/image.js.map +1 -0
- package/dist/utils/index.d.ts +10 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +10 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/retry.d.ts +70 -0
- package/dist/utils/retry.d.ts.map +1 -0
- package/dist/utils/retry.js +132 -0
- package/dist/utils/retry.js.map +1 -0
- package/dist/utils/timestamp.d.ts +27 -0
- package/dist/utils/timestamp.d.ts.map +1 -0
- package/dist/utils/timestamp.js +38 -0
- package/dist/utils/timestamp.js.map +1 -0
- package/package.json +63 -0
|
@@ -0,0 +1,122 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Base response structure for all API calls
|
|
3
|
+
*/
|
|
4
|
+
export interface BaseResponse {
|
|
5
|
+
/** Return code, 1 for success, other values for failure */
|
|
6
|
+
showapi_res_code: number;
|
|
7
|
+
/** Error message when showapi_res_code !== 1 */
|
|
8
|
+
showapi_res_error: string;
|
|
9
|
+
}
|
|
10
|
+
/**
|
|
11
|
+
* Request parameters for binding a user to a device
|
|
12
|
+
*/
|
|
13
|
+
export interface BindUserRequest {
|
|
14
|
+
/** Access Key */
|
|
15
|
+
ak: string;
|
|
16
|
+
/** Timestamp in format 'YYYY-MM-DD HH:mm:ss' */
|
|
17
|
+
timestamp: string;
|
|
18
|
+
/** Memobird device ID (obtained by double-clicking the device) */
|
|
19
|
+
memobirdID: string;
|
|
20
|
+
/** User unique identifier */
|
|
21
|
+
useridentifying: string;
|
|
22
|
+
}
|
|
23
|
+
/**
|
|
24
|
+
* Response from binding a user to a device
|
|
25
|
+
*/
|
|
26
|
+
export interface BindUserResponse extends BaseResponse {
|
|
27
|
+
/** User ID returned after successful binding */
|
|
28
|
+
showapi_userid?: number;
|
|
29
|
+
}
|
|
30
|
+
/**
|
|
31
|
+
* Request parameters for printing content
|
|
32
|
+
*/
|
|
33
|
+
export interface PrintRequest {
|
|
34
|
+
/** Access Key */
|
|
35
|
+
ak: string;
|
|
36
|
+
/** Timestamp in format 'YYYY-MM-DD HH:mm:ss' */
|
|
37
|
+
timestamp: string;
|
|
38
|
+
/** Print content in format 'T:base64text' or 'P:base64image' */
|
|
39
|
+
printcontent: string;
|
|
40
|
+
/** Memobird device ID */
|
|
41
|
+
memobirdID: string;
|
|
42
|
+
/** User ID from binding response */
|
|
43
|
+
userID: number;
|
|
44
|
+
}
|
|
45
|
+
/**
|
|
46
|
+
* Response from print operations
|
|
47
|
+
*/
|
|
48
|
+
export interface PrintResponse extends BaseResponse {
|
|
49
|
+
/** 1 if printed, 0 or other values if not printed */
|
|
50
|
+
result?: number;
|
|
51
|
+
/** Unique ID for the print content */
|
|
52
|
+
printcontentid?: number;
|
|
53
|
+
/** Device GUID */
|
|
54
|
+
smartGuid?: string;
|
|
55
|
+
}
|
|
56
|
+
/**
|
|
57
|
+
* Request parameters for checking print status
|
|
58
|
+
*/
|
|
59
|
+
export interface PrintStatusRequest {
|
|
60
|
+
/** Access Key */
|
|
61
|
+
ak: string;
|
|
62
|
+
/** Timestamp in format 'YYYY-MM-DD HH:mm:ss' */
|
|
63
|
+
timestamp: string;
|
|
64
|
+
/** Print content ID from print response */
|
|
65
|
+
printcontentid: string;
|
|
66
|
+
}
|
|
67
|
+
/**
|
|
68
|
+
* Response from print status check
|
|
69
|
+
*/
|
|
70
|
+
export interface PrintStatusResponse extends BaseResponse {
|
|
71
|
+
/** 1 if printed, 0 or other values if not printed */
|
|
72
|
+
printflag?: number;
|
|
73
|
+
/** Print content ID */
|
|
74
|
+
printcontentID?: string;
|
|
75
|
+
}
|
|
76
|
+
/**
|
|
77
|
+
* Request parameters for converting image to monochrome bitmap
|
|
78
|
+
*/
|
|
79
|
+
export interface ConvertImageRequest {
|
|
80
|
+
/** Access Key */
|
|
81
|
+
ak: string;
|
|
82
|
+
/** JPG or PNG image as Base64 string */
|
|
83
|
+
imgBase64String: string;
|
|
84
|
+
}
|
|
85
|
+
/**
|
|
86
|
+
* Response from image conversion
|
|
87
|
+
*/
|
|
88
|
+
export interface ConvertImageResponse extends BaseResponse {
|
|
89
|
+
/** Monochrome bitmap Base64 string ready for printing */
|
|
90
|
+
result?: string;
|
|
91
|
+
}
|
|
92
|
+
/**
|
|
93
|
+
* Request parameters for printing from URL
|
|
94
|
+
*/
|
|
95
|
+
export interface PrintFromUrlRequest {
|
|
96
|
+
/** Access Key */
|
|
97
|
+
ak: string;
|
|
98
|
+
/** Timestamp in format 'YYYY-MM-DD HH:mm:ss' */
|
|
99
|
+
timestamp: string;
|
|
100
|
+
/** URL of the web page to print */
|
|
101
|
+
printUrl: string;
|
|
102
|
+
/** Memobird device ID */
|
|
103
|
+
memobirdID: string;
|
|
104
|
+
/** User ID from binding response */
|
|
105
|
+
userID: number;
|
|
106
|
+
}
|
|
107
|
+
/**
|
|
108
|
+
* Request parameters for printing from HTML
|
|
109
|
+
*/
|
|
110
|
+
export interface PrintFromHtmlRequest {
|
|
111
|
+
/** Access Key */
|
|
112
|
+
ak: string;
|
|
113
|
+
/** Timestamp in format 'YYYY-MM-DD HH:mm:ss' */
|
|
114
|
+
timestamp: string;
|
|
115
|
+
/** HTML source as GBK Base64 + URL encoded */
|
|
116
|
+
printHtml: string;
|
|
117
|
+
/** Memobird device ID */
|
|
118
|
+
memobirdID: string;
|
|
119
|
+
/** User ID from binding response */
|
|
120
|
+
userID: number;
|
|
121
|
+
}
|
|
122
|
+
//# sourceMappingURL=api.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"api.d.ts","sourceRoot":"","sources":["../../src/types/api.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,MAAM,WAAW,YAAY;IAC3B,2DAA2D;IAC3D,gBAAgB,EAAE,MAAM,CAAC;IAEzB,gDAAgD;IAChD,iBAAiB,EAAE,MAAM,CAAC;CAC3B;AAED;;GAEG;AACH,MAAM,WAAW,eAAe;IAC9B,iBAAiB;IACjB,EAAE,EAAE,MAAM,CAAC;IAEX,gDAAgD;IAChD,SAAS,EAAE,MAAM,CAAC;IAElB,kEAAkE;IAClE,UAAU,EAAE,MAAM,CAAC;IAEnB,6BAA6B;IAC7B,eAAe,EAAE,MAAM,CAAC;CACzB;AAED;;GAEG;AACH,MAAM,WAAW,gBAAiB,SAAQ,YAAY;IACpD,gDAAgD;IAChD,cAAc,CAAC,EAAE,MAAM,CAAC;CACzB;AAED;;GAEG;AACH,MAAM,WAAW,YAAY;IAC3B,iBAAiB;IACjB,EAAE,EAAE,MAAM,CAAC;IAEX,gDAAgD;IAChD,SAAS,EAAE,MAAM,CAAC;IAElB,gEAAgE;IAChE,YAAY,EAAE,MAAM,CAAC;IAErB,yBAAyB;IACzB,UAAU,EAAE,MAAM,CAAC;IAEnB,oCAAoC;IACpC,MAAM,EAAE,MAAM,CAAC;CAChB;AAED;;GAEG;AACH,MAAM,WAAW,aAAc,SAAQ,YAAY;IACjD,qDAAqD;IACrD,MAAM,CAAC,EAAE,MAAM,CAAC;IAEhB,sCAAsC;IACtC,cAAc,CAAC,EAAE,MAAM,CAAC;IAExB,kBAAkB;IAClB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED;;GAEG;AACH,MAAM,WAAW,kBAAkB;IACjC,iBAAiB;IACjB,EAAE,EAAE,MAAM,CAAC;IAEX,gDAAgD;IAChD,SAAS,EAAE,MAAM,CAAC;IAElB,2CAA2C;IAC3C,cAAc,EAAE,MAAM,CAAC;CACxB;AAED;;GAEG;AACH,MAAM,WAAW,mBAAoB,SAAQ,YAAY;IACvD,qDAAqD;IACrD,SAAS,CAAC,EAAE,MAAM,CAAC;IAEnB,uBAAuB;IACvB,cAAc,CAAC,EAAE,MAAM,CAAC;CACzB;AAED;;GAEG;AACH,MAAM,WAAW,mBAAmB;IAClC,iBAAiB;IACjB,EAAE,EAAE,MAAM,CAAC;IAEX,wCAAwC;IACxC,eAAe,EAAE,MAAM,CAAC;CACzB;AAED;;GAEG;AACH,MAAM,WAAW,oBAAqB,SAAQ,YAAY;IACxD,yDAAyD;IACzD,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAED;;GAEG;AACH,MAAM,WAAW,mBAAmB;IAClC,iBAAiB;IACjB,EAAE,EAAE,MAAM,CAAC;IAEX,gDAAgD;IAChD,SAAS,EAAE,MAAM,CAAC;IAElB,mCAAmC;IACnC,QAAQ,EAAE,MAAM,CAAC;IAEjB,yBAAyB;IACzB,UAAU,EAAE,MAAM,CAAC;IAEnB,oCAAoC;IACpC,MAAM,EAAE,MAAM,CAAC;CAChB;AAED;;GAEG;AACH,MAAM,WAAW,oBAAoB;IACnC,iBAAiB;IACjB,EAAE,EAAE,MAAM,CAAC;IAEX,gDAAgD;IAChD,SAAS,EAAE,MAAM,CAAC;IAElB,8CAA8C;IAC9C,SAAS,EAAE,MAAM,CAAC;IAElB,yBAAyB;IACzB,UAAU,EAAE,MAAM,CAAC;IAEnB,oCAAoC;IACpC,MAAM,EAAE,MAAM,CAAC;CAChB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"api.js","sourceRoot":"","sources":["../../src/types/api.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Content type for print operations
|
|
3
|
+
*/
|
|
4
|
+
export type ContentType = 'text' | 'image';
|
|
5
|
+
/**
|
|
6
|
+
* Print status values
|
|
7
|
+
*/
|
|
8
|
+
export declare enum PrintStatus {
|
|
9
|
+
/** Print completed successfully */
|
|
10
|
+
PRINTED = 1,
|
|
11
|
+
/** Print pending or failed */
|
|
12
|
+
PENDING = 0
|
|
13
|
+
}
|
|
14
|
+
/**
|
|
15
|
+
* API success code
|
|
16
|
+
*/
|
|
17
|
+
export declare const API_SUCCESS_CODE = 1;
|
|
18
|
+
/**
|
|
19
|
+
* Content item for mixed content printing
|
|
20
|
+
*/
|
|
21
|
+
export interface ContentItem {
|
|
22
|
+
/** Type of content */
|
|
23
|
+
type: ContentType;
|
|
24
|
+
/** Content string (text or base64 image) */
|
|
25
|
+
content: string;
|
|
26
|
+
}
|
|
27
|
+
//# sourceMappingURL=common.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"common.d.ts","sourceRoot":"","sources":["../../src/types/common.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,MAAM,MAAM,WAAW,GAAG,MAAM,GAAG,OAAO,CAAC;AAE3C;;GAEG;AACH,oBAAY,WAAW;IACrB,mCAAmC;IACnC,OAAO,IAAI;IACX,8BAA8B;IAC9B,OAAO,IAAI;CACZ;AAED;;GAEG;AACH,eAAO,MAAM,gBAAgB,IAAI,CAAC;AAElC;;GAEG;AACH,MAAM,WAAW,WAAW;IAC1B,sBAAsB;IACtB,IAAI,EAAE,WAAW,CAAC;IAClB,4CAA4C;IAC5C,OAAO,EAAE,MAAM,CAAC;CACjB"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Print status values
|
|
3
|
+
*/
|
|
4
|
+
export var PrintStatus;
|
|
5
|
+
(function (PrintStatus) {
|
|
6
|
+
/** Print completed successfully */
|
|
7
|
+
PrintStatus[PrintStatus["PRINTED"] = 1] = "PRINTED";
|
|
8
|
+
/** Print pending or failed */
|
|
9
|
+
PrintStatus[PrintStatus["PENDING"] = 0] = "PENDING";
|
|
10
|
+
})(PrintStatus || (PrintStatus = {}));
|
|
11
|
+
/**
|
|
12
|
+
* API success code
|
|
13
|
+
*/
|
|
14
|
+
export const API_SUCCESS_CODE = 1;
|
|
15
|
+
//# sourceMappingURL=common.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"common.js","sourceRoot":"","sources":["../../src/types/common.ts"],"names":[],"mappings":"AAKA;;GAEG;AACH,MAAM,CAAN,IAAY,WAKX;AALD,WAAY,WAAW;IACrB,mCAAmC;IACnC,mDAAW,CAAA;IACX,8BAA8B;IAC9B,mDAAW,CAAA;AACb,CAAC,EALW,WAAW,KAAX,WAAW,QAKtB;AAED;;GAEG;AACH,MAAM,CAAC,MAAM,gBAAgB,GAAG,CAAC,CAAC"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import type { Options } from 'got';
|
|
2
|
+
/**
|
|
3
|
+
* Retry configuration for failed requests
|
|
4
|
+
*/
|
|
5
|
+
export interface RetryConfig {
|
|
6
|
+
/** Maximum number of retry attempts (default: 3) */
|
|
7
|
+
maxRetries?: number;
|
|
8
|
+
/** Initial delay in milliseconds before first retry (default: 1000) */
|
|
9
|
+
initialDelay?: number;
|
|
10
|
+
/** Multiplier for exponential backoff (default: 2) */
|
|
11
|
+
backoffMultiplier?: number;
|
|
12
|
+
/** Maximum delay in milliseconds between retries (default: 10000) */
|
|
13
|
+
maxDelay?: number;
|
|
14
|
+
/** HTTP status codes that should trigger a retry (default: [408, 429, 500, 502, 503, 504]) */
|
|
15
|
+
retryStatusCodes?: number[];
|
|
16
|
+
}
|
|
17
|
+
/**
|
|
18
|
+
* Memobird SDK configuration
|
|
19
|
+
*/
|
|
20
|
+
export interface MemobirdConfig {
|
|
21
|
+
/** Access Key obtained from open.memobird.cn */
|
|
22
|
+
ak: string;
|
|
23
|
+
/** Base URL for API requests (default: 'http://open.memobird.cn/home') */
|
|
24
|
+
baseUrl?: string;
|
|
25
|
+
/** HTTP request timeout in milliseconds (default: 30000) */
|
|
26
|
+
timeout?: number;
|
|
27
|
+
/** Retry configuration for failed requests */
|
|
28
|
+
retry?: RetryConfig;
|
|
29
|
+
/** Custom got HTTP client options */
|
|
30
|
+
httpOptions?: Partial<Options>;
|
|
31
|
+
}
|
|
32
|
+
//# sourceMappingURL=config.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../../src/types/config.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,KAAK,CAAC;AAEnC;;GAEG;AACH,MAAM,WAAW,WAAW;IAC1B,oDAAoD;IACpD,UAAU,CAAC,EAAE,MAAM,CAAC;IAEpB,uEAAuE;IACvE,YAAY,CAAC,EAAE,MAAM,CAAC;IAEtB,sDAAsD;IACtD,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAE3B,qEAAqE;IACrE,QAAQ,CAAC,EAAE,MAAM,CAAC;IAElB,8FAA8F;IAC9F,gBAAgB,CAAC,EAAE,MAAM,EAAE,CAAC;CAC7B;AAED;;GAEG;AACH,MAAM,WAAW,cAAc;IAC7B,gDAAgD;IAChD,EAAE,EAAE,MAAM,CAAC;IAEX,0EAA0E;IAC1E,OAAO,CAAC,EAAE,MAAM,CAAC;IAEjB,4DAA4D;IAC5D,OAAO,CAAC,EAAE,MAAM,CAAC;IAEjB,8CAA8C;IAC9C,KAAK,CAAC,EAAE,WAAW,CAAC;IAEpB,qCAAqC;IACrC,WAAW,CAAC,EAAE,OAAO,CAAC,OAAO,CAAC,CAAC;CAChC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"config.js","sourceRoot":"","sources":["../../src/types/config.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/types/index.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,cAAc,UAAU,CAAC;AACzB,cAAc,aAAa,CAAC;AAC5B,cAAc,aAAa,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/types/index.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,cAAc,UAAU,CAAC;AACzB,cAAc,aAAa,CAAC;AAC5B,cAAc,aAAa,CAAC"}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import type { ContentItem } from '../types/index.js';
|
|
2
|
+
/**
|
|
3
|
+
* Formats text content with T: prefix for printing
|
|
4
|
+
*
|
|
5
|
+
* Automatically converts UTF-8 text to GBK Base64 encoding as required by the API.
|
|
6
|
+
*
|
|
7
|
+
* @param text - Text content to print
|
|
8
|
+
* @returns Formatted print content (T:base64...)
|
|
9
|
+
*
|
|
10
|
+
* @example
|
|
11
|
+
* ```typescript
|
|
12
|
+
* const formatted = formatTextContent('Hello World');
|
|
13
|
+
* // Returns: 'T:SGVsbG8gV29ybGQ='
|
|
14
|
+
* ```
|
|
15
|
+
*/
|
|
16
|
+
export declare function formatTextContent(text: string): string;
|
|
17
|
+
/**
|
|
18
|
+
* Formats image content with P: prefix for printing
|
|
19
|
+
*
|
|
20
|
+
* @param base64Image - Monochrome bitmap Base64 image (should be pre-converted)
|
|
21
|
+
* @returns Formatted print content (P:base64...)
|
|
22
|
+
*
|
|
23
|
+
* @example
|
|
24
|
+
* ```typescript
|
|
25
|
+
* const formatted = formatImageContent(monochromeBase64);
|
|
26
|
+
* // Returns: 'P:Qk0OAgAAAAAAAD4A...'
|
|
27
|
+
* ```
|
|
28
|
+
*/
|
|
29
|
+
export declare function formatImageContent(base64Image: string): string;
|
|
30
|
+
/**
|
|
31
|
+
* Formats mixed content (text and images) for printing
|
|
32
|
+
*
|
|
33
|
+
* Combines multiple text and image items with pipe (|) separator.
|
|
34
|
+
*
|
|
35
|
+
* @param items - Array of content items with type and content
|
|
36
|
+
* @returns Formatted print content with T: and P: prefixes
|
|
37
|
+
*
|
|
38
|
+
* @example
|
|
39
|
+
* ```typescript
|
|
40
|
+
* const formatted = formatMixedContent([
|
|
41
|
+
* { type: 'text', content: 'Hello' },
|
|
42
|
+
* { type: 'image', content: 'base64imagedata' },
|
|
43
|
+
* { type: 'text', content: 'World' }
|
|
44
|
+
* ]);
|
|
45
|
+
* // Returns: 'T:SGVsbG8=|P:base64imagedata|T:V29ybGQ='
|
|
46
|
+
* ```
|
|
47
|
+
*/
|
|
48
|
+
export declare function formatMixedContent(items: ContentItem[]): string;
|
|
49
|
+
//# sourceMappingURL=content-formatter.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"content-formatter.d.ts","sourceRoot":"","sources":["../../src/utils/content-formatter.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAErD;;;;;;;;;;;;;GAaG;AACH,wBAAgB,iBAAiB,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,CAGtD;AAED;;;;;;;;;;;GAWG;AACH,wBAAgB,kBAAkB,CAAC,WAAW,EAAE,MAAM,GAAG,MAAM,CAE9D;AAED;;;;;;;;;;;;;;;;;GAiBG;AACH,wBAAgB,kBAAkB,CAAC,KAAK,EAAE,WAAW,EAAE,GAAG,MAAM,CAU/D"}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
import { textToGBKBase64 } from './encoding.js';
|
|
2
|
+
/**
|
|
3
|
+
* Formats text content with T: prefix for printing
|
|
4
|
+
*
|
|
5
|
+
* Automatically converts UTF-8 text to GBK Base64 encoding as required by the API.
|
|
6
|
+
*
|
|
7
|
+
* @param text - Text content to print
|
|
8
|
+
* @returns Formatted print content (T:base64...)
|
|
9
|
+
*
|
|
10
|
+
* @example
|
|
11
|
+
* ```typescript
|
|
12
|
+
* const formatted = formatTextContent('Hello World');
|
|
13
|
+
* // Returns: 'T:SGVsbG8gV29ybGQ='
|
|
14
|
+
* ```
|
|
15
|
+
*/
|
|
16
|
+
export function formatTextContent(text) {
|
|
17
|
+
const gbkBase64 = textToGBKBase64(text);
|
|
18
|
+
return `T:${gbkBase64}`;
|
|
19
|
+
}
|
|
20
|
+
/**
|
|
21
|
+
* Formats image content with P: prefix for printing
|
|
22
|
+
*
|
|
23
|
+
* @param base64Image - Monochrome bitmap Base64 image (should be pre-converted)
|
|
24
|
+
* @returns Formatted print content (P:base64...)
|
|
25
|
+
*
|
|
26
|
+
* @example
|
|
27
|
+
* ```typescript
|
|
28
|
+
* const formatted = formatImageContent(monochromeBase64);
|
|
29
|
+
* // Returns: 'P:Qk0OAgAAAAAAAD4A...'
|
|
30
|
+
* ```
|
|
31
|
+
*/
|
|
32
|
+
export function formatImageContent(base64Image) {
|
|
33
|
+
return `P:${base64Image}`;
|
|
34
|
+
}
|
|
35
|
+
/**
|
|
36
|
+
* Formats mixed content (text and images) for printing
|
|
37
|
+
*
|
|
38
|
+
* Combines multiple text and image items with pipe (|) separator.
|
|
39
|
+
*
|
|
40
|
+
* @param items - Array of content items with type and content
|
|
41
|
+
* @returns Formatted print content with T: and P: prefixes
|
|
42
|
+
*
|
|
43
|
+
* @example
|
|
44
|
+
* ```typescript
|
|
45
|
+
* const formatted = formatMixedContent([
|
|
46
|
+
* { type: 'text', content: 'Hello' },
|
|
47
|
+
* { type: 'image', content: 'base64imagedata' },
|
|
48
|
+
* { type: 'text', content: 'World' }
|
|
49
|
+
* ]);
|
|
50
|
+
* // Returns: 'T:SGVsbG8=|P:base64imagedata|T:V29ybGQ='
|
|
51
|
+
* ```
|
|
52
|
+
*/
|
|
53
|
+
export function formatMixedContent(items) {
|
|
54
|
+
return items
|
|
55
|
+
.map((item) => {
|
|
56
|
+
if (item.type === 'text') {
|
|
57
|
+
return formatTextContent(item.content);
|
|
58
|
+
}
|
|
59
|
+
else {
|
|
60
|
+
return formatImageContent(item.content);
|
|
61
|
+
}
|
|
62
|
+
})
|
|
63
|
+
.join('|');
|
|
64
|
+
}
|
|
65
|
+
//# sourceMappingURL=content-formatter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"content-formatter.js","sourceRoot":"","sources":["../../src/utils/content-formatter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,eAAe,CAAC;AAGhD;;;;;;;;;;;;;GAaG;AACH,MAAM,UAAU,iBAAiB,CAAC,IAAY;IAC5C,MAAM,SAAS,GAAG,eAAe,CAAC,IAAI,CAAC,CAAC;IACxC,OAAO,KAAK,SAAS,EAAE,CAAC;AAC1B,CAAC;AAED;;;;;;;;;;;GAWG;AACH,MAAM,UAAU,kBAAkB,CAAC,WAAmB;IACpD,OAAO,KAAK,WAAW,EAAE,CAAC;AAC5B,CAAC;AAED;;;;;;;;;;;;;;;;;GAiBG;AACH,MAAM,UAAU,kBAAkB,CAAC,KAAoB;IACrD,OAAO,KAAK;SACT,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;QACZ,IAAI,IAAI,CAAC,IAAI,KAAK,MAAM,EAAE,CAAC;YACzB,OAAO,iBAAiB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACzC,CAAC;aAAM,CAAC;YACN,OAAO,kBAAkB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAC1C,CAAC;IACH,CAAC,CAAC;SACD,IAAI,CAAC,GAAG,CAAC,CAAC;AACf,CAAC"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Converts UTF-8 text to GBK encoded Base64 string
|
|
3
|
+
*
|
|
4
|
+
* This is required for Chinese characters in print content according to Memobird API documentation.
|
|
5
|
+
* The API expects Chinese text to be GBK encoded before Base64 conversion.
|
|
6
|
+
*
|
|
7
|
+
* @param text - UTF-8 text to convert
|
|
8
|
+
* @returns GBK Base64 encoded string
|
|
9
|
+
* @throws {ValidationError} If encoding fails
|
|
10
|
+
*
|
|
11
|
+
* @example
|
|
12
|
+
* ```typescript
|
|
13
|
+
* const encoded = textToGBKBase64('你好世界');
|
|
14
|
+
* console.log(encoded); // Outputs GBK Base64 string
|
|
15
|
+
* ```
|
|
16
|
+
*/
|
|
17
|
+
export declare function textToGBKBase64(text: string): string;
|
|
18
|
+
/**
|
|
19
|
+
* Decodes GBK Base64 string back to UTF-8 text
|
|
20
|
+
*
|
|
21
|
+
* @param gbkBase64 - GBK Base64 encoded string
|
|
22
|
+
* @returns UTF-8 decoded text
|
|
23
|
+
* @throws {ValidationError} If decoding fails
|
|
24
|
+
*
|
|
25
|
+
* @example
|
|
26
|
+
* ```typescript
|
|
27
|
+
* const decoded = gbkBase64ToText(encodedString);
|
|
28
|
+
* console.log(decoded); // Outputs: '你好世界'
|
|
29
|
+
* ```
|
|
30
|
+
*/
|
|
31
|
+
export declare function gbkBase64ToText(gbkBase64: string): string;
|
|
32
|
+
//# sourceMappingURL=encoding.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"encoding.d.ts","sourceRoot":"","sources":["../../src/utils/encoding.ts"],"names":[],"mappings":"AAGA;;;;;;;;;;;;;;;GAeG;AACH,wBAAgB,eAAe,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,CAUpD;AAED;;;;;;;;;;;;GAYG;AACH,wBAAgB,eAAe,CAAC,SAAS,EAAE,MAAM,GAAG,MAAM,CAUzD"}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import iconv from 'iconv-lite';
|
|
2
|
+
import { ValidationError } from '../errors/index.js';
|
|
3
|
+
/**
|
|
4
|
+
* Converts UTF-8 text to GBK encoded Base64 string
|
|
5
|
+
*
|
|
6
|
+
* This is required for Chinese characters in print content according to Memobird API documentation.
|
|
7
|
+
* The API expects Chinese text to be GBK encoded before Base64 conversion.
|
|
8
|
+
*
|
|
9
|
+
* @param text - UTF-8 text to convert
|
|
10
|
+
* @returns GBK Base64 encoded string
|
|
11
|
+
* @throws {ValidationError} If encoding fails
|
|
12
|
+
*
|
|
13
|
+
* @example
|
|
14
|
+
* ```typescript
|
|
15
|
+
* const encoded = textToGBKBase64('你好世界');
|
|
16
|
+
* console.log(encoded); // Outputs GBK Base64 string
|
|
17
|
+
* ```
|
|
18
|
+
*/
|
|
19
|
+
export function textToGBKBase64(text) {
|
|
20
|
+
try {
|
|
21
|
+
const gbkBuffer = iconv.encode(text, 'gbk');
|
|
22
|
+
return gbkBuffer.toString('base64');
|
|
23
|
+
}
|
|
24
|
+
catch (error) {
|
|
25
|
+
throw new ValidationError(`Failed to encode text to GBK Base64: ${error instanceof Error ? error.message : String(error)}`, 'text');
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* Decodes GBK Base64 string back to UTF-8 text
|
|
30
|
+
*
|
|
31
|
+
* @param gbkBase64 - GBK Base64 encoded string
|
|
32
|
+
* @returns UTF-8 decoded text
|
|
33
|
+
* @throws {ValidationError} If decoding fails
|
|
34
|
+
*
|
|
35
|
+
* @example
|
|
36
|
+
* ```typescript
|
|
37
|
+
* const decoded = gbkBase64ToText(encodedString);
|
|
38
|
+
* console.log(decoded); // Outputs: '你好世界'
|
|
39
|
+
* ```
|
|
40
|
+
*/
|
|
41
|
+
export function gbkBase64ToText(gbkBase64) {
|
|
42
|
+
try {
|
|
43
|
+
const buffer = Buffer.from(gbkBase64, 'base64');
|
|
44
|
+
return iconv.decode(buffer, 'gbk');
|
|
45
|
+
}
|
|
46
|
+
catch (error) {
|
|
47
|
+
throw new ValidationError(`Failed to decode GBK Base64 to text: ${error instanceof Error ? error.message : String(error)}`, 'gbkBase64');
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
//# sourceMappingURL=encoding.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"encoding.js","sourceRoot":"","sources":["../../src/utils/encoding.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,YAAY,CAAC;AAC/B,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AAErD;;;;;;;;;;;;;;;GAeG;AACH,MAAM,UAAU,eAAe,CAAC,IAAY;IAC1C,IAAI,CAAC;QACH,MAAM,SAAS,GAAG,KAAK,CAAC,MAAM,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;QAC5C,OAAO,SAAS,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;IACtC,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,MAAM,IAAI,eAAe,CACvB,wCAAwC,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,EAChG,MAAM,CACP,CAAC;IACJ,CAAC;AACH,CAAC;AAED;;;;;;;;;;;;GAYG;AACH,MAAM,UAAU,eAAe,CAAC,SAAiB;IAC/C,IAAI,CAAC;QACH,MAAM,MAAM,GAAG,MAAM,CAAC,IAAI,CAAC,SAAS,EAAE,QAAQ,CAAC,CAAC;QAChD,OAAO,KAAK,CAAC,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;IACrC,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,MAAM,IAAI,eAAe,CACvB,wCAAwC,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,EAChG,WAAW,CACZ,CAAC;IACJ,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Validates if a string is a valid Base64 encoded string
|
|
3
|
+
*
|
|
4
|
+
* @param base64String - String to validate
|
|
5
|
+
* @returns true if valid Base64
|
|
6
|
+
*
|
|
7
|
+
* @example
|
|
8
|
+
* ```typescript
|
|
9
|
+
* isValidBase64Image('SGVsbG8gV29ybGQ='); // true
|
|
10
|
+
* isValidBase64Image('not-base64!@#'); // false
|
|
11
|
+
* ```
|
|
12
|
+
*/
|
|
13
|
+
export declare function isValidBase64Image(base64String: string): boolean;
|
|
14
|
+
/**
|
|
15
|
+
* Strips Base64 data URL prefix if present
|
|
16
|
+
*
|
|
17
|
+
* Removes 'data:image/...;base64,' prefix from data URLs.
|
|
18
|
+
*
|
|
19
|
+
* @param base64String - Base64 string (may include data URL prefix)
|
|
20
|
+
* @returns Clean Base64 string without prefix
|
|
21
|
+
*
|
|
22
|
+
* @example
|
|
23
|
+
* ```typescript
|
|
24
|
+
* stripDataUrlPrefix('...');
|
|
25
|
+
* // Returns: 'iVBORw0KG...'
|
|
26
|
+
* ```
|
|
27
|
+
*/
|
|
28
|
+
export declare function stripDataUrlPrefix(base64String: string): string;
|
|
29
|
+
/**
|
|
30
|
+
* Reads an image file and converts it to Base64
|
|
31
|
+
*
|
|
32
|
+
* @param filePath - Path to image file
|
|
33
|
+
* @returns Promise resolving to Base64 encoded image
|
|
34
|
+
* @throws {ValidationError} If file cannot be read
|
|
35
|
+
*
|
|
36
|
+
* @example
|
|
37
|
+
* ```typescript
|
|
38
|
+
* const base64 = await imageFileToBase64('./image.jpg');
|
|
39
|
+
* ```
|
|
40
|
+
*/
|
|
41
|
+
export declare function imageFileToBase64(filePath: string): Promise<string>;
|
|
42
|
+
//# sourceMappingURL=image.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"image.d.ts","sourceRoot":"","sources":["../../src/utils/image.ts"],"names":[],"mappings":"AAGA;;;;;;;;;;;GAWG;AACH,wBAAgB,kBAAkB,CAAC,YAAY,EAAE,MAAM,GAAG,OAAO,CAGhE;AAED;;;;;;;;;;;;;GAaG;AACH,wBAAgB,kBAAkB,CAAC,YAAY,EAAE,MAAM,GAAG,MAAM,CAG/D;AAED;;;;;;;;;;;GAWG;AACH,wBAAsB,iBAAiB,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAUzE"}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
import { promises as fs } from 'node:fs';
|
|
2
|
+
import { ValidationError } from '../errors/index.js';
|
|
3
|
+
/**
|
|
4
|
+
* Validates if a string is a valid Base64 encoded string
|
|
5
|
+
*
|
|
6
|
+
* @param base64String - String to validate
|
|
7
|
+
* @returns true if valid Base64
|
|
8
|
+
*
|
|
9
|
+
* @example
|
|
10
|
+
* ```typescript
|
|
11
|
+
* isValidBase64Image('SGVsbG8gV29ybGQ='); // true
|
|
12
|
+
* isValidBase64Image('not-base64!@#'); // false
|
|
13
|
+
* ```
|
|
14
|
+
*/
|
|
15
|
+
export function isValidBase64Image(base64String) {
|
|
16
|
+
const base64Pattern = /^[A-Za-z0-9+/]+=*$/;
|
|
17
|
+
return base64Pattern.test(base64String) && base64String.length % 4 === 0;
|
|
18
|
+
}
|
|
19
|
+
/**
|
|
20
|
+
* Strips Base64 data URL prefix if present
|
|
21
|
+
*
|
|
22
|
+
* Removes 'data:image/...;base64,' prefix from data URLs.
|
|
23
|
+
*
|
|
24
|
+
* @param base64String - Base64 string (may include data URL prefix)
|
|
25
|
+
* @returns Clean Base64 string without prefix
|
|
26
|
+
*
|
|
27
|
+
* @example
|
|
28
|
+
* ```typescript
|
|
29
|
+
* stripDataUrlPrefix('...');
|
|
30
|
+
* // Returns: 'iVBORw0KG...'
|
|
31
|
+
* ```
|
|
32
|
+
*/
|
|
33
|
+
export function stripDataUrlPrefix(base64String) {
|
|
34
|
+
const dataUrlPattern = /^data:image\/[a-z]+;base64,/i;
|
|
35
|
+
return base64String.replace(dataUrlPattern, '');
|
|
36
|
+
}
|
|
37
|
+
/**
|
|
38
|
+
* Reads an image file and converts it to Base64
|
|
39
|
+
*
|
|
40
|
+
* @param filePath - Path to image file
|
|
41
|
+
* @returns Promise resolving to Base64 encoded image
|
|
42
|
+
* @throws {ValidationError} If file cannot be read
|
|
43
|
+
*
|
|
44
|
+
* @example
|
|
45
|
+
* ```typescript
|
|
46
|
+
* const base64 = await imageFileToBase64('./image.jpg');
|
|
47
|
+
* ```
|
|
48
|
+
*/
|
|
49
|
+
export async function imageFileToBase64(filePath) {
|
|
50
|
+
try {
|
|
51
|
+
const buffer = await fs.readFile(filePath);
|
|
52
|
+
return buffer.toString('base64');
|
|
53
|
+
}
|
|
54
|
+
catch (error) {
|
|
55
|
+
throw new ValidationError(`Failed to read image file: ${error instanceof Error ? error.message : String(error)}`, 'filePath');
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
//# sourceMappingURL=image.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"image.js","sourceRoot":"","sources":["../../src/utils/image.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,IAAI,EAAE,EAAE,MAAM,SAAS,CAAC;AACzC,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AAErD;;;;;;;;;;;GAWG;AACH,MAAM,UAAU,kBAAkB,CAAC,YAAoB;IACrD,MAAM,aAAa,GAAG,oBAAoB,CAAC;IAC3C,OAAO,aAAa,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,YAAY,CAAC,MAAM,GAAG,CAAC,KAAK,CAAC,CAAC;AAC3E,CAAC;AAED;;;;;;;;;;;;;GAaG;AACH,MAAM,UAAU,kBAAkB,CAAC,YAAoB;IACrD,MAAM,cAAc,GAAG,8BAA8B,CAAC;IACtD,OAAO,YAAY,CAAC,OAAO,CAAC,cAAc,EAAE,EAAE,CAAC,CAAC;AAClD,CAAC;AAED;;;;;;;;;;;GAWG;AACH,MAAM,CAAC,KAAK,UAAU,iBAAiB,CAAC,QAAgB;IACtD,IAAI,CAAC;QACH,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;QAC3C,OAAO,MAAM,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;IACnC,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,MAAM,IAAI,eAAe,CACvB,8BAA8B,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,EACtF,UAAU,CACX,CAAC;IACJ,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Utility functions for Memobird SDK
|
|
3
|
+
* @module utils
|
|
4
|
+
*/
|
|
5
|
+
export * from './encoding.js';
|
|
6
|
+
export * from './timestamp.js';
|
|
7
|
+
export * from './content-formatter.js';
|
|
8
|
+
export * from './image.js';
|
|
9
|
+
export * from './retry.js';
|
|
10
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/utils/index.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,cAAc,eAAe,CAAC;AAC9B,cAAc,gBAAgB,CAAC;AAC/B,cAAc,wBAAwB,CAAC;AACvC,cAAc,YAAY,CAAC;AAC3B,cAAc,YAAY,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Utility functions for Memobird SDK
|
|
3
|
+
* @module utils
|
|
4
|
+
*/
|
|
5
|
+
export * from './encoding.js';
|
|
6
|
+
export * from './timestamp.js';
|
|
7
|
+
export * from './content-formatter.js';
|
|
8
|
+
export * from './image.js';
|
|
9
|
+
export * from './retry.js';
|
|
10
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/utils/index.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,cAAc,eAAe,CAAC;AAC9B,cAAc,gBAAgB,CAAC;AAC/B,cAAc,wBAAwB,CAAC;AACvC,cAAc,YAAY,CAAC;AAC3B,cAAc,YAAY,CAAC"}
|