@tanstack/query-sync-storage-persister 5.0.0-alpha.6 → 5.0.0-alpha.63

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 +1,2 @@
1
1
  export {};
2
+ //# sourceMappingURL=storageIsFull.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"storageIsFull.test.d.ts","sourceRoot":"","sources":["../../../src/__tests__/storageIsFull.test.ts"],"names":[],"mappings":""}
@@ -1 +1,2 @@
1
1
  export declare function sleep(timeout: number): Promise<void>;
2
+ //# sourceMappingURL=utils.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../src/__tests__/utils.ts"],"names":[],"mappings":"AAAA,wBAAgB,KAAK,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAIpD"}
@@ -1,3 +1,5 @@
1
+ 'use strict';
2
+
1
3
  function createSyncStoragePersister({
2
4
  storage,
3
5
  key = `REACT_QUERY_OFFLINE_CACHE`,
@@ -67,5 +69,5 @@ function throttle(func, wait = 100) {
67
69
  // eslint-disable-next-line @typescript-eslint/no-empty-function
68
70
  function noop() {}
69
71
 
70
- export { createSyncStoragePersister };
71
- //# sourceMappingURL=index.mjs.map
72
+ exports.createSyncStoragePersister = createSyncStoragePersister;
73
+ //# sourceMappingURL=index.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.mjs","sources":["../../src/index.ts"],"sourcesContent":["import type {\n PersistedClient,\n Persister,\n PersistRetryer,\n} from '@tanstack/query-persist-client-core'\n\ninterface Storage {\n getItem: (key: string) => string | null\n setItem: (key: string, value: string) => void\n removeItem: (key: string) => void\n}\n\ninterface CreateSyncStoragePersisterOptions {\n /** The storage client used for setting and retrieving items from cache.\n * For SSR pass in `undefined`. Note that window.localStorage can be\n * `null` in Android WebViews depending on how they are configured.\n */\n storage: Storage | undefined | null\n /** The key to use when storing the cache */\n key?: string\n /** To avoid spamming,\n * pass a time in ms to throttle saving the cache to disk */\n throttleTime?: number\n /**\n * How to serialize the data to storage.\n * @default `JSON.stringify`\n */\n serialize?: (client: PersistedClient) => string\n /**\n * How to deserialize the data from storage.\n * @default `JSON.parse`\n */\n deserialize?: (cachedString: string) => PersistedClient\n\n retry?: PersistRetryer\n}\n\nexport function createSyncStoragePersister({\n storage,\n key = `REACT_QUERY_OFFLINE_CACHE`,\n throttleTime = 1000,\n serialize = JSON.stringify,\n deserialize = JSON.parse,\n retry,\n}: CreateSyncStoragePersisterOptions): Persister {\n if (storage) {\n const trySave = (persistedClient: PersistedClient): Error | undefined => {\n try {\n storage.setItem(key, serialize(persistedClient))\n return\n } catch (error) {\n return error as Error\n }\n }\n return {\n persistClient: throttle((persistedClient) => {\n let client: PersistedClient | undefined = persistedClient\n let error = trySave(client)\n let errorCount = 0\n while (error && client) {\n errorCount++\n client = retry?.({\n persistedClient: client,\n error,\n errorCount,\n })\n\n if (client) {\n error = trySave(client)\n }\n }\n }, throttleTime),\n restoreClient: () => {\n const cacheString = storage.getItem(key)\n\n if (!cacheString) {\n return\n }\n\n return deserialize(cacheString)\n },\n removeClient: () => {\n storage.removeItem(key)\n },\n }\n }\n\n return {\n persistClient: noop,\n restoreClient: () => undefined,\n removeClient: noop,\n }\n}\n\nfunction throttle<TArgs extends any[]>(\n func: (...args: TArgs) => any,\n wait = 100,\n) {\n let timer: ReturnType<typeof setTimeout> | null = null\n let params: TArgs\n return function (...args: TArgs) {\n params = args\n if (timer === null) {\n timer = setTimeout(() => {\n func(...params)\n timer = null\n }, wait)\n }\n }\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-function\nfunction noop() {}\n"],"names":["createSyncStoragePersister","storage","key","throttleTime","serialize","JSON","stringify","deserialize","parse","retry","trySave","persistedClient","setItem","error","persistClient","throttle","client","errorCount","restoreClient","cacheString","getItem","removeClient","removeItem","noop","undefined","func","wait","timer","params","args","setTimeout"],"mappings":"AAqCO,SAASA,0BAA0B,CAAC;EACzCC,OAAO;AACPC,EAAAA,GAAG,GAAI,CAA0B,yBAAA,CAAA;AACjCC,EAAAA,YAAY,GAAG,IAAI;EACnBC,SAAS,GAAGC,IAAI,CAACC,SAAS;EAC1BC,WAAW,GAAGF,IAAI,CAACG,KAAK;AACxBC,EAAAA,KAAAA;AACiC,CAAC,EAAa;AAC/C,EAAA,IAAIR,OAAO,EAAE;IACX,MAAMS,OAAO,GAAIC,eAAgC,IAAwB;MACvE,IAAI;QACFV,OAAO,CAACW,OAAO,CAACV,GAAG,EAAEE,SAAS,CAACO,eAAe,CAAC,CAAC,CAAA;AAChD,QAAA,OAAA;OACD,CAAC,OAAOE,KAAK,EAAE;AACd,QAAA,OAAOA,KAAK,CAAA;AACd,OAAA;KACD,CAAA;IACD,OAAO;AACLC,MAAAA,aAAa,EAAEC,QAAQ,CAAEJ,eAAe,IAAK;QAC3C,IAAIK,MAAmC,GAAGL,eAAe,CAAA;AACzD,QAAA,IAAIE,KAAK,GAAGH,OAAO,CAACM,MAAM,CAAC,CAAA;QAC3B,IAAIC,UAAU,GAAG,CAAC,CAAA;QAClB,OAAOJ,KAAK,IAAIG,MAAM,EAAE;AACtBC,UAAAA,UAAU,EAAE,CAAA;UACZD,MAAM,GAAGP,KAAK,GAAG;AACfE,YAAAA,eAAe,EAAEK,MAAM;YACvBH,KAAK;AACLI,YAAAA,UAAAA;AACF,WAAC,CAAC,CAAA;AAEF,UAAA,IAAID,MAAM,EAAE;AACVH,YAAAA,KAAK,GAAGH,OAAO,CAACM,MAAM,CAAC,CAAA;AACzB,WAAA;AACF,SAAA;OACD,EAAEb,YAAY,CAAC;AAChBe,MAAAA,aAAa,EAAE,MAAM;AACnB,QAAA,MAAMC,WAAW,GAAGlB,OAAO,CAACmB,OAAO,CAAClB,GAAG,CAAC,CAAA;QAExC,IAAI,CAACiB,WAAW,EAAE;AAChB,UAAA,OAAA;AACF,SAAA;QAEA,OAAOZ,WAAW,CAACY,WAAW,CAAC,CAAA;OAChC;AACDE,MAAAA,YAAY,EAAE,MAAM;AAClBpB,QAAAA,OAAO,CAACqB,UAAU,CAACpB,GAAG,CAAC,CAAA;AACzB,OAAA;KACD,CAAA;AACH,GAAA;EAEA,OAAO;AACLY,IAAAA,aAAa,EAAES,IAAI;IACnBL,aAAa,EAAE,MAAMM,SAAS;AAC9BH,IAAAA,YAAY,EAAEE,IAAAA;GACf,CAAA;AACH,CAAA;AAEA,SAASR,QAAQ,CACfU,IAA6B,EAC7BC,IAAI,GAAG,GAAG,EACV;EACA,IAAIC,KAA2C,GAAG,IAAI,CAAA;AACtD,EAAA,IAAIC,MAAa,CAAA;EACjB,OAAO,UAAU,GAAGC,IAAW,EAAE;AAC/BD,IAAAA,MAAM,GAAGC,IAAI,CAAA;IACb,IAAIF,KAAK,KAAK,IAAI,EAAE;MAClBA,KAAK,GAAGG,UAAU,CAAC,MAAM;QACvBL,IAAI,CAAC,GAAGG,MAAM,CAAC,CAAA;AACfD,QAAAA,KAAK,GAAG,IAAI,CAAA;OACb,EAAED,IAAI,CAAC,CAAA;AACV,KAAA;GACD,CAAA;AACH,CAAA;;AAEA;AACA,SAASH,IAAI,GAAG;;;;"}
1
+ {"version":3,"file":"index.cjs","sources":["../../src/index.ts"],"sourcesContent":["import type {\n PersistedClient,\n Persister,\n PersistRetryer,\n} from '@tanstack/query-persist-client-core'\n\ninterface Storage {\n getItem: (key: string) => string | null\n setItem: (key: string, value: string) => void\n removeItem: (key: string) => void\n}\n\ninterface CreateSyncStoragePersisterOptions {\n /** The storage client used for setting and retrieving items from cache.\n * For SSR pass in `undefined`. Note that window.localStorage can be\n * `null` in Android WebViews depending on how they are configured.\n */\n storage: Storage | undefined | null\n /** The key to use when storing the cache */\n key?: string\n /** To avoid spamming,\n * pass a time in ms to throttle saving the cache to disk */\n throttleTime?: number\n /**\n * How to serialize the data to storage.\n * @default `JSON.stringify`\n */\n serialize?: (client: PersistedClient) => string\n /**\n * How to deserialize the data from storage.\n * @default `JSON.parse`\n */\n deserialize?: (cachedString: string) => PersistedClient\n\n retry?: PersistRetryer\n}\n\nexport function createSyncStoragePersister({\n storage,\n key = `REACT_QUERY_OFFLINE_CACHE`,\n throttleTime = 1000,\n serialize = JSON.stringify,\n deserialize = JSON.parse,\n retry,\n}: CreateSyncStoragePersisterOptions): Persister {\n if (storage) {\n const trySave = (persistedClient: PersistedClient): Error | undefined => {\n try {\n storage.setItem(key, serialize(persistedClient))\n return\n } catch (error) {\n return error as Error\n }\n }\n return {\n persistClient: throttle((persistedClient) => {\n let client: PersistedClient | undefined = persistedClient\n let error = trySave(client)\n let errorCount = 0\n while (error && client) {\n errorCount++\n client = retry?.({\n persistedClient: client,\n error,\n errorCount,\n })\n\n if (client) {\n error = trySave(client)\n }\n }\n }, throttleTime),\n restoreClient: () => {\n const cacheString = storage.getItem(key)\n\n if (!cacheString) {\n return\n }\n\n return deserialize(cacheString)\n },\n removeClient: () => {\n storage.removeItem(key)\n },\n }\n }\n\n return {\n persistClient: noop,\n restoreClient: () => undefined,\n removeClient: noop,\n }\n}\n\nfunction throttle<TArgs extends any[]>(\n func: (...args: TArgs) => any,\n wait = 100,\n) {\n let timer: ReturnType<typeof setTimeout> | null = null\n let params: TArgs\n return function (...args: TArgs) {\n params = args\n if (timer === null) {\n timer = setTimeout(() => {\n func(...params)\n timer = null\n }, wait)\n }\n }\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-function\nfunction noop() {}\n"],"names":["createSyncStoragePersister","storage","key","throttleTime","serialize","JSON","stringify","deserialize","parse","retry","trySave","persistedClient","setItem","error","persistClient","throttle","client","errorCount","restoreClient","cacheString","getItem","removeClient","removeItem","noop","undefined","func","wait","timer","params","args","setTimeout"],"mappings":";;AAqCO,SAASA,0BAA0BA,CAAC;EACzCC,OAAO;AACPC,EAAAA,GAAG,GAAI,CAA0B,yBAAA,CAAA;AACjCC,EAAAA,YAAY,GAAG,IAAI;EACnBC,SAAS,GAAGC,IAAI,CAACC,SAAS;EAC1BC,WAAW,GAAGF,IAAI,CAACG,KAAK;AACxBC,EAAAA,KAAAA;AACiC,CAAC,EAAa;AAC/C,EAAA,IAAIR,OAAO,EAAE;IACX,MAAMS,OAAO,GAAIC,eAAgC,IAAwB;MACvE,IAAI;QACFV,OAAO,CAACW,OAAO,CAACV,GAAG,EAAEE,SAAS,CAACO,eAAe,CAAC,CAAC,CAAA;AAChD,QAAA,OAAA;OACD,CAAC,OAAOE,KAAK,EAAE;AACd,QAAA,OAAOA,KAAK,CAAA;AACd,OAAA;KACD,CAAA;IACD,OAAO;AACLC,MAAAA,aAAa,EAAEC,QAAQ,CAAEJ,eAAe,IAAK;QAC3C,IAAIK,MAAmC,GAAGL,eAAe,CAAA;AACzD,QAAA,IAAIE,KAAK,GAAGH,OAAO,CAACM,MAAM,CAAC,CAAA;QAC3B,IAAIC,UAAU,GAAG,CAAC,CAAA;QAClB,OAAOJ,KAAK,IAAIG,MAAM,EAAE;AACtBC,UAAAA,UAAU,EAAE,CAAA;UACZD,MAAM,GAAGP,KAAK,GAAG;AACfE,YAAAA,eAAe,EAAEK,MAAM;YACvBH,KAAK;AACLI,YAAAA,UAAAA;AACF,WAAC,CAAC,CAAA;AAEF,UAAA,IAAID,MAAM,EAAE;AACVH,YAAAA,KAAK,GAAGH,OAAO,CAACM,MAAM,CAAC,CAAA;AACzB,WAAA;AACF,SAAA;OACD,EAAEb,YAAY,CAAC;MAChBe,aAAa,EAAEA,MAAM;AACnB,QAAA,MAAMC,WAAW,GAAGlB,OAAO,CAACmB,OAAO,CAAClB,GAAG,CAAC,CAAA;QAExC,IAAI,CAACiB,WAAW,EAAE;AAChB,UAAA,OAAA;AACF,SAAA;QAEA,OAAOZ,WAAW,CAACY,WAAW,CAAC,CAAA;OAChC;MACDE,YAAY,EAAEA,MAAM;AAClBpB,QAAAA,OAAO,CAACqB,UAAU,CAACpB,GAAG,CAAC,CAAA;AACzB,OAAA;KACD,CAAA;AACH,GAAA;EAEA,OAAO;AACLY,IAAAA,aAAa,EAAES,IAAI;IACnBL,aAAa,EAAEA,MAAMM,SAAS;AAC9BH,IAAAA,YAAY,EAAEE,IAAAA;GACf,CAAA;AACH,CAAA;AAEA,SAASR,QAAQA,CACfU,IAA6B,EAC7BC,IAAI,GAAG,GAAG,EACV;EACA,IAAIC,KAA2C,GAAG,IAAI,CAAA;AACtD,EAAA,IAAIC,MAAa,CAAA;EACjB,OAAO,UAAU,GAAGC,IAAW,EAAE;AAC/BD,IAAAA,MAAM,GAAGC,IAAI,CAAA;IACb,IAAIF,KAAK,KAAK,IAAI,EAAE;MAClBA,KAAK,GAAGG,UAAU,CAAC,MAAM;QACvBL,IAAI,CAAC,GAAGG,MAAM,CAAC,CAAA;AACfD,QAAAA,KAAK,GAAG,IAAI,CAAA;OACb,EAAED,IAAI,CAAC,CAAA;AACV,KAAA;GACD,CAAA;AACH,CAAA;;AAEA;AACA,SAASH,IAAIA,GAAG;;;;"}
@@ -29,3 +29,4 @@ interface CreateSyncStoragePersisterOptions {
29
29
  }
30
30
  export declare function createSyncStoragePersister({ storage, key, throttleTime, serialize, deserialize, retry, }: CreateSyncStoragePersisterOptions): Persister;
31
31
  export {};
32
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,eAAe,EACf,SAAS,EACT,cAAc,EACf,MAAM,qCAAqC,CAAA;AAE5C,UAAU,OAAO;IACf,OAAO,EAAE,CAAC,GAAG,EAAE,MAAM,KAAK,MAAM,GAAG,IAAI,CAAA;IACvC,OAAO,EAAE,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,KAAK,IAAI,CAAA;IAC7C,UAAU,EAAE,CAAC,GAAG,EAAE,MAAM,KAAK,IAAI,CAAA;CAClC;AAED,UAAU,iCAAiC;IACzC;;;OAGG;IACH,OAAO,EAAE,OAAO,GAAG,SAAS,GAAG,IAAI,CAAA;IACnC,4CAA4C;IAC5C,GAAG,CAAC,EAAE,MAAM,CAAA;IACZ;gEAC4D;IAC5D,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB;;;OAGG;IACH,SAAS,CAAC,EAAE,CAAC,MAAM,EAAE,eAAe,KAAK,MAAM,CAAA;IAC/C;;;OAGG;IACH,WAAW,CAAC,EAAE,CAAC,YAAY,EAAE,MAAM,KAAK,eAAe,CAAA;IAEvD,KAAK,CAAC,EAAE,cAAc,CAAA;CACvB;AAED,wBAAgB,0BAA0B,CAAC,EACzC,OAAO,EACP,GAAiC,EACjC,YAAmB,EACnB,SAA0B,EAC1B,WAAwB,EACxB,KAAK,GACN,EAAE,iCAAiC,GAAG,SAAS,CAgD/C"}
@@ -1,5 +1,3 @@
1
- 'use strict';
2
-
3
1
  function createSyncStoragePersister({
4
2
  storage,
5
3
  key = `REACT_QUERY_OFFLINE_CACHE`,
@@ -24,7 +22,7 @@ function createSyncStoragePersister({
24
22
  let errorCount = 0;
25
23
  while (error && client) {
26
24
  errorCount++;
27
- client = retry == null ? void 0 : retry({
25
+ client = retry?.({
28
26
  persistedClient: client,
29
27
  error,
30
28
  errorCount
@@ -69,5 +67,5 @@ function throttle(func, wait = 100) {
69
67
  // eslint-disable-next-line @typescript-eslint/no-empty-function
70
68
  function noop() {}
71
69
 
72
- exports.createSyncStoragePersister = createSyncStoragePersister;
70
+ export { createSyncStoragePersister };
73
71
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../../src/index.ts"],"sourcesContent":["import type {\n PersistedClient,\n Persister,\n PersistRetryer,\n} from '@tanstack/query-persist-client-core'\n\ninterface Storage {\n getItem: (key: string) => string | null\n setItem: (key: string, value: string) => void\n removeItem: (key: string) => void\n}\n\ninterface CreateSyncStoragePersisterOptions {\n /** The storage client used for setting and retrieving items from cache.\n * For SSR pass in `undefined`. Note that window.localStorage can be\n * `null` in Android WebViews depending on how they are configured.\n */\n storage: Storage | undefined | null\n /** The key to use when storing the cache */\n key?: string\n /** To avoid spamming,\n * pass a time in ms to throttle saving the cache to disk */\n throttleTime?: number\n /**\n * How to serialize the data to storage.\n * @default `JSON.stringify`\n */\n serialize?: (client: PersistedClient) => string\n /**\n * How to deserialize the data from storage.\n * @default `JSON.parse`\n */\n deserialize?: (cachedString: string) => PersistedClient\n\n retry?: PersistRetryer\n}\n\nexport function createSyncStoragePersister({\n storage,\n key = `REACT_QUERY_OFFLINE_CACHE`,\n throttleTime = 1000,\n serialize = JSON.stringify,\n deserialize = JSON.parse,\n retry,\n}: CreateSyncStoragePersisterOptions): Persister {\n if (storage) {\n const trySave = (persistedClient: PersistedClient): Error | undefined => {\n try {\n storage.setItem(key, serialize(persistedClient))\n return\n } catch (error) {\n return error as Error\n }\n }\n return {\n persistClient: throttle((persistedClient) => {\n let client: PersistedClient | undefined = persistedClient\n let error = trySave(client)\n let errorCount = 0\n while (error && client) {\n errorCount++\n client = retry?.({\n persistedClient: client,\n error,\n errorCount,\n })\n\n if (client) {\n error = trySave(client)\n }\n }\n }, throttleTime),\n restoreClient: () => {\n const cacheString = storage.getItem(key)\n\n if (!cacheString) {\n return\n }\n\n return deserialize(cacheString)\n },\n removeClient: () => {\n storage.removeItem(key)\n },\n }\n }\n\n return {\n persistClient: noop,\n restoreClient: () => undefined,\n removeClient: noop,\n }\n}\n\nfunction throttle<TArgs extends any[]>(\n func: (...args: TArgs) => any,\n wait = 100,\n) {\n let timer: ReturnType<typeof setTimeout> | null = null\n let params: TArgs\n return function (...args: TArgs) {\n params = args\n if (timer === null) {\n timer = setTimeout(() => {\n func(...params)\n timer = null\n }, wait)\n }\n }\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-function\nfunction noop() {}\n"],"names":["createSyncStoragePersister","storage","key","throttleTime","serialize","JSON","stringify","deserialize","parse","retry","trySave","persistedClient","setItem","error","persistClient","throttle","client","errorCount","restoreClient","cacheString","getItem","removeClient","removeItem","noop","undefined","func","wait","timer","params","args","setTimeout"],"mappings":";;AAqCO,SAASA,0BAA0B,CAAC;EACzCC,OAAO;AACPC,EAAAA,GAAG,GAAI,CAA0B,yBAAA,CAAA;AACjCC,EAAAA,YAAY,GAAG,IAAI;EACnBC,SAAS,GAAGC,IAAI,CAACC,SAAS;EAC1BC,WAAW,GAAGF,IAAI,CAACG,KAAK;AACxBC,EAAAA,KAAAA;AACiC,CAAC,EAAa;AAC/C,EAAA,IAAIR,OAAO,EAAE;IACX,MAAMS,OAAO,GAAIC,eAAgC,IAAwB;MACvE,IAAI;QACFV,OAAO,CAACW,OAAO,CAACV,GAAG,EAAEE,SAAS,CAACO,eAAe,CAAC,CAAC,CAAA;AAChD,QAAA,OAAA;OACD,CAAC,OAAOE,KAAK,EAAE;AACd,QAAA,OAAOA,KAAK,CAAA;AACd,OAAA;KACD,CAAA;IACD,OAAO;AACLC,MAAAA,aAAa,EAAEC,QAAQ,CAAEJ,eAAe,IAAK;QAC3C,IAAIK,MAAmC,GAAGL,eAAe,CAAA;AACzD,QAAA,IAAIE,KAAK,GAAGH,OAAO,CAACM,MAAM,CAAC,CAAA;QAC3B,IAAIC,UAAU,GAAG,CAAC,CAAA;QAClB,OAAOJ,KAAK,IAAIG,MAAM,EAAE;AACtBC,UAAAA,UAAU,EAAE,CAAA;AACZD,UAAAA,MAAM,GAAGP,KAAK,IAALA,IAAAA,GAAAA,KAAAA,CAAAA,GAAAA,KAAK,CAAG;AACfE,YAAAA,eAAe,EAAEK,MAAM;YACvBH,KAAK;AACLI,YAAAA,UAAAA;AACF,WAAC,CAAC,CAAA;AAEF,UAAA,IAAID,MAAM,EAAE;AACVH,YAAAA,KAAK,GAAGH,OAAO,CAACM,MAAM,CAAC,CAAA;AACzB,WAAA;AACF,SAAA;OACD,EAAEb,YAAY,CAAC;AAChBe,MAAAA,aAAa,EAAE,MAAM;AACnB,QAAA,MAAMC,WAAW,GAAGlB,OAAO,CAACmB,OAAO,CAAClB,GAAG,CAAC,CAAA;QAExC,IAAI,CAACiB,WAAW,EAAE;AAChB,UAAA,OAAA;AACF,SAAA;QAEA,OAAOZ,WAAW,CAACY,WAAW,CAAC,CAAA;OAChC;AACDE,MAAAA,YAAY,EAAE,MAAM;AAClBpB,QAAAA,OAAO,CAACqB,UAAU,CAACpB,GAAG,CAAC,CAAA;AACzB,OAAA;KACD,CAAA;AACH,GAAA;EAEA,OAAO;AACLY,IAAAA,aAAa,EAAES,IAAI;IACnBL,aAAa,EAAE,MAAMM,SAAS;AAC9BH,IAAAA,YAAY,EAAEE,IAAAA;GACf,CAAA;AACH,CAAA;AAEA,SAASR,QAAQ,CACfU,IAA6B,EAC7BC,IAAI,GAAG,GAAG,EACV;EACA,IAAIC,KAA2C,GAAG,IAAI,CAAA;AACtD,EAAA,IAAIC,MAAa,CAAA;EACjB,OAAO,UAAU,GAAGC,IAAW,EAAE;AAC/BD,IAAAA,MAAM,GAAGC,IAAI,CAAA;IACb,IAAIF,KAAK,KAAK,IAAI,EAAE;MAClBA,KAAK,GAAGG,UAAU,CAAC,MAAM;QACvBL,IAAI,CAAC,GAAGG,MAAM,CAAC,CAAA;AACfD,QAAAA,KAAK,GAAG,IAAI,CAAA;OACb,EAAED,IAAI,CAAC,CAAA;AACV,KAAA;GACD,CAAA;AACH,CAAA;;AAEA;AACA,SAASH,IAAI,GAAG;;;;"}
1
+ {"version":3,"file":"index.js","sources":["../../src/index.ts"],"sourcesContent":["import type {\n PersistedClient,\n Persister,\n PersistRetryer,\n} from '@tanstack/query-persist-client-core'\n\ninterface Storage {\n getItem: (key: string) => string | null\n setItem: (key: string, value: string) => void\n removeItem: (key: string) => void\n}\n\ninterface CreateSyncStoragePersisterOptions {\n /** The storage client used for setting and retrieving items from cache.\n * For SSR pass in `undefined`. Note that window.localStorage can be\n * `null` in Android WebViews depending on how they are configured.\n */\n storage: Storage | undefined | null\n /** The key to use when storing the cache */\n key?: string\n /** To avoid spamming,\n * pass a time in ms to throttle saving the cache to disk */\n throttleTime?: number\n /**\n * How to serialize the data to storage.\n * @default `JSON.stringify`\n */\n serialize?: (client: PersistedClient) => string\n /**\n * How to deserialize the data from storage.\n * @default `JSON.parse`\n */\n deserialize?: (cachedString: string) => PersistedClient\n\n retry?: PersistRetryer\n}\n\nexport function createSyncStoragePersister({\n storage,\n key = `REACT_QUERY_OFFLINE_CACHE`,\n throttleTime = 1000,\n serialize = JSON.stringify,\n deserialize = JSON.parse,\n retry,\n}: CreateSyncStoragePersisterOptions): Persister {\n if (storage) {\n const trySave = (persistedClient: PersistedClient): Error | undefined => {\n try {\n storage.setItem(key, serialize(persistedClient))\n return\n } catch (error) {\n return error as Error\n }\n }\n return {\n persistClient: throttle((persistedClient) => {\n let client: PersistedClient | undefined = persistedClient\n let error = trySave(client)\n let errorCount = 0\n while (error && client) {\n errorCount++\n client = retry?.({\n persistedClient: client,\n error,\n errorCount,\n })\n\n if (client) {\n error = trySave(client)\n }\n }\n }, throttleTime),\n restoreClient: () => {\n const cacheString = storage.getItem(key)\n\n if (!cacheString) {\n return\n }\n\n return deserialize(cacheString)\n },\n removeClient: () => {\n storage.removeItem(key)\n },\n }\n }\n\n return {\n persistClient: noop,\n restoreClient: () => undefined,\n removeClient: noop,\n }\n}\n\nfunction throttle<TArgs extends any[]>(\n func: (...args: TArgs) => any,\n wait = 100,\n) {\n let timer: ReturnType<typeof setTimeout> | null = null\n let params: TArgs\n return function (...args: TArgs) {\n params = args\n if (timer === null) {\n timer = setTimeout(() => {\n func(...params)\n timer = null\n }, wait)\n }\n }\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-function\nfunction noop() {}\n"],"names":["createSyncStoragePersister","storage","key","throttleTime","serialize","JSON","stringify","deserialize","parse","retry","trySave","persistedClient","setItem","error","persistClient","throttle","client","errorCount","restoreClient","cacheString","getItem","removeClient","removeItem","noop","undefined","func","wait","timer","params","args","setTimeout"],"mappings":"AAqCO,SAASA,0BAA0BA,CAAC;EACzCC,OAAO;AACPC,EAAAA,GAAG,GAAI,CAA0B,yBAAA,CAAA;AACjCC,EAAAA,YAAY,GAAG,IAAI;EACnBC,SAAS,GAAGC,IAAI,CAACC,SAAS;EAC1BC,WAAW,GAAGF,IAAI,CAACG,KAAK;AACxBC,EAAAA,KAAAA;AACiC,CAAC,EAAa;AAC/C,EAAA,IAAIR,OAAO,EAAE;IACX,MAAMS,OAAO,GAAIC,eAAgC,IAAwB;MACvE,IAAI;QACFV,OAAO,CAACW,OAAO,CAACV,GAAG,EAAEE,SAAS,CAACO,eAAe,CAAC,CAAC,CAAA;AAChD,QAAA,OAAA;OACD,CAAC,OAAOE,KAAK,EAAE;AACd,QAAA,OAAOA,KAAK,CAAA;AACd,OAAA;KACD,CAAA;IACD,OAAO;AACLC,MAAAA,aAAa,EAAEC,QAAQ,CAAEJ,eAAe,IAAK;QAC3C,IAAIK,MAAmC,GAAGL,eAAe,CAAA;AACzD,QAAA,IAAIE,KAAK,GAAGH,OAAO,CAACM,MAAM,CAAC,CAAA;QAC3B,IAAIC,UAAU,GAAG,CAAC,CAAA;QAClB,OAAOJ,KAAK,IAAIG,MAAM,EAAE;AACtBC,UAAAA,UAAU,EAAE,CAAA;UACZD,MAAM,GAAGP,KAAK,GAAG;AACfE,YAAAA,eAAe,EAAEK,MAAM;YACvBH,KAAK;AACLI,YAAAA,UAAAA;AACF,WAAC,CAAC,CAAA;AAEF,UAAA,IAAID,MAAM,EAAE;AACVH,YAAAA,KAAK,GAAGH,OAAO,CAACM,MAAM,CAAC,CAAA;AACzB,WAAA;AACF,SAAA;OACD,EAAEb,YAAY,CAAC;MAChBe,aAAa,EAAEA,MAAM;AACnB,QAAA,MAAMC,WAAW,GAAGlB,OAAO,CAACmB,OAAO,CAAClB,GAAG,CAAC,CAAA;QAExC,IAAI,CAACiB,WAAW,EAAE;AAChB,UAAA,OAAA;AACF,SAAA;QAEA,OAAOZ,WAAW,CAACY,WAAW,CAAC,CAAA;OAChC;MACDE,YAAY,EAAEA,MAAM;AAClBpB,QAAAA,OAAO,CAACqB,UAAU,CAACpB,GAAG,CAAC,CAAA;AACzB,OAAA;KACD,CAAA;AACH,GAAA;EAEA,OAAO;AACLY,IAAAA,aAAa,EAAES,IAAI;IACnBL,aAAa,EAAEA,MAAMM,SAAS;AAC9BH,IAAAA,YAAY,EAAEE,IAAAA;GACf,CAAA;AACH,CAAA;AAEA,SAASR,QAAQA,CACfU,IAA6B,EAC7BC,IAAI,GAAG,GAAG,EACV;EACA,IAAIC,KAA2C,GAAG,IAAI,CAAA;AACtD,EAAA,IAAIC,MAAa,CAAA;EACjB,OAAO,UAAU,GAAGC,IAAW,EAAE;AAC/BD,IAAAA,MAAM,GAAGC,IAAI,CAAA;IACb,IAAIF,KAAK,KAAK,IAAI,EAAE;MAClBA,KAAK,GAAGG,UAAU,CAAC,MAAM;QACvBL,IAAI,CAAC,GAAGG,MAAM,CAAC,CAAA;AACfD,QAAAA,KAAK,GAAG,IAAI,CAAA;OACb,EAAED,IAAI,CAAC,CAAA;AACV,KAAA;GACD,CAAA;AACH,CAAA;;AAEA;AACA,SAASH,IAAIA,GAAG;;;;"}
@@ -0,0 +1,73 @@
1
+ 'use strict';
2
+
3
+ function createSyncStoragePersister({
4
+ storage,
5
+ key = `REACT_QUERY_OFFLINE_CACHE`,
6
+ throttleTime = 1000,
7
+ serialize = JSON.stringify,
8
+ deserialize = JSON.parse,
9
+ retry
10
+ }) {
11
+ if (storage) {
12
+ const trySave = persistedClient => {
13
+ try {
14
+ storage.setItem(key, serialize(persistedClient));
15
+ return;
16
+ } catch (error) {
17
+ return error;
18
+ }
19
+ };
20
+ return {
21
+ persistClient: throttle(persistedClient => {
22
+ let client = persistedClient;
23
+ let error = trySave(client);
24
+ let errorCount = 0;
25
+ while (error && client) {
26
+ errorCount++;
27
+ client = retry == null ? void 0 : retry({
28
+ persistedClient: client,
29
+ error,
30
+ errorCount
31
+ });
32
+ if (client) {
33
+ error = trySave(client);
34
+ }
35
+ }
36
+ }, throttleTime),
37
+ restoreClient: () => {
38
+ const cacheString = storage.getItem(key);
39
+ if (!cacheString) {
40
+ return;
41
+ }
42
+ return deserialize(cacheString);
43
+ },
44
+ removeClient: () => {
45
+ storage.removeItem(key);
46
+ }
47
+ };
48
+ }
49
+ return {
50
+ persistClient: noop,
51
+ restoreClient: () => undefined,
52
+ removeClient: noop
53
+ };
54
+ }
55
+ function throttle(func, wait = 100) {
56
+ let timer = null;
57
+ let params;
58
+ return function (...args) {
59
+ params = args;
60
+ if (timer === null) {
61
+ timer = setTimeout(() => {
62
+ func(...params);
63
+ timer = null;
64
+ }, wait);
65
+ }
66
+ };
67
+ }
68
+
69
+ // eslint-disable-next-line @typescript-eslint/no-empty-function
70
+ function noop() {}
71
+
72
+ exports.createSyncStoragePersister = createSyncStoragePersister;
73
+ //# sourceMappingURL=index.legacy.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.legacy.cjs","sources":["../../src/index.ts"],"sourcesContent":["import type {\n PersistedClient,\n Persister,\n PersistRetryer,\n} from '@tanstack/query-persist-client-core'\n\ninterface Storage {\n getItem: (key: string) => string | null\n setItem: (key: string, value: string) => void\n removeItem: (key: string) => void\n}\n\ninterface CreateSyncStoragePersisterOptions {\n /** The storage client used for setting and retrieving items from cache.\n * For SSR pass in `undefined`. Note that window.localStorage can be\n * `null` in Android WebViews depending on how they are configured.\n */\n storage: Storage | undefined | null\n /** The key to use when storing the cache */\n key?: string\n /** To avoid spamming,\n * pass a time in ms to throttle saving the cache to disk */\n throttleTime?: number\n /**\n * How to serialize the data to storage.\n * @default `JSON.stringify`\n */\n serialize?: (client: PersistedClient) => string\n /**\n * How to deserialize the data from storage.\n * @default `JSON.parse`\n */\n deserialize?: (cachedString: string) => PersistedClient\n\n retry?: PersistRetryer\n}\n\nexport function createSyncStoragePersister({\n storage,\n key = `REACT_QUERY_OFFLINE_CACHE`,\n throttleTime = 1000,\n serialize = JSON.stringify,\n deserialize = JSON.parse,\n retry,\n}: CreateSyncStoragePersisterOptions): Persister {\n if (storage) {\n const trySave = (persistedClient: PersistedClient): Error | undefined => {\n try {\n storage.setItem(key, serialize(persistedClient))\n return\n } catch (error) {\n return error as Error\n }\n }\n return {\n persistClient: throttle((persistedClient) => {\n let client: PersistedClient | undefined = persistedClient\n let error = trySave(client)\n let errorCount = 0\n while (error && client) {\n errorCount++\n client = retry?.({\n persistedClient: client,\n error,\n errorCount,\n })\n\n if (client) {\n error = trySave(client)\n }\n }\n }, throttleTime),\n restoreClient: () => {\n const cacheString = storage.getItem(key)\n\n if (!cacheString) {\n return\n }\n\n return deserialize(cacheString)\n },\n removeClient: () => {\n storage.removeItem(key)\n },\n }\n }\n\n return {\n persistClient: noop,\n restoreClient: () => undefined,\n removeClient: noop,\n }\n}\n\nfunction throttle<TArgs extends any[]>(\n func: (...args: TArgs) => any,\n wait = 100,\n) {\n let timer: ReturnType<typeof setTimeout> | null = null\n let params: TArgs\n return function (...args: TArgs) {\n params = args\n if (timer === null) {\n timer = setTimeout(() => {\n func(...params)\n timer = null\n }, wait)\n }\n }\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-function\nfunction noop() {}\n"],"names":["createSyncStoragePersister","storage","key","throttleTime","serialize","JSON","stringify","deserialize","parse","retry","trySave","persistedClient","setItem","error","persistClient","throttle","client","errorCount","restoreClient","cacheString","getItem","removeClient","removeItem","noop","undefined","func","wait","timer","params","args","setTimeout"],"mappings":";;AAqCO,SAASA,0BAA0BA,CAAC;EACzCC,OAAO;AACPC,EAAAA,GAAG,GAAI,CAA0B,yBAAA,CAAA;AACjCC,EAAAA,YAAY,GAAG,IAAI;EACnBC,SAAS,GAAGC,IAAI,CAACC,SAAS;EAC1BC,WAAW,GAAGF,IAAI,CAACG,KAAK;AACxBC,EAAAA,KAAAA;AACiC,CAAC,EAAa;AAC/C,EAAA,IAAIR,OAAO,EAAE;IACX,MAAMS,OAAO,GAAIC,eAAgC,IAAwB;MACvE,IAAI;QACFV,OAAO,CAACW,OAAO,CAACV,GAAG,EAAEE,SAAS,CAACO,eAAe,CAAC,CAAC,CAAA;AAChD,QAAA,OAAA;OACD,CAAC,OAAOE,KAAK,EAAE;AACd,QAAA,OAAOA,KAAK,CAAA;AACd,OAAA;KACD,CAAA;IACD,OAAO;AACLC,MAAAA,aAAa,EAAEC,QAAQ,CAAEJ,eAAe,IAAK;QAC3C,IAAIK,MAAmC,GAAGL,eAAe,CAAA;AACzD,QAAA,IAAIE,KAAK,GAAGH,OAAO,CAACM,MAAM,CAAC,CAAA;QAC3B,IAAIC,UAAU,GAAG,CAAC,CAAA;QAClB,OAAOJ,KAAK,IAAIG,MAAM,EAAE;AACtBC,UAAAA,UAAU,EAAE,CAAA;AACZD,UAAAA,MAAM,GAAGP,KAAK,IAALA,IAAAA,GAAAA,KAAAA,CAAAA,GAAAA,KAAK,CAAG;AACfE,YAAAA,eAAe,EAAEK,MAAM;YACvBH,KAAK;AACLI,YAAAA,UAAAA;AACF,WAAC,CAAC,CAAA;AAEF,UAAA,IAAID,MAAM,EAAE;AACVH,YAAAA,KAAK,GAAGH,OAAO,CAACM,MAAM,CAAC,CAAA;AACzB,WAAA;AACF,SAAA;OACD,EAAEb,YAAY,CAAC;MAChBe,aAAa,EAAEA,MAAM;AACnB,QAAA,MAAMC,WAAW,GAAGlB,OAAO,CAACmB,OAAO,CAAClB,GAAG,CAAC,CAAA;QAExC,IAAI,CAACiB,WAAW,EAAE;AAChB,UAAA,OAAA;AACF,SAAA;QAEA,OAAOZ,WAAW,CAACY,WAAW,CAAC,CAAA;OAChC;MACDE,YAAY,EAAEA,MAAM;AAClBpB,QAAAA,OAAO,CAACqB,UAAU,CAACpB,GAAG,CAAC,CAAA;AACzB,OAAA;KACD,CAAA;AACH,GAAA;EAEA,OAAO;AACLY,IAAAA,aAAa,EAAES,IAAI;IACnBL,aAAa,EAAEA,MAAMM,SAAS;AAC9BH,IAAAA,YAAY,EAAEE,IAAAA;GACf,CAAA;AACH,CAAA;AAEA,SAASR,QAAQA,CACfU,IAA6B,EAC7BC,IAAI,GAAG,GAAG,EACV;EACA,IAAIC,KAA2C,GAAG,IAAI,CAAA;AACtD,EAAA,IAAIC,MAAa,CAAA;EACjB,OAAO,UAAU,GAAGC,IAAW,EAAE;AAC/BD,IAAAA,MAAM,GAAGC,IAAI,CAAA;IACb,IAAIF,KAAK,KAAK,IAAI,EAAE;MAClBA,KAAK,GAAGG,UAAU,CAAC,MAAM;QACvBL,IAAI,CAAC,GAAGG,MAAM,CAAC,CAAA;AACfD,QAAAA,KAAK,GAAG,IAAI,CAAA;OACb,EAAED,IAAI,CAAC,CAAA;AACV,KAAA;GACD,CAAA;AACH,CAAA;;AAEA;AACA,SAASH,IAAIA,GAAG;;;;"}
@@ -68,4 +68,4 @@ function throttle(func, wait = 100) {
68
68
  function noop() {}
69
69
 
70
70
  export { createSyncStoragePersister };
71
- //# sourceMappingURL=index.esm.js.map
71
+ //# sourceMappingURL=index.legacy.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.legacy.js","sources":["../../src/index.ts"],"sourcesContent":["import type {\n PersistedClient,\n Persister,\n PersistRetryer,\n} from '@tanstack/query-persist-client-core'\n\ninterface Storage {\n getItem: (key: string) => string | null\n setItem: (key: string, value: string) => void\n removeItem: (key: string) => void\n}\n\ninterface CreateSyncStoragePersisterOptions {\n /** The storage client used for setting and retrieving items from cache.\n * For SSR pass in `undefined`. Note that window.localStorage can be\n * `null` in Android WebViews depending on how they are configured.\n */\n storage: Storage | undefined | null\n /** The key to use when storing the cache */\n key?: string\n /** To avoid spamming,\n * pass a time in ms to throttle saving the cache to disk */\n throttleTime?: number\n /**\n * How to serialize the data to storage.\n * @default `JSON.stringify`\n */\n serialize?: (client: PersistedClient) => string\n /**\n * How to deserialize the data from storage.\n * @default `JSON.parse`\n */\n deserialize?: (cachedString: string) => PersistedClient\n\n retry?: PersistRetryer\n}\n\nexport function createSyncStoragePersister({\n storage,\n key = `REACT_QUERY_OFFLINE_CACHE`,\n throttleTime = 1000,\n serialize = JSON.stringify,\n deserialize = JSON.parse,\n retry,\n}: CreateSyncStoragePersisterOptions): Persister {\n if (storage) {\n const trySave = (persistedClient: PersistedClient): Error | undefined => {\n try {\n storage.setItem(key, serialize(persistedClient))\n return\n } catch (error) {\n return error as Error\n }\n }\n return {\n persistClient: throttle((persistedClient) => {\n let client: PersistedClient | undefined = persistedClient\n let error = trySave(client)\n let errorCount = 0\n while (error && client) {\n errorCount++\n client = retry?.({\n persistedClient: client,\n error,\n errorCount,\n })\n\n if (client) {\n error = trySave(client)\n }\n }\n }, throttleTime),\n restoreClient: () => {\n const cacheString = storage.getItem(key)\n\n if (!cacheString) {\n return\n }\n\n return deserialize(cacheString)\n },\n removeClient: () => {\n storage.removeItem(key)\n },\n }\n }\n\n return {\n persistClient: noop,\n restoreClient: () => undefined,\n removeClient: noop,\n }\n}\n\nfunction throttle<TArgs extends any[]>(\n func: (...args: TArgs) => any,\n wait = 100,\n) {\n let timer: ReturnType<typeof setTimeout> | null = null\n let params: TArgs\n return function (...args: TArgs) {\n params = args\n if (timer === null) {\n timer = setTimeout(() => {\n func(...params)\n timer = null\n }, wait)\n }\n }\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-function\nfunction noop() {}\n"],"names":["createSyncStoragePersister","storage","key","throttleTime","serialize","JSON","stringify","deserialize","parse","retry","trySave","persistedClient","setItem","error","persistClient","throttle","client","errorCount","restoreClient","cacheString","getItem","removeClient","removeItem","noop","undefined","func","wait","timer","params","args","setTimeout"],"mappings":"AAqCO,SAASA,0BAA0BA,CAAC;EACzCC,OAAO;AACPC,EAAAA,GAAG,GAAI,CAA0B,yBAAA,CAAA;AACjCC,EAAAA,YAAY,GAAG,IAAI;EACnBC,SAAS,GAAGC,IAAI,CAACC,SAAS;EAC1BC,WAAW,GAAGF,IAAI,CAACG,KAAK;AACxBC,EAAAA,KAAAA;AACiC,CAAC,EAAa;AAC/C,EAAA,IAAIR,OAAO,EAAE;IACX,MAAMS,OAAO,GAAIC,eAAgC,IAAwB;MACvE,IAAI;QACFV,OAAO,CAACW,OAAO,CAACV,GAAG,EAAEE,SAAS,CAACO,eAAe,CAAC,CAAC,CAAA;AAChD,QAAA,OAAA;OACD,CAAC,OAAOE,KAAK,EAAE;AACd,QAAA,OAAOA,KAAK,CAAA;AACd,OAAA;KACD,CAAA;IACD,OAAO;AACLC,MAAAA,aAAa,EAAEC,QAAQ,CAAEJ,eAAe,IAAK;QAC3C,IAAIK,MAAmC,GAAGL,eAAe,CAAA;AACzD,QAAA,IAAIE,KAAK,GAAGH,OAAO,CAACM,MAAM,CAAC,CAAA;QAC3B,IAAIC,UAAU,GAAG,CAAC,CAAA;QAClB,OAAOJ,KAAK,IAAIG,MAAM,EAAE;AACtBC,UAAAA,UAAU,EAAE,CAAA;AACZD,UAAAA,MAAM,GAAGP,KAAK,IAALA,IAAAA,GAAAA,KAAAA,CAAAA,GAAAA,KAAK,CAAG;AACfE,YAAAA,eAAe,EAAEK,MAAM;YACvBH,KAAK;AACLI,YAAAA,UAAAA;AACF,WAAC,CAAC,CAAA;AAEF,UAAA,IAAID,MAAM,EAAE;AACVH,YAAAA,KAAK,GAAGH,OAAO,CAACM,MAAM,CAAC,CAAA;AACzB,WAAA;AACF,SAAA;OACD,EAAEb,YAAY,CAAC;MAChBe,aAAa,EAAEA,MAAM;AACnB,QAAA,MAAMC,WAAW,GAAGlB,OAAO,CAACmB,OAAO,CAAClB,GAAG,CAAC,CAAA;QAExC,IAAI,CAACiB,WAAW,EAAE;AAChB,UAAA,OAAA;AACF,SAAA;QAEA,OAAOZ,WAAW,CAACY,WAAW,CAAC,CAAA;OAChC;MACDE,YAAY,EAAEA,MAAM;AAClBpB,QAAAA,OAAO,CAACqB,UAAU,CAACpB,GAAG,CAAC,CAAA;AACzB,OAAA;KACD,CAAA;AACH,GAAA;EAEA,OAAO;AACLY,IAAAA,aAAa,EAAES,IAAI;IACnBL,aAAa,EAAEA,MAAMM,SAAS;AAC9BH,IAAAA,YAAY,EAAEE,IAAAA;GACf,CAAA;AACH,CAAA;AAEA,SAASR,QAAQA,CACfU,IAA6B,EAC7BC,IAAI,GAAG,GAAG,EACV;EACA,IAAIC,KAA2C,GAAG,IAAI,CAAA;AACtD,EAAA,IAAIC,MAAa,CAAA;EACjB,OAAO,UAAU,GAAGC,IAAW,EAAE;AAC/BD,IAAAA,MAAM,GAAGC,IAAI,CAAA;IACb,IAAIF,KAAK,KAAK,IAAI,EAAE;MAClBA,KAAK,GAAGG,UAAU,CAAC,MAAM;QACvBL,IAAI,CAAC,GAAGG,MAAM,CAAC,CAAA;AACfD,QAAAA,KAAK,GAAG,IAAI,CAAA;OACb,EAAED,IAAI,CAAC,CAAA;AACV,KAAA;GACD,CAAA;AACH,CAAA;;AAEA;AACA,SAASH,IAAIA,GAAG;;;;"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@tanstack/query-sync-storage-persister",
3
- "version": "5.0.0-alpha.6",
3
+ "version": "5.0.0-alpha.63",
4
4
  "description": "A persister for synchronous storages, to be used with TanStack/Query",
5
5
  "author": "tannerlinsley",
6
6
  "license": "MIT",
@@ -10,32 +10,37 @@
10
10
  "type": "github",
11
11
  "url": "https://github.com/sponsors/tannerlinsley"
12
12
  },
13
+ "type": "module",
13
14
  "types": "build/lib/index.d.ts",
14
- "main": "build/lib/index.js",
15
- "module": "build/lib/index.esm.js",
15
+ "main": "build/lib/index.legacy.cjs",
16
+ "module": "build/lib/index.legacy.js",
16
17
  "exports": {
17
18
  ".": {
18
19
  "types": "./build/lib/index.d.ts",
19
- "import": "./build/lib/index.mjs",
20
- "default": "./build/lib/index.js"
20
+ "import": "./build/lib/index.js",
21
+ "require": "./build/lib/index.cjs",
22
+ "default": "./build/lib/index.cjs"
21
23
  },
22
24
  "./package.json": "./package.json"
23
25
  },
24
26
  "sideEffects": false,
25
27
  "files": [
26
28
  "build/lib/*",
27
- "build/umd/*",
28
29
  "src"
29
30
  ],
30
31
  "dependencies": {
31
- "@tanstack/query-persist-client-core": "5.0.0-alpha.6"
32
+ "@tanstack/query-core": "^5.0.0-alpha.43",
33
+ "@tanstack/query-persist-client-core": "^5.0.0-alpha.43"
32
34
  },
33
35
  "scripts": {
34
- "clean": "rimraf ./build",
36
+ "clean": "rimraf ./build && rimraf ./coverage",
35
37
  "test:eslint": "eslint --ext .ts,.tsx ./src",
36
- "test:types": "tsc",
38
+ "test:types": "tsc --noEmit",
37
39
  "test:lib": "vitest run --coverage",
38
40
  "test:lib:dev": "pnpm run test:lib --watch",
39
- "build:types": "tsc --build"
41
+ "test:build": "publint --strict",
42
+ "build": "pnpm build:rollup && pnpm build:types",
43
+ "build:rollup": "rollup --config rollup.config.js",
44
+ "build:types": "tsc --emitDeclarationOnly"
40
45
  }
41
46
  }
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.esm.js","sources":["../../src/index.ts"],"sourcesContent":["import type {\n PersistedClient,\n Persister,\n PersistRetryer,\n} from '@tanstack/query-persist-client-core'\n\ninterface Storage {\n getItem: (key: string) => string | null\n setItem: (key: string, value: string) => void\n removeItem: (key: string) => void\n}\n\ninterface CreateSyncStoragePersisterOptions {\n /** The storage client used for setting and retrieving items from cache.\n * For SSR pass in `undefined`. Note that window.localStorage can be\n * `null` in Android WebViews depending on how they are configured.\n */\n storage: Storage | undefined | null\n /** The key to use when storing the cache */\n key?: string\n /** To avoid spamming,\n * pass a time in ms to throttle saving the cache to disk */\n throttleTime?: number\n /**\n * How to serialize the data to storage.\n * @default `JSON.stringify`\n */\n serialize?: (client: PersistedClient) => string\n /**\n * How to deserialize the data from storage.\n * @default `JSON.parse`\n */\n deserialize?: (cachedString: string) => PersistedClient\n\n retry?: PersistRetryer\n}\n\nexport function createSyncStoragePersister({\n storage,\n key = `REACT_QUERY_OFFLINE_CACHE`,\n throttleTime = 1000,\n serialize = JSON.stringify,\n deserialize = JSON.parse,\n retry,\n}: CreateSyncStoragePersisterOptions): Persister {\n if (storage) {\n const trySave = (persistedClient: PersistedClient): Error | undefined => {\n try {\n storage.setItem(key, serialize(persistedClient))\n return\n } catch (error) {\n return error as Error\n }\n }\n return {\n persistClient: throttle((persistedClient) => {\n let client: PersistedClient | undefined = persistedClient\n let error = trySave(client)\n let errorCount = 0\n while (error && client) {\n errorCount++\n client = retry?.({\n persistedClient: client,\n error,\n errorCount,\n })\n\n if (client) {\n error = trySave(client)\n }\n }\n }, throttleTime),\n restoreClient: () => {\n const cacheString = storage.getItem(key)\n\n if (!cacheString) {\n return\n }\n\n return deserialize(cacheString)\n },\n removeClient: () => {\n storage.removeItem(key)\n },\n }\n }\n\n return {\n persistClient: noop,\n restoreClient: () => undefined,\n removeClient: noop,\n }\n}\n\nfunction throttle<TArgs extends any[]>(\n func: (...args: TArgs) => any,\n wait = 100,\n) {\n let timer: ReturnType<typeof setTimeout> | null = null\n let params: TArgs\n return function (...args: TArgs) {\n params = args\n if (timer === null) {\n timer = setTimeout(() => {\n func(...params)\n timer = null\n }, wait)\n }\n }\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-function\nfunction noop() {}\n"],"names":["createSyncStoragePersister","storage","key","throttleTime","serialize","JSON","stringify","deserialize","parse","retry","trySave","persistedClient","setItem","error","persistClient","throttle","client","errorCount","restoreClient","cacheString","getItem","removeClient","removeItem","noop","undefined","func","wait","timer","params","args","setTimeout"],"mappings":"AAqCO,SAASA,0BAA0B,CAAC;EACzCC,OAAO;AACPC,EAAAA,GAAG,GAAI,CAA0B,yBAAA,CAAA;AACjCC,EAAAA,YAAY,GAAG,IAAI;EACnBC,SAAS,GAAGC,IAAI,CAACC,SAAS;EAC1BC,WAAW,GAAGF,IAAI,CAACG,KAAK;AACxBC,EAAAA,KAAAA;AACiC,CAAC,EAAa;AAC/C,EAAA,IAAIR,OAAO,EAAE;IACX,MAAMS,OAAO,GAAIC,eAAgC,IAAwB;MACvE,IAAI;QACFV,OAAO,CAACW,OAAO,CAACV,GAAG,EAAEE,SAAS,CAACO,eAAe,CAAC,CAAC,CAAA;AAChD,QAAA,OAAA;OACD,CAAC,OAAOE,KAAK,EAAE;AACd,QAAA,OAAOA,KAAK,CAAA;AACd,OAAA;KACD,CAAA;IACD,OAAO;AACLC,MAAAA,aAAa,EAAEC,QAAQ,CAAEJ,eAAe,IAAK;QAC3C,IAAIK,MAAmC,GAAGL,eAAe,CAAA;AACzD,QAAA,IAAIE,KAAK,GAAGH,OAAO,CAACM,MAAM,CAAC,CAAA;QAC3B,IAAIC,UAAU,GAAG,CAAC,CAAA;QAClB,OAAOJ,KAAK,IAAIG,MAAM,EAAE;AACtBC,UAAAA,UAAU,EAAE,CAAA;AACZD,UAAAA,MAAM,GAAGP,KAAK,IAALA,IAAAA,GAAAA,KAAAA,CAAAA,GAAAA,KAAK,CAAG;AACfE,YAAAA,eAAe,EAAEK,MAAM;YACvBH,KAAK;AACLI,YAAAA,UAAAA;AACF,WAAC,CAAC,CAAA;AAEF,UAAA,IAAID,MAAM,EAAE;AACVH,YAAAA,KAAK,GAAGH,OAAO,CAACM,MAAM,CAAC,CAAA;AACzB,WAAA;AACF,SAAA;OACD,EAAEb,YAAY,CAAC;AAChBe,MAAAA,aAAa,EAAE,MAAM;AACnB,QAAA,MAAMC,WAAW,GAAGlB,OAAO,CAACmB,OAAO,CAAClB,GAAG,CAAC,CAAA;QAExC,IAAI,CAACiB,WAAW,EAAE;AAChB,UAAA,OAAA;AACF,SAAA;QAEA,OAAOZ,WAAW,CAACY,WAAW,CAAC,CAAA;OAChC;AACDE,MAAAA,YAAY,EAAE,MAAM;AAClBpB,QAAAA,OAAO,CAACqB,UAAU,CAACpB,GAAG,CAAC,CAAA;AACzB,OAAA;KACD,CAAA;AACH,GAAA;EAEA,OAAO;AACLY,IAAAA,aAAa,EAAES,IAAI;IACnBL,aAAa,EAAE,MAAMM,SAAS;AAC9BH,IAAAA,YAAY,EAAEE,IAAAA;GACf,CAAA;AACH,CAAA;AAEA,SAASR,QAAQ,CACfU,IAA6B,EAC7BC,IAAI,GAAG,GAAG,EACV;EACA,IAAIC,KAA2C,GAAG,IAAI,CAAA;AACtD,EAAA,IAAIC,MAAa,CAAA;EACjB,OAAO,UAAU,GAAGC,IAAW,EAAE;AAC/BD,IAAAA,MAAM,GAAGC,IAAI,CAAA;IACb,IAAIF,KAAK,KAAK,IAAI,EAAE;MAClBA,KAAK,GAAGG,UAAU,CAAC,MAAM;QACvBL,IAAI,CAAC,GAAGG,MAAM,CAAC,CAAA;AACfD,QAAAA,KAAK,GAAG,IAAI,CAAA;OACb,EAAED,IAAI,CAAC,CAAA;AACV,KAAA;GACD,CAAA;AACH,CAAA;;AAEA;AACA,SAASH,IAAI,GAAG;;;;"}
@@ -1,79 +0,0 @@
1
- (function (global, factory) {
2
- typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports) :
3
- typeof define === 'function' && define.amd ? define(['exports'], factory) :
4
- (global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory(global.QuerySyncStoragePersister = {}));
5
- })(this, (function (exports) { 'use strict';
6
-
7
- function createSyncStoragePersister({
8
- storage,
9
- key = `REACT_QUERY_OFFLINE_CACHE`,
10
- throttleTime = 1000,
11
- serialize = JSON.stringify,
12
- deserialize = JSON.parse,
13
- retry
14
- }) {
15
- if (storage) {
16
- const trySave = persistedClient => {
17
- try {
18
- storage.setItem(key, serialize(persistedClient));
19
- return;
20
- } catch (error) {
21
- return error;
22
- }
23
- };
24
- return {
25
- persistClient: throttle(persistedClient => {
26
- let client = persistedClient;
27
- let error = trySave(client);
28
- let errorCount = 0;
29
- while (error && client) {
30
- errorCount++;
31
- client = retry?.({
32
- persistedClient: client,
33
- error,
34
- errorCount
35
- });
36
- if (client) {
37
- error = trySave(client);
38
- }
39
- }
40
- }, throttleTime),
41
- restoreClient: () => {
42
- const cacheString = storage.getItem(key);
43
- if (!cacheString) {
44
- return;
45
- }
46
- return deserialize(cacheString);
47
- },
48
- removeClient: () => {
49
- storage.removeItem(key);
50
- }
51
- };
52
- }
53
- return {
54
- persistClient: noop,
55
- restoreClient: () => undefined,
56
- removeClient: noop
57
- };
58
- }
59
- function throttle(func, wait = 100) {
60
- let timer = null;
61
- let params;
62
- return function (...args) {
63
- params = args;
64
- if (timer === null) {
65
- timer = setTimeout(() => {
66
- func(...params);
67
- timer = null;
68
- }, wait);
69
- }
70
- };
71
- }
72
-
73
- // eslint-disable-next-line @typescript-eslint/no-empty-function
74
- function noop() {}
75
-
76
- exports.createSyncStoragePersister = createSyncStoragePersister;
77
-
78
- }));
79
- //# sourceMappingURL=index.development.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.development.js","sources":["../../src/index.ts"],"sourcesContent":["import type {\n PersistedClient,\n Persister,\n PersistRetryer,\n} from '@tanstack/query-persist-client-core'\n\ninterface Storage {\n getItem: (key: string) => string | null\n setItem: (key: string, value: string) => void\n removeItem: (key: string) => void\n}\n\ninterface CreateSyncStoragePersisterOptions {\n /** The storage client used for setting and retrieving items from cache.\n * For SSR pass in `undefined`. Note that window.localStorage can be\n * `null` in Android WebViews depending on how they are configured.\n */\n storage: Storage | undefined | null\n /** The key to use when storing the cache */\n key?: string\n /** To avoid spamming,\n * pass a time in ms to throttle saving the cache to disk */\n throttleTime?: number\n /**\n * How to serialize the data to storage.\n * @default `JSON.stringify`\n */\n serialize?: (client: PersistedClient) => string\n /**\n * How to deserialize the data from storage.\n * @default `JSON.parse`\n */\n deserialize?: (cachedString: string) => PersistedClient\n\n retry?: PersistRetryer\n}\n\nexport function createSyncStoragePersister({\n storage,\n key = `REACT_QUERY_OFFLINE_CACHE`,\n throttleTime = 1000,\n serialize = JSON.stringify,\n deserialize = JSON.parse,\n retry,\n}: CreateSyncStoragePersisterOptions): Persister {\n if (storage) {\n const trySave = (persistedClient: PersistedClient): Error | undefined => {\n try {\n storage.setItem(key, serialize(persistedClient))\n return\n } catch (error) {\n return error as Error\n }\n }\n return {\n persistClient: throttle((persistedClient) => {\n let client: PersistedClient | undefined = persistedClient\n let error = trySave(client)\n let errorCount = 0\n while (error && client) {\n errorCount++\n client = retry?.({\n persistedClient: client,\n error,\n errorCount,\n })\n\n if (client) {\n error = trySave(client)\n }\n }\n }, throttleTime),\n restoreClient: () => {\n const cacheString = storage.getItem(key)\n\n if (!cacheString) {\n return\n }\n\n return deserialize(cacheString)\n },\n removeClient: () => {\n storage.removeItem(key)\n },\n }\n }\n\n return {\n persistClient: noop,\n restoreClient: () => undefined,\n removeClient: noop,\n }\n}\n\nfunction throttle<TArgs extends any[]>(\n func: (...args: TArgs) => any,\n wait = 100,\n) {\n let timer: ReturnType<typeof setTimeout> | null = null\n let params: TArgs\n return function (...args: TArgs) {\n params = args\n if (timer === null) {\n timer = setTimeout(() => {\n func(...params)\n timer = null\n }, wait)\n }\n }\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-function\nfunction noop() {}\n"],"names":["createSyncStoragePersister","storage","key","throttleTime","serialize","JSON","stringify","deserialize","parse","retry","trySave","persistedClient","setItem","error","persistClient","throttle","client","errorCount","restoreClient","cacheString","getItem","removeClient","removeItem","noop","undefined","func","wait","timer","params","args","setTimeout"],"mappings":";;;;;;EAqCO,SAASA,0BAA0B,CAAC;IACzCC,OAAO;EACPC,EAAAA,GAAG,GAAI,CAA0B,yBAAA,CAAA;EACjCC,EAAAA,YAAY,GAAG,IAAI;IACnBC,SAAS,GAAGC,IAAI,CAACC,SAAS;IAC1BC,WAAW,GAAGF,IAAI,CAACG,KAAK;EACxBC,EAAAA,KAAAA;EACiC,CAAC,EAAa;EAC/C,EAAA,IAAIR,OAAO,EAAE;MACX,MAAMS,OAAO,GAAIC,eAAgC,IAAwB;QACvE,IAAI;UACFV,OAAO,CAACW,OAAO,CAACV,GAAG,EAAEE,SAAS,CAACO,eAAe,CAAC,CAAC,CAAA;EAChD,QAAA,OAAA;SACD,CAAC,OAAOE,KAAK,EAAE;EACd,QAAA,OAAOA,KAAK,CAAA;EACd,OAAA;OACD,CAAA;MACD,OAAO;EACLC,MAAAA,aAAa,EAAEC,QAAQ,CAAEJ,eAAe,IAAK;UAC3C,IAAIK,MAAmC,GAAGL,eAAe,CAAA;EACzD,QAAA,IAAIE,KAAK,GAAGH,OAAO,CAACM,MAAM,CAAC,CAAA;UAC3B,IAAIC,UAAU,GAAG,CAAC,CAAA;UAClB,OAAOJ,KAAK,IAAIG,MAAM,EAAE;EACtBC,UAAAA,UAAU,EAAE,CAAA;YACZD,MAAM,GAAGP,KAAK,GAAG;EACfE,YAAAA,eAAe,EAAEK,MAAM;cACvBH,KAAK;EACLI,YAAAA,UAAAA;EACF,WAAC,CAAC,CAAA;EAEF,UAAA,IAAID,MAAM,EAAE;EACVH,YAAAA,KAAK,GAAGH,OAAO,CAACM,MAAM,CAAC,CAAA;EACzB,WAAA;EACF,SAAA;SACD,EAAEb,YAAY,CAAC;EAChBe,MAAAA,aAAa,EAAE,MAAM;EACnB,QAAA,MAAMC,WAAW,GAAGlB,OAAO,CAACmB,OAAO,CAAClB,GAAG,CAAC,CAAA;UAExC,IAAI,CAACiB,WAAW,EAAE;EAChB,UAAA,OAAA;EACF,SAAA;UAEA,OAAOZ,WAAW,CAACY,WAAW,CAAC,CAAA;SAChC;EACDE,MAAAA,YAAY,EAAE,MAAM;EAClBpB,QAAAA,OAAO,CAACqB,UAAU,CAACpB,GAAG,CAAC,CAAA;EACzB,OAAA;OACD,CAAA;EACH,GAAA;IAEA,OAAO;EACLY,IAAAA,aAAa,EAAES,IAAI;MACnBL,aAAa,EAAE,MAAMM,SAAS;EAC9BH,IAAAA,YAAY,EAAEE,IAAAA;KACf,CAAA;EACH,CAAA;EAEA,SAASR,QAAQ,CACfU,IAA6B,EAC7BC,IAAI,GAAG,GAAG,EACV;IACA,IAAIC,KAA2C,GAAG,IAAI,CAAA;EACtD,EAAA,IAAIC,MAAa,CAAA;IACjB,OAAO,UAAU,GAAGC,IAAW,EAAE;EAC/BD,IAAAA,MAAM,GAAGC,IAAI,CAAA;MACb,IAAIF,KAAK,KAAK,IAAI,EAAE;QAClBA,KAAK,GAAGG,UAAU,CAAC,MAAM;UACvBL,IAAI,CAAC,GAAGG,MAAM,CAAC,CAAA;EACfD,QAAAA,KAAK,GAAG,IAAI,CAAA;SACb,EAAED,IAAI,CAAC,CAAA;EACV,KAAA;KACD,CAAA;EACH,CAAA;;EAEA;EACA,SAASH,IAAI,GAAG;;;;;;;;"}
@@ -1,2 +0,0 @@
1
- !function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports):"function"==typeof define&&define.amd?define(["exports"],t):t((e="undefined"!=typeof globalThis?globalThis:e||self).QuerySyncStoragePersister={})}(this,(function(e){"use strict";function t(e,t=100){let r,n=null;return function(...i){r=i,null===n&&(n=setTimeout((()=>{e(...r),n=null}),t))}}function r(){}e.createSyncStoragePersister=function({storage:e,key:n="REACT_QUERY_OFFLINE_CACHE",throttleTime:i=1e3,serialize:o=JSON.stringify,deserialize:s=JSON.parse,retry:l}){if(e){const r=t=>{try{return void e.setItem(n,o(t))}catch(e){return e}};return{persistClient:t((e=>{let t=e,n=r(t),i=0;for(;n&&t;)i++,t=l?.({persistedClient:t,error:n,errorCount:i}),t&&(n=r(t))}),i),restoreClient:()=>{const t=e.getItem(n);if(t)return s(t)},removeClient:()=>{e.removeItem(n)}}}return{persistClient:r,restoreClient:()=>{},removeClient:r}}}));
2
- //# sourceMappingURL=index.production.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.production.js","sources":["../../src/index.ts"],"sourcesContent":["import type {\n PersistedClient,\n Persister,\n PersistRetryer,\n} from '@tanstack/query-persist-client-core'\n\ninterface Storage {\n getItem: (key: string) => string | null\n setItem: (key: string, value: string) => void\n removeItem: (key: string) => void\n}\n\ninterface CreateSyncStoragePersisterOptions {\n /** The storage client used for setting and retrieving items from cache.\n * For SSR pass in `undefined`. Note that window.localStorage can be\n * `null` in Android WebViews depending on how they are configured.\n */\n storage: Storage | undefined | null\n /** The key to use when storing the cache */\n key?: string\n /** To avoid spamming,\n * pass a time in ms to throttle saving the cache to disk */\n throttleTime?: number\n /**\n * How to serialize the data to storage.\n * @default `JSON.stringify`\n */\n serialize?: (client: PersistedClient) => string\n /**\n * How to deserialize the data from storage.\n * @default `JSON.parse`\n */\n deserialize?: (cachedString: string) => PersistedClient\n\n retry?: PersistRetryer\n}\n\nexport function createSyncStoragePersister({\n storage,\n key = `REACT_QUERY_OFFLINE_CACHE`,\n throttleTime = 1000,\n serialize = JSON.stringify,\n deserialize = JSON.parse,\n retry,\n}: CreateSyncStoragePersisterOptions): Persister {\n if (storage) {\n const trySave = (persistedClient: PersistedClient): Error | undefined => {\n try {\n storage.setItem(key, serialize(persistedClient))\n return\n } catch (error) {\n return error as Error\n }\n }\n return {\n persistClient: throttle((persistedClient) => {\n let client: PersistedClient | undefined = persistedClient\n let error = trySave(client)\n let errorCount = 0\n while (error && client) {\n errorCount++\n client = retry?.({\n persistedClient: client,\n error,\n errorCount,\n })\n\n if (client) {\n error = trySave(client)\n }\n }\n }, throttleTime),\n restoreClient: () => {\n const cacheString = storage.getItem(key)\n\n if (!cacheString) {\n return\n }\n\n return deserialize(cacheString)\n },\n removeClient: () => {\n storage.removeItem(key)\n },\n }\n }\n\n return {\n persistClient: noop,\n restoreClient: () => undefined,\n removeClient: noop,\n }\n}\n\nfunction throttle<TArgs extends any[]>(\n func: (...args: TArgs) => any,\n wait = 100,\n) {\n let timer: ReturnType<typeof setTimeout> | null = null\n let params: TArgs\n return function (...args: TArgs) {\n params = args\n if (timer === null) {\n timer = setTimeout(() => {\n func(...params)\n timer = null\n }, wait)\n }\n }\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-function\nfunction noop() {}\n"],"names":["throttle","func","wait","params","timer","args","setTimeout","noop","storage","key","throttleTime","serialize","JSON","stringify","deserialize","parse","retry","trySave","persistedClient","setItem","error","persistClient","client","errorCount","restoreClient","cacheString","getItem","removeClient","removeItem"],"mappings":"iQA8FA,SAASA,EACPC,EACAC,EAAO,KAEP,IACIC,EADAC,EAA8C,KAElD,OAAO,YAAaC,GAClBF,EAASE,EACK,OAAVD,IACFA,EAAQE,YAAW,KACjBL,KAAQE,GACRC,EAAQ,IAAI,GACXF,IAGT,CAGA,SAASK,IAAO,8BA3ET,UAAoCC,QACzCA,EAAOC,IACPA,EAAO,4BAA0BC,aACjCA,EAAe,IAAIC,UACnBA,EAAYC,KAAKC,UAASC,YAC1BA,EAAcF,KAAKG,MAAKC,MACxBA,IAEA,GAAIR,EAAS,CACX,MAAMS,EAAWC,IACf,IAEE,YADAV,EAAQW,QAAQV,EAAKE,EAAUO,GAIjC,CAFE,MAAOE,GACP,OAAOA,CACT,GAEF,MAAO,CACLC,cAAerB,GAAUkB,IACvB,IAAII,EAAsCJ,EACtCE,EAAQH,EAAQK,GAChBC,EAAa,EACjB,KAAOH,GAASE,GACdC,IACAD,EAASN,IAAQ,CACfE,gBAAiBI,EACjBF,QACAG,eAGED,IACFF,EAAQH,EAAQK,GAEpB,GACCZ,GACHc,cAAe,KACb,MAAMC,EAAcjB,EAAQkB,QAAQjB,GAEpC,GAAKgB,EAIL,OAAOX,EAAYW,EAAY,EAEjCE,aAAc,KACZnB,EAAQoB,WAAWnB,EAAI,EAG7B,CAEA,MAAO,CACLY,cAAed,EACfiB,cAAe,KAAe,EAC9BG,aAAcpB,EAElB"}