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

メソッド

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 Integer (オプション) - 評価, 0〜5

    • url string (オプション) - ソースリンク

    • shape string (オプション) - 形状, squareportraitpanoramic-portraitlandscapepanoramic-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);

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 (オプション) - ファイル id

    • ids 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 (オプション) - 形状, squareportraitpanoramic-portraitlandscapepanoramic-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}`);

countSelected()

現在選択されているファイルの数を返す

  • 返り値 Promise<count: number> - count 選択されたファイル数

let selectedCount = await eagle.item.countSelected();
console.log(`選択されたファイル数: ${selectedCount}`);

// 選択されたファイル数に基づいて処理を分岐
if (selectedCount > 0) {
    console.log(`${selectedCount}個のファイルが選択されています`);
} else {
    console.log("ファイルが選択されていません");
}

fields パラメータを使用すると、特に大量のファイルを処理する際に一部の情報のみが必要な場合、パフォーマンスが大幅に向上します。

ヒント:fields パラメータは Eagle 4.0 build12 以降のバージョンが必要です。


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([]);

ヒント:このメソッドを呼び出すと、現在の選択状態が置き換えられます(既存の選択項目に追加するのではありません)。

ヒント:select() メソッドは Eagle 4.0 build12 以降のバージョンが必要です。

getIdsWithModifiedAt()

すべてのファイルの ID と最終更新時刻を高速に取得

  • 返り値 Promise<items: Object[]> - idmodifiedAt を含むオブジェクトの配列

// すべてのファイルの 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);
}

ヒント:getIdsWithModifiedAt() メソッドは Eagle 4.0 build12 以降のバージョンが必要です。

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, options)

すべてのリストに itemId に対応するファイルを表示する

  • itemIdstring - 表示するファイルID

  • options Object (オプション) - 開くオプション

    • window boolean (オプション) - 新しいウィンドウでファイルを開くかどうか、デフォルトは false

  • 戻り値 Promise<result:boolean>

// 現在のウィンドウで開く
await eagle.item.open("item_id");

// 新しいウィンドウで開く
await eagle.item.open("item_id", { window: true });

ヒント:window パラメータは Eagle 4.0 build12 以降のバージョンが必要です。

ヒント:ファイルを開くために、itemインスタンスの open() メソッドを直接呼び出すこともできます。

クラス:Item

Eagle API getによって返されるObjectタイプで、変更および保存機能を提供します。

インスタンスメソッド

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()を再度呼び出す必要はありません。

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

このファイルをすべてのリストに表示する

  • options Object (オプション) - 開くオプション

    • window boolean (オプション) - 新しいウィンドウでファイルを開くかどうか、デフォルトは false

  • 戻り値 Promise<void>

ヒント:ファイルを開くために、eagle.item.open(itemId, options) メソッドを直接呼び出すこともできます。

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 });

ヒント:window パラメータは Eagle 4.0 build12 以降のバージョンが必要です。


select()

このファイルを選択する

  • 戻り値 Promise<result: boolean> - result 選択が成功したかどうか

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

// 等価
await eagle.item.select([item.id]);

ヒント:インスタンスメソッド select() を呼び出すと、現在の選択がクリアされ、このファイルのみが選択されます。複数のファイルを一括選択する場合は、静的メソッド eagle.item.select(itemIds) を使用してください。

ヒント:select() メソッドは Eagle 4.0 build12 以降のバージョンが必要です。

インスタンス属性

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

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

読み取り専用、ファイルにサムネイルがないかどうか。サムネイルがないファイルは、元のファイルでのプレビューになります。

noPreview boolean

読み取り専用、ファイルがダブルクリックでプレビューに対応しているかどうか。

filePath string

読み取り専用、ファイルのパスを返します。

fileURL string

読み取り専用、ファイルのパスのリンク(file:///)を返します。

thumbnailPath string

読み取り専用、サムネイルのパスを返します。

thumbnailURL string

読み取り専用、サムネイルのリンク(file:///)を返します。HTMLでこのファイルを表示するには、この属性を使用します。

metadataFilePathstring

読み取り専用、このファイルの metadata.json の場所。

最終更新