contextmenu 2.0.1
contextmenu: ^2.0.1 copied to clipboard

Display a beautifully animated, material context menu using pure Flutter

contextmenu #

Gitlab pipeline status Pub Version

Display a beautiful material context menu using pure Flutter.

It works both on touch devices and on desktop devices.

See a demo here!

Demo Screen Recording

Features #

  • modern, emphasizing animation according to material design guidelines
  • handles screen edges and oversize
  • very efficient code (< 250 lines)

Getting Started #

You can easily display a context menu using the following code:

Widget build() {
  return ContextMenuArea(
    items: [
      ListTile(
        title: Text('Option 1'),
        onTap: () {
          Navigator.of(context).pop();
          ScaffoldMessenger.of(context)
              .showSnackBar(SnackBar(content: Text('Whatever')));
        },
      )
    ],
    child: Card(
      color: Theme
          .of(context)
          .primaryColor,
      child: Center(
        child: Text('Press somewhere for context menu.'),
      ),
    ),
  );
}

A more complicated way manually triggering a context menu using showContextMenu() is:

Widget build() {
  return GestureDetector(
      onSecondaryTapDown: (details) =>
          showContextMenu(
              details.globalPosition, context, items, verticalPadding, width),
      child: Text('Tap!'));
}

Setup web #

For the web, edit your index.html and add the following in the <body> tag:


<body oncontextmenu="return false;">

License #

This project is EUPL licensed. For further details, consult LICENSE.

11
likes
130
pub points
72%
popularity

Publisher

with-the-braid.cf

Display a beautifully animated, material context menu using pure Flutter

Homepage
Repository (GitLab)
View/report issues

Documentation

API reference

License

EUPL-1.2 (LICENSE)

Dependencies

after_layout, animations, flutter

More

Packages that depend on contextmenu