@accitdg/web-helpers 0.0.2 → 0.0.4

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 CHANGED
@@ -1 +1,254 @@
1
- WEB HELPERS
1
+ # Web Helpers
2
+
3
+ A collection of utility functions for web development, including currency conversion, Base64 encoding/decoding, and file handling.
4
+
5
+ ## Installation
6
+
7
+ ```bash
8
+ npm install web-helpers
9
+ ```
10
+
11
+ ## Usage
12
+
13
+ ### Import the package
14
+
15
+ ```javascript
16
+ import webHelpers from "web-helpers";
17
+ // or
18
+ import {
19
+ convertNumberToCurrency,
20
+ arrayBufferToBase64 /* ... */,
21
+ } from "web-helpers";
22
+ ```
23
+
24
+ ## Functions
25
+
26
+ ### `convertNumberToCurrency(numberValue: number): string`
27
+
28
+ Converts a number to Philippine Peso (PHP) currency format.
29
+
30
+ **Parameters:**
31
+
32
+ - `numberValue` (number): The number to convert
33
+
34
+ **Returns:** Formatted currency string
35
+
36
+ **Example:**
37
+
38
+ ```javascript
39
+ webHelpers.convertNumberToCurrency(1000);
40
+ // Output: "₱1,000.00"
41
+ ```
42
+
43
+ ---
44
+
45
+ ### `arrayBufferToBase64(buffer: ArrayBuffer): string`
46
+
47
+ Converts an ArrayBuffer to a Base64-encoded string.
48
+
49
+ **Parameters:**
50
+
51
+ - `buffer` (ArrayBuffer): The buffer to encode
52
+
53
+ **Returns:** Base64 encoded string
54
+
55
+ **Example:**
56
+
57
+ ```javascript
58
+ const buffer = new ArrayBuffer(8);
59
+ const base64 = webHelpers.arrayBufferToBase64(buffer);
60
+ ```
61
+
62
+ ---
63
+
64
+ ### `cleanBase64(base64: string): string`
65
+
66
+ Removes the data URL prefix from a Base64 string, leaving only the encoded data.
67
+
68
+ **Parameters:**
69
+
70
+ - `base64` (string): The Base64 string with or without prefix
71
+
72
+ **Returns:** Cleaned Base64 string without prefix
73
+
74
+ **Example:**
75
+
76
+ ```javascript
77
+ const cleaned = webHelpers.cleanBase64("...");
78
+ // Output: "iVBORw0KG..."
79
+ ```
80
+
81
+ ---
82
+
83
+ ### `restoreBase64(cleanedBase64: string, imageType?: string): string`
84
+
85
+ Restores a clean Base64 string to a complete data URL format.
86
+
87
+ **Parameters:**
88
+
89
+ - `cleanedBase64` (string): The Base64 string without prefix
90
+ - `imageType` (string, optional): Image type (default: "png")
91
+
92
+ **Returns:** Complete data URL string
93
+
94
+ **Example:**
95
+
96
+ ```javascript
97
+ const dataUrl = webHelpers.restoreBase64("iVBORw0KG...", "jpeg");
98
+ // Output: "..."
99
+ ```
100
+
101
+ ---
102
+
103
+ ### `downloadBase64File(base64Data: string, filename: string): void`
104
+
105
+ Triggers a download of a file from Base64-encoded data.
106
+
107
+ **Parameters:**
108
+
109
+ - `base64Data` (string): The Base64 encoded file data
110
+ - `filename` (string): The name of the file to download
111
+
112
+ **Example:**
113
+
114
+ ```javascript
115
+ webHelpers.downloadBase64File(
116
+ "...",
117
+ "image.png"
118
+ );
119
+ ```
120
+
121
+ ---
122
+
123
+ ### `getFileExtensionFromBase64(base64String: string): string | null`
124
+
125
+ Extracts the file extension from a Base64 data URL.
126
+
127
+ **Parameters:**
128
+
129
+ - `base64String` (string): The Base64 data URL
130
+
131
+ **Returns:** File extension (e.g., "png", "pdf") or null if parsing fails
132
+
133
+ **Example:**
134
+
135
+ ```javascript
136
+ const ext = webHelpers.getFileExtensionFromBase64(
137
+ "..."
138
+ );
139
+ // Output: "png"
140
+ ```
141
+
142
+ ---
143
+
144
+ ## Configuration
145
+
146
+ createPayload and createPayload2 read applicationId and notificationId from a global config object. Call configureHelpers once during app initialization to set global defaults:
147
+
148
+ ```ts
149
+ configureHelpers({
150
+ applicationId: "app-123",
151
+ notificationId: "notif-abc",
152
+ });
153
+ ```
154
+
155
+ - These global values are stored on globalThis.\_\_WEB_HELPERS_CONFIG.
156
+ - Individual calls to createPayload / createPayload2 can override these values by passing notifId / applicationId in the arguments.
157
+
158
+ ## Payload factories
159
+
160
+ ### createPayload(args?)
161
+
162
+ Returns a full, readable payload shape suitable for APIs that expect verbose keys.
163
+
164
+ Signature (TypeScript):
165
+
166
+ ```ts
167
+ createPayload(args?: {
168
+ pagination?: { count: number; page: number };
169
+ payload?: Record<string, any>;
170
+ notifId?: string | null;
171
+ })
172
+ ```
173
+
174
+ Returns:
175
+
176
+ ```ts
177
+ {
178
+ isLazyLoading: boolean;
179
+ notificationId: string | null;
180
+ applicationId: string | null;
181
+ geoLocation: {
182
+ latitude: string;
183
+ longitude: string;
184
+ dateTime: string;
185
+ }
186
+ pagination: {
187
+ count: number;
188
+ page: number;
189
+ }
190
+ payload: Record<string, any>;
191
+ }
192
+ ```
193
+
194
+ Example:
195
+
196
+ ```ts
197
+ const result = createPayload({ payload: { foo: "bar" } });
198
+ // uses configured notificationId/applicationId unless notifId is provided
199
+ ```
200
+
201
+ ### createPayload2(options?)
202
+
203
+ Returns a compact payload shape (short keys) for services that use abbreviated keys.
204
+
205
+ Signature (TypeScript):
206
+
207
+ ```ts
208
+ createPayload2({
209
+ pagination?: { c: number; p: number },
210
+ payload?: Record<string, any>,
211
+ notifId?: string | null,
212
+ applicationId?: string | null,
213
+ } = {})
214
+ ```
215
+
216
+ Returns:
217
+
218
+ ```ts
219
+ {
220
+ isLl: boolean;
221
+ nId: string | null;
222
+ aId: string | null;
223
+ gL: {
224
+ lt: string;
225
+ long: string;
226
+ date: string;
227
+ }
228
+ pg: {
229
+ c: number;
230
+ p: number;
231
+ }
232
+ p: Record<string, any>;
233
+ }
234
+ ```
235
+
236
+ Example:
237
+
238
+ ```ts
239
+ const short = createPayload2({ payload: { x: 1 } });
240
+ // uses configured applicationId/notificationId unless overridden in the call
241
+ ```
242
+
243
+ ## Supported File Types
244
+
245
+ The `cleanBase64` function supports:
246
+
247
+ - Images: png, jpg, jpeg, gif, webp, etc.
248
+ - PDF documents
249
+ - Word documents (.docx, .dotx)
250
+ - Excel spreadsheets (.xlsx)
251
+
252
+ ## License
253
+
254
+ @allcardtech2025
package/dist/index.esm.ts CHANGED
@@ -43,6 +43,60 @@ const getFileExtensionFromBase64 = base64String => {
43
43
  return null;
44
44
  }
45
45
  };
46
+ const createPayload = args => {
47
+ // ...existing code...
48
+ let param = typeof globalThis.objTrim === "function" ? globalThis.objTrim(args.payload ?? {}) : args.payload ?? {};
49
+ var data = {
50
+ isLazyLoading: false,
51
+ notificationId: args.notifId ?? globalThis.__WEB_HELPERS_CONFIG?.notificationId ?? null,
52
+ applicationId: globalThis.__WEB_HELPERS_CONFIG?.applicationId ?? null,
53
+ geoLocation: {
54
+ latitude: "0",
55
+ longitude: "0",
56
+ dateTime: new Date().toISOString()
57
+ },
58
+ pagination: args.pagination ?? {
59
+ count: 0,
60
+ page: 0
61
+ },
62
+ payload: param
63
+ };
64
+ return data;
65
+ };
66
+ const createPayload2 = ({
67
+ pagination = {
68
+ c: 0,
69
+ p: 0
70
+ },
71
+ payload = {},
72
+ notifId,
73
+ applicationId
74
+ } = {}) => {
75
+ const cfg = globalThis.__WEB_HELPERS_CONFIG || {};
76
+ const nId = notifId ?? cfg.notificationId ?? null;
77
+ const aId = applicationId ?? cfg.applicationId ?? null;
78
+ const objTrimFn = typeof globalThis.objTrim === "function" ? globalThis.objTrim : o => o;
79
+ const param = objTrimFn(payload);
80
+ return {
81
+ isLl: false,
82
+ nId,
83
+ aId,
84
+ gL: {
85
+ lt: "0",
86
+ long: "0",
87
+ date: new Date().toISOString()
88
+ },
89
+ pg: pagination,
90
+ p: param
91
+ };
92
+ };
93
+ // Add this helper to configure global values (call once during app init)
94
+ const configureHelpers = config => {
95
+ globalThis.__WEB_HELPERS_CONFIG = {
96
+ ...(globalThis.__WEB_HELPERS_CONFIG || {}),
97
+ ...config
98
+ };
99
+ };
46
100
 
47
101
  const webHelpers = {
48
102
  convertNumberToCurrency,
@@ -50,7 +104,10 @@ const webHelpers = {
50
104
  cleanBase64,
51
105
  downloadBase64File,
52
106
  restoreBase64,
53
- getFileExtensionFromBase64
107
+ getFileExtensionFromBase64,
108
+ configureHelpers,
109
+ createPayload,
110
+ createPayload2
54
111
  };
55
112
 
56
113
  export { webHelpers as default, webHelpers };
package/dist/index.ts CHANGED
@@ -47,6 +47,60 @@ const getFileExtensionFromBase64 = base64String => {
47
47
  return null;
48
48
  }
49
49
  };
50
+ const createPayload = args => {
51
+ // ...existing code...
52
+ let param = typeof globalThis.objTrim === "function" ? globalThis.objTrim(args.payload ?? {}) : args.payload ?? {};
53
+ var data = {
54
+ isLazyLoading: false,
55
+ notificationId: args.notifId ?? globalThis.__WEB_HELPERS_CONFIG?.notificationId ?? null,
56
+ applicationId: globalThis.__WEB_HELPERS_CONFIG?.applicationId ?? null,
57
+ geoLocation: {
58
+ latitude: "0",
59
+ longitude: "0",
60
+ dateTime: new Date().toISOString()
61
+ },
62
+ pagination: args.pagination ?? {
63
+ count: 0,
64
+ page: 0
65
+ },
66
+ payload: param
67
+ };
68
+ return data;
69
+ };
70
+ const createPayload2 = ({
71
+ pagination = {
72
+ c: 0,
73
+ p: 0
74
+ },
75
+ payload = {},
76
+ notifId,
77
+ applicationId
78
+ } = {}) => {
79
+ const cfg = globalThis.__WEB_HELPERS_CONFIG || {};
80
+ const nId = notifId ?? cfg.notificationId ?? null;
81
+ const aId = applicationId ?? cfg.applicationId ?? null;
82
+ const objTrimFn = typeof globalThis.objTrim === "function" ? globalThis.objTrim : o => o;
83
+ const param = objTrimFn(payload);
84
+ return {
85
+ isLl: false,
86
+ nId,
87
+ aId,
88
+ gL: {
89
+ lt: "0",
90
+ long: "0",
91
+ date: new Date().toISOString()
92
+ },
93
+ pg: pagination,
94
+ p: param
95
+ };
96
+ };
97
+ // Add this helper to configure global values (call once during app init)
98
+ const configureHelpers = config => {
99
+ globalThis.__WEB_HELPERS_CONFIG = {
100
+ ...(globalThis.__WEB_HELPERS_CONFIG || {}),
101
+ ...config
102
+ };
103
+ };
50
104
 
51
105
  const webHelpers = {
52
106
  convertNumberToCurrency,
@@ -54,7 +108,10 @@ const webHelpers = {
54
108
  cleanBase64,
55
109
  downloadBase64File,
56
110
  restoreBase64,
57
- getFileExtensionFromBase64
111
+ getFileExtensionFromBase64,
112
+ configureHelpers,
113
+ createPayload,
114
+ createPayload2
58
115
  };
59
116
 
60
117
  exports["default"] = webHelpers;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@accitdg/web-helpers",
3
- "version": "0.0.2",
3
+ "version": "0.0.4",
4
4
  "type": "module",
5
5
  "scripts": {
6
6
  "build": "rollup -c",