From b44ec1eebea94d50c03fbc8928c0244a05247039 Mon Sep 17 00:00:00 2001 From: Ross Keenan Date: Thu, 21 Oct 2021 11:51:44 +0200 Subject: [PATCH] feat: :sparkles: Notice if no next instance is found --- main.js | 27 +++++++++++++++------------ main.ts | 31 +++++++++++++++---------------- 2 files changed, 30 insertions(+), 28 deletions(-) diff --git a/main.js b/main.js index 3aa7e32..93a1da0 100644 --- a/main.js +++ b/main.js @@ -87,32 +87,35 @@ var MyPlugin = class extends import_obsidian2.Plugin { this.addSettingTab(new SettingTab(this.app, this)); }); } - selectNextInstance(editor) { + selectNextInstance(editor, appendQ = false) { return __async(this, null, function* () { const currFile = this.app.workspace.getActiveFile(); const content = yield this.app.vault.read(currFile); const currSelection = editor.getSelection(); const currPos = editor.getCursor("to"); - console.log({ content, currSelection, currPos }); - const currSelections = editor.listSelections(); const currOffset = editor.posToOffset(currPos); const nextI = content.indexOf(currSelection, currOffset); - console.log({ currOffset, nextI }); + console.log({ currSelection, currOffset, nextI }); if (nextI > -1) { - const ch = nextI; const { line } = currPos; const anchor = { - ch, + ch: nextI, line }; const head = { - ch: ch + currSelection.length, + ch: nextI + currSelection.length, line }; - currSelections.push({ anchor, head }); - console.log({ anchor, head, currSelections }); - editor.setSelections([{ anchor, head }]); - console.log(editor.listSelections()); + if (appendQ) { + const currSelections = editor.listSelections(); + currSelections.push({ anchor, head }); + console.log(editor.listSelections()); + } else { + editor.setSelections([{ anchor, head }]); + } + console.log({ anchor, head }); + } else { + new import_obsidian2.Notice(`Cannot find next instance of ${currSelection}`); } }); } @@ -228,4 +231,4 @@ var CursorsModal = class extends import_obsidian2.Modal { contentEl.empty(); } }; -//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["main.ts", "SampleSettingTab.ts"],
  "sourcesContent": ["import {\r\n\tApp,\r\n\tEditor,\r\n\tEditorPosition,\r\n\tEditorRange,\r\n\tEditorSelectionOrCaret,\r\n\tModal,\r\n\tNotice,\r\n\tPlugin,\r\n\tView,\r\n} from \"obsidian\";\r\nimport { SettingTab } from \"./SampleSettingTab\";\r\n\r\ninterface Settings {\r\n\tmySetting: string;\r\n}\r\n\r\nconst DEFAULT_SETTINGS: Settings = {\r\n\tmySetting: \"default\",\r\n};\r\n\r\nexport default class MyPlugin extends Plugin {\r\n\tsettings: Settings;\r\n\r\n\tasync onload() {\r\n\t\tconsole.log(\"Loading advanced cursors\");\r\n\r\n\t\tawait this.loadSettings();\r\n\r\n\t\tthis.addCommand({\r\n\t\t\tid: \"open-sample-modal-simple\",\r\n\t\t\tname: \"Open sample modal (simple)\",\r\n\t\t\teditorCallback: (editor: Editor, view: View) => {\r\n\t\t\t\tnew CursorsModal(this.app, editor).open();\r\n\t\t\t},\r\n\t\t});\r\n\r\n\t\tthis.addCommand({\r\n\t\t\tid: \"move-to-next-match\",\r\n\t\t\tname: \"Move to next instance of current selection\",\r\n\t\t\teditorCallback: async (editor: Editor) => {\r\n\t\t\t\tthis.selectNextInstance(editor);\r\n\t\t\t},\r\n\t\t});\r\n\t\tthis.addSettingTab(new SettingTab(this.app, this));\r\n\t}\r\n\r\n\tasync selectNextInstance(editor: Editor) {\r\n\t\tconst currFile = this.app.workspace.getActiveFile();\r\n\t\tconst content = await this.app.vault.read(currFile);\r\n\r\n\t\tconst currSelection = editor.getSelection();\r\n\t\tconst currPos = editor.getCursor(\"to\");\r\n\r\n\t\tconsole.log({ content, currSelection, currPos });\r\n\r\n\t\tconst currSelections: EditorSelectionOrCaret[] =\r\n\t\t\teditor.listSelections();\r\n\t\tconst currOffset = editor.posToOffset(currPos);\r\n\r\n\t\t// const slice = content.slice(currOffset);\r\n\r\n\t\tconst nextI = content.indexOf(currSelection, currOffset);\r\n\r\n\t\tconsole.log({ currOffset, nextI });\r\n\r\n\t\tif (nextI > -1) {\r\n\t\t\tconst ch = nextI;\r\n\t\t\tconst { line } = currPos;\r\n\t\t\tconst anchor: EditorPosition = {\r\n\t\t\t\tch,\r\n\t\t\t\tline,\r\n\t\t\t};\r\n\t\t\tconst head: EditorPosition = {\r\n\t\t\t\tch: ch + currSelection.length,\r\n\t\t\t\tline,\r\n\t\t\t};\r\n\r\n\t\t\tcurrSelections.push({ anchor, head });\r\n\t\t\tconsole.log({ anchor, head, currSelections });\r\n\r\n\t\t\teditor.setSelections([{ anchor, head }]);\r\n\t\t\tconsole.log(editor.listSelections());\r\n\t\t}\r\n\t}\r\n\r\n\tonunload() {}\r\n\r\n\tasync loadSettings() {\r\n\t\tthis.settings = Object.assign(\r\n\t\t\t{},\r\n\t\t\tDEFAULT_SETTINGS,\r\n\t\t\tawait this.loadData()\r\n\t\t);\r\n\t}\r\n\r\n\tasync saveSettings() {\r\n\t\tawait this.saveData(this.settings);\r\n\t}\r\n}\r\n\r\nclass CursorsModal extends Modal {\r\n\teditor: Editor;\r\n\tregexQ: boolean;\r\n\r\n\tconstructor(app: App, editor: Editor) {\r\n\t\tsuper(app);\r\n\t\tthis.editor = editor;\r\n\t\tthis.regexQ = true;\r\n\t}\r\n\r\n\tasync getSelectionAndOffset() {\r\n\t\tconst selection = this.editor.getSelection();\r\n\t\tconst offset = this.editor.getCursor(\"from\").line;\r\n\t\tif (selection !== \"\") {\r\n\t\t\treturn { selection, offset };\r\n\t\t} else {\r\n\t\t\tconst currFile = this.app.workspace.getActiveFile();\r\n\t\t\tconst content = await this.app.vault.cachedRead(currFile);\r\n\t\t\treturn { selection: content, offset: 0 };\r\n\t\t}\r\n\t}\r\n\r\n\tgetSelectionsFromQuery(\r\n\t\tcontent: string,\r\n\t\toffset: number,\r\n\t\tquery: string,\r\n\t\tregexQ: boolean\r\n\t) {\r\n\t\tlet regex: RegExp;\r\n\t\tif (regexQ) {\r\n\t\t\tregex = new RegExp(query, \"g\");\r\n\t\t} else {\r\n\t\t\tregex = new RegExp(\r\n\t\t\t\tquery.replace(/[-\\/\\\\^$*+?.()|[\\]{}]/g, \"\\\\$&\"),\r\n\t\t\t\t\"g\"\r\n\t\t\t);\r\n\t\t}\r\n\r\n\t\tconst lines = content.split(\"\\n\");\r\n\t\tconst selections: EditorSelectionOrCaret[] = [];\r\n\r\n\t\tlines.forEach((line, i) => {\r\n\t\t\tconst matches = line.matchAll(regex);\r\n\t\t\tconst matchesArr = [...matches];\r\n\r\n\t\t\tmatchesArr.forEach((matchArr) => {\r\n\t\t\t\tconst from = matchArr.index;\r\n\t\t\t\tif (from !== undefined) {\r\n\t\t\t\t\tconst anchor: EditorPosition = {\r\n\t\t\t\t\t\tch: from,\r\n\t\t\t\t\t\tline: i + offset,\r\n\t\t\t\t\t};\r\n\t\t\t\t\tconst head: EditorPosition = {\r\n\t\t\t\t\t\tch: from + matchArr[0].length,\r\n\t\t\t\t\t\tline: i + offset,\r\n\t\t\t\t\t};\r\n\t\t\t\t\tselections.push({ anchor, head });\r\n\t\t\t\t}\r\n\t\t\t});\r\n\t\t});\r\n\r\n\t\treturn selections;\r\n\t}\r\n\r\n\tasync onOpen() {\r\n\t\tlet { contentEl } = this;\r\n\r\n\t\tconst { selection, offset } = await this.getSelectionAndOffset();\r\n\t\tconsole.log({ selection });\r\n\r\n\t\tconst inputDiv = contentEl.createDiv({ cls: \"inputDiv\" });\r\n\r\n\t\tconst inputEl = inputDiv.createEl(\"input\", {\r\n\t\t\ttype: \"text\",\r\n\t\t\ttitle: \"Search Query\",\r\n\t\t\tattr: { placeholder: \"Search Query\" },\r\n\t\t});\r\n\t\tinputEl.focus();\r\n\r\n\t\tconst submitButton = inputDiv.createEl(\r\n\t\t\t\"input\",\r\n\t\t\t{\r\n\t\t\t\ttype: \"submit\",\r\n\t\t\t\ttext: \"submit\",\r\n\t\t\t},\r\n\t\t\t(submitEl) => {\r\n\t\t\t\tsubmitEl.addEventListener(\"click\", async () => {\r\n\t\t\t\t\ttry {\r\n\t\t\t\t\t\tconst query = inputEl.value;\r\n\t\t\t\t\t\tconsole.log(this.regexQ);\r\n\t\t\t\t\t\tconst selections = this.getSelectionsFromQuery(\r\n\t\t\t\t\t\t\tselection,\r\n\t\t\t\t\t\t\toffset,\r\n\t\t\t\t\t\t\tquery,\r\n\t\t\t\t\t\t\tthis.regexQ\r\n\t\t\t\t\t\t);\r\n\r\n\t\t\t\t\t\tconsole.log({ selections });\r\n\t\t\t\t\t\tnew Notice(`${selections.length} matches found.`);\r\n\r\n\t\t\t\t\t\tthis.editor.setSelections(selections);\r\n\t\t\t\t\t\tthis.close();\r\n\t\t\t\t\t} catch (error) {\r\n\t\t\t\t\t\tconsole.log(error);\r\n\t\t\t\t\t\tnew Notice(\r\n\t\t\t\t\t\t\t\"Something went wrong, check the console for the error.\"\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\t}\r\n\t\t\t\t});\r\n\t\t\t}\r\n\t\t);\r\n\r\n\t\tconst optionsDiv = contentEl.createDiv({ cls: \"optionsDiv\" });\r\n\r\n\t\toptionsDiv.createEl(\r\n\t\t\t\"input\",\r\n\t\t\t{\r\n\t\t\t\ttype: \"checkbox\",\r\n\t\t\t\tattr: { name: \"regexQ\", checked: this.regexQ },\r\n\t\t\t},\r\n\t\t\t(regexQInput) => {\r\n\t\t\t\tregexQInput.addEventListener(\"change\", () => {\r\n\t\t\t\t\tthis.regexQ = regexQInput.checked;\r\n\t\t\t\t});\r\n\t\t\t}\r\n\t\t);\r\n\t\toptionsDiv.createEl(\"label\", {\r\n\t\t\ttext: \"Regex?\",\r\n\t\t\tattr: { for: \"regexQ\" },\r\n\t\t});\r\n\t}\r\n\r\n\tonClose() {\r\n\t\tlet { contentEl } = this;\r\n\t\tcontentEl.empty();\r\n\t}\r\n}\r\n", "import { App, PluginSettingTab, Setting } from \"obsidian\";\r\nimport MyPlugin from \"./main\";\r\n\r\nexport class SettingTab extends PluginSettingTab {\r\n\tplugin: MyPlugin;\r\n\r\n\tconstructor(app: App, plugin: MyPlugin) {\r\n\t\tsuper(app, plugin);\r\n\t\tthis.plugin = plugin;\r\n\t}\r\n\r\n\tdisplay(): void {\r\n\t\tlet { containerEl } = this;\r\n\r\n\t\tcontainerEl.empty();\r\n\r\n\t\t// containerEl.createEl(\"h2\", { text: \"Settings for my awesome plugin.\" });\r\n\r\n\t\t// new Setting(containerEl)\r\n\t\t// \t.setName(\"Setting #1\")\r\n\t\t// \t.setDesc(\"It's a secret\")\r\n\t\t// \t.addText((text) => text\r\n\t\t// \t\t.setPlaceholder(\"Enter your secret\")\r\n\t\t// \t\t.setValue(this.plugin.settings.mySetting)\r\n\t\t// \t\t.onChange(async (value) => {\r\n\t\t// \t\t\tconsole.log(\"Secret: \" + value);\r\n\t\t// \t\t\tthis.plugin.settings.mySetting = value;\r\n\t\t// \t\t\tawait this.plugin.saveSettings();\r\n\t\t// \t\t})\r\n\t\t// \t);\r\n\t}\r\n}\r\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA,uBAUO;;;ACVP,sBAA+C;AAGxC,+BAAyB,iCAAiB;AAAA,EAGhD,YAAY,KAAU,QAAkB;AACvC,UAAM,KAAK;AACX,SAAK,SAAS;AAAA;AAAA,EAGf,UAAgB;AACf,QAAI,EAAE,gBAAgB;AAEtB,gBAAY;AAAA;AAAA;;;ADGd,IAAM,mBAA6B;AAAA,EAClC,WAAW;AAAA;AAGZ,6BAAsC,wBAAO;AAAA,EAGtC,SAAS;AAAA;AACd,cAAQ,IAAI;AAEZ,YAAM,KAAK;AAEX,WAAK,WAAW;AAAA,QACf,IAAI;AAAA,QACJ,MAAM;AAAA,QACN,gBAAgB,CAAC,QAAgB,SAAe;AAC/C,cAAI,aAAa,KAAK,KAAK,QAAQ;AAAA;AAAA;AAIrC,WAAK,WAAW;AAAA,QACf,IAAI;AAAA,QACJ,MAAM;AAAA,QACN,gBAAgB,CAAO,WAAmB;AACzC,eAAK,mBAAmB;AAAA;AAAA;AAG1B,WAAK,cAAc,IAAI,WAAW,KAAK,KAAK;AAAA;AAAA;AAAA,EAGvC,mBAAmB,QAAgB;AAAA;AACxC,YAAM,WAAW,KAAK,IAAI,UAAU;AACpC,YAAM,UAAU,MAAM,KAAK,IAAI,MAAM,KAAK;AAE1C,YAAM,gBAAgB,OAAO;AAC7B,YAAM,UAAU,OAAO,UAAU;AAEjC,cAAQ,IAAI,EAAE,SAAS,eAAe;AAEtC,YAAM,iBACL,OAAO;AACR,YAAM,aAAa,OAAO,YAAY;AAItC,YAAM,QAAQ,QAAQ,QAAQ,eAAe;AAE7C,cAAQ,IAAI,EAAE,YAAY;AAE1B,UAAI,QAAQ,IAAI;AACf,cAAM,KAAK;AACX,cAAM,EAAE,SAAS;AACjB,cAAM,SAAyB;AAAA,UAC9B;AAAA,UACA;AAAA;AAED,cAAM,OAAuB;AAAA,UAC5B,IAAI,KAAK,cAAc;AAAA,UACvB;AAAA;AAGD,uBAAe,KAAK,EAAE,QAAQ;AAC9B,gBAAQ,IAAI,EAAE,QAAQ,MAAM;AAE5B,eAAO,cAAc,CAAC,EAAE,QAAQ;AAChC,gBAAQ,IAAI,OAAO;AAAA;AAAA;AAAA;AAAA,EAIrB,WAAW;AAAA;AAAA,EAEL,eAAe;AAAA;AACpB,WAAK,WAAW,OAAO,OACtB,IACA,kBACA,MAAM,KAAK;AAAA;AAAA;AAAA,EAIP,eAAe;AAAA;AACpB,YAAM,KAAK,SAAS,KAAK;AAAA;AAAA;AAAA;AAI3B,iCAA2B,uBAAM;AAAA,EAIhC,YAAY,KAAU,QAAgB;AACrC,UAAM;AACN,SAAK,SAAS;AACd,SAAK,SAAS;AAAA;AAAA,EAGT,wBAAwB;AAAA;AAC7B,YAAM,YAAY,KAAK,OAAO;AAC9B,YAAM,SAAS,KAAK,OAAO,UAAU,QAAQ;AAC7C,UAAI,cAAc,IAAI;AACrB,eAAO,EAAE,WAAW;AAAA,aACd;AACN,cAAM,WAAW,KAAK,IAAI,UAAU;AACpC,cAAM,UAAU,MAAM,KAAK,IAAI,MAAM,WAAW;AAChD,eAAO,EAAE,WAAW,SAAS,QAAQ;AAAA;AAAA;AAAA;AAAA,EAIvC,uBACC,SACA,QACA,OACA,QACC;AACD,QAAI;AACJ,QAAI,QAAQ;AACX,cAAQ,IAAI,OAAO,OAAO;AAAA,WACpB;AACN,cAAQ,IAAI,OACX,MAAM,QAAQ,0BAA0B,SACxC;AAAA;AAIF,UAAM,QAAQ,QAAQ,MAAM;AAC5B,UAAM,aAAuC;AAE7C,UAAM,QAAQ,CAAC,MAAM,MAAM;AAC1B,YAAM,UAAU,KAAK,SAAS;AAC9B,YAAM,aAAa,CAAC,GAAG;AAEvB,iBAAW,QAAQ,CAAC,aAAa;AAChC,cAAM,OAAO,SAAS;AACtB,YAAI,SAAS,QAAW;AACvB,gBAAM,SAAyB;AAAA,YAC9B,IAAI;AAAA,YACJ,MAAM,IAAI;AAAA;AAEX,gBAAM,OAAuB;AAAA,YAC5B,IAAI,OAAO,SAAS,GAAG;AAAA,YACvB,MAAM,IAAI;AAAA;AAEX,qBAAW,KAAK,EAAE,QAAQ;AAAA;AAAA;AAAA;AAK7B,WAAO;AAAA;AAAA,EAGF,SAAS;AAAA;AACd,UAAI,EAAE,cAAc;AAEpB,YAAM,EAAE,WAAW,WAAW,MAAM,KAAK;AACzC,cAAQ,IAAI,EAAE;AAEd,YAAM,WAAW,UAAU,UAAU,EAAE,KAAK;AAE5C,YAAM,UAAU,SAAS,SAAS,SAAS;AAAA,QAC1C,MAAM;AAAA,QACN,OAAO;AAAA,QACP,MAAM,EAAE,aAAa;AAAA;AAEtB,cAAQ;AAER,YAAM,eAAe,SAAS,SAC7B,SACA;AAAA,QACC,MAAM;AAAA,QACN,MAAM;AAAA,SAEP,CAAC,aAAa;AACb,iBAAS,iBAAiB,SAAS,MAAY;AAC9C,cAAI;AACH,kBAAM,QAAQ,QAAQ;AACtB,oBAAQ,IAAI,KAAK;AACjB,kBAAM,aAAa,KAAK,uBACvB,WACA,QACA,OACA,KAAK;AAGN,oBAAQ,IAAI,EAAE;AACd,gBAAI,wBAAO,GAAG,WAAW;AAEzB,iBAAK,OAAO,cAAc;AAC1B,iBAAK;AAAA,mBACG,OAAP;AACD,oBAAQ,IAAI;AACZ,gBAAI,wBACH;AAAA;AAAA;AAAA;AAOL,YAAM,aAAa,UAAU,UAAU,EAAE,KAAK;AAE9C,iBAAW,SACV,SACA;AAAA,QACC,MAAM;AAAA,QACN,MAAM,EAAE,MAAM,UAAU,SAAS,KAAK;AAAA,SAEvC,CAAC,gBAAgB;AAChB,oBAAY,iBAAiB,UAAU,MAAM;AAC5C,eAAK,SAAS,YAAY;AAAA;AAAA;AAI7B,iBAAW,SAAS,SAAS;AAAA,QAC5B,MAAM;AAAA,QACN,MAAM,EAAE,KAAK;AAAA;AAAA;AAAA;AAAA,EAIf,UAAU;AACT,QAAI,EAAE,cAAc;AACpB,cAAU;AAAA;AAAA;",
  "names": []
}
 +//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["main.ts", "SampleSettingTab.ts"],
  "sourcesContent": ["import {\r\n\tApp,\r\n\tEditor,\r\n\tEditorPosition,\r\n\tEditorRange,\r\n\tEditorSelectionOrCaret,\r\n\tModal,\r\n\tNotice,\r\n\tPlugin,\r\n\tView,\r\n} from \"obsidian\";\r\nimport { SettingTab } from \"./SampleSettingTab\";\r\n\r\ninterface Settings {\r\n\tmySetting: string;\r\n}\r\n\r\nconst DEFAULT_SETTINGS: Settings = {\r\n\tmySetting: \"default\",\r\n};\r\n\r\nexport default class MyPlugin extends Plugin {\r\n\tsettings: Settings;\r\n\r\n\tasync onload() {\r\n\t\tconsole.log(\"Loading advanced cursors\");\r\n\r\n\t\tawait this.loadSettings();\r\n\r\n\t\tthis.addCommand({\r\n\t\t\tid: \"open-sample-modal-simple\",\r\n\t\t\tname: \"Open sample modal (simple)\",\r\n\t\t\teditorCallback: (editor: Editor, view: View) => {\r\n\t\t\t\tnew CursorsModal(this.app, editor).open();\r\n\t\t\t},\r\n\t\t});\r\n\r\n\t\tthis.addCommand({\r\n\t\t\tid: \"move-to-next-match\",\r\n\t\t\tname: \"Move to next instance of current selection\",\r\n\t\t\teditorCallback: async (editor: Editor) => {\r\n\t\t\t\tthis.selectNextInstance(editor);\r\n\t\t\t},\r\n\t\t});\r\n\t\tthis.addSettingTab(new SettingTab(this.app, this));\r\n\t}\r\n\r\n\tasync selectNextInstance(editor: Editor, appendQ = false) {\r\n\t\tconst currFile = this.app.workspace.getActiveFile();\r\n\t\tconst content = await this.app.vault.read(currFile);\r\n\r\n\t\tconst currSelection = editor.getSelection();\r\n\t\tconst currPos = editor.getCursor(\"to\");\r\n\r\n\t\tconst currOffset = editor.posToOffset(currPos);\r\n\r\n\t\tconst nextI = content.indexOf(currSelection, currOffset);\r\n\r\n\t\tconsole.log({ currSelection, currOffset, nextI });\r\n\r\n\t\tif (nextI > -1) {\r\n\t\t\tconst { line } = currPos;\r\n\t\t\tconst anchor: EditorPosition = {\r\n\t\t\t\tch: nextI,\r\n\t\t\t\tline,\r\n\t\t\t};\r\n\t\t\tconst head: EditorPosition = {\r\n\t\t\t\tch: nextI + currSelection.length,\r\n\t\t\t\tline,\r\n\t\t\t};\r\n\r\n\t\t\tif (appendQ) {\r\n\t\t\t\tconst currSelections: EditorSelectionOrCaret[] =\r\n\t\t\t\t\teditor.listSelections();\r\n\t\t\t\tcurrSelections.push({ anchor, head });\r\n\t\t\t\tconsole.log(editor.listSelections());\r\n\t\t\t} else {\r\n\t\t\t\teditor.setSelections([{ anchor, head }]);\r\n\t\t\t}\r\n\t\t\tconsole.log({ anchor, head });\r\n\t\t} else {\r\n\t\t\tnew Notice(`Cannot find next instance of ${currSelection}`);\r\n\t\t}\r\n\t}\r\n\r\n\tonunload() {}\r\n\r\n\tasync loadSettings() {\r\n\t\tthis.settings = Object.assign(\r\n\t\t\t{},\r\n\t\t\tDEFAULT_SETTINGS,\r\n\t\t\tawait this.loadData()\r\n\t\t);\r\n\t}\r\n\r\n\tasync saveSettings() {\r\n\t\tawait this.saveData(this.settings);\r\n\t}\r\n}\r\n\r\nclass CursorsModal extends Modal {\r\n\teditor: Editor;\r\n\tregexQ: boolean;\r\n\r\n\tconstructor(app: App, editor: Editor) {\r\n\t\tsuper(app);\r\n\t\tthis.editor = editor;\r\n\t\tthis.regexQ = true;\r\n\t}\r\n\r\n\tasync getSelectionAndOffset() {\r\n\t\tconst selection = this.editor.getSelection();\r\n\t\tconst offset = this.editor.getCursor(\"from\").line;\r\n\t\tif (selection !== \"\") {\r\n\t\t\treturn { selection, offset };\r\n\t\t} else {\r\n\t\t\tconst currFile = this.app.workspace.getActiveFile();\r\n\t\t\tconst content = await this.app.vault.cachedRead(currFile);\r\n\t\t\treturn { selection: content, offset: 0 };\r\n\t\t}\r\n\t}\r\n\r\n\tgetSelectionsFromQuery(\r\n\t\tcontent: string,\r\n\t\toffset: number,\r\n\t\tquery: string,\r\n\t\tregexQ: boolean\r\n\t) {\r\n\t\tlet regex: RegExp;\r\n\t\tif (regexQ) {\r\n\t\t\tregex = new RegExp(query, \"g\");\r\n\t\t} else {\r\n\t\t\tregex = new RegExp(\r\n\t\t\t\tquery.replace(/[-\\/\\\\^$*+?.()|[\\]{}]/g, \"\\\\$&\"),\r\n\t\t\t\t\"g\"\r\n\t\t\t);\r\n\t\t}\r\n\r\n\t\tconst lines = content.split(\"\\n\");\r\n\t\tconst selections: EditorSelectionOrCaret[] = [];\r\n\r\n\t\tlines.forEach((line, i) => {\r\n\t\t\tconst matches = line.matchAll(regex);\r\n\t\t\tconst matchesArr = [...matches];\r\n\r\n\t\t\tmatchesArr.forEach((matchArr) => {\r\n\t\t\t\tconst from = matchArr.index;\r\n\t\t\t\tif (from !== undefined) {\r\n\t\t\t\t\tconst anchor: EditorPosition = {\r\n\t\t\t\t\t\tch: from,\r\n\t\t\t\t\t\tline: i + offset,\r\n\t\t\t\t\t};\r\n\t\t\t\t\tconst head: EditorPosition = {\r\n\t\t\t\t\t\tch: from + matchArr[0].length,\r\n\t\t\t\t\t\tline: i + offset,\r\n\t\t\t\t\t};\r\n\t\t\t\t\tselections.push({ anchor, head });\r\n\t\t\t\t}\r\n\t\t\t});\r\n\t\t});\r\n\r\n\t\treturn selections;\r\n\t}\r\n\r\n\tasync onOpen() {\r\n\t\tlet { contentEl } = this;\r\n\r\n\t\tconst { selection, offset } = await this.getSelectionAndOffset();\r\n\t\tconsole.log({ selection });\r\n\r\n\t\tconst inputDiv = contentEl.createDiv({ cls: \"inputDiv\" });\r\n\r\n\t\tconst inputEl = inputDiv.createEl(\"input\", {\r\n\t\t\ttype: \"text\",\r\n\t\t\ttitle: \"Search Query\",\r\n\t\t\tattr: { placeholder: \"Search Query\" },\r\n\t\t});\r\n\t\tinputEl.focus();\r\n\r\n\t\tconst submitButton = inputDiv.createEl(\r\n\t\t\t\"input\",\r\n\t\t\t{\r\n\t\t\t\ttype: \"submit\",\r\n\t\t\t\ttext: \"submit\",\r\n\t\t\t},\r\n\t\t\t(submitEl) => {\r\n\t\t\t\tsubmitEl.addEventListener(\"click\", async () => {\r\n\t\t\t\t\ttry {\r\n\t\t\t\t\t\tconst query = inputEl.value;\r\n\t\t\t\t\t\tconsole.log(this.regexQ);\r\n\t\t\t\t\t\tconst selections = this.getSelectionsFromQuery(\r\n\t\t\t\t\t\t\tselection,\r\n\t\t\t\t\t\t\toffset,\r\n\t\t\t\t\t\t\tquery,\r\n\t\t\t\t\t\t\tthis.regexQ\r\n\t\t\t\t\t\t);\r\n\r\n\t\t\t\t\t\tconsole.log({ selections });\r\n\t\t\t\t\t\tnew Notice(`${selections.length} matches found.`);\r\n\r\n\t\t\t\t\t\tthis.editor.setSelections(selections);\r\n\t\t\t\t\t\tthis.close();\r\n\t\t\t\t\t} catch (error) {\r\n\t\t\t\t\t\tconsole.log(error);\r\n\t\t\t\t\t\tnew Notice(\r\n\t\t\t\t\t\t\t\"Something went wrong, check the console for the error.\"\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\t}\r\n\t\t\t\t});\r\n\t\t\t}\r\n\t\t);\r\n\r\n\t\tconst optionsDiv = contentEl.createDiv({ cls: \"optionsDiv\" });\r\n\r\n\t\toptionsDiv.createEl(\r\n\t\t\t\"input\",\r\n\t\t\t{\r\n\t\t\t\ttype: \"checkbox\",\r\n\t\t\t\tattr: { name: \"regexQ\", checked: this.regexQ },\r\n\t\t\t},\r\n\t\t\t(regexQInput) => {\r\n\t\t\t\tregexQInput.addEventListener(\"change\", () => {\r\n\t\t\t\t\tthis.regexQ = regexQInput.checked;\r\n\t\t\t\t});\r\n\t\t\t}\r\n\t\t);\r\n\t\toptionsDiv.createEl(\"label\", {\r\n\t\t\ttext: \"Regex?\",\r\n\t\t\tattr: { for: \"regexQ\" },\r\n\t\t});\r\n\t}\r\n\r\n\tonClose() {\r\n\t\tlet { contentEl } = this;\r\n\t\tcontentEl.empty();\r\n\t}\r\n}\r\n", "import { App, PluginSettingTab, Setting } from \"obsidian\";\r\nimport MyPlugin from \"./main\";\r\n\r\nexport class SettingTab extends PluginSettingTab {\r\n\tplugin: MyPlugin;\r\n\r\n\tconstructor(app: App, plugin: MyPlugin) {\r\n\t\tsuper(app, plugin);\r\n\t\tthis.plugin = plugin;\r\n\t}\r\n\r\n\tdisplay(): void {\r\n\t\tlet { containerEl } = this;\r\n\r\n\t\tcontainerEl.empty();\r\n\r\n\t\t// containerEl.createEl(\"h2\", { text: \"Settings for my awesome plugin.\" });\r\n\r\n\t\t// new Setting(containerEl)\r\n\t\t// \t.setName(\"Setting #1\")\r\n\t\t// \t.setDesc(\"It's a secret\")\r\n\t\t// \t.addText((text) => text\r\n\t\t// \t\t.setPlaceholder(\"Enter your secret\")\r\n\t\t// \t\t.setValue(this.plugin.settings.mySetting)\r\n\t\t// \t\t.onChange(async (value) => {\r\n\t\t// \t\t\tconsole.log(\"Secret: \" + value);\r\n\t\t// \t\t\tthis.plugin.settings.mySetting = value;\r\n\t\t// \t\t\tawait this.plugin.saveSettings();\r\n\t\t// \t\t})\r\n\t\t// \t);\r\n\t}\r\n}\r\n"],
  "mappings": "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",
  "names": []
}
 diff --git a/main.ts b/main.ts index 11e98c0..27f936c 100644 --- a/main.ts +++ b/main.ts @@ -45,42 +45,41 @@ export default class MyPlugin extends Plugin { this.addSettingTab(new SettingTab(this.app, this)); } - async selectNextInstance(editor: Editor) { + async selectNextInstance(editor: Editor, appendQ = false) { const currFile = this.app.workspace.getActiveFile(); const content = await this.app.vault.read(currFile); const currSelection = editor.getSelection(); const currPos = editor.getCursor("to"); - console.log({ content, currSelection, currPos }); - - const currSelections: EditorSelectionOrCaret[] = - editor.listSelections(); const currOffset = editor.posToOffset(currPos); - // const slice = content.slice(currOffset); - const nextI = content.indexOf(currSelection, currOffset); - console.log({ currOffset, nextI }); + console.log({ currSelection, currOffset, nextI }); if (nextI > -1) { - const ch = nextI; const { line } = currPos; const anchor: EditorPosition = { - ch, + ch: nextI, line, }; const head: EditorPosition = { - ch: ch + currSelection.length, + ch: nextI + currSelection.length, line, }; - currSelections.push({ anchor, head }); - console.log({ anchor, head, currSelections }); - - editor.setSelections([{ anchor, head }]); - console.log(editor.listSelections()); + if (appendQ) { + const currSelections: EditorSelectionOrCaret[] = + editor.listSelections(); + currSelections.push({ anchor, head }); + console.log(editor.listSelections()); + } else { + editor.setSelections([{ anchor, head }]); + } + console.log({ anchor, head }); + } else { + new Notice(`Cannot find next instance of ${currSelection}`); } }