ember-cli-remark-static
v3.0.6
Published
Markdown for Ember.js with component support
Downloads
18
Maintainers
Readme
ember-cli-remark-static
Install
$ ember install ember-cli-remark-static
Configure collections
// ember-cli-build.js
let app = new EmberAddon(defaults, {
remark: {
collections: {
// identifier: directory
'content': 'markdown/content',
// or
'content': {
path: 'markdown/content',
toc: true // default
}
}
}
});
Subclass files service for each collection
// app/services/content.js
import FilesService from 'remark/services/files';
export default class Content extends FilesService {
identifier = 'content';
}
Load files index
import Route from '@ember/routing/route';
import { inject as service } from "@ember/service";
export default class ApplicationRoute extends Route {
@service content;
async beforeModel() {
await this.content.load();
}
}
Load file
let file = this.content.file('hello.md');
await file.load();
Preprocess markdown
import { setOwner } from '@ember/application';
import { reads } from "macro-decorators";
import { remark } from 'remark/decorators';
export default class Page {
constructor(owner, { file }) {
setOwner(this, owner);
this.file = file;
}
@reads('file.body') body;
@remark('body')
tree(node) {
if(node.tagName === 'h1') {
node.children[0].value = 'Hey there';
}
return node;
}
async load() {
await this.file.load();
await this.tree.load(); // eager.
return this;
}
}
Render
<Remark class="content" @tree={{@page.tree}}/>