keymap 0.0.92 copy "keymap: ^0.0.92" to clipboard
keymap: ^0.0.92 copied to clipboard

A reusable keyboard shortcuts widget with a flexible, minimal UI and focus handling.

example/lib/main.dart

import 'package:flutter/material.dart';
import 'package:flutter/services.dart';

import 'package:keymap/keymap.dart';

void main() => runApp(const MyApp());

///An example showing using the keyboard widget with children containing
///focus-aware widgets, like TextFields
class MyApp extends StatelessWidget {
  const MyApp({Key? key}) : super(key: key);

  static const String _title = 'keymap shortcut example';

  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: _title,
      home: Scaffold(
        appBar: AppBar(title: const Text(_title),),
        body: const Center(
          child: Padding(
            padding: EdgeInsets.all(30.0),
            child: MyStatefulWidget(),
          ),
        ),
      ),
    );
  }
}

class MyStatefulWidget extends StatefulWidget {
  const MyStatefulWidget({Key? key}) : super(key: key);

  @override
  _MyStatefulWidgetState createState() => _MyStatefulWidgetState();
}

class _MyStatefulWidgetState extends State<MyStatefulWidget> {

  int count = 0;

  @override
  Widget build(BuildContext context) {
    return KeyboardWidget(
      columnCount: 2,
      bindings: [
        KeyAction(LogicalKeyboardKey.keyU,'increment the counter', () {
            setState(() {
              count++;
          });},),
        KeyAction(LogicalKeyboardKey.keyD, 'decrement the counter', () {
          setState(() {
            count--;
          });
        },),
      ],
      child: Column(
        children: [
          const Text('u for adding, down d to subtract'),
          Text('count: $count'),
          const TextField(
            maxLength: 20, maxLines: 1,
            decoration: InputDecoration(labelText: 'Try typing u and d'),),
          ElevatedButton(onPressed: (){}, child: const Text('Other Focus')),
        ],
      ),
    );
  }
}
29
likes
140
pub points
82%
popularity

Publisher

verified publishermutisya.dev

A reusable keyboard shortcuts widget with a flexible, minimal UI and focus handling.

Repository (GitHub)
View/report issues

Documentation

API reference

License

MIT (license)

Dependencies

flutter, flutter_markdown

More

Packages that depend on keymap