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 - 查询条件
ids
string[] (可选) - 文件 id 数组
isSelected
boolean (可选) - 正在被选中的文件
isUntagged
boolean (可选) - 尚未标签
isUnfiled
boolean (可选) - 尚未分类
keywords
string[] (可选) - 包含关键字
tags
string[] (可选) - 包含标签
folders
string[] (可选) - 包含文件夹
annotation
string (可选) - 注释
rating
Interger (可选) - 评分,0 ~ 5
shape
string (可选) - 形状,square
、portrait
、panoramic-portrait
、landscape
、panoramic-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 之文件
返回 Promise<item: Item>
- item
对应 ID 的文件
let item = await eagle.item.getById('item_id');
console.log(item);
getByIds(itemIds)
返回指定 IDs 之文件
返回 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
url
string - 欲添加图片链接,支持 http
、 https
、 base64
options
Object
website
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
base64
string - base64 格式图像
options
Object
website
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
options
Object
website
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
options
Object
base64
string (可选) - 自订缩图 base64 格式
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
对应的文件
返回 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();
moveToTrash()
将文件丢到垃圾桶
返回 Promise<result: boolean>
- result
是否成功删除
await item.moveToTrash();
replaceFile(filePath)
使用指定文件替换原文件,将自动刷新缩略图,无须再次呼叫 refreshThumbnail()
。
🦄 最佳实践: 直接对要更改的文件进行操作是具有风险的,若过程中出现错误或异常,都有可能造成文件损毁且无法复原。因此,先将新版本文件保存在电脑其它路径,确定无误后,再使用 replaceFile()
方法来替换是更稳健的作法。
filePath
string - 欲替换文件之路径
返回 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)
为文件设置自定缩略图。
thumbnailPath
string - 欲设置缩略图的路径
返回 Promise<result: boolean>
- result
是否替换成功
let item = await eagle.item.getById('item_id');
let result = await item.setCustomThumbnail('thumbnail_path');
console.log(result);
open()
在全部列表显示此文件
提示:你也可以直接呼叫 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 显示该文件,可以使用这个属性。
metadataFilePath
string
只读,该文件 metadata.json
所在位置。
🦄 最佳实践: 为了确保数据安全性,请使用 item
API 提供的 save()
方法进行数据的存取与修改,应避免直接 metadata.json
。