Skip to content

writeDownloadedAssets

TIP

Part of Export API

Integrated API to write downloaded assets to the virtual file system.

ts
declare function writeDownloadedAssets<T, Ctx>({
  ctx,
  items,
  getFileNameCtx,
  concurrency = 5,
  optimize = true
}: DownloadAndWriteAssetsParams<T, Ctx>): Promise<void>;
declare function writeDownloadedAssets<T, Ctx>({
  ctx,
  items,
  getFileNameCtx,
  concurrency = 5,
  optimize = true
}: DownloadAndWriteAssetsParams<T, Ctx>): Promise<void>;

WriteDownloadedAssetsParams

Parameters for the writeDownloadedAssets API.

ts
export interface WriteDownloadedAssetsParams<T, Ctx> extends WriteDownloadedAssetsConfig<T, Ctx> {
  ctx: ExportContext;
  items: DownloadedAsset<T>[];
  /**
   * Resolve additional context for the `getExportFileName` function.
   * @example () => ({ fileId: "..." })
   * @example node => ({ node, ...myData })
   */
  getFileNameCtx: (item: DownloadedAsset<T>) => Ctx;
}
export interface WriteDownloadedAssetsParams<T, Ctx> extends WriteDownloadedAssetsConfig<T, Ctx> {
  ctx: ExportContext;
  items: DownloadedAsset<T>[];
  /**
   * Resolve additional context for the `getExportFileName` function.
   * @example () => ({ fileId: "..." })
   * @example node => ({ node, ...myData })
   */
  getFileNameCtx: (item: DownloadedAsset<T>) => Ctx;
}

WriteDownloadedAssetsConfig

User configuration for the writeDownloadedAssets API.

ts
export interface WriteDownloadedAssetsConfig<T, Ctx> {
  optimize?: OptimizeDownloadedAssetsParams | false;
  concurrency?: number;
  /**
   * Exported nodes can provide wrong built-in names, so we can override them here.
   *
   * @param item - Downloaded item
   * @param ctx - Export context (depends on the export type, returned by `getFileNameCtx`)
   *
   * @example ({ node, format }) => `${node.source.name}.${format}`
   * @default Lowercased node name separated by "/" + scale postfix if scale > 1
   */
  getExportFileName?: (item: DownloadedAsset<T>, ctx: Ctx) => string;
}
export interface WriteDownloadedAssetsConfig<T, Ctx> {
  optimize?: OptimizeDownloadedAssetsParams | false;
  concurrency?: number;
  /**
   * Exported nodes can provide wrong built-in names, so we can override them here.
   *
   * @param item - Downloaded item
   * @param ctx - Export context (depends on the export type, returned by `getFileNameCtx`)
   *
   * @example ({ node, format }) => `${node.source.name}.${format}`
   * @default Lowercased node name separated by "/" + scale postfix if scale > 1
   */
  getExportFileName?: (item: DownloadedAsset<T>, ctx: Ctx) => string;
}

formatExportFileName

WARNING

Semi-internal API

Format file name as lower-cased string with replaced spaces and special characters to dashes.

You can use this function for building your own getExportFileName function.

ts
/**
 * @example "File.svg" -> "file.svg"
 * @example "Common/Animals and Plants/Cat_sleeping.svg" -> "common/animals-and-plants/cat_sleeping.svg"
 * @example "print: 32/copy&pasted.svg" -> "print-32/copy-pasted.svg"
 */
declare function formatExportFileName(fileName: string): string;
/**
 * @example "File.svg" -> "file.svg"
 * @example "Common/Animals and Plants/Cat_sleeping.svg" -> "common/animals-and-plants/cat_sleeping.svg"
 * @example "print: 32/copy&pasted.svg" -> "print-32/copy-pasted.svg"
 */
declare function formatExportFileName(fileName: string): string;

Released under the MIT License.