From 2f10f57f667f5fac015debcc5fb304b65d5952d2 Mon Sep 17 00:00:00 2001 From: Fabian Schuh Date: Tue, 5 Dec 2023 20:29:53 +0100 Subject: [PATCH] fix: incorporate requested changes from review --- manifest.json | 1 - src/main.ts | 45 ++++++++++++++++++++++++--------------------- 2 files changed, 24 insertions(+), 22 deletions(-) diff --git a/manifest.json b/manifest.json index f68aa4a..941e0c3 100644 --- a/manifest.json +++ b/manifest.json @@ -7,6 +7,5 @@ "author": "xeroc", "authorUrl": "https://chainsquad.com", "fundingUrl": "https://www.buymeacoffee.com/fabian.schuh", - "repo": "relay-md/relay-md-obsidian-plugin", "isDesktopOnly": false } diff --git a/src/main.ts b/src/main.ts index 02be675..288e54d 100644 --- a/src/main.ts +++ b/src/main.ts @@ -9,6 +9,7 @@ import { requestUrl, TFile, TAbstractFile, + TFolder, normalizePath } from 'obsidian'; @@ -43,8 +44,8 @@ export default class RelayMdPLugin extends Plugin { }); this.addCommand({ - id: "relay-md-send-current-active-file", - name: "Relay.md: Send current open file", + id: "send-current-active-file", + name: "Send current open file", callback: async () => { new Notice("Sending document to relay.md"); const activeFile = this.app.workspace.getActiveFile(); @@ -53,8 +54,8 @@ export default class RelayMdPLugin extends Plugin { }); this.addCommand({ - id: "relay-md-fetch-documents", - name: "Relay.md: Retreive recent files", + id: "fetch-documents", + name: "Retreive recent files", callback: async () => { new Notice("Retreiving documents from relay.md"); await this.get_recent_documents(); @@ -62,16 +63,16 @@ export default class RelayMdPLugin extends Plugin { }); // We look into all documents that are modified - this.app.vault.on('modify', (file: TAbstractFile) => { + this.registerEvent(this.app.vault.on('modify', (file: TAbstractFile) => { if(file instanceof TFile) { this.send_document(file); } - }); - this.app.vault.on('create', (file: TAbstractFile) => { + })); + this.registerEvent(this.app.vault.on('create', (file: TAbstractFile) => { if(file instanceof TFile) { this.send_document(file); } - }); + })); // Additionally, we register a timer to fetch documents for us @@ -95,19 +96,21 @@ export default class RelayMdPLugin extends Plugin { } async upsert_document(folder: string, filename: string, body: string) { - // FIXME: There is no way to check if a folder exists, so we just try create them - folder.split('/').reduce( - (directories, directory) => { - directories += `${directory}/`; - try { - this.app.vault.createFolder(directories); - } catch(e) { - // do nothing - } - return directories; - }, - '', - ); + // Does the folder exist? If not, create it "recusrively" + if (!(this.app.vault.getAbstractFileByPath(folder) instanceof TFolder)) { + folder.split('/').reduce( + (directories, directory) => { + directories += `${directory}/`; + try { + this.app.vault.createFolder(directories); + } catch(e) { + // do nothing + } + return directories; + }, + '', + ); + } const full_path_to_file = normalizePath(folder + "/" + filename); const fileRef = this.app.vault.getAbstractFileByPath(full_path_to_file); if(fileRef === undefined || fileRef === null) {