# Protevus Jael ![Pub Version (including pre-releases)](https://img.shields.io/pub/v/angel3_jael?include_prereleases) [![Null Safety](https://img.shields.io/badge/null-safety-brightgreen)](https://dart.dev/null-safety) [![Discord](https://img.shields.io/discord/1060322353214660698)](https://discord.gg/3X6bxTUdCM) [![License](https://img.shields.io/github/license/dart-backend/protevus)](https://github.com/dart-backend/protevus/tree/master/packages/jael/angel_jael/LICENSE) [Protevus 3](https://pub.dev/packages/angel3_framework) support for [Jael 3](https://pub.dev/packages/jael3). ## Installation In your `pubspec.yaml`: ```yaml dependencies: angel3_jael: ^8.0.0 ``` ## Usage Just like `mustache` and other renderers, configuring Protevus to use Jael is as simple as calling `app.configure`: ```dart import 'package:angel3_framework/angel3_framework.dart'; import 'package:angel3_jael/angel3_jael.dart'; import 'package:file/file.dart'; AngelConfigurer myPlugin(FileSystem fileSystem) { return (Protevus app) async { // Connect Jael to your server... await app.configure( jael(fileSystem.directory('views')), ); }; } ``` `package:angel3_jael` supports caching views and minified html output by default, to improve performance. You might want to disable them in development, so consider setting these flags to `false`: ```dart jael(viewsDirectory, cacheViews: false, minified: false); ``` Keep in mind that this package uses `package:file`, rather than `dart:io`. The following is a basic example of a server setup that can render Jael templates from a directory named `views`: ```dart import 'package:angel3_framework/angel3_framework.dart'; import 'package:angel3_jael/angel3_jael.dart'; import 'package:file/local.dart'; import 'package:logging/logging.dart'; void main() async { var app = Protevus(); var fileSystem = const LocalFileSystem(); await app.configure( jael(fileSystem.directory('views')), ); // Render the contents of views/index.jael app.get('/', (res) => res.render('index', {'title': 'ESKETTIT'})); app.use(() => throw AngelHttpException.notFound()); app.logger = Logger('protevus') ..onRecord.listen((rec) { print(rec); if (rec.error != null) print(rec.error); if (rec.stackTrace != null) print(rec.stackTrace); }); var server = await app.startServer(null, 3000); print('Listening at http://${server.address.address}:${server.port}'); } ``` To apply additional transforms to parsed documents, provide a set of `patch` functions, like in `package:jael3_preprocessor`. ## Performance Optimization For handling large volume of initial requests, consider using `jaelTemplatePreload` to preload all the JAEL templates into an external cache. ```dart var templateDir = fileSystem.directory('views'); // Preload JAEL view templates into cache var viewCache = {}; jaelTemplatePreload(templateDir, viewCache); // Inject cache into JAEL renderer await app.configure( jael(fileSystem.directory('views'), cache: viewCache), ); ```