104 lines
2.6 KiB
TypeScript
104 lines
2.6 KiB
TypeScript
import {
|
|
App,
|
|
Editor,
|
|
MarkdownView,
|
|
Modal,
|
|
Notice,
|
|
Plugin,
|
|
PluginSettingTab,
|
|
Setting,
|
|
WorkspaceLeaf,
|
|
} from "obsidian";
|
|
|
|
import * as plugin from "../../backend/sync_lib/pkg/sync_lib.js";
|
|
import * as wasmBin from "../../backend/sync_lib/pkg/sync_lib_bg.wasm";
|
|
import { SyncSettingsTab } from "./views/settings-tab.js";
|
|
import { SyncView } from "./views/sync-view.js";
|
|
|
|
import { Logger } from "./logger.js";
|
|
import { SyncEventHandler } from "./events/sync-event-handler.js";
|
|
import { SyncServer } from "./services/sync_service.js";
|
|
import { Database } from "./database/database.js";
|
|
|
|
export default class SyncPlugin extends Plugin {
|
|
async onload() {
|
|
Logger.getInstance().info('Starting plugin "Sample Plugin"');
|
|
|
|
await plugin.default(Promise.resolve((wasmBin as any).default));
|
|
|
|
this.addCommand({
|
|
id: "sample-editor-command",
|
|
name: "Sample editor command",
|
|
editorCallback: (editor: Editor, view: MarkdownView) => {
|
|
console.log(editor.getSelection());
|
|
editor.replaceSelection("Sample Editor Command");
|
|
},
|
|
});
|
|
|
|
const database = new Database(
|
|
await this.loadData(),
|
|
this.saveData.bind(this)
|
|
);
|
|
|
|
const syncServer = new SyncServer(database);
|
|
|
|
this.addSettingTab(
|
|
new SyncSettingsTab(this.app, this, database, syncServer)
|
|
);
|
|
|
|
const eventHandler = new SyncEventHandler(database, syncServer);
|
|
|
|
[
|
|
this.app.vault.on(
|
|
"create",
|
|
eventHandler.onCreate.bind(eventHandler)
|
|
),
|
|
this.app.vault.on(
|
|
"modify",
|
|
eventHandler.onModify.bind(eventHandler)
|
|
),
|
|
this.app.vault.on(
|
|
"delete",
|
|
eventHandler.onDelete.bind(eventHandler)
|
|
),
|
|
this.app.vault.on(
|
|
"rename",
|
|
eventHandler.onRename.bind(eventHandler)
|
|
),
|
|
].forEach((event) => this.registerEvent(event));
|
|
|
|
this.registerInterval(
|
|
window.setInterval(() => console.log("setInterval"), 5 * 60 * 1000)
|
|
);
|
|
this.registerView(SyncView.TYPE, (leaf) => new SyncView(leaf));
|
|
|
|
const ribbonIconEl = this.addRibbonIcon(
|
|
"dice",
|
|
"Sample Plugin",
|
|
(_: MouseEvent) => this.activateView()
|
|
);
|
|
ribbonIconEl.addClass("my-plugin-ribbon-class");
|
|
}
|
|
|
|
onunload() {}
|
|
|
|
async activateView() {
|
|
const { workspace } = this.app;
|
|
|
|
let leaf: WorkspaceLeaf | null = null;
|
|
const leaves = workspace.getLeavesOfType(SyncView.TYPE);
|
|
|
|
if (leaves.length > 0) {
|
|
// A leaf with our view already exists, use that
|
|
leaf = leaves[0];
|
|
} else {
|
|
// Our view could not be found in the workspace, create a new leaf
|
|
// in the right sidebar for it
|
|
leaf = workspace.getRightLeaf(false);
|
|
await leaf?.setViewState({ type: SyncView.TYPE, active: true });
|
|
}
|
|
|
|
// "Reveal" the leaf in case it is in a collapsed sidebar
|
|
workspace.revealLeaf(leaf!);
|
|
}
|
|
}
|