webext-storage 1.0.0 → 1.1.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.
@@ -1,13 +1,15 @@
1
1
  /// <reference types="chrome" />
2
- export type StorageItemOptions = {
2
+ export type StorageItemOptions<T> = {
3
3
  area?: chrome.storage.AreaName;
4
+ defaultValue?: T;
4
5
  };
5
- export declare class StorageItem<T> {
6
+ export declare class StorageItem<Base, InferredBase extends (Base | undefined) = Base | undefined, Return = InferredBase extends undefined ? Base | undefined : InferredBase> {
6
7
  readonly key: string;
7
8
  readonly area: chrome.storage.AreaName;
8
- constructor(key: string, { area }?: StorageItemOptions);
9
- get(): Promise<T | undefined>;
10
- set(value: T): Promise<void>;
9
+ readonly defaultValue?: InferredBase;
10
+ constructor(key: string, { area, defaultValue, }?: StorageItemOptions<NonNullable<InferredBase>>);
11
+ get(): Promise<Return>;
12
+ set(value: NonNullable<InferredBase>): Promise<void>;
11
13
  remove(): Promise<void>;
12
- onChange(callback: (value: T) => void, signal?: AbortSignal): void;
14
+ onChange(callback: (value: NonNullable<InferredBase>) => void, signal?: AbortSignal): void;
13
15
  }
@@ -2,14 +2,16 @@ import chromeP from 'webext-polyfill-kinda';
2
2
  export class StorageItem {
3
3
  key;
4
4
  area;
5
- constructor(key, { area = 'local' } = {}) {
5
+ defaultValue;
6
+ constructor(key, { area = 'local', defaultValue, } = {}) {
6
7
  this.key = key;
7
8
  this.area = area;
9
+ this.defaultValue = defaultValue;
8
10
  }
9
11
  async get() {
10
12
  const result = await chromeP.storage[this.area].get(this.key);
11
13
  if (!Object.hasOwn(result, this.key)) {
12
- return;
14
+ return this.defaultValue;
13
15
  }
14
16
  // eslint-disable-next-line @typescript-eslint/no-unsafe-return -- Assumes the user never uses the Storage API directly
15
17
  return result[this.key];
@@ -22,7 +24,6 @@ export class StorageItem {
22
24
  }
23
25
  onChange(callback, signal) {
24
26
  const changeHandler = (changes, area) => {
25
- console.log('changeHandler', changes, area);
26
27
  const changedItem = changes[this.key];
27
28
  if (area === this.area && changedItem) {
28
29
  // eslint-disable-next-line @typescript-eslint/no-unsafe-argument -- Assumes the user never uses the Storage API directly
@@ -32,6 +33,8 @@ export class StorageItem {
32
33
  chrome.storage.onChanged.addListener(changeHandler);
33
34
  signal?.addEventListener('abort', () => {
34
35
  chrome.storage.onChanged.removeListener(changeHandler);
35
- }, { once: true });
36
+ }, {
37
+ once: true,
38
+ });
36
39
  }
37
40
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "webext-storage",
3
- "version": "1.0.0",
3
+ "version": "1.1.0",
4
4
  "description": "A more usable typed storage API for Web Extensions",
5
5
  "keywords": [
6
6
  "browser",
@@ -52,7 +52,7 @@
52
52
  "@types/sinon-chrome": "^2.2.13",
53
53
  "jest-chrome": "^0.8.0",
54
54
  "sinon-chrome": "^3.0.1",
55
- "tsd": "^0.28.1",
55
+ "tsd": "^0.29.0",
56
56
  "typescript": "^5.2.2",
57
57
  "vitest": "^0.34.6",
58
58
  "xo": "^0.56.0"
package/readme.md CHANGED
@@ -26,6 +26,8 @@ Or download the [standalone bundle](https://bundle.fregante.com/?pkg=webext-stor
26
26
  import {StorageItem} from "webext-storage";
27
27
 
28
28
  const username = new StorageItem<string>('username')
29
+ // Or
30
+ const username = new StorageItem('username', {defaultValue: 'admin'})
29
31
 
30
32
  await username.set('Ugo');
31
33
  // Promise<void>