Skip to content

Commit

Permalink
Merge pull request #15 from wanagel/master
Browse files Browse the repository at this point in the history
Modified to work with Live Preview
  • Loading branch information
TilBlechschmidt authored Jan 11, 2022
2 parents c417778 + aa1496e commit 2b1e040
Showing 1 changed file with 6 additions and 26 deletions.
32 changes: 6 additions & 26 deletions main.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,37 +2,17 @@ import { App, MarkdownPostProcessor, MarkdownPostProcessorContext, MarkdownPrevi
import { signature, renderAbc } from 'abcjs';

export default class MusicPlugin extends Plugin {
static postprocessor: MarkdownPostProcessor = (el: HTMLElement, ctx: MarkdownPostProcessorContext) => {
// Assumption: One <pre> section always contains only the code block

const blocksToReplace = el.querySelectorAll('pre')
if (blocksToReplace.length < 1) return

// Generally, blocksToReplace will be length 1 (called for every single block of code/text)
// On print to PDF, the entire document is passed to this function at once
// This for loop handles both cases - regular render and print-to-PDF
for (var i = 0; i < blocksToReplace.length; i++) {
const musicBlock = blocksToReplace[i].querySelector('code.language-music-abc')
if (!musicBlock) continue

const source = musicBlock.textContent
const destination = document.createElement('div')
renderAbc(destination, source, {
add_classes: true,
responsive: 'resize'
})

el.replaceChild(destination, blocksToReplace[i])
}
}

onload() {
console.log('loading abcjs plugin');
MarkdownPreviewRenderer.registerPostProcessor(MusicPlugin.postprocessor)
this.registerMarkdownCodeBlockProcessor('music-abc', async (source: string, el: HTMLElement, ctx) => {
renderAbc(el, source, {
add_classes: true,
responsive: 'resize'
});
});
}

onunload() {
console.log('unloading abcjs plugin');
MarkdownPreviewRenderer.unregisterPostProcessor(MusicPlugin.postprocessor)
}
}

0 comments on commit 2b1e040

Please sign in to comment.