item

The eagle.item API allows you to easily query the current content of the resource library or add new content to the resource library.

eagle.onPluginCreate(async (plugin) => {
    // Get the currently selected file in the Eagle app
    let items = await eagle.item.getSelected();
    let item = items[0];
    
    // Modify attributes
    item.name = 'New Name';
    item.tags = ['tag1', 'tag2'];
    
    // Save modifications
    await item.save();
});

Methods

get(options)

Universal search method that can get files with specified conditions.

  • options Object - Query conditions

    • id string (optional) - File id

    • ids string[] (optional) - Array of file ids

    • isSelected boolean (optional) - Currently selected files

    • isUntagged boolean (optional) - Files that have not been tagged

    • isUnfiled boolean (optional) - Files that have not been categorized

    • keywords string[] (optional) - Contains keywords

    • tags string[] (optional) - Contains tags

    • folders string[] (optional) - Contains folders

    • ext string (optional) - Format

    • annotation string (optional) - Annotation

    • rating Integer (optional) - Rating, range from 0 ~ 5

    • url string (optional) - Source URL

    • shape string (optional) - Shape, options are square, portrait, panoramic-portrait, landscape, panoramic-landscape

  • Returns Promise<items: Item[]> - items query result

let items = await eagle.item.get({
    ids: [],
    isSelected: true,
    isUnfiled: true,
    isUntagged: true,
    keywords: [""],
    ext: "",
    tags: [],
    folders: [],
    shape: "square",
    rating: 5,
    annotation: "",
    url: ""
});


let selected = await eagle.item.get({
    isSelected: true
});

let jpgs = await eagle.item.get({
    ext: "jpg"
});

getAll()

Return all files.

  • Returns Promise<items: Item[]> - items all files

let items = await eagle.item.getAll();
console.log(items);

getById(itemId)

Return the file with the specified ID.

  • itemId string

  • Returns Promise<item: Item> - item the file with the corresponding ID

let item = await eagle.item.getById('item_id');
console.log(item);

getByIds(itemIds)

Return the files with the specified IDs.

  • itemIds string[]

  • Returns Promise<items: Item[]> - items the files with the corresponding IDs

let items = await eagle.item.getByIds(['item_id_1', 'item_id_2']);
console.log(items);

getSelected()

Return the currently selected files in the application.

  • Returns Promise<items: Item[]> - items selected files

let selected = await eagle.item.getSelected();
console.log(selected);

addFromURL(url, options)

Add an image link to Eagle.

  • urlstring - The image link to add, supports http, https, base64

  • options Object

    • name string (optional) - File name

    • website string (optional) - Source URL

    • tags string[] (optional) - Tags

    • folders string[] (optional) - Belonging folder IDs

    • annotation string (optional) - Annotation

  • Returns Promise<itemId: string> - itemId is the successfully created item ID

const imgURL = 'https://cdn.dribbble.com/userupload/3885520/file/original-ee68b80a6e10edab6f192e1e542da6ed.jpg';
const itemId = await eagle.item.addFromURL(imgURL, { 
    name: 'Camping', 
    website: 'https://dribbble.com/shots/19744134-Camping-2', 
    tags: ["Dribbble", "Illustration"],
    folders: [],
    annotation: 'add from eagle api',
});

addFromBase64(base64, options)

Add a base64 image to Eagle.

  • base64string - Base64 format image

  • options Object

    • name string (optional) - File name

    • website string (optional) - Source URL

    • tags string[] (optional) - Tags

    • folders string[] (optional) - Belonging folder IDs

    • annotation string (optional) - Annotation

  • Returns Promise<itemId: string> - itemId is the successfully created item ID

const base64 = '';
const itemId = await eagle.item.addFromBase64(base64, { 
    name: 'Illustation Logo', 
    website: 'https://www.eagle.cool/', 
    tags: ["Adobe", "Logo"],
    folders: [],
    annotation: 'ai logo form api',
});

addFromPath(path, options)

Add files to Eagle from a local file path.

  • pathstring - The file path to add

  • options Object

    • name string (optional) - File name

    • website string (optional) - Source URL

    • tags string[] (optional) - Tags

    • folders string[] (optional) - Belonging folder IDs

    • annotation string (optional) - Annotation

  • Returns Promise<itemId: string> - itemId is the successfully created item ID

const filePath = 'C:\\Users\\User\\Downloads\\ai.svg';
const itemId = await eagle.item.addFromPath(filePath, { 
    name: 'Illustation Logo', 
    website: 'https://www.eagle.cool/', 
    tags: ["Adobe", "Logo"],
    folders: [],
    annotation: 'ai logo form api',
});

addBookmark(url, options)

Add a bookmark link to Eagle.

  • urlstring - The bookmark link to add

  • options Object

    • name string (optional) - Bookmark name

    • base64 string (optional) - Custom thumbnail in base64 format

    • tags string[] (optional) - Tags

    • folders string[] (optional) - Belonging folder IDs

    • annotation string (optional) - Annotation

  • Returns Promise<itemId: string> - itemId is the successfully created item ID

const bookmarkURL = 'https://www.google.com/';
const itemId = await eagle.item.addBookmark(bookmarkURL, { 
    name: 'Eagle', 
    tags: ["Eagle", "Site"],
    folders: [],
    annotation: 'bookmark form api',
});
const bookmarkURL = 'https://www.google.com/';
const base64 = '';
const itemId = await eagle.item.addBookmark(bookmarkURL, { 
    name: 'Eagle', 
    base64: base64,
    tags: ["Eagle", "Site"],
    folders: [],
    annotation: 'bookmark form api',
});

open(itemId)

Display the file corresponding to itemId in the full list

  • itemId string - ID of the file to display

  • Returns Promise<result: boolean>

await eagle.item.open("item_id");

Hint: You can also directly call the open() method of the item instance to open the file.


Class: Item

Object type returned by Eagle API get, provides modification and save features.


Instance methods

save()

Save all modifications

  • Returns Promise<result: boolean> - result indicates whether the modification was successful

let item = await eagle.item.getById('item_id');
item.name = 'New Name';
item.tags = ['tag_1', 'tag_2'];

// Save changes
await item.save();

moveToTrash()

Move the file to the trash.

  • Returns Promise<result: boolean> - result Indicates whether the deletion was successful.

await item.moveToTrash();

replaceFile(filePath)

Replace the original file with the specified file, automatically refreshing the thumbnail without needing to call refreshThumbnail() again.

  • filePath string - Path of the file to replace

  • Returns Promise<result: boolean> - result indicates whether the replacement was successful

let item = await eagle.item.getById('item_id');
let result = await item.replaceFile('new_file_path');

console.log(result);

refreshThumbnail()

Refreshes the file thumbnail, and updates the properties like file size, color analysis, dimensions, etc.

  • Returns Promise<result: boolean> - result indicates whether the operation was successful

let item = await eagle.item.getById('item_id');
let result = await item.refreshThumbnail();

console.log(result);

setCustomThumbnail(thumbnailPath)

Set a custom thumbnail for the file.

  • thumbnailPath string - Path of the thumbnail to set

  • Returns Promise<result: boolean> - result indicates whether the replacement was successful

let item = await eagle.item.getById('item_id');
let result = await item.setCustomThumbnail('thumbnail_path');

console.log(result);

open()

Display this file in the full list

  • Returns Promise<void>

Hint: You can also directly call the eagle.item.open(itemId) method to open the file.

let item = await eagle.item.getById('item_id');
await item.open();

// Equivalent to
await eagle.item.open('item_id');

Instance properties

id string

Read-only, file ID.

name string

File name.

ext string

Read-only, file extension.

width Interger

Image width.

height Interger

Image height.

url string

Source link.

isDeleted boolean

Read-only, is the file in the trash.

annotation string

File annotation.

tags string[]

File tags.

folders string[]

Belonging folder ids.

palettes Object[]

Read-only, color palette information.

size Interger

Read-only, file size.

star Interger

Rating information, 0 ~ 5.

importedAt Interger

Read-only, time the file was added.

let date = new Date(item.importedAt);

noThumbnail boolean

Read-only, the file doesn't have a thumbnail. Files without a thumbnail will be previewed using the original file.

noPreview boolean

Read-only, the file is not supported for double-click preview.

filePath string

Read-only, returns the file path.

fileURL string

Read-only, returns the file URL (file:///).

thumbnailPath string

Read-only, returns the thumbnail path.

thumbnailURL string

Read-only, returns the thumbnail URL (file:///). Use this property if you want to display the file in HTML.

metadataFilePathstring

Read-only, location of the metadata.json file for this file.

Last updated