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 (オプション) - ファイル idids
string[] (オプション) - ファイル id の配列isSelected
boolean (オプション) - 現在選択されているファイルisUntagged
boolean (オプション) - 未タグ付けisUnfiled
boolean (オプション) - 未分類keywords
string[] (オプション) - キーワードを含むtags
string[] (オプション) - タグを含むfolders
string[] (オプション) - フォルダを含むext
string (オプション) - 形式annotation
string (オプション) - 注釈rating
Integer (オプション) - 評価,0〜5
url
string (オプション) - ソースリンクshape
string (オプション) - 形状,square
、portrait
、panoramic-portrait
、landscape
、panoramic-landscape
fields
string[] (オプション) - 返すフィールドを指定し、必要なデータのみを返すことでパフォーマンスを向上
返り値
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のファイルを返す
itemId
string返り値
Promise<item: Item>
-item
該当IDのファイル
let item = await eagle.item.getById('item_id');
console.log(item);
getByIds(itemIds)
指定されたIDのファイルを返す
itemIds
string[]返り値
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)
指定した検索条件に一致するファイルの数を返す
options
Object - 検索条件id
string (オプション) - ファイル idids
string[] (オプション) - ファイル id の配列isSelected
boolean (オプション) - 現在選択されているファイルisUntagged
boolean (オプション) - 未タグ付けisUnfiled
boolean (オプション) - 未分類keywords
string[] (オプション) - キーワードを含むtags
string[] (オプション) - タグを含むfolders
string[] (オプション) - フォルダを含むext
string (オプション) - 形式annotation
string (オプション) - 注釈rating
Integer (オプション) - 評価,0〜5
url
string (オプション) - ソースリンクshape
string (オプション) - 形状,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)
指定されたファイルを選択する
itemIds
string[] - 選択するファイル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 に追加する
url
string - 追加したい画像リンク。http
、https
、base64
に対応。options
Objectname
string (オプション) - ファイル名website
string (オプション) - 送信元のサイトtags
string[] (オプション) - タグfolders
string[] (オプション) - 所属フォルダの IDsannotation
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
Objectname
string (オプション) - ファイル名website
string (オプション) - 送信元のサイトtags
string[] (オプション) - タグfolders
string[] (オプション) - 所属フォルダの IDsannotation
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
path
string - 欲添加文件路径options
Objectname
string (可选) - 文件名website
string (可选) - 来源网址tags
string[] (可选) - 标签folders
string[] (可选) - 所属文件夹 IDsannotation
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
url
string - 欲添加书签链接options
Objectname
string (可选) - 书签名base64
string (可选) - 自订缩图 base64 格式tags
string[] (可选) - 标签folders
string[] (可选) - 所属文件夹 IDsannotation
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, options)
すべてのリストに itemId
に対応するファイルを表示する
itemId
string - 表示するファイルIDoptions
Object (オプション) - 開くオプションwindow
boolean (オプション) - 新しいウィンドウでファイルを開くかどうか、デフォルトは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()
メソッドを使用して置き換えることが、より確実な方法です。
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(options)
このファイルをすべてのリストに表示する
options
Object (オプション) - 開くオプションwindow
boolean (オプション) - 新しいウィンドウでファイルを開くかどうか、デフォルトは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でこのファイルを表示するには、この属性を使用します。
metadataFilePath
string
metadataFilePath
string読み取り専用、このファイルの metadata.json
の場所。
🦄 ベストプラクティス: データの安全性を確保するために、item
APIが提供する save()
メソッドを使用してデータの読み書きと変更を行ってください。metadata.json
を直接変更しないでください。
最終更新