block_input 1.2.7 copy "block_input: ^1.2.7" to clipboard
block_input: ^1.2.7 copied to clipboard

Simple character blocked input that usually used for redeem code or validation code input.

example/lib/main.dart

import 'dart:math';

import 'package:block_input/block_input_controller.dart';
import 'package:block_input/block_input_keyboard_type.dart';
import 'package:block_input/block_input_style.dart';
import 'package:block_input/block_keyboard_style.dart';
import 'package:flutter/material.dart';

import 'package:block_input/block_input.dart';

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

class MyApp extends StatefulWidget {
  @override
  _MyAppState createState() => _MyAppState();
}

class _MyAppState extends State<MyApp> {

  BlockInputController blockInputController = BlockInputController(6);

  // ------ MONGOLIAN REGISTER NO CONTROLLER ------
  // for first 2 cyrillic character
  BlockInputController cyrillicInputController = BlockInputController(2);
  // for remaining 8 numeric character
  TextEditingController numberInputController = TextEditingController();

  @override
  void initState() {
    blockInputController.addListener(() {
      print(blockInputController.text);
    });
    super.initState();
  }

  @override
  void dispose() {
    blockInputController.dispose();
    cyrillicInputController.dispose();
    numberInputController.dispose();
    super.dispose();
  }

  @override
  Widget build(BuildContext context) {
    return GestureDetector(
      onTap: () {
        FocusScope.of(context).unfocus();
      },
      child: MaterialApp(
        home: Scaffold(
            appBar: AppBar(
              title: const Text('Block Input Example'),
            ),
            body: SingleChildScrollView(
              child: Column(
                children: [
                  Container(
                    padding: EdgeInsets.all(10),
                    child: BlockInput(
                      controller: blockInputController,
                      keyboardType: BlockInputKeyboardType.number,
                      axisAlignment: MainAxisAlignment.spaceBetween,
                      style: BlockInputStyle(
                          backgroundColor: Colors.black12,
                          border: OutlineInputBorder(
                            borderRadius: BorderRadius.all(Radius.circular(10)),
                            borderSide: BorderSide(color: Colors.deepOrange, width: 1)
                          ),
                          focusedBorder: OutlineInputBorder(
                            borderRadius: BorderRadius.all(Radius.circular(10)),
                            borderSide: BorderSide(color: Colors.blueAccent, width: 2)
                          )
                      ),
                    ),
                  ),
                  Container(
                    padding: EdgeInsets.all(10),
                    child: Row(
                      children: [
                        RaisedButton(
                          child: Text('CLEAR'),
                          onPressed: () {
                            blockInputController.clear();
                          },
                        ),
                        SizedBox(width: 10,),
                        RaisedButton(
                          child: Text('RANDOM FILL'),
                          onPressed: () {
                            Random rand = Random();
                            StringBuffer strBuffer = StringBuffer();
                            for(int i = 0; i < blockInputController.size; i++) {
                              strBuffer.write(rand.nextInt(9).toString());
                            }
                            blockInputController.text = strBuffer.toString();
                          },
                        ),
                        SizedBox(width: 10,),
                        RaisedButton(
                          child: Text('TEST'),
                          onPressed: () {
                            blockInputController.text = 'MARAAAAAAA';
                          },
                        )
                      ],
                    ),
                  ),

                  // ------ MONGOLIAN REGISTER NO DEMO ------
                  Divider(),
                  Container(
                    padding: EdgeInsets.all(10),
                    child: Row(
                      children: [
                        Container(
                          width: 90,
                          child: BlockInput(
                            controller: cyrillicInputController,
                            keyboardType: BlockInputKeyboardType.mnCyrillic,
                            axisAlignment: MainAxisAlignment.spaceBetween,
                            style: BlockInputStyle(
                                keyboardStyle: BlockKeyboardStyle(
                                  keyColor: Colors.blueAccent,
                                  backgroundColor: Colors.white,
                                  width: 40,
                                  height: 40,
                                  textStyle: TextStyle(),
                                  keyShape: RoundedRectangleBorder(
                                      borderRadius: BorderRadius.circular(18.0),
                                      side: BorderSide(color: Colors.red)
                                  ),
                                ),
                                backgroundColor: Colors.white,
                                border: OutlineInputBorder(
                                    borderRadius: BorderRadius.all(Radius.circular(7)),
                                    borderSide: BorderSide(color: Colors.blueGrey, width: 1)
                                ),
                                focusedBorder: OutlineInputBorder(
                                    borderRadius: BorderRadius.all(Radius.circular(7)),
                                    borderSide: BorderSide(color: Colors.blue, width: 3)
                                )
                            ),
                          ),
                        ),
                        SizedBox(width: 10,),
                        Container(
                            child: Expanded(
                              child: TextField(
                                controller: numberInputController,
                                keyboardType: TextInputType.number,
                                decoration: InputDecoration(
                                    contentPadding: EdgeInsets.symmetric(vertical: 0, horizontal: 5),
                                    enabledBorder: OutlineInputBorder(
                                        borderRadius: BorderRadius.all(Radius.circular(7)),
                                        borderSide: BorderSide(color: Colors.blueGrey, width: 1)
                                    ),
                                    focusedBorder: OutlineInputBorder(
                                        borderRadius: BorderRadius.all(Radius.circular(7)),
                                        borderSide: BorderSide(color: Colors.blue, width: 3)
                                    )
                                ),
                              ),
                            )
                        )
                      ],
                    ),
                  ),
                  Container(
                    padding: EdgeInsets.all(10),
                    child: Row(
                      children: [
                        RaisedButton(
                          child: Text('GET REGISTER'),
                          onPressed: () {
                            print(cyrillicInputController.text + numberInputController.text);
                          },
                        ),
                      ],
                    ),
                  ),
                ],
              ),
            )
        ),
      ),
    );
  }


}
4
likes
80
pub points
51%
popularity

Publisher

verified publisherwiser.studio

Simple character blocked input that usually used for redeem code or validation code input.

Repository (GitHub)
View/report issues

Documentation

API reference

License

Apache-2.0 (license)

Dependencies

flutter, flutter_custom_dialog

More

Packages that depend on block_input