Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/willviles/ember-cli-markdown-resolver
Ember CLI addon for resolving markdown files and trees of md files.
https://github.com/willviles/ember-cli-markdown-resolver
ember ember-addon ember-cli ember-cli-addon frontmatter markdown resolver
Last synced: 4 months ago
JSON representation
Ember CLI addon for resolving markdown files and trees of md files.
- Host: GitHub
- URL: https://github.com/willviles/ember-cli-markdown-resolver
- Owner: willviles
- License: mit
- Created: 2017-09-12T20:06:30.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2018-07-21T10:26:48.000Z (over 6 years ago)
- Last Synced: 2024-10-03T13:06:13.238Z (4 months ago)
- Topics: ember, ember-addon, ember-cli, ember-cli-addon, frontmatter, markdown, resolver
- Language: JavaScript
- Homepage: https://willviles.github.io/ember-cli-markdown-resolver
- Size: 519 KB
- Stars: 26
- Watchers: 3
- Forks: 7
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
- awesome-ember - ember-cli-markdown-resolver - Ember CLI addon for resolving markdown files in custom folders and retrieving content via a service. (Packages / Adapters)
README
Ember CLI Markdown Resolver
======
[![Build Status](https://travis-ci.org/willviles/ember-cli-markdown-resolver.svg)](https://travis-ci.org/willviles/ember-cli-markdown-resolver) [![Ember Observer Score](http://emberobserver.com/badges/ember-cli-markdown-resolver.svg)](http://emberobserver.com/addons/ember-cli-markdown-resolver) [![Download count all time](https://img.shields.io/npm/dt/ember-cli-markdown-resolver.svg)]((https://www.npmjs.com/package/ember-cli-markdown-resolver)) [![npm](https://img.shields.io/npm/v/ember-cli-markdown-resolver.svg)](https://www.npmjs.com/package/ember-cli-markdown-resolver)Ember CLI Markdown Resolver is the quickest way to include static markdown content in your Ember.js application using [Broccoli Markdown Resolver](https://github.com/willviles/broccoli-markdown-resolver).
## Installation
```
ember install ember-cli-markdown-resolver
```## Configuration
The addon requires you specify the locations of markdown files:
```js
// config/environment.jsENV['ember-cli-markdown-resolver'] = {
folders: {
'guides': 'app/guides'
}
};
```And to populate your folder with markdown content:
```shell
.
└── app/
└── guides/
├── quick-start.md
├── examples.md
└── examples/
└── first.md
```## Usage
Ember CLI Markdown Resolver enables markdown content to be retrieved via the `markdownResolver` service.
### `this.get('markdownResolver').file(type, path)`
The `file` method returns promisified markdown content, allowing the content to be chainable via `.then()`.
```js
// routes/guides/single.jsimport Route from '@ember/routing/route';
import { get } from '@ember/object';
import { inject } from '@ember/service';export default Route.extend({
markdownResolver: inject(),model({ path }) {
return get(this, 'markdownResolver').file('guides', path);
}
});
```Each markdown file exposes the path, raw content, frontmatter attributes and its children.
```hbs
{{model.content}}
{{model.path}}
{{model.attributes}}
{{model.children}}
```### `this.get('markdownResolver').tree(type)`
The `tree` method returns a tree object for a given folder, allowing menu interfaces to be built from the markdown file structure.
```js
// routes/guides.jsimport Route from '@ember/routing/route';
import { get } from '@ember/object';
import { inject } from '@ember/service';export default Route.extend({
markdownResolver: inject(),model() {
return get(this, 'markdownResolver').tree('guides');
}
});
```Adding an `order` value to a file's frontmatter will automatically order files within the tree.
```md
---
title: Quick Start
order: 0
---Lorem ipsum dolor sit amet...
```Additionally, adding a `fragmentIdLinks` object to a file's frontmatter will generate a list local fragment identifier links which are used within the `{{markdown-menu-item}}` component. This is handy when you want to link to several individual sections of a large parent markdown file instead of having individual child markdown files.
The `fragmentIdLinks` object expects child key-value pairs where each `key` represents the hash fragment id link and each `value` represents the text label to be shown as a child on the `{{markdown-menu}}` component.
```md
---
title: Fragment Identifier Links
order: 4
fragmentIdLinks:
iamsectionone: "Section One"
section-two: "Section Two"
---### I am section one
Lorem ipsum dolor sit amet...Lorem ipsum dolor sit amet...
```By default, when you click on each `fragmentIdLinks` child link within the `{{markdown-menu-item}}` component it will update the url hash. You can easily override this default behavior by passing an `onClick` closure action into the `{{markdown-menu}}` component.
```hbs
{{!-- templates/guides.hbs --}}
{{markdown-menu onClick=(action "clickedMenuItemLink")}}
``````js
// controllers/guides.js
import Controller from '@ember/controller';export default Controller.extend({
actions: {
clickedMenuItemLink(fragmentIdLink) {
document.querySelector(`#${fragmentIdLink}`).scrollIntoView({
behavior: 'smooth'
});
}
}
});
```The addon ships with a `markdown-menu` component which builds a nested list from your file tree and can be styled using your own css.
```hbs
{{markdown-menu
title="My Markdown Menu"
tree=model}}
{{outlet}}
```## Helpers
Ember CLI Markdown Resolver defines the following template helpers:
```hbs
{{get (get-markdown-file 'guides' 'nested/page-slug') 'title'}}
{{my-render-component content=(get-markdown-content 'guides' 'nested/page-slug')}}
{{markdown-menu tree=(get-markdown-tree 'guides')}}
```## Demo
Check out the [Ember CLI Markdown Resolver guides](https://willviles.github.io/ember-cli-markdown-resolver), which is generated using the addon.
Code for the guides can be found [here](https://github.com/willviles/ember-cli-markdown-resolver/tree/master/tests/dummy).
## Node Version
Ember CLI Markdown Resolver currently supports Node >=6.
## Contributing
### Installation
* `git clone https://github.com/willviles/ember-cli-markdown-resolver.git`
* `cd ember-cli-markdown-resolver`
* `yarn install`### Running
* `ember serve`
* Visit your app at [http://localhost:4200](http://localhost:4200).### Running Tests
* `yarn test` (Runs `ember try:each` to test your addon against multiple Ember versions)
* `ember test`
* `ember test --server`### Building
* `ember build`
For more information on using ember-cli, visit [https://ember-cli.com/](https://ember-cli.com/).