Skip to content

Export file assets API Reference

CLI

Configuration for export command in .figma.config.js.

typescript
export interface ExportFileAssetsCliParams extends BasicConfiguration {
  /**
   * "file-assets" is using by default, so you don't need to specify it.
   */
  type?: 'file-assets';
  /**
   * Optional if you already defined `fileId` in root configuration.
   */
  fileId?: string;
  /**
   * Path to the output directory of exported files (relative to the current working directory)
   */
  output?: string;
}
export interface ExportFileAssetsCliParams extends BasicConfiguration {
  /**
   * "file-assets" is using by default, so you don't need to specify it.
   */
  type?: 'file-assets';
  /**
   * Optional if you already defined `fileId` in root configuration.
   */
  fileId?: string;
  /**
   * Path to the output directory of exported files (relative to the current working directory)
   */
  output?: string;
}

Node.js

In Node.js, you can use exportFileAssets function to export assets from a Figma file.

typescript
declare function exportFileAssets(params: ExportFileAssetsParams): Promise<void>;
declare function exportFileAssets(params: ExportFileAssetsParams): Promise<void>;
typescript
export interface ExportFileAssetsParams extends BasicConfiguration {
  ctx: ExportContext;
}
export interface ExportFileAssetsParams extends BasicConfiguration {
  ctx: ExportContext;
}

Basic configuration

typescript
export interface BasicConfiguration {
  write?: WriteDownloadedAssetsConfig<AnyGraphNode, GraphNode<DocumentNode>>;
  collect?: CollectNodesParams;
  /**
   * File nodes have their own optional user-defined export settings.
   * To cover it, you could pass `resolve.exportAs: "export"`
   *
   * @example {
   *   resolve: {
   *     exportAs: "export",
   *   }
   * }
   */
  resolve?: ResolveExportedAssetsConfig<AnyGraphNode, typeof fileGraphResolversMap>;
  download?: DownloadExportedAssetsConfig;
}
export interface BasicConfiguration {
  write?: WriteDownloadedAssetsConfig<AnyGraphNode, GraphNode<DocumentNode>>;
  collect?: CollectNodesParams;
  /**
   * File nodes have their own optional user-defined export settings.
   * To cover it, you could pass `resolve.exportAs: "export"`
   *
   * @example {
   *   resolve: {
   *     exportAs: "export",
   *   }
   * }
   */
  resolve?: ResolveExportedAssetsConfig<AnyGraphNode, typeof fileGraphResolversMap>;
  download?: DownloadExportedAssetsConfig;
}

Released under the MIT License.