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();
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
。
Last updated