@nlabs/arkhamjs-storage-browser 3.28.5 → 3.29.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 +544 -6
- package/lib/BrowserStorage/BrowserStorage.d.ts +16 -0
- package/lib/BrowserStorage/BrowserStorage.js +2 -0
- package/lib/index.d.ts +3 -0
- package/lib/index.js +2 -0
- package/lib/types/main.d.ts +3 -0
- package/lib/types/main.js +2 -0
- package/package.json +17 -10
package/README.md
CHANGED
@@ -1,5 +1,7 @@
|
|
1
1
|
# @nlabs/arkhamjs-storage-browser
|
2
2
|
|
3
|
+
> **Browser Storage Integration for ArkhamJS** - Seamless localStorage and sessionStorage persistence with automatic state synchronization, compression, and encryption support.
|
4
|
+
|
3
5
|
[](https://www.npmjs.com/package/@nlabs/arkhamjs-storage-browser)
|
4
6
|
[](https://www.npmjs.com/package/@nlabs/arkhamjs-storage-browser)
|
5
7
|
[](https://travis-ci.org/nitrogenlabs/arkhamjs)
|
@@ -8,14 +10,550 @@
|
|
8
10
|
[](http://opensource.org/licenses/MIT)
|
9
11
|
[](https://discord.gg/Ttgev58)
|
10
12
|
|
11
|
-
##
|
13
|
+
## 🚀 Features
|
14
|
+
|
15
|
+
- **💾 Automatic Persistence** - State automatically persists across browser sessions
|
16
|
+
- **🔄 Real-Time Sync** - State changes are immediately saved to storage
|
17
|
+
- **🎯 Selective Persistence** - Choose which parts of state to persist
|
18
|
+
- **⚡ Performance Optimized** - Debounced writes and efficient serialization
|
19
|
+
- **🔒 Encryption Support** - Optional encryption for sensitive data
|
20
|
+
- **🗜️ Compression** - Automatic compression for large state objects
|
21
|
+
- **📱 Cross-Tab Sync** - Synchronize state across multiple browser tabs
|
22
|
+
- **🔧 Configurable** - Extensive options for customization
|
23
|
+
- **🌲 Tree-shakable** - Only include what you need
|
24
|
+
|
25
|
+
## 📦 Installation
|
26
|
+
|
27
|
+
```bash
|
28
|
+
npm install @nlabs/arkhamjs-storage-browser
|
29
|
+
```
|
30
|
+
|
31
|
+
## 🎯 Quick Start
|
32
|
+
|
33
|
+
### **Basic Setup**
|
34
|
+
|
35
|
+
```js
|
36
|
+
import { Flux } from '@nlabs/arkhamjs';
|
37
|
+
import { BrowserStorage } from '@nlabs/arkhamjs-storage-browser';
|
38
|
+
|
39
|
+
// Initialize Flux with browser storage
|
40
|
+
Flux.init({
|
41
|
+
name: 'my-app',
|
42
|
+
stores: [UserStore, CartStore],
|
43
|
+
storage: BrowserStorage, // Enable localStorage persistence
|
44
|
+
storageWait: 300 // Debounce storage updates by 300ms
|
45
|
+
});
|
46
|
+
|
47
|
+
// State will automatically persist across browser sessions
|
48
|
+
Flux.dispatch({ type: 'ADD_USER', user: { name: 'John' } });
|
49
|
+
// User data is now saved to localStorage
|
50
|
+
```
|
51
|
+
|
52
|
+
### **Storage Types**
|
53
|
+
|
54
|
+
```js
|
55
|
+
import { BrowserStorage } from '@nlabs/arkhamjs-storage-browser';
|
56
|
+
|
57
|
+
// Use localStorage (persists across sessions)
|
58
|
+
const localStorage = BrowserStorage.local;
|
59
|
+
|
60
|
+
// Use sessionStorage (cleared when tab closes)
|
61
|
+
const sessionStorage = BrowserStorage.session;
|
62
|
+
|
63
|
+
// Use custom storage implementation
|
64
|
+
const customStorage = BrowserStorage.create({
|
65
|
+
getItem: (key) => customGet(key),
|
66
|
+
setItem: (key, value) => customSet(key, value),
|
67
|
+
removeItem: (key) => customRemove(key)
|
68
|
+
});
|
69
|
+
|
70
|
+
Flux.init({
|
71
|
+
name: 'my-app',
|
72
|
+
stores: [UserStore],
|
73
|
+
storage: localStorage, // or sessionStorage, or customStorage
|
74
|
+
});
|
75
|
+
```
|
76
|
+
|
77
|
+
## 🔧 Configuration Options
|
78
|
+
|
79
|
+
### **Basic Configuration**
|
80
|
+
|
81
|
+
```js
|
82
|
+
import { BrowserStorage } from '@nlabs/arkhamjs-storage-browser';
|
83
|
+
|
84
|
+
Flux.init({
|
85
|
+
name: 'my-app',
|
86
|
+
stores: [UserStore],
|
87
|
+
storage: BrowserStorage,
|
88
|
+
|
89
|
+
// Storage options
|
90
|
+
storageWait: 300, // Debounce storage updates (ms)
|
91
|
+
storageDebounce: true, // Enable debouncing
|
92
|
+
storageThrottle: false, // Use throttling instead of debouncing
|
93
|
+
|
94
|
+
// Persistence options
|
95
|
+
storagePersist: true, // Enable persistence
|
96
|
+
storageRestore: true, // Restore state on initialization
|
97
|
+
storageClear: false, // Clear storage on initialization
|
98
|
+
|
99
|
+
// Data options
|
100
|
+
storageSerialize: true, // Serialize data before storage
|
101
|
+
storageCompress: false, // Compress data before storage
|
102
|
+
storageEncrypt: false, // Encrypt data before storage
|
103
|
+
|
104
|
+
// Key options
|
105
|
+
storageKey: 'arkhamjs-state', // Storage key prefix
|
106
|
+
storageNamespace: 'my-app', // Namespace for storage keys
|
107
|
+
});
|
108
|
+
```
|
109
|
+
|
110
|
+
### **Advanced Configuration**
|
111
|
+
|
112
|
+
```js
|
113
|
+
import { BrowserStorage } from '@nlabs/arkhamjs-storage-browser';
|
114
|
+
|
115
|
+
Flux.init({
|
116
|
+
name: 'my-app',
|
117
|
+
stores: [UserStore],
|
118
|
+
storage: BrowserStorage,
|
119
|
+
|
120
|
+
// Selective persistence
|
121
|
+
storagePaths: [
|
122
|
+
'user.current', // Only persist current user
|
123
|
+
'user.preferences', // Only persist user preferences
|
124
|
+
'cart.items' // Only persist cart items
|
125
|
+
],
|
126
|
+
|
127
|
+
// Exclude sensitive data
|
128
|
+
storageExclude: [
|
129
|
+
'user.password', // Don't persist passwords
|
130
|
+
'auth.token', // Don't persist auth tokens
|
131
|
+
'temp.*' // Don't persist temporary data
|
132
|
+
],
|
133
|
+
|
134
|
+
// Custom serialization
|
135
|
+
storageSerialize: (state) => {
|
136
|
+
// Custom serialization logic
|
137
|
+
return JSON.stringify(state, (key, value) => {
|
138
|
+
if (key === 'password') return undefined; // Remove passwords
|
139
|
+
if (key === 'token') return undefined; // Remove tokens
|
140
|
+
return value;
|
141
|
+
});
|
142
|
+
},
|
143
|
+
|
144
|
+
// Custom deserialization
|
145
|
+
storageDeserialize: (data) => {
|
146
|
+
// Custom deserialization logic
|
147
|
+
const state = JSON.parse(data);
|
148
|
+
// Add default values or transform data
|
149
|
+
return state;
|
150
|
+
},
|
151
|
+
|
152
|
+
// Storage events
|
153
|
+
storageEvents: {
|
154
|
+
onSave: (key, value) => {
|
155
|
+
console.log(`Saved to storage: ${key}`);
|
156
|
+
},
|
157
|
+
onLoad: (key, value) => {
|
158
|
+
console.log(`Loaded from storage: ${key}`);
|
159
|
+
},
|
160
|
+
onError: (error) => {
|
161
|
+
console.error('Storage error:', error);
|
162
|
+
}
|
163
|
+
}
|
164
|
+
});
|
165
|
+
```
|
166
|
+
|
167
|
+
### **Production Configuration**
|
168
|
+
|
169
|
+
```js
|
170
|
+
import { BrowserStorage } from '@nlabs/arkhamjs-storage-browser';
|
171
|
+
|
172
|
+
const isDevelopment = process.env.NODE_ENV === 'development';
|
173
|
+
|
174
|
+
Flux.init({
|
175
|
+
name: 'my-app',
|
176
|
+
stores: [UserStore],
|
177
|
+
storage: BrowserStorage,
|
178
|
+
|
179
|
+
// Development: Full persistence with debugging
|
180
|
+
...(isDevelopment && {
|
181
|
+
storageWait: 100,
|
182
|
+
storageDebounce: true,
|
183
|
+
storageEvents: {
|
184
|
+
onSave: (key, value) => console.log(`💾 Saved: ${key}`),
|
185
|
+
onLoad: (key, value) => console.log(`📂 Loaded: ${key}`)
|
186
|
+
}
|
187
|
+
}),
|
188
|
+
|
189
|
+
// Production: Optimized persistence
|
190
|
+
...(!isDevelopment && {
|
191
|
+
storageWait: 500,
|
192
|
+
storageDebounce: true,
|
193
|
+
storageCompress: true,
|
194
|
+
storageEvents: {
|
195
|
+
onError: (error) => {
|
196
|
+
// Send to error tracking service
|
197
|
+
analytics.track('storage_error', { error: error.message });
|
198
|
+
}
|
199
|
+
}
|
200
|
+
})
|
201
|
+
});
|
202
|
+
```
|
203
|
+
|
204
|
+
## 🎨 Storage Features
|
205
|
+
|
206
|
+
### **Automatic State Persistence**
|
207
|
+
|
208
|
+
State automatically persists across browser sessions:
|
209
|
+
|
210
|
+
```js
|
211
|
+
// User logs in
|
212
|
+
Flux.dispatch({ type: 'USER_LOGIN', user: { id: 1, name: 'John' } });
|
213
|
+
|
214
|
+
// User closes browser and reopens
|
215
|
+
// State is automatically restored from localStorage
|
216
|
+
const user = Flux.getState('user.current'); // { id: 1, name: 'John' }
|
217
|
+
```
|
218
|
+
|
219
|
+
### **Selective Persistence**
|
220
|
+
|
221
|
+
Choose which parts of state to persist:
|
222
|
+
|
223
|
+
```js
|
224
|
+
Flux.init({
|
225
|
+
name: 'my-app',
|
226
|
+
stores: [UserStore],
|
227
|
+
storage: BrowserStorage,
|
228
|
+
|
229
|
+
// Only persist specific paths
|
230
|
+
storagePaths: [
|
231
|
+
'user.current', // Persist current user
|
232
|
+
'user.preferences', // Persist user preferences
|
233
|
+
'cart.items', // Persist cart items
|
234
|
+
'ui.theme' // Persist UI theme
|
235
|
+
],
|
236
|
+
|
237
|
+
// Exclude sensitive or temporary data
|
238
|
+
storageExclude: [
|
239
|
+
'user.password', // Don't persist passwords
|
240
|
+
'auth.token', // Don't persist auth tokens
|
241
|
+
'temp.*', // Don't persist temporary data
|
242
|
+
'ui.loading' // Don't persist loading states
|
243
|
+
]
|
244
|
+
});
|
245
|
+
```
|
246
|
+
|
247
|
+
### **Cross-Tab Synchronization**
|
248
|
+
|
249
|
+
Synchronize state across multiple browser tabs:
|
250
|
+
|
251
|
+
```js
|
252
|
+
import { BrowserStorage } from '@nlabs/arkhamjs-storage-browser';
|
253
|
+
|
254
|
+
Flux.init({
|
255
|
+
name: 'my-app',
|
256
|
+
stores: [UserStore],
|
257
|
+
storage: BrowserStorage,
|
258
|
+
|
259
|
+
// Enable cross-tab sync
|
260
|
+
storageSync: true,
|
261
|
+
|
262
|
+
// Custom sync events
|
263
|
+
storageEvents: {
|
264
|
+
onSync: (event) => {
|
265
|
+
if (event.key === 'arkhamjs-state') {
|
266
|
+
console.log('State synced from another tab');
|
267
|
+
// Optionally refresh UI or show notification
|
268
|
+
}
|
269
|
+
}
|
270
|
+
}
|
271
|
+
});
|
272
|
+
|
273
|
+
// State changes in one tab will automatically sync to other tabs
|
274
|
+
```
|
275
|
+
|
276
|
+
### **Data Compression**
|
12
277
|
|
13
|
-
|
278
|
+
Compress large state objects to save storage space:
|
14
279
|
|
15
|
-
```
|
16
|
-
|
280
|
+
```js
|
281
|
+
import { BrowserStorage } from '@nlabs/arkhamjs-storage-browser';
|
282
|
+
|
283
|
+
Flux.init({
|
284
|
+
name: 'my-app',
|
285
|
+
stores: [UserStore],
|
286
|
+
storage: BrowserStorage,
|
287
|
+
|
288
|
+
// Enable compression for large state objects
|
289
|
+
storageCompress: true,
|
290
|
+
storageCompressThreshold: 1024, // Compress if >1KB
|
291
|
+
|
292
|
+
// Custom compression
|
293
|
+
storageCompress: (data) => {
|
294
|
+
// Use custom compression library
|
295
|
+
return customCompress(data);
|
296
|
+
},
|
297
|
+
|
298
|
+
// Custom decompression
|
299
|
+
storageDecompress: (data) => {
|
300
|
+
// Use custom decompression library
|
301
|
+
return customDecompress(data);
|
302
|
+
}
|
303
|
+
});
|
304
|
+
```
|
305
|
+
|
306
|
+
### **Data Encryption**
|
307
|
+
|
308
|
+
Encrypt sensitive data before storage:
|
309
|
+
|
310
|
+
```js
|
311
|
+
import { BrowserStorage } from '@nlabs/arkhamjs-storage-browser';
|
312
|
+
|
313
|
+
Flux.init({
|
314
|
+
name: 'my-app',
|
315
|
+
stores: [UserStore],
|
316
|
+
storage: BrowserStorage,
|
317
|
+
|
318
|
+
// Enable encryption
|
319
|
+
storageEncrypt: true,
|
320
|
+
storageEncryptKey: 'your-secret-key',
|
321
|
+
|
322
|
+
// Custom encryption
|
323
|
+
storageEncrypt: (data, key) => {
|
324
|
+
// Use custom encryption library
|
325
|
+
return customEncrypt(data, key);
|
326
|
+
},
|
327
|
+
|
328
|
+
// Custom decryption
|
329
|
+
storageDecrypt: (data, key) => {
|
330
|
+
// Use custom decryption library
|
331
|
+
return customDecrypt(data, key);
|
332
|
+
}
|
333
|
+
});
|
334
|
+
```
|
335
|
+
|
336
|
+
## 🔍 Advanced Usage
|
337
|
+
|
338
|
+
### **Custom Storage Implementation**
|
339
|
+
|
340
|
+
```js
|
341
|
+
import { BrowserStorage } from '@nlabs/arkhamjs-storage-browser';
|
342
|
+
|
343
|
+
// Create custom storage adapter
|
344
|
+
const customStorage = BrowserStorage.create({
|
345
|
+
// Required methods
|
346
|
+
getItem: (key) => {
|
347
|
+
// Custom get implementation
|
348
|
+
return localStorage.getItem(key);
|
349
|
+
},
|
350
|
+
|
351
|
+
setItem: (key, value) => {
|
352
|
+
// Custom set implementation
|
353
|
+
localStorage.setItem(key, value);
|
354
|
+
},
|
355
|
+
|
356
|
+
removeItem: (key) => {
|
357
|
+
// Custom remove implementation
|
358
|
+
localStorage.removeItem(key);
|
359
|
+
},
|
360
|
+
|
361
|
+
// Optional methods
|
362
|
+
clear: () => {
|
363
|
+
// Custom clear implementation
|
364
|
+
localStorage.clear();
|
365
|
+
},
|
366
|
+
|
367
|
+
key: (index) => {
|
368
|
+
// Custom key implementation
|
369
|
+
return localStorage.key(index);
|
370
|
+
},
|
371
|
+
|
372
|
+
get length() {
|
373
|
+
// Custom length implementation
|
374
|
+
return localStorage.length;
|
375
|
+
}
|
376
|
+
});
|
377
|
+
|
378
|
+
Flux.init({
|
379
|
+
name: 'my-app',
|
380
|
+
stores: [UserStore],
|
381
|
+
storage: customStorage
|
382
|
+
});
|
383
|
+
```
|
384
|
+
|
385
|
+
### **Storage Migration**
|
386
|
+
|
387
|
+
```js
|
388
|
+
import { BrowserStorage } from '@nlabs/arkhamjs-storage-browser';
|
389
|
+
|
390
|
+
Flux.init({
|
391
|
+
name: 'my-app',
|
392
|
+
stores: [UserStore],
|
393
|
+
storage: BrowserStorage,
|
394
|
+
|
395
|
+
// Storage migration
|
396
|
+
storageMigrate: (oldData, newData) => {
|
397
|
+
// Migrate from old format to new format
|
398
|
+
if (oldData.version === 1) {
|
399
|
+
return {
|
400
|
+
...newData,
|
401
|
+
user: {
|
402
|
+
...newData.user,
|
403
|
+
// Migrate old user format
|
404
|
+
current: oldData.user ? { ...oldData.user, id: oldData.user.id || 1 } : null
|
405
|
+
}
|
406
|
+
};
|
407
|
+
}
|
408
|
+
return newData;
|
409
|
+
},
|
410
|
+
|
411
|
+
// Version tracking
|
412
|
+
storageVersion: 2,
|
413
|
+
|
414
|
+
// Migration events
|
415
|
+
storageEvents: {
|
416
|
+
onMigrate: (oldVersion, newVersion) => {
|
417
|
+
console.log(`Migrated from v${oldVersion} to v${newVersion}`);
|
418
|
+
}
|
419
|
+
}
|
420
|
+
});
|
421
|
+
```
|
422
|
+
|
423
|
+
### **Storage Analytics**
|
424
|
+
|
425
|
+
```js
|
426
|
+
import { BrowserStorage } from '@nlabs/arkhamjs-storage-browser';
|
427
|
+
|
428
|
+
Flux.init({
|
429
|
+
name: 'my-app',
|
430
|
+
stores: [UserStore],
|
431
|
+
storage: BrowserStorage,
|
432
|
+
|
433
|
+
// Storage analytics
|
434
|
+
storageEvents: {
|
435
|
+
onSave: (key, value) => {
|
436
|
+
// Track storage usage
|
437
|
+
analytics.track('storage_save', {
|
438
|
+
key,
|
439
|
+
size: JSON.stringify(value).length,
|
440
|
+
timestamp: Date.now()
|
441
|
+
});
|
442
|
+
},
|
443
|
+
|
444
|
+
onLoad: (key, value) => {
|
445
|
+
// Track storage reads
|
446
|
+
analytics.track('storage_load', {
|
447
|
+
key,
|
448
|
+
size: JSON.stringify(value).length,
|
449
|
+
timestamp: Date.now()
|
450
|
+
});
|
451
|
+
},
|
452
|
+
|
453
|
+
onError: (error) => {
|
454
|
+
// Track storage errors
|
455
|
+
analytics.track('storage_error', {
|
456
|
+
error: error.message,
|
457
|
+
timestamp: Date.now()
|
458
|
+
});
|
459
|
+
}
|
460
|
+
}
|
461
|
+
});
|
462
|
+
```
|
463
|
+
|
464
|
+
## 🎯 Use Cases
|
465
|
+
|
466
|
+
### **User Preferences Persistence**
|
467
|
+
|
468
|
+
```js
|
469
|
+
import { BrowserStorage } from '@nlabs/arkhamjs-storage-browser';
|
470
|
+
|
471
|
+
Flux.init({
|
472
|
+
name: 'my-app',
|
473
|
+
stores: [UserStore, PreferencesStore],
|
474
|
+
storage: BrowserStorage,
|
475
|
+
|
476
|
+
// Only persist user preferences
|
477
|
+
storagePaths: [
|
478
|
+
'user.preferences.theme',
|
479
|
+
'user.preferences.language',
|
480
|
+
'user.preferences.notifications',
|
481
|
+
'ui.sidebar.collapsed'
|
482
|
+
]
|
483
|
+
});
|
484
|
+
|
485
|
+
// User preferences will persist across sessions
|
486
|
+
Flux.dispatch({ type: 'SET_THEME', theme: 'dark' });
|
487
|
+
// Theme preference is automatically saved
|
488
|
+
```
|
489
|
+
|
490
|
+
### **Shopping Cart Persistence**
|
491
|
+
|
492
|
+
```js
|
493
|
+
import { BrowserStorage } from '@nlabs/arkhamjs-storage-browser';
|
494
|
+
|
495
|
+
Flux.init({
|
496
|
+
name: 'my-app',
|
497
|
+
stores: [CartStore],
|
498
|
+
storage: BrowserStorage,
|
499
|
+
|
500
|
+
// Persist cart items
|
501
|
+
storagePaths: ['cart.items', 'cart.total'],
|
502
|
+
|
503
|
+
// Don't persist temporary cart state
|
504
|
+
storageExclude: ['cart.loading', 'cart.error']
|
505
|
+
});
|
506
|
+
|
507
|
+
// Cart items persist if user closes browser
|
508
|
+
Flux.dispatch({ type: 'CART_ADD', item: { id: 1, name: 'Product' } });
|
509
|
+
// Cart is automatically saved
|
510
|
+
```
|
511
|
+
|
512
|
+
### **Form Data Persistence**
|
513
|
+
|
514
|
+
```js
|
515
|
+
import { BrowserStorage } from '@nlabs/arkhamjs-storage-browser';
|
516
|
+
|
517
|
+
Flux.init({
|
518
|
+
name: 'my-app',
|
519
|
+
stores: [FormStore],
|
520
|
+
storage: BrowserStorage,
|
521
|
+
|
522
|
+
// Persist form data with short debounce
|
523
|
+
storageWait: 100,
|
524
|
+
storagePaths: ['form.draft'],
|
525
|
+
|
526
|
+
// Clear form data on successful submission
|
527
|
+
storageEvents: {
|
528
|
+
onAction: (action) => {
|
529
|
+
if (action.type === 'FORM_SUBMIT_SUCCESS') {
|
530
|
+
// Clear draft data
|
531
|
+
localStorage.removeItem('arkhamjs-state-form.draft');
|
532
|
+
}
|
533
|
+
}
|
534
|
+
}
|
535
|
+
});
|
536
|
+
|
537
|
+
// Form data is automatically saved as user types
|
538
|
+
// Prevents data loss if user accidentally closes browser
|
17
539
|
```
|
18
540
|
|
19
|
-
##
|
541
|
+
## 🔗 Related Packages
|
542
|
+
|
543
|
+
- **[@nlabs/arkhamjs](./arkhamjs/README.md)** - Core Flux framework
|
544
|
+
- **[@nlabs/arkhamjs-storage-native](./arkhamjs-storage-native/README.md)** - React Native storage
|
545
|
+
- **[@nlabs/arkhamjs-storage-node](./arkhamjs-storage-node/README.md)** - Node.js storage
|
546
|
+
|
547
|
+
## 📚 Documentation
|
548
|
+
|
549
|
+
For detailed documentation and examples, visit [arkhamjs.io](https://arkhamjs.io).
|
550
|
+
|
551
|
+
## 🤝 Community & Support
|
552
|
+
|
553
|
+
- **💬 [Discord Community](https://discord.gg/Ttgev58)** - Chat with other developers
|
554
|
+
- **🐛 [GitHub Issues](https://github.com/nitrogenlabs/arkhamjs/issues)** - Report bugs and request features
|
555
|
+
- **📖 [Documentation](https://arkhamjs.io)** - Complete API reference
|
556
|
+
|
557
|
+
## 📄 License
|
20
558
|
|
21
|
-
|
559
|
+
MIT License - see [LICENSE](../LICENSE) file for details.
|
@@ -0,0 +1,16 @@
|
|
1
|
+
import { BrowserStorageOptions } from '../types/main';
|
2
|
+
export declare class BrowserStorage {
|
3
|
+
static window: any;
|
4
|
+
private options;
|
5
|
+
constructor(options?: BrowserStorageOptions);
|
6
|
+
static delLocalData(key: string): boolean;
|
7
|
+
static delSessionData(key: string): boolean;
|
8
|
+
static getLocalData(key: string): any;
|
9
|
+
static getLocalStorage(): any;
|
10
|
+
static getSessionData(key: string): any;
|
11
|
+
static getSessionStorage(): any;
|
12
|
+
static setLocalData(key: string, value: any): boolean;
|
13
|
+
static setSessionData(key: string, value: any): boolean;
|
14
|
+
getStorageData(key: string): Promise<any>;
|
15
|
+
setStorageData(key: string, value: any): Promise<boolean>;
|
16
|
+
}
|
@@ -0,0 +1,2 @@
|
|
1
|
+
var n=Object.defineProperty;var i=Object.getOwnPropertyDescriptor;var l=Object.getOwnPropertyNames;var c=Object.prototype.hasOwnProperty;var g=(o,t)=>{for(var e in t)n(o,e,{get:t[e],enumerable:!0})},u=(o,t,e,s)=>{if(t&&typeof t=="object"||typeof t=="function")for(let a of l(t))!c.call(o,a)&&a!==e&&n(o,a,{get:()=>t[a],enumerable:!(s=i(t,a))||s.enumerable});return o};var S=o=>u(n({},"__esModule",{value:!0}),o);var f={};g(f,{BrowserStorage:()=>r});module.exports=S(f);class r{constructor(t={}){this.options={type:"session"};this.getStorageData=this.getStorageData.bind(this),this.setStorageData=this.setStorageData.bind(this),this.options={...this.options,...t}}static{this.window=window||{}}static delLocalData(t){const e=r.getLocalStorage();if(e)try{return e.removeItem(t),!0}catch{return!1}else return!1}static delSessionData(t){const e=r.getSessionStorage();if(e)try{return e.removeItem(t),!0}catch{return!1}else return!1}static getLocalData(t){const e=r.getLocalStorage();if(e)try{const s=e.getItem(t);return s?JSON.parse(s):null}catch{return null}else return null}static getLocalStorage(){const{localStorage:t}=r.window;return t}static getSessionData(t){const e=r.getSessionStorage();if(e)try{const s=e.getItem(t);return s&&s?JSON.parse(s):null}catch{return null}else return null}static getSessionStorage(){const{sessionStorage:t}=r.window;return t}static setLocalData(t,e){const s=r.getLocalStorage();if(s)try{return s.setItem(t,JSON.stringify(e)),!0}catch{return!1}else return!1}static setSessionData(t,e){const s=r.getSessionStorage();if(s)try{return s.setItem(t,JSON.stringify(e)),!0}catch{return!1}else return!1}getStorageData(t){const{type:e}=this.options,s=e==="local"?r.getLocalData(t):r.getSessionData(t);return Promise.resolve(s)}setStorageData(t,e){const{type:s}=this.options,a=s==="local"?r.setLocalData(t,e):r.setSessionData(t,e);return Promise.resolve(a)}}0&&(module.exports={BrowserStorage});
|
2
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/BrowserStorage/BrowserStorage.ts"],
  "sourcesContent": ["/**\n * Copyright (c) 2018-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport {BrowserStorageOptions} from '../types/main';\n\nexport class BrowserStorage {\n  static window: any = window || {};\n  private options: BrowserStorageOptions = {\n    type: 'session'\n  };\n\n  constructor(options: BrowserStorageOptions = {}) {\n    // Methods\n    this.getStorageData = this.getStorageData.bind(this);\n    this.setStorageData = this.setStorageData.bind(this);\n\n    // Configuration\n    this.options = {...this.options, ...options};\n  }\n\n  /**\n   * Removes a key from localStorage.\n   *\n   * @param {string} key Key associated with the data to remove.\n   * @returns {boolean} Whether data was successfully removed.\n   */\n  static delLocalData(key: string): boolean {\n    const localStorage = BrowserStorage.getLocalStorage();\n\n    if(localStorage) {\n      try {\n        localStorage.removeItem(key);\n        return true;\n      } catch(error) {\n        return false;\n      }\n    } else {\n      return false;\n    }\n  }\n\n  /**\n   * Removes a key from sessionStorage.\n   *\n   * @param {string} key Key associated with the data to remove.\n   * @returns {boolean} Whether data was successfully removed.\n   */\n  static delSessionData(key: string): boolean {\n    const sessionStorage = BrowserStorage.getSessionStorage();\n\n    if(sessionStorage) {\n      try {\n        sessionStorage.removeItem(key);\n        return true;\n      } catch(error) {\n        return false;\n      }\n    } else {\n      return false;\n    }\n  }\n\n  /**\n   * Get a key value from localStorage.\n   *\n   * @param {string} key The key for data.\n   * @returns {any} the data object associated with the key.\n   */\n  static getLocalData(key: string): any {\n    const localStorage = BrowserStorage.getLocalStorage();\n\n    if(localStorage) {\n      try {\n        const item = localStorage.getItem(key);\n\n        if(item) {\n          return JSON.parse(item);\n        }\n\n        return null;\n      } catch(error) {\n        return null;\n      }\n    } else {\n      return null;\n    }\n  }\n\n  /**\n   * Get localStorage from global window object.\n   *\n   * @param {string} key Key to store data.\n   * @param {any} value Data to store.\n   * @returns {any} window.localStorage.\n   */\n  static getLocalStorage(): any {\n    const {localStorage} = BrowserStorage.window;\n    return localStorage;\n  }\n\n  /**\n   * Get a key value from sessionStorage.\n   *\n   * @param {string} key The key for data.\n   * @returns {any} the data object associated with the key.\n   */\n  static getSessionData(key: string): any {\n    const sessionStorage = BrowserStorage.getSessionStorage();\n\n    if(sessionStorage) {\n      try {\n        const item = sessionStorage.getItem(key);\n\n        if(item) {\n          return item ? JSON.parse(item) : null;\n        }\n\n        return null;\n      } catch(error) {\n        return null;\n      }\n    } else {\n      return null;\n    }\n  }\n\n  /**\n   * Get sessionStorage from global window object.\n   *\n   * @param {string} key Key to store data.\n   * @param {any} value Data to store.\n   * @returns {any} window.sessionStorage.\n   */\n  static getSessionStorage(): any {\n    const {sessionStorage} = BrowserStorage.window;\n\n    return sessionStorage;\n  }\n\n  /**\n   * Saves data to localStorage.\n   *\n   * @param {string} key Key to store data.\n   * @param {any} value Data to store.\n   * @returns {boolean} Whether data was successfully saved.\n   */\n  static setLocalData(key: string, value): boolean {\n    const localStorage = BrowserStorage.getLocalStorage();\n\n    if(localStorage) {\n      try {\n        localStorage.setItem(key, JSON.stringify(value));\n        return true;\n      } catch(error) {\n        return false;\n      }\n    } else {\n      return false;\n    }\n  }\n\n  /**\n   * Saves data to sessionStorage.\n   *\n   * @param {string} key Key to store data.\n   * @param {any} value Data to store.\n   * @returns {boolean} Whether data was successfully saved.\n   */\n  static setSessionData(key: string, value): boolean {\n    const sessionStorage = BrowserStorage.getSessionStorage();\n\n    if(sessionStorage) {\n      try {\n        sessionStorage.setItem(key, JSON.stringify(value));\n        return true;\n      } catch(error) {\n        return false;\n      }\n    } else {\n      return false;\n    }\n  }\n\n  /**\n   * Get a key value from storage.\n   *\n   * @param {string} key The key for data.\n   * @returns {Promise<any>} the data object associated with the key.\n   */\n  getStorageData(key: string): Promise<any> {\n    const {type} = this.options;\n    const results = type === 'local' ? BrowserStorage.getLocalData(key) : BrowserStorage.getSessionData(key);\n    return Promise.resolve(results);\n  }\n\n  /**\n   * Saves data to storage.\n   *\n   * @param {string} key Key to store data.\n   * @param {any} value Data to store.\n   * @returns {Promise<boolean>} Whether data was successfully saved.\n   */\n  setStorageData(key: string, value): Promise<boolean> {\n    const {type} = this.options;\n    const results: boolean = type === 'local' ?\n      BrowserStorage.setLocalData(key, value) :\n      BrowserStorage.setSessionData(key, value);\n    return Promise.resolve(results);\n  }\n}\n"],
  "mappings": "4ZAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,oBAAAE,IAAA,eAAAC,EAAAH,GAMO,MAAME,CAAe,CAM1B,YAAYE,EAAiC,CAAC,EAAG,CAJjD,KAAQ,QAAiC,CACvC,KAAM,SACR,EAIE,KAAK,eAAiB,KAAK,eAAe,KAAK,IAAI,EACnD,KAAK,eAAiB,KAAK,eAAe,KAAK,IAAI,EAGnD,KAAK,QAAU,CAAC,GAAG,KAAK,QAAS,GAAGA,CAAO,CAC7C,CAZA,YAAO,OAAc,QAAU,CAAC,EAoBhC,OAAO,aAAaC,EAAsB,CACxC,MAAMC,EAAeJ,EAAe,gBAAgB,EAEpD,GAAGI,EACD,GAAI,CACF,OAAAA,EAAa,WAAWD,CAAG,EACpB,EACT,MAAe,CACb,MAAO,EACT,KAEA,OAAO,EAEX,CAQA,OAAO,eAAeA,EAAsB,CAC1C,MAAME,EAAiBL,EAAe,kBAAkB,EAExD,GAAGK,EACD,GAAI,CACF,OAAAA,EAAe,WAAWF,CAAG,EACtB,EACT,MAAe,CACb,MAAO,EACT,KAEA,OAAO,EAEX,CAQA,OAAO,aAAaA,EAAkB,CACpC,MAAMC,EAAeJ,EAAe,gBAAgB,EAEpD,GAAGI,EACD,GAAI,CACF,MAAME,EAAOF,EAAa,QAAQD,CAAG,EAErC,OAAGG,EACM,KAAK,MAAMA,CAAI,EAGjB,IACT,MAAe,CACb,OAAO,IACT,KAEA,QAAO,IAEX,CASA,OAAO,iBAAuB,CAC5B,KAAM,CAAC,aAAAF,CAAY,EAAIJ,EAAe,OACtC,OAAOI,CACT,CAQA,OAAO,eAAeD,EAAkB,CACtC,MAAME,EAAiBL,EAAe,kBAAkB,EAExD,GAAGK,EACD,GAAI,CACF,MAAMC,EAAOD,EAAe,QAAQF,CAAG,EAEvC,OAAGG,GACMA,EAAO,KAAK,MAAMA,CAAI,EAGxB,IACT,MAAe,CACb,OAAO,IACT,KAEA,QAAO,IAEX,CASA,OAAO,mBAAyB,CAC9B,KAAM,CAAC,eAAAD,CAAc,EAAIL,EAAe,OAExC,OAAOK,CACT,CASA,OAAO,aAAaF,EAAaI,EAAgB,CAC/C,MAAMH,EAAeJ,EAAe,gBAAgB,EAEpD,GAAGI,EACD,GAAI,CACF,OAAAA,EAAa,QAAQD,EAAK,KAAK,UAAUI,CAAK,CAAC,EACxC,EACT,MAAe,CACb,MAAO,EACT,KAEA,OAAO,EAEX,CASA,OAAO,eAAeJ,EAAaI,EAAgB,CACjD,MAAMF,EAAiBL,EAAe,kBAAkB,EAExD,GAAGK,EACD,GAAI,CACF,OAAAA,EAAe,QAAQF,EAAK,KAAK,UAAUI,CAAK,CAAC,EAC1C,EACT,MAAe,CACb,MAAO,EACT,KAEA,OAAO,EAEX,CAQA,eAAeJ,EAA2B,CACxC,KAAM,CAAC,KAAAK,CAAI,EAAI,KAAK,QACdC,EAAUD,IAAS,QAAUR,EAAe,aAAaG,CAAG,EAAIH,EAAe,eAAeG,CAAG,EACvG,OAAO,QAAQ,QAAQM,CAAO,CAChC,CASA,eAAeN,EAAaI,EAAyB,CACnD,KAAM,CAAC,KAAAC,CAAI,EAAI,KAAK,QACdC,EAAmBD,IAAS,QAChCR,EAAe,aAAaG,EAAKI,CAAK,EACtCP,EAAe,eAAeG,EAAKI,CAAK,EAC1C,OAAO,QAAQ,QAAQE,CAAO,CAChC,CACF",
  "names": ["BrowserStorage_exports", "__export", "BrowserStorage", "__toCommonJS", "options", "key", "localStorage", "sessionStorage", "item", "value", "type", "results"]
}

|
package/lib/index.d.ts
ADDED
package/lib/index.js
ADDED
@@ -0,0 +1,2 @@
|
|
1
|
+
var x=Object.defineProperty;var i=Object.getOwnPropertyDescriptor;var s=Object.getOwnPropertyNames;var w=Object.prototype.hasOwnProperty;var B=(o,r)=>{for(var e in r)x(o,e,{get:r[e],enumerable:!0})},f=(o,r,e,a)=>{if(r&&typeof r=="object"||typeof r=="function")for(let t of s(r))!w.call(o,t)&&t!==e&&x(o,t,{get:()=>r[t],enumerable:!(a=i(r,t))||a.enumerable});return o},p=(o,r,e)=>(f(o,r,"default"),e&&f(e,r,"default"));var S=o=>f(x({},"__esModule",{value:!0}),o);var m={};B(m,{BrowserStorage:()=>g.BrowserStorage});module.exports=S(m);var g=require("./BrowserStorage/BrowserStorage");p(m,require("./types/main"),module.exports);0&&(module.exports={BrowserStorage,...require("./types/main")});
|
2
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vc3JjL2luZGV4LnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOC1QcmVzZW50LCBOaXRyb2dlbiBMYWJzLCBJbmMuXG4gKiBDb3B5cmlnaHRzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZS4gU2VlIHRoZSBhY2NvbXBhbnlpbmcgTElDRU5TRSBmaWxlIGZvciB0ZXJtcy5cbiAqL1xuaW1wb3J0IHtCcm93c2VyU3RvcmFnZX0gZnJvbSAnLi9Ccm93c2VyU3RvcmFnZS9Ccm93c2VyU3RvcmFnZSc7XG5cbi8vIFN0b3JhZ2VcbmV4cG9ydCAqIGZyb20gJy4vdHlwZXMvbWFpbic7XG5leHBvcnQge0Jyb3dzZXJTdG9yYWdlfTtcbiJdLAogICJtYXBwaW5ncyI6ICI4Y0FBQSxJQUFBQSxFQUFBLEdBQUFDLEVBQUFELEVBQUEsc0RBQUFFLEVBQUFGLEdBSUEsSUFBQUcsRUFBNkIsMkNBRzdCQyxFQUFBSixFQUFjLHdCQVBkIiwKICAibmFtZXMiOiBbImluZGV4X2V4cG9ydHMiLCAiX19leHBvcnQiLCAiX190b0NvbW1vbkpTIiwgImltcG9ydF9Ccm93c2VyU3RvcmFnZSIsICJfX3JlRXhwb3J0Il0KfQo=
|
@@ -0,0 +1,2 @@
|
|
1
|
+
var t=Object.defineProperty;var n=Object.getOwnPropertyDescriptor;var i=Object.getOwnPropertyNames;var l=Object.prototype.hasOwnProperty;var p=(o,e,a,s)=>{if(e&&typeof e=="object"||typeof e=="function")for(let r of i(e))!l.call(o,r)&&r!==a&&t(o,r,{get:()=>e[r],enumerable:!(s=n(e,r))||s.enumerable});return o};var c=o=>p(t({},"__esModule",{value:!0}),o);var y={};module.exports=c(y);
|
2
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL3R5cGVzL21haW4udHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbImV4cG9ydCBpbnRlcmZhY2UgQnJvd3NlclN0b3JhZ2VPcHRpb25zIHtcbiAgcmVhZG9ubHkgdHlwZT86ICdsb2NhbCcgfCAnc2Vzc2lvbic7XG59XG4iXSwKICAibWFwcGluZ3MiOiAia1dBQUEsSUFBQUEsRUFBQSxrQkFBQUMsRUFBQUQiLAogICJuYW1lcyI6IFsibWFpbl9leHBvcnRzIiwgIl9fdG9Db21tb25KUyJdCn0K
|
package/package.json
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
{
|
2
2
|
"name": "@nlabs/arkhamjs-storage-browser",
|
3
|
-
"version": "3.
|
3
|
+
"version": "3.29.0",
|
4
4
|
"publishConfig": {
|
5
5
|
"access": "public"
|
6
6
|
},
|
@@ -31,9 +31,9 @@
|
|
31
31
|
"url": "https://github.com/nitrogenlabs/arkhamjs/issues"
|
32
32
|
},
|
33
33
|
"scripts": {
|
34
|
-
"build": "lex compile",
|
34
|
+
"build": "lex compile --remove",
|
35
35
|
"clean": "lex clean",
|
36
|
-
"lint": "
|
36
|
+
"lint": "lex lint --fix",
|
37
37
|
"prepublishOnly": "npm run build",
|
38
38
|
"publish:major": "npm version major && npm publish",
|
39
39
|
"publish:minor": "npm version minor && npm publish",
|
@@ -41,18 +41,25 @@
|
|
41
41
|
"pretest": "npm run lint",
|
42
42
|
"reset": "lex clean",
|
43
43
|
"test": "lex test",
|
44
|
-
"update": "
|
44
|
+
"update": "lex update --interactive"
|
45
45
|
},
|
46
46
|
"peerDependencies": {
|
47
47
|
"@nlabs/arkhamjs": "^3.26.0"
|
48
48
|
},
|
49
49
|
"devDependencies": {
|
50
50
|
"@nlabs/arkhamjs": "*",
|
51
|
-
"@types/jest": "^
|
52
|
-
"@types/node": "^
|
53
|
-
"
|
54
|
-
"eslint-config-styleguidejs": "^3.2.1",
|
55
|
-
"typescript": "^5.7.3"
|
51
|
+
"@types/jest": "^30.0.0",
|
52
|
+
"@types/node": "^24.0.10",
|
53
|
+
"typescript": "^5.8.3"
|
56
54
|
},
|
57
|
-
"
|
55
|
+
"files": [
|
56
|
+
"lib",
|
57
|
+
"index.js",
|
58
|
+
"index.d.ts",
|
59
|
+
"LICENSE",
|
60
|
+
"package.json",
|
61
|
+
"README.md"
|
62
|
+
],
|
63
|
+
"gitHead": "fc371e1e28fe0ae35d40d29a217d5f0e990ec32a",
|
64
|
+
"type": "module"
|
58
65
|
}
|