item(项目)

透过 eagle.item API 可以方便的查询当前资源库内容或添加新的内容到资源库中。

eagle.onPluginCreate(async (plugin) => {
    // 取得 Eagle 应用当前被选中的文件
    let items = await eagle.item.getSelected();
    let item = items[0];
    
    // 修改属性
    item.name = 'New Name';
    item.tags = ['tag1', 'tag2'];
    
    // 保存修改
    await item.save();
});

🦄 最佳实践: 为了确保数据安全性,请使用 item API 提供的 save() 方法进行数据的存取与修改,应避免直接修改 Eagle 资源库底下的 metadata.json 或任意文件。


方法

get(options)

万用搜索方法,可获取指定条件的文件。

  • options Object - 查询条件

    • id string (可选) - 文件 id

    • ids string[] (可选) - 文件 id 数组

    • isSelected boolean (可选) - 正在被选中的文件

    • isUntagged boolean (可选) - 尚未标签

    • isUnfiled boolean (可选) - 尚未分类

    • keywords string[] (可选) - 包含关键字

    • tags string[] (可选) - 包含标签

    • folders string[] (可选) - 包含文件夹

    • ext string (可选) - 格式

    • annotation string (可选) - 注释

    • rating Interger (可选) - 评分,0 ~ 5

    • url string (可选) - 来源链接

    • shape string (可选) - 形状,squareportraitpanoramic-portraitlandscapepanoramic-landscape

  • 返回 Promise<items: Item[]> - items 查询结果

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()

返回所有文件

  • 返回 Promise<items: Item[]> - items 所有文件

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

🦄 最佳实践: 如果资源库文件数量非常多(例:20W+),避免无限制的呼叫此方法,避免造成应用性能的降低。


getById(itemId)

返回指定 ID 之文件

  • itemId string

  • 返回 Promise<item: Item> - item 对应 ID 的文件

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

getByIds(itemIds)

返回指定 IDs 之文件

  • itemIds string[]

  • 返回 Promise<items: Item[]> - items 对应 IDs 的文件

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

getSelected()

返回应用当前选中的文件

  • 返回 Promise<items: Item[]> - items 选中之文件

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

addFromURL(url, options)

将图片链接添加至 Eagle

  • urlstring - 欲添加图片链接,支持 httphttpsbase64

  • options Object

    • name string (可选) - 文件名

    • website string (可选) - 来源网址

    • tags string[] (可选) - 标签

    • folders string[] (可选) - 所属文件夹 IDs

    • annotation string (可选) - 注释

  • 返回 Promise<itemId: string> - itemId成功创建的项目 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)

添加 base64 图像至 Eagle

  • base64string - base64 格式图像

  • options Object

    • name string (可选) - 文件名

    • website string (可选) - 来源网址

    • tags string[] (可选) - 标签

    • folders string[] (可选) - 所属文件夹 IDs

    • annotation string (可选) - 注释

  • 返回 Promise<itemId: string> - itemId成功创建的项目 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)

从本地文件路径添加文件至 Eagle

  • pathstring - 欲添加文件路径

  • options Object

    • name string (可选) - 文件名

    • website string (可选) - 来源网址

    • tags string[] (可选) - 标签

    • folders string[] (可选) - 所属文件夹 IDs

    • annotation string (可选) - 注释

  • 返回 Promise<itemId: string> - itemId成功创建的项目 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)

添加书签链接至 Eagle

  • urlstring - 欲添加书签链接

  • options Object

    • name string (可选) - 书签名

    • base64 string (可选) - 自订缩图 base64 格式

    • tags string[] (可选) - 标签

    • folders string[] (可选) - 所属文件夹 IDs

    • annotation string (可选) - 注释

  • 返回 Promise<itemId: string> - itemId成功创建的项目 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)

在全部列表显示 itemId 对应的文件

  • itemIdstring - 欲显示文件 ID

  • 返回 Promise<result: boolean>

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

提示:你也可以直接呼叫 item 实例的 open() 方法打开文件。


類:Item

由 Eagle API get返回的 Object 类型,提供修改、保存功能。

🦄 最佳实践: 为了确保数据安全性,请使用 Item 实例提供的 save() 方法进行数据的存取与修改,应避免直接修改 Eagle 资源库底下的 metadata.json 或任意文件。


实例方法

save()

保存所有修改

  • 返回 Promise<result: boolean> - result是否修改成功

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

// 保存修改
await item.save();

replaceFile(filePath)

使用指定文件替换原文件,将自动刷新缩略图,无须再次呼叫 refreshThumbnail()

🦄 最佳实践: 直接对要更改的文件进行操作是具有风险的,若过程中出现错误或异常,都有可能造成文件损毁且无法复原。因此,先将新版本文件保存在电脑其它路径,确定无误后,再使用 replaceFile()方法来替换是更稳健的作法。

  • filePathstring - 欲替换文件之路径

  • 返回 Promise<result: boolean> - result是否替换成功

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

console.log(result);

refreshThumbnail()

重新刷新文件缩略图,同时也会重新获取文件大小、颜色分析、尺寸等属性。

  • 返回 Promise<result: boolean> - result是否成功

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

console.log(result);

setCustomThumbnail(thumbnailPath)

为文件设置自定缩略图。

  • thumbnailPathstring - 欲设置缩略图的路径

  • 返回 Promise<result: boolean> - result是否替换成功

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

console.log(result);

open()

在全部列表显示此文件

  • 返回 Promise<void>

提示:你也可以直接呼叫 eagle.item.open(itemId)方法打开文件夹。

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

// 等价于
await eagle.item.open('item_id');

实例属性

id string

只读,文件 ID。

name string

文件名。

ext string

只读,文件扩展名。

width Interger

图像宽度。

height Interger

图像高度。

url string

来源链接。

isDeleted boolean

只读,文件是否在垃圾桶。

annotation string

文件注释。

tags string[]

文件标签。

folders string[]

所属文件夹 ids。

palettes Object[]

只读,色票信息。

size Interger

只读,文件大小。

star Interger

评分信息,0 ~ 5

importedAt Interger

只读,添加时间。

let date = new Date(item.importedAt);

noThumbnail boolean

只读,文件是否有缩略图,无缩略图文件将以原始文件进行预览。

noPreview boolean

只读,文件是否支持双击预览。

filePath string

只读,返回文件所在路径。

fileURL string

只读,返回文件所在路径之链接(file:///)。

thumbnailPath string

只读,返回缩略图路径。

thumbnailURL string

只读,返回缩略图链接(file:///),如需在 HTML 显示该文件,可以使用这个属性。

metadataFilePathstring

只读,该文件 metadata.json 所在位置。

🦄 最佳实践: 为了确保数据安全性,请使用 item API 提供的 save() 方法进行数据的存取与修改,应避免直接 metadata.json

最后更新于