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

  • if the page failes in the middle of browsing, provide a back button to go back to the previous file
  • expose more customization permitted by markdown_widget to the application.
  • Testing more markdown content

Known issues

  • Unable to navigate to the specific section in the same markdown file or another if the link is pointing to a section. This doesn't seems to be supported by markdown_widget package

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.

Libraries

markdown_browser