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)
万能検索メソッド。指定条件のファイルを取得できます。
optionsObject - 検索条件idstring (オプション) - ファイル ididsstring[] (オプション) - ファイル id の配列isSelectedboolean (オプション) - 現在選択されているファイルisUntaggedboolean (オプション) - 未タグ付けisUnfiledboolean (オプション) - 未分類keywordsstring[] (オプション) - キーワードを含むtagsstring[] (オプション) - タグを含むfoldersstring[] (オプション) - フォルダを含むextstring (オプション) - 形式annotationstring (オプション) - 注釈ratingInteger (オプション) - 評価,0〜5urlstring (オプション) - ソースリンクshapestring (オプション) - 形状,square、portrait、panoramic-portrait、landscape、panoramic-landscapefieldsstring[] (オプション) - 返すフィールドを指定し、必要なデータのみを返すことでパフォーマンスを向上
返り値
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"
});
// 特定のフィールドのみを取得してパフォーマンスを向上
let itemsWithFields = await eagle.item.get({
tags: ["Design"],
fields: ["id", "name", "tags", "modifiedAt"]
});getAll()
全てのファイルを返す
返り値
Promise<items: Item[]>-items全てのファイル
let items = await eagle.item.getAll();
console.log(items);🦄 ベストプラクティス: リソースリポジトリのファイル数が非常に多い場合(例:20万件以上)、無制限にこのメソッドを呼び出さないでください。アプリケーションのパフォーマンスが低下する可能性があります。
getById(itemId)
指定のIDのファイルを返す
itemIdstring返り値
Promise<item: Item>-item該当IDのファイル
let item = await eagle.item.getById('item_id');
console.log(item);getByIds(itemIds)
指定されたIDのファイルを返す
itemIdsstring[]返り値
Promise<items: Item[]>-items該当IDのファイル
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);count(options)
指定した検索条件に一致するファイルの数を返す
optionsObject - 検索条件idstring (オプション) - ファイル ididsstring[] (オプション) - ファイル id の配列isSelectedboolean (オプション) - 現在選択されているファイルisUntaggedboolean (オプション) - 未タグ付けisUnfiledboolean (オプション) - 未分類keywordsstring[] (オプション) - キーワードを含むtagsstring[] (オプション) - タグを含むfoldersstring[] (オプション) - フォルダを含むextstring (オプション) - 形式annotationstring (オプション) - 注釈ratingInteger (オプション) - 評価,0〜5urlstring (オプション) - ソースリンクshapestring (オプション) - 形状,square、portrait、panoramic-portrait、landscape、panoramic-landscape
返り値
Promise<count: number>-count検索条件に一致するファイルの数
// 特定のタグを持つファイルの数を計算
let tagCount = await eagle.item.count({
tags: ["design", "ui"]
});
// JPG形式のファイルの数を計算
let jpgCount = await eagle.item.count({
ext: "jpg"
});
// 選択されたファイルの数を計算
let selectedCount = await eagle.item.count({
isSelected: true
});
console.log(`選択されたファイル数: ${selectedCount}`);🦄 ベストプラクティス: このメソッドはパフォーマンスが最適化されており、大量のファイルが含まれるリソースリポジトリでも効率的に動作します。ファイルの実際の内容を読み込まず、数のみを計算するため、高速に結果を取得できます。
countAll()
リソースリポジトリ内の全ファイル数を返す
返り値
Promise<count: number>-count全ファイル数
let totalCount = await eagle.item.countAll();
console.log(`総ファイル数: ${totalCount}`);🦄 ベストプラクティス: このメソッドは getAll() よりもパフォーマンスが優れており、大量のファイルを含むリソースリポジトリで使用する際に推奨されます。ファイルの内容を読み込まず、数のみを計算するため、メモリ使用量を抑えることができます。
countSelected()
現在選択されているファイルの数を返す
返り値
Promise<count: number>-count選択されたファイル数
let selectedCount = await eagle.item.countSelected();
console.log(`選択されたファイル数: ${selectedCount}`);
// 選択されたファイル数に基づいて処理を分岐
if (selectedCount > 0) {
console.log(`${selectedCount}個のファイルが選択されています`);
} else {
console.log("ファイルが選択されていません");
}🦄 ベストプラクティス: このメソッドは getSelected() の軽量版で、選択されたファイルの詳細情報が不要で数のみを知りたい場合に使用することで、パフォーマンスを向上させることができます。
fields パラメータを使用すると、特に大量のファイルを処理する際に一部の情報のみが必要な場合、パフォーマンスが大幅に向上します。
select(itemIds)
指定されたファイルを選択する
itemIdsstring[] - 選択するファイルIDの配列返り値
Promise<result: boolean>-result選択が成功したかどうか
// 単一ファイルを選択
await eagle.item.select(['ITEM_ID_1']);
// 複数ファイルを選択
await eagle.item.select(['ITEM_ID_1', 'ITEM_ID_2', 'ITEM_ID_3']);
// 選択をクリア
await eagle.item.select([]);getIdsWithModifiedAt()
すべてのファイルの ID と最終更新時刻を高速に取得
返り値
Promise<items: Object[]>-idとmodifiedAtを含むオブジェクトの配列
// すべてのファイルの ID と更新時刻を取得
let idsWithTimestamps = await eagle.item.getIdsWithModifiedAt();
console.log(idsWithTimestamps);
// [{ id: "item_1", modifiedAt: 1640995200000 }, { id: "item_2", modifiedAt: 1640995300000 }, ...]
// 増分同期用例:最後の同期以降に更新されたファイルを取得
let lastSyncTime = 1640995000000;
let updatedItems = idsWithTimestamps.filter(item => item.modifiedAt > lastSyncTime);
console.log(`${updatedItems.length}個のファイルが更新されました`);
// 更新されたファイルの完全な情報を取得
if (updatedItems.length > 0) {
let updatedIds = updatedItems.map(item => item.id);
let fullItems = await eagle.item.getByIds(updatedIds);
console.log(fullItems);
}🦄 ベストプラクティス: このメソッドはファイル ID と更新時刻の取得に特化して最適化されており、get() メソッドで完全なデータを取得するよりもはるかに高速です。増分同期やファイル変更の監視に最適です。
addFromURL(url, options)
画像リンクを Eagle に追加する
urlstring - 追加したい画像リンク。http、https、base64に対応。optionsObjectnamestring (オプション) - ファイル名websitestring (オプション) - 送信元のサイトtagsstring[] (オプション) - タグfoldersstring[] (オプション) - 所属フォルダの IDsannotationstring (オプション) - 注釈
返り値
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形式の画像optionsObjectnamestring (オプション) - ファイル名websitestring (オプション) - 送信元のサイトtagsstring[] (オプション) - タグfoldersstring[] (オプション) - 所属フォルダの IDsannotationstring (オプション) - 注釈
返り値
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 - 欲添加文件路径optionsObjectnamestring (可选) - 文件名websitestring (可选) - 来源网址tagsstring[] (可选) - 标签foldersstring[] (可选) - 所属文件夹 IDsannotationstring (可选) - 注释
返回
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 - 欲添加书签链接optionsObjectnamestring (可选) - 书签名base64string (可选) - 自订缩图 base64 格式tagsstring[] (可选) - 标签foldersstring[] (可选) - 所属文件夹 IDsannotationstring (可选) - 注释
返回
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, options)
すべてのリストに itemId に対応するファイルを表示する
itemIdstring - 表示するファイルIDoptionsObject (オプション) - 開くオプションwindowboolean (オプション) - 新しいウィンドウでファイルを開くかどうか、デフォルトはfalse
戻り値
Promise<result:boolean>
// 現在のウィンドウで開く
await eagle.item.open("item_id");
// 新しいウィンドウで開く
await eagle.item.open("item_id", { window: true });クラス: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() メソッドを使用して置き換えることが、より確実な方法です。
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(options)
このファイルをすべてのリストに表示する
optionsObject (オプション) - 開くオプションwindowboolean (オプション) - 新しいウィンドウでファイルを開くかどうか、デフォルトはfalse
戻り値
Promise<void>
let item = await eagle.item.getById('item_id');
// 現在のウィンドウで開く
await item.open();
// 新しいウィンドウで開く
await item.open({ window: true });
// 等価
await eagle.item.open('item_id');
await eagle.item.open('item_id', { window: true });select()
このファイルを選択する
戻り値
Promise<result: boolean>-result選択が成功したかどうか
let item = await eagle.item.getById('item_id');
await item.select();
// 等価
await eagle.item.select([item.id]);インスタンス属性
id string
id string読み取り専用、ファイルID。
name string
name stringファイル名。
ext string
ext string読み取り専用、ファイル拡張子。
width Interger
width Interger画像の幅。
height Interger
height Interger画像の高さ。
url string
url string出典リンク。
isDeleted boolean
isDeleted boolean読み取り専用、ファイルがゴミ箱に入っているかどうか。
annotation string
annotation stringファイルの注釈。
tags string[]
tags string[]ファイルのタグ。
folders string[]
folders string[]所属フォルダの ids。
palettes Object[]
palettes Object[]読み取り専用、カラーパレット情報。
size Interger
size Interger読み取り専用、ファイルサイズ。
star Interger
star Interger評価情報、0 ~ 5。
importedAt Interger
importedAt Interger読み取り専用、追加された時間。
let date = new Date(item.importedAt);modifiedAt Interger
modifiedAt Interger読み取り専用、最終更新時刻。
let modifiedDate = new Date(item.modifiedAt);
console.log(`ファイルは ${modifiedDate.toLocaleString()} に更新されました`);
// ファイルが最近更新されたかチェック
let hourAgo = Date.now() - (60 * 60 * 1000);
if (item.modifiedAt > hourAgo) {
console.log("このファイルは1時間以内に更新されました");
}noThumbnail boolean
noThumbnail boolean読み取り専用、ファイルにサムネイルがないかどうか。サムネイルがないファイルは、元のファイルでのプレビューになります。
noPreview boolean
noPreview boolean読み取り専用、ファイルがダブルクリックでプレビューに対応しているかどうか。
filePath string
filePath string読み取り専用、ファイルのパスを返します。
fileURL string
fileURL string読み取り専用、ファイルのパスのリンク(file:///)を返します。
thumbnailPath string
thumbnailPath string読み取り専用、サムネイルのパスを返します。
thumbnailURL string
thumbnailURL string読み取り専用、サムネイルのリンク(file:///)を返します。HTMLでこのファイルを表示するには、この属性を使用します。
metadataFilePathstring
metadataFilePathstring読み取り専用、このファイルの metadata.json の場所。
🦄 ベストプラクティス: データの安全性を確保するために、item APIが提供する save() メソッドを使用してデータの読み書きと変更を行ってください。metadata.jsonを直接変更しないでください。
最終更新