spinner_input 0.1.2 copy "spinner_input: ^0.1.2" to clipboard
spinner_input: ^0.1.2 copied to clipboard

A Spinner Input for flutter. like html5 input-spinners with handy options

example/example.dart

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

void main() => runApp(MySpinner());

class MySpinner extends StatefulWidget {
  @override
  _MySpinnerState createState() => _MySpinnerState();
}

class _MySpinnerState extends State<MySpinner> {
  double spinner = 0;
  double spinner3 = -5;
  double spinner4 = 20;
  double spinner5 = 82.654;
  double spinner6 = 5;

  @override
  Widget build(BuildContext context) {
    return MaterialApp(
        home: Scaffold(
          appBar: AppBar(),
          body: Column(
            children: <Widget>[


              // default spinner
              Container(
                margin: EdgeInsets.all(20),
                child: SpinnerInput(
                  spinnerValue: spinner,
//                  minValue: 0,
//                  maxValue: 200,
                  onChange: (newValue) {
                    setState(() {
                      spinner = newValue;
                    });
                  },
                ),
              ),



              // Set step ( can be int or double )
              Container(
                margin: EdgeInsets.all(20),
                child: SpinnerInput(
                  minValue: 0,
                  maxValue: 200,
                  step: 5,
                  plusButton: SpinnerButtonStyle(elevation: 0, color: Colors.blue, borderRadius: BorderRadius.circular(0)),
                  minusButton: SpinnerButtonStyle(elevation: 0, color: Colors.red, borderRadius: BorderRadius.circular(0)),
                  middleNumberWidth: 70,
                  middleNumberStyle: TextStyle(fontSize: 21),
                  middleNumberBackground: Colors.yellowAccent.withOpacity(0.5),
                  spinnerValue: spinner3,
                  onChange: (newValue) {
                    setState(() {
                      spinner3 = newValue;
                    });
                  },
                ),
              ),




              // Disable long press and input-popup
              Container(
                margin: EdgeInsets.all(20),
                child: SpinnerInput(
                  minValue: 0,
                  maxValue: 200,
                  disabledLongPress: true,
                  disabledPopup: true,
                  step: 5,
                  spinnerValue: spinner4,
                  onChange: (newValue) {
                    setState(() {
                      spinner4 = newValue;
                    });
                  },
                ),
              ),


              // A little more customized buttons
              Container(
                margin: EdgeInsets.all(20),
                child: SpinnerInput(
                  minValue: 0,
                  maxValue: 200,
                  step: 5.524,
                  fractionDigits: 3,
                  plusButton: SpinnerButtonStyle(
                      color: Colors.green,
                      height: 60,
                      width: 60,
                      elevation: 1,
                      highlightElevation: 10,
                      child: Icon(Icons.thumb_up)
                  ),
                  minusButton: SpinnerButtonStyle(
                    color: Colors.red,
                    borderRadius: BorderRadius.circular(0),
                  ),
                  spinnerValue: spinner5,
                  onChange: (newValue) {
                    setState(() {
                      spinner5 = newValue;
                    });
                  },
                ),
              ),



              // RTL support
              Container(
                margin: EdgeInsets.all(50),
                child: SpinnerInput(
                  direction: TextDirection.rtl,
                  spinnerValue: spinner6,
                  onChange: (newValue) {
                    setState(() {
                      spinner6 = newValue;
                    });
                  },
                ),
              )




            ],
          ),
        ));
  }
}
21
likes
30
pub points
62%
popularity

Publisher

verified publisherflutterdev.site

A Spinner Input for flutter. like html5 input-spinners with handy options

Repository (GitHub)
View/report issues

License

unknown (license)

Dependencies

flutter

More

Packages that depend on spinner_input