platform/packages/markdown
2022-03-19 09:37:28 +08:00
..
example Published markdown 2021-06-21 14:33:18 +08:00
lib Migrated markdown 2021-06-21 23:04:36 +08:00
.gitignore Add 'packages/markdown/' from commit 'deccd615054c1d5a84071a52d4fe55c50f0f771f' 2020-02-15 18:28:38 -05:00
.travis.yml Add 'packages/markdown/' from commit 'deccd615054c1d5a84071a52d4fe55c50f0f771f' 2020-02-15 18:28:38 -05:00
analysis_options.yaml Updated linter 2022-01-04 20:03:52 +08:00
AUTHORS.md Merged from sdk-2.12.x_nnbd 2021-06-20 20:37:20 +08:00
CHANGELOG.md Updated linter 2022-01-04 20:03:52 +08:00
LICENSE Updated linter 2022-01-04 20:03:52 +08:00
melos_angel3_markdown.iml Added melos 2022-03-19 09:37:28 +08:00
pubspec.yaml Updated linter 2022-01-04 20:03:52 +08:00
README.md Updated linter 2022-01-04 20:03:52 +08:00

Angel3 Markdown

Pub Version (including pre-releases) Null Safety Gitter License

Markdown view generator for Angel3.

With this plug-in, you can easily serve static sites without doing more than writing simple Markdown. Thus, it is a friendly choice for writing API documentation or other tedious HTML-writing tasks.

Installation

In your pubspec.yaml:

dependencies:
  angel3_framework: ^4.2.0
  angel3_markdown: ^3.0.0

Usage

It's very straightforward to configure an Angel server to use Markdown. Keep in mind to use package:file instead of dart:io:

configureServer(Angel app) async {
  var fs = LocalFileSystem();
  await app.configure(markdown(
    // The directory where your views are located.
    fs.directory('views'),
  ));
}

You can then generate HTML on-the-fly in a request handler. Assuming your view directory contained a file named hello.md, the following would render it as an HTML response:

configureServer(Angel app) async {
  app.get('/hello', (res) => res.render('hello'));
}

package:angel3_markdown by default searches for files with a .md extension; however, you can easily override this.

Interpolation

angel3_markdown can interpolate the values of data from locals before building the Markdown.

For example, with the following template species.md:

# Species: {{species.name}}
The species *{{species.genus.name}} {{species.name}}* is fascinating...

You can render as follows:

requestHandler(ResponseContext res) {
  return res.render('species', {
    'species': new Species('sapiens', genius: 'homo')
  });
}

To disable interpolation for a single bracket, prefix it with an @, ex: @{{raw | not_interpolated | angular}}.

Templates

Markdown is frequently used to build the content of sites, but not the templates. You might want to wrap the content of pages in a custom template to apply pretty CSS and JS, etc:

configureServer(Angel app) async {
  await app.configure(
    markdown(
        // The directory where your views are located.
        fs.directory('views'), template: (content, Map locals) {
      return '''<!DOCTYPE html>
<html>
    <head>
        <title>${locals['title']} - My Site</title>
    </head>
    <body>
      $content
    </body>
</html>
        ''';
    }),
  );
}

The template function will have access to whatever values were passed to the renderer, or an empty Map.

Enhancing Markdown

You can pass an extensionSet to add additional features to the Markdown renderer. By default, this plug-in configures it to enable Github-flavored Markdown.