platform/packages/jael/jael2
2021-05-15 17:38:15 +08:00
..
bin Migrated jael to jael2 2021-05-15 17:38:15 +08:00
example Migrated jael to jael2 2021-05-15 17:38:15 +08:00
lib Migrated jael to jael2 2021-05-15 17:38:15 +08:00
test Migrated jael to jael2 2021-05-15 17:38:15 +08:00
.gitignore Migrated jael to jael2 2021-05-15 17:38:15 +08:00
analysis_options.yaml Migrated jael to jael2 2021-05-15 17:38:15 +08:00
AUTHORS.md Migrated jael to jael2 2021-05-15 17:38:15 +08:00
CHANGELOG.md Migrated jael to jael2 2021-05-15 17:38:15 +08:00
LICENSE Migrated jael to jael2 2021-05-15 17:38:15 +08:00
mono_pkg.yaml Migrated jael to jael2 2021-05-15 17:38:15 +08:00
pubspec.yaml Migrated jael to jael2 2021-05-15 17:38:15 +08:00
README.md Migrated jael to jael2 2021-05-15 17:38:15 +08:00

angel3_jael_engine

version Null Safety Gitter

License

A simple server-side HTML templating engine for Dart.

See documentation.

Installation

In your pubspec.yaml:

dependencies:
  jael3: ^4.0.0

API

The core jael package exports classes for parsing Jael templates, an AST library, and a Renderer class that generates HTML on-the-fly.

import 'package:angel3_code_buffer/code_buffer.dart';
import 'package:jael3/jael.dart' as jael;
import 'package:angel3_symbol_table/symbol_table.dart';

void myFunction() {
    const template = '''
<html>
  <body>
    <h1>Hello</h1>
    <img src=profile['avatar']>
  </body>
</html>
''';

    var buf = CodeBuffer();
    var document = jael.parseDocument(template, sourceUrl: 'test.jael', asDSX: false);
    var scope = SymbolTable(values: {
      'profile': {
        'avatar': 'thosakwe.png',
      }
    });

    const jael.Renderer().render(document, buf, scope);
    print(buf);
}

Pre-processing (i.e. handling of blocks and includes) is handled by package:jael_preprocessor..