commit ac82511ddd17d5472ae3cfea9bbad9754f5a4d62 Author: Simon Cambier <simon.cambier@protonmail.com> Date: Sat Oct 22 08:23:42 2022 +0200 Screw that cache, seriously. commit 8ba40d1be73daaaffea09e07bc56c339266db9b6 Author: Simon Cambier <simon.cambier@protonmail.com> Date: Fri Oct 21 22:36:48 2022 +0200 Stuff commit 27b8fd7dc809be9714a109d3a458eb1276a47e2e Author: Simon Cambier <simon.cambier@protonmail.com> Date: Fri Oct 21 22:22:20 2022 +0200 Moved files commit fb1349c914907e586e103ca54fb04b9ddd45ef5d Author: Simon Cambier <simon.cambier@protonmail.com> Date: Thu Oct 20 22:25:29 2022 +0200 Removed duplicate code commit e7371138e60cbe4155cfd4fb44e3ee1d2e3ee088 Author: Simon Cambier <simon.cambier@protonmail.com> Date: Thu Oct 20 21:50:09 2022 +0200 Moved a bunch of files commit 2ee1b2a0e799d4b41ab3a444d8cc44dfff5b5623 Author: Simon Cambier <simon.cambier@protonmail.com> Date: Thu Oct 20 21:32:21 2022 +0200 Removed useless code commit 76c530dfb9adbad1bbe9079de2330fe43a044249 Author: Simon Cambier <simon.cambier@protonmail.com> Date: Thu Oct 20 20:44:11 2022 +0200 Split file reading and indexing
101 lines
2.6 KiB
TypeScript
101 lines
2.6 KiB
TypeScript
import { type CachedMetadata, MarkdownView, TFile } from 'obsidian'
|
|
import { stringsToRegex } from './utils'
|
|
import type { ResultNote } from '../globals'
|
|
|
|
export async function openNote(
|
|
item: ResultNote,
|
|
newPane = false
|
|
): Promise<void> {
|
|
const reg = stringsToRegex(item.foundWords)
|
|
reg.exec(item.content)
|
|
const offset = reg.lastIndex
|
|
|
|
// Check if the note is already open,
|
|
// to avoid opening it twice if the first one is pinned
|
|
let alreadyOpenAndPinned = false
|
|
app.workspace.iterateAllLeaves(leaf => {
|
|
if (leaf.view instanceof MarkdownView) {
|
|
if (
|
|
!newPane &&
|
|
leaf.getViewState().state?.file === item.path &&
|
|
leaf.getViewState()?.pinned
|
|
) {
|
|
app.workspace.setActiveLeaf(leaf, { focus: true })
|
|
alreadyOpenAndPinned = true
|
|
}
|
|
}
|
|
})
|
|
|
|
if (!alreadyOpenAndPinned) {
|
|
// Open the note normally
|
|
await app.workspace.openLinkText(item.path, '', newPane)
|
|
}
|
|
|
|
const view = app.workspace.getActiveViewOfType(MarkdownView)
|
|
if (!view) {
|
|
// Not an editable document, so no cursor to place
|
|
// throw new Error('OmniSearch - No active MarkdownView')
|
|
return
|
|
}
|
|
const pos = view.editor.offsetToPos(offset)
|
|
pos.ch = 0
|
|
|
|
view.editor.setCursor(pos)
|
|
view.editor.scrollIntoView({
|
|
from: { line: pos.line - 10, ch: 0 },
|
|
to: { line: pos.line + 10, ch: 0 },
|
|
})
|
|
}
|
|
|
|
export async function createNote(name: string, newLeaf = false): Promise<void> {
|
|
try {
|
|
let pathPrefix: string
|
|
switch (app.vault.getConfig('newFileLocation')) {
|
|
case 'current':
|
|
pathPrefix = (app.workspace.getActiveFile()?.parent.path ?? '') + '/'
|
|
break
|
|
case 'folder':
|
|
pathPrefix = app.vault.getConfig('newFileFolderPath') + '/'
|
|
break
|
|
default: // 'root'
|
|
pathPrefix = ''
|
|
break
|
|
}
|
|
await app.workspace.openLinkText(`${pathPrefix}${name}.md`, '', newLeaf)
|
|
} catch (e) {
|
|
;(e as any).message =
|
|
'OmniSearch - Could not create note: ' + (e as any).message
|
|
console.error(e)
|
|
throw e
|
|
}
|
|
}
|
|
|
|
/**
|
|
* For a given file, returns a list of links leading to notes that don't exist
|
|
* @param file
|
|
* @param metadata
|
|
* @returns
|
|
*/
|
|
export function getNonExistingNotes(
|
|
file: TFile,
|
|
metadata: CachedMetadata
|
|
): string[] {
|
|
return (metadata.links ?? [])
|
|
.map(l => {
|
|
const path = removeAnchors(l.link)
|
|
return app.metadataCache.getFirstLinkpathDest(path, file.path)
|
|
? ''
|
|
: l.link
|
|
})
|
|
.filter(l => !!l)
|
|
}
|
|
|
|
/**
|
|
* Removes anchors and headings
|
|
* @param name
|
|
* @returns
|
|
*/
|
|
export function removeAnchors(name: string): string {
|
|
return name.split(/[\^#]+/)[0]
|
|
}
|