Access Clipy From Node.js
English | 日本語
Clipy is a Clipboard extension app for macOS. This package allow developers access Clipy's folders and snippets using Node.js.
It also provides TypeScript API and all tests are written by TypeScript.
[Attention] This package will access Clipy's Realm Database directly, so you may need to restart Clipy App if snippets updated.
- MacOS 10.10 and over
- Clipy v1.2.0 and over
- Node.js v8.9.0 and < v12 (Why?)
Use the package manager npm to install.
npm i clipy-mate-core
const ClipyMate = require('clipy-mate-core');
const clipy = new ClipyMate();
import ClipyMate from 'clipy-mate-core'
const clipy: ClipyMate = new ClipyMate();
// Read all Folders and Snippets
clipy.readSnippets().then((folders) => {
console.log(folders);
console.log(folders[0].snippets);
});
// Parse `snippet.xml`
const fs = require('fs');
clipy.parseXml(fs.readFileSync('./snippet.xml')).then((folders) => {
console.log(folders);
console.log(folders[0].snippets);
});
// Create or Update a folder
// it will update a folder has same `identifier` field
// or create a new folder if `identifier` is blank or not found
clipy.upsertFolder({ title: 'test folder' }).then(folder => {
console.log(folder.identifier);
});
// Create or Update a snippet inside a folder
// it will update a snippet has same `identifier` field
// or create a new snippet if `identifier` is blank or not found
const folder = clipy.CPYFolder[0];
const folderId = folder.identifier;
clipy.upsertSnippet({ title: 'test snippet', content: 'test' }, folderId).then(snippet => {
console.log(snippet.identifier);
});
// Destroy a specific folder (All snippets in this folder will also be destroyed)
const folder = clipy.CPYFolder[0];
const folderId = folder.identifier;
clipy.destroyFolder(snippetId).then(folder => {
console.log(folder);
});
// Destroy a specific snippet
const snippet = clipy.CPYSnippet[0];
const snippetId = snippet.identifier;
clipy.destroySnippet(snippetId).then(snippet => {
console.log(snippet);
});
// [Danger!] Destroy all folders and snippets
clipy.clearAllSnippets().then();
// After all
clipy.disconnect();
Pull requests are welcome. For major changes, please open an issue first to discuss what you would like to change.
Please make sure to update tests as appropriate.