Markdown Browser
A package to simplify browsing markdown files.
This package is useful in situations where the application is required to provide a set of markdown files as help content or a user manual and requires a browser widget to display it inside a Flutter application.
The markdown files can be placed either in the assets folder or served from an external server.
Screenshots
Features
- Browse across the markdown files within the same folder / served under the same base URL.
- Opens other links in a webview.
- Supports Header browsing and history.
- Supports Latex equations (Use $..$ and $$..$$).
- Basic navigation menu, which disappears when reading the document.
- is provided as a widget; hence, it can be embedded into any other widget. It is not necessary to be a standalone page.
For rendering markdown files, the markdown_widget package is used. Refer to the demo to understand the supported features and limitations.
Getting started
Add the package to your pubspec.yaml
file
flutter pub add markdown_browser
Add riverpod
This package uses Riverpod to manage state.
flutter pub add flutter_riverpod
As required by riverpod, wrap the entire application in a "ProviderScope" widget.
void main() {
runApp(
ProviderScope(
child: MyApp(),
),
);
}
Invoke widget
import 'package:markdown_browser/markdown_browser.dart';
Use the Widget
MarkdownBrowser(
urlBase: "http://127.0.0.1:5000",
onExitCB: () {
// Your logic to remove the Markdown browser
}),
landingPage: "my_indexPage.md", // defaults to index.md
onGetMarkDownCB: (String path) async {
final String content = // your logic to download/load the file
return content
} // defaults to internal http based logic
Usage
Refer the provided example, to understand how to use this package for both offline content and online content.
Offline
Store the folder containing under assets and add it into <Application>/pubspec.yaml
. Do not forget to add the subfolders inside the content.
flutter:
assets:
- assets/user_manual_1/
- assets/user_manual_1/topic/
Invoke the widget with urlBase set to assets/user_manual_1
.
Online
Ensure the link <urlBase>/<landingPage>
is valid.
To test this package for online feature, a test server is provided under example/server folder. Ensure you have python3, python3-pip and python3-venv are installed and run the provided script.
On a linux box, this can be done as below
sudo apt install python3 python3-pip python3-venv -y
cd example/server
bash start_server.sh
This will start the Flask server and serve on both the local and network addresses.
....
* Serving Flask app 'server.py'
* Debug mode: off
WARNING: This is a development server. Do not use it in a production deployment. Use a production WSGI server instead.
* Running on all addresses (0.0.0.0)
* Running on http://127.0.0.1:5000
* Running on http://x.x.x.x:5000
If you are testing the application on the same machine, the online variant should work without any changes using http://127.0.0.1:5000
.
If you are testing on a mobile device or another machine, ensure that the server is serving on the network by modifying the BaseURL to http://x.x.x.x:5000
before running the Flutter app.
Additional information
Planned enhancements
Known issues
Support
If you face any issues or have any enhancement suggestions, create an issue on GitHub or contact me at cloudonlanapps (at) gmail (dot) com.
You may also send your pull request if you want to contribute.