sliftutils 0.20.0 → 0.22.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/index.d.ts CHANGED
@@ -594,7 +594,7 @@ declare module "sliftutils/storage/FileFolderAPI" {
594
594
  hasKey(key: string): Promise<boolean>;
595
595
  getStorage(key: string): Promise<FileStorage>;
596
596
  removeStorage(key: string): Promise<void>;
597
- getKeys(): Promise<string[]>;
597
+ getKeys(includeFolders?: boolean): Promise<string[]>;
598
598
  };
599
599
  export type FileStorage = IStorageRaw & {
600
600
  folder: NestedFileStorage;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "sliftutils",
3
- "version": "0.20.0",
3
+ "version": "0.22.0",
4
4
  "main": "index.js",
5
5
  "license": "MIT",
6
6
  "files": [
@@ -200,7 +200,7 @@ export class InputLabel extends preact.Component<InputLabelProps> {
200
200
  }
201
201
  return (
202
202
  <label onClick={onClick} className={
203
- css.hbox(0).relative
203
+ css.hbox(5).relative
204
204
  + " trigger-hover "
205
205
  + props.outerClass
206
206
  + (props.flavor === "large" && css.fontSize(18, "soft"))
@@ -64,7 +64,7 @@ export type NestedFileStorage = {
64
64
  hasKey(key: string): Promise<boolean>;
65
65
  getStorage(key: string): Promise<FileStorage>;
66
66
  removeStorage(key: string): Promise<void>;
67
- getKeys(): Promise<string[]>;
67
+ getKeys(includeFolders?: boolean): Promise<string[]>;
68
68
  };
69
69
  export type FileStorage = IStorageRaw & {
70
70
  folder: NestedFileStorage;
@@ -213,7 +213,7 @@ export const getDirectoryHandle = lazy(async function getDirectoryHandle(): Prom
213
213
 
214
214
  let handle: DirectoryWrapper | undefined;
215
215
 
216
- let storedId = localStorage.getItem(getFileAPIKey());
216
+ const storedId = localStorage.getItem(getFileAPIKey());
217
217
  if (storedId) {
218
218
  let doneLoad = false;
219
219
  setTimeout(() => {
@@ -223,7 +223,45 @@ export const getDirectoryHandle = lazy(async function getDirectoryHandle(): Prom
223
223
  }, 500);
224
224
  try {
225
225
  handle = await tryToLoadPointer(storedId);
226
- } catch { }
226
+ } catch (e) {
227
+ console.error(e);
228
+ // Check if the error is due to user activation being required
229
+ const errorMessage = e instanceof Error ? e.message : String(e);
230
+ if (errorMessage.includes("user activation") || errorMessage.includes("User activation")) {
231
+ doneLoad = true;
232
+ // Show UI to get user to click and retry
233
+ let retryCallback: (success: boolean) => void;
234
+ let retryPromise = new Promise<boolean>(resolve => {
235
+ retryCallback = resolve;
236
+ });
237
+ displayData.ui = (
238
+ <button
239
+ className={css.fontSize(40).pad2(80, 40)}
240
+ onClick={async () => {
241
+ displayData.ui = "Loading...";
242
+ try {
243
+ const retryHandle = await tryToLoadPointer(storedId);
244
+ if (retryHandle) {
245
+ handle = retryHandle;
246
+ retryCallback(true);
247
+ } else {
248
+ retryCallback(false);
249
+ }
250
+ } catch (retryError) {
251
+ console.error("Retry failed:", retryError);
252
+ retryCallback(false);
253
+ }
254
+ }}
255
+ >
256
+ Click to restore file system access
257
+ </button>
258
+ );
259
+ const success = await retryPromise;
260
+ if (handle) {
261
+ return handle;
262
+ }
263
+ }
264
+ }
227
265
  doneLoad = true;
228
266
  if (handle) {
229
267
  return handle;
@@ -280,7 +318,7 @@ export type NestedFileStorage = {
280
318
  hasKey(key: string): Promise<boolean>;
281
319
  getStorage(key: string): Promise<FileStorage>;
282
320
  removeStorage(key: string): Promise<void>;
283
- getKeys(): Promise<string[]>;
321
+ getKeys(includeFolders?: boolean): Promise<string[]>;
284
322
  };
285
323
 
286
324
  export type FileStorage = IStorageRaw & {
@@ -368,10 +406,10 @@ function wrapHandleFiles(handle: DirectoryWrapper): IStorageRaw {
368
406
  await handle.removeEntry(key);
369
407
  },
370
408
 
371
- async getKeys(): Promise<string[]> {
409
+ async getKeys(includeFolders: boolean = false): Promise<string[]> {
372
410
  const keys: string[] = [];
373
411
  for await (const [name, entry] of handle) {
374
- if (entry.kind === "file") {
412
+ if (entry.kind === "file" || includeFolders) {
375
413
  keys.push(entry.name);
376
414
  }
377
415
  }