custom_numpad 0.0.1 copy "custom_numpad: ^0.0.1" to clipboard
custom_numpad: ^0.0.1 copied to clipboard

outdated

Provide customizable numpad widget.

example/lib/main.dart

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

void main() {
  runApp(const MyApp());
}

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

  @override
  State<MyApp> createState() => _MyAppState();
}

class _MyAppState extends State<MyApp> {
  bool _show = false;

  List<int> numbers = [];

  static const _maxLength = 6;

  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      home: NumpadContainer(
        show: _show,
        duration: const Duration(milliseconds: 300),
        onNumInput: (number) {
          if (numbers.length < _maxLength) {
            setState(() {
              numbers.add(number);

              if (numbers.length == _maxLength) {
                _show = false;
              }
            });
          }
        },
        onDelete: () {
          if (numbers.isNotEmpty) {
            setState(() {
              numbers.removeLast();
            });
          }
        },
        child: GestureDetector(
          onTap: () => setState(() {
            _show = false;
          }),
          child: Scaffold(
            appBar: AppBar(
              title: const Text('Custom Numpad Example'),
            ),
            body: Column(
              children: [
                GestureDetector(
                  behavior: HitTestBehavior.opaque,
                  onTap: () {
                    setState(() {
                      _show = !_show;
                    });
                  },
                  child: Padding(
                    padding: const EdgeInsets.symmetric(horizontal: 12),
                    child: SizedBox(
                      height: 100,
                      child: Row(
                        children: List.generate(
                          _maxLength,
                          (index) {
                            final number = numbers.isEmpty
                                ? null
                                : index < numbers.length
                                    ? numbers[index]
                                    : null;

                            return Expanded(
                              child: Padding(
                                padding: const EdgeInsets.all(8.0),
                                child: Container(
                                  decoration: BoxDecoration(
                                      borderRadius: BorderRadius.circular(12),
                                      border: Border.all(
                                        color: Colors.black,
                                      )),
                                  child: Center(
                                    child: Text(
                                      number == null ? '-' : number.toString(),
                                      style: const TextStyle(
                                        color: Colors.black,
                                        fontWeight: FontWeight.bold,
                                        fontSize: 30,
                                      ),
                                    ),
                                  ),
                                ),
                              ),
                            );
                          },
                        ).toList(growable: false),
                      ),
                    ),
                  ),
                ),
                Expanded(
                  child: ListView.builder(
                    itemCount: 100,
                    itemBuilder: ((context, index) {
                      return ListTile(
                        title: Text('Item $index'),
                      );
                    }),
                  ),
                ),
              ],
            ),
            floatingActionButton: FloatingActionButton(
              child: _show
                  ? const Icon(Icons.toggle_off)
                  : const Icon(Icons.toggle_on),
              onPressed: () {
                setState(() {
                  _show = !_show;
                });
              },
            ),
          ),
        ),
      ),
    );
  }
}
0
likes
0
points
0
downloads

Publisher

verified publisherblacklemon.dev

Weekly Downloads

Provide customizable numpad widget.

Repository (GitHub)
View/report issues

License

unknown (license)

Dependencies

flutter, freezed_annotation, provider

More

Packages that depend on custom_numpad