# Angel3 Markdown data:image/s3,"s3://crabby-images/3188b/3188b08ff33ba41860d79a6a2f3e962e5d18aa5b" alt="Pub Version (including pre-releases)" [data:image/s3,"s3://crabby-images/cc24c/cc24c9992b9bd4bb544755ee64116ad60cc9823c" alt="Null Safety"](https://dart.dev/null-safety) [data:image/s3,"s3://crabby-images/3b53f/3b53ff9b845bb2370ce88461a55b4ceca5bb315e" alt="Gitter"](https://gitter.im/angel_dart/discussion) [data:image/s3,"s3://crabby-images/afdad/afdad11ca656c436ec43a0b7f5dcb0957b3b7d96" alt="License"](https://github.com/dukefirehawk/angel/tree/master/packages/markdown/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`: ```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`: ```dart 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: ```dart 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`: ```markdown # Species: {{species.name}} The species *{{species.genus.name}} {{species.name}}* is fascinating... ``` You can render as follows: ```dart 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: ```dart configureServer(Angel app) async { await app.configure( markdown( // The directory where your views are located. fs.directory('views'), template: (content, Map locals) { return '''